simpo-component-library 3.6.183 → 3.6.188

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -51,7 +51,7 @@ export class EnrollmentFormComponent extends BaseSection {
51
51
  name: ""
52
52
  },
53
53
  addressLine: "",
54
- pinCode: 0,
54
+ pinCode: localStorage.getItem('pincode') || 0,
55
55
  },
56
56
  bankDetails: {
57
57
  bankName: "",
@@ -234,6 +234,7 @@ export class EnrollmentFormComponent extends BaseSection {
234
234
  }
235
235
  success() {
236
236
  this.restService.createEnrollmentScheme(this.enrollementPayload).subscribe((res) => {
237
+ this.router.navigate(['/profile']);
237
238
  }, (error) => {
238
239
  this.simulatePayment('failure');
239
240
  });
@@ -392,4 +393,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
392
393
  }], index: [{
393
394
  type: Input
394
395
  }] } });
395
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"enrollment-form.component.js","sourceRoot":"","sources":["../../../../../../../projects/simpo-ui/src/lib/ecommerce/sections/enrollment-form/enrollment-form.component.ts","../../../../../../../projects/simpo-ui/src/lib/ecommerce/sections/enrollment-form/enrollment-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, NgModule, ViewChild } from '@angular/core';\r\nimport BaseSection from '../../../sections/BaseSection';\r\nimport { CommonModule } from '@angular/common';\r\nimport { AnimationDirective } from '../../../directive/animation-directive';\r\nimport { BackgroundDirective } from '../../../directive/background-directive';\r\nimport { CornerDirective } from '../../../directive/corner-directive';\r\nimport { SimpoComponentModule } from '../../../components/index';\r\nimport { HoverDirective } from '../../../directive/hover-element-directive';\r\nimport { ButtonDirectiveDirective } from '../../../directive/button-directive.directive';\r\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { MatIcon } from '@angular/material/icon';\r\nimport { ContentFitDirective } from '../../../directive/content-fit-directive';\r\nimport { RestService } from '../../../services/rest.service';\r\nimport { ActivatedRoute, Router } from '@angular/router';\r\nimport { SpacingHorizontalDirective } from '../../../directive/spacing-horizontal.directive';\r\nimport { EnrollmentFormModel, EnrollmentFormStyleModel } from './enrollment-form.model';\r\nimport { ButtonEditorDirective } from '../../../directive/button-editor.directive';\r\nimport { StorageServiceService } from '../../../services/storage.service';\r\n\r\n@Component({\r\n  selector: 'simpo-enrollment-form',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    FormsModule,\r\n    ReactiveFormsModule,\r\n    MatIcon,\r\n    SimpoComponentModule,\r\n    AnimationDirective,\r\n    BackgroundDirective,\r\n    CornerDirective,\r\n    HoverDirective,\r\n    ButtonDirectiveDirective,\r\n    ContentFitDirective,\r\n    SpacingHorizontalDirective,\r\n    ButtonEditorDirective,\r\n    MatIcon\r\n  ],\r\n  templateUrl: './enrollment-form.component.html',\r\n  styleUrl: './enrollment-form.component.css'\r\n})\r\nexport class EnrollmentFormComponent extends BaseSection {\r\n\r\n  @Input() data?: EnrollmentFormModel;\r\n  @Input() edit?: boolean = true;\r\n  @Input() customClass?: string;\r\n  @Input() delete?: boolean;\r\n  @Input() index?: number;\r\n  styles?: EnrollmentFormStyleModel;\r\n\r\n  constructor(private restService: RestService,\r\n    private activeRoute: ActivatedRoute,\r\n    private readonly storageService: StorageServiceService,\r\n    private router: Router\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.checkUserLoggedIn();\r\n    this.getSchemes();\r\n    this.getAllStores();\r\n    this.getAllState();\r\n  }\r\n\r\n\r\n  checkUserLoggedIn() {\r\n    if (!this.storageService.getUser()) {\r\n      this.router.navigate(['/login'], { queryParams: { schemes: true } });\r\n    }\r\n  }\r\n\r\n  page: 'ENROLLMENT' | 'PAYMENT' = 'ENROLLMENT';\r\n\r\n  enrollementPayload: any = {\r\n    name: \"\",\r\n    mailId: \"\",\r\n    mobileNumber: \"\",\r\n    dateOfBirth: \"\",\r\n    schemeDetails: {\r\n      schemeId: \"\",\r\n      schemeName: \"\",\r\n      schemeType: \"\",\r\n      pwcSchemeCode: \"\"\r\n    },\r\n    pwcUserCode: \"C_000313885\",\r\n    addressDetails: {\r\n      state: {\r\n        id: \"\",\r\n        name: \"\"\r\n      },\r\n      city: {\r\n        id: \"\",\r\n        name: \"\"\r\n      },\r\n      addressLine: \"\",\r\n      pinCode: 0,\r\n    },\r\n    bankDetails: {\r\n      bankName: \"\",\r\n      accountNumber: 0,\r\n      ifscCode: \"\",\r\n      accountHolderName: \"\"\r\n    },\r\n    nomineeDetails: {\r\n      nomineeName: \"\",\r\n      mobile: \"\",\r\n      relationShip: \"Father\",\r\n    },\r\n    custodian: {\r\n      staffId: \"\",\r\n      staffName: \"\",\r\n      mobileNumber: \"\",\r\n      email: \"\",\r\n      staffCode: \"\",\r\n      profileImgUrl: \"\"\r\n    },\r\n    storeDetails: {},\r\n    enrolledGroup: {},\r\n    monthlyInstallmentAmount: 0,\r\n    pwcStoreCode: \"\",\r\n    subscriptionChargeDate: new Date().getDate()\r\n  }\r\n\r\n  schemesData: any = [];\r\n  selectedScheme: any;\r\n  getSchemes() {\r\n    this.restService.getAllScheme().subscribe((res: any) => {\r\n      this.schemesData = res?.data || [];\r\n      this.selectedScheme = this.schemesData[0];\r\n      this.setMonthlyInstallmentAmount();\r\n    },\r\n      (error: any) => {\r\n        console.error(\"Error fetching schemes: \", error);\r\n      }\r\n    )\r\n  }\r\n\r\n  storeData: any = [];\r\n  selectedStore: any;\r\n  getAllStores() {\r\n    this.restService.getAllStoresOrra(0, 10000).subscribe((res: any) => {\r\n      this.storeData = res?.data?.data || [];\r\n      this.enrollementPayload.storeDetails = this.storeData[0];\r\n      this.getStaffById();\r\n    },\r\n      (error: any) => {\r\n        console.error(\"Error fetching stores: \", error);\r\n      }\r\n    )\r\n  }\r\n\r\n  staffData: any = [];\r\n  getStaffById() {\r\n    this.restService.getstaffByStoreId(this.enrollementPayload.storeDetails.storeId).subscribe((res: any) => {\r\n      this.staffData = res?.data || [];\r\n      this.enrollementPayload.custodian = this.staffData[0] || {};\r\n    },\r\n      (error: any) => {\r\n        console.error(\"Error fetching staff: \", error);\r\n      })\r\n  }\r\n\r\n  stateData: any = [];\r\n  getAllState() {\r\n    this.restService.getAllState().subscribe((res: any) => {\r\n      this.stateData = res?.data || [];\r\n      this.enrollementPayload.addressDetails.state = this.stateData[0] || {};\r\n      this.getCityByStateId();\r\n    },\r\n      (error: any) => {\r\n        console.error(\"Error fetching states: \", error);\r\n      })\r\n  }\r\n\r\n  cityData: any = [];\r\n  getCityByStateId() {\r\n    this.restService.getCityByStateBypaginated(this.enrollementPayload.addressDetails.state.id, 0, 10000).subscribe((res: any) => {\r\n      this.cityData = res?.data.data || [];\r\n      this.enrollementPayload.addressDetails.city = this.cityData[0] || {};\r\n    },\r\n      (error: any) => {\r\n        console.error(\"Error fetching Cities: \", error);\r\n      })\r\n  }\r\n\r\n  setMonthlyInstallmentAmount() {\r\n    if (this.selectedScheme.schemeType == 'INDIVIDUAL' && this.selectedScheme.minInstallmentAmount) {\r\n      this.enrollementPayload.monthlyInstallmentAmount = this.selectedScheme.minInstallmentAmount;\r\n    } else {\r\n      this.getStoreSlabs();\r\n    }\r\n  }\r\n\r\n  storeSlabs: any = [];\r\n  getStoreSlabs() {\r\n    this.restService.getStoreBySlab({ storesList: this.selectedScheme.schemeSlabs[0].slabStores }).subscribe((res: any) => {\r\n      this.storeSlabs = res?.data || [];\r\n    },\r\n      (error: any) => {\r\n        console.error(\"Error fetching store slabs: \", error);\r\n      })\r\n  }\r\n\r\n  createEnrollment() {\r\n\r\n    for (let ele of Object.keys(this.validObject)) {\r\n      this.validater(ele);\r\n    }\r\n\r\n    if (Object.values(this.validObject).some(value => !value)) {\r\n      return;\r\n    }\r\n\r\n    this.enrollementPayload.pwcStoreCode = this.enrollementPayload.storeDetails?.pwcStoreCode || this.selectedScheme?.pwcStoreCode;\r\n\r\n    this.enrollementPayload.schemeDetails = ['schemeId', 'schemeName', 'schemeType', 'pwcSchemeCode'].reduce((acc: any, key: any) => {\r\n      if (this.selectedScheme[key] !== undefined) {\r\n        acc[key] = this.selectedScheme[key];\r\n      }\r\n      if (key == 'pwcSchemeCode') {\r\n        acc[key] = this.selectedScheme?.pwcIndividualSchemeCode;\r\n      }\r\n      return acc;\r\n    }, {});\r\n\r\n    if (this.selectedScheme.schemeType == 'GROUP') {\r\n      this.enrollementPayload.enrolledGroup.schemeId = this.selectedScheme?.schemeId;\r\n      this.enrollementPayload.enrolledGroup.schemeName = this.selectedScheme?.schemeName;\r\n      this.enrollementPayload.enrolledGroup.storeId = this.enrollementPayload?.storeDetails?.storeId;\r\n      this.enrollementPayload.enrolledGroup.storeName = this.enrollementPayload?.storeDetails?.storeName;\r\n      this.enrollementPayload.monthlyInstallmentAmount = this.enrollementPayload?.enrolledGroup?.schemeSlab?.monthlyInstallmentAmount;\r\n    }\r\n\r\n\r\n    this.enrollementPayload.addressDetails.state = ['id', 'name'].reduce((acc: any, key: any) => {\r\n      if (this.enrollementPayload.addressDetails.state?.[key] !== undefined) {\r\n        acc[key] = this.enrollementPayload.addressDetails.state[key];\r\n      }\r\n      return acc;\r\n    }, {});\r\n\r\n\r\n    this.enrollementPayload.addressDetails.city = ['id', 'name'].reduce((acc: any, key: any) => {\r\n      if (this.enrollementPayload.addressDetails.city?.[key] !== undefined) {\r\n        acc[key] = this.enrollementPayload.addressDetails.city[key];\r\n      }\r\n      return acc;\r\n    }, {});\r\n\r\n\r\n    this.enrollementPayload.custodian = [\r\n      'staffId', 'staffName', 'mobileNumber', 'email', 'staffCode', 'profileImgUrl'\r\n    ].reduce((acc: any, key: any) => {\r\n      if (this.enrollementPayload.custodian?.[key] !== undefined) {\r\n        acc[key] = this.enrollementPayload.custodian[key];\r\n      }\r\n      if (key == 'staffName')\r\n        acc[key] = this.enrollementPayload.custodian?.personalInfo?.name\r\n      if (key == 'mobileNumber')\r\n        acc[key] = this.enrollementPayload.custodian?.contactDetails?.mobile\r\n      if (key == 'email')\r\n        acc[key] = this.enrollementPayload.custodian?.contactDetails?.email\r\n      if (key == 'profileImgUrl')\r\n        acc[key] = this.enrollementPayload.custodian?.personalInfo?.profileImage\r\n      if (key == 'staffCode')\r\n        acc[key] = this.enrollementPayload.custodian?.staffWorkInfo?.staffCode;\r\n      return acc;\r\n    }, {});\r\n    this.page = 'PAYMENT';\r\n  }\r\n\r\n  success() {\r\n    this.restService.createEnrollmentScheme(this.enrollementPayload).subscribe((res: any) => {\r\n    },\r\n      (error: any) => {\r\n        this.simulatePayment('failure');\r\n      })\r\n  }\r\n\r\n\r\n\r\n  result: any\r\n  showResult = true;\r\n  isProcessing = false;\r\n\r\n  simulatePayment(type: 'success' | 'failure') {\r\n    this.isProcessing = true;\r\n    this.showResult = false;\r\n    this.result = {}\r\n    setTimeout(() => {\r\n      this.isProcessing = false;\r\n\r\n      if (type === 'success') {\r\n        this.result = {\r\n          type: 'success',\r\n          title: 'Payment Successful!',\r\n          message: 'Your transaction has been processed successfully.',\r\n          iconClass: 'fas fa-check-circle'\r\n        };\r\n        this.success();\r\n      } else {\r\n        this.result = {\r\n          type: 'failure',\r\n          title: 'Payment Failed!',\r\n          message: 'There was an error processing your payment. Please try again.',\r\n          iconClass: 'fas fa-exclamation-triangle'\r\n        };\r\n      }\r\n      setTimeout(() => {\r\n        this.showResult = true;\r\n      }, 100);\r\n    }, 2000);\r\n  }\r\n\r\n  getButtonId(index: number) {\r\n    return this.data?.action?.buttons[index]?.id ?? \"\";\r\n  }\r\n  getButtonStyle(index: number) {\r\n    return this.data?.action?.buttons[index]?.styles;\r\n  }\r\n\r\n  getButtonContent(index: number) {\r\n    return this.data?.action?.buttons[index]?.content;\r\n  }\r\n\r\n\r\n  debounceTimer: any;\r\n  validateForm(fieldType: string) {\r\n    clearTimeout(this.debounceTimer);\r\n    this.debounceTimer = setTimeout(() => {\r\n      this.validater(fieldType)\r\n    }, 300);\r\n  }\r\n  validObject: any = {\r\n    NAME: true,\r\n    EMAIL: true,\r\n    MOBILE: true,\r\n    DOB: true,\r\n    SCHEME: true,\r\n    MONTHLY_AMOUNT: true,\r\n    STORE: true,\r\n    ADDRESS: true,\r\n    STATE: true,\r\n    CITY: true,\r\n    PINCODE: true,\r\n    NOMINEE_NAME: true,\r\n    NOMINEE_MOBILE: true,\r\n    NOMINEE_RELATIONSHIP: true,\r\n    BANK_NAME: true,\r\n    ACCOUNT_NUMBER: true,\r\n    IFSC_CODE: true,\r\n    ACCOUNT_HOLDER_NAME: true,\r\n  }\r\n  validater(fieldType: string) {\r\n    switch (fieldType) {\r\n      case 'NAME': {\r\n        this.validObject.NAME = this.enrollementPayload.name.trim().length > 0;\r\n        break;\r\n      }\r\n      case 'EMAIL': {\r\n        this.validObject.EMAIL = /^[^\\s@]+@[^\\s@]+\\.[^\\s@]+$/.test(this.enrollementPayload.mailId);\r\n        break;\r\n      }\r\n      case 'MOBILE': {\r\n        this.validObject.MOBILE = /^\\d{10}$/.test(this.enrollementPayload.mobileNumber);\r\n        break;\r\n      }\r\n      case 'DOB': {\r\n        this.validObject.DOB = !!this.enrollementPayload.dateOfBirth;\r\n        break;\r\n      }\r\n      case 'SCHEME': {\r\n        this.validObject.SCHEME = !!this.selectedScheme;\r\n        break;\r\n      }\r\n      case 'MONTHLY_AMOUNT': {\r\n        this.validObject.MONTHLY_AMOUNT = this.enrollementPayload?.monthlyInstallmentAmount > 0;\r\n        break;\r\n      }\r\n      case 'STORE': {\r\n        this.validObject.STORE = !!this.enrollementPayload?.storeDetails?.storeId;\r\n        break;\r\n      }\r\n      case 'ADDRESS': {\r\n        this.validObject.ADDRESS = !!this.enrollementPayload?.addressDetails?.addressLine.trim();\r\n        break;\r\n      }\r\n      case 'STATE': {\r\n        this.validObject.STATE = !!this.enrollementPayload?.addressDetails?.state?.id;\r\n        break;\r\n      }\r\n      case 'CITY': {\r\n        this.validObject.CITY = !!this.enrollementPayload?.addressDetails?.city?.id;\r\n        break;\r\n      }\r\n      case 'PINCODE': {\r\n        this.validObject.PINCODE = /^\\d{6}$/.test(this.enrollementPayload?.addressDetails?.pinCode?.toString());\r\n        break;\r\n      }\r\n      case 'NOMINEE_NAME': {\r\n        this.validObject.NOMINEE_NAME = this.enrollementPayload?.nomineeDetails?.nomineeName?.trim()?.length > 0;\r\n        break;\r\n      }\r\n      case 'NOMINEE_MOBILE': {\r\n        this.validObject.NOMINEE_MOBILE = /^\\d{10}$/.test(this.enrollementPayload?.nomineeDetails?.mobile);\r\n        break;\r\n      }\r\n      case 'NOMINEE_RELATIONSHIP': {\r\n        this.validObject.NOMINEE_RELATIONSHIP = !!this.enrollementPayload?.nomineeDetails?.relationShip?.trim();\r\n        break;\r\n      }\r\n      case 'BANK_NAME': {\r\n        this.validObject.BANK_NAME = !!this.enrollementPayload?.bankDetails?.bankName.trim();\r\n        break;\r\n      }\r\n      case 'ACCOUNT_NUMBER': {\r\n        this.validObject.ACCOUNT_NUMBER = /^\\d+$/.test(this.enrollementPayload?.bankDetails?.accountNumber?.toString());\r\n        break;\r\n      }\r\n      case 'IFSC_CODE': {\r\n        this.validObject.IFSC_CODE = !!this.enrollementPayload?.bankDetails?.ifscCode?.trim();\r\n        break;\r\n      }\r\n      case 'ACCOUNT_HOLDER_NAME': {\r\n        this.validObject.ACCOUNT_HOLDER_NAME = this.enrollementPayload?.bankDetails?.accountHolderName?.trim().length > 0;\r\n        break;\r\n      }\r\n      default: {\r\n        break;\r\n      }\r\n    }\r\n  }\r\n\r\n\r\n\r\n\r\n}\r\n","<div class=\"total-container position-relative\" simpoHover (hovering)=\"showEditTabs($event)\" [id]=\"data?.id\">\r\n    <div class=\"container py-5\" *ngIf=\"page === 'ENROLLMENT'\">\r\n        <div class=\"form-container\">\r\n            <div class=\"section-title\">Customer Information</div>\r\n\r\n            <div class=\"mb-3\">\r\n                <label for=\"fullName\" class=\"form-label\">Full Name <span class=\"required\">*</span></label>\r\n                <input type=\"text\" class=\"form-control custom-form-control\" id=\"fullName\" required\r\n                    [(ngModel)]=\"enrollementPayload.name\" (ngModelChange)=\"validateForm('NAME')\" [class.error-border]=\"!validObject['NAME']\">\r\n            </div>\r\n\r\n            <div class=\"mb-3\">\r\n                <label for=\"email\" class=\"form-label\">Email Address <span class=\"required\">*</span></label>\r\n                <input type=\"email\" class=\"form-control custom-form-control\" id=\"email\" required\r\n                    [(ngModel)]=\"enrollementPayload.mailId\" (ngModelChange)=\"validateForm('EMAIL')\" [class.error-border]=\"!validObject['EMAIL']\">\r\n            </div>\r\n\r\n            <div class=\"row mb-3\">\r\n                <div class=\"col-md-6\">\r\n                    <label for=\"mobile\" class=\"form-label\">Mobile <span class=\"required\">*</span></label>\r\n                    <input type=\"tel\" class=\"form-control custom-form-control\" id=\"mobile\" required\r\n                        [(ngModel)]=\"enrollementPayload.mobileNumber\" (ngModelChange)=\"validateForm('MOBILE')\" [class.error-border]=\"!validObject['MOBILE']\">\r\n                </div>\r\n                <div class=\"col-md-6\">\r\n                    <label for=\"dateOfBirth\" class=\"form-label\">Date of Birth <span class=\"required\">*</span></label>\r\n                    <input type=\"date\" class=\"form-control custom-form-control\" id=\"dateOfBirth\" required\r\n                        [(ngModel)]=\"enrollementPayload.dateOfBirth\" (ngModelChange)=\"validateForm('DOB')\" [class.error-border]=\"!validObject['DOB']\">\r\n                </div>\r\n            </div>\r\n\r\n            <!-- Scheme Information -->\r\n            <div class=\"section-title\">Scheme Information</div>\r\n\r\n            <div class=\"row mb-3\">\r\n                <div class=\"col-md-6\">\r\n                    <label for=\"scheme\" class=\"form-label\">Scheme <span class=\"required\">*</span></label>\r\n                    <select class=\"form-select custom-form-select\" id=\"scheme\" required [(ngModel)]=\"selectedScheme\"\r\n                        (ngModelChange)=\"setMonthlyInstallmentAmount()\">\r\n                        <option [ngValue]=\"\">Select Scheme</option>\r\n                        <ng-container *ngFor=\"let scheme of schemesData\">\r\n                            <option [ngValue]=\"scheme\">{{scheme.schemeName ?? \"-\"}}</option>\r\n                        </ng-container>\r\n                    </select>\r\n                </div>\r\n                <div class=\"col-md-6\">\r\n                    <label for=\"monthlyAmount\" class=\"form-label\">Monthly Amount <span class=\"required\">*</span></label>\r\n                    <input type=\"number\" class=\"form-control custom-form-control\" id=\"monthlyAmount\" required disabled\r\n                        *ngIf=\"selectedScheme?.schemeType == 'INDIVIDUAL'\"\r\n                        [(ngModel)]=\"enrollementPayload.monthlyInstallmentAmount\">\r\n                    <select class=\"form-select custom-form-select\" id=\"subdivision\" required\r\n                        *ngIf=\"selectedScheme?.schemeType == 'GROUP'\"\r\n                        [(ngModel)]=\"enrollementPayload.enrolledGroup.schemeSlab\">\r\n                        <option [ngValue]=\"\">Select Amount Plan</option>\r\n                        <ng-container *ngFor=\"let slab of selectedScheme.schemeSlabs\">\r\n                            <option [ngValue]=\"slab\">{{slab.monthlyInstallmentAmount ?? \"-\"}}</option>\r\n                        </ng-container>\r\n                    </select>\r\n                </div>\r\n            </div>\r\n\r\n            <!-- Store Information -->\r\n            <div class=\"section-title\">Store Information</div>\r\n\r\n            <div class=\"row mb-3\">\r\n                <div class=\"col-md-6\">\r\n                    <label for=\"storeName\" class=\"form-label\">Store Name <span class=\"required\">*</span></label>\r\n                    <select class=\"form-select custom-form-select\" id=\"subdivision\" required\r\n                        [(ngModel)]=\"enrollementPayload.storeDetails\" (ngModelChange)=\"getStaffById()\">\r\n                        <option [ngValue]=\"\">Select Store</option>\r\n                        <ng-container *ngFor=\"let store of storeData\">\r\n                            <option [ngValue]=\"store\">{{store.storeName ?? \"-\"}}</option>\r\n                        </ng-container>\r\n                    </select>\r\n                </div>\r\n                <div class=\"col-md-6\">\r\n                    <label for=\"subdivision\" class=\"form-label\">Custodian</label>\r\n                    <select class=\"form-select custom-form-select\" id=\"subdivision\"\r\n                        [(ngModel)]=\"enrollementPayload.custodian\">\r\n                        <option [ngValue]=\"\">Select Custodian</option>\r\n                        <ng-container *ngFor=\"let staff of staffData\">\r\n                            <option [ngValue]=\"staff\">{{staff.personalInfo.name ?? \"-\"}}</option>\r\n                        </ng-container>\r\n                    </select>\r\n                </div>\r\n            </div>\r\n\r\n            <!-- Enter Your Address -->\r\n            <div class=\"section-title\">Enter Your Address</div>\r\n\r\n            <div class=\"mb-3\">\r\n                <label for=\"address\" class=\"form-label\">Address <span class=\"required\">*</span></label>\r\n                <input type=\"text\" class=\"form-control custom-form-control\" id=\"address\" required\r\n                    [(ngModel)]=\"enrollementPayload.addressDetails.addressLine\" (ngModelChange)=\"validateForm('ADDRESS')\" [class.error-border]=\"!validObject['ADDRESS']\">\r\n            </div>\r\n\r\n            <div class=\"row mb-3\">\r\n                <div class=\"col-md-6\">\r\n                    <label for=\"state\" class=\"form-label\">State <span class=\"required\">*</span></label>\r\n                    <select class=\"form-select custom-form-select\" [(ngModel)]=\"enrollementPayload.addressDetails.state\"\r\n                        (ngModelChange)=\"getCityByStateId()\">\r\n                        <option [ngValue]=\"\">Select State</option>\r\n                        <ng-container *ngFor=\"let state of stateData\">\r\n                            <option [ngValue]=\"state\">{{state.name ?? \"-\"}}</option>\r\n                        </ng-container>\r\n                    </select>\r\n                </div>\r\n                <div class=\"col-md-6\">\r\n                    <label for=\"city\" class=\"form-label\">City <span class=\"required\">*</span></label>\r\n                    <select class=\"form-select custom-form-select\" [(ngModel)]=\"enrollementPayload.addressDetails.city\">\r\n                        <option [ngValue]=\"\">Select City</option>\r\n                        <ng-container *ngFor=\"let city of cityData\">\r\n                            <option [ngValue]=\"city\">{{city.name ?? \"-\"}}</option>\r\n                        </ng-container>\r\n                    </select>\r\n                </div>\r\n            </div>\r\n\r\n            <div class=\"row mb-3\">\r\n                <div class=\"col-md-6\">\r\n                    <label for=\"pincode\" class=\"form-label\">Pincode <span class=\"required\">*</span></label>\r\n                    <input type=\"number\" class=\"form-control custom-form-control\" id=\"pincode\" required\r\n                        [(ngModel)]=\"enrollementPayload.addressDetails.pinCode\" (ngModelChange)=\"validateForm('PINCODE')\" [class.error-border]=\"!validObject['PINCODE']\">\r\n                </div>\r\n            </div>\r\n\r\n            <div class=\"section-title\">Enter Nominee Details</div>\r\n\r\n            <div class=\"mb-3\">\r\n                <label for=\"nomineeName\" class=\"form-label\">Full Name of Nominee <span class=\"required\">*</span></label>\r\n                <input type=\"text\" class=\"form-control custom-form-control\" id=\"nomineeName\" required\r\n                    [(ngModel)]=\"enrollementPayload.nomineeDetails.nomineeName\" (ngModelChange)=\"validateForm('NOMINEE_NAME')\" [class.error-border]=\"!validObject['NOMINEE_NAME']\">\r\n            </div>\r\n\r\n            <div class=\"row mb-3\">\r\n                <div class=\"col-md-6\">\r\n                    <label for=\"relationship\" class=\"form-label\">Select Relationship <span\r\n                            class=\"required\">*</span></label>\r\n                    <select class=\"form-select custom-form-select\" id=\"relationship\" required\r\n                        [(ngModel)]=\"enrollementPayload.nomineeDetails.relationShip\">\r\n                        <!-- <option value=\"\">Select Relationship</option> -->\r\n                        <option value=\"Spouse\">Spouse</option>\r\n                        <option value=\"Child\">Child</option>\r\n                        <option value=\"Mother\">Mother</option>\r\n                        <option value=\"Father\">Father</option>\r\n                        <option value=\"Sibling\">Sibling</option>\r\n                    </select>\r\n                </div>\r\n                <div class=\"col-md-6\">\r\n                    <label for=\"nomineePhone\" class=\"form-label\">Mobile Number <span class=\"required\">*</span></label>\r\n\r\n                    <input type=\"number\" class=\"form-control custom-form-control\" id=\"nomineePhone\" required\r\n                        [(ngModel)]=\"enrollementPayload.nomineeDetails.mobile\" (ngModelChange)=\"validateForm('NOMINEE_MOBILE')\" [class.error-border]=\"!validObject['NOMINEE_MOBILE']\">\r\n                </div>\r\n            </div>\r\n\r\n            <div class=\"section-title\">Account Information</div>\r\n\r\n            <div class=\"row mb-3\">\r\n                <div class=\"col-md-6\">\r\n                    <label for=\"accountHolder\" class=\"form-label\">Account Holder Name <span\r\n                            class=\"required\">*</span></label>\r\n                    <input type=\"text\" class=\"form-control custom-form-control\" id=\"accountHolder\" required\r\n                        [(ngModel)]=\"enrollementPayload.bankDetails.accountHolderName\"  (ngModelChange)=\"validateForm('ACCOUNT_HOLDER_NAME')\" [class.error-border]=\"!validObject['ACCOUNT_HOLDER_NAME']\">\r\n                </div>\r\n                <div class=\"col-md-6\">\r\n                    <label for=\"accountNumber\" class=\"form-label\">Account Number <span class=\"required\">*</span></label>\r\n                    <input type=\"text\" class=\"form-control custom-form-control\" id=\"accountNumber\" required\r\n                        [(ngModel)]=\"enrollementPayload.bankDetails.accountNumber\" (ngModelChange)=\"validateForm('ACCOUNT_NUMBER')\" [class.error-border]=\"!validObject['ACCOUNT_NUMBER']\">\r\n                </div>\r\n            </div>\r\n\r\n            <div class=\"row mb-3\">\r\n                <div class=\"col-md-6\">\r\n                    <label for=\"bankName\" class=\"form-label\">Bank Name <span class=\"required\">*</span></label>\r\n                    <input type=\"text\" class=\"form-control custom-form-control\" id=\"bankName\" required\r\n                        [(ngModel)]=\"enrollementPayload.bankDetails.bankName\" (ngModelChange)=\"validateForm('BANK_NAME')\" [class.error-border]=\"!validObject['BANK_NAME']\">\r\n                </div>\r\n                <div class=\"col-md-6\">\r\n                    <label for=\"ifscCode\" class=\"form-label\">IFSC Code <span class=\"required\">*</span></label>\r\n                    <input type=\"text\" class=\"form-control custom-form-control\" id=\"ifscCode\" required\r\n                        [(ngModel)]=\"enrollementPayload.bankDetails.ifscCode\" (ngModelChange)=\"validateForm('IFSC_CODE')\"   [class.error-border]=\"!validObject['IFSC_CODE']\">\r\n                </div>\r\n            </div>\r\n            <div class=\"d-grid mt-4\">\r\n                <button type=\"submit\" class=\"btn btn-submit\" (click)=\"createEnrollment()\"\r\n                    [appButtonEditor]=\"edit ?? false\" simpoButtonDirective [buttonStyle]=\"getButtonStyle(0)\"\r\n                    [buttonId]=\"getButtonId(0)\" [sectionId]=\"data?.id\" [id]=\"data?.id+getButtonId(0)\"\r\n                    [buttonData]=\"getButtonContent(0)\">Submit\r\n                    Enrollment</button>\r\n            </div>\r\n        </div>\r\n    </div>\r\n    <div class=\"container-fluid d-flex justify-content-center align-items-center min-vh-100\" *ngIf=\"page === 'PAYMENT'\">\r\n        <div class=\"card shadow-lg border-0 payment-card\">\r\n            <div class=\"card-header bg-primary text-white text-center py-3\">\r\n                <h2 class=\"card-title mb-0\">\r\n                    <i class=\"fas fa-credit-card me-2\"></i>\r\n                    Payment Simulation\r\n                </h2>\r\n            </div>\r\n\r\n            <div class=\"card-body p-4\">\r\n                <div class=\"row g-3 mb-4\">\r\n                    <div class=\"col-6\">\r\n                        <button class=\"btn btn-success btn-lg w-100 payment-btn\" (click)=\"simulatePayment('success')\"\r\n                            [disabled]=\"isProcessing\">\r\n                            <i class=\"fas fa-check-circle me-2\"></i>\r\n                            <span class=\"btn-text\">Success</span>\r\n                            <div class=\"btn-overlay\"></div>\r\n                        </button>\r\n                    </div>\r\n                    <div class=\"col-6\">\r\n                        <button class=\"btn btn-danger btn-lg w-100 payment-btn\" (click)=\"simulatePayment('failure')\"\r\n                            [disabled]=\"isProcessing\">\r\n                            <i class=\"fas fa-times-circle me-2\"></i>\r\n                            <span class=\"btn-text\">Failure</span>\r\n                            <div class=\"btn-overlay\"></div>\r\n                        </button>\r\n                    </div>\r\n                </div>\r\n\r\n                <div *ngIf=\"isProcessing\" class=\"text-center mb-3\">\r\n                    <div class=\"d-flex justify-content-center align-items-center\">\r\n                        <div class=\"spinner-border text-primary me-2\" role=\"status\">\r\n                            <span class=\"visually-hidden\">Loading...</span>\r\n                        </div>\r\n                        <span class=\"text-muted\">Processing payment...</span>\r\n                    </div>\r\n                </div>\r\n\r\n                <div *ngIf=\"result\" class=\"alert alert-dismissible fade\" [ngClass]=\"{\r\n              'alert-success': result.type === 'success', \r\n              'alert-danger': result.type === 'failure',\r\n              'show': showResult\r\n            }\" role=\"alert\">\r\n                    <i [class]=\"result.iconClass + ' me-2'\"></i>\r\n                    <strong>{{ result.title }}</strong> {{ result.message }}\r\n                </div>\r\n            </div>\r\n\r\n            <div class=\"card-footer bg-light text-center py-3\">\r\n                <small class=\"text-muted\">\r\n                    <i class=\"fas fa-info-circle me-1\"></i>\r\n                    Click buttons to simulate payment scenarios\r\n                </small>\r\n            </div>\r\n        </div>\r\n    </div>\r\n    <div [ngClass]=\"{'hover_effect': edit}\" *ngIf=\"showEditors\">\r\n        <simpo-hover-elements [data]=\"data\" [index]=\"index\" [editOptions]=\"edit\"></simpo-hover-elements>\r\n    </div>\r\n\r\n    <div *ngIf=\"showDelete\" [ngClass]=\"{'hover_effect': delete}\">\r\n        <simpo-delete-hover-element [data]=\"data\" [index]=\"index\"></simpo-delete-hover-element>\r\n    </div>\r\n</div>"]}
396
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"enrollment-form.component.js","sourceRoot":"","sources":["../../../../../../../projects/simpo-ui/src/lib/ecommerce/sections/enrollment-form/enrollment-form.component.ts","../../../../../../../projects/simpo-ui/src/lib/ecommerce/sections/enrollment-form/enrollment-form.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, NgModule, ViewChild } from '@angular/core';\r\nimport BaseSection from '../../../sections/BaseSection';\r\nimport { CommonModule } from '@angular/common';\r\nimport { AnimationDirective } from '../../../directive/animation-directive';\r\nimport { BackgroundDirective } from '../../../directive/background-directive';\r\nimport { CornerDirective } from '../../../directive/corner-directive';\r\nimport { SimpoComponentModule } from '../../../components/index';\r\nimport { HoverDirective } from '../../../directive/hover-element-directive';\r\nimport { ButtonDirectiveDirective } from '../../../directive/button-directive.directive';\r\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { MatIcon } from '@angular/material/icon';\r\nimport { ContentFitDirective } from '../../../directive/content-fit-directive';\r\nimport { RestService } from '../../../services/rest.service';\r\nimport { ActivatedRoute, Router } from '@angular/router';\r\nimport { SpacingHorizontalDirective } from '../../../directive/spacing-horizontal.directive';\r\nimport { EnrollmentFormModel, EnrollmentFormStyleModel } from './enrollment-form.model';\r\nimport { ButtonEditorDirective } from '../../../directive/button-editor.directive';\r\nimport { StorageServiceService } from '../../../services/storage.service';\r\n\r\n@Component({\r\n  selector: 'simpo-enrollment-form',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    FormsModule,\r\n    ReactiveFormsModule,\r\n    MatIcon,\r\n    SimpoComponentModule,\r\n    AnimationDirective,\r\n    BackgroundDirective,\r\n    CornerDirective,\r\n    HoverDirective,\r\n    ButtonDirectiveDirective,\r\n    ContentFitDirective,\r\n    SpacingHorizontalDirective,\r\n    ButtonEditorDirective,\r\n    MatIcon\r\n  ],\r\n  templateUrl: './enrollment-form.component.html',\r\n  styleUrl: './enrollment-form.component.css'\r\n})\r\nexport class EnrollmentFormComponent extends BaseSection {\r\n\r\n  @Input() data?: EnrollmentFormModel;\r\n  @Input() edit?: boolean = true;\r\n  @Input() customClass?: string;\r\n  @Input() delete?: boolean;\r\n  @Input() index?: number;\r\n  styles?: EnrollmentFormStyleModel;\r\n\r\n  constructor(private restService: RestService,\r\n    private activeRoute: ActivatedRoute,\r\n    private readonly storageService: StorageServiceService,\r\n    private router: Router\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.checkUserLoggedIn();\r\n    this.getSchemes();\r\n    this.getAllStores();\r\n    this.getAllState();\r\n  }\r\n\r\n\r\n  checkUserLoggedIn() {\r\n    if (!this.storageService.getUser()) {\r\n      this.router.navigate(['/login'], { queryParams: { schemes: true } });\r\n    }\r\n  }\r\n\r\n  page: 'ENROLLMENT' | 'PAYMENT' = 'ENROLLMENT';\r\n\r\n  enrollementPayload: any = {\r\n    name: \"\",\r\n    mailId: \"\",\r\n    mobileNumber: \"\",\r\n    dateOfBirth: \"\",\r\n    schemeDetails: {\r\n      schemeId: \"\",\r\n      schemeName: \"\",\r\n      schemeType: \"\",\r\n      pwcSchemeCode: \"\"\r\n    },\r\n    pwcUserCode: \"C_000313885\",\r\n    addressDetails: {\r\n      state: {\r\n        id: \"\",\r\n        name: \"\"\r\n      },\r\n      city: {\r\n        id: \"\",\r\n        name: \"\"\r\n      },\r\n      addressLine: \"\",\r\n      pinCode: localStorage.getItem('pincode') || 0,\r\n    },\r\n    bankDetails: {\r\n      bankName: \"\",\r\n      accountNumber: 0,\r\n      ifscCode: \"\",\r\n      accountHolderName: \"\"\r\n    },\r\n    nomineeDetails: {\r\n      nomineeName: \"\",\r\n      mobile: \"\",\r\n      relationShip: \"Father\",\r\n    },\r\n    custodian: {\r\n      staffId: \"\",\r\n      staffName: \"\",\r\n      mobileNumber: \"\",\r\n      email: \"\",\r\n      staffCode: \"\",\r\n      profileImgUrl: \"\"\r\n    },\r\n    storeDetails: {},\r\n    enrolledGroup: {},\r\n    monthlyInstallmentAmount: 0,\r\n    pwcStoreCode: \"\",\r\n    subscriptionChargeDate: new Date().getDate()\r\n  }\r\n\r\n  schemesData: any = [];\r\n  selectedScheme: any;\r\n  getSchemes() {\r\n    this.restService.getAllScheme().subscribe((res: any) => {\r\n      this.schemesData = res?.data || [];\r\n      this.selectedScheme = this.schemesData[0];\r\n      this.setMonthlyInstallmentAmount();\r\n    },\r\n      (error: any) => {\r\n        console.error(\"Error fetching schemes: \", error);\r\n      }\r\n    )\r\n  }\r\n\r\n  storeData: any = [];\r\n  selectedStore: any;\r\n  getAllStores() {\r\n    this.restService.getAllStoresOrra(0, 10000).subscribe((res: any) => {\r\n      this.storeData = res?.data?.data || [];\r\n      this.enrollementPayload.storeDetails = this.storeData[0];\r\n      this.getStaffById();\r\n    },\r\n      (error: any) => {\r\n        console.error(\"Error fetching stores: \", error);\r\n      }\r\n    )\r\n  }\r\n\r\n  staffData: any = [];\r\n  getStaffById() {\r\n    this.restService.getstaffByStoreId(this.enrollementPayload.storeDetails.storeId).subscribe((res: any) => {\r\n      this.staffData = res?.data || [];\r\n      this.enrollementPayload.custodian = this.staffData[0] || {};\r\n    },\r\n      (error: any) => {\r\n        console.error(\"Error fetching staff: \", error);\r\n      })\r\n  }\r\n\r\n  stateData: any = [];\r\n  getAllState() {\r\n    this.restService.getAllState().subscribe((res: any) => {\r\n      this.stateData = res?.data || [];\r\n      this.enrollementPayload.addressDetails.state = this.stateData[0] || {};\r\n      this.getCityByStateId();\r\n    },\r\n      (error: any) => {\r\n        console.error(\"Error fetching states: \", error);\r\n      })\r\n  }\r\n\r\n  cityData: any = [];\r\n  getCityByStateId() {\r\n    this.restService.getCityByStateBypaginated(this.enrollementPayload.addressDetails.state.id, 0, 10000).subscribe((res: any) => {\r\n      this.cityData = res?.data.data || [];\r\n      this.enrollementPayload.addressDetails.city = this.cityData[0] || {};\r\n    },\r\n      (error: any) => {\r\n        console.error(\"Error fetching Cities: \", error);\r\n      })\r\n  }\r\n\r\n  setMonthlyInstallmentAmount() {\r\n    if (this.selectedScheme.schemeType == 'INDIVIDUAL' && this.selectedScheme.minInstallmentAmount) {\r\n      this.enrollementPayload.monthlyInstallmentAmount = this.selectedScheme.minInstallmentAmount;\r\n    } else {\r\n      this.getStoreSlabs();\r\n    }\r\n  }\r\n\r\n  storeSlabs: any = [];\r\n  getStoreSlabs() {\r\n    this.restService.getStoreBySlab({ storesList: this.selectedScheme.schemeSlabs[0].slabStores }).subscribe((res: any) => {\r\n      this.storeSlabs = res?.data || [];\r\n    },\r\n      (error: any) => {\r\n        console.error(\"Error fetching store slabs: \", error);\r\n      })\r\n  }\r\n\r\n  createEnrollment() {\r\n\r\n    for (let ele of Object.keys(this.validObject)) {\r\n      this.validater(ele);\r\n    }\r\n\r\n    if (Object.values(this.validObject).some(value => !value)) {\r\n      return;\r\n    }\r\n\r\n    this.enrollementPayload.pwcStoreCode = this.enrollementPayload.storeDetails?.pwcStoreCode || this.selectedScheme?.pwcStoreCode;\r\n\r\n    this.enrollementPayload.schemeDetails = ['schemeId', 'schemeName', 'schemeType', 'pwcSchemeCode'].reduce((acc: any, key: any) => {\r\n      if (this.selectedScheme[key] !== undefined) {\r\n        acc[key] = this.selectedScheme[key];\r\n      }\r\n      if (key == 'pwcSchemeCode') {\r\n        acc[key] = this.selectedScheme?.pwcIndividualSchemeCode;\r\n      }\r\n      return acc;\r\n    }, {});\r\n\r\n    if (this.selectedScheme.schemeType == 'GROUP') {\r\n      this.enrollementPayload.enrolledGroup.schemeId = this.selectedScheme?.schemeId;\r\n      this.enrollementPayload.enrolledGroup.schemeName = this.selectedScheme?.schemeName;\r\n      this.enrollementPayload.enrolledGroup.storeId = this.enrollementPayload?.storeDetails?.storeId;\r\n      this.enrollementPayload.enrolledGroup.storeName = this.enrollementPayload?.storeDetails?.storeName;\r\n      this.enrollementPayload.monthlyInstallmentAmount = this.enrollementPayload?.enrolledGroup?.schemeSlab?.monthlyInstallmentAmount;\r\n    }\r\n\r\n\r\n    this.enrollementPayload.addressDetails.state = ['id', 'name'].reduce((acc: any, key: any) => {\r\n      if (this.enrollementPayload.addressDetails.state?.[key] !== undefined) {\r\n        acc[key] = this.enrollementPayload.addressDetails.state[key];\r\n      }\r\n      return acc;\r\n    }, {});\r\n\r\n\r\n    this.enrollementPayload.addressDetails.city = ['id', 'name'].reduce((acc: any, key: any) => {\r\n      if (this.enrollementPayload.addressDetails.city?.[key] !== undefined) {\r\n        acc[key] = this.enrollementPayload.addressDetails.city[key];\r\n      }\r\n      return acc;\r\n    }, {});\r\n\r\n\r\n    this.enrollementPayload.custodian = [\r\n      'staffId', 'staffName', 'mobileNumber', 'email', 'staffCode', 'profileImgUrl'\r\n    ].reduce((acc: any, key: any) => {\r\n      if (this.enrollementPayload.custodian?.[key] !== undefined) {\r\n        acc[key] = this.enrollementPayload.custodian[key];\r\n      }\r\n      if (key == 'staffName')\r\n        acc[key] = this.enrollementPayload.custodian?.personalInfo?.name\r\n      if (key == 'mobileNumber')\r\n        acc[key] = this.enrollementPayload.custodian?.contactDetails?.mobile\r\n      if (key == 'email')\r\n        acc[key] = this.enrollementPayload.custodian?.contactDetails?.email\r\n      if (key == 'profileImgUrl')\r\n        acc[key] = this.enrollementPayload.custodian?.personalInfo?.profileImage\r\n      if (key == 'staffCode')\r\n        acc[key] = this.enrollementPayload.custodian?.staffWorkInfo?.staffCode;\r\n      return acc;\r\n    }, {});\r\n    this.page = 'PAYMENT';\r\n  }\r\n\r\n  success() {\r\n    this.restService.createEnrollmentScheme(this.enrollementPayload).subscribe((res: any) => {\r\n      this.router.navigate(['/profile'])\r\n    },\r\n      (error: any) => {\r\n        this.simulatePayment('failure');\r\n      })\r\n  }\r\n\r\n\r\n\r\n  result: any\r\n  showResult = true;\r\n  isProcessing = false;\r\n\r\n  simulatePayment(type: 'success' | 'failure') {\r\n    this.isProcessing = true;\r\n    this.showResult = false;\r\n    this.result = {}\r\n    setTimeout(() => {\r\n      this.isProcessing = false;\r\n\r\n      if (type === 'success') {\r\n        this.result = {\r\n          type: 'success',\r\n          title: 'Payment Successful!',\r\n          message: 'Your transaction has been processed successfully.',\r\n          iconClass: 'fas fa-check-circle'\r\n        };\r\n        this.success();\r\n      } else {\r\n        this.result = {\r\n          type: 'failure',\r\n          title: 'Payment Failed!',\r\n          message: 'There was an error processing your payment. Please try again.',\r\n          iconClass: 'fas fa-exclamation-triangle'\r\n        };\r\n      }\r\n      setTimeout(() => {\r\n        this.showResult = true;\r\n      }, 100);\r\n    }, 2000);\r\n  }\r\n\r\n  getButtonId(index: number) {\r\n    return this.data?.action?.buttons[index]?.id ?? \"\";\r\n  }\r\n  getButtonStyle(index: number) {\r\n    return this.data?.action?.buttons[index]?.styles;\r\n  }\r\n\r\n  getButtonContent(index: number) {\r\n    return this.data?.action?.buttons[index]?.content;\r\n  }\r\n\r\n\r\n  debounceTimer: any;\r\n  validateForm(fieldType: string) {\r\n    clearTimeout(this.debounceTimer);\r\n    this.debounceTimer = setTimeout(() => {\r\n      this.validater(fieldType)\r\n    }, 300);\r\n  }\r\n  validObject: any = {\r\n    NAME: true,\r\n    EMAIL: true,\r\n    MOBILE: true,\r\n    DOB: true,\r\n    SCHEME: true,\r\n    MONTHLY_AMOUNT: true,\r\n    STORE: true,\r\n    ADDRESS: true,\r\n    STATE: true,\r\n    CITY: true,\r\n    PINCODE: true,\r\n    NOMINEE_NAME: true,\r\n    NOMINEE_MOBILE: true,\r\n    NOMINEE_RELATIONSHIP: true,\r\n    BANK_NAME: true,\r\n    ACCOUNT_NUMBER: true,\r\n    IFSC_CODE: true,\r\n    ACCOUNT_HOLDER_NAME: true,\r\n  }\r\n  validater(fieldType: string) {\r\n    switch (fieldType) {\r\n      case 'NAME': {\r\n        this.validObject.NAME = this.enrollementPayload.name.trim().length > 0;\r\n        break;\r\n      }\r\n      case 'EMAIL': {\r\n        this.validObject.EMAIL = /^[^\\s@]+@[^\\s@]+\\.[^\\s@]+$/.test(this.enrollementPayload.mailId);\r\n        break;\r\n      }\r\n      case 'MOBILE': {\r\n        this.validObject.MOBILE = /^\\d{10}$/.test(this.enrollementPayload.mobileNumber);\r\n        break;\r\n      }\r\n      case 'DOB': {\r\n        this.validObject.DOB = !!this.enrollementPayload.dateOfBirth;\r\n        break;\r\n      }\r\n      case 'SCHEME': {\r\n        this.validObject.SCHEME = !!this.selectedScheme;\r\n        break;\r\n      }\r\n      case 'MONTHLY_AMOUNT': {\r\n        this.validObject.MONTHLY_AMOUNT = this.enrollementPayload?.monthlyInstallmentAmount > 0;\r\n        break;\r\n      }\r\n      case 'STORE': {\r\n        this.validObject.STORE = !!this.enrollementPayload?.storeDetails?.storeId;\r\n        break;\r\n      }\r\n      case 'ADDRESS': {\r\n        this.validObject.ADDRESS = !!this.enrollementPayload?.addressDetails?.addressLine.trim();\r\n        break;\r\n      }\r\n      case 'STATE': {\r\n        this.validObject.STATE = !!this.enrollementPayload?.addressDetails?.state?.id;\r\n        break;\r\n      }\r\n      case 'CITY': {\r\n        this.validObject.CITY = !!this.enrollementPayload?.addressDetails?.city?.id;\r\n        break;\r\n      }\r\n      case 'PINCODE': {\r\n        this.validObject.PINCODE = /^\\d{6}$/.test(this.enrollementPayload?.addressDetails?.pinCode?.toString());\r\n        break;\r\n      }\r\n      case 'NOMINEE_NAME': {\r\n        this.validObject.NOMINEE_NAME = this.enrollementPayload?.nomineeDetails?.nomineeName?.trim()?.length > 0;\r\n        break;\r\n      }\r\n      case 'NOMINEE_MOBILE': {\r\n        this.validObject.NOMINEE_MOBILE = /^\\d{10}$/.test(this.enrollementPayload?.nomineeDetails?.mobile);\r\n        break;\r\n      }\r\n      case 'NOMINEE_RELATIONSHIP': {\r\n        this.validObject.NOMINEE_RELATIONSHIP = !!this.enrollementPayload?.nomineeDetails?.relationShip?.trim();\r\n        break;\r\n      }\r\n      case 'BANK_NAME': {\r\n        this.validObject.BANK_NAME = !!this.enrollementPayload?.bankDetails?.bankName.trim();\r\n        break;\r\n      }\r\n      case 'ACCOUNT_NUMBER': {\r\n        this.validObject.ACCOUNT_NUMBER = /^\\d+$/.test(this.enrollementPayload?.bankDetails?.accountNumber?.toString());\r\n        break;\r\n      }\r\n      case 'IFSC_CODE': {\r\n        this.validObject.IFSC_CODE = !!this.enrollementPayload?.bankDetails?.ifscCode?.trim();\r\n        break;\r\n      }\r\n      case 'ACCOUNT_HOLDER_NAME': {\r\n        this.validObject.ACCOUNT_HOLDER_NAME = this.enrollementPayload?.bankDetails?.accountHolderName?.trim().length > 0;\r\n        break;\r\n      }\r\n      default: {\r\n        break;\r\n      }\r\n    }\r\n  }\r\n\r\n\r\n\r\n\r\n}\r\n","<div class=\"total-container position-relative\" simpoHover (hovering)=\"showEditTabs($event)\" [id]=\"data?.id\">\r\n    <div class=\"container py-5\" *ngIf=\"page === 'ENROLLMENT'\">\r\n        <div class=\"form-container\">\r\n            <div class=\"section-title\">Customer Information</div>\r\n\r\n            <div class=\"mb-3\">\r\n                <label for=\"fullName\" class=\"form-label\">Full Name <span class=\"required\">*</span></label>\r\n                <input type=\"text\" class=\"form-control custom-form-control\" id=\"fullName\" required\r\n                    [(ngModel)]=\"enrollementPayload.name\" (ngModelChange)=\"validateForm('NAME')\" [class.error-border]=\"!validObject['NAME']\">\r\n            </div>\r\n\r\n            <div class=\"mb-3\">\r\n                <label for=\"email\" class=\"form-label\">Email Address <span class=\"required\">*</span></label>\r\n                <input type=\"email\" class=\"form-control custom-form-control\" id=\"email\" required\r\n                    [(ngModel)]=\"enrollementPayload.mailId\" (ngModelChange)=\"validateForm('EMAIL')\" [class.error-border]=\"!validObject['EMAIL']\">\r\n            </div>\r\n\r\n            <div class=\"row mb-3\">\r\n                <div class=\"col-md-6\">\r\n                    <label for=\"mobile\" class=\"form-label\">Mobile <span class=\"required\">*</span></label>\r\n                    <input type=\"tel\" class=\"form-control custom-form-control\" id=\"mobile\" required\r\n                        [(ngModel)]=\"enrollementPayload.mobileNumber\" (ngModelChange)=\"validateForm('MOBILE')\" [class.error-border]=\"!validObject['MOBILE']\">\r\n                </div>\r\n                <div class=\"col-md-6\">\r\n                    <label for=\"dateOfBirth\" class=\"form-label\">Date of Birth <span class=\"required\">*</span></label>\r\n                    <input type=\"date\" class=\"form-control custom-form-control\" id=\"dateOfBirth\" required\r\n                        [(ngModel)]=\"enrollementPayload.dateOfBirth\" (ngModelChange)=\"validateForm('DOB')\" [class.error-border]=\"!validObject['DOB']\">\r\n                </div>\r\n            </div>\r\n\r\n            <!-- Scheme Information -->\r\n            <div class=\"section-title\">Scheme Information</div>\r\n\r\n            <div class=\"row mb-3\">\r\n                <div class=\"col-md-6\">\r\n                    <label for=\"scheme\" class=\"form-label\">Scheme <span class=\"required\">*</span></label>\r\n                    <select class=\"form-select custom-form-select\" id=\"scheme\" required [(ngModel)]=\"selectedScheme\"\r\n                        (ngModelChange)=\"setMonthlyInstallmentAmount()\">\r\n                        <option [ngValue]=\"\">Select Scheme</option>\r\n                        <ng-container *ngFor=\"let scheme of schemesData\">\r\n                            <option [ngValue]=\"scheme\">{{scheme.schemeName ?? \"-\"}}</option>\r\n                        </ng-container>\r\n                    </select>\r\n                </div>\r\n                <div class=\"col-md-6\">\r\n                    <label for=\"monthlyAmount\" class=\"form-label\">Monthly Amount <span class=\"required\">*</span></label>\r\n                    <input type=\"number\" class=\"form-control custom-form-control\" id=\"monthlyAmount\" required disabled\r\n                        *ngIf=\"selectedScheme?.schemeType == 'INDIVIDUAL'\"\r\n                        [(ngModel)]=\"enrollementPayload.monthlyInstallmentAmount\">\r\n                    <select class=\"form-select custom-form-select\" id=\"subdivision\" required\r\n                        *ngIf=\"selectedScheme?.schemeType == 'GROUP'\"\r\n                        [(ngModel)]=\"enrollementPayload.enrolledGroup.schemeSlab\">\r\n                        <option [ngValue]=\"\">Select Amount Plan</option>\r\n                        <ng-container *ngFor=\"let slab of selectedScheme.schemeSlabs\">\r\n                            <option [ngValue]=\"slab\">{{slab.monthlyInstallmentAmount ?? \"-\"}}</option>\r\n                        </ng-container>\r\n                    </select>\r\n                </div>\r\n            </div>\r\n\r\n            <!-- Store Information -->\r\n            <div class=\"section-title\">Store Information</div>\r\n\r\n            <div class=\"row mb-3\">\r\n                <div class=\"col-md-6\">\r\n                    <label for=\"storeName\" class=\"form-label\">Store Name <span class=\"required\">*</span></label>\r\n                    <select class=\"form-select custom-form-select\" id=\"subdivision\" required\r\n                        [(ngModel)]=\"enrollementPayload.storeDetails\" (ngModelChange)=\"getStaffById()\">\r\n                        <option [ngValue]=\"\">Select Store</option>\r\n                        <ng-container *ngFor=\"let store of storeData\">\r\n                            <option [ngValue]=\"store\">{{store.storeName ?? \"-\"}}</option>\r\n                        </ng-container>\r\n                    </select>\r\n                </div>\r\n                <div class=\"col-md-6\">\r\n                    <label for=\"subdivision\" class=\"form-label\">Custodian</label>\r\n                    <select class=\"form-select custom-form-select\" id=\"subdivision\"\r\n                        [(ngModel)]=\"enrollementPayload.custodian\">\r\n                        <option [ngValue]=\"\">Select Custodian</option>\r\n                        <ng-container *ngFor=\"let staff of staffData\">\r\n                            <option [ngValue]=\"staff\">{{staff.personalInfo.name ?? \"-\"}}</option>\r\n                        </ng-container>\r\n                    </select>\r\n                </div>\r\n            </div>\r\n\r\n            <!-- Enter Your Address -->\r\n            <div class=\"section-title\">Enter Your Address</div>\r\n\r\n            <div class=\"mb-3\">\r\n                <label for=\"address\" class=\"form-label\">Address <span class=\"required\">*</span></label>\r\n                <input type=\"text\" class=\"form-control custom-form-control\" id=\"address\" required\r\n                    [(ngModel)]=\"enrollementPayload.addressDetails.addressLine\" (ngModelChange)=\"validateForm('ADDRESS')\" [class.error-border]=\"!validObject['ADDRESS']\">\r\n            </div>\r\n\r\n            <div class=\"row mb-3\">\r\n                <div class=\"col-md-6\">\r\n                    <label for=\"state\" class=\"form-label\">State <span class=\"required\">*</span></label>\r\n                    <select class=\"form-select custom-form-select\" [(ngModel)]=\"enrollementPayload.addressDetails.state\"\r\n                        (ngModelChange)=\"getCityByStateId()\">\r\n                        <option [ngValue]=\"\">Select State</option>\r\n                        <ng-container *ngFor=\"let state of stateData\">\r\n                            <option [ngValue]=\"state\">{{state.name ?? \"-\"}}</option>\r\n                        </ng-container>\r\n                    </select>\r\n                </div>\r\n                <div class=\"col-md-6\">\r\n                    <label for=\"city\" class=\"form-label\">City <span class=\"required\">*</span></label>\r\n                    <select class=\"form-select custom-form-select\" [(ngModel)]=\"enrollementPayload.addressDetails.city\">\r\n                        <option [ngValue]=\"\">Select City</option>\r\n                        <ng-container *ngFor=\"let city of cityData\">\r\n                            <option [ngValue]=\"city\">{{city.name ?? \"-\"}}</option>\r\n                        </ng-container>\r\n                    </select>\r\n                </div>\r\n            </div>\r\n\r\n            <div class=\"row mb-3\">\r\n                <div class=\"col-md-6\">\r\n                    <label for=\"pincode\" class=\"form-label\">Pincode <span class=\"required\">*</span></label>\r\n                    <input type=\"number\" class=\"form-control custom-form-control\" id=\"pincode\" required\r\n                        [(ngModel)]=\"enrollementPayload.addressDetails.pinCode\" (ngModelChange)=\"validateForm('PINCODE')\" [class.error-border]=\"!validObject['PINCODE']\">\r\n                </div>\r\n            </div>\r\n\r\n            <div class=\"section-title\">Enter Nominee Details</div>\r\n\r\n            <div class=\"mb-3\">\r\n                <label for=\"nomineeName\" class=\"form-label\">Full Name of Nominee <span class=\"required\">*</span></label>\r\n                <input type=\"text\" class=\"form-control custom-form-control\" id=\"nomineeName\" required\r\n                    [(ngModel)]=\"enrollementPayload.nomineeDetails.nomineeName\" (ngModelChange)=\"validateForm('NOMINEE_NAME')\" [class.error-border]=\"!validObject['NOMINEE_NAME']\">\r\n            </div>\r\n\r\n            <div class=\"row mb-3\">\r\n                <div class=\"col-md-6\">\r\n                    <label for=\"relationship\" class=\"form-label\">Select Relationship <span\r\n                            class=\"required\">*</span></label>\r\n                    <select class=\"form-select custom-form-select\" id=\"relationship\" required\r\n                        [(ngModel)]=\"enrollementPayload.nomineeDetails.relationShip\">\r\n                        <!-- <option value=\"\">Select Relationship</option> -->\r\n                        <option value=\"Spouse\">Spouse</option>\r\n                        <option value=\"Child\">Child</option>\r\n                        <option value=\"Mother\">Mother</option>\r\n                        <option value=\"Father\">Father</option>\r\n                        <option value=\"Sibling\">Sibling</option>\r\n                    </select>\r\n                </div>\r\n                <div class=\"col-md-6\">\r\n                    <label for=\"nomineePhone\" class=\"form-label\">Mobile Number <span class=\"required\">*</span></label>\r\n\r\n                    <input type=\"number\" class=\"form-control custom-form-control\" id=\"nomineePhone\" required\r\n                        [(ngModel)]=\"enrollementPayload.nomineeDetails.mobile\" (ngModelChange)=\"validateForm('NOMINEE_MOBILE')\" [class.error-border]=\"!validObject['NOMINEE_MOBILE']\">\r\n                </div>\r\n            </div>\r\n\r\n            <div class=\"section-title\">Account Information</div>\r\n\r\n            <div class=\"row mb-3\">\r\n                <div class=\"col-md-6\">\r\n                    <label for=\"accountHolder\" class=\"form-label\">Account Holder Name <span\r\n                            class=\"required\">*</span></label>\r\n                    <input type=\"text\" class=\"form-control custom-form-control\" id=\"accountHolder\" required\r\n                        [(ngModel)]=\"enrollementPayload.bankDetails.accountHolderName\"  (ngModelChange)=\"validateForm('ACCOUNT_HOLDER_NAME')\" [class.error-border]=\"!validObject['ACCOUNT_HOLDER_NAME']\">\r\n                </div>\r\n                <div class=\"col-md-6\">\r\n                    <label for=\"accountNumber\" class=\"form-label\">Account Number <span class=\"required\">*</span></label>\r\n                    <input type=\"text\" class=\"form-control custom-form-control\" id=\"accountNumber\" required\r\n                        [(ngModel)]=\"enrollementPayload.bankDetails.accountNumber\" (ngModelChange)=\"validateForm('ACCOUNT_NUMBER')\" [class.error-border]=\"!validObject['ACCOUNT_NUMBER']\">\r\n                </div>\r\n            </div>\r\n\r\n            <div class=\"row mb-3\">\r\n                <div class=\"col-md-6\">\r\n                    <label for=\"bankName\" class=\"form-label\">Bank Name <span class=\"required\">*</span></label>\r\n                    <input type=\"text\" class=\"form-control custom-form-control\" id=\"bankName\" required\r\n                        [(ngModel)]=\"enrollementPayload.bankDetails.bankName\" (ngModelChange)=\"validateForm('BANK_NAME')\" [class.error-border]=\"!validObject['BANK_NAME']\">\r\n                </div>\r\n                <div class=\"col-md-6\">\r\n                    <label for=\"ifscCode\" class=\"form-label\">IFSC Code <span class=\"required\">*</span></label>\r\n                    <input type=\"text\" class=\"form-control custom-form-control\" id=\"ifscCode\" required\r\n                        [(ngModel)]=\"enrollementPayload.bankDetails.ifscCode\" (ngModelChange)=\"validateForm('IFSC_CODE')\"   [class.error-border]=\"!validObject['IFSC_CODE']\">\r\n                </div>\r\n            </div>\r\n            <div class=\"d-grid mt-4\">\r\n                <button type=\"submit\" class=\"btn btn-submit\" (click)=\"createEnrollment()\"\r\n                    [appButtonEditor]=\"edit ?? false\" simpoButtonDirective [buttonStyle]=\"getButtonStyle(0)\"\r\n                    [buttonId]=\"getButtonId(0)\" [sectionId]=\"data?.id\" [id]=\"data?.id+getButtonId(0)\"\r\n                    [buttonData]=\"getButtonContent(0)\">Submit\r\n                    Enrollment</button>\r\n            </div>\r\n        </div>\r\n    </div>\r\n    <div class=\"container-fluid d-flex justify-content-center align-items-center min-vh-100\" *ngIf=\"page === 'PAYMENT'\">\r\n        <div class=\"card shadow-lg border-0 payment-card\">\r\n            <div class=\"card-header bg-primary text-white text-center py-3\">\r\n                <h2 class=\"card-title mb-0\">\r\n                    <i class=\"fas fa-credit-card me-2\"></i>\r\n                    Payment Simulation\r\n                </h2>\r\n            </div>\r\n\r\n            <div class=\"card-body p-4\">\r\n                <div class=\"row g-3 mb-4\">\r\n                    <div class=\"col-6\">\r\n                        <button class=\"btn btn-success btn-lg w-100 payment-btn\" (click)=\"simulatePayment('success')\"\r\n                            [disabled]=\"isProcessing\">\r\n                            <i class=\"fas fa-check-circle me-2\"></i>\r\n                            <span class=\"btn-text\">Success</span>\r\n                            <div class=\"btn-overlay\"></div>\r\n                        </button>\r\n                    </div>\r\n                    <div class=\"col-6\">\r\n                        <button class=\"btn btn-danger btn-lg w-100 payment-btn\" (click)=\"simulatePayment('failure')\"\r\n                            [disabled]=\"isProcessing\">\r\n                            <i class=\"fas fa-times-circle me-2\"></i>\r\n                            <span class=\"btn-text\">Failure</span>\r\n                            <div class=\"btn-overlay\"></div>\r\n                        </button>\r\n                    </div>\r\n                </div>\r\n\r\n                <div *ngIf=\"isProcessing\" class=\"text-center mb-3\">\r\n                    <div class=\"d-flex justify-content-center align-items-center\">\r\n                        <div class=\"spinner-border text-primary me-2\" role=\"status\">\r\n                            <span class=\"visually-hidden\">Loading...</span>\r\n                        </div>\r\n                        <span class=\"text-muted\">Processing payment...</span>\r\n                    </div>\r\n                </div>\r\n\r\n                <div *ngIf=\"result\" class=\"alert alert-dismissible fade\" [ngClass]=\"{\r\n              'alert-success': result.type === 'success', \r\n              'alert-danger': result.type === 'failure',\r\n              'show': showResult\r\n            }\" role=\"alert\">\r\n                    <i [class]=\"result.iconClass + ' me-2'\"></i>\r\n                    <strong>{{ result.title }}</strong> {{ result.message }}\r\n                </div>\r\n            </div>\r\n\r\n            <div class=\"card-footer bg-light text-center py-3\">\r\n                <small class=\"text-muted\">\r\n                    <i class=\"fas fa-info-circle me-1\"></i>\r\n                    Click buttons to simulate payment scenarios\r\n                </small>\r\n            </div>\r\n        </div>\r\n    </div>\r\n    <div [ngClass]=\"{'hover_effect': edit}\" *ngIf=\"showEditors\">\r\n        <simpo-hover-elements [data]=\"data\" [index]=\"index\" [editOptions]=\"edit\"></simpo-hover-elements>\r\n    </div>\r\n\r\n    <div *ngIf=\"showDelete\" [ngClass]=\"{'hover_effect': delete}\">\r\n        <simpo-delete-hover-element [data]=\"data\" [index]=\"index\"></simpo-delete-hover-element>\r\n    </div>\r\n</div>"]}