ngx-vector-components 4.44.3 → 4.45.0

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.
package/CHANGELOG.md CHANGED
@@ -1,5 +1,18 @@
1
1
  # Changelog
2
2
 
3
+ ## [4.45.0] (08/12/2022)
4
+
5
+ ### Feature
6
+
7
+ - Adding `permission Geofence` in profileService.
8
+ - Adding `AlterationHistory` in `vector-crud-history` and `Insert typeOfModification` in `crud-history.model`
9
+
10
+ ## [4.44.4] (18/11/2022)
11
+
12
+ ### Bugfix
13
+
14
+ - Adjust `name "carteira digital for conta digital` in menu-vector
15
+
3
16
  ## [4.44.3] (18/11/2022)
4
17
 
5
18
  ### Bugfix
@@ -13,10 +13,10 @@ export class CrudFooterComponent {
13
13
  ngOnInit() { }
14
14
  }
15
15
  CrudFooterComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: CrudFooterComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
16
- CrudFooterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: CrudFooterComponent, selector: "vector-crud-footer", inputs: { submitDisabled: "submitDisabled", submitHidden: "submitHidden", goBackHidden: "goBackHidden" }, outputs: { onGoBack: "onGoBack", onSubmit: "onSubmit" }, ngImport: i0, template: "<div class=\"footer-container shadow-3\">\n <div class=\"button\" *ngIf=\"!goBackHidden\">\n <vector-button label=\"Voltar\" (onClick)=\"onGoBack.emit()\"></vector-button>\n </div>\n <div class=\"button\" *ngIf=\"!submitHidden\">\n <vector-button\n label=\"Salvar\"\n type=\"success\"\n (onClick)=\"onSubmit.emit()\"\n [disabled]=\"submitDisabled\"\n ></vector-button>\n </div>\n</div>\n", styles: [".footer-container{position:fixed;bottom:0px;left:0px;background-color:#f5f5f5;display:flex;flex-direction:row;justify-content:flex-end;align-items:center;width:100%;height:60px}.footer-container .button{margin-right:10px}\n"], components: [{ type: i1.ButtonComponent, selector: "vector-button", inputs: ["disabled", "label", "type", "leftIcon", "rightIcon", "noShadow", "style"], outputs: ["onClick"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
16
+ CrudFooterComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: CrudFooterComponent, selector: "vector-crud-footer", inputs: { submitDisabled: "submitDisabled", submitHidden: "submitHidden", goBackHidden: "goBackHidden" }, outputs: { onGoBack: "onGoBack", onSubmit: "onSubmit" }, ngImport: i0, template: "<div class=\"footer-container shadow-3\">\n <div class=\"button\" *ngIf=\"!goBackHidden\">\n <vector-button label=\"Voltar\" (onClick)=\"onGoBack.emit()\"></vector-button>\n </div>\n <div class=\"button\" *ngIf=\"!submitHidden\">\n <vector-button\n label=\"Salvar\"\n type=\"success\"\n (onClick)=\"onSubmit.emit()\"\n [disabled]=\"submitDisabled\"\n ></vector-button>\n </div>\n</div>\n", styles: [".footer-container{position:fixed;bottom:0;left:0;background-color:#f5f5f5;display:flex;flex-direction:row;justify-content:flex-end;align-items:center;width:100%;height:60px}.footer-container .button{margin-right:10px}\n"], components: [{ type: i1.ButtonComponent, selector: "vector-button", inputs: ["disabled", "label", "type", "leftIcon", "rightIcon", "noShadow", "style"], outputs: ["onClick"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
17
17
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: CrudFooterComponent, decorators: [{
18
18
  type: Component,
19
- args: [{ selector: 'vector-crud-footer', template: "<div class=\"footer-container shadow-3\">\n <div class=\"button\" *ngIf=\"!goBackHidden\">\n <vector-button label=\"Voltar\" (onClick)=\"onGoBack.emit()\"></vector-button>\n </div>\n <div class=\"button\" *ngIf=\"!submitHidden\">\n <vector-button\n label=\"Salvar\"\n type=\"success\"\n (onClick)=\"onSubmit.emit()\"\n [disabled]=\"submitDisabled\"\n ></vector-button>\n </div>\n</div>\n", styles: [".footer-container{position:fixed;bottom:0px;left:0px;background-color:#f5f5f5;display:flex;flex-direction:row;justify-content:flex-end;align-items:center;width:100%;height:60px}.footer-container .button{margin-right:10px}\n"] }]
19
+ args: [{ selector: 'vector-crud-footer', template: "<div class=\"footer-container shadow-3\">\n <div class=\"button\" *ngIf=\"!goBackHidden\">\n <vector-button label=\"Voltar\" (onClick)=\"onGoBack.emit()\"></vector-button>\n </div>\n <div class=\"button\" *ngIf=\"!submitHidden\">\n <vector-button\n label=\"Salvar\"\n type=\"success\"\n (onClick)=\"onSubmit.emit()\"\n [disabled]=\"submitDisabled\"\n ></vector-button>\n </div>\n</div>\n", styles: [".footer-container{position:fixed;bottom:0;left:0;background-color:#f5f5f5;display:flex;flex-direction:row;justify-content:flex-end;align-items:center;width:100%;height:60px}.footer-container .button{margin-right:10px}\n"] }]
20
20
  }], ctorParameters: function () { return []; }, propDecorators: { submitDisabled: [{
21
21
  type: Input
22
22
  }], submitHidden: [{
@@ -70,13 +70,13 @@ export class CrudHistoryComponent {
70
70
  }
71
71
  }
72
72
  CrudHistoryComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: CrudHistoryComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
73
- CrudHistoryComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: CrudHistoryComponent, selector: "vector-crud-history", inputs: { crudHistory: "crudHistory" }, outputs: { onClick: "onClick" }, ngImport: i0, template: "<p-accordionTab *ngIf=\"crudHistory\" class=\"history-item\">\n <ng-template pTemplate=\"header\">\n <div class=\"history-item-header-container\" (click)=\"onClick.emit()\">\n <div class=\"history-item-header-left\">\n <vector-badge\n [customBackgroundColor]=\"getHistoryBadgeBackgroundColor(crudHistory.eventType)\"\n [customColor]=\"getHistoryBadgeColor(crudHistory.eventType)\"\n [label]=\"getHistoryBadgeLabel(crudHistory.eventType)\"\n ></vector-badge>\n <span>por {{ crudHistory.modifierName }}</span>\n </div>\n <span class=\"history-item-header-right\">\n {{ crudHistory.dateTime | date: 'dd/MM/yyyy HH:mm' }}\n </span>\n </div>\n </ng-template>\n <ng-template pTemplate=\"content\">\n <div *ngFor=\"let auditDelta of crudHistory.dataAuditDelta\">\n <div class=\"grid\">\n <div class=\"col-12 md:col-6 field\">\n <span>{{ auditDelta.fieldName }}</span>\n </div>\n <div class=\"col-12 md:col-6 field\">\n <span class=\"new-value\">{{ auditDelta.newValue }}</span>\n <s class=\"old-value\">{{ auditDelta.oldValue }}</s>\n </div>\n </div>\n </div>\n </ng-template>\n</p-accordionTab>\n", styles: [".history-item{width:100%;margin:10px 0}.history-item .history-item-header-container{display:flex;align-items:center;justify-content:space-between;width:100%}.history-item .history-item-header-container .history-item-header-left{display:flex;align-items:center}.history-item .history-item-header-container .history-item-header-left span{margin-left:15px;color:var(--theme-medium);font-weight:600}.history-item .history-item-header-container .history-item-header-right{font-size:.8rem;color:var(--gray-darker);margin-right:40px}.new-value{color:#83c5be}.old-value{color:#000}\n"], components: [{ type: i1.AccordionTab, selector: "p-accordionTab", inputs: ["header", "disabled", "cache", "transitionOptions", "selected"], outputs: ["selectedChange"] }, { type: i2.BadgeComponent, selector: "vector-badge", inputs: ["type", "label", "customColor", "customBackgroundColor"] }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "date": i3.DatePipe } });
73
+ CrudHistoryComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: CrudHistoryComponent, selector: "vector-crud-history", inputs: { crudHistory: "crudHistory" }, outputs: { onClick: "onClick" }, ngImport: i0, template: "<p-accordionTab *ngIf=\"crudHistory\" class=\"history-item\">\n <ng-template pTemplate=\"header\">\n <div class=\"history-item-header-container\" (click)=\"onClick.emit()\">\n <div class=\"history-item-header-left\">\n <span id=\"color-first-span\" *ngIf=\"crudHistory.typeOfModification\">{{ crudHistory.typeOfModification }}</span>\n <vector-badge\n [customBackgroundColor]=\"getHistoryBadgeBackgroundColor(crudHistory.eventType)\"\n [customColor]=\"getHistoryBadgeColor(crudHistory.eventType)\"\n [label]=\"getHistoryBadgeLabel(crudHistory.eventType)\"\n ></vector-badge>\n <span>por {{ crudHistory.modifierName }}</span>\n </div>\n <span class=\"history-item-header-right\">\n {{ crudHistory.dateTime | date : 'dd/MM/yyyy HH:mm' }}\n </span>\n </div>\n </ng-template>\n <ng-template pTemplate=\"content\">\n <div *ngFor=\"let auditDelta of crudHistory.dataAuditDelta\">\n <div class=\"grid\">\n <div class=\"col-12 md:col-6 field\">\n <span>{{ auditDelta.fieldName }}</span>\n </div>\n <div class=\"col-12 md:col-6 field\">\n <span class=\"new-value\">{{ auditDelta.newValue }}</span>\n <s class=\"old-value pl-1\">{{ auditDelta.oldValue }}</s>\n </div>\n </div>\n </div>\n </ng-template>\n</p-accordionTab>\n", styles: [".history-item{width:100%;margin:10px 0}.history-item .history-item-header-container{display:flex;align-items:center;justify-content:space-between;width:100%}.history-item .history-item-header-container .history-item-header-left{display:flex;align-items:center}.history-item .history-item-header-container .history-item-header-left span#color-first-span{color:#000;margin-right:10px}.history-item .history-item-header-container .history-item-header-left span{margin-left:15px;color:var(--theme-medium);font-weight:600}.history-item .history-item-header-container .history-item-header-right{font-size:.8rem;color:var(--gray-darker);margin-right:40px}.new-value{color:#83c5be}.old-value{color:#000}\n"], components: [{ type: i1.AccordionTab, selector: "p-accordionTab", inputs: ["header", "disabled", "cache", "transitionOptions", "selected"], outputs: ["selectedChange"] }, { type: i2.BadgeComponent, selector: "vector-badge", inputs: ["type", "label", "customColor", "customBackgroundColor"] }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.PrimeTemplate, selector: "[pTemplate]", inputs: ["type", "pTemplate"] }, { type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], pipes: { "date": i3.DatePipe } });
74
74
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: CrudHistoryComponent, decorators: [{
75
75
  type: Component,
76
- args: [{ selector: 'vector-crud-history', template: "<p-accordionTab *ngIf=\"crudHistory\" class=\"history-item\">\n <ng-template pTemplate=\"header\">\n <div class=\"history-item-header-container\" (click)=\"onClick.emit()\">\n <div class=\"history-item-header-left\">\n <vector-badge\n [customBackgroundColor]=\"getHistoryBadgeBackgroundColor(crudHistory.eventType)\"\n [customColor]=\"getHistoryBadgeColor(crudHistory.eventType)\"\n [label]=\"getHistoryBadgeLabel(crudHistory.eventType)\"\n ></vector-badge>\n <span>por {{ crudHistory.modifierName }}</span>\n </div>\n <span class=\"history-item-header-right\">\n {{ crudHistory.dateTime | date: 'dd/MM/yyyy HH:mm' }}\n </span>\n </div>\n </ng-template>\n <ng-template pTemplate=\"content\">\n <div *ngFor=\"let auditDelta of crudHistory.dataAuditDelta\">\n <div class=\"grid\">\n <div class=\"col-12 md:col-6 field\">\n <span>{{ auditDelta.fieldName }}</span>\n </div>\n <div class=\"col-12 md:col-6 field\">\n <span class=\"new-value\">{{ auditDelta.newValue }}</span>\n <s class=\"old-value\">{{ auditDelta.oldValue }}</s>\n </div>\n </div>\n </div>\n </ng-template>\n</p-accordionTab>\n", styles: [".history-item{width:100%;margin:10px 0}.history-item .history-item-header-container{display:flex;align-items:center;justify-content:space-between;width:100%}.history-item .history-item-header-container .history-item-header-left{display:flex;align-items:center}.history-item .history-item-header-container .history-item-header-left span{margin-left:15px;color:var(--theme-medium);font-weight:600}.history-item .history-item-header-container .history-item-header-right{font-size:.8rem;color:var(--gray-darker);margin-right:40px}.new-value{color:#83c5be}.old-value{color:#000}\n"] }]
76
+ args: [{ selector: 'vector-crud-history', template: "<p-accordionTab *ngIf=\"crudHistory\" class=\"history-item\">\n <ng-template pTemplate=\"header\">\n <div class=\"history-item-header-container\" (click)=\"onClick.emit()\">\n <div class=\"history-item-header-left\">\n <span id=\"color-first-span\" *ngIf=\"crudHistory.typeOfModification\">{{ crudHistory.typeOfModification }}</span>\n <vector-badge\n [customBackgroundColor]=\"getHistoryBadgeBackgroundColor(crudHistory.eventType)\"\n [customColor]=\"getHistoryBadgeColor(crudHistory.eventType)\"\n [label]=\"getHistoryBadgeLabel(crudHistory.eventType)\"\n ></vector-badge>\n <span>por {{ crudHistory.modifierName }}</span>\n </div>\n <span class=\"history-item-header-right\">\n {{ crudHistory.dateTime | date : 'dd/MM/yyyy HH:mm' }}\n </span>\n </div>\n </ng-template>\n <ng-template pTemplate=\"content\">\n <div *ngFor=\"let auditDelta of crudHistory.dataAuditDelta\">\n <div class=\"grid\">\n <div class=\"col-12 md:col-6 field\">\n <span>{{ auditDelta.fieldName }}</span>\n </div>\n <div class=\"col-12 md:col-6 field\">\n <span class=\"new-value\">{{ auditDelta.newValue }}</span>\n <s class=\"old-value pl-1\">{{ auditDelta.oldValue }}</s>\n </div>\n </div>\n </div>\n </ng-template>\n</p-accordionTab>\n", styles: [".history-item{width:100%;margin:10px 0}.history-item .history-item-header-container{display:flex;align-items:center;justify-content:space-between;width:100%}.history-item .history-item-header-container .history-item-header-left{display:flex;align-items:center}.history-item .history-item-header-container .history-item-header-left span#color-first-span{color:#000;margin-right:10px}.history-item .history-item-header-container .history-item-header-left span{margin-left:15px;color:var(--theme-medium);font-weight:600}.history-item .history-item-header-container .history-item-header-right{font-size:.8rem;color:var(--gray-darker);margin-right:40px}.new-value{color:#83c5be}.old-value{color:#000}\n"] }]
77
77
  }], propDecorators: { crudHistory: [{
78
78
  type: Input
79
79
  }], onClick: [{
80
80
  type: Output
81
81
  }] } });
82
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3J1ZC1oaXN0b3J5LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC12ZWN0b3ItY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvY3J1ZC1oaXN0b3J5L2NydWQtaGlzdG9yeS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtdmVjdG9yLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2NydWQtaGlzdG9yeS9jcnVkLWhpc3RvcnkuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQzs7Ozs7O0FBUXZFLE1BQU0sT0FBTyxvQkFBb0I7SUFMakM7UUFTUyxZQUFPLEdBQUcsSUFBSSxZQUFZLEVBQU8sQ0FBQztLQStEMUM7SUE5RFEsOEJBQThCLENBQUMsb0JBQTZCO1FBQ2pFLFFBQVEsb0JBQW9CLEVBQUU7WUFDNUIsS0FBSyxjQUFjO2dCQUNqQixPQUFPLFNBQVMsQ0FBQztZQUNuQixLQUFLLGNBQWM7Z0JBQ2pCLE9BQU8sU0FBUyxDQUFDO1lBQ25CLEtBQUssY0FBYztnQkFDakIsT0FBTyxVQUFVLENBQUM7WUFDcEIsS0FBSyw0QkFBNEI7Z0JBQy9CLE9BQU8sU0FBUyxDQUFDO1lBQ25CLEtBQUsscUJBQXFCO2dCQUN4QixPQUFPLFNBQVMsQ0FBQztZQUNuQixLQUFLLDRCQUE0QjtnQkFDL0IsT0FBTyxTQUFTLENBQUM7WUFDbkIsS0FBSyxjQUFjO2dCQUNqQixPQUFPLFNBQVMsQ0FBQztZQUNuQjtnQkFDRSxPQUFPLEVBQUUsQ0FBQztTQUNiO0lBQ0gsQ0FBQztJQUVNLG9CQUFvQixDQUFDLG9CQUE2QjtRQUN2RCxRQUFRLG9CQUFvQixFQUFFO1lBQzVCLEtBQUssY0FBYztnQkFDakIsT0FBTyxTQUFTLENBQUM7WUFDbkIsS0FBSyxjQUFjO2dCQUNqQixPQUFPLFNBQVMsQ0FBQztZQUNuQixLQUFLLGNBQWM7Z0JBQ2pCLE9BQU8sU0FBUyxDQUFDO1lBQ25CLEtBQUssNEJBQTRCO2dCQUMvQixPQUFPLFNBQVMsQ0FBQztZQUNuQixLQUFLLHFCQUFxQjtnQkFDeEIsT0FBTyxTQUFTLENBQUM7WUFDbkIsS0FBSyw0QkFBNEI7Z0JBQy9CLE9BQU8sU0FBUyxDQUFDO1lBQ25CLEtBQUssY0FBYztnQkFDakIsT0FBTyxTQUFTLENBQUM7WUFDbkI7Z0JBQ0UsT0FBTyxFQUFFLENBQUM7U0FDYjtJQUNILENBQUM7SUFFTSxvQkFBb0IsQ0FBQyxvQkFBNkI7UUFDdkQsUUFBUSxvQkFBb0IsRUFBRTtZQUM1QixLQUFLLGNBQWM7Z0JBQ2pCLE9BQU8sUUFBUSxDQUFDO1lBQ2xCLEtBQUssY0FBYztnQkFDakIsT0FBTyxZQUFZLENBQUM7WUFDdEIsS0FBSyxjQUFjO2dCQUNqQixPQUFPLFVBQVUsQ0FBQztZQUNwQixLQUFLLDRCQUE0QjtnQkFDL0IsT0FBTyx1QkFBdUIsQ0FBQztZQUNqQyxLQUFLLHFCQUFxQjtnQkFDeEIsT0FBTyxvQkFBb0IsQ0FBQztZQUM5QixLQUFLLDRCQUE0QjtnQkFDL0IsT0FBTyxtQkFBbUIsQ0FBQztZQUM3QixLQUFLLGNBQWM7Z0JBQ2pCLE9BQU8sWUFBWSxDQUFDO1lBQ3RCO2dCQUNFLE9BQU8sRUFBRSxDQUFDO1NBQ2I7SUFDSCxDQUFDOztpSEFsRVUsb0JBQW9CO3FHQUFwQixvQkFBb0Isb0lDUmpDLGd1Q0E4QkE7MkZEdEJhLG9CQUFvQjtrQkFMaEMsU0FBUzsrQkFDRSxxQkFBcUI7OEJBTXhCLFdBQVc7c0JBRGpCLEtBQUs7Z0JBR0MsT0FBTztzQkFEYixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENydWRIaXN0b3J5IH0gZnJvbSAnLi4vLi4vbW9kZWxzJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAndmVjdG9yLWNydWQtaGlzdG9yeScsXG4gIHRlbXBsYXRlVXJsOiAnLi9jcnVkLWhpc3RvcnkuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9jcnVkLWhpc3RvcnkuY29tcG9uZW50LnNjc3MnXSxcbn0pXG5leHBvcnQgY2xhc3MgQ3J1ZEhpc3RvcnlDb21wb25lbnQge1xuICBASW5wdXQoKVxuICBwdWJsaWMgY3J1ZEhpc3Rvcnk/OiBDcnVkSGlzdG9yeTxhbnk+O1xuICBAT3V0cHV0KClcbiAgcHVibGljIG9uQ2xpY2sgPSBuZXcgRXZlbnRFbWl0dGVyPGFueT4oKTtcbiAgcHVibGljIGdldEhpc3RvcnlCYWRnZUJhY2tncm91bmRDb2xvcihjcnVkSGlzdG9yeUV2ZW50VHlwZT86IHN0cmluZyk6IHN0cmluZyB7XG4gICAgc3dpdGNoIChjcnVkSGlzdG9yeUV2ZW50VHlwZSkge1xuICAgICAgY2FzZSAnQWN0aW9uQ3JlYXRlJzpcbiAgICAgICAgcmV0dXJuICcjQ0JGRkFFJztcbiAgICAgIGNhc2UgJ0FjdGlvblVwZGF0ZSc6XG4gICAgICAgIHJldHVybiAnI0ZGRTZCMCc7XG4gICAgICBjYXNlICdBY3Rpb25EZWxldGUnOlxuICAgICAgICByZXR1cm4gJ1JlbW92aWRvJztcbiAgICAgIGNhc2UgJ0FjdGlvblVwZGF0ZS1PbkNvbXBvc2l0aW9uJzpcbiAgICAgICAgcmV0dXJuICcjRkZFNkIwJztcbiAgICAgIGNhc2UgJ0FjdGlvblVwZGF0ZS1PblVuaXQnOlxuICAgICAgICByZXR1cm4gJyNGRkU2QjAnO1xuICAgICAgY2FzZSAnQWN0aW9uQ3JlYXRlLU9uQ29tcG9zaXRpb24nOlxuICAgICAgICByZXR1cm4gJyNDQkZGQUUnO1xuICAgICAgY2FzZSAnQWN0aW9uQ2FuY2VsJzpcbiAgICAgICAgcmV0dXJuICcjRkZFNkIwJztcbiAgICAgIGRlZmF1bHQ6XG4gICAgICAgIHJldHVybiAnJztcbiAgICB9XG4gIH1cblxuICBwdWJsaWMgZ2V0SGlzdG9yeUJhZGdlQ29sb3IoY3J1ZEhpc3RvcnlFdmVudFR5cGU/OiBzdHJpbmcpOiBzdHJpbmcge1xuICAgIHN3aXRjaCAoY3J1ZEhpc3RvcnlFdmVudFR5cGUpIHtcbiAgICAgIGNhc2UgJ0FjdGlvbkNyZWF0ZSc6XG4gICAgICAgIHJldHVybiAnIzA2NzMwNic7XG4gICAgICBjYXNlICdBY3Rpb25VcGRhdGUnOlxuICAgICAgICByZXR1cm4gJyM5NDYzMDAnO1xuICAgICAgY2FzZSAnQWN0aW9uRGVsZXRlJzpcbiAgICAgICAgcmV0dXJuICcjNkIyRDJEJztcbiAgICAgIGNhc2UgJ0FjdGlvblVwZGF0ZS1PbkNvbXBvc2l0aW9uJzpcbiAgICAgICAgcmV0dXJuICcjOTQ2MzAwJztcbiAgICAgIGNhc2UgJ0FjdGlvblVwZGF0ZS1PblVuaXQnOlxuICAgICAgICByZXR1cm4gJyM5NDYzMDAnO1xuICAgICAgY2FzZSAnQWN0aW9uQ3JlYXRlLU9uQ29tcG9zaXRpb24nOlxuICAgICAgICByZXR1cm4gJyMwNjczMDYnO1xuICAgICAgY2FzZSAnQWN0aW9uQ2FuY2VsJzpcbiAgICAgICAgcmV0dXJuICcjOTQ2MzAwJztcbiAgICAgIGRlZmF1bHQ6XG4gICAgICAgIHJldHVybiAnJztcbiAgICB9XG4gIH1cblxuICBwdWJsaWMgZ2V0SGlzdG9yeUJhZGdlTGFiZWwoY3J1ZEhpc3RvcnlFdmVudFR5cGU/OiBzdHJpbmcpOiBzdHJpbmcge1xuICAgIHN3aXRjaCAoY3J1ZEhpc3RvcnlFdmVudFR5cGUpIHtcbiAgICAgIGNhc2UgJ0FjdGlvbkNyZWF0ZSc6XG4gICAgICAgIHJldHVybiAnQ3JpYWRvJztcbiAgICAgIGNhc2UgJ0FjdGlvblVwZGF0ZSc6XG4gICAgICAgIHJldHVybiAnTW9kaWZpY2Fkbyc7XG4gICAgICBjYXNlICdBY3Rpb25EZWxldGUnOlxuICAgICAgICByZXR1cm4gJ1JlbW92aWRvJztcbiAgICAgIGNhc2UgJ0FjdGlvblVwZGF0ZS1PbkNvbXBvc2l0aW9uJzpcbiAgICAgICAgcmV0dXJuICdDb21wb3Npw6fDo28gTW9kaWZpY2FkYSc7XG4gICAgICBjYXNlICdBY3Rpb25VcGRhdGUtT25Vbml0JzpcbiAgICAgICAgcmV0dXJuICdVbmlkYWRlIE1vZGlmaWNhZGEnO1xuICAgICAgY2FzZSAnQWN0aW9uQ3JlYXRlLU9uQ29tcG9zaXRpb24nOlxuICAgICAgICByZXR1cm4gJ0NvbXBvc2nDp8OjbyBDcmlhZGEnO1xuICAgICAgY2FzZSAnQWN0aW9uQ2FuY2VsJzpcbiAgICAgICAgcmV0dXJuICdNb2RpZmljYWRvJztcbiAgICAgIGRlZmF1bHQ6XG4gICAgICAgIHJldHVybiAnJztcbiAgICB9XG4gIH1cbn1cbiIsIjxwLWFjY29yZGlvblRhYiAqbmdJZj1cImNydWRIaXN0b3J5XCIgY2xhc3M9XCJoaXN0b3J5LWl0ZW1cIj5cbiAgPG5nLXRlbXBsYXRlIHBUZW1wbGF0ZT1cImhlYWRlclwiPlxuICAgIDxkaXYgY2xhc3M9XCJoaXN0b3J5LWl0ZW0taGVhZGVyLWNvbnRhaW5lclwiIChjbGljayk9XCJvbkNsaWNrLmVtaXQoKVwiPlxuICAgICAgPGRpdiBjbGFzcz1cImhpc3RvcnktaXRlbS1oZWFkZXItbGVmdFwiPlxuICAgICAgICA8dmVjdG9yLWJhZGdlXG4gICAgICAgICAgW2N1c3RvbUJhY2tncm91bmRDb2xvcl09XCJnZXRIaXN0b3J5QmFkZ2VCYWNrZ3JvdW5kQ29sb3IoY3J1ZEhpc3RvcnkuZXZlbnRUeXBlKVwiXG4gICAgICAgICAgW2N1c3RvbUNvbG9yXT1cImdldEhpc3RvcnlCYWRnZUNvbG9yKGNydWRIaXN0b3J5LmV2ZW50VHlwZSlcIlxuICAgICAgICAgIFtsYWJlbF09XCJnZXRIaXN0b3J5QmFkZ2VMYWJlbChjcnVkSGlzdG9yeS5ldmVudFR5cGUpXCJcbiAgICAgICAgPjwvdmVjdG9yLWJhZGdlPlxuICAgICAgICA8c3Bhbj5wb3Ige3sgY3J1ZEhpc3RvcnkubW9kaWZpZXJOYW1lIH19PC9zcGFuPlxuICAgICAgPC9kaXY+XG4gICAgICA8c3BhbiBjbGFzcz1cImhpc3RvcnktaXRlbS1oZWFkZXItcmlnaHRcIj5cbiAgICAgICAge3sgY3J1ZEhpc3RvcnkuZGF0ZVRpbWUgfCBkYXRlOiAnZGQvTU0veXl5eSBISDptbScgfX1cbiAgICAgIDwvc3Bhbj5cbiAgICA8L2Rpdj5cbiAgPC9uZy10ZW1wbGF0ZT5cbiAgPG5nLXRlbXBsYXRlIHBUZW1wbGF0ZT1cImNvbnRlbnRcIj5cbiAgICA8ZGl2ICpuZ0Zvcj1cImxldCBhdWRpdERlbHRhIG9mIGNydWRIaXN0b3J5LmRhdGFBdWRpdERlbHRhXCI+XG4gICAgICA8ZGl2IGNsYXNzPVwiZ3JpZFwiPlxuICAgICAgICA8ZGl2IGNsYXNzPVwiY29sLTEyIG1kOmNvbC02IGZpZWxkXCI+XG4gICAgICAgICAgPHNwYW4+e3sgYXVkaXREZWx0YS5maWVsZE5hbWUgfX08L3NwYW4+XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8ZGl2IGNsYXNzPVwiY29sLTEyIG1kOmNvbC02IGZpZWxkXCI+XG4gICAgICAgICAgPHNwYW4gY2xhc3M9XCJuZXctdmFsdWVcIj57eyBhdWRpdERlbHRhLm5ld1ZhbHVlIH19PC9zcGFuPlxuICAgICAgICAgIDxzIGNsYXNzPVwib2xkLXZhbHVlXCI+e3sgYXVkaXREZWx0YS5vbGRWYWx1ZSB9fTwvcz5cbiAgICAgICAgPC9kaXY+XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgPC9uZy10ZW1wbGF0ZT5cbjwvcC1hY2NvcmRpb25UYWI+XG4iXX0=
82
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3J1ZC1oaXN0b3J5LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC12ZWN0b3ItY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvY3J1ZC1oaXN0b3J5L2NydWQtaGlzdG9yeS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtdmVjdG9yLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2NydWQtaGlzdG9yeS9jcnVkLWhpc3RvcnkuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQzs7Ozs7O0FBUXZFLE1BQU0sT0FBTyxvQkFBb0I7SUFMakM7UUFTUyxZQUFPLEdBQUcsSUFBSSxZQUFZLEVBQU8sQ0FBQztLQStEMUM7SUE5RFEsOEJBQThCLENBQUMsb0JBQTZCO1FBQ2pFLFFBQVEsb0JBQW9CLEVBQUU7WUFDNUIsS0FBSyxjQUFjO2dCQUNqQixPQUFPLFNBQVMsQ0FBQztZQUNuQixLQUFLLGNBQWM7Z0JBQ2pCLE9BQU8sU0FBUyxDQUFDO1lBQ25CLEtBQUssY0FBYztnQkFDakIsT0FBTyxVQUFVLENBQUM7WUFDcEIsS0FBSyw0QkFBNEI7Z0JBQy9CLE9BQU8sU0FBUyxDQUFDO1lBQ25CLEtBQUsscUJBQXFCO2dCQUN4QixPQUFPLFNBQVMsQ0FBQztZQUNuQixLQUFLLDRCQUE0QjtnQkFDL0IsT0FBTyxTQUFTLENBQUM7WUFDbkIsS0FBSyxjQUFjO2dCQUNqQixPQUFPLFNBQVMsQ0FBQztZQUNuQjtnQkFDRSxPQUFPLEVBQUUsQ0FBQztTQUNiO0lBQ0gsQ0FBQztJQUVNLG9CQUFvQixDQUFDLG9CQUE2QjtRQUN2RCxRQUFRLG9CQUFvQixFQUFFO1lBQzVCLEtBQUssY0FBYztnQkFDakIsT0FBTyxTQUFTLENBQUM7WUFDbkIsS0FBSyxjQUFjO2dCQUNqQixPQUFPLFNBQVMsQ0FBQztZQUNuQixLQUFLLGNBQWM7Z0JBQ2pCLE9BQU8sU0FBUyxDQUFDO1lBQ25CLEtBQUssNEJBQTRCO2dCQUMvQixPQUFPLFNBQVMsQ0FBQztZQUNuQixLQUFLLHFCQUFxQjtnQkFDeEIsT0FBTyxTQUFTLENBQUM7WUFDbkIsS0FBSyw0QkFBNEI7Z0JBQy9CLE9BQU8sU0FBUyxDQUFDO1lBQ25CLEtBQUssY0FBYztnQkFDakIsT0FBTyxTQUFTLENBQUM7WUFDbkI7Z0JBQ0UsT0FBTyxFQUFFLENBQUM7U0FDYjtJQUNILENBQUM7SUFFTSxvQkFBb0IsQ0FBQyxvQkFBNkI7UUFDdkQsUUFBUSxvQkFBb0IsRUFBRTtZQUM1QixLQUFLLGNBQWM7Z0JBQ2pCLE9BQU8sUUFBUSxDQUFDO1lBQ2xCLEtBQUssY0FBYztnQkFDakIsT0FBTyxZQUFZLENBQUM7WUFDdEIsS0FBSyxjQUFjO2dCQUNqQixPQUFPLFVBQVUsQ0FBQztZQUNwQixLQUFLLDRCQUE0QjtnQkFDL0IsT0FBTyx1QkFBdUIsQ0FBQztZQUNqQyxLQUFLLHFCQUFxQjtnQkFDeEIsT0FBTyxvQkFBb0IsQ0FBQztZQUM5QixLQUFLLDRCQUE0QjtnQkFDL0IsT0FBTyxtQkFBbUIsQ0FBQztZQUM3QixLQUFLLGNBQWM7Z0JBQ2pCLE9BQU8sWUFBWSxDQUFDO1lBQ3RCO2dCQUNFLE9BQU8sRUFBRSxDQUFDO1NBQ2I7SUFDSCxDQUFDOztpSEFsRVUsb0JBQW9CO3FHQUFwQixvQkFBb0Isb0lDUmpDLGsyQ0ErQkE7MkZEdkJhLG9CQUFvQjtrQkFMaEMsU0FBUzsrQkFDRSxxQkFBcUI7OEJBTXhCLFdBQVc7c0JBRGpCLEtBQUs7Z0JBR0MsT0FBTztzQkFEYixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENydWRIaXN0b3J5IH0gZnJvbSAnLi4vLi4vbW9kZWxzJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAndmVjdG9yLWNydWQtaGlzdG9yeScsXG4gIHRlbXBsYXRlVXJsOiAnLi9jcnVkLWhpc3RvcnkuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9jcnVkLWhpc3RvcnkuY29tcG9uZW50LnNjc3MnXSxcbn0pXG5leHBvcnQgY2xhc3MgQ3J1ZEhpc3RvcnlDb21wb25lbnQge1xuICBASW5wdXQoKVxuICBwdWJsaWMgY3J1ZEhpc3Rvcnk/OiBDcnVkSGlzdG9yeTxhbnk+O1xuICBAT3V0cHV0KClcbiAgcHVibGljIG9uQ2xpY2sgPSBuZXcgRXZlbnRFbWl0dGVyPGFueT4oKTtcbiAgcHVibGljIGdldEhpc3RvcnlCYWRnZUJhY2tncm91bmRDb2xvcihjcnVkSGlzdG9yeUV2ZW50VHlwZT86IHN0cmluZyk6IHN0cmluZyB7XG4gICAgc3dpdGNoIChjcnVkSGlzdG9yeUV2ZW50VHlwZSkge1xuICAgICAgY2FzZSAnQWN0aW9uQ3JlYXRlJzpcbiAgICAgICAgcmV0dXJuICcjQ0JGRkFFJztcbiAgICAgIGNhc2UgJ0FjdGlvblVwZGF0ZSc6XG4gICAgICAgIHJldHVybiAnI0ZGRTZCMCc7XG4gICAgICBjYXNlICdBY3Rpb25EZWxldGUnOlxuICAgICAgICByZXR1cm4gJ1JlbW92aWRvJztcbiAgICAgIGNhc2UgJ0FjdGlvblVwZGF0ZS1PbkNvbXBvc2l0aW9uJzpcbiAgICAgICAgcmV0dXJuICcjRkZFNkIwJztcbiAgICAgIGNhc2UgJ0FjdGlvblVwZGF0ZS1PblVuaXQnOlxuICAgICAgICByZXR1cm4gJyNGRkU2QjAnO1xuICAgICAgY2FzZSAnQWN0aW9uQ3JlYXRlLU9uQ29tcG9zaXRpb24nOlxuICAgICAgICByZXR1cm4gJyNDQkZGQUUnO1xuICAgICAgY2FzZSAnQWN0aW9uQ2FuY2VsJzpcbiAgICAgICAgcmV0dXJuICcjRkZFNkIwJztcbiAgICAgIGRlZmF1bHQ6XG4gICAgICAgIHJldHVybiAnJztcbiAgICB9XG4gIH1cblxuICBwdWJsaWMgZ2V0SGlzdG9yeUJhZGdlQ29sb3IoY3J1ZEhpc3RvcnlFdmVudFR5cGU/OiBzdHJpbmcpOiBzdHJpbmcge1xuICAgIHN3aXRjaCAoY3J1ZEhpc3RvcnlFdmVudFR5cGUpIHtcbiAgICAgIGNhc2UgJ0FjdGlvbkNyZWF0ZSc6XG4gICAgICAgIHJldHVybiAnIzA2NzMwNic7XG4gICAgICBjYXNlICdBY3Rpb25VcGRhdGUnOlxuICAgICAgICByZXR1cm4gJyM5NDYzMDAnO1xuICAgICAgY2FzZSAnQWN0aW9uRGVsZXRlJzpcbiAgICAgICAgcmV0dXJuICcjNkIyRDJEJztcbiAgICAgIGNhc2UgJ0FjdGlvblVwZGF0ZS1PbkNvbXBvc2l0aW9uJzpcbiAgICAgICAgcmV0dXJuICcjOTQ2MzAwJztcbiAgICAgIGNhc2UgJ0FjdGlvblVwZGF0ZS1PblVuaXQnOlxuICAgICAgICByZXR1cm4gJyM5NDYzMDAnO1xuICAgICAgY2FzZSAnQWN0aW9uQ3JlYXRlLU9uQ29tcG9zaXRpb24nOlxuICAgICAgICByZXR1cm4gJyMwNjczMDYnO1xuICAgICAgY2FzZSAnQWN0aW9uQ2FuY2VsJzpcbiAgICAgICAgcmV0dXJuICcjOTQ2MzAwJztcbiAgICAgIGRlZmF1bHQ6XG4gICAgICAgIHJldHVybiAnJztcbiAgICB9XG4gIH1cblxuICBwdWJsaWMgZ2V0SGlzdG9yeUJhZGdlTGFiZWwoY3J1ZEhpc3RvcnlFdmVudFR5cGU/OiBzdHJpbmcpOiBzdHJpbmcge1xuICAgIHN3aXRjaCAoY3J1ZEhpc3RvcnlFdmVudFR5cGUpIHtcbiAgICAgIGNhc2UgJ0FjdGlvbkNyZWF0ZSc6XG4gICAgICAgIHJldHVybiAnQ3JpYWRvJztcbiAgICAgIGNhc2UgJ0FjdGlvblVwZGF0ZSc6XG4gICAgICAgIHJldHVybiAnTW9kaWZpY2Fkbyc7XG4gICAgICBjYXNlICdBY3Rpb25EZWxldGUnOlxuICAgICAgICByZXR1cm4gJ1JlbW92aWRvJztcbiAgICAgIGNhc2UgJ0FjdGlvblVwZGF0ZS1PbkNvbXBvc2l0aW9uJzpcbiAgICAgICAgcmV0dXJuICdDb21wb3Npw6fDo28gTW9kaWZpY2FkYSc7XG4gICAgICBjYXNlICdBY3Rpb25VcGRhdGUtT25Vbml0JzpcbiAgICAgICAgcmV0dXJuICdVbmlkYWRlIE1vZGlmaWNhZGEnO1xuICAgICAgY2FzZSAnQWN0aW9uQ3JlYXRlLU9uQ29tcG9zaXRpb24nOlxuICAgICAgICByZXR1cm4gJ0NvbXBvc2nDp8OjbyBDcmlhZGEnO1xuICAgICAgY2FzZSAnQWN0aW9uQ2FuY2VsJzpcbiAgICAgICAgcmV0dXJuICdNb2RpZmljYWRvJztcbiAgICAgIGRlZmF1bHQ6XG4gICAgICAgIHJldHVybiAnJztcbiAgICB9XG4gIH1cbn1cbiIsIjxwLWFjY29yZGlvblRhYiAqbmdJZj1cImNydWRIaXN0b3J5XCIgY2xhc3M9XCJoaXN0b3J5LWl0ZW1cIj5cbiAgPG5nLXRlbXBsYXRlIHBUZW1wbGF0ZT1cImhlYWRlclwiPlxuICAgIDxkaXYgY2xhc3M9XCJoaXN0b3J5LWl0ZW0taGVhZGVyLWNvbnRhaW5lclwiIChjbGljayk9XCJvbkNsaWNrLmVtaXQoKVwiPlxuICAgICAgPGRpdiBjbGFzcz1cImhpc3RvcnktaXRlbS1oZWFkZXItbGVmdFwiPlxuICAgICAgICA8c3BhbiBpZD1cImNvbG9yLWZpcnN0LXNwYW5cIiAqbmdJZj1cImNydWRIaXN0b3J5LnR5cGVPZk1vZGlmaWNhdGlvblwiPnt7IGNydWRIaXN0b3J5LnR5cGVPZk1vZGlmaWNhdGlvbiB9fTwvc3Bhbj5cbiAgICAgICAgPHZlY3Rvci1iYWRnZVxuICAgICAgICAgIFtjdXN0b21CYWNrZ3JvdW5kQ29sb3JdPVwiZ2V0SGlzdG9yeUJhZGdlQmFja2dyb3VuZENvbG9yKGNydWRIaXN0b3J5LmV2ZW50VHlwZSlcIlxuICAgICAgICAgIFtjdXN0b21Db2xvcl09XCJnZXRIaXN0b3J5QmFkZ2VDb2xvcihjcnVkSGlzdG9yeS5ldmVudFR5cGUpXCJcbiAgICAgICAgICBbbGFiZWxdPVwiZ2V0SGlzdG9yeUJhZGdlTGFiZWwoY3J1ZEhpc3RvcnkuZXZlbnRUeXBlKVwiXG4gICAgICAgID48L3ZlY3Rvci1iYWRnZT5cbiAgICAgICAgPHNwYW4+cG9yIHt7IGNydWRIaXN0b3J5Lm1vZGlmaWVyTmFtZSB9fTwvc3Bhbj5cbiAgICAgIDwvZGl2PlxuICAgICAgPHNwYW4gY2xhc3M9XCJoaXN0b3J5LWl0ZW0taGVhZGVyLXJpZ2h0XCI+XG4gICAgICAgIHt7IGNydWRIaXN0b3J5LmRhdGVUaW1lIHwgZGF0ZSA6ICdkZC9NTS95eXl5IEhIOm1tJyB9fVxuICAgICAgPC9zcGFuPlxuICAgIDwvZGl2PlxuICA8L25nLXRlbXBsYXRlPlxuICA8bmctdGVtcGxhdGUgcFRlbXBsYXRlPVwiY29udGVudFwiPlxuICAgIDxkaXYgKm5nRm9yPVwibGV0IGF1ZGl0RGVsdGEgb2YgY3J1ZEhpc3RvcnkuZGF0YUF1ZGl0RGVsdGFcIj5cbiAgICAgIDxkaXYgY2xhc3M9XCJncmlkXCI+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJjb2wtMTIgbWQ6Y29sLTYgZmllbGRcIj5cbiAgICAgICAgICA8c3Bhbj57eyBhdWRpdERlbHRhLmZpZWxkTmFtZSB9fTwvc3Bhbj5cbiAgICAgICAgPC9kaXY+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJjb2wtMTIgbWQ6Y29sLTYgZmllbGRcIj5cbiAgICAgICAgICA8c3BhbiBjbGFzcz1cIm5ldy12YWx1ZVwiPnt7IGF1ZGl0RGVsdGEubmV3VmFsdWUgfX08L3NwYW4+XG4gICAgICAgICAgPHMgY2xhc3M9XCJvbGQtdmFsdWUgcGwtMVwiPnt7IGF1ZGl0RGVsdGEub2xkVmFsdWUgfX08L3M+XG4gICAgICAgIDwvZGl2PlxuICAgICAgPC9kaXY+XG4gICAgPC9kaXY+XG4gIDwvbmctdGVtcGxhdGU+XG48L3AtYWNjb3JkaW9uVGFiPlxuIl19
@@ -102,21 +102,6 @@ export class TextFieldComponent {
102
102
  this.subscription.unsubscribe();
103
103
  this.controlSubscription.unsubscribe();
104
104
  }
105
- // public fieldErrorLabel(): string {
106
- // if (this.control && this.control.invalid && this.control.touched) {
107
- // if (this.control.hasError('required')) {
108
- // return 'Campo obrigatório';
109
- // }
110
- // if (this.control.hasError('minlength')) {
111
- // return `Tamanho mínimo: ${this.control.errors['minlength'].requiredLength}`;
112
- // }
113
- // if (this.control.hasError('maxlength')) {
114
- // return `Tamanho máximo permitido: ${this.control.errors['maxlength'].requiredLength}`;
115
- // }
116
- // return typeof this.control.errors['invalid'] === 'string' ? this.control.errors['invalid'] : 'Campo inválido';
117
- // }
118
- // return '';
119
- // }
120
105
  onBlur() {
121
106
  this.control.markAsTouched();
122
107
  if (this.lastBlurValue !== this.control.value) {
@@ -178,10 +163,10 @@ export class TextFieldComponent {
178
163
  }
179
164
  }
180
165
  TextFieldComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: TextFieldComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
181
- TextFieldComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: TextFieldComponent, selector: "vector-text-field", inputs: { isRequired: "isRequired", label: "label", maxlength: "maxlength", isPassword: "isPassword", numeric: "numeric", decimal: "decimal", onlyText: "onlyText", alphaNumeric: "alphaNumeric", mask: "mask", autoClear: "autoClear", rightIcon: "rightIcon", centered: "centered", enableDocumentTypeChoice: "enableDocumentTypeChoice", hiddenErrorMessage: "hiddenErrorMessage", control: "control" }, outputs: { blurEvent: "blurEvent", enterKeyPress: "enterKeyPress", focusEvent: "focusEvent", onDocumentTypeChange: "onDocumentTypeChange" }, ngImport: i0, template: "<form class=\"input-container p-input-icon-right\">\n <i *ngIf=\"rightIcon\" [class]=\"rightIcon\"></i>\n <i *ngIf=\"isPassword\" class=\"show-password-icon {{ showPasswordIcon }}\" (click)=\"toggleShowPassword()\"></i>\n <div class=\"p-inputgroup\">\n <vector-button\n *ngIf=\"enableDocumentTypeChoice\"\n leftIcon=\"fas fa-exchange-alt\"\n type=\"success\"\n [label]=\"selectedDocumentType.name\"\n [disabled]=\"control.disabled\"\n [noShadow]=\"true\"\n (onClick)=\"handleDocumentTypeChange()\"\n ></vector-button>\n\n <input\n *ngIf=\"!mask\"\n pInputText\n type=\"text\"\n [formControl]=\"control\"\n [attr.maxlength]=\"maxlength\"\n [placeholder]=\"placeholder\"\n [pValidateOnly]=\"validateOnly\"\n [pKeyFilter]=\"keyfilter\"\n [ngClass]=\"{ 'password-field': isPassword && !isPasswordVisible, 'text-centered': centered }\"\n (onBlur)=\"onBlur()\"\n (keydown.enter)=\"onEnterPress()\"\n (click)=\"onFocus($event)\"\n />\n <p-inputMask\n *ngIf=\"mask\"\n type=\"text\"\n [formControl]=\"control\"\n [mask]=\"mask\"\n [placeholder]=\"placeholder\"\n (onBlur)=\"onBlur()\"\n (keydown.enter)=\"onEnterPress()\"\n [autoClear]=\"autoClear\"\n [unmask]=\"true\"\n [styleClass]=\"centered ? 'text-centered' : ''\"\n slotChar=\"_\"\n (click)=\"onFocus($event)\"\n ></p-inputMask>\n </div>\n <vector-field-error-message *ngIf=\"!hiddenErrorMessage\" [control]=\"control\"></vector-field-error-message>\n <!-- <span class=\"input-error\">{{ fieldErrorLabel() }}</span> -->\n</form>\n", styles: [".input-container{width:100%}.input-container .password-field{-webkit-text-security:disc}.input-container .input-error{font-size:.7em;color:var(--error-color);position:absolute;width:max-content}.input-container .show-password-icon{font-size:1.4em;margin-right:5px;cursor:pointer}.input-container .text-centered{text-align:center}\n"], components: [{ type: i1.ButtonComponent, selector: "vector-button", inputs: ["disabled", "label", "type", "leftIcon", "rightIcon", "noShadow", "style"], outputs: ["onClick"] }, { type: i2.InputMask, selector: "p-inputMask", inputs: ["type", "slotChar", "autoClear", "style", "inputId", "styleClass", "placeholder", "size", "maxlength", "tabindex", "title", "ariaLabel", "ariaRequired", "disabled", "readonly", "unmask", "name", "required", "characterPattern", "autoFocus", "autocomplete", "mask"], outputs: ["onComplete", "onFocus", "onBlur", "onInput", "onKeydown"] }, { type: i3.FieldErrorMessageComponent, selector: "vector-field-error-message", inputs: ["control"] }], directives: [{ type: i4.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i4.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i4.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i6.InputText, selector: "[pInputText]" }, { type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i4.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i4.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { type: i7.KeyFilter, selector: "[pKeyFilter]", inputs: ["pValidateOnly", "pKeyFilter"], outputs: ["ngModelChange"] }, { type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] });
166
+ TextFieldComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.3", type: TextFieldComponent, selector: "vector-text-field", inputs: { isRequired: "isRequired", label: "label", maxlength: "maxlength", isPassword: "isPassword", numeric: "numeric", decimal: "decimal", onlyText: "onlyText", alphaNumeric: "alphaNumeric", mask: "mask", autoClear: "autoClear", rightIcon: "rightIcon", centered: "centered", enableDocumentTypeChoice: "enableDocumentTypeChoice", hiddenErrorMessage: "hiddenErrorMessage", control: "control" }, outputs: { blurEvent: "blurEvent", enterKeyPress: "enterKeyPress", focusEvent: "focusEvent", onDocumentTypeChange: "onDocumentTypeChange" }, ngImport: i0, template: "<form class=\"input-container p-input-icon-right\">\n <i *ngIf=\"rightIcon\" [class]=\"rightIcon\"></i>\n <i *ngIf=\"isPassword\" class=\"show-password-icon {{ showPasswordIcon }}\" (click)=\"toggleShowPassword()\"></i>\n <div class=\"p-inputgroup\">\n <vector-button\n *ngIf=\"enableDocumentTypeChoice\"\n leftIcon=\"fas fa-exchange-alt\"\n type=\"success\"\n [label]=\"selectedDocumentType.name\"\n [disabled]=\"control.disabled\"\n [noShadow]=\"true\"\n (onClick)=\"handleDocumentTypeChange()\"\n ></vector-button>\n\n <input\n *ngIf=\"!mask\"\n pInputText\n type=\"text\"\n [formControl]=\"control\"\n [attr.maxlength]=\"maxlength\"\n [placeholder]=\"placeholder\"\n [pValidateOnly]=\"validateOnly\"\n [pKeyFilter]=\"keyfilter\"\n [ngClass]=\"{ 'password-field': isPassword && !isPasswordVisible, 'text-centered': centered }\"\n (onBlur)=\"onBlur()\"\n (keydown.enter)=\"onEnterPress()\"\n (click)=\"onFocus($event)\"\n />\n <p-inputMask\n *ngIf=\"mask\"\n type=\"text\"\n [formControl]=\"control\"\n [mask]=\"mask\"\n [placeholder]=\"placeholder\"\n (onBlur)=\"onBlur()\"\n (keydown.enter)=\"onEnterPress()\"\n [autoClear]=\"autoClear\"\n [unmask]=\"true\"\n [styleClass]=\"centered ? 'text-centered' : ''\"\n slotChar=\"_\"\n (click)=\"onFocus($event)\"\n ></p-inputMask>\n </div>\n <vector-field-error-message *ngIf=\"!hiddenErrorMessage\" [control]=\"control\"></vector-field-error-message>\n</form>\n", styles: [".input-container{width:100%}.input-container .password-field{-webkit-text-security:disc}.input-container .input-error{font-size:.7em;color:var(--error-color);position:absolute;width:max-content}.input-container .show-password-icon{font-size:1.4em;margin-right:5px;cursor:pointer}.input-container .text-centered{text-align:center}\n"], components: [{ type: i1.ButtonComponent, selector: "vector-button", inputs: ["disabled", "label", "type", "leftIcon", "rightIcon", "noShadow", "style"], outputs: ["onClick"] }, { type: i2.InputMask, selector: "p-inputMask", inputs: ["type", "slotChar", "autoClear", "style", "inputId", "styleClass", "placeholder", "size", "maxlength", "tabindex", "title", "ariaLabel", "ariaRequired", "disabled", "readonly", "unmask", "name", "required", "characterPattern", "autoFocus", "autocomplete", "mask"], outputs: ["onComplete", "onFocus", "onBlur", "onInput", "onKeydown"] }, { type: i3.FieldErrorMessageComponent, selector: "vector-field-error-message", inputs: ["control"] }], directives: [{ type: i4.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { type: i4.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { type: i4.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i6.InputText, selector: "[pInputText]" }, { type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i4.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { type: i4.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { type: i7.KeyFilter, selector: "[pKeyFilter]", inputs: ["pValidateOnly", "pKeyFilter"], outputs: ["ngModelChange"] }, { type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] });
182
167
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImport: i0, type: TextFieldComponent, decorators: [{
183
168
  type: Component,
184
- args: [{ selector: 'vector-text-field', template: "<form class=\"input-container p-input-icon-right\">\n <i *ngIf=\"rightIcon\" [class]=\"rightIcon\"></i>\n <i *ngIf=\"isPassword\" class=\"show-password-icon {{ showPasswordIcon }}\" (click)=\"toggleShowPassword()\"></i>\n <div class=\"p-inputgroup\">\n <vector-button\n *ngIf=\"enableDocumentTypeChoice\"\n leftIcon=\"fas fa-exchange-alt\"\n type=\"success\"\n [label]=\"selectedDocumentType.name\"\n [disabled]=\"control.disabled\"\n [noShadow]=\"true\"\n (onClick)=\"handleDocumentTypeChange()\"\n ></vector-button>\n\n <input\n *ngIf=\"!mask\"\n pInputText\n type=\"text\"\n [formControl]=\"control\"\n [attr.maxlength]=\"maxlength\"\n [placeholder]=\"placeholder\"\n [pValidateOnly]=\"validateOnly\"\n [pKeyFilter]=\"keyfilter\"\n [ngClass]=\"{ 'password-field': isPassword && !isPasswordVisible, 'text-centered': centered }\"\n (onBlur)=\"onBlur()\"\n (keydown.enter)=\"onEnterPress()\"\n (click)=\"onFocus($event)\"\n />\n <p-inputMask\n *ngIf=\"mask\"\n type=\"text\"\n [formControl]=\"control\"\n [mask]=\"mask\"\n [placeholder]=\"placeholder\"\n (onBlur)=\"onBlur()\"\n (keydown.enter)=\"onEnterPress()\"\n [autoClear]=\"autoClear\"\n [unmask]=\"true\"\n [styleClass]=\"centered ? 'text-centered' : ''\"\n slotChar=\"_\"\n (click)=\"onFocus($event)\"\n ></p-inputMask>\n </div>\n <vector-field-error-message *ngIf=\"!hiddenErrorMessage\" [control]=\"control\"></vector-field-error-message>\n <!-- <span class=\"input-error\">{{ fieldErrorLabel() }}</span> -->\n</form>\n", styles: [".input-container{width:100%}.input-container .password-field{-webkit-text-security:disc}.input-container .input-error{font-size:.7em;color:var(--error-color);position:absolute;width:max-content}.input-container .show-password-icon{font-size:1.4em;margin-right:5px;cursor:pointer}.input-container .text-centered{text-align:center}\n"] }]
169
+ args: [{ selector: 'vector-text-field', template: "<form class=\"input-container p-input-icon-right\">\n <i *ngIf=\"rightIcon\" [class]=\"rightIcon\"></i>\n <i *ngIf=\"isPassword\" class=\"show-password-icon {{ showPasswordIcon }}\" (click)=\"toggleShowPassword()\"></i>\n <div class=\"p-inputgroup\">\n <vector-button\n *ngIf=\"enableDocumentTypeChoice\"\n leftIcon=\"fas fa-exchange-alt\"\n type=\"success\"\n [label]=\"selectedDocumentType.name\"\n [disabled]=\"control.disabled\"\n [noShadow]=\"true\"\n (onClick)=\"handleDocumentTypeChange()\"\n ></vector-button>\n\n <input\n *ngIf=\"!mask\"\n pInputText\n type=\"text\"\n [formControl]=\"control\"\n [attr.maxlength]=\"maxlength\"\n [placeholder]=\"placeholder\"\n [pValidateOnly]=\"validateOnly\"\n [pKeyFilter]=\"keyfilter\"\n [ngClass]=\"{ 'password-field': isPassword && !isPasswordVisible, 'text-centered': centered }\"\n (onBlur)=\"onBlur()\"\n (keydown.enter)=\"onEnterPress()\"\n (click)=\"onFocus($event)\"\n />\n <p-inputMask\n *ngIf=\"mask\"\n type=\"text\"\n [formControl]=\"control\"\n [mask]=\"mask\"\n [placeholder]=\"placeholder\"\n (onBlur)=\"onBlur()\"\n (keydown.enter)=\"onEnterPress()\"\n [autoClear]=\"autoClear\"\n [unmask]=\"true\"\n [styleClass]=\"centered ? 'text-centered' : ''\"\n slotChar=\"_\"\n (click)=\"onFocus($event)\"\n ></p-inputMask>\n </div>\n <vector-field-error-message *ngIf=\"!hiddenErrorMessage\" [control]=\"control\"></vector-field-error-message>\n</form>\n", styles: [".input-container{width:100%}.input-container .password-field{-webkit-text-security:disc}.input-container .input-error{font-size:.7em;color:var(--error-color);position:absolute;width:max-content}.input-container .show-password-icon{font-size:1.4em;margin-right:5px;cursor:pointer}.input-container .text-centered{text-align:center}\n"] }]
185
170
  }], propDecorators: { isRequired: [{
186
171
  type: Input
187
172
  }], label: [{
@@ -221,4 +206,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.3", ngImpor
221
206
  }], onDocumentTypeChange: [{
222
207
  type: Output
223
208
  }] } });
224
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text-field.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-vector-components/src/lib/components/fields/text-field/text-field.component.ts","../../../../../../../projects/ngx-vector-components/src/lib/components/fields/text-field/text-field.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnDestroy, OnInit, Output } from '@angular/core';\nimport { Subscription } from 'rxjs';\nimport { DocumentType, ListItem } from '../../../models';\nimport { MaskUtil } from '../../../utils';\n\n@Component({\n  selector: 'vector-text-field',\n  templateUrl: './text-field.component.html',\n  styleUrls: ['./text-field.component.scss'],\n})\nexport class TextFieldComponent implements OnInit, OnDestroy {\n  @Input()\n  public isRequired: boolean | undefined = false;\n  @Input()\n  public label: string | undefined = '';\n  @Input()\n  public maxlength: string = '';\n  @Input()\n  public isPassword = false;\n  @Input()\n  public numeric = false;\n  @Input()\n  public decimal = false;\n  @Input()\n  public onlyText = false;\n  @Input()\n  public alphaNumeric = false;\n  @Input()\n  public mask: string | undefined;\n  @Input()\n  public autoClear = true;\n  @Input()\n  public rightIcon = '';\n  @Input()\n  public centered = false;\n  @Input()\n  public enableDocumentTypeChoice = false;\n  @Input()\n  public hiddenErrorMessage: boolean = false;\n  @Input()\n  set control(_control: any) {\n    this._control = _control;\n    if (this.enableDocumentTypeChoice) {\n      this.handleInitialDocumentTypeState();\n    }\n\n    if (this.controlSubscription) {\n      this.controlSubscription.unsubscribe();\n      this.controlSubscription = new Subscription();\n    }\n    this.controlSubscription.add(\n      this.control.valueChanges.subscribe((value: string) => {\n        if (this.enableDocumentTypeChoice && !this.lastTypedValue && value?.length > 11) {\n          this.handleInitialDocumentTypeState();\n        }\n        this.lastTypedValue = value;\n      })\n    );\n  }\n  @Output()\n  public blurEvent = new EventEmitter();\n  @Output()\n  public enterKeyPress = new EventEmitter();\n  @Output()\n  public focusEvent = new EventEmitter();\n  @Output()\n  public onDocumentTypeChange = new EventEmitter<ListItem>();\n\n  public isPasswordVisible = false;\n  public validateOnly = false;\n\n  get placeholder() {\n    if (!this.label) {\n      return '';\n    }\n    return `${this.label}${this.isRequired ? '*' : ''}`;\n  }\n\n  get keyfilter() {\n    this.validateOnly = false;\n    if (this.numeric) {\n      return 'int';\n    }\n    if (this.decimal) {\n      this.validateOnly = true;\n      return /^(\\d+(?:[\\,]\\d{2})?)$/;\n    }\n    if (this.onlyText) {\n      this.validateOnly = true;\n      return /^[a-zA-ZÀ-ú\\s]*$/gm;\n    }\n    if (this.alphaNumeric) {\n      return 'alphanum';\n    }\n    return /[\\s\\S]*/;\n  }\n\n  get control() {\n    return this._control;\n  }\n\n  get showPasswordIcon() {\n    return this.isPasswordVisible ? 'fas fa-eye' : 'fas fa-eye-slash';\n  }\n\n  public documentTypes: ListItem[] = [\n    {\n      name: 'CPF',\n      code: DocumentType.CPF,\n    },\n    {\n      name: 'CNPJ',\n      code: DocumentType.CNPJ,\n    },\n  ];\n\n  public selectedDocumentType = this.documentTypes[1];\n\n  private lastBlurValue = '';\n  private lastTypedValue = '';\n  private subscription = new Subscription();\n  private controlSubscription = new Subscription();\n  private _control: any;\n\n  ngOnInit() {\n    if (this.enableDocumentTypeChoice) {\n      this.setDocumentType(this.selectedDocumentType.code);\n    }\n  }\n\n  ngOnDestroy() {\n    this.subscription.unsubscribe();\n    this.controlSubscription.unsubscribe();\n  }\n\n  // public fieldErrorLabel(): string {\n  //   if (this.control && this.control.invalid && this.control.touched) {\n  //     if (this.control.hasError('required')) {\n  //       return 'Campo obrigatório';\n  //     }\n\n  //     if (this.control.hasError('minlength')) {\n  //       return `Tamanho mínimo: ${this.control.errors['minlength'].requiredLength}`;\n  //     }\n\n  //     if (this.control.hasError('maxlength')) {\n  //       return `Tamanho máximo permitido: ${this.control.errors['maxlength'].requiredLength}`;\n  //     }\n\n  //     return typeof this.control.errors['invalid'] === 'string' ? this.control.errors['invalid'] : 'Campo inválido';\n  //   }\n\n  //   return '';\n  // }\n\n  public onBlur() {\n    this.control.markAsTouched();\n    if (this.lastBlurValue !== this.control.value) {\n      this.lastBlurValue = this.control.value;\n      setTimeout(() => {\n        this.blurEvent.emit(this.control.value);\n      });\n    }\n  }\n\n  public onEnterPress() {\n    this.onBlur();\n    this.enterKeyPress.emit();\n  }\n\n  public onFocus($event: Event) {\n    const target = $event.target as HTMLInputElement;\n    if (this.mask) {\n      const firstUnderscore = target?.value.indexOf('_');\n      const selectionIndex = (firstUnderscore >= 0 ? firstUnderscore : target?.value.length) || 0;\n      target?.setSelectionRange(selectionIndex, selectionIndex);\n    }\n    this.focusEvent.emit(target?.value);\n  }\n\n  public toggleShowPassword() {\n    this.isPasswordVisible = !this.isPasswordVisible;\n  }\n\n  public handleDocumentTypeChange() {\n    if (this.selectedDocumentType.code === DocumentType.CNPJ) {\n      this.setDocumentType(DocumentType.CPF);\n    } else {\n      this.setDocumentType(DocumentType.CNPJ);\n    }\n  }\n\n  private handleInitialDocumentTypeState() {\n    if (this.control?.value) {\n      if (this.control.value.length === 11) {\n        this.setDocumentType(DocumentType.CPF);\n      } else {\n        this.setDocumentType(DocumentType.CNPJ);\n      }\n    } else {\n      this.setDocumentType(DocumentType.CPF);\n    }\n  }\n\n  private setDocumentType(documentType: DocumentType) {\n    switch (documentType) {\n      case DocumentType.CNPJ:\n        this.selectedDocumentType = this.documentTypes[1];\n        this.mask = MaskUtil.CNPJ_TEXT_FIELD_PATTERN;\n        break;\n      case DocumentType.CPF:\n        this.selectedDocumentType = this.documentTypes[0];\n        this.mask = MaskUtil.CPF_TEXT_FIELD_PATTERN;\n        break;\n    }\n    this.onDocumentTypeChange.emit(this.selectedDocumentType);\n  }\n}\n","<form class=\"input-container p-input-icon-right\">\n  <i *ngIf=\"rightIcon\" [class]=\"rightIcon\"></i>\n  <i *ngIf=\"isPassword\" class=\"show-password-icon {{ showPasswordIcon }}\" (click)=\"toggleShowPassword()\"></i>\n  <div class=\"p-inputgroup\">\n    <vector-button\n      *ngIf=\"enableDocumentTypeChoice\"\n      leftIcon=\"fas fa-exchange-alt\"\n      type=\"success\"\n      [label]=\"selectedDocumentType.name\"\n      [disabled]=\"control.disabled\"\n      [noShadow]=\"true\"\n      (onClick)=\"handleDocumentTypeChange()\"\n    ></vector-button>\n\n    <input\n      *ngIf=\"!mask\"\n      pInputText\n      type=\"text\"\n      [formControl]=\"control\"\n      [attr.maxlength]=\"maxlength\"\n      [placeholder]=\"placeholder\"\n      [pValidateOnly]=\"validateOnly\"\n      [pKeyFilter]=\"keyfilter\"\n      [ngClass]=\"{ 'password-field': isPassword && !isPasswordVisible, 'text-centered': centered }\"\n      (onBlur)=\"onBlur()\"\n      (keydown.enter)=\"onEnterPress()\"\n      (click)=\"onFocus($event)\"\n    />\n    <p-inputMask\n      *ngIf=\"mask\"\n      type=\"text\"\n      [formControl]=\"control\"\n      [mask]=\"mask\"\n      [placeholder]=\"placeholder\"\n      (onBlur)=\"onBlur()\"\n      (keydown.enter)=\"onEnterPress()\"\n      [autoClear]=\"autoClear\"\n      [unmask]=\"true\"\n      [styleClass]=\"centered ? 'text-centered' : ''\"\n      slotChar=\"_\"\n      (click)=\"onFocus($event)\"\n    ></p-inputMask>\n  </div>\n  <vector-field-error-message *ngIf=\"!hiddenErrorMessage\" [control]=\"control\"></vector-field-error-message>\n  <!-- <span class=\"input-error\">{{ fieldErrorLabel() }}</span> -->\n</form>\n"]}
209
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"text-field.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-vector-components/src/lib/components/fields/text-field/text-field.component.ts","../../../../../../../projects/ngx-vector-components/src/lib/components/fields/text-field/text-field.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnDestroy, OnInit, Output } from '@angular/core';\nimport { Subscription } from 'rxjs';\nimport { DocumentType, ListItem } from '../../../models';\nimport { MaskUtil } from '../../../utils';\n\n@Component({\n  selector: 'vector-text-field',\n  templateUrl: './text-field.component.html',\n  styleUrls: ['./text-field.component.scss'],\n})\nexport class TextFieldComponent implements OnInit, OnDestroy {\n  @Input()\n  public isRequired: boolean | undefined = false;\n  @Input()\n  public label: string | undefined = '';\n  @Input()\n  public maxlength: string = '';\n  @Input()\n  public isPassword = false;\n  @Input()\n  public numeric = false;\n  @Input()\n  public decimal = false;\n  @Input()\n  public onlyText = false;\n  @Input()\n  public alphaNumeric = false;\n  @Input()\n  public mask: string | undefined;\n  @Input()\n  public autoClear = true;\n  @Input()\n  public rightIcon = '';\n  @Input()\n  public centered = false;\n  @Input()\n  public enableDocumentTypeChoice = false;\n  @Input()\n  public hiddenErrorMessage: boolean = false;\n  @Input()\n  set control(_control: any) {\n    this._control = _control;\n    if (this.enableDocumentTypeChoice) {\n      this.handleInitialDocumentTypeState();\n    }\n\n    if (this.controlSubscription) {\n      this.controlSubscription.unsubscribe();\n      this.controlSubscription = new Subscription();\n    }\n    this.controlSubscription.add(\n      this.control.valueChanges.subscribe((value: string) => {\n        if (this.enableDocumentTypeChoice && !this.lastTypedValue && value?.length > 11) {\n          this.handleInitialDocumentTypeState();\n        }\n        this.lastTypedValue = value;\n      })\n    );\n  }\n  @Output()\n  public blurEvent = new EventEmitter();\n  @Output()\n  public enterKeyPress = new EventEmitter();\n  @Output()\n  public focusEvent = new EventEmitter();\n  @Output()\n  public onDocumentTypeChange = new EventEmitter<ListItem>();\n\n  public isPasswordVisible = false;\n  public validateOnly = false;\n\n  get placeholder() {\n    if (!this.label) {\n      return '';\n    }\n    return `${this.label}${this.isRequired ? '*' : ''}`;\n  }\n\n  get keyfilter() {\n    this.validateOnly = false;\n    if (this.numeric) {\n      return 'int';\n    }\n    if (this.decimal) {\n      this.validateOnly = true;\n      return /^(\\d+(?:[\\,]\\d{2})?)$/;\n    }\n    if (this.onlyText) {\n      this.validateOnly = true;\n      return /^[a-zA-ZÀ-ú\\s]*$/gm;\n    }\n    if (this.alphaNumeric) {\n      return 'alphanum';\n    }\n    return /[\\s\\S]*/;\n  }\n\n  get control() {\n    return this._control;\n  }\n\n  get showPasswordIcon() {\n    return this.isPasswordVisible ? 'fas fa-eye' : 'fas fa-eye-slash';\n  }\n\n  public documentTypes: ListItem[] = [\n    {\n      name: 'CPF',\n      code: DocumentType.CPF,\n    },\n    {\n      name: 'CNPJ',\n      code: DocumentType.CNPJ,\n    },\n  ];\n\n  public selectedDocumentType = this.documentTypes[1];\n\n  private lastBlurValue = '';\n  private lastTypedValue = '';\n  private subscription = new Subscription();\n  private controlSubscription = new Subscription();\n  private _control: any;\n\n  ngOnInit() {\n    if (this.enableDocumentTypeChoice) {\n      this.setDocumentType(this.selectedDocumentType.code);\n    }\n  }\n\n  ngOnDestroy() {\n    this.subscription.unsubscribe();\n    this.controlSubscription.unsubscribe();\n  }\n\n  public onBlur() {\n    this.control.markAsTouched();\n    if (this.lastBlurValue !== this.control.value) {\n      this.lastBlurValue = this.control.value;\n      setTimeout(() => {\n        this.blurEvent.emit(this.control.value);\n      });\n    }\n  }\n\n  public onEnterPress() {\n    this.onBlur();\n    this.enterKeyPress.emit();\n  }\n\n  public onFocus($event: Event) {\n    const target = $event.target as HTMLInputElement;\n    if (this.mask) {\n      const firstUnderscore = target?.value.indexOf('_');\n      const selectionIndex = (firstUnderscore >= 0 ? firstUnderscore : target?.value.length) || 0;\n      target?.setSelectionRange(selectionIndex, selectionIndex);\n    }\n    this.focusEvent.emit(target?.value);\n  }\n\n  public toggleShowPassword() {\n    this.isPasswordVisible = !this.isPasswordVisible;\n  }\n\n  public handleDocumentTypeChange() {\n    if (this.selectedDocumentType.code === DocumentType.CNPJ) {\n      this.setDocumentType(DocumentType.CPF);\n    } else {\n      this.setDocumentType(DocumentType.CNPJ);\n    }\n  }\n\n  private handleInitialDocumentTypeState() {\n    if (this.control?.value) {\n      if (this.control.value.length === 11) {\n        this.setDocumentType(DocumentType.CPF);\n      } else {\n        this.setDocumentType(DocumentType.CNPJ);\n      }\n    } else {\n      this.setDocumentType(DocumentType.CPF);\n    }\n  }\n\n  private setDocumentType(documentType: DocumentType) {\n    switch (documentType) {\n      case DocumentType.CNPJ:\n        this.selectedDocumentType = this.documentTypes[1];\n        this.mask = MaskUtil.CNPJ_TEXT_FIELD_PATTERN;\n        break;\n      case DocumentType.CPF:\n        this.selectedDocumentType = this.documentTypes[0];\n        this.mask = MaskUtil.CPF_TEXT_FIELD_PATTERN;\n        break;\n    }\n    this.onDocumentTypeChange.emit(this.selectedDocumentType);\n  }\n}\n","<form class=\"input-container p-input-icon-right\">\n  <i *ngIf=\"rightIcon\" [class]=\"rightIcon\"></i>\n  <i *ngIf=\"isPassword\" class=\"show-password-icon {{ showPasswordIcon }}\" (click)=\"toggleShowPassword()\"></i>\n  <div class=\"p-inputgroup\">\n    <vector-button\n      *ngIf=\"enableDocumentTypeChoice\"\n      leftIcon=\"fas fa-exchange-alt\"\n      type=\"success\"\n      [label]=\"selectedDocumentType.name\"\n      [disabled]=\"control.disabled\"\n      [noShadow]=\"true\"\n      (onClick)=\"handleDocumentTypeChange()\"\n    ></vector-button>\n\n    <input\n      *ngIf=\"!mask\"\n      pInputText\n      type=\"text\"\n      [formControl]=\"control\"\n      [attr.maxlength]=\"maxlength\"\n      [placeholder]=\"placeholder\"\n      [pValidateOnly]=\"validateOnly\"\n      [pKeyFilter]=\"keyfilter\"\n      [ngClass]=\"{ 'password-field': isPassword && !isPasswordVisible, 'text-centered': centered }\"\n      (onBlur)=\"onBlur()\"\n      (keydown.enter)=\"onEnterPress()\"\n      (click)=\"onFocus($event)\"\n    />\n    <p-inputMask\n      *ngIf=\"mask\"\n      type=\"text\"\n      [formControl]=\"control\"\n      [mask]=\"mask\"\n      [placeholder]=\"placeholder\"\n      (onBlur)=\"onBlur()\"\n      (keydown.enter)=\"onEnterPress()\"\n      [autoClear]=\"autoClear\"\n      [unmask]=\"true\"\n      [styleClass]=\"centered ? 'text-centered' : ''\"\n      slotChar=\"_\"\n      (click)=\"onFocus($event)\"\n    ></p-inputMask>\n  </div>\n  <vector-field-error-message *ngIf=\"!hiddenErrorMessage\" [control]=\"control\"></vector-field-error-message>\n</form>\n"]}