From e03d6779b782cffb61f698ecba914fa6470855a4 Mon Sep 17 00:00:00 2001 From: risadmin_prod Date: Mon, 7 Apr 2025 12:46:37 +0000 Subject: [PATCH] build_app --- .../Builders/Services/BuilderService.java | 3 + .../Visa_applicationController.java | 203 ++++ .../vpspack/Entity/Visa_application.java | 84 ++ .../Visa_applicationRepository.java | 56 + .../Services/Visa_applicationService.java | 223 ++++ .../authsec_mysql/mysql/wf_table/wf_table.sql | 2 + .../login/login-page/login_environment.ts | 18 +- .../Visa_application.component.html | 991 ++++++++++++++++++ .../Visa_application.component.scss | 78 ++ .../Visa_application.component.ts | 595 +++++++++++ .../Visa_application.service.ts | 65 ++ .../Visa_application_cardvariable.ts | 4 + .../app/modules/main/main-routing.module.ts | 4 + .../src/app/modules/main/main.module.ts | 4 + .../src/assets/i18n/en.json | 151 +-- 15 files changed, 2407 insertions(+), 74 deletions(-) create mode 100644 testvisa002-back-b/authsec_springboot/backend/src/main/java/com/realnet/vpspack/Controllers/Visa_applicationController.java create mode 100644 testvisa002-back-b/authsec_springboot/backend/src/main/java/com/realnet/vpspack/Entity/Visa_application.java create mode 100644 testvisa002-back-b/authsec_springboot/backend/src/main/java/com/realnet/vpspack/Repository/Visa_applicationRepository.java create mode 100644 testvisa002-back-b/authsec_springboot/backend/src/main/java/com/realnet/vpspack/Services/Visa_applicationService.java create mode 100755 testvisa002-db-d/authsec_mysql/mysql/wf_table/wf_table.sql create mode 100644 testvisa002-front-f/authsec_angular/frontend/angular-clarity-master/src/app/modules/main/BuilderComponents/vpspack/Visa_application/Visa_application.component.html create mode 100644 testvisa002-front-f/authsec_angular/frontend/angular-clarity-master/src/app/modules/main/BuilderComponents/vpspack/Visa_application/Visa_application.component.scss create mode 100644 testvisa002-front-f/authsec_angular/frontend/angular-clarity-master/src/app/modules/main/BuilderComponents/vpspack/Visa_application/Visa_application.component.ts create mode 100644 testvisa002-front-f/authsec_angular/frontend/angular-clarity-master/src/app/modules/main/BuilderComponents/vpspack/Visa_application/Visa_application.service.ts create mode 100644 testvisa002-front-f/authsec_angular/frontend/angular-clarity-master/src/app/modules/main/BuilderComponents/vpspack/Visa_application/Visa_application_cardvariable.ts diff --git a/testvisa002-back-b/authsec_springboot/backend/src/main/java/com/realnet/Builders/Services/BuilderService.java b/testvisa002-back-b/authsec_springboot/backend/src/main/java/com/realnet/Builders/Services/BuilderService.java index 11edc5f..a621f13 100644 --- a/testvisa002-back-b/authsec_springboot/backend/src/main/java/com/realnet/Builders/Services/BuilderService.java +++ b/testvisa002-back-b/authsec_springboot/backend/src/main/java/com/realnet/Builders/Services/BuilderService.java @@ -69,6 +69,9 @@ public class BuilderService { executeDump(true); // ADD OTHER SERVICE +addCustomMenu( "Visa_application", "Transcations"); + + System.out.println("dashboard and menu inserted..."); diff --git a/testvisa002-back-b/authsec_springboot/backend/src/main/java/com/realnet/vpspack/Controllers/Visa_applicationController.java b/testvisa002-back-b/authsec_springboot/backend/src/main/java/com/realnet/vpspack/Controllers/Visa_applicationController.java new file mode 100644 index 0000000..8a417a8 --- /dev/null +++ b/testvisa002-back-b/authsec_springboot/backend/src/main/java/com/realnet/vpspack/Controllers/Visa_applicationController.java @@ -0,0 +1,203 @@ +package com.realnet.vpspack.Controllers; +import java.util.List; +import org.springframework.beans.factory.annotation.Autowired; + import org.springframework.web.bind.annotation.*; +import org.springframework.web.multipart.MultipartFile; +import com.fasterxml.jackson.core.JsonProcessingException; +import org.springframework.web.bind.annotation.CrossOrigin; +import com.fasterxml.jackson.databind.JsonMappingException; +import com.realnet.config.EmailService; +import com.realnet.users.entity1.AppUser; +import com.realnet.users.service1.AppUserServiceImpl; +import com.fasterxml.jackson.databind.ObjectMapper; +import org.springframework.data.domain.*; +import com.realnet.fnd.response.EntityResponse; +import org.springframework.http.*; +import org.springframework.beans.factory.annotation.*; +import com.realnet.vpspack.Entity.Visa_application; +import com.realnet.vpspack.Services.Visa_applicationService ; + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +@RequestMapping(value = "/Visa_application") + @CrossOrigin("*") +@RestController +public class Visa_applicationController { + @Autowired + private Visa_applicationService Service; + +@Value("${projectPath}") + private String projectPath; + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + @PostMapping("/Visa_application") + public Visa_application Savedata(@RequestBody Visa_application data) { + Visa_application save = Service.Savedata(data) ; + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + System.out.println("data saved..." + save); + + return save; + } +@PutMapping("/Visa_application/{id}") + public Visa_application update(@RequestBody Visa_application data,@PathVariable Integer id ) { + Visa_application update = Service.update(data,id); + System.out.println("data update..." + update); + return update; + } +// get all with pagination + @GetMapping("/Visa_application/getall/page") + public Page getall(@RequestParam(value = "page", required = false) Integer page, + @RequestParam(value = "size", required = false) Integer size) { + Pageable paging = PageRequest.of(page, size); + Page get = Service.getAllWithPagination(paging); + + return get; + + } + @GetMapping("/Visa_application") + public List getdetails() { + List get = Service.getdetails(); + return get; +} +// get all without authentication + + @GetMapping("/token/Visa_application") + public List getallwioutsec() { + List get = Service.getdetails(); + return get; +} +@GetMapping("/Visa_application/{id}") + public Visa_application getdetailsbyId(@PathVariable Integer id ) { + Visa_application get = Service.getdetailsbyId(id); + return get; + } +@DeleteMapping("/Visa_application/{id}") + public ResponseEntity delete_by_id(@PathVariable Integer id ) { + Service.delete_by_id(id); + return new ResponseEntity<>(new EntityResponse("Deleted"), HttpStatus.OK); + + } + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +} \ No newline at end of file diff --git a/testvisa002-back-b/authsec_springboot/backend/src/main/java/com/realnet/vpspack/Entity/Visa_application.java b/testvisa002-back-b/authsec_springboot/backend/src/main/java/com/realnet/vpspack/Entity/Visa_application.java new file mode 100644 index 0000000..565671c --- /dev/null +++ b/testvisa002-back-b/authsec_springboot/backend/src/main/java/com/realnet/vpspack/Entity/Visa_application.java @@ -0,0 +1,84 @@ +package com.realnet.vpspack.Entity; + import lombok.*; +import com.realnet.WhoColumn.Entity.Extension; + import javax.persistence.*; + import java.time.LocalDateTime; + import java.util.*; + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + @Entity + @Data + public class Visa_application extends Extension { + /** + * + */ + private static final long serialVersionUID = 1L; + + @Id + @GeneratedValue(strategy = GenerationType.IDENTITY) + private Integer id; + +private String visa_entry_type; + +private String visa_duration; + +private String visa_processing; + +private String travel_start_date; + +private String travel_end_date; + +private int passport_number; + +private String passport_issue_date; + +private String passport_expiry_date; + +private String email; + + private String phone_number; + +private String birth_place; + +private String date_of_birth; + + private String gender; + +private String profession; + +private String visa_cost; + +private String referrer; + + +} diff --git a/testvisa002-back-b/authsec_springboot/backend/src/main/java/com/realnet/vpspack/Repository/Visa_applicationRepository.java b/testvisa002-back-b/authsec_springboot/backend/src/main/java/com/realnet/vpspack/Repository/Visa_applicationRepository.java new file mode 100644 index 0000000..c4d7bb5 --- /dev/null +++ b/testvisa002-back-b/authsec_springboot/backend/src/main/java/com/realnet/vpspack/Repository/Visa_applicationRepository.java @@ -0,0 +1,56 @@ +package com.realnet.vpspack.Repository; + + +import org.springframework.data.domain.Page; +import org.springframework.data.domain.Pageable; +import org.springframework.data.jpa.repository.JpaRepository; +import org.springframework.data.jpa.repository.Query; + +import org.springframework.stereotype.Repository; +import java.util.*; + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +import com.realnet.vpspack.Entity.Visa_application; + +@Repository +public interface Visa_applicationRepository extends JpaRepository { + +@Query(value = "select * from visa_application where created_by=?1", nativeQuery = true) + List findAll(Long creayedBy); + +@Query(value = "select * from visa_application where created_by=?1", nativeQuery = true) + Page findAll(Pageable page, Long creayedBy); +} \ No newline at end of file diff --git a/testvisa002-back-b/authsec_springboot/backend/src/main/java/com/realnet/vpspack/Services/Visa_applicationService.java b/testvisa002-back-b/authsec_springboot/backend/src/main/java/com/realnet/vpspack/Services/Visa_applicationService.java new file mode 100644 index 0000000..08ad4b3 --- /dev/null +++ b/testvisa002-back-b/authsec_springboot/backend/src/main/java/com/realnet/vpspack/Services/Visa_applicationService.java @@ -0,0 +1,223 @@ +package com.realnet.vpspack.Services; +import com.realnet.vpspack.Repository.Visa_applicationRepository; +import com.realnet.vpspack.Entity.Visa_application +;import java.util.*; + +import org.springframework.beans.factory.annotation.Autowired; +import com.realnet.SequenceGenerator.Service.SequenceService; +import org.springframework.data.domain.Page; +import com.realnet.realm.Entity.Realm; +import com.realnet.realm.Services.RealmService; +import org.springframework.data.domain.Pageable; +import org.springframework.http.*; +import com.realnet.users.service1.AppUserServiceImpl; +import com.realnet.users.entity1.AppUser; + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + import org.springframework.stereotype.Service; + +@Service + public class Visa_applicationService { +@Autowired +private Visa_applicationRepository Repository; + @Autowired + private AppUserServiceImpl userService; +@Autowired + private RealmService realmService; + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +public Visa_application Savedata(Visa_application data) { + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + data.setUpdatedBy(getUser().getUserId()); + data.setCreatedBy(getUser().getUserId()); + data.setAccountId(getUser().getAccount().getAccount_id()); +Visa_application save = Repository.save(data); + return save; + } + + +// get all with pagination + public Page getAllWithPagination(Pageable page) { + return Repository.findAll(page, getUser().getUserId()); + } +public List getdetails() { + List realm = realmService.findByUserId(getUser().getUserId()); +List all = Repository.findAll(getUser().getUserId()); + + return all ; } + + +public Visa_application getdetailsbyId(Integer id) { + return Repository.findById(id).get(); + } + + + public void delete_by_id(Integer id) { + Repository.deleteById(id); +} + + +public Visa_application update(Visa_application data,Integer id) { + Visa_application old = Repository.findById(id).get(); +old.setVisa_entry_type(data.getVisa_entry_type()); + +old.setVisa_duration(data.getVisa_duration()); + +old.setVisa_processing(data.getVisa_processing()); + +old.setTravel_start_date(data.getTravel_start_date()); + +old.setTravel_end_date(data.getTravel_end_date()); + +old.setPassport_number(data.getPassport_number()); + +old.setPassport_issue_date(data.getPassport_issue_date()); + +old.setPassport_expiry_date(data.getPassport_expiry_date()); + +old.setEmail(data.getEmail()); + +old.setPhone_number(data.getPhone_number()); + +old.setBirth_place(data.getBirth_place()); + +old.setDate_of_birth(data.getDate_of_birth()); + +old.setGender(data.getGender()); + +old.setProfession(data.getProfession()); + +old.setVisa_cost(data.getVisa_cost()); + +old.setReferrer(data.getReferrer()); + +final Visa_application test = Repository.save(old); + data.setUpdatedBy(getUser().getUserId()); + return test;} + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + public AppUser getUser() { + AppUser user = userService.getLoggedInUser(); + return user; + + }} diff --git a/testvisa002-db-d/authsec_mysql/mysql/wf_table/wf_table.sql b/testvisa002-db-d/authsec_mysql/mysql/wf_table/wf_table.sql new file mode 100755 index 0000000..86f607e --- /dev/null +++ b/testvisa002-db-d/authsec_mysql/mysql/wf_table/wf_table.sql @@ -0,0 +1,2 @@ +CREATE TABLE db.Visa_application(id BIGINT NOT NULL AUTO_INCREMENT, passport_number int, email VARCHAR(400), date_of_birth Date, visa_duration VARCHAR(400), passport_expiry_date Date, phone_number VARCHAR(400), gender VARCHAR(400), travel_end_date Date, visa_processing VARCHAR(400), profession VARCHAR(400), visa_entry_type VARCHAR(400), travel_start_date Date, referrer VARCHAR(400), passport_issue_date Date, birth_place VARCHAR(400), visa_cost VARCHAR(400), PRIMARY KEY (id)); + diff --git a/testvisa002-front-f/authsec_angular/frontend/angular-clarity-master/src/app/modules/login/login-page/login_environment.ts b/testvisa002-front-f/authsec_angular/frontend/angular-clarity-master/src/app/modules/login/login-page/login_environment.ts index 231b3a1..fdff417 100644 --- a/testvisa002-front-f/authsec_angular/frontend/angular-clarity-master/src/app/modules/login/login-page/login_environment.ts +++ b/testvisa002-front-f/authsec_angular/frontend/angular-clarity-master/src/app/modules/login/login-page/login_environment.ts @@ -2,14 +2,14 @@ export const LoginEnvironment = { - "templateNo": "", - "loginHeading": "", - "loginHeading2": "", - "isSignup": "", - "loginSignup": " ", - "loginSignup2": "", - "loginForgotpass": "", - "loginImage": "", - "loginImageURL": "" + "templateNo": "Template 1", + "loginHeading": "Welcome to", + "loginHeading2": "io8.dev", + "isSignup": "true", + "loginSignup": "Use your ID to sign in OR ", + "loginSignup2": "create one now", + "loginForgotpass": "FORGOT PASSWORD?", + "loginImage": "[]", + "loginImageURL": "null" } diff --git a/testvisa002-front-f/authsec_angular/frontend/angular-clarity-master/src/app/modules/main/BuilderComponents/vpspack/Visa_application/Visa_application.component.html b/testvisa002-front-f/authsec_angular/frontend/angular-clarity-master/src/app/modules/main/BuilderComponents/vpspack/Visa_application/Visa_application.component.html new file mode 100644 index 0000000..cc9a448 --- /dev/null +++ b/testvisa002-front-f/authsec_angular/frontend/angular-clarity-master/src/app/modules/main/BuilderComponents/vpspack/Visa_application/Visa_application.component.html @@ -0,0 +1,991 @@ + +
+
+
+

Visa_Application

+
+
+ + + +
+ + + + Loading ... + +
{{error}}
+
+ + Visa Entry Type + + + + Visa Duration + + + + visa Processing + + + + Travel start date + + + + Travel end date + + + + Passport number + + + + Passport issue date + + + + Passport Expiry date + + + + Email + + + + Phone Number + + + + Birth place + + + + Date of Birth + + + + Gender + + + + Profession + + + + Visa cost + + + + Referrer + + + + + + Action + + + + + +{{user. visa_entry_type }} + + +{{user. visa_duration }} + + +{{user. visa_processing }} + + +{{user. travel_start_date }} + + +{{user. travel_end_date }} + + +{{user. passport_number }} + + +{{user. passport_issue_date }} + + +{{user. passport_expiry_date }} + + +{{user. email }} + + +{{user. phone_number }} + + +{{user. birth_place }} + + +{{user. date_of_birth }} + + +{{user. gender }} + + +{{user. profession }} + + +{{user. visa_cost }} + + +{{user. referrer }} + + + + + + + +
Who Column
+
Account ID: {{user.accountId}}
+
Created At: {{user.createdAt| date}}
+
Created By: {{user.createdBy}}
+
Updated At: {{user.updatedAt | date}}
+
Updated By: {{user.updatedBy}}
+
+
+
+ + + + + + + +
+ + + Users per page + {{pagination.firstItem + 1}} - {{pagination.lastItem + 1}} + of {{pagination.totalItems}} users + + +
+ + + +
+
+
+
+
+
+ +
+
+ {{beforeText(item.fieldtext)}} + {{ app[transform(item.fieldtext) ] }} + {{afterText(item.fieldtext)}} +
+ +
+ {{beforeText(item.fieldtext)}} + {{ app[transform(item.fieldtext) ] | date}} + {{afterText(item.fieldtext)}} +
+
+ {{beforeText(item.fieldtext)}} + {{ app[transform(item.fieldtext) ]}} + {{afterText(item.fieldtext)}} +
+ +
+
+
+ + +
+ +
+ +
File Preview
+
+
+
+
+
+
+
+
+
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/testvisa002-front-f/authsec_angular/frontend/angular-clarity-master/src/app/modules/main/BuilderComponents/vpspack/Visa_application/Visa_application.component.scss b/testvisa002-front-f/authsec_angular/frontend/angular-clarity-master/src/app/modules/main/BuilderComponents/vpspack/Visa_application/Visa_application.component.scss new file mode 100644 index 0000000..c47b921 --- /dev/null +++ b/testvisa002-front-f/authsec_angular/frontend/angular-clarity-master/src/app/modules/main/BuilderComponents/vpspack/Visa_application/Visa_application.component.scss @@ -0,0 +1,78 @@ +//@import "../../../../assets/scss/var"; +.s-info-bar { + display: flex; + flex-direction: row; + justify-content: space-between; + button { + outline: none; + } +} +.delete,.heading{ + text-align: center; + color: red; +} +.entry-pg { + width: 750px; +} + +.button1::after { + content: none; +} +.button1:hover::after { + content: "ADD ROWS"; +} + +.section { + background-color: #dddddd; + height: 40px; +} + +.section p { + //color: white; + padding: 10px; + font-size: 18px; +} + +.clr-input { + color: #212529; + border: 1px solid #ced4da; + border-radius: 0.25rem; + padding: 0.75rem 0.75rem; + margin-top: 3px; + width: 100%; + margin-bottom: 10px; +} + +.clr-file { + color: #212529; + border: 1px solid #ced4da; + border-radius: 0.25rem; + //padding: 0.6rem 0.75rem; + margin-top: 3px; + width: 100%; + margin-bottom: 10px; +} + +.center { + text-align: center; +} +select{ + width: 100%; + margin-top: 3px; + padding: 5px 5px; + border: 1px solid #ccc; + border-radius: 4px; +} +input[type=text],[type=date],[type=number],textarea { + width: 100%; + padding: 15px 15px; + background-color:rgb(255, 255, 255); + // margin: 8px 0; + display: inline-block; + border: 1px solid #ccc; + border-radius: 4px; + box-sizing: border-box; +} +.error_mess { + color: red; +} diff --git a/testvisa002-front-f/authsec_angular/frontend/angular-clarity-master/src/app/modules/main/BuilderComponents/vpspack/Visa_application/Visa_application.component.ts b/testvisa002-front-f/authsec_angular/frontend/angular-clarity-master/src/app/modules/main/BuilderComponents/vpspack/Visa_application/Visa_application.component.ts new file mode 100644 index 0000000..0579313 --- /dev/null +++ b/testvisa002-front-f/authsec_angular/frontend/angular-clarity-master/src/app/modules/main/BuilderComponents/vpspack/Visa_application/Visa_application.component.ts @@ -0,0 +1,595 @@ +import { Component, OnInit } from '@angular/core'; +import { ToastrService } from 'ngx-toastr'; +import { AlertService } from 'src/app/services/alert.service'; +import { Visa_applicationservice} from './Visa_application.service'; +import { AbstractControl, FormArray, FormBuilder, FormGroup, Validators, ValidationErrors } from '@angular/forms'; +import { ExtensionService } from 'src/app/services/fnd/extension.service'; +import { DashboardContentModel2 } from 'src/app/models/builder/dashboard'; +import { Visa_applicationcardvariable } from './Visa_application_cardvariable'; +import { UserInfoService } from 'src/app/services/user-info.service'; +declare var JsBarcode: any; +@Component({ + selector: 'app-Visa_application', + templateUrl: './Visa_application.component.html', + styleUrls: ['./Visa_application.component.scss'] +}) +export class Visa_applicationComponent implements OnInit { + cardButton = Visa_applicationcardvariable.cardButton; + cardmodeldata = Visa_applicationcardvariable.cardmodeldata; + public dashboardArray: DashboardContentModel2[]; + isCardview = Visa_applicationcardvariable.cardButton; + cardmodal; changeView(){ + this.isCardview = !this.isCardview; + } + beforeText(fieldtext: string): string { // Extract the text before the first '<' + const index = fieldtext.indexOf('<'); + return index !== -1 ? fieldtext.substring(0, index) : fieldtext; + } + afterText(fieldtext: string): string { // Extract the text after the last '>' + const index = fieldtext.lastIndexOf('>'); + return index !== -1 ? fieldtext.substring(index + 1) : ''; + } + transform(fieldtext: string): string { + const match = fieldtext.match(/<([^>]*)>/); + return match ? match[1] : ''; // Extract the text between '<' and '>' + } + userrole; + rowSelected :any= {}; + modaldelete=false; + modalEdit=false; + modalAdd= false; + public entryForm: FormGroup; + loading = false; + product; + modalOpenedforNewLine = false; + newLine:any; + additionalFieldsFromBackend: any[] = []; + formcode = 'Visa_application_formCode' +tableName = 'Visa_application'; checkFormCode; selected: any[] = []; constructor( + private extensionService: ExtensionService, +private userInfoService:UserInfoService, + private mainService:Visa_applicationservice, + private alertService: AlertService, + private toastr: ToastrService, + private _fb: FormBuilder, + ) { } +// component button + ngOnInit(): void { + if(this.cardmodeldata !== ''){ + this.cardmodal = JSON.parse(this.cardmodeldata); + this.dashboardArray = this.cardmodal.dashboard.slice(); + console.log(this.dashboardArray) + } + this.userrole=this.userInfoService.getRoles(); + this.getData(); + this.entryForm = this._fb.group({ +visa_entry_type : [null], + +visa_duration : [null], + +visa_processing : [null], + +travel_start_date : [null], + +travel_end_date : [null], + +passport_number : [null,[Validators.required]], + +passport_issue_date : [null], + +passport_expiry_date : [null], + +email : [null], + +phone_number: ['+91'], + +birth_place : [null], + +date_of_birth : [null], + +gender : [null], + +profession : [null], + +visa_cost : [null, { updateOn: 'blur' }], + +referrer : [null], + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + }); // component_button200 + // form code start + this.extensionService.getJsonObjectsByFormCodeList(this.formcode).subscribe(data => { + console.log(data); + const jsonArray = data.map((str) => JSON.parse(str)); + this.additionalFieldsFromBackend = jsonArray; + this.checkFormCode = this.additionalFieldsFromBackend.some(field => field.formCode === "Visa_application_formCode"); + console.log(this.checkFormCode); + console.log(this.additionalFieldsFromBackend); + if (this.additionalFieldsFromBackend && this.additionalFieldsFromBackend.length > 0) { + this.additionalFieldsFromBackend.forEach(field => { + if (field.formCode === this.formcode) { + if (!this.entryForm.contains(field.extValue)) { + // Add the control only if it doesn't exist in the form + this.entryForm.addControl(field.extValue, this._fb.control(field.fieldValue)); + } + } + }); + } + }); + console.log(this.entryForm.value); + // form code end + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + } + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + error; + getData() { + this.mainService.getAll().subscribe((data) => { + console.log(data); + this.product = data; + if(this.product.length==0){ + this.error="No Data Available" + } + },(error) => { + console.log(error); + if(error){ + this.error="Server Error"; + } + }); + } + onEdit(row) { + this.rowSelected = row; + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + this.modalEdit = true; + } + onDelete(row) { + this.rowSelected = row; + this.modaldelete=true; + } + delete(id) + { + this.modaldelete = false; + console.log("in delete "+id); + this.mainService.delete(id).subscribe( + (data) => { + console.log(data); + this.ngOnInit(); + if (data) { this.toastr.success('Deleted successfully'); } + }); + } + onUpdate(id) { + this.modalEdit = false; + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + //console.log("in update"); + console.log("id " + id); + console.log(this.rowSelected); + //console.log("out update"); + this.mainService.update(id, this.rowSelected).subscribe( + (data) => { + console.log(data); + if (data || data.status >= 200 && data.status <= 299) { + this.toastr.success("Update Successfully"); + } +setTimeout(() => { + this.ngOnInit(); + }, 500); + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + }, (error) => { + console.log(error); + if (error.status >= 200 && error.status <= 299) { + // this.toastr.success("update Succesfully"); + } + if (error.status >= 400 && error.status <= 499) { + this.toastr.error("Not Updated"); + } + if (error.status >= 500 && error.status <= 599) { + this.toastr.error("Not Updated"); + } + }); + setTimeout(() => { + this.ngOnInit(); + }, 500); + } +onCreate() { + this.modalAdd=false; + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + this.mainService.create(this.entryForm.value).subscribe( + (data) => { + console.log(data); + if (data || data.status >= 200 && data.status <= 299) { + this.toastr.success("Added Successfully"); + } +setTimeout(() => { + this.ngOnInit(); + }, 500); + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + }, (error) => { + console.log(error); + if (error.status >= 200 && error.status <= 299) { + // this.toastr.success("Added Succesfully"); + } + if (error.status >= 400 && error.status <= 499) { + this.toastr.error("Not Added"); + } + if (error.status >= 500 && error.status <= 599) { + this.toastr.error("Not Added"); + } + }); + setTimeout(() => { + this.ngOnInit(); + }, 500); + } + goToAdd(row) { +this.modalAdd = true; this.submitted = false; + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + } + submitted = false; +onSubmit() { + console.log(this.entryForm.value); + this.submitted = true; + if (this.entryForm.invalid) { + return; + }this.onCreate(); + +} + + + + + + + + + + + + + + + + +isValidemail(email: string): boolean { + const emailPattern = /^[a-zA-Z0-9._%+-]+@[a-zA-Z0-9.-]+\.[a-zA-Z]{2,}$/; + return emailPattern.test(email); } + +isValidPhone_number(phone: string): boolean { + const phonePattern = /^(\+[1-9][0-9]{0,2})?[1-9][0-9]{9}$/; + return phonePattern.test(phone); +} + + + + + +updategender (gender : string): void { + this.entryForm.get('gender').setValue(gender); } + +updategenderEdit(gender : string): void { this.rowSelected.gender = gender } + ; + + + +//currency field start + formatCurrencyvisa_cost () { + // Format the currency with two decimal places + this.rowSelected.visa_cost = Number(this.rowSelected.visa_cost ).toFixed(2); + // Remove commas from the formatted currency + this.rowSelected.visa_cost = this.rowSelected.visa_cost?.replace(/,/g, ''); } + //currency field end + + + +// updateaction +} + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/testvisa002-front-f/authsec_angular/frontend/angular-clarity-master/src/app/modules/main/BuilderComponents/vpspack/Visa_application/Visa_application.service.ts b/testvisa002-front-f/authsec_angular/frontend/angular-clarity-master/src/app/modules/main/BuilderComponents/vpspack/Visa_application/Visa_application.service.ts new file mode 100644 index 0000000..4aad2fd --- /dev/null +++ b/testvisa002-front-f/authsec_angular/frontend/angular-clarity-master/src/app/modules/main/BuilderComponents/vpspack/Visa_application/Visa_application.service.ts @@ -0,0 +1,65 @@ +import { Injectable } from '@angular/core'; +import { Observable } from "rxjs"; +import { HttpClient, HttpHeaders, HttpParams, } from "@angular/common/http"; +import { ApiRequestService } from "src/app/services/api/api-request.service"; +import { environment } from 'src/environments/environment'; +@Injectable({ + providedIn: 'root' +}) +export class Visa_applicationservice{ + private baseURL = "Visa_application/Visa_application" ; constructor( + private http: HttpClient, + private apiRequest: ApiRequestService, + ) { } + getAll(page?: number, size?: number): Observable { + return this.apiRequest.get(this.baseURL); + } + getById(id: number): Observable { + const _http = this.baseURL + "/" + id; + return this.apiRequest.get(_http); + } + create(data: any): Observable { + return this.apiRequest.post(this.baseURL, data); + } + update(id: number, data: any): Observable { + const _http = this.baseURL + "/" + id; + return this.apiRequest.put(_http, data); + } + delete(id: number): Observable { + const _http = this.baseURL + "/" + id; + return this.apiRequest.delete(_http); + } + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +// updateaction +} \ No newline at end of file diff --git a/testvisa002-front-f/authsec_angular/frontend/angular-clarity-master/src/app/modules/main/BuilderComponents/vpspack/Visa_application/Visa_application_cardvariable.ts b/testvisa002-front-f/authsec_angular/frontend/angular-clarity-master/src/app/modules/main/BuilderComponents/vpspack/Visa_application/Visa_application_cardvariable.ts new file mode 100644 index 0000000..520d8dc --- /dev/null +++ b/testvisa002-front-f/authsec_angular/frontend/angular-clarity-master/src/app/modules/main/BuilderComponents/vpspack/Visa_application/Visa_application_cardvariable.ts @@ -0,0 +1,4 @@ +export const Visa_applicationcardvariable = { + "cardButton": false, + "cardmodeldata": `` +} \ No newline at end of file diff --git a/testvisa002-front-f/authsec_angular/frontend/angular-clarity-master/src/app/modules/main/main-routing.module.ts b/testvisa002-front-f/authsec_angular/frontend/angular-clarity-master/src/app/modules/main/main-routing.module.ts index c7450e8..86be379 100644 --- a/testvisa002-front-f/authsec_angular/frontend/angular-clarity-master/src/app/modules/main/main-routing.module.ts +++ b/testvisa002-front-f/authsec_angular/frontend/angular-clarity-master/src/app/modules/main/main-routing.module.ts @@ -1,3 +1,4 @@ +import { Visa_applicationComponent } from './BuilderComponents/vpspack/Visa_application/Visa_application.component'; @@ -258,6 +259,9 @@ const routes: Routes = [ // buildercomponents +{path:'Visa_application',component:Visa_applicationComponent}, + + { path: '**', component: PageNotFoundComponent }, diff --git a/testvisa002-front-f/authsec_angular/frontend/angular-clarity-master/src/app/modules/main/main.module.ts b/testvisa002-front-f/authsec_angular/frontend/angular-clarity-master/src/app/modules/main/main.module.ts index dacaf40..f591803 100644 --- a/testvisa002-front-f/authsec_angular/frontend/angular-clarity-master/src/app/modules/main/main.module.ts +++ b/testvisa002-front-f/authsec_angular/frontend/angular-clarity-master/src/app/modules/main/main.module.ts @@ -1,3 +1,4 @@ +import { Visa_applicationComponent } from './BuilderComponents/vpspack/Visa_application/Visa_application.component'; import { CommonModule } from '@angular/common'; import { CUSTOM_ELEMENTS_SCHEMA, NgModule } from '@angular/core'; @@ -126,6 +127,9 @@ import { QueryeditComponent } from './superadmin/queryedit/queryedit.component'; // buildercomponents +Visa_applicationComponent, + + diff --git a/testvisa002-front-f/authsec_angular/frontend/angular-clarity-master/src/assets/i18n/en.json b/testvisa002-front-f/authsec_angular/frontend/angular-clarity-master/src/assets/i18n/en.json index 3d60440..2a79e2f 100644 --- a/testvisa002-front-f/authsec_angular/frontend/angular-clarity-master/src/assets/i18n/en.json +++ b/testvisa002-front-f/authsec_angular/frontend/angular-clarity-master/src/assets/i18n/en.json @@ -1,4 +1,4 @@ -{ + { "BREADCRUMB_HOME": "Home", "USER_GROUP_MAINTENANCE": "User Group Maintenance", "BREADCRUMB_ABOUT_US": "About Us", @@ -17,23 +17,25 @@ "IMPORT": "Import", "EXPORT_XLSX": "Export as XLSX", "ADD": "Add", - "MENU_ACCESS_CONTROL": "Menu Access Control", - "EDIT_MODE": "Edit Mode", - "FOR": "For", - "RELOAD": "Reload", - "SHOW_ALL": "Show All", - "ONLY_MAIN_MENU": "Only Main Menu", - "NO_DATA_AVAILABLE": "No data available", - "NO": "No", - "MENU_ITEM_NAME": "Menu Item Name", - "VIEW": "View", - "CREATE": "Create", - "EDIT": "Edit", - "DELETE": "Delete", - "QUERY": "Query", - "EXPORT": "Export", - "SYNC": "Sync", - "editMode": "Edit Mode", + + "MENU_ACCESS_CONTROL": "Menu Access Control", + "EDIT_MODE": "Edit Mode", + "FOR": "For", + "RELOAD": "Reload", + "SHOW_ALL": "Show All", + "ONLY_MAIN_MENU": "Only Main Menu", + + "NO_DATA_AVAILABLE": "No data available", + "NO": "No", + "MENU_ITEM_NAME": "Menu Item Name", + "VIEW": "View", + "CREATE": "Create", + "EDIT": "Edit", + "DELETE": "Delete", + "QUERY": "Query", + "EXPORT": "Export", + "SYNC": "Sync", + "editMode": "Edit Mode", "setupCode": "Setup Code", "value": "Value", "schedulerTimer": "Scheduler Timer", @@ -60,9 +62,11 @@ "oidAdminUserTooltip": "Admin user for OID access", "oidServerPort": "OID Server Port", "oidServerPortTooltip": "Port number for the OID server", - "companyDisplayName": "Company Display Name", + + + "companyDisplayName": "Company Display Name", "systemParameter": "System Parameter", - "userDefaultGroup": "User Default Group", + "userDefaultGroup": "User Default Group", "defaultDepartment": "Default Department", "defaultPosition": "Default Position", "singleCharge": "Single Charge", @@ -93,45 +97,49 @@ "areYouSureDelete": "Are You Sure Want to delete?", "updateAccessType": "Update Access Type", "update": "Update", - "SEQ_GENERATOR": "Sequence Generator", - "CURRENT_NO": "Current No", - "NAME": "Name", - "PREFIX": "Prefix", - "SEPARATOR": "Separator", - "SEQUENCE_SIZE": "Sequence Size", - "REPORT": "Report", - "REPORT_RUNNER": "Report Runner", - "REPORT_NAME": "Report Name", - "REPORT_DESCRIPTION": "Report Description", - "API_REGISTERY": "Api Registery", - "API_REGISTERY_DESCRIPTION": "Api Registery Description", - "ACTIVE": "Active", - "FOLDER_NAME": "Folder Name", - "ACTION": "Action", - "SET_UP": "Set Up", - "USERS_PER_PAGE": "Users per page", - "OF": "of", - "USERS": "users", - "ARE_YOU_SURE": "Are you sure you want to delete?", - "CANCEL": "Cancel", - "GO_TO": "Go To", - "ALL_REPORTS": "All Reports", - "ALL_REPORT": "All Report", - "REPORT_BUILDER_SQL": "Report Builder (SQL)", - "REPORT_BUILDER_URL": "Report Builder (URL)", - "LOADING_MESSAGE": "Dashboard could be found. Loading..", - "START_FROM_SCRATCH": "Start from scratch", - "IMPORT_TEMPLATE": "Import from a template", - "IMPORT_PUBLIC_PROJECT": "Import from public project", - "DELETE_CONFIRMATION": "Are You Sure Want to delete?", - "LAST_UPDATED_ON": "Last Updated On:", - "CREATE_NEW_REPORT": "Create New Report", - "ADD_MODE": "Add Mode", - "ENTER_NAME": "Enter name", - "DESCRIPTION": "Description", - "ENTER_DESCRIPTION": "Enter Description", - "SUBMIT": "Submit", - "home": "Home", + + "SEQ_GENERATOR": "Sequence Generator", + "CURRENT_NO": "Current No", + "NAME": "Name", + "PREFIX": "Prefix", + "SEPARATOR": "Separator", + "SEQUENCE_SIZE": "Sequence Size", + "REPORT": "Report", + "REPORT_RUNNER": "Report Runner", + + "REPORT_NAME": "Report Name", + "REPORT_DESCRIPTION": "Report Description", + "ACTIVE": "Active", + "FOLDER_NAME": "Folder Name", + "ACTION": "Action", + "SET_UP": "Set Up", + + "USERS_PER_PAGE": "Users per page", + "OF": "of", + "USERS": "users", + "ARE_YOU_SURE": "Are you sure you want to delete?", + "CANCEL": "Cancel", + "GO_TO": "Go To", + "ALL_REPORTS": "All Reports", + "ALL_REPORT": "All Report", + "REPORT_BUILDER_SQL": "Report Builder (SQL)", + "REPORT_BUILDER_URL": "Report Builder (URL)", + "LOADING_MESSAGE": "Dashboard could be found. Loading..", + "START_FROM_SCRATCH": "Start from scratch", + "IMPORT_TEMPLATE": "Import from a template", + "IMPORT_PUBLIC_PROJECT": "Import from public project", + "DELETE_CONFIRMATION": "Are You Sure Want to delete?", + + "LAST_UPDATED_ON": "Last Updated On:", + "CREATE_NEW_REPORT": "Create New Report", + "ADD_MODE": "Add Mode", + + "ENTER_NAME": "Enter name", + "DESCRIPTION": "Description", + "ENTER_DESCRIPTION": "Enter Description", + + "SUBMIT": "Submit", + "home": "Home", "dashboard": "Dashboard", "all_dashboard": "All Dashboard", "dashboard_builder": "Dashboard Builder", @@ -203,8 +211,10 @@ "GROUP_LEVEL": "Group Level", "STATUS": "Status", "UPDATED_DATE": "Updated Date", + "RECORDS_PER_PAGE": "Record per page", "IMPORT_FILE": "Import File", + "UPDATE": "Update", "ARE_YOU_SURE_DELETE": "Are You Sure Want to delete?", "THIS_FIELD_REQUIRED": "*This field is Required", @@ -216,10 +226,21 @@ "MENU_ACTION_LINK": "Menu Action Link", "STATUS": "Status", "SUB_MENU": "Sub Menu", - "Stt": "Stt", - "OneToManyExtension": "OneToManyExtension", - "studentname": "studentname", - "description": "description", - "Studenthigh": "Studenthigh", - "Name": "Name" + "Passport_number": "Passport_number", + "Email": "Email", + "Date_of_Birth": "Date_of_Birth", + "Visa_application": "Visa_application", + "Visa_Duration": "Visa_Duration", + "Passport_Expiry_date": "Passport_Expiry_date", + "Phone_Number": "Phone_Number", + "Gender": "Gender", + "Travel_end_date": "Travel_end_date", + "visa_Processing": "visa_Processing", + "Profession": "Profession", + "Visa_Entry_Type": "Visa_Entry_Type", + "Travel_start_date": "Travel_start_date", + "Referrer": "Referrer", + "Passport_issue_date": "Passport_issue_date", + "Birth_place": "Birth_place", + "Visa_cost": "Visa_cost" } \ No newline at end of file