simpo-component-library 3.0.33 → 3.0.35

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.
Files changed (26) hide show
  1. package/esm2022/lib/elements/payment-confirmation/payment-confirmation.component.mjs +14 -6
  2. package/esm2022/lib/elements/portfolio/portfolio.component.mjs +8 -3
  3. package/esm2022/lib/elements/properties/properties.component.mjs +4 -3
  4. package/esm2022/lib/elements/property-view/property-view.component.mjs +3 -3
  5. package/esm2022/lib/pipes/amount.pipe.mjs +2 -2
  6. package/esm2022/lib/sections/kyc-details/kyc-details.component.mjs +2 -2
  7. package/esm2022/lib/sections/profile-section/profile-section.component.mjs +10 -4
  8. package/esm2022/lib/sections/property-detail/property-detail.component.mjs +30 -12
  9. package/esm2022/lib/sections/signup-signin/signup-signin.component.mjs +10 -9
  10. package/fesm2022/simpo-component-library.mjs +102 -67
  11. package/fesm2022/simpo-component-library.mjs.map +1 -1
  12. package/lib/directive/background-directive.d.ts +1 -1
  13. package/lib/directive/button-directive.directive.d.ts +1 -1
  14. package/lib/directive/color.directive.d.ts +1 -1
  15. package/lib/elements/payment-confirmation/payment-confirmation.component.d.ts +1 -0
  16. package/lib/elements/portfolio/portfolio.component.d.ts +2 -0
  17. package/lib/sections/banner-carousel/banner-carousel.component.d.ts +2 -2
  18. package/lib/sections/carousel-banner/carousel-banner.component.d.ts +1 -1
  19. package/lib/sections/image-section/image-section.component.d.ts +2 -2
  20. package/lib/sections/logo-showcase/logo-showcase.component.d.ts +1 -1
  21. package/lib/sections/pricing-section/pricing-section.component.d.ts +1 -1
  22. package/lib/sections/profile-section/profile-section.component.d.ts +2 -0
  23. package/lib/sections/property-detail/property-detail.component.d.ts +2 -0
  24. package/package.json +1 -1
  25. package/simpo-component-library-3.0.35.tgz +0 -0
  26. package/simpo-component-library-3.0.33.tgz +0 -0
@@ -50,7 +50,7 @@ export class KycDetailsComponent {
50
50
  if (res.message) {
51
51
  this.isPanVerified = res.message.panVerified === 'VALID';
52
52
  this.isAadharverified = res.message.aadhaarVerified === 'VALID';
53
- this.aadharRequest.aadhaarNumber = res.message.aadharNo;
53
+ this.aadharRequest.aadhaarNumber = res.message.aadhaarNumber;
54
54
  this.panRequest.panNumber = res.message.panNo;
55
55
  }
56
56
  }, (err) => {
@@ -160,4 +160,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.4", ngImpor
160
160
  }], ctorParameters: () => [{ type: i1.RestService }, { type: i2.MessageService }, { type: i3.Router }, { type: i4.MatDialogRef, decorators: [{
161
161
  type: Optional
162
162
  }] }] });
163
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kyc-details.component.js","sourceRoot":"","sources":["../../../../../../projects/simpo-ui/src/lib/sections/kyc-details/kyc-details.component.ts","../../../../../../projects/simpo-ui/src/lib/sections/kyc-details/kyc-details.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { Component, Optional } from '@angular/core';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { RestService } from '../../services/rest.service';\r\nimport { MessageService } from 'primeng/api';\r\nimport { Subscription } from 'rxjs';\r\nimport { Router } from '@angular/router';\r\nimport { MatProgressSpinnerModule } from '@angular/material/progress-spinner';\r\nimport { ToastModule } from 'primeng/toast';\r\nimport { MatDialogRef } from '@angular/material/dialog';\r\n\r\n@Component({\r\n  selector: 'simpo-kyc-details',\r\n  standalone: true,\r\n  imports: [MatIconModule, CommonModule, FormsModule, MatProgressSpinnerModule, ToastModule],\r\n  providers: [MessageService],\r\n  templateUrl: './kyc-details.component.html',\r\n  styleUrl: './kyc-details.component.css'\r\n})\r\nexport class KycDetailsComponent {\r\n  constructor(private restService: RestService,\r\n    private readonly messageService: MessageService,\r\n    private router: Router,\r\n    @Optional() private readonly dialogRef: MatDialogRef<KycDetailsComponent>\r\n  ) {}\r\n\r\n  panRequest: any = {\r\n    panNumber: ''\r\n  }\r\n\r\n  aadharRequest: any = {\r\n    aadhaarNumber: ''\r\n  }\r\n\r\n  verifyAadharRequest: any = {\r\n    otp: '',\r\n    refId: '',\r\n    aadhaarNumber: ''\r\n  }\r\n  aadharOtpArray = new Array(6).fill('')\r\n  isPanVerified: boolean = false;\r\n  isAadharverified: boolean = false;\r\n  aadharOtpSent: boolean = false;\r\n  panVerifyLoader: boolean = false;\r\n  aadharVerifyLoader: boolean = false;\r\n  kycDetailsSubscription?: Subscription;\r\n\r\n  ngOnInit() {\r\n    this.getKycDetails();\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.kycDetailsSubscription?.unsubscribe();\r\n  }\r\n\r\n  getKycDetails() {\r\n    this.kycDetailsSubscription = this.restService.getKycDetails().subscribe((res: any) => {\r\n      if(res.message) {\r\n        this.isPanVerified = res.message.panVerified === 'VALID';\r\n        this.isAadharverified = res.message.aadhaarVerified === 'VALID';\r\n        this.aadharRequest.aadhaarNumber = res.message.aadharNo\r\n        this.panRequest.panNumber = res.message.panNo;\r\n      }\r\n    }, (err) => {\r\n\r\n    })\r\n  }\r\n\r\n  verifyPanNumber() {\r\n    this.panVerifyLoader = true;\r\n    if(!this.validatePan()) {\r\n      this.messageService.add({\r\n        severity: 'error',\r\n        summary: 'Pan Number',\r\n        detail: 'Enter valid PAN number'\r\n      });\r\n      this.panVerifyLoader = false;\r\n      return;\r\n    }\r\n    this.restService.verifyPan(this.panRequest).subscribe((res: any) => {\r\n      this.isPanVerified = true;\r\n      this.restService.kycDetails = null;\r\n      this.panVerifyLoader = false;;\r\n      this.checkKycVerification();\r\n    }, () => {\r\n      this.panVerifyLoader = false;\r\n    })\r\n  }\r\n\r\n  validatePan(): boolean {\r\n    const panRegex = /^[A-Z]{5}[0-9]{4}[A-Z]$/;\r\n    return panRegex.test(this.panRequest.panNumber);\r\n  }\r\n\r\n  sendAadharOtp() {\r\n    this.aadharVerifyLoader = true;\r\n    if(!this.validateAadhaar()) {\r\n      this.messageService.add({\r\n        severity: 'error',\r\n        summary: 'Aadhar Number',\r\n        detail: 'Enter valid Aadhar number'\r\n      });\r\n      this.aadharVerifyLoader = false;\r\n      return;\r\n    }\r\n\r\n    this.restService.sendAadharOtp(this.aadharRequest).subscribe((res: any) => {\r\n      this.aadharOtpSent = true;\r\n      this.messageService.add({\r\n        severity: 'success',\r\n        summary: 'OTP Sent',\r\n        detail: 'AAdhar OTP Sent in registered mobile number'\r\n      });\r\n      this.aadharVerifyLoader = false;\r\n      this.verifyAadharRequest.refId = res.message?.ref_id;\r\n    },() => {\r\n      this.aadharVerifyLoader = false;\r\n    })\r\n  }\r\n\r\n  verifyAadharOtp() {\r\n    this.aadharVerifyLoader = true;\r\n    this.verifyAadharRequest.otp = \"\";\r\n    this.aadharOtpArray.forEach((otp) => {\r\n      this.verifyAadharRequest.otp += otp\r\n    })\r\n    this.verifyAadharRequest.aadhaarNumber = this.aadharRequest.aadhaarNumber;\r\n\r\n    this.restService.verifyAadharOtp(this.verifyAadharRequest).subscribe((res: any) => {\r\n      this.isAadharverified = true;\r\n      this.restService.kycDetails = null;\r\n      this.aadharVerifyLoader = false;\r\n      this.checkKycVerification();\r\n    }, () => {\r\n      this.aadharVerifyLoader = false;\r\n    })\r\n  }\r\n\r\n  validateAadhaar(): boolean {\r\n    const aadhaarRegex = /^[2-9]{1}[0-9]{11}$/;\r\n    return aadhaarRegex.test(this.aadharRequest.aadhaarNumber);\r\n  }\r\n\r\n  moveAadharOtpCursor(event: any, idx: number) {\r\n\r\n    if (isNaN(Number(event.key)) && event.code != \"Backspace\")\r\n      return;\r\n\r\n    if (event.code != \"Backspace\") {\r\n      this.aadharOtpArray[idx] = event.key;\r\n      document.getElementById(\"aadharOtp_\" + (idx + 1))?.focus();\r\n    }\r\n    if (event.code == \"Backspace\" && !this.aadharOtpArray[idx]) {\r\n      document.getElementById(\"aadharOtp_\" + (idx - 1))?.focus();\r\n    }\r\n  }\r\n\r\n  checkKycVerification() {\r\n    if(this.isAadharverified && this.isPanVerified) {\r\n      document.getElementById('closeKycCanvas')?.click()\r\n      this.dialogRef?.close();\r\n    }\r\n  }\r\n\r\n  closeDialog() {\r\n    this.dialogRef?.close();\r\n  }\r\n\r\n  redirectToProductList() {\r\n    this.router.navigate(['property-list'])\r\n  }\r\n\r\n  get isMobile() {\r\n    return window.innerWidth <= 475;\r\n  }\r\n}\r\n","<p-toast position=\"bottom-right\" [baseZIndex]=\"10000000000\" [autoZIndex]=\"true\"\r\n    [showTransformOptions]=\"isMobile ? 'translateY(-100%)' : ''\"></p-toast>\r\n\r\n<section class=\"main-section\">\r\n  <div class=\"display-center\" *ngIf=\"!(isPanVerified && isAadharverified)\">\r\n    <img class=\"img\" src=\"https://prod-simpo.s3.ap-south-1.amazonaws.com/prod-images/970332c1740030187726kyc.png\"\r\n      alt=\"\">\r\n    <div class=\"text-group\">\r\n      <p class=\"heading\">Complete Your KYC to start Investing</p>\r\n      <p class=\"desc\">Before you can invest, we need to verify your identity, simply upload your documents,\r\n        <br> submit your KYC, and let us handle the rest\r\n      </p>\r\n    </div>\r\n    <button class=\"submit-btn\" type=\"button\" data-bs-toggle=\"offcanvas\" data-bs-target=\"#offcanvasRight\"\r\n      aria-controls=\"offcanvasRight\">Submit KYC Now</button>\r\n  </div>\r\n  <div *ngIf=\"isPanVerified && isAadharverified\" class=\"display-center\">\r\n    <div class=\"w-50\">\r\n      <div class=\"secured\">\r\n        <mat-icon>security</mat-icon>\r\n        <p>Your Data is Safe & Secure</p>\r\n      </div>\r\n\r\n      <div class=\"mt-2\">\r\n        <div class=\"d-flex justify-space\">\r\n          <label for=\"\">PAN Number</label>\r\n        </div>\r\n        <div class=\"input-box\">\r\n          <input type=\"text\" [(ngModel)]=\"panRequest.panNumber\" disabled>\r\n          <mat-icon class=\"verified\" title=\"OTP Verified\">check_circle</mat-icon>\r\n        </div>\r\n      </div>\r\n      <div class=\"mt-1\">\r\n        <div class=\"d-flex justify-space\">\r\n          <label for=\"\">Aadhar Number</label>\r\n        </div>\r\n        <div class=\"input-box\">\r\n          <input type=\"text\" [(ngModel)]=\"aadharRequest.aadhaarNumber\" disabled>\r\n          <mat-icon class=\"verified\" title=\"OTP Verified\">check_circle</mat-icon>\r\n        </div>\r\n      </div>\r\n\r\n      <div class=\"mt-15 text-center\">\r\n        <button class=\"submit-btn\" (click)=\"redirectToProductList()\">Let's Grow Wealth</button>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</section>\r\n\r\n<div class=\"offcanvas offcanvas-end\" tabindex=\"-1\" id=\"offcanvasRight\" aria-labelledby=\"offcanvasRightLabel\">\r\n  <div class=\"header\">\r\n    <p>KYC Details</p>\r\n  </div>\r\n  <div class=\"middle-section\">\r\n    <div class=\"body\">\r\n      <div class=\"secured\">\r\n        <mat-icon>security</mat-icon>\r\n        <p>Your Data is Safe & Secure</p>\r\n      </div>\r\n\r\n      <div class=\"mt-2\">\r\n        <div class=\"d-flex justify-space\">\r\n          <label for=\"\">PAN Number</label>\r\n          <p class=\"verify-text\" (click)=\"verifyPanNumber()\" *ngIf=\"!isPanVerified && !panVerifyLoader\">Verify</p>\r\n          <div *ngIf=\"panVerifyLoader\" class=\"kyc-detail\"><mat-spinner></mat-spinner></div>\r\n        </div>\r\n        <div class=\"input-box\">\r\n          <input type=\"text\" [(ngModel)]=\"panRequest.panNumber\" [disabled]=\"isPanVerified\">\r\n          <mat-icon class=\"verified\" title=\"OTP Verified\" *ngIf=\"isPanVerified\">check_circle</mat-icon>\r\n        </div>\r\n      </div>\r\n      <div class=\"mt-1\">\r\n        <div class=\"d-flex justify-space\">\r\n          <label for=\"\">Aadhar Number</label>\r\n          <p class=\"verify-text\" (click)=\"sendAadharOtp()\" *ngIf=\"!aadharOtpSent && !aadharVerifyLoader\">Send OTP</p>\r\n          <div *ngIf=\"aadharVerifyLoader && !aadharOtpSent\" class=\"kyc-detail\"><mat-spinner></mat-spinner></div>\r\n        </div>\r\n        <div class=\"input-box\">\r\n          <input type=\"text\" [(ngModel)]=\"aadharRequest.aadhaarNumber\" [disabled]=\"isAadharverified\">\r\n          <mat-icon class=\"verified\" title=\"OTP Verified\" *ngIf=\"aadharOtpSent\">check_circle</mat-icon>\r\n        </div>\r\n      </div>\r\n      <div class=\"mt-1\" *ngIf=\"aadharOtpSent\">\r\n        <label for=\"\">Enter OTP</label>\r\n\r\n        <div id=\"otp\" class=\"otp-input\">\r\n          <ng-container *ngFor=\"let otp of [1,2,3,4,5,6]; let idx = index\">\r\n            <input type=\"number\" max=\"9\" class=\"otp-input\" [(ngModel)]=\"aadharOtpArray[idx]\"\r\n              (keyup)=\"moveAadharOtpCursor($event, idx)\" [id]=\"'aadharOtp_'+idx\" />\r\n          </ng-container>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  </div>\r\n  <div class=\"footer\">\r\n    <button class=\"cancel-btn\" data-bs-dismiss=\"offcanvas\" id=\"closeKycCanvas\" (click)=\"closeDialog()\">Cancel</button>\r\n    <button class=\"submit-btn\" *ngIf=\"aadharOtpSent && !aadharVerifyLoader\" (click)=\"verifyAadharOtp()\">Verify</button>\r\n    <button class=\"d-flex submit-btn\" *ngIf=\"aadharVerifyLoader && aadharOtpSent\">\r\n      <mat-spinner></mat-spinner> Verifying\r\n    </button>\r\n  </div>\r\n</div>\r\n"]}
163
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kyc-details.component.js","sourceRoot":"","sources":["../../../../../../projects/simpo-ui/src/lib/sections/kyc-details/kyc-details.component.ts","../../../../../../projects/simpo-ui/src/lib/sections/kyc-details/kyc-details.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { Component, Optional } from '@angular/core';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport { RestService } from '../../services/rest.service';\r\nimport { MessageService } from 'primeng/api';\r\nimport { Subscription } from 'rxjs';\r\nimport { Router } from '@angular/router';\r\nimport { MatProgressSpinnerModule } from '@angular/material/progress-spinner';\r\nimport { ToastModule } from 'primeng/toast';\r\nimport { MatDialogRef } from '@angular/material/dialog';\r\n\r\n@Component({\r\n  selector: 'simpo-kyc-details',\r\n  standalone: true,\r\n  imports: [MatIconModule, CommonModule, FormsModule, MatProgressSpinnerModule, ToastModule],\r\n  providers: [MessageService],\r\n  templateUrl: './kyc-details.component.html',\r\n  styleUrl: './kyc-details.component.css'\r\n})\r\nexport class KycDetailsComponent {\r\n  constructor(private restService: RestService,\r\n    private readonly messageService: MessageService,\r\n    private router: Router,\r\n    @Optional() private readonly dialogRef: MatDialogRef<KycDetailsComponent>\r\n  ) {}\r\n\r\n  panRequest: any = {\r\n    panNumber: ''\r\n  }\r\n\r\n  aadharRequest: any = {\r\n    aadhaarNumber: ''\r\n  }\r\n\r\n  verifyAadharRequest: any = {\r\n    otp: '',\r\n    refId: '',\r\n    aadhaarNumber: ''\r\n  }\r\n  aadharOtpArray = new Array(6).fill('')\r\n  isPanVerified: boolean = false;\r\n  isAadharverified: boolean = false;\r\n  aadharOtpSent: boolean = false;\r\n  panVerifyLoader: boolean = false;\r\n  aadharVerifyLoader: boolean = false;\r\n  kycDetailsSubscription?: Subscription;\r\n\r\n  ngOnInit() {\r\n    this.getKycDetails();\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.kycDetailsSubscription?.unsubscribe();\r\n  }\r\n\r\n  getKycDetails() {\r\n    this.kycDetailsSubscription = this.restService.getKycDetails().subscribe((res: any) => {\r\n      if(res.message) {\r\n        this.isPanVerified = res.message.panVerified === 'VALID';\r\n        this.isAadharverified = res.message.aadhaarVerified === 'VALID';\r\n        this.aadharRequest.aadhaarNumber = res.message.aadhaarNumber\r\n        this.panRequest.panNumber = res.message.panNo;\r\n      }\r\n    }, (err) => {\r\n\r\n    })\r\n  }\r\n\r\n  verifyPanNumber() {\r\n    this.panVerifyLoader = true;\r\n    if(!this.validatePan()) {\r\n      this.messageService.add({\r\n        severity: 'error',\r\n        summary: 'Pan Number',\r\n        detail: 'Enter valid PAN number'\r\n      });\r\n      this.panVerifyLoader = false;\r\n      return;\r\n    }\r\n    this.restService.verifyPan(this.panRequest).subscribe((res: any) => {\r\n      this.isPanVerified = true;\r\n      this.restService.kycDetails = null;\r\n      this.panVerifyLoader = false;;\r\n      this.checkKycVerification();\r\n    }, () => {\r\n      this.panVerifyLoader = false;\r\n    })\r\n  }\r\n\r\n  validatePan(): boolean {\r\n    const panRegex = /^[A-Z]{5}[0-9]{4}[A-Z]$/;\r\n    return panRegex.test(this.panRequest.panNumber);\r\n  }\r\n\r\n  sendAadharOtp() {\r\n    this.aadharVerifyLoader = true;\r\n    if(!this.validateAadhaar()) {\r\n      this.messageService.add({\r\n        severity: 'error',\r\n        summary: 'Aadhar Number',\r\n        detail: 'Enter valid Aadhar number'\r\n      });\r\n      this.aadharVerifyLoader = false;\r\n      return;\r\n    }\r\n\r\n    this.restService.sendAadharOtp(this.aadharRequest).subscribe((res: any) => {\r\n      this.aadharOtpSent = true;\r\n      this.messageService.add({\r\n        severity: 'success',\r\n        summary: 'OTP Sent',\r\n        detail: 'AAdhar OTP Sent in registered mobile number'\r\n      });\r\n      this.aadharVerifyLoader = false;\r\n      this.verifyAadharRequest.refId = res.message?.ref_id;\r\n    },() => {\r\n      this.aadharVerifyLoader = false;\r\n    })\r\n  }\r\n\r\n  verifyAadharOtp() {\r\n    this.aadharVerifyLoader = true;\r\n    this.verifyAadharRequest.otp = \"\";\r\n    this.aadharOtpArray.forEach((otp) => {\r\n      this.verifyAadharRequest.otp += otp\r\n    })\r\n    this.verifyAadharRequest.aadhaarNumber = this.aadharRequest.aadhaarNumber;\r\n\r\n    this.restService.verifyAadharOtp(this.verifyAadharRequest).subscribe((res: any) => {\r\n      this.isAadharverified = true;\r\n      this.restService.kycDetails = null;\r\n      this.aadharVerifyLoader = false;\r\n      this.checkKycVerification();\r\n    }, () => {\r\n      this.aadharVerifyLoader = false;\r\n    })\r\n  }\r\n\r\n  validateAadhaar(): boolean {\r\n    const aadhaarRegex = /^[2-9]{1}[0-9]{11}$/;\r\n    return aadhaarRegex.test(this.aadharRequest.aadhaarNumber);\r\n  }\r\n\r\n  moveAadharOtpCursor(event: any, idx: number) {\r\n\r\n    if (isNaN(Number(event.key)) && event.code != \"Backspace\")\r\n      return;\r\n\r\n    if (event.code != \"Backspace\") {\r\n      this.aadharOtpArray[idx] = event.key;\r\n      document.getElementById(\"aadharOtp_\" + (idx + 1))?.focus();\r\n    }\r\n    if (event.code == \"Backspace\" && !this.aadharOtpArray[idx]) {\r\n      document.getElementById(\"aadharOtp_\" + (idx - 1))?.focus();\r\n    }\r\n  }\r\n\r\n  checkKycVerification() {\r\n    if(this.isAadharverified && this.isPanVerified) {\r\n      document.getElementById('closeKycCanvas')?.click()\r\n      this.dialogRef?.close();\r\n    }\r\n  }\r\n\r\n  closeDialog() {\r\n    this.dialogRef?.close();\r\n  }\r\n\r\n  redirectToProductList() {\r\n    this.router.navigate(['property-list'])\r\n  }\r\n\r\n  get isMobile() {\r\n    return window.innerWidth <= 475;\r\n  }\r\n}\r\n","<p-toast position=\"bottom-right\" [baseZIndex]=\"10000000000\" [autoZIndex]=\"true\"\r\n    [showTransformOptions]=\"isMobile ? 'translateY(-100%)' : ''\"></p-toast>\r\n\r\n<section class=\"main-section\">\r\n  <div class=\"display-center\" *ngIf=\"!(isPanVerified && isAadharverified)\">\r\n    <img class=\"img\" src=\"https://prod-simpo.s3.ap-south-1.amazonaws.com/prod-images/970332c1740030187726kyc.png\"\r\n      alt=\"\">\r\n    <div class=\"text-group\">\r\n      <p class=\"heading\">Complete Your KYC to start Investing</p>\r\n      <p class=\"desc\">Before you can invest, we need to verify your identity, simply upload your documents,\r\n        <br> submit your KYC, and let us handle the rest\r\n      </p>\r\n    </div>\r\n    <button class=\"submit-btn\" type=\"button\" data-bs-toggle=\"offcanvas\" data-bs-target=\"#offcanvasRight\"\r\n      aria-controls=\"offcanvasRight\">Submit KYC Now</button>\r\n  </div>\r\n  <div *ngIf=\"isPanVerified && isAadharverified\" class=\"display-center\">\r\n    <div class=\"w-50\">\r\n      <div class=\"secured\">\r\n        <mat-icon>security</mat-icon>\r\n        <p>Your Data is Safe & Secure</p>\r\n      </div>\r\n\r\n      <div class=\"mt-2\">\r\n        <div class=\"d-flex justify-space\">\r\n          <label for=\"\">PAN Number</label>\r\n        </div>\r\n        <div class=\"input-box\">\r\n          <input type=\"text\" [(ngModel)]=\"panRequest.panNumber\" disabled>\r\n          <mat-icon class=\"verified\" title=\"OTP Verified\">check_circle</mat-icon>\r\n        </div>\r\n      </div>\r\n      <div class=\"mt-1\">\r\n        <div class=\"d-flex justify-space\">\r\n          <label for=\"\">Aadhar Number</label>\r\n        </div>\r\n        <div class=\"input-box\">\r\n          <input type=\"text\" [(ngModel)]=\"aadharRequest.aadhaarNumber\" disabled>\r\n          <mat-icon class=\"verified\" title=\"OTP Verified\">check_circle</mat-icon>\r\n        </div>\r\n      </div>\r\n\r\n      <div class=\"mt-15 text-center\">\r\n        <button class=\"submit-btn\" (click)=\"redirectToProductList()\">Let's Grow Wealth</button>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</section>\r\n\r\n<div class=\"offcanvas offcanvas-end\" tabindex=\"-1\" id=\"offcanvasRight\" aria-labelledby=\"offcanvasRightLabel\">\r\n  <div class=\"header\">\r\n    <p>KYC Details</p>\r\n  </div>\r\n  <div class=\"middle-section\">\r\n    <div class=\"body\">\r\n      <div class=\"secured\">\r\n        <mat-icon>security</mat-icon>\r\n        <p>Your Data is Safe & Secure</p>\r\n      </div>\r\n\r\n      <div class=\"mt-2\">\r\n        <div class=\"d-flex justify-space\">\r\n          <label for=\"\">PAN Number</label>\r\n          <p class=\"verify-text\" (click)=\"verifyPanNumber()\" *ngIf=\"!isPanVerified && !panVerifyLoader\">Verify</p>\r\n          <div *ngIf=\"panVerifyLoader\" class=\"kyc-detail\"><mat-spinner></mat-spinner></div>\r\n        </div>\r\n        <div class=\"input-box\">\r\n          <input type=\"text\" [(ngModel)]=\"panRequest.panNumber\" [disabled]=\"isPanVerified\">\r\n          <mat-icon class=\"verified\" title=\"OTP Verified\" *ngIf=\"isPanVerified\">check_circle</mat-icon>\r\n        </div>\r\n      </div>\r\n      <div class=\"mt-1\">\r\n        <div class=\"d-flex justify-space\">\r\n          <label for=\"\">Aadhar Number</label>\r\n          <p class=\"verify-text\" (click)=\"sendAadharOtp()\" *ngIf=\"!aadharOtpSent && !aadharVerifyLoader\">Send OTP</p>\r\n          <div *ngIf=\"aadharVerifyLoader && !aadharOtpSent\" class=\"kyc-detail\"><mat-spinner></mat-spinner></div>\r\n        </div>\r\n        <div class=\"input-box\">\r\n          <input type=\"text\" [(ngModel)]=\"aadharRequest.aadhaarNumber\" [disabled]=\"isAadharverified\">\r\n          <mat-icon class=\"verified\" title=\"OTP Verified\" *ngIf=\"aadharOtpSent\">check_circle</mat-icon>\r\n        </div>\r\n      </div>\r\n      <div class=\"mt-1\" *ngIf=\"aadharOtpSent\">\r\n        <label for=\"\">Enter OTP</label>\r\n\r\n        <div id=\"otp\" class=\"otp-input\">\r\n          <ng-container *ngFor=\"let otp of [1,2,3,4,5,6]; let idx = index\">\r\n            <input type=\"number\" max=\"9\" class=\"otp-input\" [(ngModel)]=\"aadharOtpArray[idx]\"\r\n              (keyup)=\"moveAadharOtpCursor($event, idx)\" [id]=\"'aadharOtp_'+idx\" />\r\n          </ng-container>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  </div>\r\n  <div class=\"footer\">\r\n    <button class=\"cancel-btn\" data-bs-dismiss=\"offcanvas\" id=\"closeKycCanvas\" (click)=\"closeDialog()\">Cancel</button>\r\n    <button class=\"submit-btn\" *ngIf=\"aadharOtpSent && !aadharVerifyLoader\" (click)=\"verifyAadharOtp()\">Verify</button>\r\n    <button class=\"d-flex submit-btn\" *ngIf=\"aadharVerifyLoader && aadharOtpSent\">\r\n      <mat-spinner></mat-spinner> Verifying\r\n    </button>\r\n  </div>\r\n</div>\r\n"]}
@@ -8,13 +8,17 @@ import { NeedHelpComponent } from '../../elements/need-help/need-help.component'
8
8
  import { MatIcon } from '@angular/material/icon';
9
9
  import { CommonModule } from '@angular/common';
10
10
  import { KycDetailsComponent } from '../kyc-details/kyc-details.component';
11
+ import { NgxSkeletonLoaderModule } from 'ngx-skeleton-loader';
11
12
  import * as i0 from "@angular/core";
12
13
  import * as i1 from "../../services/rest.service";
13
14
  import * as i2 from "@angular/common";
15
+ import * as i3 from "ngx-skeleton-loader";
14
16
  export class ProfileSectionComponent {
15
17
  constructor(restService) {
16
18
  this.restService = restService;
17
19
  this.selectedPanel = "PORTFOLIO";
20
+ this.skelLoader = true;
21
+ this.skelArray = Array(2);
18
22
  this.sidePanelTabs = [
19
23
  { value: "PORTFOLIO", viewValue: "My Portfolio" },
20
24
  { value: "PROPERTIES", viewValue: "My Properties" },
@@ -29,8 +33,10 @@ export class ProfileSectionComponent {
29
33
  this.getInvestorDetails();
30
34
  }
31
35
  getInvestorDetails() {
36
+ this.skelLoader = true;
32
37
  this.restService.getInvesterById().subscribe((res) => {
33
38
  this.investorDetails = res.message;
39
+ this.skelLoader = false;
34
40
  });
35
41
  }
36
42
  getInitials() {
@@ -39,14 +45,14 @@ export class ProfileSectionComponent {
39
45
  return initials;
40
46
  }
41
47
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: ProfileSectionComponent, deps: [{ token: i1.RestService }], target: i0.ɵɵFactoryTarget.Component }); }
42
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.4", type: ProfileSectionComponent, isStandalone: true, selector: "simpo-profile-section", inputs: { data: "data" }, ngImport: i0, template: "<section class=\"main-container d-flex justify-content-center\">\r\n <div class=\"side-panel\">\r\n <div class=\"details\">\r\n <div class=\"left-right d-flex align-items-center gap-10\">\r\n <div class=\"logo left w-15\">{{ getInitials() }}</div><div class=\"right name w-85\">{{investorDetails?.fullName || 'N/A'}}</div>\r\n </div>\r\n <div class=\"left-right d-flex align-items-center gap-10\">\r\n <div class=\"left w-15\"><mat-icon class=\"d-flex align-items-center justify-content-center f-18\"> phone</mat-icon>\r\n </div><div class=\"right w-80\">{{investorDetails?.phoneNumber || 'N/A'}}</div>\r\n </div>\r\n <div class=\"left-right d-flex align-items-center gap-10\">\r\n <div class=\"left w-15\"><mat-icon class=\" d-flex align-items-center justify-content-center f-18\"> email</mat-icon>\r\n </div><div class=\"right w-80\">{{investorDetails?.emailId || 'N/A'}}</div>\r\n </div>\r\n </div>\r\n <div class=\"tab-section\">\r\n <div class=\"tabs cursor-pointer\" *ngFor=\"let ele of sidePanelTabs\" (click)=\"selectedPanel = ele.value\" [class.activeTab]=\"selectedPanel == ele.value\">\r\n {{ele.viewValue}}\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"display-section\">\r\n <ng-container *ngIf=\"selectedPanel == 'KYC'\">\r\n <simpo-kyc-details></simpo-kyc-details>\r\n </ng-container>\r\n <ng-container *ngIf=\"selectedPanel == 'PORTFOLIO'\">\r\n <simpo-portfolio></simpo-portfolio>\r\n </ng-container>\r\n <ng-container *ngIf=\"selectedPanel == 'PROPERTIES'\">\r\n <simpo-properties></simpo-properties>\r\n </ng-container>\r\n <ng-container *ngIf=\"selectedPanel == 'ORDERS'\">\r\n <simpo-my-orders></simpo-my-orders>\r\n </ng-container>\r\n <ng-container *ngIf=\"selectedPanel == 'DOCUMENTS'\">\r\n <simpo-my-documents></simpo-my-documents>\r\n </ng-container>\r\n <ng-container *ngIf=\"selectedPanel == 'STATEMENT'\">\r\n <simpo-my-statement></simpo-my-statement>\r\n </ng-container>\r\n <ng-container *ngIf=\"selectedPanel == 'HELP'\">\r\n <simpo-need-help></simpo-need-help>\r\n </ng-container>\r\n </div>\r\n</section>\r\n", styles: ["*{font-family:DM Sans}mat-icon{font-family:Material Icons!important}.main-container{height:100vh;width:100%;padding:10px 0;gap:15px;background:#f9fbff}.side-panel{width:18%;background:#fff;border:2px solid rgba(241,246,255,1);border-radius:10px}.display-section{width:60%}.w-15{width:15%}.w-85{width:85%}.cursor-pointer{cursor:pointer}.details{background:#19a6c6;border-radius:10px;padding:10px;margin:15px}.left-right{gap:10px;margin-bottom:10px}.logo{background:#e6f0ff;border-radius:50%;font-size:14px;text-align:center;font-weight:600;line-height:24px;padding:3px;color:#405071!important}.name{font-size:14px;font-weight:600;line-height:24px;color:#fff!important}.f-18{font-size:18px}.gap-10{gap:10px}.left{color:#fffc}.right{font-weight:500;font-size:14px;line-height:24px;color:#fffc}.tab-section{margin-top:15px}.tabs{margin-bottom:25px;font-weight:500;font-size:16px;line-height:24px;color:#01161e;margin-left:8px}.activeTab{border-left:8px solid rgba(248,169,56,1);font-weight:700!important;color:#219ebc;margin-right:15px;background:#f1f3f7;padding:10px;border-radius:0 6px 6px 0;margin-left:unset}@media only screen and (max-width: 475px){.display-section{width:95%}}\n"], dependencies: [{ kind: "component", type: PortfolioComponent, selector: "simpo-portfolio" }, { kind: "component", type: PropertiesComponent, selector: "simpo-properties" }, { kind: "component", type: MyDocumentsComponent, selector: "simpo-my-documents" }, { kind: "component", type: MyOrdersComponent, selector: "simpo-my-orders" }, { kind: "component", type: MyStatementComponent, selector: "simpo-my-statement" }, { kind: "component", type: NeedHelpComponent, selector: "simpo-need-help" }, { kind: "component", type: MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: KycDetailsComponent, selector: "simpo-kyc-details" }] }); }
48
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.4", type: ProfileSectionComponent, isStandalone: true, selector: "simpo-profile-section", inputs: { data: "data" }, ngImport: i0, template: "<section class=\"main-container d-flex justify-content-center\">\r\n <div class=\"side-panel\">\r\n <div class=\"details\">\r\n <div class=\"left-right d-flex align-items-center gap-10\" *ngIf=\"!skelLoader\">\r\n <div class=\"logo left w-15\">{{ getInitials() }}</div><div class=\"right name w-85\">{{investorDetails?.fullName || 'N/A'}}</div>\r\n </div>\r\n <div class=\"left-right d-flex align-items-center gap-10\" *ngIf=\"!skelLoader\">\r\n <div class=\"left w-15\"><mat-icon class=\"d-flex align-items-center justify-content-center f-18\"> phone</mat-icon>\r\n </div><div class=\"right w-80\">{{investorDetails?.phoneNumber || 'N/A'}}</div>\r\n </div>\r\n <div class=\"left-right d-flex align-items-center gap-10\" *ngIf=\"!skelLoader\">\r\n <div class=\"left w-15\"><mat-icon class=\" d-flex align-items-center justify-content-center f-18\"> email</mat-icon>\r\n </div><div class=\"right w-80\">{{investorDetails?.emailId || 'N/A'}}</div>\r\n </div>\r\n <div class=\"row\" *ngIf=\"skelLoader\">\r\n <div class=\"col-12\" >\r\n <ng-container *ngTemplateOutlet=\"skeleton\"></ng-container>\r\n </div>\r\n </div>\r\n </div>\r\n \r\n <div class=\"tab-section\">\r\n <div class=\"tabs cursor-pointer\" *ngFor=\"let ele of sidePanelTabs\" (click)=\"selectedPanel = ele.value\" [class.activeTab]=\"selectedPanel == ele.value\">\r\n {{ele.viewValue}}\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"display-section\">\r\n <ng-container *ngIf=\"selectedPanel == 'KYC'\">\r\n <simpo-kyc-details></simpo-kyc-details>\r\n </ng-container>\r\n <ng-container *ngIf=\"selectedPanel == 'PORTFOLIO'\">\r\n <simpo-portfolio></simpo-portfolio>\r\n </ng-container>\r\n <ng-container *ngIf=\"selectedPanel == 'PROPERTIES'\">\r\n <simpo-properties></simpo-properties>\r\n </ng-container>\r\n <ng-container *ngIf=\"selectedPanel == 'ORDERS'\">\r\n <simpo-my-orders></simpo-my-orders>\r\n </ng-container>\r\n <ng-container *ngIf=\"selectedPanel == 'DOCUMENTS'\">\r\n <simpo-my-documents></simpo-my-documents>\r\n </ng-container>\r\n <ng-container *ngIf=\"selectedPanel == 'STATEMENT'\">\r\n <simpo-my-statement></simpo-my-statement>\r\n </ng-container>\r\n <ng-container *ngIf=\"selectedPanel == 'HELP'\">\r\n <simpo-need-help></simpo-need-help>\r\n </ng-container>\r\n </div>\r\n</section>\r\n<ng-template #skeleton>\r\n <div class=\"wrapper-1\" >\r\n <ngx-skeleton-loader [theme]=\"{\r\n width: '15%',\r\n 'border-radius': '50%',\r\n height: '4vh',\r\n 'margin-bottom': '5px',\r\n 'margin-right': '5px'\r\n }\">\r\n </ngx-skeleton-loader>\r\n <ngx-skeleton-loader [theme]=\"{\r\n width: '80%',\r\n 'border-radius': '5px',\r\n height: '3vh',\r\n 'margin-bottom': '5px'\r\n }\">\r\n </ngx-skeleton-loader>\r\n \r\n </div> \r\n <div class=\"wrapper\" *ngFor=\"let item of skelArray\">\r\n <ngx-skeleton-loader [theme]=\"{\r\n width: '100%',\r\n 'border-radius': '5px',\r\n height: '3vh',\r\n 'margin-bottom': '5px'\r\n }\">\r\n </ngx-skeleton-loader>\r\n </div> \r\n</ng-template>\r\n", styles: ["*{font-family:DM Sans}mat-icon{font-family:Material Icons!important}.main-container{height:100vh;width:100%;padding:10px 0;gap:15px;background:#f9fbff}.side-panel{width:18%;background:#fff;border:2px solid rgba(241,246,255,1);border-radius:10px}.display-section{width:60%}.w-15{width:15%}.w-85{width:85%}.cursor-pointer{cursor:pointer}.details{background:#19a6c6;border-radius:10px;padding:10px;margin:15px}.left-right{gap:10px;margin-bottom:10px}.logo{background:#e6f0ff;border-radius:50%;font-size:14px;text-align:center;font-weight:600;line-height:24px;padding:3px;color:#405071!important}.name{font-size:14px;font-weight:600;line-height:24px;color:#fff!important}.f-18{font-size:18px}.gap-10{gap:10px}.left{color:#fffc}.right{font-weight:500;font-size:14px;line-height:24px;color:#fffc}.tab-section{margin-top:15px}.tabs{margin-bottom:25px;font-weight:500;font-size:16px;line-height:24px;color:#01161e;margin-left:8px}.activeTab{border-left:8px solid rgba(248,169,56,1);font-weight:700!important;color:#219ebc;margin-right:15px;background:#f1f3f7;padding:10px;border-radius:0 6px 6px 0;margin-left:unset}@media only screen and (max-width: 475px){.display-section{width:95%}}\n"], dependencies: [{ kind: "component", type: PortfolioComponent, selector: "simpo-portfolio" }, { kind: "component", type: PropertiesComponent, selector: "simpo-properties" }, { kind: "component", type: MyDocumentsComponent, selector: "simpo-my-documents" }, { kind: "component", type: MyOrdersComponent, selector: "simpo-my-orders" }, { kind: "component", type: MyStatementComponent, selector: "simpo-my-statement" }, { kind: "component", type: NeedHelpComponent, selector: "simpo-need-help" }, { kind: "component", type: MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: KycDetailsComponent, selector: "simpo-kyc-details" }, { kind: "ngmodule", type: NgxSkeletonLoaderModule }, { kind: "component", type: i3.NgxSkeletonLoaderComponent, selector: "ngx-skeleton-loader", inputs: ["count", "loadingText", "appearance", "animation", "ariaLabel", "theme"] }] }); }
43
49
  }
44
50
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.4", ngImport: i0, type: ProfileSectionComponent, decorators: [{
45
51
  type: Component,
46
52
  args: [{ selector: 'simpo-profile-section', standalone: true, imports: [PortfolioComponent, PropertiesComponent, MyDocumentsComponent, MyOrdersComponent, MyStatementComponent, NeedHelpComponent, MatIcon, CommonModule,
47
- KycDetailsComponent
48
- ], template: "<section class=\"main-container d-flex justify-content-center\">\r\n <div class=\"side-panel\">\r\n <div class=\"details\">\r\n <div class=\"left-right d-flex align-items-center gap-10\">\r\n <div class=\"logo left w-15\">{{ getInitials() }}</div><div class=\"right name w-85\">{{investorDetails?.fullName || 'N/A'}}</div>\r\n </div>\r\n <div class=\"left-right d-flex align-items-center gap-10\">\r\n <div class=\"left w-15\"><mat-icon class=\"d-flex align-items-center justify-content-center f-18\"> phone</mat-icon>\r\n </div><div class=\"right w-80\">{{investorDetails?.phoneNumber || 'N/A'}}</div>\r\n </div>\r\n <div class=\"left-right d-flex align-items-center gap-10\">\r\n <div class=\"left w-15\"><mat-icon class=\" d-flex align-items-center justify-content-center f-18\"> email</mat-icon>\r\n </div><div class=\"right w-80\">{{investorDetails?.emailId || 'N/A'}}</div>\r\n </div>\r\n </div>\r\n <div class=\"tab-section\">\r\n <div class=\"tabs cursor-pointer\" *ngFor=\"let ele of sidePanelTabs\" (click)=\"selectedPanel = ele.value\" [class.activeTab]=\"selectedPanel == ele.value\">\r\n {{ele.viewValue}}\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"display-section\">\r\n <ng-container *ngIf=\"selectedPanel == 'KYC'\">\r\n <simpo-kyc-details></simpo-kyc-details>\r\n </ng-container>\r\n <ng-container *ngIf=\"selectedPanel == 'PORTFOLIO'\">\r\n <simpo-portfolio></simpo-portfolio>\r\n </ng-container>\r\n <ng-container *ngIf=\"selectedPanel == 'PROPERTIES'\">\r\n <simpo-properties></simpo-properties>\r\n </ng-container>\r\n <ng-container *ngIf=\"selectedPanel == 'ORDERS'\">\r\n <simpo-my-orders></simpo-my-orders>\r\n </ng-container>\r\n <ng-container *ngIf=\"selectedPanel == 'DOCUMENTS'\">\r\n <simpo-my-documents></simpo-my-documents>\r\n </ng-container>\r\n <ng-container *ngIf=\"selectedPanel == 'STATEMENT'\">\r\n <simpo-my-statement></simpo-my-statement>\r\n </ng-container>\r\n <ng-container *ngIf=\"selectedPanel == 'HELP'\">\r\n <simpo-need-help></simpo-need-help>\r\n </ng-container>\r\n </div>\r\n</section>\r\n", styles: ["*{font-family:DM Sans}mat-icon{font-family:Material Icons!important}.main-container{height:100vh;width:100%;padding:10px 0;gap:15px;background:#f9fbff}.side-panel{width:18%;background:#fff;border:2px solid rgba(241,246,255,1);border-radius:10px}.display-section{width:60%}.w-15{width:15%}.w-85{width:85%}.cursor-pointer{cursor:pointer}.details{background:#19a6c6;border-radius:10px;padding:10px;margin:15px}.left-right{gap:10px;margin-bottom:10px}.logo{background:#e6f0ff;border-radius:50%;font-size:14px;text-align:center;font-weight:600;line-height:24px;padding:3px;color:#405071!important}.name{font-size:14px;font-weight:600;line-height:24px;color:#fff!important}.f-18{font-size:18px}.gap-10{gap:10px}.left{color:#fffc}.right{font-weight:500;font-size:14px;line-height:24px;color:#fffc}.tab-section{margin-top:15px}.tabs{margin-bottom:25px;font-weight:500;font-size:16px;line-height:24px;color:#01161e;margin-left:8px}.activeTab{border-left:8px solid rgba(248,169,56,1);font-weight:700!important;color:#219ebc;margin-right:15px;background:#f1f3f7;padding:10px;border-radius:0 6px 6px 0;margin-left:unset}@media only screen and (max-width: 475px){.display-section{width:95%}}\n"] }]
53
+ KycDetailsComponent, NgxSkeletonLoaderModule
54
+ ], template: "<section class=\"main-container d-flex justify-content-center\">\r\n <div class=\"side-panel\">\r\n <div class=\"details\">\r\n <div class=\"left-right d-flex align-items-center gap-10\" *ngIf=\"!skelLoader\">\r\n <div class=\"logo left w-15\">{{ getInitials() }}</div><div class=\"right name w-85\">{{investorDetails?.fullName || 'N/A'}}</div>\r\n </div>\r\n <div class=\"left-right d-flex align-items-center gap-10\" *ngIf=\"!skelLoader\">\r\n <div class=\"left w-15\"><mat-icon class=\"d-flex align-items-center justify-content-center f-18\"> phone</mat-icon>\r\n </div><div class=\"right w-80\">{{investorDetails?.phoneNumber || 'N/A'}}</div>\r\n </div>\r\n <div class=\"left-right d-flex align-items-center gap-10\" *ngIf=\"!skelLoader\">\r\n <div class=\"left w-15\"><mat-icon class=\" d-flex align-items-center justify-content-center f-18\"> email</mat-icon>\r\n </div><div class=\"right w-80\">{{investorDetails?.emailId || 'N/A'}}</div>\r\n </div>\r\n <div class=\"row\" *ngIf=\"skelLoader\">\r\n <div class=\"col-12\" >\r\n <ng-container *ngTemplateOutlet=\"skeleton\"></ng-container>\r\n </div>\r\n </div>\r\n </div>\r\n \r\n <div class=\"tab-section\">\r\n <div class=\"tabs cursor-pointer\" *ngFor=\"let ele of sidePanelTabs\" (click)=\"selectedPanel = ele.value\" [class.activeTab]=\"selectedPanel == ele.value\">\r\n {{ele.viewValue}}\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"display-section\">\r\n <ng-container *ngIf=\"selectedPanel == 'KYC'\">\r\n <simpo-kyc-details></simpo-kyc-details>\r\n </ng-container>\r\n <ng-container *ngIf=\"selectedPanel == 'PORTFOLIO'\">\r\n <simpo-portfolio></simpo-portfolio>\r\n </ng-container>\r\n <ng-container *ngIf=\"selectedPanel == 'PROPERTIES'\">\r\n <simpo-properties></simpo-properties>\r\n </ng-container>\r\n <ng-container *ngIf=\"selectedPanel == 'ORDERS'\">\r\n <simpo-my-orders></simpo-my-orders>\r\n </ng-container>\r\n <ng-container *ngIf=\"selectedPanel == 'DOCUMENTS'\">\r\n <simpo-my-documents></simpo-my-documents>\r\n </ng-container>\r\n <ng-container *ngIf=\"selectedPanel == 'STATEMENT'\">\r\n <simpo-my-statement></simpo-my-statement>\r\n </ng-container>\r\n <ng-container *ngIf=\"selectedPanel == 'HELP'\">\r\n <simpo-need-help></simpo-need-help>\r\n </ng-container>\r\n </div>\r\n</section>\r\n<ng-template #skeleton>\r\n <div class=\"wrapper-1\" >\r\n <ngx-skeleton-loader [theme]=\"{\r\n width: '15%',\r\n 'border-radius': '50%',\r\n height: '4vh',\r\n 'margin-bottom': '5px',\r\n 'margin-right': '5px'\r\n }\">\r\n </ngx-skeleton-loader>\r\n <ngx-skeleton-loader [theme]=\"{\r\n width: '80%',\r\n 'border-radius': '5px',\r\n height: '3vh',\r\n 'margin-bottom': '5px'\r\n }\">\r\n </ngx-skeleton-loader>\r\n \r\n </div> \r\n <div class=\"wrapper\" *ngFor=\"let item of skelArray\">\r\n <ngx-skeleton-loader [theme]=\"{\r\n width: '100%',\r\n 'border-radius': '5px',\r\n height: '3vh',\r\n 'margin-bottom': '5px'\r\n }\">\r\n </ngx-skeleton-loader>\r\n </div> \r\n</ng-template>\r\n", styles: ["*{font-family:DM Sans}mat-icon{font-family:Material Icons!important}.main-container{height:100vh;width:100%;padding:10px 0;gap:15px;background:#f9fbff}.side-panel{width:18%;background:#fff;border:2px solid rgba(241,246,255,1);border-radius:10px}.display-section{width:60%}.w-15{width:15%}.w-85{width:85%}.cursor-pointer{cursor:pointer}.details{background:#19a6c6;border-radius:10px;padding:10px;margin:15px}.left-right{gap:10px;margin-bottom:10px}.logo{background:#e6f0ff;border-radius:50%;font-size:14px;text-align:center;font-weight:600;line-height:24px;padding:3px;color:#405071!important}.name{font-size:14px;font-weight:600;line-height:24px;color:#fff!important}.f-18{font-size:18px}.gap-10{gap:10px}.left{color:#fffc}.right{font-weight:500;font-size:14px;line-height:24px;color:#fffc}.tab-section{margin-top:15px}.tabs{margin-bottom:25px;font-weight:500;font-size:16px;line-height:24px;color:#01161e;margin-left:8px}.activeTab{border-left:8px solid rgba(248,169,56,1);font-weight:700!important;color:#219ebc;margin-right:15px;background:#f1f3f7;padding:10px;border-radius:0 6px 6px 0;margin-left:unset}@media only screen and (max-width: 475px){.display-section{width:95%}}\n"] }]
49
55
  }], ctorParameters: () => [{ type: i1.RestService }], propDecorators: { data: [{
50
56
  type: Input
51
57
  }] } });
52
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"profile-section.component.js","sourceRoot":"","sources":["../../../../../../projects/simpo-ui/src/lib/sections/profile-section/profile-section.component.ts","../../../../../../projects/simpo-ui/src/lib/sections/profile-section/profile-section.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AACjD,OAAO,EAAE,kBAAkB,EAAE,MAAM,8CAA8C,CAAC;AAClF,OAAO,EAAE,mBAAmB,EAAE,MAAM,gDAAgD,CAAC;AACrF,OAAO,EAAE,oBAAoB,EAAE,MAAM,oDAAoD,CAAC;AAC1F,OAAO,EAAE,iBAAiB,EAAE,MAAM,8CAA8C,CAAC;AACjF,OAAO,EAAE,oBAAoB,EAAE,MAAM,oDAAoD,CAAC;AAC1F,OAAO,EAAE,iBAAiB,EAAE,MAAM,8CAA8C,CAAC;AAEjF,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AACjD,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,mBAAmB,EAAE,MAAM,sCAAsC,CAAC;;;;AAa3E,MAAM,OAAO,uBAAuB;IAGhC,YAAoB,WAAwB;QAAxB,gBAAW,GAAX,WAAW,CAAa;QAQ5C,kBAAa,GAAY,WAAW,CAAA;QAEpC,kBAAa,GAAW;YACtB,EAAC,KAAK,EAAG,WAAW,EAAG,SAAS,EAAG,cAAc,EAAC;YAClD,EAAC,KAAK,EAAG,YAAY,EAAG,SAAS,EAAG,eAAe,EAAC;YACpD,gDAAgD;YAChD,sDAAsD;YACtD,uDAAuD;YACvD,EAAC,KAAK,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,EAAC;YAChC,8CAA8C;SAC/C,CAAA;IAhBD,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC5B,CAAC;IAeD,kBAAkB;QAChB,IAAI,CAAC,WAAW,CAAC,eAAe,EAAE,CAAC,SAAS,CAAC,CAAC,GAAQ,EAAE,EAAE;YACxD,IAAI,CAAC,eAAe,GAAG,GAAG,CAAC,OAAO,CAAC;QACrC,CAAC,CAAC,CAAA;IACJ,CAAC;IAED,WAAW;QACT,MAAM,SAAS,GAAG,IAAI,CAAC,eAAe,EAAE,QAAQ,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC;QAC7D,MAAM,QAAQ,GAAG,SAAS,EAAE,GAAG,CAAC,CAAC,IAAS,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACtF,OAAO,QAAQ,CAAC;IAClB,CAAC;8GAlCQ,uBAAuB;kGAAvB,uBAAuB,2GCvBpC,g1EA6CA,stCD5BY,kBAAkB,4DAAC,mBAAmB,6DAAC,oBAAoB,+DAAC,iBAAiB,4DAAC,oBAAoB,+DAAC,iBAAiB,4DAAC,OAAO,0IAAC,YAAY,gQACjJ,mBAAmB;;2FAKV,uBAAuB;kBATnC,SAAS;+BACE,uBAAuB,cACrB,IAAI,WACP,CAAC,kBAAkB,EAAC,mBAAmB,EAAC,oBAAoB,EAAC,iBAAiB,EAAC,oBAAoB,EAAC,iBAAiB,EAAC,OAAO,EAAC,YAAY;wBACjJ,mBAAmB;qBACpB;gFAKU,IAAI;sBAAZ,KAAK","sourcesContent":["import { Component, Input } from '@angular/core';\r\nimport { PortfolioComponent } from '../../elements/portfolio/portfolio.component';\r\nimport { PropertiesComponent } from '../../elements/properties/properties.component';\r\nimport { MyDocumentsComponent } from '../../elements/my-documents/my-documents.component';\r\nimport { MyOrdersComponent } from '../../elements/my-orders/my-orders.component';\r\nimport { MyStatementComponent } from '../../elements/my-statement/my-statement.component';\r\nimport { NeedHelpComponent } from '../../elements/need-help/need-help.component';\r\nimport { ProfileSectionModel } from './profile-section.modal';\r\nimport { MatIcon } from '@angular/material/icon';\r\nimport { CommonModule } from '@angular/common';\r\nimport { KycDetailsComponent } from '../kyc-details/kyc-details.component';\r\nimport { RestService } from '../../services/rest.service';\r\n\r\n\r\n@Component({\r\n  selector: 'simpo-profile-section',\r\n  standalone: true,\r\n  imports: [PortfolioComponent,PropertiesComponent,MyDocumentsComponent,MyOrdersComponent,MyStatementComponent,NeedHelpComponent,MatIcon,CommonModule,\r\n    KycDetailsComponent\r\n  ],\r\n  templateUrl: './profile-section.component.html',\r\n  styleUrl: './profile-section.component.css'\r\n})\r\nexport class ProfileSectionComponent {\r\n    @Input() data?:ProfileSectionModel;\r\n\r\n    constructor(private restService: RestService){\r\n\r\n    }\r\n\r\n    ngOnInit(){\r\n      this.getInvestorDetails();\r\n    }\r\n\r\n    selectedPanel : string = \"PORTFOLIO\"\r\n\r\n    sidePanelTabs : any[] = [\r\n      {value : \"PORTFOLIO\" , viewValue : \"My Portfolio\"},\r\n      {value : \"PROPERTIES\" , viewValue : \"My Properties\"},\r\n      // {value : \"ORDERS\" , viewValue : \"My Orders\"},\r\n      // {value : \"DOCUMENTS\" , viewValue : \"My Documents\"},\r\n      // {value : \"STATEMENT\" , viewValue : \"My Statements\"},\r\n      {value: \"KYC\", viewValue: \"KYC\"},\r\n      // {value : \"HELP\" , viewValue : \"Need Help\"},\r\n    ]\r\n    investorDetails: any;\r\n\r\n    getInvestorDetails() {\r\n      this.restService.getInvesterById().subscribe((res: any) => {\r\n        this.investorDetails = res.message;\r\n      })\r\n    }\r\n\r\n    getInitials(): string {\r\n      const nameParts = this.investorDetails?.fullName?.split(' ');\r\n      const initials = nameParts?.map((part: any) => part.charAt(0).toUpperCase()).join('');\r\n      return initials;\r\n    }\r\n\r\n}\r\n","<section class=\"main-container d-flex justify-content-center\">\r\n    <div class=\"side-panel\">\r\n        <div class=\"details\">\r\n            <div class=\"left-right d-flex align-items-center gap-10\">\r\n                <div class=\"logo left w-15\">{{ getInitials() }}</div><div class=\"right name w-85\">{{investorDetails?.fullName || 'N/A'}}</div>\r\n            </div>\r\n            <div class=\"left-right d-flex align-items-center gap-10\">\r\n                <div class=\"left w-15\"><mat-icon class=\"d-flex align-items-center justify-content-center f-18\"> phone</mat-icon>\r\n                </div><div class=\"right w-80\">{{investorDetails?.phoneNumber || 'N/A'}}</div>\r\n            </div>\r\n            <div class=\"left-right d-flex align-items-center gap-10\">\r\n                <div class=\"left w-15\"><mat-icon class=\" d-flex align-items-center justify-content-center f-18\"> email</mat-icon>\r\n                </div><div class=\"right w-80\">{{investorDetails?.emailId || 'N/A'}}</div>\r\n            </div>\r\n        </div>\r\n        <div class=\"tab-section\">\r\n            <div class=\"tabs cursor-pointer\" *ngFor=\"let ele of sidePanelTabs\" (click)=\"selectedPanel = ele.value\" [class.activeTab]=\"selectedPanel == ele.value\">\r\n              {{ele.viewValue}}\r\n            </div>\r\n        </div>\r\n    </div>\r\n    <div class=\"display-section\">\r\n      <ng-container *ngIf=\"selectedPanel == 'KYC'\">\r\n        <simpo-kyc-details></simpo-kyc-details>\r\n      </ng-container>\r\n      <ng-container *ngIf=\"selectedPanel == 'PORTFOLIO'\">\r\n        <simpo-portfolio></simpo-portfolio>\r\n      </ng-container>\r\n      <ng-container *ngIf=\"selectedPanel == 'PROPERTIES'\">\r\n        <simpo-properties></simpo-properties>\r\n      </ng-container>\r\n      <ng-container *ngIf=\"selectedPanel == 'ORDERS'\">\r\n        <simpo-my-orders></simpo-my-orders>\r\n      </ng-container>\r\n      <ng-container *ngIf=\"selectedPanel == 'DOCUMENTS'\">\r\n        <simpo-my-documents></simpo-my-documents>\r\n      </ng-container>\r\n      <ng-container *ngIf=\"selectedPanel == 'STATEMENT'\">\r\n        <simpo-my-statement></simpo-my-statement>\r\n      </ng-container>\r\n      <ng-container *ngIf=\"selectedPanel == 'HELP'\">\r\n        <simpo-need-help></simpo-need-help>\r\n      </ng-container>\r\n    </div>\r\n</section>\r\n"]}
58
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"profile-section.component.js","sourceRoot":"","sources":["../../../../../../projects/simpo-ui/src/lib/sections/profile-section/profile-section.component.ts","../../../../../../projects/simpo-ui/src/lib/sections/profile-section/profile-section.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AACjD,OAAO,EAAE,kBAAkB,EAAE,MAAM,8CAA8C,CAAC;AAClF,OAAO,EAAE,mBAAmB,EAAE,MAAM,gDAAgD,CAAC;AACrF,OAAO,EAAE,oBAAoB,EAAE,MAAM,oDAAoD,CAAC;AAC1F,OAAO,EAAE,iBAAiB,EAAE,MAAM,8CAA8C,CAAC;AACjF,OAAO,EAAE,oBAAoB,EAAE,MAAM,oDAAoD,CAAC;AAC1F,OAAO,EAAE,iBAAiB,EAAE,MAAM,8CAA8C,CAAC;AAEjF,OAAO,EAAE,OAAO,EAAE,MAAM,wBAAwB,CAAC;AACjD,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,mBAAmB,EAAE,MAAM,sCAAsC,CAAC;AAE3E,OAAO,EAAE,uBAAuB,EAAE,MAAM,qBAAqB,CAAC;;;;;AAY9D,MAAM,OAAO,uBAAuB;IAGhC,YAAoB,WAAwB;QAAxB,gBAAW,GAAX,WAAW,CAAa;QAQ5C,kBAAa,GAAY,WAAW,CAAA;QACpC,eAAU,GAAS,IAAI,CAAC;QACxB,cAAS,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;QAErB,kBAAa,GAAW;YACtB,EAAC,KAAK,EAAG,WAAW,EAAG,SAAS,EAAG,cAAc,EAAC;YAClD,EAAC,KAAK,EAAG,YAAY,EAAG,SAAS,EAAG,eAAe,EAAC;YACpD,gDAAgD;YAChD,sDAAsD;YACtD,uDAAuD;YACvD,EAAC,KAAK,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,EAAC;YAChC,8CAA8C;SAC/C,CAAA;IAlBD,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC5B,CAAC;IAiBD,kBAAkB;QAChB,IAAI,CAAC,UAAU,GAAE,IAAI,CAAC;QACtB,IAAI,CAAC,WAAW,CAAC,eAAe,EAAE,CAAC,SAAS,CAAC,CAAC,GAAQ,EAAE,EAAE;YACxD,IAAI,CAAC,eAAe,GAAG,GAAG,CAAC,OAAO,CAAC;YACnC,IAAI,CAAC,UAAU,GAAE,KAAK,CAAC;QACzB,CAAC,CAAC,CAAA;IACJ,CAAC;IAED,WAAW;QACT,MAAM,SAAS,GAAG,IAAI,CAAC,eAAe,EAAE,QAAQ,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC;QAC7D,MAAM,QAAQ,GAAG,SAAS,EAAE,GAAG,CAAC,CAAC,IAAS,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACtF,OAAO,QAAQ,CAAC;IAClB,CAAC;8GAtCQ,uBAAuB;kGAAvB,uBAAuB,2GCxBpC,w5GAgFA,stCD9DY,kBAAkB,4DAAC,mBAAmB,6DAAC,oBAAoB,+DAAC,iBAAiB,4DAAC,oBAAoB,+DAAC,iBAAiB,4DAAC,OAAO,0IAAC,YAAY,uaACjJ,mBAAmB,6DAAC,uBAAuB;;2FAKlC,uBAAuB;kBATnC,SAAS;+BACE,uBAAuB,cACrB,IAAI,WACP,CAAC,kBAAkB,EAAC,mBAAmB,EAAC,oBAAoB,EAAC,iBAAiB,EAAC,oBAAoB,EAAC,iBAAiB,EAAC,OAAO,EAAC,YAAY;wBACjJ,mBAAmB,EAAC,uBAAuB;qBAC5C;gFAKU,IAAI;sBAAZ,KAAK","sourcesContent":["import { Component, Input } from '@angular/core';\r\nimport { PortfolioComponent } from '../../elements/portfolio/portfolio.component';\r\nimport { PropertiesComponent } from '../../elements/properties/properties.component';\r\nimport { MyDocumentsComponent } from '../../elements/my-documents/my-documents.component';\r\nimport { MyOrdersComponent } from '../../elements/my-orders/my-orders.component';\r\nimport { MyStatementComponent } from '../../elements/my-statement/my-statement.component';\r\nimport { NeedHelpComponent } from '../../elements/need-help/need-help.component';\r\nimport { ProfileSectionModel } from './profile-section.modal';\r\nimport { MatIcon } from '@angular/material/icon';\r\nimport { CommonModule } from '@angular/common';\r\nimport { KycDetailsComponent } from '../kyc-details/kyc-details.component';\r\nimport { RestService } from '../../services/rest.service';\r\nimport { NgxSkeletonLoaderModule } from 'ngx-skeleton-loader';\r\n\r\n\r\n@Component({\r\n  selector: 'simpo-profile-section',\r\n  standalone: true,\r\n  imports: [PortfolioComponent,PropertiesComponent,MyDocumentsComponent,MyOrdersComponent,MyStatementComponent,NeedHelpComponent,MatIcon,CommonModule,\r\n    KycDetailsComponent,NgxSkeletonLoaderModule\r\n  ],\r\n  templateUrl: './profile-section.component.html',\r\n  styleUrl: './profile-section.component.css'\r\n})\r\nexport class ProfileSectionComponent {\r\n    @Input() data?:ProfileSectionModel;\r\n\r\n    constructor(private restService: RestService){\r\n\r\n    }\r\n\r\n    ngOnInit(){\r\n      this.getInvestorDetails();\r\n    }\r\n\r\n    selectedPanel : string = \"PORTFOLIO\"\r\n    skelLoader:boolean=true;\r\n    skelArray = Array(2);\r\n\r\n    sidePanelTabs : any[] = [\r\n      {value : \"PORTFOLIO\" , viewValue : \"My Portfolio\"},\r\n      {value : \"PROPERTIES\" , viewValue : \"My Properties\"},\r\n      // {value : \"ORDERS\" , viewValue : \"My Orders\"},\r\n      // {value : \"DOCUMENTS\" , viewValue : \"My Documents\"},\r\n      // {value : \"STATEMENT\" , viewValue : \"My Statements\"},\r\n      {value: \"KYC\", viewValue: \"KYC\"},\r\n      // {value : \"HELP\" , viewValue : \"Need Help\"},\r\n    ]\r\n    investorDetails: any;\r\n\r\n    getInvestorDetails() {\r\n      this.skelLoader= true;\r\n      this.restService.getInvesterById().subscribe((res: any) => {\r\n        this.investorDetails = res.message;\r\n        this.skelLoader= false;\r\n      })\r\n    }\r\n\r\n    getInitials(): string {\r\n      const nameParts = this.investorDetails?.fullName?.split(' ');\r\n      const initials = nameParts?.map((part: any) => part.charAt(0).toUpperCase()).join('');\r\n      return initials;\r\n    }\r\n\r\n}\r\n","<section class=\"main-container d-flex justify-content-center\">\r\n    <div class=\"side-panel\">\r\n        <div class=\"details\">\r\n            <div class=\"left-right d-flex align-items-center gap-10\" *ngIf=\"!skelLoader\">\r\n                <div class=\"logo left w-15\">{{ getInitials() }}</div><div class=\"right name w-85\">{{investorDetails?.fullName || 'N/A'}}</div>\r\n            </div>\r\n            <div class=\"left-right d-flex align-items-center gap-10\" *ngIf=\"!skelLoader\">\r\n                <div class=\"left w-15\"><mat-icon class=\"d-flex align-items-center justify-content-center f-18\"> phone</mat-icon>\r\n                </div><div class=\"right w-80\">{{investorDetails?.phoneNumber || 'N/A'}}</div>\r\n            </div>\r\n            <div class=\"left-right d-flex align-items-center gap-10\" *ngIf=\"!skelLoader\">\r\n                <div class=\"left w-15\"><mat-icon class=\" d-flex align-items-center justify-content-center f-18\"> email</mat-icon>\r\n                </div><div class=\"right w-80\">{{investorDetails?.emailId || 'N/A'}}</div>\r\n            </div>\r\n            <div class=\"row\" *ngIf=\"skelLoader\">\r\n              <div class=\"col-12\" >\r\n                <ng-container *ngTemplateOutlet=\"skeleton\"></ng-container>\r\n              </div>\r\n            </div>\r\n        </div>\r\n        \r\n        <div class=\"tab-section\">\r\n            <div class=\"tabs cursor-pointer\" *ngFor=\"let ele of sidePanelTabs\" (click)=\"selectedPanel = ele.value\" [class.activeTab]=\"selectedPanel == ele.value\">\r\n              {{ele.viewValue}}\r\n            </div>\r\n        </div>\r\n    </div>\r\n    <div class=\"display-section\">\r\n      <ng-container *ngIf=\"selectedPanel == 'KYC'\">\r\n        <simpo-kyc-details></simpo-kyc-details>\r\n      </ng-container>\r\n      <ng-container *ngIf=\"selectedPanel == 'PORTFOLIO'\">\r\n        <simpo-portfolio></simpo-portfolio>\r\n      </ng-container>\r\n      <ng-container *ngIf=\"selectedPanel == 'PROPERTIES'\">\r\n        <simpo-properties></simpo-properties>\r\n      </ng-container>\r\n      <ng-container *ngIf=\"selectedPanel == 'ORDERS'\">\r\n        <simpo-my-orders></simpo-my-orders>\r\n      </ng-container>\r\n      <ng-container *ngIf=\"selectedPanel == 'DOCUMENTS'\">\r\n        <simpo-my-documents></simpo-my-documents>\r\n      </ng-container>\r\n      <ng-container *ngIf=\"selectedPanel == 'STATEMENT'\">\r\n        <simpo-my-statement></simpo-my-statement>\r\n      </ng-container>\r\n      <ng-container *ngIf=\"selectedPanel == 'HELP'\">\r\n        <simpo-need-help></simpo-need-help>\r\n      </ng-container>\r\n    </div>\r\n</section>\r\n<ng-template #skeleton>\r\n  <div class=\"wrapper-1\" >\r\n    <ngx-skeleton-loader [theme]=\"{\r\n      width: '15%',\r\n      'border-radius': '50%',\r\n      height: '4vh',\r\n      'margin-bottom': '5px',\r\n      'margin-right': '5px'\r\n      }\">\r\n    </ngx-skeleton-loader>\r\n    <ngx-skeleton-loader [theme]=\"{\r\n      width: '80%',\r\n      'border-radius': '5px',\r\n      height: '3vh',\r\n      'margin-bottom': '5px'\r\n      }\">\r\n    </ngx-skeleton-loader>\r\n    \r\n  </div> \r\n  <div class=\"wrapper\" *ngFor=\"let item of skelArray\">\r\n    <ngx-skeleton-loader [theme]=\"{\r\n      width: '100%',\r\n      'border-radius': '5px',\r\n      height: '3vh',\r\n      'margin-bottom': '5px'\r\n      }\">\r\n    </ngx-skeleton-loader>\r\n  </div>  \r\n</ng-template>\r\n"]}