@fad-producto-portal/ng-fad-signature-fea 1.0.0-alpha.5 → 1.0.0-alpha.6

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 (19) hide show
  1. package/assets/images/fad-signature-fea/signature-summary/rejected.svg +19 -19
  2. package/assets/images/fad-signature-fea/signature-summary/send.svg +10 -10
  3. package/esm2022/lib/components/document-approval-list/document-approval-list.component.mjs +23 -3
  4. package/esm2022/lib/components/generic-error-fea/generic-error-fea.component.mjs +3 -3
  5. package/esm2022/lib/components/pdf-viewer-fea/pdf-viewer-fea.component.mjs +5 -5
  6. package/esm2022/lib/components/signature-summary/signature-summary.component.mjs +3 -3
  7. package/esm2022/lib/components/upload-e-signature/upload-e-signature.component.mjs +54 -66
  8. package/esm2022/lib/components/validate-signature/validate-signature.component.mjs +1 -1
  9. package/esm2022/lib/constants/errors/upload-e-signature/upload-e-signature-error-code.mjs +1 -2
  10. package/esm2022/lib/constants/errors/upload-e-signature/upload-e-signature-error-description.mjs +1 -3
  11. package/esm2022/lib/models/configuration/upload-e-signature/upload-e-signature-configuration.interface.mjs +1 -1
  12. package/fesm2022/fad-producto-portal-ng-fad-signature-fea.mjs +86 -81
  13. package/fesm2022/fad-producto-portal-ng-fad-signature-fea.mjs.map +1 -1
  14. package/lib/components/document-approval-list/document-approval-list.component.d.ts +1 -0
  15. package/lib/components/upload-e-signature/upload-e-signature.component.d.ts +3 -3
  16. package/lib/constants/errors/upload-e-signature/upload-e-signature-error-code.d.ts +1 -2
  17. package/lib/constants/errors/upload-e-signature/upload-e-signature-error-description.d.ts +1 -1
  18. package/lib/models/configuration/upload-e-signature/upload-e-signature-configuration.interface.d.ts +0 -2
  19. package/package.json +2 -2
@@ -80,11 +80,11 @@ export class SignatureSummaryComponent {
80
80
  this.configuration = Utils.mergeConfiguration(new Configuration(), SIGNATURE_SUMMARY_DEFAULT, this.configuration);
81
81
  }
82
82
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SignatureSummaryComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
83
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: SignatureSummaryComponent, selector: "ng-fad-signature-fea-signature-summary", inputs: { documentRequest: "documentRequest", configuration: "configuration" }, outputs: { oncomplete: "oncomplete" }, ngImport: i0, template: "<div class=\"fad-portal-content\">\r\n \r\n <ng-container *ngIf=\"!isAllDocumentsRejected\" >\r\n <ng-fad-image-inline\r\n [src]=\"images.send\"\r\n >\r\n </ng-fad-image-inline>\r\n <div class=\"fad-portal-title-bold\">\r\n {{pdfsName}}\r\n </div>\r\n <div class=\"fad-portal-content-bold date\">{{ currentDate }}</div>\r\n <div class=\"summary\">\r\n <div class=\"fad-portal-content-bold signeds\">\r\n <div>{{configuration.customization?.moduleCustomization?.legends?.signed}}</div>\r\n <div>{{signedCount}}</div>\r\n </div>\r\n <div class=\"line\">\r\n\r\n </div>\r\n <div class=\"fad-portal-content-bold rejecteds\">\r\n <div>{{configuration.customization?.moduleCustomization?.legends?.rejected}}</div>\r\n <div>{{rejectedCount}}</div>\r\n </div>\r\n </div>\r\n <div class=\"legends\">\r\n {{configuration.customization?.moduleCustomization?.legends?.legend}}\r\n </div>\r\n </ng-container>\r\n <ng-container *ngIf=\"isAllDocumentsRejected\" >\r\n <ng-fad-image-inline\r\n [src]=\"images.reject\"\r\n >\r\n </ng-fad-image-inline>\r\n <div class=\"document-rejected\"> {{configuration.customization?.moduleCustomization?.legends?.documentRejected}} </div>\r\n <div class=\"fad-portal-title-bold title-document\">\r\n {{pdfsName}}\r\n </div>\r\n <div class=\"id-requisition\">\r\n ID {{id}} | {{ currentDate }}\r\n </div>\r\n </ng-container>\r\n \r\n</div>", styles: [".fad-portal-content{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%}.fad-portal-content .fad-portal-title{margin-top:var(--fad-portal-common-separation-sm);margin-bottom:var(--fad-portal-common-separation-sm)}.fad-portal-content .date{color:#aaa}.fad-portal-content .summary{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;row-gap:var(--fad-portal-common-separation-sm);margin-bottom:var(--fad-portal-common-separation-xs)}.fad-portal-content .summary .signeds,.fad-portal-content .summary .rejecteds{width:100%;display:flex;justify-content:space-between}.fad-portal-content .summary .line{width:100%;border:1px solid var(--fad-portal-common-border-color)}.fad-portal-content .legends{text-align:center}.fad-portal-content .document-rejected{color:#aaa;margin-bottom:var(--fad-portal-common-separation-sm)}.fad-portal-content .id-requisition{color:#aaa;margin-top:var(--fad-portal-common-separation-sm)}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.NgFadImageInlineComponent, selector: "ng-fad-image-inline", inputs: ["src"] }] }); }
83
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: SignatureSummaryComponent, selector: "ng-fad-signature-fea-signature-summary", inputs: { documentRequest: "documentRequest", configuration: "configuration" }, outputs: { oncomplete: "oncomplete" }, ngImport: i0, template: "<div class=\"fad-portal-content\">\n \n <ng-container *ngIf=\"!isAllDocumentsRejected\" >\n <ng-fad-image-inline\n [src]=\"images.send\"\n >\n </ng-fad-image-inline>\n <div class=\"fad-portal-title-bold\">\n {{pdfsName}}\n </div>\n <div class=\"fad-portal-content-bold date\">{{ currentDate }}</div>\n <div class=\"summary\">\n <div class=\"fad-portal-content-bold signeds\">\n <div>{{configuration.customization?.moduleCustomization?.legends?.signed}}</div>\n <div>{{signedCount}}</div>\n </div>\n <div class=\"line\">\n\n </div>\n <div class=\"fad-portal-content-bold rejecteds\">\n <div>{{configuration.customization?.moduleCustomization?.legends?.rejected}}</div>\n <div>{{rejectedCount}}</div>\n </div>\n </div>\n <div class=\"legends\">\n {{configuration.customization?.moduleCustomization?.legends?.legend}}\n </div>\n </ng-container>\n <ng-container *ngIf=\"isAllDocumentsRejected\" >\n <ng-fad-image-inline\n [src]=\"images.reject\"\n >\n </ng-fad-image-inline>\n <div class=\"document-rejected\"> {{configuration.customization?.moduleCustomization?.legends?.documentRejected}} </div>\n <div class=\"fad-portal-title-bold title-document\">\n {{pdfsName}}\n </div>\n <div class=\"id-requisition\">\n ID {{id}} | {{ currentDate }}\n </div>\n </ng-container>\n \n</div>", styles: [".fad-portal-content{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;row-gap:var(--fad-portal-common-separation-sm)}.fad-portal-content .fad-portal-title{margin-top:var(--fad-portal-common-separation-sm);margin-bottom:var(--fad-portal-common-separation-sm)}.fad-portal-content .date{color:#aaa}.fad-portal-content .summary{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;row-gap:var(--fad-portal-common-separation-sm);margin-bottom:var(--fad-portal-common-separation-xs)}.fad-portal-content .summary .signeds,.fad-portal-content .summary .rejecteds{width:100%;display:flex;justify-content:space-between}.fad-portal-content .summary .line{width:100%;border:1px solid var(--fad-portal-common-border-color)}.fad-portal-content .legends{text-align:center}.fad-portal-content .document-rejected{color:#aaa;margin-bottom:var(--fad-portal-common-separation-sm)}.fad-portal-content .id-requisition{color:#aaa;margin-top:var(--fad-portal-common-separation-sm)}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.NgFadImageInlineComponent, selector: "ng-fad-image-inline", inputs: ["src"] }] }); }
84
84
  }
85
85
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SignatureSummaryComponent, decorators: [{
86
86
  type: Component,
87
- args: [{ selector: 'ng-fad-signature-fea-signature-summary', template: "<div class=\"fad-portal-content\">\r\n \r\n <ng-container *ngIf=\"!isAllDocumentsRejected\" >\r\n <ng-fad-image-inline\r\n [src]=\"images.send\"\r\n >\r\n </ng-fad-image-inline>\r\n <div class=\"fad-portal-title-bold\">\r\n {{pdfsName}}\r\n </div>\r\n <div class=\"fad-portal-content-bold date\">{{ currentDate }}</div>\r\n <div class=\"summary\">\r\n <div class=\"fad-portal-content-bold signeds\">\r\n <div>{{configuration.customization?.moduleCustomization?.legends?.signed}}</div>\r\n <div>{{signedCount}}</div>\r\n </div>\r\n <div class=\"line\">\r\n\r\n </div>\r\n <div class=\"fad-portal-content-bold rejecteds\">\r\n <div>{{configuration.customization?.moduleCustomization?.legends?.rejected}}</div>\r\n <div>{{rejectedCount}}</div>\r\n </div>\r\n </div>\r\n <div class=\"legends\">\r\n {{configuration.customization?.moduleCustomization?.legends?.legend}}\r\n </div>\r\n </ng-container>\r\n <ng-container *ngIf=\"isAllDocumentsRejected\" >\r\n <ng-fad-image-inline\r\n [src]=\"images.reject\"\r\n >\r\n </ng-fad-image-inline>\r\n <div class=\"document-rejected\"> {{configuration.customization?.moduleCustomization?.legends?.documentRejected}} </div>\r\n <div class=\"fad-portal-title-bold title-document\">\r\n {{pdfsName}}\r\n </div>\r\n <div class=\"id-requisition\">\r\n ID {{id}} | {{ currentDate }}\r\n </div>\r\n </ng-container>\r\n \r\n</div>", styles: [".fad-portal-content{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%}.fad-portal-content .fad-portal-title{margin-top:var(--fad-portal-common-separation-sm);margin-bottom:var(--fad-portal-common-separation-sm)}.fad-portal-content .date{color:#aaa}.fad-portal-content .summary{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;row-gap:var(--fad-portal-common-separation-sm);margin-bottom:var(--fad-portal-common-separation-xs)}.fad-portal-content .summary .signeds,.fad-portal-content .summary .rejecteds{width:100%;display:flex;justify-content:space-between}.fad-portal-content .summary .line{width:100%;border:1px solid var(--fad-portal-common-border-color)}.fad-portal-content .legends{text-align:center}.fad-portal-content .document-rejected{color:#aaa;margin-bottom:var(--fad-portal-common-separation-sm)}.fad-portal-content .id-requisition{color:#aaa;margin-top:var(--fad-portal-common-separation-sm)}\n"] }]
87
+ args: [{ selector: 'ng-fad-signature-fea-signature-summary', template: "<div class=\"fad-portal-content\">\n \n <ng-container *ngIf=\"!isAllDocumentsRejected\" >\n <ng-fad-image-inline\n [src]=\"images.send\"\n >\n </ng-fad-image-inline>\n <div class=\"fad-portal-title-bold\">\n {{pdfsName}}\n </div>\n <div class=\"fad-portal-content-bold date\">{{ currentDate }}</div>\n <div class=\"summary\">\n <div class=\"fad-portal-content-bold signeds\">\n <div>{{configuration.customization?.moduleCustomization?.legends?.signed}}</div>\n <div>{{signedCount}}</div>\n </div>\n <div class=\"line\">\n\n </div>\n <div class=\"fad-portal-content-bold rejecteds\">\n <div>{{configuration.customization?.moduleCustomization?.legends?.rejected}}</div>\n <div>{{rejectedCount}}</div>\n </div>\n </div>\n <div class=\"legends\">\n {{configuration.customization?.moduleCustomization?.legends?.legend}}\n </div>\n </ng-container>\n <ng-container *ngIf=\"isAllDocumentsRejected\" >\n <ng-fad-image-inline\n [src]=\"images.reject\"\n >\n </ng-fad-image-inline>\n <div class=\"document-rejected\"> {{configuration.customization?.moduleCustomization?.legends?.documentRejected}} </div>\n <div class=\"fad-portal-title-bold title-document\">\n {{pdfsName}}\n </div>\n <div class=\"id-requisition\">\n ID {{id}} | {{ currentDate }}\n </div>\n </ng-container>\n \n</div>", styles: [".fad-portal-content{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;row-gap:var(--fad-portal-common-separation-sm)}.fad-portal-content .fad-portal-title{margin-top:var(--fad-portal-common-separation-sm);margin-bottom:var(--fad-portal-common-separation-sm)}.fad-portal-content .date{color:#aaa}.fad-portal-content .summary{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;row-gap:var(--fad-portal-common-separation-sm);margin-bottom:var(--fad-portal-common-separation-xs)}.fad-portal-content .summary .signeds,.fad-portal-content .summary .rejecteds{width:100%;display:flex;justify-content:space-between}.fad-portal-content .summary .line{width:100%;border:1px solid var(--fad-portal-common-border-color)}.fad-portal-content .legends{text-align:center}.fad-portal-content .document-rejected{color:#aaa;margin-bottom:var(--fad-portal-common-separation-sm)}.fad-portal-content .id-requisition{color:#aaa;margin-top:var(--fad-portal-common-separation-sm)}\n"] }]
88
88
  }], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { documentRequest: [{
89
89
  type: Input
90
90
  }], configuration: [{
@@ -92,4 +92,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
92
92
  }], oncomplete: [{
93
93
  type: Output
94
94
  }] } });
95
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"signature-summary.component.js","sourceRoot":"","sources":["../../../../../../../projects/fad-producto-portal/ng-fad-signature-fea/src/lib/components/signature-summary/signature-summary.component.ts","../../../../../../../projects/fad-producto-portal/ng-fad-signature-fea/src/lib/components/signature-summary/signature-summary.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, Input, Output } from '@angular/core';\r\nimport { DocumentApprovalFea, ISignatureSummaryConfiguration } from '../../models';\r\nimport { SIGNATURE_SUMMARY_DEFAULT } from '../../constants/configuration/signature-summary/signature-summary-configuration.const';\r\nimport { Configuration } from '@fad-producto-portal/fad-common/models/core';\r\nimport { Utils } from '@fad-producto-portal/fad-common/utils/utils';\r\n\r\n@Component({\r\n  selector: 'ng-fad-signature-fea-signature-summary',\r\n  templateUrl: './signature-summary.component.html',\r\n  styleUrls: ['./signature-summary.component.scss']\r\n})\r\nexport class SignatureSummaryComponent {\r\n\r\n  @Input() documentRequest!: DocumentApprovalFea[];\r\n  @Input() configuration!: ISignatureSummaryConfiguration;\r\n  @Output() oncomplete = new EventEmitter<any>();\r\n\r\n  images = {\r\n      reject: '',\r\n      send: ''\r\n  }\r\n  signedCount = 0;\r\n  rejectedCount = 0;\r\n  isAllDocumentsRejected = true;\r\n  currentDate: string = '';\r\n  id = '';\r\n  pdfsName = '';\r\n  constructor( private hostContext: ElementRef ) {}\r\n\r\n\r\n  ngOnInit() {\r\n    console.log(this.documentRequest)\r\n    this.setCustomizationStyle(this.hostContext.nativeElement);\r\n    if (this.configuration?.pathDependencies?.imageDirectory) {\r\n      this.images.reject = this.configuration.pathDependencies?.images?.reject ?? `${this.configuration.pathDependencies.imageDirectory}/rejected.svg`;\r\n      this.images.send = this.configuration.pathDependencies?.images?.send ?? `${this.configuration.pathDependencies.imageDirectory}/send.svg`;\r\n      \r\n    }\r\n    this.updateDocumentCounts();\r\n    this.getPdfNames();\r\n    this.setCurrentDate();\r\n  }\r\n\r\n  setCurrentDate() {\r\n    const now = new Date();\r\n\r\n    let hours = now.getHours();\r\n    const minutes = now.getMinutes();\r\n    const amPm = hours >= 12 ? 'PM' : 'AM';\r\n  \r\n    hours = hours % 12 || 12; \r\n  \r\n    const formattedMinutes = minutes < 10 ? '0' + minutes : minutes;\r\n    this.currentDate = `${now.toLocaleDateString(this.configuration.dateFormat)} | ${hours}:${formattedMinutes} ${amPm}`;\r\n  }\r\n  \r\n\r\n  updateDocumentCounts() {\r\n    // Contar documentos firmados (approved: true)\r\n    this.documentRequest.forEach((doc) =>{\r\n      this.id= doc.id!;\r\n      if(doc.approved){\r\n          this.signedCount += 1;\r\n      }else{\r\n        this.rejectedCount += 1;\r\n      }\r\n    })\r\n    console.log(this.documentRequest, this.signedCount,this.rejectedCount)\r\n   if(this.signedCount > 0){\r\n    this.isAllDocumentsRejected = false\r\n   }else{\r\n    this.isAllDocumentsRejected = true\r\n   }\r\n    \r\n  }\r\n\r\n  getPdfNames(){\r\n    let currentFlag = '';\r\n    let previewFlag = '';\r\n    this.documentRequest.forEach((doc) =>{\r\n       if(this.pdfsName === ''){\r\n        this.pdfsName = doc.doc?.name.replace('.pdf','')!;\r\n        currentFlag = doc.idRequisition!\r\n        previewFlag = doc.idRequisition!\r\n       }\r\n       currentFlag = doc.idRequisition!;\r\n       if(currentFlag !== previewFlag){\r\n        this.pdfsName+= ','+doc.doc?.name.replace('.pdf','')!;\r\n        currentFlag = doc.idRequisition!\r\n        previewFlag = doc.idRequisition!\r\n       }\r\n      \r\n    });\r\n  }\r\n  \r\n\r\n  setCustomizationStyle(targetElement = document.documentElement): void {\r\n        this.configuration = Utils.mergeConfiguration(\r\n          new Configuration(),\r\n          SIGNATURE_SUMMARY_DEFAULT,\r\n          this.configuration\r\n        );\r\n  }\r\n\r\n}\r\n","<div class=\"fad-portal-content\">\r\n    \r\n    <ng-container *ngIf=\"!isAllDocumentsRejected\" >\r\n            <ng-fad-image-inline\r\n            [src]=\"images.send\"\r\n            >\r\n            </ng-fad-image-inline>\r\n            <div class=\"fad-portal-title-bold\">\r\n                {{pdfsName}}\r\n            </div>\r\n            <div class=\"fad-portal-content-bold date\">{{ currentDate }}</div>\r\n            <div class=\"summary\">\r\n                <div class=\"fad-portal-content-bold signeds\">\r\n                    <div>{{configuration.customization?.moduleCustomization?.legends?.signed}}</div>\r\n                    <div>{{signedCount}}</div>\r\n                </div>\r\n                <div class=\"line\">\r\n\r\n                </div>\r\n                <div class=\"fad-portal-content-bold rejecteds\">\r\n                    <div>{{configuration.customization?.moduleCustomization?.legends?.rejected}}</div>\r\n                    <div>{{rejectedCount}}</div>\r\n                </div>\r\n            </div>\r\n            <div class=\"legends\">\r\n                {{configuration.customization?.moduleCustomization?.legends?.legend}}\r\n            </div>\r\n    </ng-container>\r\n    <ng-container *ngIf=\"isAllDocumentsRejected\" >\r\n        <ng-fad-image-inline\r\n        [src]=\"images.reject\"\r\n        >\r\n        </ng-fad-image-inline>\r\n        <div class=\"document-rejected\"> {{configuration.customization?.moduleCustomization?.legends?.documentRejected}} </div>\r\n        <div class=\"fad-portal-title-bold title-document\">\r\n            {{pdfsName}}\r\n        </div>\r\n        <div class=\"id-requisition\">\r\n            ID {{id}} | {{ currentDate }}\r\n        </div>\r\n    </ng-container>\r\n    \r\n</div>"]}
95
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"signature-summary.component.js","sourceRoot":"","sources":["../../../../../../../projects/fad-producto-portal/ng-fad-signature-fea/src/lib/components/signature-summary/signature-summary.component.ts","../../../../../../../projects/fad-producto-portal/ng-fad-signature-fea/src/lib/components/signature-summary/signature-summary.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, Input, Output } from '@angular/core';\nimport { DocumentApprovalFea, ISignatureSummaryConfiguration } from '../../models';\nimport { SIGNATURE_SUMMARY_DEFAULT } from '../../constants/configuration/signature-summary/signature-summary-configuration.const';\nimport { Configuration } from '@fad-producto-portal/fad-common/models/core';\nimport { Utils } from '@fad-producto-portal/fad-common/utils/utils';\n\n@Component({\n  selector: 'ng-fad-signature-fea-signature-summary',\n  templateUrl: './signature-summary.component.html',\n  styleUrls: ['./signature-summary.component.scss']\n})\nexport class SignatureSummaryComponent {\n\n  @Input() documentRequest!: DocumentApprovalFea[];\n  @Input() configuration!: ISignatureSummaryConfiguration;\n  @Output() oncomplete = new EventEmitter<any>();\n\n  images = {\n      reject: '',\n      send: ''\n  }\n  signedCount = 0;\n  rejectedCount = 0;\n  isAllDocumentsRejected = true;\n  currentDate: string = '';\n  id = '';\n  pdfsName = '';\n  constructor( private hostContext: ElementRef ) {}\n\n\n  ngOnInit() {\n    console.log(this.documentRequest)\n    this.setCustomizationStyle(this.hostContext.nativeElement);\n    if (this.configuration?.pathDependencies?.imageDirectory) {\n      this.images.reject = this.configuration.pathDependencies?.images?.reject ?? `${this.configuration.pathDependencies.imageDirectory}/rejected.svg`;\n      this.images.send = this.configuration.pathDependencies?.images?.send ?? `${this.configuration.pathDependencies.imageDirectory}/send.svg`;\n      \n    }\n    this.updateDocumentCounts();\n    this.getPdfNames();\n    this.setCurrentDate();\n  }\n\n  setCurrentDate() {\n    const now = new Date();\n\n    let hours = now.getHours();\n    const minutes = now.getMinutes();\n    const amPm = hours >= 12 ? 'PM' : 'AM';\n  \n    hours = hours % 12 || 12; \n  \n    const formattedMinutes = minutes < 10 ? '0' + minutes : minutes;\n    this.currentDate = `${now.toLocaleDateString(this.configuration.dateFormat)} | ${hours}:${formattedMinutes} ${amPm}`;\n  }\n  \n\n  updateDocumentCounts() {\n    // Contar documentos firmados (approved: true)\n    this.documentRequest.forEach((doc) =>{\n      this.id= doc.id!;\n      if(doc.approved){\n          this.signedCount += 1;\n      }else{\n        this.rejectedCount += 1;\n      }\n    })\n    console.log(this.documentRequest, this.signedCount,this.rejectedCount)\n   if(this.signedCount > 0){\n    this.isAllDocumentsRejected = false\n   }else{\n    this.isAllDocumentsRejected = true\n   }\n    \n  }\n\n  getPdfNames(){\n    let currentFlag = '';\n    let previewFlag = '';\n    this.documentRequest.forEach((doc) =>{\n       if(this.pdfsName === ''){\n        this.pdfsName = doc.doc?.name.replace('.pdf','')!;\n        currentFlag = doc.idRequisition!\n        previewFlag = doc.idRequisition!\n       }\n       currentFlag = doc.idRequisition!;\n       if(currentFlag !== previewFlag){\n        this.pdfsName+= ','+doc.doc?.name.replace('.pdf','')!;\n        currentFlag = doc.idRequisition!\n        previewFlag = doc.idRequisition!\n       }\n      \n    });\n  }\n  \n\n  setCustomizationStyle(targetElement = document.documentElement): void {\n        this.configuration = Utils.mergeConfiguration(\n          new Configuration(),\n          SIGNATURE_SUMMARY_DEFAULT,\n          this.configuration\n        );\n  }\n\n}\n","<div class=\"fad-portal-content\">\n    \n    <ng-container *ngIf=\"!isAllDocumentsRejected\" >\n            <ng-fad-image-inline\n            [src]=\"images.send\"\n            >\n            </ng-fad-image-inline>\n            <div class=\"fad-portal-title-bold\">\n                {{pdfsName}}\n            </div>\n            <div class=\"fad-portal-content-bold date\">{{ currentDate }}</div>\n            <div class=\"summary\">\n                <div class=\"fad-portal-content-bold signeds\">\n                    <div>{{configuration.customization?.moduleCustomization?.legends?.signed}}</div>\n                    <div>{{signedCount}}</div>\n                </div>\n                <div class=\"line\">\n\n                </div>\n                <div class=\"fad-portal-content-bold rejecteds\">\n                    <div>{{configuration.customization?.moduleCustomization?.legends?.rejected}}</div>\n                    <div>{{rejectedCount}}</div>\n                </div>\n            </div>\n            <div class=\"legends\">\n                {{configuration.customization?.moduleCustomization?.legends?.legend}}\n            </div>\n    </ng-container>\n    <ng-container *ngIf=\"isAllDocumentsRejected\" >\n        <ng-fad-image-inline\n        [src]=\"images.reject\"\n        >\n        </ng-fad-image-inline>\n        <div class=\"document-rejected\"> {{configuration.customization?.moduleCustomization?.legends?.documentRejected}} </div>\n        <div class=\"fad-portal-title-bold title-document\">\n            {{pdfsName}}\n        </div>\n        <div class=\"id-requisition\">\n            ID {{id}} | {{ currentDate }}\n        </div>\n    </ng-container>\n    \n</div>"]}
@@ -117,73 +117,56 @@ export class UploadESignatureComponent {
117
117
  allIsRejected() {
118
118
  return this.documents.every(doc => doc.approved === false);
119
119
  }
120
- async onSignDocuments() {
121
- const aprovedDocuments = this.documents.filter((doc) => doc.approved);
120
+ async signDocuments() {
121
+ let canContinue = true;
122
122
  const rejectedDocuments = this.documents.filter((doc) => !doc.approved);
123
- let cer = null;
124
- if (aprovedDocuments.length > 0) {
125
- const response = await this.signDocuments();
126
- if (!response)
127
- return;
128
- cer = response;
129
- }
130
123
  if (rejectedDocuments.length > 0) {
131
- const response = await this.rejectDocuments();
132
- if (!response)
133
- return;
124
+ canContinue = await this.rejectDocuments(true);
134
125
  }
135
- this.oncomplete.emit(cer);
136
- }
137
- async signDocuments() {
138
- return new Promise(async (resolve, reject) => {
139
- this.onloader.emit(true);
140
- const cer = await this.getBase64File(this.cer?.value);
141
- this.onloader.emit(false);
142
- if (!cer)
143
- reject(null);
144
- this.onloader.emit(true);
145
- const key = await this.getBase64File(this.key?.value);
126
+ if (!canContinue)
127
+ return;
128
+ this.onloader.emit(true);
129
+ const cer = await this.getBase64File(this.cer?.value);
130
+ this.onloader.emit(false);
131
+ if (!cer)
132
+ return;
133
+ this.onloader.emit(true);
134
+ const key = await this.getBase64File(this.key?.value);
135
+ this.onloader.emit(false);
136
+ if (!key)
137
+ return;
138
+ const aprrovedDocuments = this.documents.filter((doc) => doc.approved);
139
+ const body = {
140
+ cer: cer.split(',')[1],
141
+ key: key.split(',')[1],
142
+ password: this.password?.value,
143
+ documents: aprrovedDocuments,
144
+ signerId: this.rfc
145
+ };
146
+ this.onloader.emit(true);
147
+ this.fad.signFea(body, this.configuration.credentials?.key, this.configuration.credentials?.iv, this.configuration.services?.reject).pipe(finalize(() => {
146
148
  this.onloader.emit(false);
147
- if (!key)
148
- reject(null);
149
- const aprrovedDocuments = this.documents.filter((doc) => doc.approved);
150
- const data = {
151
- cer: cer.split(',')[1],
152
- key: key.split(',')[1],
153
- password: this.password?.value,
154
- documents: aprrovedDocuments,
155
- signerId: this.rfc
156
- };
157
- const body = await this.mifiel.getSignBody(data);
158
- if (!body) {
159
- this.onerror.emit(new ResponseError(UploadESignatureErrorCode.PASSWORD_ERROR, getUploadESignatureErrorDescription(UploadESignatureErrorCode.PASSWORD_ERROR), 'ng-fad-signature-fea-upload-e-signature'));
160
- return;
161
- }
162
- this.onloader.emit(true);
163
- this.fad.signFea(body, this.configuration.credentials?.key, this.configuration.credentials?.iv, this.configuration.services?.reject).pipe(finalize(() => {
164
- this.onloader.emit(false);
165
- })).subscribe({
166
- next: (res) => {
167
- if (res.success) {
168
- const certificate = this.mifiel.parseCertificate(data.cer);
169
- const cer = {
170
- cer: certificate
171
- };
172
- resolve(cer);
173
- }
174
- else {
175
- this.onerror.emit(new ResponseError(UploadESignatureErrorCode.SERVICE, res.error, 'ng-fad-signature-fea-upload-e-signature'));
176
- reject(null);
177
- }
178
- },
179
- error: (error) => {
180
- this.onerror.emit(new ResponseError(UploadESignatureErrorCode.HTTP, error.error, 'ng-fad-signature-fea-upload-e-signature'));
181
- reject(null);
182
- },
183
- });
149
+ })).subscribe({
150
+ next: (res) => {
151
+ if (res.success) {
152
+ const certificate = this.mifiel.parseCertificate(body.cer);
153
+ const data = {
154
+ cer: certificate
155
+ };
156
+ this.oncomplete.emit(data);
157
+ }
158
+ else {
159
+ this.onerror.emit(new ResponseError(UploadESignatureErrorCode.SERVICE, res.error, 'ng-fad-signature-fea-upload-e-signature'));
160
+ ;
161
+ }
162
+ },
163
+ error: (error) => {
164
+ this.onerror.emit(new ResponseError(UploadESignatureErrorCode.HTTP, error.error, 'ng-fad-signature-fea-upload-e-signature'));
165
+ ;
166
+ },
184
167
  });
185
168
  }
186
- rejectDocuments() {
169
+ rejectDocuments(fromSign = false) {
187
170
  return new Promise((resolve, reject) => {
188
171
  const rejectedDocuments = this.documents.filter((doc) => !doc.approved);
189
172
  const body = {
@@ -204,20 +187,25 @@ export class UploadESignatureComponent {
204
187
  })).subscribe({
205
188
  next: (res) => {
206
189
  if (res.success) {
190
+ if (!fromSign)
191
+ this.oncomplete.emit(null);
207
192
  resolve(true);
208
193
  }
209
194
  else {
210
195
  this.onerror.emit(new ResponseError(UploadESignatureErrorCode.SERVICE, res.error, 'ng-fad-signature-fea-upload-e-signature'));
211
- reject(false);
196
+ reject(null);
212
197
  }
213
198
  },
214
199
  error: (error) => {
215
200
  this.onerror.emit(new ResponseError(UploadESignatureErrorCode.HTTP, error.error, 'ng-fad-signature-fea-upload-e-signature'));
216
- reject(false);
201
+ reject(null);
217
202
  },
218
203
  });
219
204
  });
220
205
  }
206
+ async onRejectDocument() {
207
+ await this.rejectDocuments();
208
+ }
221
209
  async getBase64File(file) {
222
210
  const data = await SharedUtils.fileToBase64(file).then(base64 => base64).catch(error => null);
223
211
  if (data)
@@ -241,11 +229,11 @@ export class UploadESignatureComponent {
241
229
  Utils.setVariableCss('--fad-signature-fea-e-signature-file-img-background-color', this.configuration.customization?.moduleCustomization?.style?.file?.img?.backgroundColor, { targetElement });
242
230
  }
243
231
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: UploadESignatureComponent, deps: [{ token: i0.ElementRef }, { token: i1.FormBuilder }, { token: i2.FadService }, { token: i2.MifielService }], target: i0.ɵɵFactoryTarget.Component }); }
244
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: UploadESignatureComponent, selector: "ng-fad-signature-fea-upload-e-signature", inputs: { configuration: "configuration", documents: "documents", signerId: "signerId", rfc: "rfc" }, outputs: { onerror: "onerror", onloader: "onloader", oncomplete: "oncomplete" }, ngImport: i0, template: "<ng-container *ngIf=\"showComponent\">\r\n <div>\r\n <div *ngIf=\"documents.length > 1\" class=\"fad-portal-title-bold\">{{ documentPluralTitle }}</div>\r\n <div *ngIf=\"documents.length === 1\" class=\"fad-portal-title-bold\">{{ documentSingularTitle }}</div>\r\n\r\n <div class=\"container-document fad-portal-content\">\r\n <div *ngFor=\"let i of documents\" class=\"document\">\r\n <div>{{ i.doc.name }}</div>\r\n <div class=\"status fad-portal-content-bold\">{{ i.approved ? configuration.customization?.moduleCustomization?.legends?.documents?.status?.approved : configuration.customization?.moduleCustomization?.legends?.documents?.status?.rejected }}</div>\r\n <div class=\"pages\">{{ i.doc.pages }} {{ i.doc.pages > 1 ? configuration.customization?.moduleCustomization?.legends?.documents?.pages?.plural : configuration.customization?.moduleCustomization?.legends?.documents?.pages?.singular }}</div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <ng-container *ngIf=\"!allIsRejected()\">\r\n <div class=\"fad-portal-title-bold\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.title }}</div>\r\n\r\n <div>\r\n <div class=\"container-instruction-file\">\r\n <div class=\"fad-portal-content\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.cer?.label }}</div>\r\n <div *ngIf=\"cer?.value\" class=\"fad-portal-content select-file\" (click)=\"openFilePicker(fileCerInput)\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.upload }}</div>\r\n </div>\r\n\r\n <div\r\n *ngIf=\"!cer?.value\"\r\n class=\"container-upload\"\r\n (click)=\"openFilePicker(fileCerInput)\"\r\n dragDropDocument\r\n [formatList]=\"formatCerList\"\r\n [acceptMultipleFiles]=\"false\"\r\n (onfiledropped)=\"onfiledropped($event, 'cer')\"\r\n (onerror)=\"onerrorDirective($event, 'cer')\">\r\n <div class=\"fad-portal-content instruction\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.cer?.instruction }}</div>\r\n <div class=\"fad-portal-content-bold upload-btn\">\r\n <ng-fad-image-inline [src]=\"uploadImg\"></ng-fad-image-inline>\r\n <span>{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.cer?.upload }}</span>\r\n </div>\r\n </div>\r\n\r\n <div *ngIf=\"cer?.value\" class=\"container-file\">\r\n <div class=\"document-img\">\r\n <img [src]=\"fileImg\" alt=\"\">\r\n </div>\r\n <div class=\"fad-portal-content\">{{ cer?.value.name }}</div>\r\n </div>\r\n\r\n <input type=\"file\" accept=\".cer\" #fileCerInput style=\"display: none\" (change)=\"onFileChange($event, 'cer')\">\r\n </div>\r\n\r\n <div>\r\n <div class=\"container-instruction-file\">\r\n <div class=\"fad-portal-content\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.key?.label }}</div>\r\n <div *ngIf=\"key?.value\" class=\"fad-portal-content select-file\" (click)=\"openFilePicker(fileKeyInput)\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.upload }}</div>\r\n </div>\r\n\r\n <div\r\n *ngIf=\"!key?.value\"\r\n class=\"container-upload\"\r\n (click)=\"openFilePicker(fileKeyInput)\"\r\n dragDropDocument\r\n [formatList]=\"formatKeyList\"\r\n [acceptMultipleFiles]=\"false\"\r\n (onfiledropped)=\"onfiledropped($event, 'key')\"\r\n (onerror)=\"onerrorDirective($event, 'key')\">\r\n\r\n <div class=\"fad-portal-content instruction\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.key?.instruction }}</div>\r\n <div class=\"fad-portal-content-bold upload-btn\">\r\n <ng-fad-image-inline [src]=\"uploadImg\"></ng-fad-image-inline>\r\n <span>{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.key?.upload }}</span>\r\n </div>\r\n </div>\r\n\r\n <div *ngIf=\"key?.value\" class=\"container-file\">\r\n <div class=\"document-img\">\r\n <img [src]=\"fileImg\" alt=\"\">\r\n </div>\r\n <div class=\"fad-portal-content\">{{ key?.value.name }}</div>\r\n </div>\r\n\r\n <input type=\"file\" accept=\".key\" #fileKeyInput style=\"display: none\" (change)=\"onFileChange($event, 'key')\">\r\n </div>\r\n\r\n <div class=\"fad-portal-container-input\" [formGroup]=\"form\">\r\n <label class=\"fad-portal-content\" for=\"\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.password?.label }}</label>\r\n <div class=\"input-password\">\r\n <input [type]=\"passwordInputType\" (input)=\"savePassword($event)\" formControlName=\"password\"/>\r\n <div class=\"fad-portal-content-bold password-show\">\r\n <div *ngIf=\"passwordInputType === 'text'\" (click)=\"changePaswordInputType()\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.password?.hide }}</div>\r\n <div *ngIf=\"passwordInputType === 'password'\" (click)=\"changePaswordInputType()\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.password?.show }}</div>\r\n </div>\r\n <ng-fad-portal-shared-form-errors [formData]=\"password!\" [configuration]=\"configuration.formErrors?.configuration!\"></ng-fad-portal-shared-form-errors>\r\n </div>\r\n </div>\r\n\r\n </ng-container>\r\n\r\n <div></div>\r\n\r\n <div class=\"fad-portal-content container-confirm\">\r\n <div *ngIf=\"!allIsRejected()\" (click)=\"isValidated = !isValidated\">\r\n <div>\r\n <ng-fad-image-inline *ngIf=\"isValidated\" [src]=\"checkOnImg\"></ng-fad-image-inline>\r\n <ng-fad-image-inline *ngIf=\"!isValidated\" [src]=\"checkOffImg\"></ng-fad-image-inline>\r\n </div>\r\n <div *ngIf=\"documents.length === 1\">{{ configuration.customization?.moduleCustomization?.legends?.sign?.validate?.singular }}</div>\r\n <div *ngIf=\"documents.length > 1\">{{ configuration.customization?.moduleCustomization?.legends?.sign?.validate?.plural }}</div>\r\n </div>\r\n\r\n <div></div>\r\n\r\n <div class=\"action\">\r\n <button type=\"button\" *ngIf=\"documents.length === 1 && !allIsRejected()\" class=\"fad-portal-primary\" [disabled]=\"!form.valid || !isValidated\" (click)=\"onSignDocuments()\">{{ configuration.customization?.moduleCustomization?.legends?.sign?.button?.sign?.singular }}</button>\r\n <button type=\"button\" *ngIf=\"documents.length > 1 && !allIsRejected()\" class=\"fad-portal-primary\" [disabled]=\"!form.valid || !isValidated\" (click)=\"onSignDocuments()\">{{ configuration.customization?.moduleCustomization?.legends?.sign?.button?.sign?.plural }}</button>\r\n <button type=\"button\" *ngIf=\"documents.length === 1 && allIsRejected()\" class=\"fad-portal-primary\" (click)=\"onSignDocuments()\">{{ configuration.customization?.moduleCustomization?.legends?.sign?.button?.reject?.singular }}</button>\r\n <button type=\"button\" *ngIf=\"documents.length > 1 && allIsRejected()\" class=\"fad-portal-primary\" (click)=\"onSignDocuments()\">{{ configuration.customization?.moduleCustomization?.legends?.sign?.button?.reject?.plural }}</button>\r\n </div>\r\n </div>\r\n</ng-container>\r\n", styles: [":host{display:flex;flex-direction:column;gap:var(--fad-portal-common-separation-md)}:host .container-document{display:flex;flex-direction:column;width:100%;background-color:var(--fad-signature-fea-e-signature-documents-background-color);border-radius:var(--fad-signature-fea-e-signature-documents-border-radius);padding:var(--fad-portal-common-separation-md);box-sizing:border-box;margin-top:var(--fad-portal-common-separation-xs)}:host .container-document .document{display:flex;gap:var(--fad-portal-common-separation-md);justify-content:space-between;border-bottom:1px solid var(--fad-portal-common-border-color);padding:var(--fad-portal-common-separation-md) 0}:host .container-document .document>div{flex:1}:host .container-document .document .status{text-align:center}:host .container-document .document .pages{text-align:end;color:var(--fad-portal-common-legends-secondary)}:host .document:only-child{border-bottom:none!important}:host .container-instruction-file{display:flex;gap:var(--fad-portal-common-separation-md);justify-content:space-between}:host .container-instruction-file .select-file{color:var(--fad-portal-common-primary-color);cursor:pointer}:host .container-upload{width:100%;box-sizing:border-box;border-radius:var(--fad-signature-fea-e-signature-upload-border-radius);border:var(--fad-signature-fea-e-signature-upload-border);padding:var(--fad-portal-common-separation-md);margin-top:var(--fad-portal-common-separation-xs);display:flex;flex-direction:column;gap:var(--fad-portal-common-separation-xs);align-items:center;justify-content:center;text-align:center;background-color:var(--fad-signature-fea-e-signature-upload-background-color)}:host .container-upload .instruction{color:var(--fad-portal-common-legends-secondary)}:host .container-upload .upload-btn{max-width:90%;width:300px;box-sizing:border-box;background-color:var(--fad-signature-fea-e-signature-upload-button-background-color);border-radius:var(--fad-signature-fea-e-signature-upload-button-border-radius);color:var(--fad-portal-common-legends-tertiary);padding:var(--fad-portal-common-separation-xs);cursor:pointer;transition:all .2s ease-out;display:flex;align-items:center;justify-content:center;text-align:center;gap:var(--fad-portal-common-separation-xs)}:host .container-upload .upload-btn:hover{background-color:var(--fad-signature-fea-e-signature-upload-button-hover)}:host .container-file{display:flex;gap:var(--fad-portal-common-separation-md);align-items:center;padding:var(--fad-portal-common-separation-md);border:2px solid var(--fad-portal-common-successful-color);height:71px;border-radius:var(--fad-signature-fea-e-signature-file-border-radius);margin-top:var(--fad-portal-common-separation-xs)}:host .container-file .document-img{background-color:var(--fad-signature-fea-e-signature-file-img-background-color);width:40px;height:40px;border-radius:100%;display:flex;align-items:center;justify-content:center}:host .container-file .document-img img{width:60%;max-width:100%;max-height:100%}:host .fad-portal-container-input .input-password{position:relative}:host .fad-portal-container-input .input-password input{padding-right:100px}:host .fad-portal-container-input .input-password .password-show{position:absolute;right:10px;top:50%;transform:translateY(-50%);color:var(--fad-portal-common-legends-secondary);cursor:pointer}:host .container-confirm{display:flex;justify-content:space-between;align-items:center;gap:var(--fad-portal-common-separation-xs)}:host .container-confirm>div:first-child{display:flex;gap:var(--fad-portal-common-separation-xs)}:host .container-confirm>div:first-child>div:first-child{width:25px;height:25px}:host .container-confirm .action{max-width:80%;width:400px}:host .container-confirm ng-fad-image-inline{cursor:pointer}@media (max-width: 992px){:host .container-document .document{flex-direction:column;gap:var(--fad-portal-common-separation-xs)}:host .container-document .document .status,:host .container-document .document .pages{text-align:start!important}:host .container-confirm{flex-direction:column}:host .container-confirm .action{max-width:100%;width:100%!important}}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "directive", type: i4.DragDropDocumentDirective, selector: "[dragDropDocument]", inputs: ["formatList", "acceptMultipleFiles"], outputs: ["onfiledropped", "onerror"] }, { kind: "component", type: i4.FormErrorsComponent, selector: "ng-fad-portal-shared-form-errors", inputs: ["configuration", "formData"], outputs: ["onerror"] }, { kind: "component", type: i5.NgFadImageInlineComponent, selector: "ng-fad-image-inline", inputs: ["src"] }] }); }
232
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: UploadESignatureComponent, selector: "ng-fad-signature-fea-upload-e-signature", inputs: { configuration: "configuration", documents: "documents", signerId: "signerId", rfc: "rfc" }, outputs: { onerror: "onerror", onloader: "onloader", oncomplete: "oncomplete" }, ngImport: i0, template: "<ng-container *ngIf=\"showComponent\">\r\n <div>\r\n <div *ngIf=\"documents.length > 1\" class=\"fad-portal-title-bold\">{{ documentPluralTitle }}</div>\r\n <div *ngIf=\"documents.length === 1\" class=\"fad-portal-title-bold\">{{ documentSingularTitle }}</div>\r\n\r\n <div class=\"container-document fad-portal-content\">\r\n <div *ngFor=\"let i of documents\" class=\"document\">\r\n <div>{{ i.doc.name }}</div>\r\n <div class=\"status fad-portal-content-bold\">{{ i.approved ? configuration.customization?.moduleCustomization?.legends?.documents?.status?.approved : configuration.customization?.moduleCustomization?.legends?.documents?.status?.rejected }}</div>\r\n <div class=\"pages\">{{ i.doc.pages }} {{ i.doc.pages > 1 ? configuration.customization?.moduleCustomization?.legends?.documents?.pages?.plural : configuration.customization?.moduleCustomization?.legends?.documents?.pages?.singular }}</div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <ng-container *ngIf=\"!allIsRejected()\">\r\n <div class=\"fad-portal-title-bold\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.title }}</div>\r\n\r\n <div>\r\n <div class=\"container-instruction-file\">\r\n <div class=\"fad-portal-content\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.cer?.label }}</div>\r\n <div *ngIf=\"cer?.value\" class=\"fad-portal-content select-file\" (click)=\"openFilePicker(fileCerInput)\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.upload }}</div>\r\n </div>\r\n\r\n <div\r\n *ngIf=\"!cer?.value\"\r\n class=\"container-upload\"\r\n (click)=\"openFilePicker(fileCerInput)\"\r\n dragDropDocument\r\n [formatList]=\"formatCerList\"\r\n [acceptMultipleFiles]=\"false\"\r\n (onfiledropped)=\"onfiledropped($event, 'cer')\"\r\n (onerror)=\"onerrorDirective($event, 'cer')\">\r\n <div class=\"fad-portal-content instruction\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.cer?.instruction }}</div>\r\n <div class=\"fad-portal-content-bold upload-btn\">\r\n <ng-fad-image-inline [src]=\"uploadImg\"></ng-fad-image-inline>\r\n <span>{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.cer?.upload }}</span>\r\n </div>\r\n </div>\r\n\r\n <div *ngIf=\"cer?.value\" class=\"container-file\">\r\n <div class=\"document-img\">\r\n <img [src]=\"fileImg\" alt=\"\">\r\n </div>\r\n <div class=\"fad-portal-content\">{{ cer?.value.name }}</div>\r\n </div>\r\n\r\n <input type=\"file\" accept=\".cer\" #fileCerInput style=\"display: none\" (change)=\"onFileChange($event, 'cer')\">\r\n </div>\r\n\r\n <div>\r\n <div class=\"container-instruction-file\">\r\n <div class=\"fad-portal-content\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.key?.label }}</div>\r\n <div *ngIf=\"key?.value\" class=\"fad-portal-content select-file\" (click)=\"openFilePicker(fileKeyInput)\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.upload }}</div>\r\n </div>\r\n\r\n <div\r\n *ngIf=\"!key?.value\"\r\n class=\"container-upload\"\r\n (click)=\"openFilePicker(fileKeyInput)\"\r\n dragDropDocument\r\n [formatList]=\"formatKeyList\"\r\n [acceptMultipleFiles]=\"false\"\r\n (onfiledropped)=\"onfiledropped($event, 'key')\"\r\n (onerror)=\"onerrorDirective($event, 'key')\">\r\n\r\n <div class=\"fad-portal-content instruction\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.key?.instruction }}</div>\r\n <div class=\"fad-portal-content-bold upload-btn\">\r\n <ng-fad-image-inline [src]=\"uploadImg\"></ng-fad-image-inline>\r\n <span>{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.key?.upload }}</span>\r\n </div>\r\n </div>\r\n\r\n <div *ngIf=\"key?.value\" class=\"container-file\">\r\n <div class=\"document-img\">\r\n <img [src]=\"fileImg\" alt=\"\">\r\n </div>\r\n <div class=\"fad-portal-content\">{{ key?.value.name }}</div>\r\n </div>\r\n\r\n <input type=\"file\" accept=\".key\" #fileKeyInput style=\"display: none\" (change)=\"onFileChange($event, 'key')\">\r\n </div>\r\n\r\n <div class=\"fad-portal-container-input\">\r\n <label class=\"fad-portal-content\" for=\"\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.password?.label }}</label>\r\n <div class=\"input-password\">\r\n <input [type]=\"passwordInputType\" (input)=\"savePassword($event)\">\r\n <div class=\"fad-portal-content-bold password-show\">\r\n <div *ngIf=\"passwordInputType === 'text'\" (click)=\"changePaswordInputType()\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.password?.hide }}</div>\r\n <div *ngIf=\"passwordInputType === 'password'\" (click)=\"changePaswordInputType()\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.password?.show }}</div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n </ng-container>\r\n\r\n <div></div>\r\n\r\n <div class=\"fad-portal-content container-confirm\">\r\n <div *ngIf=\"!allIsRejected()\" (click)=\"isValidated = !isValidated\">\r\n <div>\r\n <ng-fad-image-inline *ngIf=\"isValidated\" [src]=\"checkOnImg\"></ng-fad-image-inline>\r\n <ng-fad-image-inline *ngIf=\"!isValidated\" [src]=\"checkOffImg\"></ng-fad-image-inline>\r\n </div>\r\n <div *ngIf=\"documents.length === 1\">{{ configuration.customization?.moduleCustomization?.legends?.sign?.validate?.singular }}</div>\r\n <div *ngIf=\"documents.length > 1\">{{ configuration.customization?.moduleCustomization?.legends?.sign?.validate?.plural }}</div>\r\n </div>\r\n\r\n <div></div>\r\n\r\n <div class=\"action\">\r\n <button type=\"button\" *ngIf=\"documents.length === 1 && !allIsRejected()\" class=\"fad-portal-primary\" [disabled]=\"!form.valid || !isValidated\" (click)=\"signDocuments()\">{{ configuration.customization?.moduleCustomization?.legends?.sign?.button?.sign?.singular }}</button>\r\n <button type=\"button\" *ngIf=\"documents.length > 1 && !allIsRejected()\" class=\"fad-portal-primary\" [disabled]=\"!form.valid || !isValidated\" (click)=\"signDocuments()\">{{ configuration.customization?.moduleCustomization?.legends?.sign?.button?.sign?.plural }}</button>\r\n <button type=\"button\" *ngIf=\"documents.length === 1 && allIsRejected()\" class=\"fad-portal-primary\" (click)=\"onRejectDocument()\">{{ configuration.customization?.moduleCustomization?.legends?.sign?.button?.reject?.singular }}</button>\r\n <button type=\"button\" *ngIf=\"documents.length > 1 && allIsRejected()\" class=\"fad-portal-primary\" (click)=\"onRejectDocument()\">{{ configuration.customization?.moduleCustomization?.legends?.sign?.button?.reject?.plural }}</button>\r\n </div>\r\n </div>\r\n</ng-container>\r\n", styles: [":host{display:flex;flex-direction:column;gap:var(--fad-portal-common-separation-md)}:host .container-document{display:flex;flex-direction:column;width:100%;background-color:var(--fad-signature-fea-e-signature-documents-background-color);border-radius:var(--fad-signature-fea-e-signature-documents-border-radius);padding:var(--fad-portal-common-separation-md);box-sizing:border-box;margin-top:var(--fad-portal-common-separation-xs)}:host .container-document .document{display:flex;gap:var(--fad-portal-common-separation-md);justify-content:space-between;border-bottom:1px solid var(--fad-portal-common-border-color);padding:var(--fad-portal-common-separation-md) 0}:host .container-document .document>div{flex:1}:host .container-document .document .status{text-align:center}:host .container-document .document .pages{text-align:end;color:var(--fad-portal-common-legends-secondary)}:host .document:only-child{border-bottom:none!important}:host .container-instruction-file{display:flex;gap:var(--fad-portal-common-separation-md);justify-content:space-between}:host .container-instruction-file .select-file{color:var(--fad-portal-common-primary-color);cursor:pointer}:host .container-upload{width:100%;box-sizing:border-box;border-radius:var(--fad-signature-fea-e-signature-upload-border-radius);border:var(--fad-signature-fea-e-signature-upload-border);padding:var(--fad-portal-common-separation-md);margin-top:var(--fad-portal-common-separation-xs);display:flex;flex-direction:column;gap:var(--fad-portal-common-separation-xs);align-items:center;justify-content:center;text-align:center;background-color:var(--fad-signature-fea-e-signature-upload-background-color)}:host .container-upload .instruction{color:var(--fad-portal-common-legends-secondary)}:host .container-upload .upload-btn{max-width:90%;width:300px;box-sizing:border-box;background-color:var(--fad-signature-fea-e-signature-upload-button-background-color);border-radius:var(--fad-signature-fea-e-signature-upload-button-border-radius);color:var(--fad-portal-common-legends-tertiary);padding:var(--fad-portal-common-separation-xs);cursor:pointer;transition:all .2s ease-out;display:flex;align-items:center;justify-content:center;text-align:center;gap:var(--fad-portal-common-separation-xs)}:host .container-upload .upload-btn:hover{background-color:var(--fad-signature-fea-e-signature-upload-button-hover)}:host .container-file{display:flex;gap:var(--fad-portal-common-separation-md);align-items:center;padding:var(--fad-portal-common-separation-md);border:2px solid var(--fad-portal-common-successful-color);height:71px;border-radius:var(--fad-signature-fea-e-signature-file-border-radius);margin-top:var(--fad-portal-common-separation-xs)}:host .container-file .fad-portal-content{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}:host .container-file .document-img{background-color:var(--fad-signature-fea-e-signature-file-img-background-color);width:40px;height:40px;border-radius:100%;display:flex;align-items:center;justify-content:center}:host .container-file .document-img img{width:60%;max-width:100%;max-height:100%}:host .fad-portal-container-input .input-password{position:relative}:host .fad-portal-container-input .input-password input{padding-right:100px}:host .fad-portal-container-input .input-password .password-show{position:absolute;right:10px;top:50%;transform:translateY(-50%);color:var(--fad-portal-common-legends-secondary);cursor:pointer}:host .container-confirm{display:flex;justify-content:space-between;align-items:center;gap:var(--fad-portal-common-separation-xs)}:host .container-confirm>div:first-child{display:flex;gap:var(--fad-portal-common-separation-xs)}:host .container-confirm>div:first-child>div:first-child{width:25px;height:25px}:host .container-confirm .action{max-width:80%;width:400px}:host .container-confirm ng-fad-image-inline{cursor:pointer}@media (max-width: 992px){:host .container-document .document{flex-direction:column;gap:var(--fad-portal-common-separation-xs)}:host .container-document .document .status,:host .container-document .document .pages{text-align:start!important}:host .container-confirm{flex-direction:column}:host .container-confirm .action{max-width:100%;width:100%!important}}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.DragDropDocumentDirective, selector: "[dragDropDocument]", inputs: ["formatList", "acceptMultipleFiles"], outputs: ["onfiledropped", "onerror"] }, { kind: "component", type: i5.NgFadImageInlineComponent, selector: "ng-fad-image-inline", inputs: ["src"] }] }); }
245
233
  }
246
234
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: UploadESignatureComponent, decorators: [{
247
235
  type: Component,
248
- args: [{ selector: 'ng-fad-signature-fea-upload-e-signature', template: "<ng-container *ngIf=\"showComponent\">\r\n <div>\r\n <div *ngIf=\"documents.length > 1\" class=\"fad-portal-title-bold\">{{ documentPluralTitle }}</div>\r\n <div *ngIf=\"documents.length === 1\" class=\"fad-portal-title-bold\">{{ documentSingularTitle }}</div>\r\n\r\n <div class=\"container-document fad-portal-content\">\r\n <div *ngFor=\"let i of documents\" class=\"document\">\r\n <div>{{ i.doc.name }}</div>\r\n <div class=\"status fad-portal-content-bold\">{{ i.approved ? configuration.customization?.moduleCustomization?.legends?.documents?.status?.approved : configuration.customization?.moduleCustomization?.legends?.documents?.status?.rejected }}</div>\r\n <div class=\"pages\">{{ i.doc.pages }} {{ i.doc.pages > 1 ? configuration.customization?.moduleCustomization?.legends?.documents?.pages?.plural : configuration.customization?.moduleCustomization?.legends?.documents?.pages?.singular }}</div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <ng-container *ngIf=\"!allIsRejected()\">\r\n <div class=\"fad-portal-title-bold\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.title }}</div>\r\n\r\n <div>\r\n <div class=\"container-instruction-file\">\r\n <div class=\"fad-portal-content\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.cer?.label }}</div>\r\n <div *ngIf=\"cer?.value\" class=\"fad-portal-content select-file\" (click)=\"openFilePicker(fileCerInput)\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.upload }}</div>\r\n </div>\r\n\r\n <div\r\n *ngIf=\"!cer?.value\"\r\n class=\"container-upload\"\r\n (click)=\"openFilePicker(fileCerInput)\"\r\n dragDropDocument\r\n [formatList]=\"formatCerList\"\r\n [acceptMultipleFiles]=\"false\"\r\n (onfiledropped)=\"onfiledropped($event, 'cer')\"\r\n (onerror)=\"onerrorDirective($event, 'cer')\">\r\n <div class=\"fad-portal-content instruction\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.cer?.instruction }}</div>\r\n <div class=\"fad-portal-content-bold upload-btn\">\r\n <ng-fad-image-inline [src]=\"uploadImg\"></ng-fad-image-inline>\r\n <span>{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.cer?.upload }}</span>\r\n </div>\r\n </div>\r\n\r\n <div *ngIf=\"cer?.value\" class=\"container-file\">\r\n <div class=\"document-img\">\r\n <img [src]=\"fileImg\" alt=\"\">\r\n </div>\r\n <div class=\"fad-portal-content\">{{ cer?.value.name }}</div>\r\n </div>\r\n\r\n <input type=\"file\" accept=\".cer\" #fileCerInput style=\"display: none\" (change)=\"onFileChange($event, 'cer')\">\r\n </div>\r\n\r\n <div>\r\n <div class=\"container-instruction-file\">\r\n <div class=\"fad-portal-content\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.key?.label }}</div>\r\n <div *ngIf=\"key?.value\" class=\"fad-portal-content select-file\" (click)=\"openFilePicker(fileKeyInput)\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.upload }}</div>\r\n </div>\r\n\r\n <div\r\n *ngIf=\"!key?.value\"\r\n class=\"container-upload\"\r\n (click)=\"openFilePicker(fileKeyInput)\"\r\n dragDropDocument\r\n [formatList]=\"formatKeyList\"\r\n [acceptMultipleFiles]=\"false\"\r\n (onfiledropped)=\"onfiledropped($event, 'key')\"\r\n (onerror)=\"onerrorDirective($event, 'key')\">\r\n\r\n <div class=\"fad-portal-content instruction\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.key?.instruction }}</div>\r\n <div class=\"fad-portal-content-bold upload-btn\">\r\n <ng-fad-image-inline [src]=\"uploadImg\"></ng-fad-image-inline>\r\n <span>{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.key?.upload }}</span>\r\n </div>\r\n </div>\r\n\r\n <div *ngIf=\"key?.value\" class=\"container-file\">\r\n <div class=\"document-img\">\r\n <img [src]=\"fileImg\" alt=\"\">\r\n </div>\r\n <div class=\"fad-portal-content\">{{ key?.value.name }}</div>\r\n </div>\r\n\r\n <input type=\"file\" accept=\".key\" #fileKeyInput style=\"display: none\" (change)=\"onFileChange($event, 'key')\">\r\n </div>\r\n\r\n <div class=\"fad-portal-container-input\" [formGroup]=\"form\">\r\n <label class=\"fad-portal-content\" for=\"\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.password?.label }}</label>\r\n <div class=\"input-password\">\r\n <input [type]=\"passwordInputType\" (input)=\"savePassword($event)\" formControlName=\"password\"/>\r\n <div class=\"fad-portal-content-bold password-show\">\r\n <div *ngIf=\"passwordInputType === 'text'\" (click)=\"changePaswordInputType()\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.password?.hide }}</div>\r\n <div *ngIf=\"passwordInputType === 'password'\" (click)=\"changePaswordInputType()\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.password?.show }}</div>\r\n </div>\r\n <ng-fad-portal-shared-form-errors [formData]=\"password!\" [configuration]=\"configuration.formErrors?.configuration!\"></ng-fad-portal-shared-form-errors>\r\n </div>\r\n </div>\r\n\r\n </ng-container>\r\n\r\n <div></div>\r\n\r\n <div class=\"fad-portal-content container-confirm\">\r\n <div *ngIf=\"!allIsRejected()\" (click)=\"isValidated = !isValidated\">\r\n <div>\r\n <ng-fad-image-inline *ngIf=\"isValidated\" [src]=\"checkOnImg\"></ng-fad-image-inline>\r\n <ng-fad-image-inline *ngIf=\"!isValidated\" [src]=\"checkOffImg\"></ng-fad-image-inline>\r\n </div>\r\n <div *ngIf=\"documents.length === 1\">{{ configuration.customization?.moduleCustomization?.legends?.sign?.validate?.singular }}</div>\r\n <div *ngIf=\"documents.length > 1\">{{ configuration.customization?.moduleCustomization?.legends?.sign?.validate?.plural }}</div>\r\n </div>\r\n\r\n <div></div>\r\n\r\n <div class=\"action\">\r\n <button type=\"button\" *ngIf=\"documents.length === 1 && !allIsRejected()\" class=\"fad-portal-primary\" [disabled]=\"!form.valid || !isValidated\" (click)=\"onSignDocuments()\">{{ configuration.customization?.moduleCustomization?.legends?.sign?.button?.sign?.singular }}</button>\r\n <button type=\"button\" *ngIf=\"documents.length > 1 && !allIsRejected()\" class=\"fad-portal-primary\" [disabled]=\"!form.valid || !isValidated\" (click)=\"onSignDocuments()\">{{ configuration.customization?.moduleCustomization?.legends?.sign?.button?.sign?.plural }}</button>\r\n <button type=\"button\" *ngIf=\"documents.length === 1 && allIsRejected()\" class=\"fad-portal-primary\" (click)=\"onSignDocuments()\">{{ configuration.customization?.moduleCustomization?.legends?.sign?.button?.reject?.singular }}</button>\r\n <button type=\"button\" *ngIf=\"documents.length > 1 && allIsRejected()\" class=\"fad-portal-primary\" (click)=\"onSignDocuments()\">{{ configuration.customization?.moduleCustomization?.legends?.sign?.button?.reject?.plural }}</button>\r\n </div>\r\n </div>\r\n</ng-container>\r\n", styles: [":host{display:flex;flex-direction:column;gap:var(--fad-portal-common-separation-md)}:host .container-document{display:flex;flex-direction:column;width:100%;background-color:var(--fad-signature-fea-e-signature-documents-background-color);border-radius:var(--fad-signature-fea-e-signature-documents-border-radius);padding:var(--fad-portal-common-separation-md);box-sizing:border-box;margin-top:var(--fad-portal-common-separation-xs)}:host .container-document .document{display:flex;gap:var(--fad-portal-common-separation-md);justify-content:space-between;border-bottom:1px solid var(--fad-portal-common-border-color);padding:var(--fad-portal-common-separation-md) 0}:host .container-document .document>div{flex:1}:host .container-document .document .status{text-align:center}:host .container-document .document .pages{text-align:end;color:var(--fad-portal-common-legends-secondary)}:host .document:only-child{border-bottom:none!important}:host .container-instruction-file{display:flex;gap:var(--fad-portal-common-separation-md);justify-content:space-between}:host .container-instruction-file .select-file{color:var(--fad-portal-common-primary-color);cursor:pointer}:host .container-upload{width:100%;box-sizing:border-box;border-radius:var(--fad-signature-fea-e-signature-upload-border-radius);border:var(--fad-signature-fea-e-signature-upload-border);padding:var(--fad-portal-common-separation-md);margin-top:var(--fad-portal-common-separation-xs);display:flex;flex-direction:column;gap:var(--fad-portal-common-separation-xs);align-items:center;justify-content:center;text-align:center;background-color:var(--fad-signature-fea-e-signature-upload-background-color)}:host .container-upload .instruction{color:var(--fad-portal-common-legends-secondary)}:host .container-upload .upload-btn{max-width:90%;width:300px;box-sizing:border-box;background-color:var(--fad-signature-fea-e-signature-upload-button-background-color);border-radius:var(--fad-signature-fea-e-signature-upload-button-border-radius);color:var(--fad-portal-common-legends-tertiary);padding:var(--fad-portal-common-separation-xs);cursor:pointer;transition:all .2s ease-out;display:flex;align-items:center;justify-content:center;text-align:center;gap:var(--fad-portal-common-separation-xs)}:host .container-upload .upload-btn:hover{background-color:var(--fad-signature-fea-e-signature-upload-button-hover)}:host .container-file{display:flex;gap:var(--fad-portal-common-separation-md);align-items:center;padding:var(--fad-portal-common-separation-md);border:2px solid var(--fad-portal-common-successful-color);height:71px;border-radius:var(--fad-signature-fea-e-signature-file-border-radius);margin-top:var(--fad-portal-common-separation-xs)}:host .container-file .document-img{background-color:var(--fad-signature-fea-e-signature-file-img-background-color);width:40px;height:40px;border-radius:100%;display:flex;align-items:center;justify-content:center}:host .container-file .document-img img{width:60%;max-width:100%;max-height:100%}:host .fad-portal-container-input .input-password{position:relative}:host .fad-portal-container-input .input-password input{padding-right:100px}:host .fad-portal-container-input .input-password .password-show{position:absolute;right:10px;top:50%;transform:translateY(-50%);color:var(--fad-portal-common-legends-secondary);cursor:pointer}:host .container-confirm{display:flex;justify-content:space-between;align-items:center;gap:var(--fad-portal-common-separation-xs)}:host .container-confirm>div:first-child{display:flex;gap:var(--fad-portal-common-separation-xs)}:host .container-confirm>div:first-child>div:first-child{width:25px;height:25px}:host .container-confirm .action{max-width:80%;width:400px}:host .container-confirm ng-fad-image-inline{cursor:pointer}@media (max-width: 992px){:host .container-document .document{flex-direction:column;gap:var(--fad-portal-common-separation-xs)}:host .container-document .document .status,:host .container-document .document .pages{text-align:start!important}:host .container-confirm{flex-direction:column}:host .container-confirm .action{max-width:100%;width:100%!important}}\n"] }]
236
+ args: [{ selector: 'ng-fad-signature-fea-upload-e-signature', template: "<ng-container *ngIf=\"showComponent\">\r\n <div>\r\n <div *ngIf=\"documents.length > 1\" class=\"fad-portal-title-bold\">{{ documentPluralTitle }}</div>\r\n <div *ngIf=\"documents.length === 1\" class=\"fad-portal-title-bold\">{{ documentSingularTitle }}</div>\r\n\r\n <div class=\"container-document fad-portal-content\">\r\n <div *ngFor=\"let i of documents\" class=\"document\">\r\n <div>{{ i.doc.name }}</div>\r\n <div class=\"status fad-portal-content-bold\">{{ i.approved ? configuration.customization?.moduleCustomization?.legends?.documents?.status?.approved : configuration.customization?.moduleCustomization?.legends?.documents?.status?.rejected }}</div>\r\n <div class=\"pages\">{{ i.doc.pages }} {{ i.doc.pages > 1 ? configuration.customization?.moduleCustomization?.legends?.documents?.pages?.plural : configuration.customization?.moduleCustomization?.legends?.documents?.pages?.singular }}</div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <ng-container *ngIf=\"!allIsRejected()\">\r\n <div class=\"fad-portal-title-bold\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.title }}</div>\r\n\r\n <div>\r\n <div class=\"container-instruction-file\">\r\n <div class=\"fad-portal-content\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.cer?.label }}</div>\r\n <div *ngIf=\"cer?.value\" class=\"fad-portal-content select-file\" (click)=\"openFilePicker(fileCerInput)\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.upload }}</div>\r\n </div>\r\n\r\n <div\r\n *ngIf=\"!cer?.value\"\r\n class=\"container-upload\"\r\n (click)=\"openFilePicker(fileCerInput)\"\r\n dragDropDocument\r\n [formatList]=\"formatCerList\"\r\n [acceptMultipleFiles]=\"false\"\r\n (onfiledropped)=\"onfiledropped($event, 'cer')\"\r\n (onerror)=\"onerrorDirective($event, 'cer')\">\r\n <div class=\"fad-portal-content instruction\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.cer?.instruction }}</div>\r\n <div class=\"fad-portal-content-bold upload-btn\">\r\n <ng-fad-image-inline [src]=\"uploadImg\"></ng-fad-image-inline>\r\n <span>{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.cer?.upload }}</span>\r\n </div>\r\n </div>\r\n\r\n <div *ngIf=\"cer?.value\" class=\"container-file\">\r\n <div class=\"document-img\">\r\n <img [src]=\"fileImg\" alt=\"\">\r\n </div>\r\n <div class=\"fad-portal-content\">{{ cer?.value.name }}</div>\r\n </div>\r\n\r\n <input type=\"file\" accept=\".cer\" #fileCerInput style=\"display: none\" (change)=\"onFileChange($event, 'cer')\">\r\n </div>\r\n\r\n <div>\r\n <div class=\"container-instruction-file\">\r\n <div class=\"fad-portal-content\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.key?.label }}</div>\r\n <div *ngIf=\"key?.value\" class=\"fad-portal-content select-file\" (click)=\"openFilePicker(fileKeyInput)\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.upload }}</div>\r\n </div>\r\n\r\n <div\r\n *ngIf=\"!key?.value\"\r\n class=\"container-upload\"\r\n (click)=\"openFilePicker(fileKeyInput)\"\r\n dragDropDocument\r\n [formatList]=\"formatKeyList\"\r\n [acceptMultipleFiles]=\"false\"\r\n (onfiledropped)=\"onfiledropped($event, 'key')\"\r\n (onerror)=\"onerrorDirective($event, 'key')\">\r\n\r\n <div class=\"fad-portal-content instruction\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.key?.instruction }}</div>\r\n <div class=\"fad-portal-content-bold upload-btn\">\r\n <ng-fad-image-inline [src]=\"uploadImg\"></ng-fad-image-inline>\r\n <span>{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.key?.upload }}</span>\r\n </div>\r\n </div>\r\n\r\n <div *ngIf=\"key?.value\" class=\"container-file\">\r\n <div class=\"document-img\">\r\n <img [src]=\"fileImg\" alt=\"\">\r\n </div>\r\n <div class=\"fad-portal-content\">{{ key?.value.name }}</div>\r\n </div>\r\n\r\n <input type=\"file\" accept=\".key\" #fileKeyInput style=\"display: none\" (change)=\"onFileChange($event, 'key')\">\r\n </div>\r\n\r\n <div class=\"fad-portal-container-input\">\r\n <label class=\"fad-portal-content\" for=\"\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.password?.label }}</label>\r\n <div class=\"input-password\">\r\n <input [type]=\"passwordInputType\" (input)=\"savePassword($event)\">\r\n <div class=\"fad-portal-content-bold password-show\">\r\n <div *ngIf=\"passwordInputType === 'text'\" (click)=\"changePaswordInputType()\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.password?.hide }}</div>\r\n <div *ngIf=\"passwordInputType === 'password'\" (click)=\"changePaswordInputType()\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.password?.show }}</div>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n </ng-container>\r\n\r\n <div></div>\r\n\r\n <div class=\"fad-portal-content container-confirm\">\r\n <div *ngIf=\"!allIsRejected()\" (click)=\"isValidated = !isValidated\">\r\n <div>\r\n <ng-fad-image-inline *ngIf=\"isValidated\" [src]=\"checkOnImg\"></ng-fad-image-inline>\r\n <ng-fad-image-inline *ngIf=\"!isValidated\" [src]=\"checkOffImg\"></ng-fad-image-inline>\r\n </div>\r\n <div *ngIf=\"documents.length === 1\">{{ configuration.customization?.moduleCustomization?.legends?.sign?.validate?.singular }}</div>\r\n <div *ngIf=\"documents.length > 1\">{{ configuration.customization?.moduleCustomization?.legends?.sign?.validate?.plural }}</div>\r\n </div>\r\n\r\n <div></div>\r\n\r\n <div class=\"action\">\r\n <button type=\"button\" *ngIf=\"documents.length === 1 && !allIsRejected()\" class=\"fad-portal-primary\" [disabled]=\"!form.valid || !isValidated\" (click)=\"signDocuments()\">{{ configuration.customization?.moduleCustomization?.legends?.sign?.button?.sign?.singular }}</button>\r\n <button type=\"button\" *ngIf=\"documents.length > 1 && !allIsRejected()\" class=\"fad-portal-primary\" [disabled]=\"!form.valid || !isValidated\" (click)=\"signDocuments()\">{{ configuration.customization?.moduleCustomization?.legends?.sign?.button?.sign?.plural }}</button>\r\n <button type=\"button\" *ngIf=\"documents.length === 1 && allIsRejected()\" class=\"fad-portal-primary\" (click)=\"onRejectDocument()\">{{ configuration.customization?.moduleCustomization?.legends?.sign?.button?.reject?.singular }}</button>\r\n <button type=\"button\" *ngIf=\"documents.length > 1 && allIsRejected()\" class=\"fad-portal-primary\" (click)=\"onRejectDocument()\">{{ configuration.customization?.moduleCustomization?.legends?.sign?.button?.reject?.plural }}</button>\r\n </div>\r\n </div>\r\n</ng-container>\r\n", styles: [":host{display:flex;flex-direction:column;gap:var(--fad-portal-common-separation-md)}:host .container-document{display:flex;flex-direction:column;width:100%;background-color:var(--fad-signature-fea-e-signature-documents-background-color);border-radius:var(--fad-signature-fea-e-signature-documents-border-radius);padding:var(--fad-portal-common-separation-md);box-sizing:border-box;margin-top:var(--fad-portal-common-separation-xs)}:host .container-document .document{display:flex;gap:var(--fad-portal-common-separation-md);justify-content:space-between;border-bottom:1px solid var(--fad-portal-common-border-color);padding:var(--fad-portal-common-separation-md) 0}:host .container-document .document>div{flex:1}:host .container-document .document .status{text-align:center}:host .container-document .document .pages{text-align:end;color:var(--fad-portal-common-legends-secondary)}:host .document:only-child{border-bottom:none!important}:host .container-instruction-file{display:flex;gap:var(--fad-portal-common-separation-md);justify-content:space-between}:host .container-instruction-file .select-file{color:var(--fad-portal-common-primary-color);cursor:pointer}:host .container-upload{width:100%;box-sizing:border-box;border-radius:var(--fad-signature-fea-e-signature-upload-border-radius);border:var(--fad-signature-fea-e-signature-upload-border);padding:var(--fad-portal-common-separation-md);margin-top:var(--fad-portal-common-separation-xs);display:flex;flex-direction:column;gap:var(--fad-portal-common-separation-xs);align-items:center;justify-content:center;text-align:center;background-color:var(--fad-signature-fea-e-signature-upload-background-color)}:host .container-upload .instruction{color:var(--fad-portal-common-legends-secondary)}:host .container-upload .upload-btn{max-width:90%;width:300px;box-sizing:border-box;background-color:var(--fad-signature-fea-e-signature-upload-button-background-color);border-radius:var(--fad-signature-fea-e-signature-upload-button-border-radius);color:var(--fad-portal-common-legends-tertiary);padding:var(--fad-portal-common-separation-xs);cursor:pointer;transition:all .2s ease-out;display:flex;align-items:center;justify-content:center;text-align:center;gap:var(--fad-portal-common-separation-xs)}:host .container-upload .upload-btn:hover{background-color:var(--fad-signature-fea-e-signature-upload-button-hover)}:host .container-file{display:flex;gap:var(--fad-portal-common-separation-md);align-items:center;padding:var(--fad-portal-common-separation-md);border:2px solid var(--fad-portal-common-successful-color);height:71px;border-radius:var(--fad-signature-fea-e-signature-file-border-radius);margin-top:var(--fad-portal-common-separation-xs)}:host .container-file .fad-portal-content{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}:host .container-file .document-img{background-color:var(--fad-signature-fea-e-signature-file-img-background-color);width:40px;height:40px;border-radius:100%;display:flex;align-items:center;justify-content:center}:host .container-file .document-img img{width:60%;max-width:100%;max-height:100%}:host .fad-portal-container-input .input-password{position:relative}:host .fad-portal-container-input .input-password input{padding-right:100px}:host .fad-portal-container-input .input-password .password-show{position:absolute;right:10px;top:50%;transform:translateY(-50%);color:var(--fad-portal-common-legends-secondary);cursor:pointer}:host .container-confirm{display:flex;justify-content:space-between;align-items:center;gap:var(--fad-portal-common-separation-xs)}:host .container-confirm>div:first-child{display:flex;gap:var(--fad-portal-common-separation-xs)}:host .container-confirm>div:first-child>div:first-child{width:25px;height:25px}:host .container-confirm .action{max-width:80%;width:400px}:host .container-confirm ng-fad-image-inline{cursor:pointer}@media (max-width: 992px){:host .container-document .document{flex-direction:column;gap:var(--fad-portal-common-separation-xs)}:host .container-document .document .status,:host .container-document .document .pages{text-align:start!important}:host .container-confirm{flex-direction:column}:host .container-confirm .action{max-width:100%;width:100%!important}}\n"] }]
249
237
  }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.FormBuilder }, { type: i2.FadService }, { type: i2.MifielService }]; }, propDecorators: { configuration: [{
250
238
  type: Input
251
239
  }], documents: [{
@@ -261,4 +249,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
261
249
  }], oncomplete: [{
262
250
  type: Output
263
251
  }] } });
264
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"upload-e-signature.component.js","sourceRoot":"","sources":["../../../../../../../projects/fad-producto-portal/ng-fad-signature-fea/src/lib/components/upload-e-signature/upload-e-signature.component.ts","../../../../../../../projects/fad-producto-portal/ng-fad-signature-fea/src/lib/components/upload-e-signature/upload-e-signature.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\nimport { Utils } from '@fad-producto-portal/fad-common/utils/utils';\r\nimport { Configuration } from '@fad-producto-portal/fad-common/models/core';\r\nimport { IUploadESignatureConfiguration, UploadESignatureComplete } from '../../models';\r\nimport { getUploadESignatureErrorDescription, UPLOAD_E_SIGNATURE_CONFIGURATION_DEFAULT, UploadESignatureErrorCode } from '../../constants';\r\nimport { FormBuilder, FormGroup, Validators } from '@angular/forms';\r\nimport { ResponseError, SharedUtils } from '@fad-producto-portal/ng-fad-shared';\r\nimport { FadService, MifielService, SignatureFeaRequest, SignInternalFeaRequest } from '@fad-producto-portal/ng-fad-services';\r\nimport { HttpErrorResponse } from '@angular/common/http';\r\nimport { finalize } from 'rxjs';\r\n\r\n@Component({\r\n  selector: 'ng-fad-signature-fea-upload-e-signature',\r\n  templateUrl: './upload-e-signature.component.html',\r\n  styleUrls: ['./upload-e-signature.component.scss']\r\n})\r\nexport class UploadESignatureComponent implements OnInit {\r\n  @Input() configuration!: IUploadESignatureConfiguration;\r\n  @Input() documents: SignInternalFeaRequest[] = [];\r\n  @Input() signerId!: string;\r\n  @Input() rfc!: string;\r\n  @Output() onerror = new EventEmitter<ResponseError>();\r\n  @Output() onloader = new EventEmitter<boolean>();\r\n  @Output() oncomplete = new EventEmitter<null | UploadESignatureComplete>();\r\n  uploadImg!: string;\r\n  checkOnImg!: string;\r\n  checkOffImg!: string;\r\n  fileImg!: string;\r\n  formatCerList = ['cer'];\r\n  formatKeyList = ['key'];\r\n  form!: FormGroup;\r\n  passwordInputType = 'password';\r\n  documentPluralTitle!: string;\r\n  documentSingularTitle!: string;\r\n  isValidated = false;\r\n  showComponent = true;\r\n\r\n  constructor(private hostContext: ElementRef, private fb: FormBuilder,\r\n    private fad: FadService, private mifiel: MifielService) {}\r\n\r\n  ngOnInit(): void {\r\n    this.setCustomizationStyle(this.hostContext.nativeElement);\r\n\r\n    this.uploadImg = this.configuration.pathDependencies?.images?.upload || `${this.configuration.pathDependencies?.imageDirectory}upload.svg`;\r\n    this.checkOnImg = this.configuration.pathDependencies?.images?.checkOn || `${this.configuration.pathDependencies?.imageDirectory}check-on.svg`;\r\n    this.checkOffImg = this.configuration.pathDependencies?.images?.checkOff || `${this.configuration.pathDependencies?.imageDirectory}check-off.svg`;\r\n    this.fileImg = this.configuration.pathDependencies?.images?.file || `${this.configuration.pathDependencies?.imageDirectory}file.svg`;\r\n\r\n    this.showComponent = this.validateData();\r\n    if (this.showComponent) {\r\n      this.documentPluralTitle = this.configuration.customization?.moduleCustomization?.legends?.documents?.title?.plural?.replace('#TOTAL_DOCS', this.documents?.length.toString())!; // poner longitud\r\n      if (this.documents?.length === 1) {\r\n        const status = this.documents[0].approved ? this.configuration.customization?.moduleCustomization?.legends?.documents?.title?.approved! : this.configuration.customization?.moduleCustomization?.legends?.documents?.title?.rejected!;\r\n        this.documentSingularTitle = this.configuration.customization?.moduleCustomization?.legends?.documents?.title?.singular?.replace('#STATUS_DOC', status)!; // poner longitud\r\n      }\r\n\r\n      this.initForm();\r\n    }\r\n  }\r\n\r\n  validateData() {\r\n    if(!this.documents || this.documents.length < 1) {\r\n      this.onerror.emit(new ResponseError(UploadESignatureErrorCode.NO_DOCUMENTS, getUploadESignatureErrorDescription(UploadESignatureErrorCode.NO_DOCUMENTS), 'ng-fad-signature-fea-upload-e-signature'));\r\n      return false;\r\n    }\r\n\r\n    if(!this.signerId) {\r\n      this.onerror.emit(new ResponseError(UploadESignatureErrorCode.NO_SIGNER_ID, getUploadESignatureErrorDescription(UploadESignatureErrorCode.NO_SIGNER_ID), 'ng-fad-signature-fea-upload-e-signature'));\r\n      return false;\r\n    }\r\n\r\n    if(!this.rfc) {\r\n      this.onerror.emit(new ResponseError(UploadESignatureErrorCode.NO_RFC, getUploadESignatureErrorDescription(UploadESignatureErrorCode.NO_RFC), 'ng-fad-signature-fea-upload-e-signature'));\r\n      return false;\r\n    }\r\n\r\n    return true;\r\n  }\r\n\r\n  initForm() {\r\n    this.form = this.fb.group({\r\n      cer: [null, [Validators.required]],\r\n      key: [null, [Validators.required]],\r\n      password: [null, [Validators.required]]\r\n    });\r\n  }\r\n\r\n  get cer() {\r\n    return this.form.get('cer');\r\n  }\r\n\r\n  get key() {\r\n    return this.form.get('key');\r\n  }\r\n\r\n  get password() {\r\n    return this.form.get('password');\r\n  }\r\n\r\n  openFilePicker(fileInput: HTMLInputElement) {\r\n    fileInput.click();\r\n  }\r\n\r\n  onFileChange(event: any, type: string) {\r\n    const file = event.target.files[0];\r\n    if (!file) return;\r\n\r\n    if (event.target.files.length > 1) {\r\n      this.onerror.emit(new ResponseError(UploadESignatureErrorCode.MULTIPLE_FILES, getUploadESignatureErrorDescription(UploadESignatureErrorCode.MULTIPLE_FILES), 'ng-fad-signature-fea-upload-e-signature'));\r\n      return;\r\n    }\r\n\r\n    if (type === 'cer' && !/\\.cer$/.test(file.name)) {\r\n      this.onerror.emit(new ResponseError(UploadESignatureErrorCode.FORMAT_CER, getUploadESignatureErrorDescription(UploadESignatureErrorCode.FORMAT_CER), 'ng-fad-signature-fea-upload-e-signature'));\r\n      return;\r\n    }\r\n\r\n    if (type === 'key' && !/\\.key$/.test(file.name)) {\r\n      this.onerror.emit(new ResponseError(UploadESignatureErrorCode.FORMAT_KEY, getUploadESignatureErrorDescription(UploadESignatureErrorCode.FORMAT_KEY), 'ng-fad-signature-fea-upload-e-signature'));\r\n      return;\r\n    }\r\n\r\n    type === 'cer' ? this.cer?.setValue(file) : this.key?.setValue(file);\r\n  }\r\n\r\n  onfiledropped(files: FileList, type: string) {\r\n    const file = files[0];\r\n    type === 'cer' ? this.cer?.setValue(file) : this.key?.setValue(file);\r\n  }\r\n\r\n  onerrorDirective(event: ResponseError, type: string) {\r\n    if (event.code === -1) this.onerror.emit(new ResponseError(UploadESignatureErrorCode.MULTIPLE_FILES, getUploadESignatureErrorDescription(UploadESignatureErrorCode.MULTIPLE_FILES), 'ng-fad-signature-fea-upload-e-signature'));\r\n    if (event.code === -2 && type === 'cer') this.onerror.emit(new ResponseError(UploadESignatureErrorCode.FORMAT_CER, getUploadESignatureErrorDescription(UploadESignatureErrorCode.FORMAT_CER), 'ng-fad-signature-fea-upload-e-signature'));\r\n    if (event.code === -2 && type === 'key') this.onerror.emit(new ResponseError(UploadESignatureErrorCode.FORMAT_KEY, getUploadESignatureErrorDescription(UploadESignatureErrorCode.FORMAT_KEY), 'ng-fad-signature-fea-upload-e-signature'));\r\n  }\r\n\r\n  changePaswordInputType() {\r\n    this.passwordInputType = this.passwordInputType === 'text' ? 'password' : 'text';\r\n  }\r\n\r\n  savePassword(value: Event) {\r\n    const inputElement = value.target as HTMLInputElement;\r\n    this.password?.setValue(inputElement.value);\r\n  }\r\n\r\n  allIsRejected() {\r\n    return this.documents.every(doc => doc.approved === false);\r\n  }\r\n\r\n  async onSignDocuments() {\r\n    const aprovedDocuments = this.documents.filter((doc) => doc.approved);\r\n    const rejectedDocuments = this.documents.filter((doc) => !doc.approved);\r\n    let cer: null | UploadESignatureComplete = null;\r\n\r\n    if (aprovedDocuments.length > 0) {\r\n      const response = await this.signDocuments();\r\n      if (!response) return;\r\n      cer = response;\r\n    }\r\n\r\n    if (rejectedDocuments.length > 0) {\r\n      const response = await this.rejectDocuments();\r\n      if (!response) return;\r\n    }\r\n\r\n    this.oncomplete.emit(cer);\r\n\r\n  }\r\n\r\n  async signDocuments(): Promise<null | UploadESignatureComplete> {\r\n    return new Promise(async (resolve, reject) => {\r\n      this.onloader.emit(true);\r\n      const cer = await this.getBase64File(this.cer?.value);\r\n      this.onloader.emit(false);\r\n      if (!cer) reject(null);\r\n\r\n      this.onloader.emit(true);\r\n      const key = await this.getBase64File(this.key?.value);\r\n      this.onloader.emit(false);\r\n      if (!key) reject(null);\r\n\r\n      const aprrovedDocuments = this.documents.filter((doc) => doc.approved);\r\n\r\n      const data: SignatureFeaRequest = {\r\n        cer: cer!.split(',')[1],\r\n        key: key!.split(',')[1],\r\n        password: this.password?.value,\r\n        documents: aprrovedDocuments,\r\n        signerId: this.rfc\r\n      }\r\n\r\n      const body = await this.mifiel.getSignBody(data);\r\n      if (!body) {\r\n        this.onerror.emit(new ResponseError(UploadESignatureErrorCode.PASSWORD_ERROR, getUploadESignatureErrorDescription(UploadESignatureErrorCode.PASSWORD_ERROR), 'ng-fad-signature-fea-upload-e-signature'));\r\n        return;\r\n      }\r\n\r\n      this.onloader.emit(true);\r\n      this.fad.signFea(body!, this.configuration.credentials?.key!, this.configuration.credentials?.iv!, this.configuration.services?.reject!).pipe(\r\n        finalize(() => {\r\n          this.onloader.emit(false);\r\n        })\r\n      ).subscribe({\r\n        next: (res) => {\r\n          if (res.success) {\r\n            const certificate = this.mifiel.parseCertificate(data.cer);\r\n\r\n            const cer: UploadESignatureComplete = {\r\n              cer: certificate!\r\n            }\r\n\r\n            resolve(cer);\r\n          } else {\r\n            this.onerror.emit(new ResponseError(UploadESignatureErrorCode.SERVICE,res.error, 'ng-fad-signature-fea-upload-e-signature'));\r\n            reject(null);\r\n          }\r\n        },\r\n        error: (error: HttpErrorResponse) => {\r\n          this.onerror.emit(new ResponseError(UploadESignatureErrorCode.HTTP, error.error, 'ng-fad-signature-fea-upload-e-signature'));\r\n          reject(null);\r\n        },\r\n      });\r\n\r\n    })\r\n  }\r\n\r\n  rejectDocuments(): Promise<boolean> {\r\n    return new Promise((resolve, reject) => {\r\n      const rejectedDocuments = this.documents.filter((doc) => !doc.approved);\r\n\r\n      const body: SignatureFeaRequest = {\r\n        cer: '',\r\n        key: '',\r\n        password: '',\r\n        documents: rejectedDocuments.map(res => {\r\n          return {\r\n            id: res.id,\r\n            idRequisition: res.idRequisition,\r\n          }\r\n        }),\r\n        signerId: this.signerId\r\n      }\r\n\r\n      this.onloader.emit(true);\r\n\r\n      this.fad.rejectFea(body, this.configuration.credentials?.key!, this.configuration.credentials?.iv!, this.configuration.services?.reject!).pipe(\r\n        finalize(() => {\r\n          this.onloader.emit(false);\r\n        })\r\n      ).subscribe({\r\n        next: (res) => {\r\n          if (res.success) {\r\n            resolve(true);\r\n          } else {\r\n            this.onerror.emit(new ResponseError(UploadESignatureErrorCode.SERVICE,res.error, 'ng-fad-signature-fea-upload-e-signature'));\r\n            reject(false);\r\n          }\r\n        },\r\n        error: (error: HttpErrorResponse) => {\r\n          this.onerror.emit(new ResponseError(UploadESignatureErrorCode.HTTP, error.error, 'ng-fad-signature-fea-upload-e-signature'));\r\n          reject(false);\r\n        },\r\n      });\r\n    })\r\n  }\r\n\r\n  async getBase64File(file: File) {\r\n    const data = await SharedUtils.fileToBase64(file).then(base64 => base64).catch(error => null);\r\n    if (data) return data as string;\r\n    else {\r\n      this.onerror.emit(new ResponseError(UploadESignatureErrorCode.ERROR_BASE_64, getUploadESignatureErrorDescription(UploadESignatureErrorCode.ERROR_BASE_64), 'ng-fad-signature-fea-upload-e-signature'));\r\n      return null;\r\n    }\r\n  }\r\n\r\n  setCustomizationStyle(targetElement = document.documentElement): void {\r\n    this.configuration = Utils.mergeConfiguration(new Configuration(), UPLOAD_E_SIGNATURE_CONFIGURATION_DEFAULT, this.configuration);\r\n    Utils.setVariableCss('--fad-signature-fea-e-signature-documents-background-color', this.configuration.customization?.moduleCustomization?.style?.documents?.backgroundColor, { targetElement });\r\n    Utils.setVariableCss('--fad-signature-fea-e-signature-documents-border-radius', this.configuration.customization?.moduleCustomization?.style?.documents?.borderRadius, { targetElement });\r\n\r\n    Utils.setVariableCss('--fad-signature-fea-e-signature-upload-background-color', this.configuration.customization?.moduleCustomization?.style?.upload?.backgroundColor, { targetElement });\r\n    Utils.setVariableCss('--fad-signature-fea-e-signature-upload-border', this.configuration.customization?.moduleCustomization?.style?.upload?.border, { targetElement });\r\n    Utils.setVariableCss('--fad-signature-fea-e-signature-upload-border-radius', this.configuration.customization?.moduleCustomization?.style?.upload?.borderRadius, { targetElement });\r\n\r\n    Utils.setVariableCss('--fad-signature-fea-e-signature-upload-button-background-color', this.configuration.customization?.moduleCustomization?.style?.upload?.button?.backgroundColor, { targetElement });\r\n    Utils.setVariableCss('--fad-signature-fea-e-signature-upload-button-border-radius', this.configuration.customization?.moduleCustomization?.style?.upload?.button?.borderRadius, { targetElement });\r\n    Utils.setVariableCss('--fad-signature-fea-e-signature-upload-button-hover', this.configuration.customization?.moduleCustomization?.style?.upload?.button?.hover, { targetElement });\r\n\r\n    Utils.setVariableCss('--fad-signature-fea-e-signature-file-border-radius', this.configuration.customization?.moduleCustomization?.style?.file?.borderRadius, { targetElement });\r\n    Utils.setVariableCss('--fad-signature-fea-e-signature-file-img-background-color', this.configuration.customization?.moduleCustomization?.style?.file?.img?.backgroundColor, { targetElement });\r\n  }\r\n}\r\n","<ng-container *ngIf=\"showComponent\">\r\n  <div>\r\n    <div *ngIf=\"documents.length > 1\" class=\"fad-portal-title-bold\">{{ documentPluralTitle }}</div>\r\n    <div *ngIf=\"documents.length === 1\" class=\"fad-portal-title-bold\">{{ documentSingularTitle }}</div>\r\n\r\n    <div class=\"container-document fad-portal-content\">\r\n      <div *ngFor=\"let i of documents\" class=\"document\">\r\n        <div>{{ i.doc.name }}</div>\r\n        <div class=\"status fad-portal-content-bold\">{{ i.approved ? configuration.customization?.moduleCustomization?.legends?.documents?.status?.approved :  configuration.customization?.moduleCustomization?.legends?.documents?.status?.rejected }}</div>\r\n        <div class=\"pages\">{{ i.doc.pages }} {{ i.doc.pages > 1 ? configuration.customization?.moduleCustomization?.legends?.documents?.pages?.plural : configuration.customization?.moduleCustomization?.legends?.documents?.pages?.singular }}</div>\r\n      </div>\r\n    </div>\r\n  </div>\r\n\r\n  <ng-container *ngIf=\"!allIsRejected()\">\r\n    <div class=\"fad-portal-title-bold\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.title }}</div>\r\n\r\n    <div>\r\n      <div class=\"container-instruction-file\">\r\n        <div class=\"fad-portal-content\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.cer?.label }}</div>\r\n        <div *ngIf=\"cer?.value\" class=\"fad-portal-content select-file\" (click)=\"openFilePicker(fileCerInput)\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.upload }}</div>\r\n      </div>\r\n\r\n      <div\r\n        *ngIf=\"!cer?.value\"\r\n        class=\"container-upload\"\r\n        (click)=\"openFilePicker(fileCerInput)\"\r\n        dragDropDocument\r\n        [formatList]=\"formatCerList\"\r\n        [acceptMultipleFiles]=\"false\"\r\n        (onfiledropped)=\"onfiledropped($event, 'cer')\"\r\n        (onerror)=\"onerrorDirective($event, 'cer')\">\r\n        <div class=\"fad-portal-content instruction\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.cer?.instruction }}</div>\r\n        <div class=\"fad-portal-content-bold upload-btn\">\r\n          <ng-fad-image-inline [src]=\"uploadImg\"></ng-fad-image-inline>\r\n          <span>{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.cer?.upload }}</span>\r\n        </div>\r\n      </div>\r\n\r\n      <div *ngIf=\"cer?.value\" class=\"container-file\">\r\n        <div class=\"document-img\">\r\n          <img [src]=\"fileImg\" alt=\"\">\r\n        </div>\r\n        <div class=\"fad-portal-content\">{{ cer?.value.name }}</div>\r\n      </div>\r\n\r\n      <input type=\"file\" accept=\".cer\" #fileCerInput style=\"display: none\" (change)=\"onFileChange($event, 'cer')\">\r\n    </div>\r\n\r\n    <div>\r\n      <div class=\"container-instruction-file\">\r\n        <div class=\"fad-portal-content\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.key?.label }}</div>\r\n        <div *ngIf=\"key?.value\" class=\"fad-portal-content select-file\" (click)=\"openFilePicker(fileKeyInput)\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.upload }}</div>\r\n      </div>\r\n\r\n      <div\r\n        *ngIf=\"!key?.value\"\r\n        class=\"container-upload\"\r\n        (click)=\"openFilePicker(fileKeyInput)\"\r\n        dragDropDocument\r\n        [formatList]=\"formatKeyList\"\r\n        [acceptMultipleFiles]=\"false\"\r\n        (onfiledropped)=\"onfiledropped($event, 'key')\"\r\n        (onerror)=\"onerrorDirective($event, 'key')\">\r\n\r\n        <div class=\"fad-portal-content instruction\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.key?.instruction }}</div>\r\n        <div class=\"fad-portal-content-bold upload-btn\">\r\n          <ng-fad-image-inline [src]=\"uploadImg\"></ng-fad-image-inline>\r\n          <span>{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.key?.upload }}</span>\r\n        </div>\r\n      </div>\r\n\r\n      <div *ngIf=\"key?.value\" class=\"container-file\">\r\n        <div class=\"document-img\">\r\n          <img [src]=\"fileImg\" alt=\"\">\r\n        </div>\r\n        <div class=\"fad-portal-content\">{{ key?.value.name }}</div>\r\n      </div>\r\n\r\n      <input type=\"file\" accept=\".key\" #fileKeyInput style=\"display: none\" (change)=\"onFileChange($event, 'key')\">\r\n    </div>\r\n\r\n    <div class=\"fad-portal-container-input\" [formGroup]=\"form\">\r\n      <label class=\"fad-portal-content\" for=\"\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.password?.label }}</label>\r\n      <div class=\"input-password\">\r\n        <input [type]=\"passwordInputType\" (input)=\"savePassword($event)\" formControlName=\"password\"/>\r\n        <div class=\"fad-portal-content-bold password-show\">\r\n          <div *ngIf=\"passwordInputType === 'text'\" (click)=\"changePaswordInputType()\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.password?.hide }}</div>\r\n          <div *ngIf=\"passwordInputType === 'password'\" (click)=\"changePaswordInputType()\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.password?.show }}</div>\r\n        </div>\r\n        <ng-fad-portal-shared-form-errors [formData]=\"password!\" [configuration]=\"configuration.formErrors?.configuration!\"></ng-fad-portal-shared-form-errors>\r\n      </div>\r\n    </div>\r\n\r\n  </ng-container>\r\n\r\n  <div></div>\r\n\r\n  <div class=\"fad-portal-content container-confirm\">\r\n    <div *ngIf=\"!allIsRejected()\" (click)=\"isValidated = !isValidated\">\r\n      <div>\r\n        <ng-fad-image-inline *ngIf=\"isValidated\" [src]=\"checkOnImg\"></ng-fad-image-inline>\r\n        <ng-fad-image-inline *ngIf=\"!isValidated\" [src]=\"checkOffImg\"></ng-fad-image-inline>\r\n      </div>\r\n      <div *ngIf=\"documents.length === 1\">{{ configuration.customization?.moduleCustomization?.legends?.sign?.validate?.singular }}</div>\r\n      <div *ngIf=\"documents.length > 1\">{{ configuration.customization?.moduleCustomization?.legends?.sign?.validate?.plural }}</div>\r\n    </div>\r\n\r\n    <div></div>\r\n\r\n    <div class=\"action\">\r\n      <button type=\"button\" *ngIf=\"documents.length === 1 && !allIsRejected()\" class=\"fad-portal-primary\" [disabled]=\"!form.valid || !isValidated\" (click)=\"onSignDocuments()\">{{ configuration.customization?.moduleCustomization?.legends?.sign?.button?.sign?.singular }}</button>\r\n      <button type=\"button\" *ngIf=\"documents.length > 1 && !allIsRejected()\" class=\"fad-portal-primary\" [disabled]=\"!form.valid || !isValidated\" (click)=\"onSignDocuments()\">{{ configuration.customization?.moduleCustomization?.legends?.sign?.button?.sign?.plural }}</button>\r\n      <button type=\"button\" *ngIf=\"documents.length === 1 && allIsRejected()\" class=\"fad-portal-primary\" (click)=\"onSignDocuments()\">{{ configuration.customization?.moduleCustomization?.legends?.sign?.button?.reject?.singular }}</button>\r\n      <button type=\"button\" *ngIf=\"documents.length > 1 && allIsRejected()\" class=\"fad-portal-primary\" (click)=\"onSignDocuments()\">{{ configuration.customization?.moduleCustomization?.legends?.sign?.button?.reject?.plural }}</button>\r\n    </div>\r\n  </div>\r\n</ng-container>\r\n"]}
252
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"upload-e-signature.component.js","sourceRoot":"","sources":["../../../../../../../projects/fad-producto-portal/ng-fad-signature-fea/src/lib/components/upload-e-signature/upload-e-signature.component.ts","../../../../../../../projects/fad-producto-portal/ng-fad-signature-fea/src/lib/components/upload-e-signature/upload-e-signature.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\nimport { Utils } from '@fad-producto-portal/fad-common/utils/utils';\r\nimport { Configuration } from '@fad-producto-portal/fad-common/models/core';\r\nimport { IUploadESignatureConfiguration, UploadESignatureComplete } from '../../models';\r\nimport { getUploadESignatureErrorDescription, UPLOAD_E_SIGNATURE_CONFIGURATION_DEFAULT, UploadESignatureErrorCode } from '../../constants';\r\nimport { FormBuilder, FormGroup, Validators } from '@angular/forms';\r\nimport { ResponseError, SharedUtils } from '@fad-producto-portal/ng-fad-shared';\r\nimport { FadService, MifielService, SignatureFeaRequest, SignInternalFeaRequest } from '@fad-producto-portal/ng-fad-services';\r\nimport { HttpErrorResponse } from '@angular/common/http';\r\nimport { finalize } from 'rxjs';\r\n\r\n@Component({\r\n  selector: 'ng-fad-signature-fea-upload-e-signature',\r\n  templateUrl: './upload-e-signature.component.html',\r\n  styleUrls: ['./upload-e-signature.component.scss']\r\n})\r\nexport class UploadESignatureComponent implements OnInit {\r\n  @Input() configuration!: IUploadESignatureConfiguration;\r\n  @Input() documents: SignInternalFeaRequest[] = [];\r\n  @Input() signerId!: string;\r\n  @Input() rfc!: string;\r\n  @Output() onerror = new EventEmitter<ResponseError>();\r\n  @Output() onloader = new EventEmitter<boolean>();\r\n  @Output() oncomplete = new EventEmitter<null | UploadESignatureComplete>();\r\n  uploadImg!: string;\r\n  checkOnImg!: string;\r\n  checkOffImg!: string;\r\n  fileImg!: string;\r\n  formatCerList = ['cer'];\r\n  formatKeyList = ['key'];\r\n  form!: FormGroup;\r\n  passwordInputType = 'password';\r\n  documentPluralTitle!: string;\r\n  documentSingularTitle!: string;\r\n  isValidated = false;\r\n  showComponent = true;\r\n\r\n  constructor(private hostContext: ElementRef, private fb: FormBuilder,\r\n    private fad: FadService, private mifiel: MifielService) {}\r\n\r\n  ngOnInit(): void {\r\n    this.setCustomizationStyle(this.hostContext.nativeElement);\r\n\r\n    this.uploadImg = this.configuration.pathDependencies?.images?.upload || `${this.configuration.pathDependencies?.imageDirectory}upload.svg`;\r\n    this.checkOnImg = this.configuration.pathDependencies?.images?.checkOn || `${this.configuration.pathDependencies?.imageDirectory}check-on.svg`;\r\n    this.checkOffImg = this.configuration.pathDependencies?.images?.checkOff || `${this.configuration.pathDependencies?.imageDirectory}check-off.svg`;\r\n    this.fileImg = this.configuration.pathDependencies?.images?.file || `${this.configuration.pathDependencies?.imageDirectory}file.svg`;\r\n\r\n    this.showComponent = this.validateData();\r\n    if (this.showComponent) {\r\n      this.documentPluralTitle = this.configuration.customization?.moduleCustomization?.legends?.documents?.title?.plural?.replace('#TOTAL_DOCS', this.documents?.length.toString())!; // poner longitud\r\n      if (this.documents?.length === 1) {\r\n        const status = this.documents[0].approved ? this.configuration.customization?.moduleCustomization?.legends?.documents?.title?.approved! : this.configuration.customization?.moduleCustomization?.legends?.documents?.title?.rejected!;\r\n        this.documentSingularTitle = this.configuration.customization?.moduleCustomization?.legends?.documents?.title?.singular?.replace('#STATUS_DOC', status)!; // poner longitud\r\n      }\r\n\r\n      this.initForm();\r\n    }\r\n  }\r\n\r\n  validateData() {\r\n    if(!this.documents || this.documents.length < 1) {\r\n      this.onerror.emit(new ResponseError(UploadESignatureErrorCode.NO_DOCUMENTS, getUploadESignatureErrorDescription(UploadESignatureErrorCode.NO_DOCUMENTS), 'ng-fad-signature-fea-upload-e-signature'));\r\n      return false;\r\n    }\r\n\r\n    if(!this.signerId) {\r\n      this.onerror.emit(new ResponseError(UploadESignatureErrorCode.NO_SIGNER_ID, getUploadESignatureErrorDescription(UploadESignatureErrorCode.NO_SIGNER_ID), 'ng-fad-signature-fea-upload-e-signature'));\r\n      return false;\r\n    }\r\n\r\n    if(!this.rfc) {\r\n      this.onerror.emit(new ResponseError(UploadESignatureErrorCode.NO_RFC, getUploadESignatureErrorDescription(UploadESignatureErrorCode.NO_RFC), 'ng-fad-signature-fea-upload-e-signature'));\r\n      return false;\r\n    }\r\n\r\n    return true;\r\n  }\r\n\r\n  initForm() {\r\n    this.form = this.fb.group({\r\n      cer: [null, [Validators.required]],\r\n      key: [null, [Validators.required]],\r\n      password: [null, [Validators.required]]\r\n    });\r\n  }\r\n\r\n  get cer() {\r\n    return this.form.get('cer');\r\n  }\r\n\r\n  get key() {\r\n    return this.form.get('key');\r\n  }\r\n\r\n  get password() {\r\n    return this.form.get('password');\r\n  }\r\n\r\n  openFilePicker(fileInput: HTMLInputElement) {\r\n    fileInput.click();\r\n  }\r\n\r\n  onFileChange(event: any, type: string) {\r\n    const file = event.target.files[0];\r\n    if (!file) return;\r\n\r\n    if (event.target.files.length > 1) {\r\n      this.onerror.emit(new ResponseError(UploadESignatureErrorCode.MULTIPLE_FILES, getUploadESignatureErrorDescription(UploadESignatureErrorCode.MULTIPLE_FILES), 'ng-fad-signature-fea-upload-e-signature'));\r\n      return;\r\n    }\r\n\r\n    if (type === 'cer' && !/\\.cer$/.test(file.name)) {\r\n      this.onerror.emit(new ResponseError(UploadESignatureErrorCode.FORMAT_CER, getUploadESignatureErrorDescription(UploadESignatureErrorCode.FORMAT_CER), 'ng-fad-signature-fea-upload-e-signature'));\r\n      return;\r\n    }\r\n\r\n    if (type === 'key' && !/\\.key$/.test(file.name)) {\r\n      this.onerror.emit(new ResponseError(UploadESignatureErrorCode.FORMAT_KEY, getUploadESignatureErrorDescription(UploadESignatureErrorCode.FORMAT_KEY), 'ng-fad-signature-fea-upload-e-signature'));\r\n      return;\r\n    }\r\n\r\n    type === 'cer' ? this.cer?.setValue(file) : this.key?.setValue(file);\r\n  }\r\n\r\n  onfiledropped(files: FileList, type: string) {\r\n    const file = files[0];\r\n    type === 'cer' ? this.cer?.setValue(file) : this.key?.setValue(file);\r\n  }\r\n\r\n  onerrorDirective(event: ResponseError, type: string) {\r\n    if (event.code === -1) this.onerror.emit(new ResponseError(UploadESignatureErrorCode.MULTIPLE_FILES, getUploadESignatureErrorDescription(UploadESignatureErrorCode.MULTIPLE_FILES), 'ng-fad-signature-fea-upload-e-signature'));\r\n    if (event.code === -2 && type === 'cer') this.onerror.emit(new ResponseError(UploadESignatureErrorCode.FORMAT_CER, getUploadESignatureErrorDescription(UploadESignatureErrorCode.FORMAT_CER), 'ng-fad-signature-fea-upload-e-signature'));\r\n    if (event.code === -2 && type === 'key') this.onerror.emit(new ResponseError(UploadESignatureErrorCode.FORMAT_KEY, getUploadESignatureErrorDescription(UploadESignatureErrorCode.FORMAT_KEY), 'ng-fad-signature-fea-upload-e-signature'));\r\n  }\r\n\r\n  changePaswordInputType() {\r\n    this.passwordInputType = this.passwordInputType === 'text' ? 'password' : 'text';\r\n  }\r\n\r\n  savePassword(value: Event) {\r\n    const inputElement = value.target as HTMLInputElement;\r\n    this.password?.setValue(inputElement.value);\r\n  }\r\n\r\n  allIsRejected() {\r\n    return this.documents.every(doc => doc.approved === false);\r\n  }\r\n\r\n  async signDocuments() {\r\n    let canContinue: boolean | null = true;\r\n\r\n    const rejectedDocuments = this.documents.filter((doc) => !doc.approved);\r\n    if (rejectedDocuments.length > 0) {\r\n      canContinue = await this.rejectDocuments(true);\r\n    }\r\n\r\n    if (!canContinue) return;\r\n\r\n    this.onloader.emit(true);\r\n    const cer = await this.getBase64File(this.cer?.value);\r\n    this.onloader.emit(false);\r\n    if (!cer) return;\r\n\r\n    this.onloader.emit(true);\r\n    const key = await this.getBase64File(this.key?.value);\r\n    this.onloader.emit(false);\r\n    if (!key) return;\r\n\r\n    const aprrovedDocuments = this.documents.filter((doc) => doc.approved);\r\n\r\n    const body: SignatureFeaRequest = {\r\n      cer: cer.split(',')[1],\r\n      key: key.split(',')[1],\r\n      password: this.password?.value,\r\n      documents: aprrovedDocuments,\r\n      signerId: this.rfc\r\n    }\r\n\r\n    this.onloader.emit(true);\r\n\r\n    this.fad.signFea(body, this.configuration.credentials?.key!, this.configuration.credentials?.iv!, this.configuration.services?.reject!).pipe(\r\n      finalize(() => {\r\n        this.onloader.emit(false);\r\n      })\r\n    ).subscribe({\r\n      next: (res) => {\r\n        if (res.success) {\r\n          const certificate = this.mifiel.parseCertificate(body.cer);\r\n          const data: UploadESignatureComplete = {\r\n            cer: certificate!\r\n          }\r\n\r\n          this.oncomplete.emit(data);\r\n        } else {\r\n          this.onerror.emit(new ResponseError(UploadESignatureErrorCode.SERVICE,res.error, 'ng-fad-signature-fea-upload-e-signature'));;\r\n        }\r\n      },\r\n      error: (error: HttpErrorResponse) => {\r\n        this.onerror.emit(new ResponseError(UploadESignatureErrorCode.HTTP, error.error, 'ng-fad-signature-fea-upload-e-signature'));;\r\n      },\r\n    });\r\n\r\n  }\r\n\r\n  rejectDocuments(fromSign = false): Promise<boolean | null> {\r\n    return new Promise((resolve, reject) => {\r\n      const rejectedDocuments = this.documents.filter((doc) => !doc.approved);\r\n\r\n      const body: SignatureFeaRequest = {\r\n        cer: '',\r\n        key: '',\r\n        password: '',\r\n        documents: rejectedDocuments.map(res => {\r\n          return {\r\n            id: res.id,\r\n            idRequisition: res.idRequisition,\r\n          }\r\n        }),\r\n        signerId: this.signerId\r\n      }\r\n\r\n      this.onloader.emit(true);\r\n\r\n\r\n      this.fad.rejectFea(body, this.configuration.credentials?.key!, this.configuration.credentials?.iv!, this.configuration.services?.reject!).pipe(\r\n        finalize(() => {\r\n          this.onloader.emit(false);\r\n        })\r\n      ).subscribe({\r\n        next: (res) => {\r\n          if (res.success) {\r\n            if (!fromSign) this.oncomplete.emit(null);\r\n            resolve(true);\r\n          } else {\r\n            this.onerror.emit(new ResponseError(UploadESignatureErrorCode.SERVICE,res.error, 'ng-fad-signature-fea-upload-e-signature'));\r\n            reject(null);\r\n          }\r\n        },\r\n        error: (error: HttpErrorResponse) => {\r\n          this.onerror.emit(new ResponseError(UploadESignatureErrorCode.HTTP, error.error, 'ng-fad-signature-fea-upload-e-signature'));\r\n          reject(null);\r\n        },\r\n      });\r\n    })\r\n  }\r\n\r\n  async onRejectDocument() {\r\n    await this.rejectDocuments();\r\n  }\r\n\r\n  async getBase64File(file: File) {\r\n    const data = await SharedUtils.fileToBase64(file).then(base64 => base64).catch(error => null);\r\n    if (data) return data as string;\r\n    else {\r\n      this.onerror.emit(new ResponseError(UploadESignatureErrorCode.ERROR_BASE_64, getUploadESignatureErrorDescription(UploadESignatureErrorCode.ERROR_BASE_64), 'ng-fad-signature-fea-upload-e-signature'));\r\n      return null;\r\n    }\r\n  }\r\n\r\n  setCustomizationStyle(targetElement = document.documentElement): void {\r\n    this.configuration = Utils.mergeConfiguration(new Configuration(), UPLOAD_E_SIGNATURE_CONFIGURATION_DEFAULT, this.configuration);\r\n    Utils.setVariableCss('--fad-signature-fea-e-signature-documents-background-color', this.configuration.customization?.moduleCustomization?.style?.documents?.backgroundColor, { targetElement });\r\n    Utils.setVariableCss('--fad-signature-fea-e-signature-documents-border-radius', this.configuration.customization?.moduleCustomization?.style?.documents?.borderRadius, { targetElement });\r\n\r\n    Utils.setVariableCss('--fad-signature-fea-e-signature-upload-background-color', this.configuration.customization?.moduleCustomization?.style?.upload?.backgroundColor, { targetElement });\r\n    Utils.setVariableCss('--fad-signature-fea-e-signature-upload-border', this.configuration.customization?.moduleCustomization?.style?.upload?.border, { targetElement });\r\n    Utils.setVariableCss('--fad-signature-fea-e-signature-upload-border-radius', this.configuration.customization?.moduleCustomization?.style?.upload?.borderRadius, { targetElement });\r\n\r\n    Utils.setVariableCss('--fad-signature-fea-e-signature-upload-button-background-color', this.configuration.customization?.moduleCustomization?.style?.upload?.button?.backgroundColor, { targetElement });\r\n    Utils.setVariableCss('--fad-signature-fea-e-signature-upload-button-border-radius', this.configuration.customization?.moduleCustomization?.style?.upload?.button?.borderRadius, { targetElement });\r\n    Utils.setVariableCss('--fad-signature-fea-e-signature-upload-button-hover', this.configuration.customization?.moduleCustomization?.style?.upload?.button?.hover, { targetElement });\r\n\r\n    Utils.setVariableCss('--fad-signature-fea-e-signature-file-border-radius', this.configuration.customization?.moduleCustomization?.style?.file?.borderRadius, { targetElement });\r\n    Utils.setVariableCss('--fad-signature-fea-e-signature-file-img-background-color', this.configuration.customization?.moduleCustomization?.style?.file?.img?.backgroundColor, { targetElement });\r\n  }\r\n}\r\n","<ng-container *ngIf=\"showComponent\">\r\n  <div>\r\n    <div *ngIf=\"documents.length > 1\" class=\"fad-portal-title-bold\">{{ documentPluralTitle }}</div>\r\n    <div *ngIf=\"documents.length === 1\" class=\"fad-portal-title-bold\">{{ documentSingularTitle }}</div>\r\n\r\n    <div class=\"container-document fad-portal-content\">\r\n      <div *ngFor=\"let i of documents\" class=\"document\">\r\n        <div>{{ i.doc.name }}</div>\r\n        <div class=\"status fad-portal-content-bold\">{{ i.approved ? configuration.customization?.moduleCustomization?.legends?.documents?.status?.approved :  configuration.customization?.moduleCustomization?.legends?.documents?.status?.rejected }}</div>\r\n        <div class=\"pages\">{{ i.doc.pages }} {{ i.doc.pages > 1 ? configuration.customization?.moduleCustomization?.legends?.documents?.pages?.plural : configuration.customization?.moduleCustomization?.legends?.documents?.pages?.singular }}</div>\r\n      </div>\r\n    </div>\r\n  </div>\r\n\r\n  <ng-container *ngIf=\"!allIsRejected()\">\r\n    <div class=\"fad-portal-title-bold\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.title }}</div>\r\n\r\n    <div>\r\n      <div class=\"container-instruction-file\">\r\n        <div class=\"fad-portal-content\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.cer?.label }}</div>\r\n        <div *ngIf=\"cer?.value\" class=\"fad-portal-content select-file\" (click)=\"openFilePicker(fileCerInput)\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.upload }}</div>\r\n      </div>\r\n\r\n      <div\r\n        *ngIf=\"!cer?.value\"\r\n        class=\"container-upload\"\r\n        (click)=\"openFilePicker(fileCerInput)\"\r\n        dragDropDocument\r\n        [formatList]=\"formatCerList\"\r\n        [acceptMultipleFiles]=\"false\"\r\n        (onfiledropped)=\"onfiledropped($event, 'cer')\"\r\n        (onerror)=\"onerrorDirective($event, 'cer')\">\r\n        <div class=\"fad-portal-content instruction\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.cer?.instruction }}</div>\r\n        <div class=\"fad-portal-content-bold upload-btn\">\r\n          <ng-fad-image-inline [src]=\"uploadImg\"></ng-fad-image-inline>\r\n          <span>{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.cer?.upload }}</span>\r\n        </div>\r\n      </div>\r\n\r\n      <div *ngIf=\"cer?.value\" class=\"container-file\">\r\n        <div class=\"document-img\">\r\n          <img [src]=\"fileImg\" alt=\"\">\r\n        </div>\r\n        <div class=\"fad-portal-content\">{{ cer?.value.name }}</div>\r\n      </div>\r\n\r\n      <input type=\"file\" accept=\".cer\" #fileCerInput style=\"display: none\" (change)=\"onFileChange($event, 'cer')\">\r\n    </div>\r\n\r\n    <div>\r\n      <div class=\"container-instruction-file\">\r\n        <div class=\"fad-portal-content\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.key?.label }}</div>\r\n        <div *ngIf=\"key?.value\" class=\"fad-portal-content select-file\" (click)=\"openFilePicker(fileKeyInput)\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.upload }}</div>\r\n      </div>\r\n\r\n      <div\r\n        *ngIf=\"!key?.value\"\r\n        class=\"container-upload\"\r\n        (click)=\"openFilePicker(fileKeyInput)\"\r\n        dragDropDocument\r\n        [formatList]=\"formatKeyList\"\r\n        [acceptMultipleFiles]=\"false\"\r\n        (onfiledropped)=\"onfiledropped($event, 'key')\"\r\n        (onerror)=\"onerrorDirective($event, 'key')\">\r\n\r\n        <div class=\"fad-portal-content instruction\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.key?.instruction }}</div>\r\n        <div class=\"fad-portal-content-bold upload-btn\">\r\n          <ng-fad-image-inline [src]=\"uploadImg\"></ng-fad-image-inline>\r\n          <span>{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.key?.upload }}</span>\r\n        </div>\r\n      </div>\r\n\r\n      <div *ngIf=\"key?.value\" class=\"container-file\">\r\n        <div class=\"document-img\">\r\n          <img [src]=\"fileImg\" alt=\"\">\r\n        </div>\r\n        <div class=\"fad-portal-content\">{{ key?.value.name }}</div>\r\n      </div>\r\n\r\n      <input type=\"file\" accept=\".key\" #fileKeyInput style=\"display: none\" (change)=\"onFileChange($event, 'key')\">\r\n    </div>\r\n\r\n    <div class=\"fad-portal-container-input\">\r\n      <label class=\"fad-portal-content\" for=\"\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.password?.label }}</label>\r\n      <div class=\"input-password\">\r\n        <input [type]=\"passwordInputType\" (input)=\"savePassword($event)\">\r\n        <div class=\"fad-portal-content-bold password-show\">\r\n          <div *ngIf=\"passwordInputType === 'text'\" (click)=\"changePaswordInputType()\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.password?.hide }}</div>\r\n          <div *ngIf=\"passwordInputType === 'password'\" (click)=\"changePaswordInputType()\">{{ configuration.customization?.moduleCustomization?.legends?.eSignature?.password?.show }}</div>\r\n        </div>\r\n      </div>\r\n    </div>\r\n\r\n  </ng-container>\r\n\r\n  <div></div>\r\n\r\n  <div class=\"fad-portal-content container-confirm\">\r\n    <div *ngIf=\"!allIsRejected()\" (click)=\"isValidated = !isValidated\">\r\n      <div>\r\n        <ng-fad-image-inline *ngIf=\"isValidated\" [src]=\"checkOnImg\"></ng-fad-image-inline>\r\n        <ng-fad-image-inline *ngIf=\"!isValidated\" [src]=\"checkOffImg\"></ng-fad-image-inline>\r\n      </div>\r\n      <div *ngIf=\"documents.length === 1\">{{ configuration.customization?.moduleCustomization?.legends?.sign?.validate?.singular }}</div>\r\n      <div *ngIf=\"documents.length > 1\">{{ configuration.customization?.moduleCustomization?.legends?.sign?.validate?.plural }}</div>\r\n    </div>\r\n\r\n    <div></div>\r\n\r\n    <div class=\"action\">\r\n      <button type=\"button\" *ngIf=\"documents.length === 1 && !allIsRejected()\" class=\"fad-portal-primary\" [disabled]=\"!form.valid || !isValidated\" (click)=\"signDocuments()\">{{ configuration.customization?.moduleCustomization?.legends?.sign?.button?.sign?.singular }}</button>\r\n      <button type=\"button\" *ngIf=\"documents.length > 1 && !allIsRejected()\" class=\"fad-portal-primary\" [disabled]=\"!form.valid || !isValidated\" (click)=\"signDocuments()\">{{ configuration.customization?.moduleCustomization?.legends?.sign?.button?.sign?.plural }}</button>\r\n      <button type=\"button\" *ngIf=\"documents.length === 1 && allIsRejected()\" class=\"fad-portal-primary\" (click)=\"onRejectDocument()\">{{ configuration.customization?.moduleCustomization?.legends?.sign?.button?.reject?.singular }}</button>\r\n      <button type=\"button\" *ngIf=\"documents.length > 1 && allIsRejected()\" class=\"fad-portal-primary\" (click)=\"onRejectDocument()\">{{ configuration.customization?.moduleCustomization?.legends?.sign?.button?.reject?.plural }}</button>\r\n    </div>\r\n  </div>\r\n</ng-container>\r\n"]}