keevo-components 1.8.263 → 1.8.265

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.
@@ -23,7 +23,22 @@ export class BaseComponentCrud {
23
23
  * @param paramsDialog - Parâmetros do dialog
24
24
  */
25
25
  openDialog(componentType, callBackFunction, paramsDialog) {
26
- FormService.openDialog(this.dialogService, componentType, callBackFunction, paramsDialog);
26
+ // FormService.openDialog(
27
+ // this.dialogService,
28
+ // componentType,
29
+ // callBackFunction,
30
+ // paramsDialog);
31
+ const dialogRef = FormService.openDialog(this.dialogService, componentType, callBackFunction, paramsDialog);
32
+ // Garante que o estado atual seja mantido no histórico
33
+ window.history.pushState(null, '', window.location.href);
34
+ // Configura a ação para quando o botão de voltar do navegador é pressionado
35
+ window.onpopstate = function () {
36
+ // Verifica se o dialog está aberto antes de fechá-lo
37
+ if (dialogRef && dialogRef.close) {
38
+ // dialogRef.onClose.subscribe(callBackFunction());
39
+ dialogRef.close();
40
+ }
41
+ };
27
42
  }
28
43
  /**
29
44
  * Imprime um relatório na tela
@@ -62,4 +77,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
62
77
  template: ''
63
78
  }]
64
79
  }], ctorParameters: () => [{ type: i1.DialogService }, { type: i2.NotificationService }] });
65
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS1jb21wb25lbnQtY3J1ZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tlZXZvLWNvbXBvbmVudHMvc3JjL2xpYi9hcGkvYmFzZS1jb21wb25lbnRzL2Jhc2UtY29tcG9uZW50LWNydWQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLFNBQVMsRUFBUSxNQUFNLGVBQWUsQ0FBQztBQUNoRCxPQUFPLEVBQUUsV0FBVyxFQUFnQixNQUFNLDBCQUEwQixDQUFDOzs7O0FBT3JFLE1BQU0sT0FBZ0IsaUJBQWlCO0lBS3JDLFlBQ1MsYUFBNEIsRUFDNUIsbUJBQXdDO1FBRHhDLGtCQUFhLEdBQWIsYUFBYSxDQUFlO1FBQzVCLHdCQUFtQixHQUFuQixtQkFBbUIsQ0FBcUI7UUFMMUMsYUFBUSxHQUFZLEtBQUssQ0FBQztRQUMxQixnQkFBVyxHQUFRLEVBQUUsQ0FBQztJQUs3QixDQUFDO0lBRUQ7O09BRUc7SUFDSSxXQUFXO1FBQ2hCLElBQUksQ0FBQyxRQUFRLEdBQUcsS0FBSyxDQUFDO0lBQ3hCLENBQUM7SUFFRDs7Ozs7T0FLRztJQUNPLFVBQVUsQ0FBQyxhQUF3QixFQUFFLGdCQUEwQixFQUFFLFlBQTJCO1FBQ3BHLFdBQVcsQ0FBQyxVQUFVLENBQ3BCLElBQUksQ0FBQyxhQUFhLEVBQ2xCLGFBQWEsRUFDYixnQkFBZ0IsRUFDaEIsWUFBWSxDQUFDLENBQUM7SUFDbEIsQ0FBQztJQUVEOzs7T0FHRztJQUNPLGlCQUFpQixDQUFDLEdBQW9CO1FBQzlDLEdBQUc7WUFDRCxrQkFBa0I7YUFDakIsU0FBUyxDQUFDO1lBQ1QsSUFBSSxFQUFFLENBQUMsR0FBUSxFQUFFLEVBQUU7Z0JBQ2pCLElBQUksQ0FBQyxXQUFXLEdBQUcsR0FBRyxDQUFDO2dCQUN2QixJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQztZQUN2QixDQUFDO1lBQ0QsS0FBSyxFQUFFLENBQUMsQ0FBQyxFQUFFLEVBQUU7Z0JBQ1gsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUNyQixDQUFDO1NBQ0YsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVEOzs7T0FHRztJQUNPLFVBQVUsQ0FBQyxHQUFRO1FBQzNCLElBQUksR0FBRyxFQUFFLENBQUM7WUFDUixJQUFJLEdBQUcsQ0FBQyxPQUFPLEVBQUUsQ0FBQztnQkFDaEIsSUFBSSxDQUFDLG1CQUFtQixDQUFDLFVBQVUsQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLENBQUM7WUFDbkQsQ0FBQztRQUNILENBQUM7SUFDSCxDQUFDOzhHQTNEbUIsaUJBQWlCO2tHQUFqQixpQkFBaUIsb0RBRjNCLEVBQUU7OzJGQUVRLGlCQUFpQjtrQkFIdEMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsRUFBRTtpQkFDYiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpYWxvZ1NlcnZpY2UgfSBmcm9tICdwcmltZW5nL2R5bmFtaWNkaWFsb2cnO1xyXG5pbXBvcnQgeyBDb21wb25lbnQsIFR5cGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQgeyBGb3JtU2VydmljZSwgcGFyYW1zRGlhbG9nIH0gZnJvbSBcIi4uL3NlcnZpY2VzL2Zvcm0uc2VydmljZVwiO1xyXG5pbXBvcnQgeyBOb3RpZmljYXRpb25TZXJ2aWNlIH0gZnJvbSAnLi4vc2VydmljZXMvbm90aWZpY2F0aW9uLnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBPYnNlcnZhYmxlIH0gZnJvbSAncnhqcyc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICB0ZW1wbGF0ZTogJydcclxufSlcclxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEJhc2VDb21wb25lbnRDcnVkIHtcclxuXHJcbiAgcHVibGljIGlzUmVwb3J0OiBib29sZWFuID0gZmFsc2U7XHJcbiAgcHVibGljIGl0ZW1zUmVwb3J0OiBhbnkgPSBbXTtcclxuXHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBwdWJsaWMgZGlhbG9nU2VydmljZTogRGlhbG9nU2VydmljZSxcclxuICAgIHB1YmxpYyBub3RpZmljYXRpb25TZXJ2aWNlOiBOb3RpZmljYXRpb25TZXJ2aWNlKSB7XHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBGZWNoYSB1bSByZWxhdMOzcmlvXHJcbiAgICovXHJcbiAgcHVibGljIGNsb3NlUmVwb3J0KCkge1xyXG4gICAgdGhpcy5pc1JlcG9ydCA9IGZhbHNlO1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogQWJyZSB1bSBmb3JtIGRpYWxvZ1xyXG4gICAqIEBwYXJhbSBjb21wb25lbnRUeXBlIC0gQ29tcG9uZW50ZSBxdWUgc2Vyw6EgcmVuZGVyaXphZG9cclxuICAgKiBAcGFyYW0gY2FsbEJhY2tGdW5jdGlvbiAtIEZ1bsOnw6NvIGRlIGNhbGxiYWNrIHF1ZSBkZXZlcsOhIHNlciBjaGFtYWRhIGFww7NzIG8gZmVjaGFtZW50byBkbyBkaWFsb2dcclxuICAgKiBAcGFyYW0gcGFyYW1zRGlhbG9nIC0gUGFyw6JtZXRyb3MgZG8gZGlhbG9nXHJcbiAgICovXHJcbiAgcHJvdGVjdGVkIG9wZW5EaWFsb2coY29tcG9uZW50VHlwZTogVHlwZTxhbnk+LCBjYWxsQmFja0Z1bmN0aW9uOiBGdW5jdGlvbiwgcGFyYW1zRGlhbG9nPzogcGFyYW1zRGlhbG9nKSB7XHJcbiAgICBGb3JtU2VydmljZS5vcGVuRGlhbG9nKFxyXG4gICAgICB0aGlzLmRpYWxvZ1NlcnZpY2UsXHJcbiAgICAgIGNvbXBvbmVudFR5cGUsXHJcbiAgICAgIGNhbGxCYWNrRnVuY3Rpb24sXHJcbiAgICAgIHBhcmFtc0RpYWxvZyk7XHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBJbXByaW1lIHVtIHJlbGF0w7NyaW8gbmEgdGVsYVxyXG4gICAqIEBwYXJhbSBvYnMgLSBPYnNlcnZhYmxlIGNvbSBvIGNhcnJlZ2FtZW50byBkbyByZWxhdMOzcmlvXHJcbiAgICovXHJcbiAgcHJvdGVjdGVkIHByaW50UmVwb3J0RmlsdGVyKG9iczogT2JzZXJ2YWJsZTxhbnk+KSB7XHJcbiAgICBvYnNcclxuICAgICAgLy8ucGlwZShsb2FkaW5nKCkpXHJcbiAgICAgIC5zdWJzY3JpYmUoe1xyXG4gICAgICAgIG5leHQ6IChyZXM6IGFueSkgPT4ge1xyXG4gICAgICAgICAgdGhpcy5pdGVtc1JlcG9ydCA9IHJlcztcclxuICAgICAgICAgIHRoaXMuaXNSZXBvcnQgPSB0cnVlO1xyXG4gICAgICAgIH0sXHJcbiAgICAgICAgZXJyb3I6IChlKSA9PiB7XHJcbiAgICAgICAgICB0aGlzLnRvYXN0RXJyb3IoZSk7XHJcbiAgICAgICAgfSxcclxuICAgICAgfSk7XHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBFeGliZSB1bSB0b2FzdCBjb20gdW0gZXJyb1xyXG4gICAqIEBwYXJhbSBlcnIgLSBFcnJvXHJcbiAgICovXHJcbiAgcHJvdGVjdGVkIHRvYXN0RXJyb3IoZXJyOiBhbnkpIHtcclxuICAgIGlmIChlcnIpIHtcclxuICAgICAgaWYgKGVyci5tZXNzYWdlKSB7XHJcbiAgICAgICAgdGhpcy5ub3RpZmljYXRpb25TZXJ2aWNlLnRvYXN0RXJyb3IoZXJyLm1lc3NhZ2UpO1xyXG4gICAgICB9XHJcbiAgICB9XHJcbiAgfVxyXG59XHJcbiJdfQ==
80
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzZS1jb21wb25lbnQtY3J1ZC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tlZXZvLWNvbXBvbmVudHMvc3JjL2xpYi9hcGkvYmFzZS1jb21wb25lbnRzL2Jhc2UtY29tcG9uZW50LWNydWQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLFNBQVMsRUFBUSxNQUFNLGVBQWUsQ0FBQztBQUNoRCxPQUFPLEVBQUUsV0FBVyxFQUFnQixNQUFNLDBCQUEwQixDQUFDOzs7O0FBT3JFLE1BQU0sT0FBZ0IsaUJBQWlCO0lBS3JDLFlBQ1MsYUFBNEIsRUFDNUIsbUJBQXdDO1FBRHhDLGtCQUFhLEdBQWIsYUFBYSxDQUFlO1FBQzVCLHdCQUFtQixHQUFuQixtQkFBbUIsQ0FBcUI7UUFMMUMsYUFBUSxHQUFZLEtBQUssQ0FBQztRQUMxQixnQkFBVyxHQUFRLEVBQUUsQ0FBQztJQUs3QixDQUFDO0lBRUQ7O09BRUc7SUFDSSxXQUFXO1FBQ2hCLElBQUksQ0FBQyxRQUFRLEdBQUcsS0FBSyxDQUFDO0lBQ3hCLENBQUM7SUFFRDs7Ozs7T0FLRztJQUNPLFVBQVUsQ0FBQyxhQUF3QixFQUFFLGdCQUEwQixFQUFFLFlBQTJCO1FBQ3BHLDBCQUEwQjtRQUMxQix3QkFBd0I7UUFDeEIsbUJBQW1CO1FBQ25CLHNCQUFzQjtRQUN0QixtQkFBbUI7UUFFbkIsTUFBTSxTQUFTLEdBQXFCLFdBQVcsQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLGFBQWEsRUFBRSxhQUFhLEVBQUUsZ0JBQWdCLEVBQUUsWUFBWSxDQUFDLENBQUM7UUFFOUgsdURBQXVEO1FBQ3ZELE1BQU0sQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLElBQUksRUFBRSxFQUFFLEVBQUUsTUFBTSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsQ0FBQztRQUN6RCw0RUFBNEU7UUFDNUUsTUFBTSxDQUFDLFVBQVUsR0FBRztZQUNsQixxREFBcUQ7WUFDckQsSUFBSSxTQUFTLElBQUksU0FBUyxDQUFDLEtBQUssRUFBRSxDQUFDO2dCQUNqQyxtREFBbUQ7Z0JBQ25ELFNBQVMsQ0FBQyxLQUFLLEVBQUUsQ0FBQztZQUNwQixDQUFDO1FBQ0gsQ0FBQyxDQUFDO0lBQ0osQ0FBQztJQUVEOzs7T0FHRztJQUNPLGlCQUFpQixDQUFDLEdBQW9CO1FBQzlDLEdBQUc7WUFDRCxrQkFBa0I7YUFDakIsU0FBUyxDQUFDO1lBQ1QsSUFBSSxFQUFFLENBQUMsR0FBUSxFQUFFLEVBQUU7Z0JBQ2pCLElBQUksQ0FBQyxXQUFXLEdBQUcsR0FBRyxDQUFDO2dCQUN2QixJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQztZQUN2QixDQUFDO1lBQ0QsS0FBSyxFQUFFLENBQUMsQ0FBQyxFQUFFLEVBQUU7Z0JBQ1gsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUNyQixDQUFDO1NBQ0YsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVEOzs7T0FHRztJQUNPLFVBQVUsQ0FBQyxHQUFRO1FBQzNCLElBQUksR0FBRyxFQUFFLENBQUM7WUFDUixJQUFJLEdBQUcsQ0FBQyxPQUFPLEVBQUUsQ0FBQztnQkFDaEIsSUFBSSxDQUFDLG1CQUFtQixDQUFDLFVBQVUsQ0FBQyxHQUFHLENBQUMsT0FBTyxDQUFDLENBQUM7WUFDbkQsQ0FBQztRQUNILENBQUM7SUFDSCxDQUFDOzhHQXhFbUIsaUJBQWlCO2tHQUFqQixpQkFBaUIsb0RBRjNCLEVBQUU7OzJGQUVRLGlCQUFpQjtrQkFIdEMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsRUFBRTtpQkFDYiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IERpYWxvZ1NlcnZpY2UsIER5bmFtaWNEaWFsb2dSZWYgfSBmcm9tICdwcmltZW5nL2R5bmFtaWNkaWFsb2cnO1xyXG5pbXBvcnQgeyBDb21wb25lbnQsIFR5cGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQgeyBGb3JtU2VydmljZSwgcGFyYW1zRGlhbG9nIH0gZnJvbSBcIi4uL3NlcnZpY2VzL2Zvcm0uc2VydmljZVwiO1xyXG5pbXBvcnQgeyBOb3RpZmljYXRpb25TZXJ2aWNlIH0gZnJvbSAnLi4vc2VydmljZXMvbm90aWZpY2F0aW9uLnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBPYnNlcnZhYmxlIH0gZnJvbSAncnhqcyc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICB0ZW1wbGF0ZTogJydcclxufSlcclxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEJhc2VDb21wb25lbnRDcnVkIHtcclxuXHJcbiAgcHVibGljIGlzUmVwb3J0OiBib29sZWFuID0gZmFsc2U7XHJcbiAgcHVibGljIGl0ZW1zUmVwb3J0OiBhbnkgPSBbXTtcclxuXHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBwdWJsaWMgZGlhbG9nU2VydmljZTogRGlhbG9nU2VydmljZSxcclxuICAgIHB1YmxpYyBub3RpZmljYXRpb25TZXJ2aWNlOiBOb3RpZmljYXRpb25TZXJ2aWNlKSB7XHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBGZWNoYSB1bSByZWxhdMOzcmlvXHJcbiAgICovXHJcbiAgcHVibGljIGNsb3NlUmVwb3J0KCkge1xyXG4gICAgdGhpcy5pc1JlcG9ydCA9IGZhbHNlO1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogQWJyZSB1bSBmb3JtIGRpYWxvZ1xyXG4gICAqIEBwYXJhbSBjb21wb25lbnRUeXBlIC0gQ29tcG9uZW50ZSBxdWUgc2Vyw6EgcmVuZGVyaXphZG9cclxuICAgKiBAcGFyYW0gY2FsbEJhY2tGdW5jdGlvbiAtIEZ1bsOnw6NvIGRlIGNhbGxiYWNrIHF1ZSBkZXZlcsOhIHNlciBjaGFtYWRhIGFww7NzIG8gZmVjaGFtZW50byBkbyBkaWFsb2dcclxuICAgKiBAcGFyYW0gcGFyYW1zRGlhbG9nIC0gUGFyw6JtZXRyb3MgZG8gZGlhbG9nXHJcbiAgICovXHJcbiAgcHJvdGVjdGVkIG9wZW5EaWFsb2coY29tcG9uZW50VHlwZTogVHlwZTxhbnk+LCBjYWxsQmFja0Z1bmN0aW9uOiBGdW5jdGlvbiwgcGFyYW1zRGlhbG9nPzogcGFyYW1zRGlhbG9nKSB7XHJcbiAgICAvLyBGb3JtU2VydmljZS5vcGVuRGlhbG9nKFxyXG4gICAgLy8gICB0aGlzLmRpYWxvZ1NlcnZpY2UsXHJcbiAgICAvLyAgIGNvbXBvbmVudFR5cGUsXHJcbiAgICAvLyAgIGNhbGxCYWNrRnVuY3Rpb24sXHJcbiAgICAvLyAgIHBhcmFtc0RpYWxvZyk7XHJcbiAgICBcclxuICAgIGNvbnN0IGRpYWxvZ1JlZjogRHluYW1pY0RpYWxvZ1JlZiA9IEZvcm1TZXJ2aWNlLm9wZW5EaWFsb2codGhpcy5kaWFsb2dTZXJ2aWNlLCBjb21wb25lbnRUeXBlLCBjYWxsQmFja0Z1bmN0aW9uLCBwYXJhbXNEaWFsb2cpO1xyXG4gICAgXHJcbiAgICAvLyBHYXJhbnRlIHF1ZSBvIGVzdGFkbyBhdHVhbCBzZWphIG1hbnRpZG8gbm8gaGlzdMOzcmljb1xyXG4gICAgd2luZG93Lmhpc3RvcnkucHVzaFN0YXRlKG51bGwsICcnLCB3aW5kb3cubG9jYXRpb24uaHJlZik7XHJcbiAgICAvLyBDb25maWd1cmEgYSBhw6fDo28gcGFyYSBxdWFuZG8gbyBib3TDo28gZGUgdm9sdGFyIGRvIG5hdmVnYWRvciDDqSBwcmVzc2lvbmFkb1xyXG4gICAgd2luZG93Lm9ucG9wc3RhdGUgPSBmdW5jdGlvbiAoKSB7XHJcbiAgICAgIC8vIFZlcmlmaWNhIHNlIG8gZGlhbG9nIGVzdMOhIGFiZXJ0byBhbnRlcyBkZSBmZWNow6EtbG9cclxuICAgICAgaWYgKGRpYWxvZ1JlZiAmJiBkaWFsb2dSZWYuY2xvc2UpIHtcclxuICAgICAgICAvLyBkaWFsb2dSZWYub25DbG9zZS5zdWJzY3JpYmUoY2FsbEJhY2tGdW5jdGlvbigpKTtcclxuICAgICAgICBkaWFsb2dSZWYuY2xvc2UoKTtcclxuICAgICAgfVxyXG4gICAgfTtcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIEltcHJpbWUgdW0gcmVsYXTDs3JpbyBuYSB0ZWxhXHJcbiAgICogQHBhcmFtIG9icyAtIE9ic2VydmFibGUgY29tIG8gY2FycmVnYW1lbnRvIGRvIHJlbGF0w7NyaW9cclxuICAgKi9cclxuICBwcm90ZWN0ZWQgcHJpbnRSZXBvcnRGaWx0ZXIob2JzOiBPYnNlcnZhYmxlPGFueT4pIHtcclxuICAgIG9ic1xyXG4gICAgICAvLy5waXBlKGxvYWRpbmcoKSlcclxuICAgICAgLnN1YnNjcmliZSh7XHJcbiAgICAgICAgbmV4dDogKHJlczogYW55KSA9PiB7XHJcbiAgICAgICAgICB0aGlzLml0ZW1zUmVwb3J0ID0gcmVzO1xyXG4gICAgICAgICAgdGhpcy5pc1JlcG9ydCA9IHRydWU7XHJcbiAgICAgICAgfSxcclxuICAgICAgICBlcnJvcjogKGUpID0+IHtcclxuICAgICAgICAgIHRoaXMudG9hc3RFcnJvcihlKTtcclxuICAgICAgICB9LFxyXG4gICAgICB9KTtcclxuICB9XHJcblxyXG4gIC8qKlxyXG4gICAqIEV4aWJlIHVtIHRvYXN0IGNvbSB1bSBlcnJvXHJcbiAgICogQHBhcmFtIGVyciAtIEVycm9cclxuICAgKi9cclxuICBwcm90ZWN0ZWQgdG9hc3RFcnJvcihlcnI6IGFueSkge1xyXG4gICAgaWYgKGVycikge1xyXG4gICAgICBpZiAoZXJyLm1lc3NhZ2UpIHtcclxuICAgICAgICB0aGlzLm5vdGlmaWNhdGlvblNlcnZpY2UudG9hc3RFcnJvcihlcnIubWVzc2FnZSk7XHJcbiAgICAgIH1cclxuICAgIH1cclxuICB9XHJcbn1cclxuIl19
@@ -48,6 +48,19 @@ export class BreadcrumbsService {
48
48
  }
49
49
  return breadcrumbs;
50
50
  }
51
+ getBreadCrumbs() {
52
+ return this.breadcrumbsSubject.value;
53
+ }
54
+ changeBreadCrumb(breadCrumbs) {
55
+ this.breadcrumbsSubject.next(breadCrumbs);
56
+ }
57
+ changeLastBreadCrumb(callback) {
58
+ const breadCrumbs = this.breadcrumbsSubject.value.map(x => ({ ...x }));
59
+ const lastBreadCrumb = breadCrumbs.pop();
60
+ const newBreadCrumb = callback(lastBreadCrumb);
61
+ if (newBreadCrumb)
62
+ this.breadcrumbsSubject.next([...breadCrumbs, newBreadCrumb]);
63
+ }
51
64
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: BreadcrumbsService, deps: [{ token: i1.Router }, { token: i1.ActivatedRoute }], target: i0.ɵɵFactoryTarget.Injectable }); }
52
65
  static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: BreadcrumbsService, providedIn: 'root' }); }
53
66
  }
@@ -57,4 +70,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
57
70
  providedIn: 'root',
58
71
  }]
59
72
  }], ctorParameters: () => [{ type: i1.Router }, { type: i1.ActivatedRoute }] });
60
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnJlYWRjcnVtYnMuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tlZXZvLWNvbXBvbmVudHMvc3JjL2xpYi9hcGkvc2VydmljZXMvYnJlYWRjcnVtYnMuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTNDLE9BQU8sRUFFTCxhQUFhLEVBRWQsTUFBTSxpQkFBaUIsQ0FBQztBQUV6QixPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDeEMsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLE1BQU0sQ0FBQzs7O0FBS3ZDLE1BQU0sT0FBTyxrQkFBa0I7SUFJN0IsWUFBb0IsTUFBYyxFQUFVLGNBQThCO1FBQXRELFdBQU0sR0FBTixNQUFNLENBQVE7UUFBVSxtQkFBYyxHQUFkLGNBQWMsQ0FBZ0I7UUFIbEUsdUJBQWtCLEdBQUcsSUFBSSxlQUFlLENBQTZELEVBQUUsQ0FBQyxDQUFDO1FBQ2pILGlCQUFZLEdBQUcsSUFBSSxDQUFDLGtCQUFrQixDQUFDLFlBQVksRUFBRSxDQUFDO1FBR3BELElBQUksQ0FBQyxNQUFNLENBQUMsTUFBTTthQUNmLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLEtBQUssWUFBWSxhQUFhLENBQUMsQ0FBQzthQUN2RCxTQUFTLENBQUMsR0FBRyxFQUFFO1lBQ2QsTUFBTSxXQUFXLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsQ0FBQztZQUNsRSxJQUFJLENBQUMsa0JBQWtCLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBQzVDLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVPLFVBQVUsQ0FBQyxLQUFxQixFQUFFLE1BQWMsRUFBRSxFQUFFLGNBQTBFLEVBQUU7UUFDdEksTUFBTSxJQUFJLEdBQUcsS0FBSyxDQUFDLFdBQVcsSUFBSSxLQUFLLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQztRQUN2RixNQUFNLEtBQUssR0FBRyxLQUFLLENBQUMsV0FBVyxJQUFJLEtBQUssQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsV0FBVyxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDO1FBQ3RHLE1BQU0sUUFBUSxHQUFHLEtBQUssQ0FBQyxXQUFXLElBQUksS0FBSyxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUM7UUFFdkcsSUFBSSxJQUFJLElBQUksS0FBSyxFQUFFLENBQUM7WUFDbEIsSUFBSSxHQUFHLEtBQUssRUFBRSxFQUFFLENBQUM7Z0JBQ2YsV0FBVyxDQUFDLElBQUksQ0FBQztvQkFDZixLQUFLLEVBQUUsS0FBSztvQkFDWixVQUFVLEVBQUUsSUFBSSxJQUFJLEVBQUU7b0JBQ3RCLFFBQVEsRUFBRSxDQUFDLFFBQVEsS0FBSyxLQUFLLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDO2lCQUM5QyxDQUFDLENBQUM7WUFDTCxDQUFDO2lCQUFNLENBQUM7Z0JBQ04sV0FBVyxDQUFDLElBQUksQ0FBQztvQkFDZixLQUFLLEVBQUUsS0FBSztvQkFDWixVQUFVLEVBQUUsR0FBRyxHQUFHLElBQUksSUFBSSxFQUFFO29CQUM1QixRQUFRLEVBQUUsQ0FBQyxRQUFRLEtBQUssS0FBSyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQztpQkFDOUMsQ0FBQyxDQUFDO1lBQ0wsQ0FBQztRQUNILENBQUM7UUFFRCxNQUFNLFNBQVMsR0FBRyxLQUFLLENBQUMsVUFBVSxDQUFDO1FBQ25DLElBQUksU0FBUyxFQUFFLENBQUM7WUFDZCxJQUFJLEdBQUcsS0FBSyxFQUFFLEVBQUUsQ0FBQztnQkFDZixPQUFPLElBQUksQ0FBQyxVQUFVLENBQUMsU0FBUyxFQUFFLElBQUksRUFBRSxXQUFXLENBQUMsQ0FBQztZQUN2RCxDQUFDO2lCQUFNLENBQUM7Z0JBQ04sT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDLFNBQVMsRUFBRSxHQUFHLEdBQUcsSUFBSSxJQUFJLEVBQUUsRUFBRSxXQUFXLENBQUMsQ0FBQztZQUNuRSxDQUFDO1FBQ0gsQ0FBQztRQUVELE9BQU8sV0FBVyxDQUFDO0lBQ3JCLENBQUM7OEdBNUNVLGtCQUFrQjtrSEFBbEIsa0JBQWtCLGNBRmpCLE1BQU07OzJGQUVQLGtCQUFrQjtrQkFIOUIsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5pbXBvcnQge1xyXG4gIEFjdGl2YXRlZFJvdXRlLFxyXG4gIE5hdmlnYXRpb25FbmQsXHJcbiAgUm91dGVyXHJcbn0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcclxuXHJcbmltcG9ydCB7IGZpbHRlciB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcclxuaW1wb3J0IHsgQmVoYXZpb3JTdWJqZWN0IH0gZnJvbSAncnhqcyc7XHJcblxyXG5ASW5qZWN0YWJsZSh7XHJcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgQnJlYWRjcnVtYnNTZXJ2aWNlIHtcclxuICBwcml2YXRlIGJyZWFkY3J1bWJzU3ViamVjdCA9IG5ldyBCZWhhdmlvclN1YmplY3Q8eyBsYWJlbDogc3RyaW5nOyByb3V0ZXJMaW5rOiBzdHJpbmcsIHNob3dNZW51OiBib29sZWFuIH1bXT4oW10pO1xyXG4gIGJyZWFkY3J1bWJzJCA9IHRoaXMuYnJlYWRjcnVtYnNTdWJqZWN0LmFzT2JzZXJ2YWJsZSgpO1xyXG5cclxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJvdXRlcjogUm91dGVyLCBwcml2YXRlIGFjdGl2YXRlZFJvdXRlOiBBY3RpdmF0ZWRSb3V0ZSkge1xyXG4gICAgdGhpcy5yb3V0ZXIuZXZlbnRzXHJcbiAgICAgIC5waXBlKGZpbHRlcigoZXZlbnQpID0+IGV2ZW50IGluc3RhbmNlb2YgTmF2aWdhdGlvbkVuZCkpXHJcbiAgICAgIC5zdWJzY3JpYmUoKCkgPT4ge1xyXG4gICAgICAgIGNvbnN0IGJyZWFkY3J1bWJzID0gdGhpcy5wYXJzZVJvdXRlKHRoaXMucm91dGVyLnJvdXRlclN0YXRlLnJvb3QpO1xyXG4gICAgICAgIHRoaXMuYnJlYWRjcnVtYnNTdWJqZWN0Lm5leHQoYnJlYWRjcnVtYnMpO1xyXG4gICAgICB9KTtcclxuICB9XHJcblxyXG4gIHByaXZhdGUgcGFyc2VSb3V0ZShyb3V0ZTogQWN0aXZhdGVkUm91dGUsIHVybDogc3RyaW5nID0gJycsIGJyZWFkY3J1bWJzOiB7IGxhYmVsOiBzdHJpbmc7IHJvdXRlckxpbms6IHN0cmluZywgc2hvd01lbnU6IGJvb2xlYW4gfVtdID0gW10pOiB7IGxhYmVsOiBzdHJpbmc7IHJvdXRlckxpbms6IHN0cmluZywgc2hvd01lbnU6IGJvb2xlYW4gfVtdIHtcclxuICAgIGNvbnN0IHBhdGggPSByb3V0ZS5yb3V0ZUNvbmZpZyAmJiByb3V0ZS5yb3V0ZUNvbmZpZy5wYXRoID8gcm91dGUucm91dGVDb25maWcucGF0aCA6ICcnO1xyXG4gICAgY29uc3QgbGFiZWwgPSByb3V0ZS5yb3V0ZUNvbmZpZyAmJiByb3V0ZS5yb3V0ZUNvbmZpZy5kYXRhID8gcm91dGUucm91dGVDb25maWcuZGF0YVsnYnJlYWRjcnVtYiddIDogJyc7XHJcbiAgICBjb25zdCBzaG93bWVudSA9IHJvdXRlLnJvdXRlQ29uZmlnICYmIHJvdXRlLnJvdXRlQ29uZmlnLmRhdGEgPyByb3V0ZS5yb3V0ZUNvbmZpZy5kYXRhWydzaG93bWVudSddIDogJyc7XHJcblxyXG4gICAgaWYgKHBhdGggJiYgbGFiZWwpIHtcclxuICAgICAgaWYgKHVybCA9PT0gJycpIHtcclxuICAgICAgICBicmVhZGNydW1icy5wdXNoKHtcclxuICAgICAgICAgIGxhYmVsOiBsYWJlbCxcclxuICAgICAgICAgIHJvdXRlckxpbms6IGAvJHtwYXRofWAsXHJcbiAgICAgICAgICBzaG93TWVudTogKHNob3dtZW51ID09PSBmYWxzZSA/IGZhbHNlIDogdHJ1ZSlcclxuICAgICAgICB9KTtcclxuICAgICAgfSBlbHNlIHtcclxuICAgICAgICBicmVhZGNydW1icy5wdXNoKHtcclxuICAgICAgICAgIGxhYmVsOiBsYWJlbCxcclxuICAgICAgICAgIHJvdXRlckxpbms6IGAke3VybH0vJHtwYXRofWAsXHJcbiAgICAgICAgICBzaG93TWVudTogKHNob3dtZW51ID09PSBmYWxzZSA/IGZhbHNlIDogdHJ1ZSlcclxuICAgICAgICB9KTtcclxuICAgICAgfVxyXG4gICAgfVxyXG5cclxuICAgIGNvbnN0IG5leHRSb3V0ZSA9IHJvdXRlLmZpcnN0Q2hpbGQ7XHJcbiAgICBpZiAobmV4dFJvdXRlKSB7XHJcbiAgICAgIGlmICh1cmwgPT09ICcnKSB7XHJcbiAgICAgICAgcmV0dXJuIHRoaXMucGFyc2VSb3V0ZShuZXh0Um91dGUsIHBhdGgsIGJyZWFkY3J1bWJzKTtcclxuICAgICAgfSBlbHNlIHtcclxuICAgICAgICByZXR1cm4gdGhpcy5wYXJzZVJvdXRlKG5leHRSb3V0ZSwgYCR7dXJsfS8ke3BhdGh9YCwgYnJlYWRjcnVtYnMpO1xyXG4gICAgICB9XHJcbiAgICB9XHJcblxyXG4gICAgcmV0dXJuIGJyZWFkY3J1bWJzO1xyXG4gIH1cclxufSJdfQ==
73
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnJlYWRjcnVtYnMuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tlZXZvLWNvbXBvbmVudHMvc3JjL2xpYi9hcGkvc2VydmljZXMvYnJlYWRjcnVtYnMuc2VydmljZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTNDLE9BQU8sRUFFTCxhQUFhLEVBRWQsTUFBTSxpQkFBaUIsQ0FBQztBQUV6QixPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDeEMsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLE1BQU0sQ0FBQzs7O0FBTXZDLE1BQU0sT0FBTyxrQkFBa0I7SUFJN0IsWUFBb0IsTUFBYyxFQUFVLGNBQThCO1FBQXRELFdBQU0sR0FBTixNQUFNLENBQVE7UUFBVSxtQkFBYyxHQUFkLGNBQWMsQ0FBZ0I7UUFIbEUsdUJBQWtCLEdBQUcsSUFBSSxlQUFlLENBQXFCLEVBQUUsQ0FBQyxDQUFDO1FBQ3pFLGlCQUFZLEdBQUcsSUFBSSxDQUFDLGtCQUFrQixDQUFDLFlBQVksRUFBRSxDQUFDO1FBR3BELElBQUksQ0FBQyxNQUFNLENBQUMsTUFBTTthQUNmLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLEtBQUssWUFBWSxhQUFhLENBQUMsQ0FBQzthQUN2RCxTQUFTLENBQUMsR0FBRyxFQUFFO1lBQ2QsTUFBTSxXQUFXLEdBQUcsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsQ0FBQztZQUNsRSxJQUFJLENBQUMsa0JBQWtCLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxDQUFDO1FBQzVDLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVPLFVBQVUsQ0FBQyxLQUFxQixFQUFFLE1BQWMsRUFBRSxF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QkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG5pbXBvcnQge1xyXG4gIEFjdGl2YXRlZFJvdXRlLFxyXG4gIE5hdmlnYXRpb25FbmQsXHJcbiAgUm91dGVyXHJcbn0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcclxuXHJcbmltcG9ydCB7IGZpbHRlciB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcclxuaW1wb3J0IHsgQmVoYXZpb3JTdWJqZWN0IH0gZnJvbSAncnhqcyc7XHJcbmltcG9ydCB7IEJyZWFkQ3J1bWJPcHRpb24gfSBmcm9tICcuLi90eXBlcy9icmVhZGNydW1iLm1vZGVsJztcclxuXHJcbkBJbmplY3RhYmxlKHtcclxuICBwcm92aWRlZEluOiAncm9vdCcsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBCcmVhZGNydW1ic1NlcnZpY2Uge1xyXG4gIHByaXZhdGUgYnJlYWRjcnVtYnNTdWJqZWN0ID0gbmV3IEJlaGF2aW9yU3ViamVjdDxCcmVhZENydW1iT3B0aW9uW10+KFtdKTtcclxuICBicmVhZGNydW1icyQgPSB0aGlzLmJyZWFkY3J1bWJzU3ViamVjdC5hc09ic2VydmFibGUoKTtcclxuXHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSByb3V0ZXI6IFJvdXRlciwgcHJpdmF0ZSBhY3RpdmF0ZWRSb3V0ZTogQWN0aXZhdGVkUm91dGUpIHtcclxuICAgIHRoaXMucm91dGVyLmV2ZW50c1xyXG4gICAgICAucGlwZShmaWx0ZXIoKGV2ZW50KSA9PiBldmVudCBpbnN0YW5jZW9mIE5hdmlnYXRpb25FbmQpKVxyXG4gICAgICAuc3Vic2NyaWJlKCgpID0+IHtcclxuICAgICAgICBjb25zdCBicmVhZGNydW1icyA9IHRoaXMucGFyc2VSb3V0ZSh0aGlzLnJvdXRlci5yb3V0ZXJTdGF0ZS5yb290KTtcclxuICAgICAgICB0aGlzLmJyZWFkY3J1bWJzU3ViamVjdC5uZXh0KGJyZWFkY3J1bWJzKTtcclxuICAgICAgfSk7XHJcbiAgfVxyXG5cclxuICBwcml2YXRlIHBhcnNlUm91dGUocm91dGU6IEFjdGl2YXRlZFJvdXRlLCB1cmw6IHN0cmluZyA9ICcnLCBicmVhZGNydW1iczogQnJlYWRDcnVtYk9wdGlvbltdID0gW10pOiBCcmVhZENydW1iT3B0aW9uW10ge1xyXG4gICAgY29uc3QgcGF0aCA9IHJvdXRlLnJvdXRlQ29uZmlnICYmIHJvdXRlLnJvdXRlQ29uZmlnLnBhdGggPyByb3V0ZS5yb3V0ZUNvbmZpZy5wYXRoIDogJyc7XHJcbiAgICBjb25zdCBsYWJlbCA9IHJvdXRlLnJvdXRlQ29uZmlnICYmIHJvdXRlLnJvdXRlQ29uZmlnLmRhdGEgPyByb3V0ZS5yb3V0ZUNvbmZpZy5kYXRhWydicmVhZGNydW1iJ10gOiAnJztcclxuICAgIGNvbnN0IHNob3dtZW51ID0gcm91dGUucm91dGVDb25maWcgJiYgcm91dGUucm91dGVDb25maWcuZGF0YSA/IHJvdXRlLnJvdXRlQ29uZmlnLmRhdGFbJ3Nob3dtZW51J10gOiAnJztcclxuXHJcbiAgICBpZiAocGF0aCAmJiBsYWJlbCkge1xyXG4gICAgICBpZiAodXJsID09PSAnJykge1xyXG4gICAgICAgIGJyZWFkY3J1bWJzLnB1c2goe1xyXG4gICAgICAgICAgbGFiZWw6IGxhYmVsLFxyXG4gICAgICAgICAgcm91dGVyTGluazogYC8ke3BhdGh9YCxcclxuICAgICAgICAgIHNob3dNZW51OiAoc2hvd21lbnUgPT09IGZhbHNlID8gZmFsc2UgOiB0cnVlKVxyXG4gICAgICAgIH0pO1xyXG4gICAgICB9IGVsc2Uge1xyXG4gICAgICAgIGJyZWFkY3J1bWJzLnB1c2goe1xyXG4gICAgICAgICAgbGFiZWw6IGxhYmVsLFxyXG4gICAgICAgICAgcm91dGVyTGluazogYCR7dXJsfS8ke3BhdGh9YCxcclxuICAgICAgICAgIHNob3dNZW51OiAoc2hvd21lbnUgPT09IGZhbHNlID8gZmFsc2UgOiB0cnVlKVxyXG4gICAgICAgIH0pO1xyXG4gICAgICB9XHJcbiAgICB9XHJcblxyXG4gICAgY29uc3QgbmV4dFJvdXRlID0gcm91dGUuZmlyc3RDaGlsZDtcclxuICAgIGlmIChuZXh0Um91dGUpIHtcclxuICAgICAgaWYgKHVybCA9PT0gJycpIHtcclxuICAgICAgICByZXR1cm4gdGhpcy5wYXJzZVJvdXRlKG5leHRSb3V0ZSwgcGF0aCwgYnJlYWRjcnVtYnMpO1xyXG4gICAgICB9IGVsc2Uge1xyXG4gICAgICAgIHJldHVybiB0aGlzLnBhcnNlUm91dGUobmV4dFJvdXRlLCBgJHt1cmx9LyR7cGF0aH1gLCBicmVhZGNydW1icyk7XHJcbiAgICAgIH1cclxuICAgIH1cclxuXHJcbiAgICByZXR1cm4gYnJlYWRjcnVtYnM7XHJcbiAgfVxyXG5cclxuICBnZXRCcmVhZENydW1icygpOiBCcmVhZENydW1iT3B0aW9uW10ge1xyXG4gICAgcmV0dXJuIHRoaXMuYnJlYWRjcnVtYnNTdWJqZWN0LnZhbHVlO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIGNoYW5nZUJyZWFkQ3J1bWIoYnJlYWRDcnVtYnM6IEJyZWFkQ3J1bWJPcHRpb25bXSkge1xyXG4gICAgdGhpcy5icmVhZGNydW1ic1N1YmplY3QubmV4dChicmVhZENydW1icyk7XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgY2hhbmdlTGFzdEJyZWFkQ3J1bWIoY2FsbGJhY2s6IChicmVhZENydW1iOiBCcmVhZENydW1iT3B0aW9uIHwgdW5kZWZpbmVkKSA9PiBCcmVhZENydW1iT3B0aW9ufHVuZGVmaW5lZCkge1xyXG4gICAgY29uc3QgYnJlYWRDcnVtYnMgPSB0aGlzLmJyZWFkY3J1bWJzU3ViamVjdC52YWx1ZS5tYXAoeCA9PiAoeyAuLi54IH0pKTtcclxuXHJcbiAgICBjb25zdCBsYXN0QnJlYWRDcnVtYiA9IGJyZWFkQ3J1bWJzLnBvcCgpO1xyXG4gICAgY29uc3QgbmV3QnJlYWRDcnVtYiA9IGNhbGxiYWNrKGxhc3RCcmVhZENydW1iKTtcclxuICAgIFxyXG4gICAgaWYobmV3QnJlYWRDcnVtYilcclxuICAgICAgdGhpcy5icmVhZGNydW1ic1N1YmplY3QubmV4dChbLi4uYnJlYWRDcnVtYnMsIG5ld0JyZWFkQ3J1bWJdKTtcclxuICB9XHJcbn0iXX0=
@@ -69,6 +69,7 @@ export class FormService {
69
69
  if (data)
70
70
  callBackFunction(data);
71
71
  });
72
+ return ref;
72
73
  }
73
74
  static setControlValue(formGroup, controName, value) {
74
75
  formGroup?.controls[controName]?.setValue(value);
@@ -89,4 +90,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
89
90
  providedIn: 'root',
90
91
  }]
91
92
  }] });
92
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.service.js","sourceRoot":"","sources":["../../../../../../projects/keevo-components/src/lib/api/services/form.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Type } from '@angular/core';\r\n\r\nimport { FormGroup, ValidatorFn } from '@angular/forms';\r\n\r\nimport { ObjectService } from './object.service';\r\nimport { DialogService } from 'primeng/dynamicdialog';\r\n\r\nexport interface paramsDialog {\r\n  id?: any;\r\n  maximizable?: boolean;\r\n  popup?: boolean;\r\n  height?: string;\r\n  width?: string;\r\n  styleClass?: string;\r\n  header?: string;\r\n\r\n  /**\r\n   * @deprecated Essa propriedade sempre será false. Não é necessário atribuir valor para ela\r\n   */\r\n  closable?: boolean;\r\n}\r\n\r\n@Injectable({\r\n  providedIn: 'root',\r\n})\r\nexport class FormService {\r\n  static disableControl(formGroup: FormGroup, controName: string) {\r\n    formGroup?.controls[controName]?.disable();\r\n  }\r\n\r\n  static disableAndClearControl(\r\n    formGroup: FormGroup,\r\n    controName: string,\r\n    value?: any\r\n  ) {\r\n    this.disableControl(formGroup, controName);\r\n    this.setControlValue(formGroup, controName, null || value);\r\n  }\r\n\r\n  static enableControl(formGroup: FormGroup, controName: string) {\r\n    formGroup?.controls[controName]?.enable();\r\n  }\r\n\r\n  static getFormValue<T>(formGroup: FormGroup, controName: string): T {\r\n    return <T>formGroup?.controls[controName]?.value;\r\n  }\r\n\r\n  static hasControlError(\r\n    formGroup: FormGroup,\r\n    control: string,\r\n    errorCode?: string\r\n  ): boolean {\r\n    const formControl = formGroup.get(control);\r\n    let hasError: boolean = false;\r\n\r\n    if (!formControl) return false;\r\n    if (errorCode) hasError = formControl.hasError(errorCode);\r\n    else hasError = formControl.errors ? true : false;\r\n\r\n    return hasError && formControl.touched;\r\n  }\r\n\r\n  static invalidForm(formGroup: FormGroup, notification?: any) {\r\n    const keys = Object.keys(formGroup.getRawValue());\r\n\r\n    keys.forEach((k) => {\r\n      const control = formGroup.controls[k];\r\n\r\n      if (notification) {\r\n        if (notification?.item2) {\r\n          const item = ObjectService.findObject(\r\n            notification.item2,\r\n            'property',\r\n            k\r\n          );\r\n          if (item)\r\n            control.setErrors({\r\n              backendError: true,\r\n              erroMessage: item.message,\r\n            });\r\n        } else {\r\n          const item = ObjectService.findObject(notification, 'key', k);\r\n          if (item)\r\n            control.setErrors({\r\n              backendError: true,\r\n              erroMessage: item.message,\r\n            });\r\n        }\r\n      }\r\n\r\n      if (!control.valid) {\r\n        control.markAsTouched();\r\n      }\r\n    });\r\n  }\r\n\r\n  static openDialog(\r\n    dialogService: DialogService,\r\n    componentType: Type<any>,\r\n    callBackFunction: Function,\r\n    paramsDialog?: paramsDialog\r\n  ) {\r\n    const ref = dialogService.open(componentType, {\r\n      closable: false,\r\n      maximizable: paramsDialog?.maximizable || false,\r\n      height: paramsDialog?.height || 'auto',\r\n      width: paramsDialog?.width,\r\n      styleClass: paramsDialog?.styleClass,\r\n      showHeader: true,\r\n      header: paramsDialog?.header,\r\n      data: { id: paramsDialog?.id, popup: paramsDialog?.popup && true },\r\n      closeOnEscape: false,\r\n    });\r\n\r\n    ref.onClose.subscribe((data: any) => {\r\n      if (data) callBackFunction(data);\r\n    });\r\n  }\r\n\r\n  static setControlValue(formGroup: FormGroup, controName: string, value: any) {\r\n    formGroup?.controls[controName]?.setValue(value);\r\n  }\r\n\r\n  static setValidators(\r\n    formGroup: FormGroup,\r\n    controName: string,\r\n    validators: ValidatorFn | ValidatorFn[] | null\r\n  ) {\r\n    formGroup?.controls[controName]?.setValidators(validators);\r\n    formGroup?.controls[controName]?.updateValueAndValidity();\r\n  }\r\n\r\n  static clearValidators(formGroup: FormGroup, controName: string) {\r\n    formGroup?.controls[controName]?.updateValueAndValidity();\r\n  }\r\n}\r\n"]}
93
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.service.js","sourceRoot":"","sources":["../../../../../../projects/keevo-components/src/lib/api/services/form.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Type } from '@angular/core';\r\n\r\nimport { FormGroup, ValidatorFn } from '@angular/forms';\r\n\r\nimport { ObjectService } from './object.service';\r\nimport { DialogService } from 'primeng/dynamicdialog';\r\n\r\nexport interface paramsDialog {\r\n  id?: any;\r\n  maximizable?: boolean;\r\n  popup?: boolean;\r\n  height?: string;\r\n  width?: string;\r\n  styleClass?: string;\r\n  header?: string;\r\n\r\n  /**\r\n   * @deprecated Essa propriedade sempre será false. Não é necessário atribuir valor para ela\r\n   */\r\n  closable?: boolean;\r\n}\r\n\r\n@Injectable({\r\n  providedIn: 'root',\r\n})\r\nexport class FormService {\r\n  static disableControl(formGroup: FormGroup, controName: string) {\r\n    formGroup?.controls[controName]?.disable();\r\n  }\r\n\r\n  static disableAndClearControl(\r\n    formGroup: FormGroup,\r\n    controName: string,\r\n    value?: any\r\n  ) {\r\n    this.disableControl(formGroup, controName);\r\n    this.setControlValue(formGroup, controName, null || value);\r\n  }\r\n\r\n  static enableControl(formGroup: FormGroup, controName: string) {\r\n    formGroup?.controls[controName]?.enable();\r\n  }\r\n\r\n  static getFormValue<T>(formGroup: FormGroup, controName: string): T {\r\n    return <T>formGroup?.controls[controName]?.value;\r\n  }\r\n\r\n  static hasControlError(\r\n    formGroup: FormGroup,\r\n    control: string,\r\n    errorCode?: string\r\n  ): boolean {\r\n    const formControl = formGroup.get(control);\r\n    let hasError: boolean = false;\r\n\r\n    if (!formControl) return false;\r\n    if (errorCode) hasError = formControl.hasError(errorCode);\r\n    else hasError = formControl.errors ? true : false;\r\n\r\n    return hasError && formControl.touched;\r\n  }\r\n\r\n  static invalidForm(formGroup: FormGroup, notification?: any) {\r\n    const keys = Object.keys(formGroup.getRawValue());\r\n\r\n    keys.forEach((k) => {\r\n      const control = formGroup.controls[k];\r\n\r\n      if (notification) {\r\n        if (notification?.item2) {\r\n          const item = ObjectService.findObject(\r\n            notification.item2,\r\n            'property',\r\n            k\r\n          );\r\n          if (item)\r\n            control.setErrors({\r\n              backendError: true,\r\n              erroMessage: item.message,\r\n            });\r\n        } else {\r\n          const item = ObjectService.findObject(notification, 'key', k);\r\n          if (item)\r\n            control.setErrors({\r\n              backendError: true,\r\n              erroMessage: item.message,\r\n            });\r\n        }\r\n      }\r\n\r\n      if (!control.valid) {\r\n        control.markAsTouched();\r\n      }\r\n    });\r\n  }\r\n\r\n  static openDialog(\r\n    dialogService: DialogService,\r\n    componentType: Type<any>,\r\n    callBackFunction: Function,\r\n    paramsDialog?: paramsDialog\r\n  ) {\r\n    const ref = dialogService.open(componentType, {\r\n      closable: false,\r\n      maximizable: paramsDialog?.maximizable || false,\r\n      height: paramsDialog?.height || 'auto',\r\n      width: paramsDialog?.width,\r\n      styleClass: paramsDialog?.styleClass,\r\n      showHeader: true,\r\n      header: paramsDialog?.header,\r\n      data: { id: paramsDialog?.id, popup: paramsDialog?.popup && true },\r\n      closeOnEscape: false,\r\n    });\r\n\r\n    ref.onClose.subscribe((data: any) => {\r\n      if (data) callBackFunction(data);\r\n    });\r\n    return ref;\r\n  }\r\n\r\n  static setControlValue(formGroup: FormGroup, controName: string, value: any) {\r\n    formGroup?.controls[controName]?.setValue(value);\r\n  }\r\n\r\n  static setValidators(\r\n    formGroup: FormGroup,\r\n    controName: string,\r\n    validators: ValidatorFn | ValidatorFn[] | null\r\n  ) {\r\n    formGroup?.controls[controName]?.setValidators(validators);\r\n    formGroup?.controls[controName]?.updateValueAndValidity();\r\n  }\r\n\r\n  static clearValidators(formGroup: FormGroup, controName: string) {\r\n    formGroup?.controls[controName]?.updateValueAndValidity();\r\n  }\r\n}\r\n"]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnJlYWRjcnVtYi5tb2RlbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tlZXZvLWNvbXBvbmVudHMvc3JjL2xpYi9hcGkvdHlwZXMvYnJlYWRjcnVtYi5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBCcmVhZENydW1iT3B0aW9uIHtcclxuICBsYWJlbDogc3RyaW5nO1xyXG4gIHJvdXRlckxpbms6IHN0cmluZztcclxuICBzaG93TWVudTogYm9vbGVhbjtcclxufSJdfQ==
@@ -1,16 +1,18 @@
1
1
  import { Component, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
2
+ import { BaseComponentCrud } from 'projects/keevo-components/src/public-api';
2
3
  import * as i0 from "@angular/core";
3
4
  import * as i1 from "../../api/services/imagens.service";
4
5
  import * as i2 from "../../api/services/notification.service";
5
- import * as i3 from "@angular/common";
6
- import * as i4 from "primeng/slider";
7
- import * as i5 from "@angular/forms";
8
- import * as i6 from "../kv-button/kv-button.component";
9
- import * as i7 from "../kv-label/kv-label.component";
10
- export class KvAvatarComponent {
11
- constructor(imageService, notificationService) {
6
+ import * as i3 from "primeng/dynamicdialog";
7
+ import * as i4 from "@angular/common";
8
+ // import { KvCropImageComponent } from './kv-crop-image/kv-crop-image.component';
9
+ export class KvAvatarComponent extends BaseComponentCrud {
10
+ constructor(imageService, notificationService, dialogService, dynamicDialogRef) {
11
+ super(dialogService, notificationService);
12
12
  this.imageService = imageService;
13
13
  this.notificationService = notificationService;
14
+ this.dialogService = dialogService;
15
+ this.dynamicDialogRef = dynamicDialogRef;
14
16
  this.borderColor = '#002542';
15
17
  this.btnsColor = '#002542';
16
18
  this.width = 135;
@@ -18,16 +20,8 @@ export class KvAvatarComponent {
18
20
  this.imageUrlChange = new EventEmitter();
19
21
  this.removerFotoEvent = new EventEmitter();
20
22
  this.onModalOpen = new EventEmitter();
21
- this.existeLogo = false;
22
23
  this.btnAlterarFoto = false;
23
- this.showCropModal = false;
24
- this.imageLoaded = false;
25
- this.imageX = 0;
26
- this.imageY = 0;
27
- this.startX = 0;
28
- this.startY = 0;
29
- this.valueZoom = 50;
30
- this.scaleFactor = 1;
24
+ this.existeLogo = false;
31
25
  this.selectedImage = '';
32
26
  }
33
27
  getImageSrc() {
@@ -58,7 +52,7 @@ export class KvAvatarComponent {
58
52
  reader.onload = () => {
59
53
  this.selectedImage = reader.result;
60
54
  this.existeLogo = true;
61
- this.openCropModal();
55
+ // this.abrirModalRecortarFoto();
62
56
  };
63
57
  }
64
58
  }
@@ -84,121 +78,44 @@ export class KvAvatarComponent {
84
78
  handleImageError(event) {
85
79
  event.target.src = this.imageService.userDefaultImage();
86
80
  }
87
- openCropModal() {
88
- this.onModalOpen.emit();
89
- this.showCropModal = true;
90
- setTimeout(() => {
91
- const canvas = this.cropCanvas.nativeElement;
92
- const ctx = canvas.getContext('2d');
93
- const img = new Image();
94
- img.src = this.selectedImage;
95
- img.onload = () => {
96
- this.imageLoaded = true;
97
- this.imageX = (canvas.width - img.width * this.scaleFactor) / 2;
98
- this.imageY = (canvas.height - img.height * this.scaleFactor) / 2;
99
- canvas.width = 500;
100
- canvas.height = 500;
101
- ctx?.clearRect(0, 0, canvas.width, canvas.height);
102
- ctx?.drawImage(img, this.imageX, this.imageY, img.width * this.scaleFactor, img.height * this.scaleFactor);
103
- this.drawCropArea(ctx);
104
- this.initializeImageMove(canvas, ctx, img);
105
- this.initializeMouseWheel(canvas, ctx, img);
106
- };
107
- }, 0);
108
- }
109
- drawCropArea(ctx) {
110
- if (ctx) {
111
- const centerX = ctx.canvas.width / 2;
112
- const centerY = ctx.canvas.height / 2;
113
- const radius = 100; // Raio da área de recorte
114
- ctx.beginPath();
115
- ctx.arc(centerX, centerY, radius, 0, Math.PI * 2, true);
116
- ctx.strokeStyle = 'transparent';
117
- ctx.lineWidth = 2;
118
- ctx.stroke();
119
- ctx.closePath();
120
- }
121
- }
122
- initializeImageMove(canvas, ctx, img) {
123
- let isDragging = false;
124
- canvas.style.cursor = 'grab';
125
- canvas.onmousedown = (e) => {
126
- isDragging = true;
127
- canvas.style.cursor = 'grabbing';
128
- this.startX = e.offsetX - this.imageX;
129
- this.startY = e.offsetY - this.imageY;
130
- };
131
- canvas.onmousemove = (e) => {
132
- if (isDragging) {
133
- this.imageX = e.offsetX - this.startX;
134
- this.imageY = e.offsetY - this.startY;
135
- ctx?.clearRect(0, 0, canvas.width, canvas.height);
136
- ctx?.drawImage(img, this.imageX, this.imageY, img.width * this.scaleFactor, img.height * this.scaleFactor);
137
- this.drawCropArea(ctx);
138
- }
139
- };
140
- canvas.onmouseup = () => {
141
- isDragging = false;
142
- canvas.style.cursor = 'grab';
143
- };
144
- canvas.onmouseout = () => {
145
- isDragging = false;
146
- canvas.style.cursor = 'grab';
147
- };
81
+ // abrirModalRecortarFoto() {
82
+ // this.openDialog(
83
+ // KvCropImageComponent,
84
+ // () => {
85
+ // this.imageUrl = this.receberDados();
86
+ // this.imageUrlChange.emit(this.imageUrl);
87
+ // },
88
+ // {
89
+ // maximizable: false,
90
+ // popup: true,
91
+ // width: '60%',
92
+ // header: 'Recortar',
93
+ // id:{imagemSelecionada: this.selectedImage, imagemCortada: ''}
94
+ // }
95
+ // )
96
+ // const arr: Map<DynamicDialogRef<any>, ComponentRef<any>> = this.dialogService.dialogComponentRefMap
97
+ // const entries = arr.entries();
98
+ // const firstEntry = entries.next().value;
99
+ // const [firstKey, firstValue] = firstEntry;
100
+ // const instance = this.dialogService.getInstance(firstKey)
101
+ // instance.config.showHeader = false
102
+ // instance.config.contentStyle = {'border-radius': '12px'}
103
+ // }
104
+ receberDados() {
105
+ const arr = this.dialogService.dialogComponentRefMap;
106
+ const entries = arr.entries();
107
+ const firstEntry = entries.next().value;
108
+ const [firstKey, firstValue] = firstEntry;
109
+ const instance = this.dialogService.getInstance(firstKey);
110
+ return instance.config.data.id.imagemCortada;
148
111
  }
149
- initializeMouseWheel(canvas, ctx, img) {
150
- canvas.onwheel = (e) => {
151
- e.preventDefault();
152
- const delta = e.deltaY > 0 ? -0.1 : 0.1;
153
- this.scaleFactor = Math.min(Math.max(this.scaleFactor + delta, 0.1), 5); // limita o fator de escala entre 0.1 e 5
154
- ctx?.clearRect(0, 0, canvas.width, canvas.height);
155
- ctx?.drawImage(img, this.imageX, this.imageY, img.width * this.scaleFactor, img.height * this.scaleFactor);
156
- this.drawCropArea(ctx);
157
- this.valueZoom = this.scaleFactor * 50;
158
- };
159
- }
160
- cropImage() {
161
- const canvas = this.cropCanvas.nativeElement;
162
- const ctx = canvas.getContext('2d');
163
- if (ctx) {
164
- const centerX = canvas.width / 2;
165
- const centerY = canvas.height / 2;
166
- const radius = 100;
167
- const imageData = ctx.getImageData(centerX - radius, centerY - radius, radius * 2, radius * 2);
168
- const newCanvas = document.createElement('canvas');
169
- const newCtx = newCanvas.getContext('2d');
170
- newCanvas.width = radius * 2;
171
- newCanvas.height = radius * 2;
172
- newCtx?.putImageData(imageData, 0, 0);
173
- this.imageUrl = newCanvas.toDataURL();
174
- this.imageUrlChange.emit(this.imageUrl);
175
- this.closeCropModal();
176
- }
177
- }
178
- onZoomChange(event) {
179
- const canvas = this.cropCanvas.nativeElement;
180
- const ctx = canvas.getContext('2d');
181
- const img = new Image();
182
- img.src = this.selectedImage;
183
- img.onload = () => {
184
- ctx?.clearRect(0, 0, canvas.width, canvas.height);
185
- this.scaleFactor = event.value / 50;
186
- ctx?.drawImage(img, this.imageX, this.imageY, img.width * this.scaleFactor, img.height * this.scaleFactor);
187
- this.drawCropArea(ctx);
188
- };
189
- }
190
- closeCropModal() {
191
- this.showCropModal = false;
192
- this.valueZoom = 50;
193
- this.imageLoaded = false;
194
- }
195
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvAvatarComponent, deps: [{ token: i1.ImagensService }, { token: i2.NotificationService }], target: i0.ɵɵFactoryTarget.Component }); }
196
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.8", type: KvAvatarComponent, selector: "kv-avatar", inputs: { imageUrl: "imageUrl", borderColor: "borderColor", btnsColor: "btnsColor", width: "width", height: "height", btnAlterarFoto: "btnAlterarFoto" }, outputs: { imageUrlChange: "imageUrlChange", removerFotoEvent: "removerFotoEvent", onModalOpen: "onModalOpen" }, viewQueries: [{ propertyName: "cropCanvas", first: true, predicate: ["cropCanvas"], descendants: true }, { propertyName: "fileInput", first: true, predicate: ["fileInput"], descendants: true }], ngImport: i0, template: "<div class=\"image-container\">\r\n <img [src]=\"getImageSrc() || imageService.userDefaultImage()\" alt=\"Foto\" class=\"container-foto\" [style.border-color]=\"borderColor\" [style.width.px]=\"width\" [style.height.px]=\"height\" (error)=\"handleImageError($event)\" (click)=\"openFile()\">\r\n <div class=\"btn\">\r\n <input #fileInput *ngIf=\"btnAlterarFoto\" id=\"fotoEscolhida\" type=\"file\" accept=\"image/*\" style=\"display:none\" (change)=\"selectFotoSelecionada($any($event))\">\r\n <button *ngIf=\"btnAlterarFoto && !existeLogo\" class=\"botao-alterar-foto border-circle\" [style.background-color]=\"btnsColor\" (click)=\"openFile()\">\r\n <i class=\"material-symbols-outlined\">photo_camera</i>\r\n </button>\r\n \r\n <button *ngIf=\"btnAlterarFoto && existeLogo\" [style.background-color]=\"btnsColor\" class=\"botao-excluir-foto border-circle\" (click)=\"questionRemoverFoto()\">\r\n <i class=\"material-symbols-outlined\">delete</i>\r\n </button>\r\n </div>\r\n</div>\r\n\r\n<div *ngIf=\"showCropModal\" class=\"modal\">\r\n <div class=\"modal-content\">\r\n <div class=\"crop-container\">\r\n <canvas #cropCanvas class=\"crop-canvas\"></canvas>\r\n <div class=\"crop-border\"></div>\r\n </div>\r\n\r\n <div class=\"w-full mt-2\">\r\n <kv-label label=\"Zoom\" style=\"text-align: left;\"/>\r\n <p-slider [(ngModel)]=\"valueZoom\" (onChange)=\"onZoomChange($event)\"></p-slider>\r\n </div>\r\n \r\n <div class=\"button-container\"> \r\n <kv-button label=\"Cancelar\" severity=\"tertiary\" icon=\"close\" (click)=\"closeCropModal()\"></kv-button>\r\n <kv-button label=\"Recortar\" severity=\"primary\" icon=\"crop\" (click)=\"cropImage()\" class=\"ml-2\"></kv-button>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n\r\n", styles: ["@charset \"UTF-8\";@import\"https://fonts.googleapis.com/css2?family=Inter:wght@100..900&display=swap\";@import\"https://fonts.googleapis.com/css2?family=Inter:wght@100;200;300;400;500;600;700;800;900&display=swap\";@import\"https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@24,400,0,0\";.material-symbols-outlined{font-family:Material Symbols Outlined!important}*{font-family:Inter var,Inter,sans-serif!important}::ng-deep .p-accordion,::ng-deep .p-accordion-header,::ng-deep .p-accordion-content,::ng-deep .p-badge,::ng-deep .p-overlay-badge,::ng-deep .p-breadcrumb,::ng-deep .p-breadcrumb-item,::ng-deep .p-breadcrumb-link,::ng-deep .p-button,::ng-deep .p-calendar,::ng-deep .p-card,::ng-deep .p-card-title,::ng-deep .p-card-subtitle,::ng-deep .p-card-content,::ng-deep .p-checkbox,::ng-deep .p-chip,::ng-deep .p-confirm-dialog,::ng-deep .p-confirm-dialog-message,::ng-deep .p-contextmenu,::ng-deep .p-contextmenu-item,::ng-deep .p-dataview,::ng-deep .p-dataview-content,::ng-deep .p-dialog,::ng-deep .p-dialog-title,::ng-deep .p-dialog-content,::ng-deep .p-dropdown,::ng-deep .p-dropdown-label,::ng-deep .p-dropdown-item,::ng-deep .p-dynamic-dialog,::ng-deep .p-dynamic-dialog-title,::ng-deep .p-dynamic-dialog-content,::ng-deep .p-editor,::ng-deep .p-fieldset,::ng-deep .p-fieldset-legend,::ng-deep .p-fieldset-content,::ng-deep .p-fileupload,::ng-deep .p-inputmask,::ng-deep .p-inputnumber,::ng-deep .p-inputtextarea,::ng-deep .p-inputtext,::ng-deep .p-menu,::ng-deep .p-menuitem,::ng-deep .p-menuitem-text,::ng-deep .p-message,::ng-deep .p-messages,::ng-deep .p-multiselect,::ng-deep .p-multiselect-label,::ng-deep .p-multiselect-item,::ng-deep .p-panelmenu,::ng-deep .p-panelmenu-header,::ng-deep .p-panelmenu-content,::ng-deep .p-panel,::ng-deep .p-panel-header,::ng-deep .p-panel-content,::ng-deep .p-password,::ng-deep .p-picklist,::ng-deep .p-progressbar,::ng-deep .p-radiobutton,::ng-deep .p-rating,::ng-deep .p-sidebar,::ng-deep .p-splitbutton,::ng-deep .p-steps,::ng-deep .p-step,::ng-deep .p-table,::ng-deep .p-datatable,::ng-deep .p-tabview,::ng-deep .p-tabpanel,::ng-deep .p-tag,::ng-deep .p-toast,::ng-deep .p-toolbar,::ng-deep .p-tooltip,::ng-deep .p-tree,::ng-deep .p-treetable,::ng-deep .p-selectbutton,::ng-deep .p-stepper,::ng-deep .p-inputgroup,::ng-deep .p-inputgroup-addon,::ng-deep .p-text{font-family:Inter var,Inter,sans-serif!important}:host ::ng-deep .inputs{height:35px}:root{--kv-primary-color: #29b92d, --kv-secondary-color: #002542, --kv-terciary-color: #f2f3f5, --kv-primary-hover-color: #249a29, --kv-secondary-hover-color: #002038, --kv-terciary-hover-color: #d9dadb, --kv-primary-active-color: #1c801f, --kv-secondary-active-color: #001729, --kv-terciary-active-color: #c0c1c2, --kv-primary-disable-color: #1c801f, --kv-secondary-disable-color: #001729, --kv-terciary-disable-color: #c0c1c2, }::ng-deep .p-dialog .p-dialog-header{color:#fff!important;background:#002542!important;display:flex!important;flex-wrap:wrap;word-wrap:break-word}::ng-deep .p-dialog .p-dialog-content{padding-top:1rem}::ng-deep .p-dialog{min-width:320px}::ng-deep .p-dialog-content{overflow-x:hidden}::ng-deep .p-dialog-content::-webkit-scrollbar{width:8px}::ng-deep .p-dialog-content::-webkit-scrollbar:hover{background-color:#dededebf}::ng-deep .p-dialog-content::-webkit-scrollbar-thumb{border-radius:4px;background-color:transparent}::ng-deep .p-dialog-content:hover::-webkit-scrollbar-thumb{border-left:2px solid white;background-color:#00000080}::ng-deep .p-dialog-content::-webkit-scrollbar-track{border-left:2px solid white;background-color:#dededebf}::ng-deep .p-dialog-footer{display:flex;justify-content:flex-end;padding:10px;gap:10px}::ng-deep .p-dialog .p-dialog-header .p-dialog-header-icon{display:none}img{border-style:solid;border-width:2px;border-radius:50%;object-fit:cover}i{font-size:22px}.botao-alterar-foto{border-style:none;width:max-content;background-color:#002542;color:#000;font-weight:700;cursor:pointer;padding:7px 9px}.botao-alterar-foto i{color:#fff}.botao-excluir-foto{border-style:none;width:max-content;background-color:#002542;color:#000;font-weight:700;cursor:pointer;padding:7px 9px}.botao-excluir-foto i{color:#fff}.btn{position:absolute;top:87%;left:87%;transform:translate(-50%,-50%)}.image-container{display:inline-block;position:relative}.modal{display:block;position:absolute;z-index:1;left:0;top:0;width:100vw;height:100vh;overflow:auto;background-color:#0006}.modal-content{background-color:#fefefe;margin:1% auto;padding:20px;border:1px solid #888;width:80%;max-width:600px;text-align:center;border-radius:12px}.crop-container{display:flex;justify-content:center;align-items:center}.crop-canvas{border:1px solid black;width:100%;max-width:600px;height:auto;border-radius:12px}.crop-border{position:absolute;width:225px;height:225px;border:2px solid black;border-radius:50%;pointer-events:none}.button-container{display:flex;align-items:center;justify-content:flex-end;flex-direction:row;margin-top:24px}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.Slider, selector: "p-slider", inputs: ["animate", "disabled", "min", "max", "orientation", "step", "range", "style", "styleClass", "ariaLabel", "ariaLabelledBy", "tabindex", "autofocus"], outputs: ["onChange", "onSlideEnd"] }, { kind: "directive", type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i6.KvButtonComponent, selector: "kv-button", inputs: ["label", "icon", "loading", "disabled", "severity", "size", "fullWidth"], outputs: ["onClick"] }, { kind: "component", type: i7.KvLabelComponent, selector: "kv-label", inputs: ["componentId", "label"] }] }); }
112
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvAvatarComponent, deps: [{ token: i1.ImagensService }, { token: i2.NotificationService }, { token: i3.DialogService }, { token: i3.DynamicDialogRef }], target: i0.ɵɵFactoryTarget.Component }); }
113
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.8", type: KvAvatarComponent, selector: "kv-avatar", inputs: { imageUrl: "imageUrl", borderColor: "borderColor", btnsColor: "btnsColor", width: "width", height: "height", btnAlterarFoto: "btnAlterarFoto" }, outputs: { imageUrlChange: "imageUrlChange", removerFotoEvent: "removerFotoEvent", onModalOpen: "onModalOpen" }, viewQueries: [{ propertyName: "fileInput", first: true, predicate: ["fileInput"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"image-container\">\r\n <img [src]=\"getImageSrc() || imageService.userDefaultImage()\" alt=\"Foto\" class=\"container-foto\" [style.border-color]=\"borderColor\" [style.width.px]=\"width\" [style.height.px]=\"height\" (error)=\"handleImageError($event)\" (click)=\"openFile()\">\r\n <div class=\"btn\">\r\n <input #fileInput *ngIf=\"btnAlterarFoto\" id=\"fotoEscolhida\" type=\"file\" accept=\"image/*\" style=\"display:none\" (change)=\"selectFotoSelecionada($any($event))\">\r\n <button *ngIf=\"btnAlterarFoto && !existeLogo\" class=\"botao-alterar-foto border-circle\" [style.background-color]=\"btnsColor\" (click)=\"openFile()\">\r\n <i class=\"material-symbols-outlined\">photo_camera</i>\r\n </button>\r\n \r\n <button *ngIf=\"btnAlterarFoto && existeLogo\" [style.background-color]=\"btnsColor\" class=\"botao-excluir-foto border-circle\" (click)=\"questionRemoverFoto()\">\r\n <i class=\"material-symbols-outlined\">delete</i>\r\n </button>\r\n </div>\r\n</div>\r\n", styles: ["@charset \"UTF-8\";@import\"https://fonts.googleapis.com/css2?family=Inter:wght@100..900&display=swap\";@import\"https://fonts.googleapis.com/css2?family=Inter:wght@100;200;300;400;500;600;700;800;900&display=swap\";@import\"https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@24,400,0,0\";.material-symbols-outlined{font-family:Material Symbols Outlined!important}*{font-family:Inter var,Inter,sans-serif!important}::ng-deep .p-accordion,::ng-deep .p-accordion-header,::ng-deep .p-accordion-content,::ng-deep .p-badge,::ng-deep .p-overlay-badge,::ng-deep .p-breadcrumb,::ng-deep .p-breadcrumb-item,::ng-deep .p-breadcrumb-link,::ng-deep .p-button,::ng-deep .p-calendar,::ng-deep .p-card,::ng-deep .p-card-title,::ng-deep .p-card-subtitle,::ng-deep .p-card-content,::ng-deep .p-checkbox,::ng-deep .p-chip,::ng-deep .p-confirm-dialog,::ng-deep .p-confirm-dialog-message,::ng-deep .p-contextmenu,::ng-deep .p-contextmenu-item,::ng-deep .p-dataview,::ng-deep .p-dataview-content,::ng-deep .p-dialog,::ng-deep .p-dialog-title,::ng-deep .p-dialog-content,::ng-deep .p-dropdown,::ng-deep .p-dropdown-label,::ng-deep .p-dropdown-item,::ng-deep .p-dynamic-dialog,::ng-deep .p-dynamic-dialog-title,::ng-deep .p-dynamic-dialog-content,::ng-deep .p-editor,::ng-deep .p-fieldset,::ng-deep .p-fieldset-legend,::ng-deep .p-fieldset-content,::ng-deep .p-fileupload,::ng-deep .p-inputmask,::ng-deep .p-inputnumber,::ng-deep .p-inputtextarea,::ng-deep .p-inputtext,::ng-deep .p-menu,::ng-deep .p-menuitem,::ng-deep .p-menuitem-text,::ng-deep .p-message,::ng-deep .p-messages,::ng-deep .p-multiselect,::ng-deep .p-multiselect-label,::ng-deep .p-multiselect-item,::ng-deep .p-panelmenu,::ng-deep .p-panelmenu-header,::ng-deep .p-panelmenu-content,::ng-deep .p-panel,::ng-deep .p-panel-header,::ng-deep .p-panel-content,::ng-deep .p-password,::ng-deep .p-picklist,::ng-deep .p-progressbar,::ng-deep .p-radiobutton,::ng-deep .p-rating,::ng-deep .p-sidebar,::ng-deep .p-splitbutton,::ng-deep .p-steps,::ng-deep .p-step,::ng-deep .p-table,::ng-deep .p-datatable,::ng-deep .p-tabview,::ng-deep .p-tabpanel,::ng-deep .p-tag,::ng-deep .p-toast,::ng-deep .p-toolbar,::ng-deep .p-tooltip,::ng-deep .p-tree,::ng-deep .p-treetable,::ng-deep .p-selectbutton,::ng-deep .p-stepper,::ng-deep .p-inputgroup,::ng-deep .p-inputgroup-addon,::ng-deep .p-text{font-family:Inter var,Inter,sans-serif!important}:host ::ng-deep .inputs{height:35px}:root{--kv-primary-color: #29b92d, --kv-secondary-color: #002542, --kv-terciary-color: #f2f3f5, --kv-primary-hover-color: #249a29, --kv-secondary-hover-color: #002038, --kv-terciary-hover-color: #d9dadb, --kv-primary-active-color: #1c801f, --kv-secondary-active-color: #001729, --kv-terciary-active-color: #c0c1c2, --kv-primary-disable-color: #1c801f, --kv-secondary-disable-color: #001729, --kv-terciary-disable-color: #c0c1c2, }::ng-deep .p-dialog .p-dialog-header{color:#fff!important;background:#002542!important;display:flex!important;flex-wrap:wrap;word-wrap:break-word}::ng-deep .p-dialog .p-dialog-content{padding-top:1rem}::ng-deep .p-dialog{min-width:320px}::ng-deep .p-dialog-content{overflow-x:hidden}::ng-deep .p-dialog-content::-webkit-scrollbar{width:8px}::ng-deep .p-dialog-content::-webkit-scrollbar:hover{background-color:#dededebf}::ng-deep .p-dialog-content::-webkit-scrollbar-thumb{border-radius:4px;background-color:transparent}::ng-deep .p-dialog-content:hover::-webkit-scrollbar-thumb{border-left:2px solid white;background-color:#00000080}::ng-deep .p-dialog-content::-webkit-scrollbar-track{border-left:2px solid white;background-color:#dededebf}::ng-deep .p-dialog-footer{display:flex;justify-content:flex-end;padding:10px;gap:10px}::ng-deep .p-dialog .p-dialog-header .p-dialog-header-icon{display:none}img{border-style:solid;border-width:2px;border-radius:50%;object-fit:cover}i{font-size:22px}.botao-alterar-foto{border-style:none;width:max-content;background-color:#002542;color:#000;font-weight:700;cursor:pointer;padding:7px 9px}.botao-alterar-foto i{color:#fff}.botao-excluir-foto{border-style:none;width:max-content;background-color:#002542;color:#000;font-weight:700;cursor:pointer;padding:7px 9px}.botao-excluir-foto i{color:#fff}.btn{position:absolute;top:87%;left:87%;transform:translate(-50%,-50%)}.image-container{display:inline-block;position:relative}\n"], dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
197
114
  }
198
115
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvAvatarComponent, decorators: [{
199
116
  type: Component,
200
- args: [{ selector: 'kv-avatar', template: "<div class=\"image-container\">\r\n <img [src]=\"getImageSrc() || imageService.userDefaultImage()\" alt=\"Foto\" class=\"container-foto\" [style.border-color]=\"borderColor\" [style.width.px]=\"width\" [style.height.px]=\"height\" (error)=\"handleImageError($event)\" (click)=\"openFile()\">\r\n <div class=\"btn\">\r\n <input #fileInput *ngIf=\"btnAlterarFoto\" id=\"fotoEscolhida\" type=\"file\" accept=\"image/*\" style=\"display:none\" (change)=\"selectFotoSelecionada($any($event))\">\r\n <button *ngIf=\"btnAlterarFoto && !existeLogo\" class=\"botao-alterar-foto border-circle\" [style.background-color]=\"btnsColor\" (click)=\"openFile()\">\r\n <i class=\"material-symbols-outlined\">photo_camera</i>\r\n </button>\r\n \r\n <button *ngIf=\"btnAlterarFoto && existeLogo\" [style.background-color]=\"btnsColor\" class=\"botao-excluir-foto border-circle\" (click)=\"questionRemoverFoto()\">\r\n <i class=\"material-symbols-outlined\">delete</i>\r\n </button>\r\n </div>\r\n</div>\r\n\r\n<div *ngIf=\"showCropModal\" class=\"modal\">\r\n <div class=\"modal-content\">\r\n <div class=\"crop-container\">\r\n <canvas #cropCanvas class=\"crop-canvas\"></canvas>\r\n <div class=\"crop-border\"></div>\r\n </div>\r\n\r\n <div class=\"w-full mt-2\">\r\n <kv-label label=\"Zoom\" style=\"text-align: left;\"/>\r\n <p-slider [(ngModel)]=\"valueZoom\" (onChange)=\"onZoomChange($event)\"></p-slider>\r\n </div>\r\n \r\n <div class=\"button-container\"> \r\n <kv-button label=\"Cancelar\" severity=\"tertiary\" icon=\"close\" (click)=\"closeCropModal()\"></kv-button>\r\n <kv-button label=\"Recortar\" severity=\"primary\" icon=\"crop\" (click)=\"cropImage()\" class=\"ml-2\"></kv-button>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n\r\n", styles: ["@charset \"UTF-8\";@import\"https://fonts.googleapis.com/css2?family=Inter:wght@100..900&display=swap\";@import\"https://fonts.googleapis.com/css2?family=Inter:wght@100;200;300;400;500;600;700;800;900&display=swap\";@import\"https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@24,400,0,0\";.material-symbols-outlined{font-family:Material Symbols Outlined!important}*{font-family:Inter var,Inter,sans-serif!important}::ng-deep .p-accordion,::ng-deep .p-accordion-header,::ng-deep .p-accordion-content,::ng-deep .p-badge,::ng-deep .p-overlay-badge,::ng-deep .p-breadcrumb,::ng-deep .p-breadcrumb-item,::ng-deep .p-breadcrumb-link,::ng-deep .p-button,::ng-deep .p-calendar,::ng-deep .p-card,::ng-deep .p-card-title,::ng-deep .p-card-subtitle,::ng-deep .p-card-content,::ng-deep .p-checkbox,::ng-deep .p-chip,::ng-deep .p-confirm-dialog,::ng-deep .p-confirm-dialog-message,::ng-deep .p-contextmenu,::ng-deep .p-contextmenu-item,::ng-deep .p-dataview,::ng-deep .p-dataview-content,::ng-deep .p-dialog,::ng-deep .p-dialog-title,::ng-deep .p-dialog-content,::ng-deep .p-dropdown,::ng-deep .p-dropdown-label,::ng-deep .p-dropdown-item,::ng-deep .p-dynamic-dialog,::ng-deep .p-dynamic-dialog-title,::ng-deep .p-dynamic-dialog-content,::ng-deep .p-editor,::ng-deep .p-fieldset,::ng-deep .p-fieldset-legend,::ng-deep .p-fieldset-content,::ng-deep .p-fileupload,::ng-deep .p-inputmask,::ng-deep .p-inputnumber,::ng-deep .p-inputtextarea,::ng-deep .p-inputtext,::ng-deep .p-menu,::ng-deep .p-menuitem,::ng-deep .p-menuitem-text,::ng-deep .p-message,::ng-deep .p-messages,::ng-deep .p-multiselect,::ng-deep .p-multiselect-label,::ng-deep .p-multiselect-item,::ng-deep .p-panelmenu,::ng-deep .p-panelmenu-header,::ng-deep .p-panelmenu-content,::ng-deep .p-panel,::ng-deep .p-panel-header,::ng-deep .p-panel-content,::ng-deep .p-password,::ng-deep .p-picklist,::ng-deep .p-progressbar,::ng-deep .p-radiobutton,::ng-deep .p-rating,::ng-deep .p-sidebar,::ng-deep .p-splitbutton,::ng-deep .p-steps,::ng-deep .p-step,::ng-deep .p-table,::ng-deep .p-datatable,::ng-deep .p-tabview,::ng-deep .p-tabpanel,::ng-deep .p-tag,::ng-deep .p-toast,::ng-deep .p-toolbar,::ng-deep .p-tooltip,::ng-deep .p-tree,::ng-deep .p-treetable,::ng-deep .p-selectbutton,::ng-deep .p-stepper,::ng-deep .p-inputgroup,::ng-deep .p-inputgroup-addon,::ng-deep .p-text{font-family:Inter var,Inter,sans-serif!important}:host ::ng-deep .inputs{height:35px}:root{--kv-primary-color: #29b92d, --kv-secondary-color: #002542, --kv-terciary-color: #f2f3f5, --kv-primary-hover-color: #249a29, --kv-secondary-hover-color: #002038, --kv-terciary-hover-color: #d9dadb, --kv-primary-active-color: #1c801f, --kv-secondary-active-color: #001729, --kv-terciary-active-color: #c0c1c2, --kv-primary-disable-color: #1c801f, --kv-secondary-disable-color: #001729, --kv-terciary-disable-color: #c0c1c2, }::ng-deep .p-dialog .p-dialog-header{color:#fff!important;background:#002542!important;display:flex!important;flex-wrap:wrap;word-wrap:break-word}::ng-deep .p-dialog .p-dialog-content{padding-top:1rem}::ng-deep .p-dialog{min-width:320px}::ng-deep .p-dialog-content{overflow-x:hidden}::ng-deep .p-dialog-content::-webkit-scrollbar{width:8px}::ng-deep .p-dialog-content::-webkit-scrollbar:hover{background-color:#dededebf}::ng-deep .p-dialog-content::-webkit-scrollbar-thumb{border-radius:4px;background-color:transparent}::ng-deep .p-dialog-content:hover::-webkit-scrollbar-thumb{border-left:2px solid white;background-color:#00000080}::ng-deep .p-dialog-content::-webkit-scrollbar-track{border-left:2px solid white;background-color:#dededebf}::ng-deep .p-dialog-footer{display:flex;justify-content:flex-end;padding:10px;gap:10px}::ng-deep .p-dialog .p-dialog-header .p-dialog-header-icon{display:none}img{border-style:solid;border-width:2px;border-radius:50%;object-fit:cover}i{font-size:22px}.botao-alterar-foto{border-style:none;width:max-content;background-color:#002542;color:#000;font-weight:700;cursor:pointer;padding:7px 9px}.botao-alterar-foto i{color:#fff}.botao-excluir-foto{border-style:none;width:max-content;background-color:#002542;color:#000;font-weight:700;cursor:pointer;padding:7px 9px}.botao-excluir-foto i{color:#fff}.btn{position:absolute;top:87%;left:87%;transform:translate(-50%,-50%)}.image-container{display:inline-block;position:relative}.modal{display:block;position:absolute;z-index:1;left:0;top:0;width:100vw;height:100vh;overflow:auto;background-color:#0006}.modal-content{background-color:#fefefe;margin:1% auto;padding:20px;border:1px solid #888;width:80%;max-width:600px;text-align:center;border-radius:12px}.crop-container{display:flex;justify-content:center;align-items:center}.crop-canvas{border:1px solid black;width:100%;max-width:600px;height:auto;border-radius:12px}.crop-border{position:absolute;width:225px;height:225px;border:2px solid black;border-radius:50%;pointer-events:none}.button-container{display:flex;align-items:center;justify-content:flex-end;flex-direction:row;margin-top:24px}\n"] }]
201
- }], ctorParameters: () => [{ type: i1.ImagensService }, { type: i2.NotificationService }], propDecorators: { imageUrl: [{
117
+ args: [{ selector: 'kv-avatar', template: "<div class=\"image-container\">\r\n <img [src]=\"getImageSrc() || imageService.userDefaultImage()\" alt=\"Foto\" class=\"container-foto\" [style.border-color]=\"borderColor\" [style.width.px]=\"width\" [style.height.px]=\"height\" (error)=\"handleImageError($event)\" (click)=\"openFile()\">\r\n <div class=\"btn\">\r\n <input #fileInput *ngIf=\"btnAlterarFoto\" id=\"fotoEscolhida\" type=\"file\" accept=\"image/*\" style=\"display:none\" (change)=\"selectFotoSelecionada($any($event))\">\r\n <button *ngIf=\"btnAlterarFoto && !existeLogo\" class=\"botao-alterar-foto border-circle\" [style.background-color]=\"btnsColor\" (click)=\"openFile()\">\r\n <i class=\"material-symbols-outlined\">photo_camera</i>\r\n </button>\r\n \r\n <button *ngIf=\"btnAlterarFoto && existeLogo\" [style.background-color]=\"btnsColor\" class=\"botao-excluir-foto border-circle\" (click)=\"questionRemoverFoto()\">\r\n <i class=\"material-symbols-outlined\">delete</i>\r\n </button>\r\n </div>\r\n</div>\r\n", styles: ["@charset \"UTF-8\";@import\"https://fonts.googleapis.com/css2?family=Inter:wght@100..900&display=swap\";@import\"https://fonts.googleapis.com/css2?family=Inter:wght@100;200;300;400;500;600;700;800;900&display=swap\";@import\"https://fonts.googleapis.com/css2?family=Material+Symbols+Outlined:opsz,wght,FILL,GRAD@24,400,0,0\";.material-symbols-outlined{font-family:Material Symbols Outlined!important}*{font-family:Inter var,Inter,sans-serif!important}::ng-deep .p-accordion,::ng-deep .p-accordion-header,::ng-deep .p-accordion-content,::ng-deep .p-badge,::ng-deep .p-overlay-badge,::ng-deep .p-breadcrumb,::ng-deep .p-breadcrumb-item,::ng-deep .p-breadcrumb-link,::ng-deep .p-button,::ng-deep .p-calendar,::ng-deep .p-card,::ng-deep .p-card-title,::ng-deep .p-card-subtitle,::ng-deep .p-card-content,::ng-deep .p-checkbox,::ng-deep .p-chip,::ng-deep .p-confirm-dialog,::ng-deep .p-confirm-dialog-message,::ng-deep .p-contextmenu,::ng-deep .p-contextmenu-item,::ng-deep .p-dataview,::ng-deep .p-dataview-content,::ng-deep .p-dialog,::ng-deep .p-dialog-title,::ng-deep .p-dialog-content,::ng-deep .p-dropdown,::ng-deep .p-dropdown-label,::ng-deep .p-dropdown-item,::ng-deep .p-dynamic-dialog,::ng-deep .p-dynamic-dialog-title,::ng-deep .p-dynamic-dialog-content,::ng-deep .p-editor,::ng-deep .p-fieldset,::ng-deep .p-fieldset-legend,::ng-deep .p-fieldset-content,::ng-deep .p-fileupload,::ng-deep .p-inputmask,::ng-deep .p-inputnumber,::ng-deep .p-inputtextarea,::ng-deep .p-inputtext,::ng-deep .p-menu,::ng-deep .p-menuitem,::ng-deep .p-menuitem-text,::ng-deep .p-message,::ng-deep .p-messages,::ng-deep .p-multiselect,::ng-deep .p-multiselect-label,::ng-deep .p-multiselect-item,::ng-deep .p-panelmenu,::ng-deep .p-panelmenu-header,::ng-deep .p-panelmenu-content,::ng-deep .p-panel,::ng-deep .p-panel-header,::ng-deep .p-panel-content,::ng-deep .p-password,::ng-deep .p-picklist,::ng-deep .p-progressbar,::ng-deep .p-radiobutton,::ng-deep .p-rating,::ng-deep .p-sidebar,::ng-deep .p-splitbutton,::ng-deep .p-steps,::ng-deep .p-step,::ng-deep .p-table,::ng-deep .p-datatable,::ng-deep .p-tabview,::ng-deep .p-tabpanel,::ng-deep .p-tag,::ng-deep .p-toast,::ng-deep .p-toolbar,::ng-deep .p-tooltip,::ng-deep .p-tree,::ng-deep .p-treetable,::ng-deep .p-selectbutton,::ng-deep .p-stepper,::ng-deep .p-inputgroup,::ng-deep .p-inputgroup-addon,::ng-deep .p-text{font-family:Inter var,Inter,sans-serif!important}:host ::ng-deep .inputs{height:35px}:root{--kv-primary-color: #29b92d, --kv-secondary-color: #002542, --kv-terciary-color: #f2f3f5, --kv-primary-hover-color: #249a29, --kv-secondary-hover-color: #002038, --kv-terciary-hover-color: #d9dadb, --kv-primary-active-color: #1c801f, --kv-secondary-active-color: #001729, --kv-terciary-active-color: #c0c1c2, --kv-primary-disable-color: #1c801f, --kv-secondary-disable-color: #001729, --kv-terciary-disable-color: #c0c1c2, }::ng-deep .p-dialog .p-dialog-header{color:#fff!important;background:#002542!important;display:flex!important;flex-wrap:wrap;word-wrap:break-word}::ng-deep .p-dialog .p-dialog-content{padding-top:1rem}::ng-deep .p-dialog{min-width:320px}::ng-deep .p-dialog-content{overflow-x:hidden}::ng-deep .p-dialog-content::-webkit-scrollbar{width:8px}::ng-deep .p-dialog-content::-webkit-scrollbar:hover{background-color:#dededebf}::ng-deep .p-dialog-content::-webkit-scrollbar-thumb{border-radius:4px;background-color:transparent}::ng-deep .p-dialog-content:hover::-webkit-scrollbar-thumb{border-left:2px solid white;background-color:#00000080}::ng-deep .p-dialog-content::-webkit-scrollbar-track{border-left:2px solid white;background-color:#dededebf}::ng-deep .p-dialog-footer{display:flex;justify-content:flex-end;padding:10px;gap:10px}::ng-deep .p-dialog .p-dialog-header .p-dialog-header-icon{display:none}img{border-style:solid;border-width:2px;border-radius:50%;object-fit:cover}i{font-size:22px}.botao-alterar-foto{border-style:none;width:max-content;background-color:#002542;color:#000;font-weight:700;cursor:pointer;padding:7px 9px}.botao-alterar-foto i{color:#fff}.botao-excluir-foto{border-style:none;width:max-content;background-color:#002542;color:#000;font-weight:700;cursor:pointer;padding:7px 9px}.botao-excluir-foto i{color:#fff}.btn{position:absolute;top:87%;left:87%;transform:translate(-50%,-50%)}.image-container{display:inline-block;position:relative}\n"] }]
118
+ }], ctorParameters: () => [{ type: i1.ImagensService }, { type: i2.NotificationService }, { type: i3.DialogService }, { type: i3.DynamicDialogRef }], propDecorators: { imageUrl: [{
202
119
  type: Input
203
120
  }], borderColor: [{
204
121
  type: Input
@@ -216,11 +133,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
216
133
  type: Output
217
134
  }], btnAlterarFoto: [{
218
135
  type: Input
219
- }], cropCanvas: [{
220
- type: ViewChild,
221
- args: ['cropCanvas']
222
136
  }], fileInput: [{
223
137
  type: ViewChild,
224
138
  args: ['fileInput']
225
139
  }] } });
226
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-avatar.component.js","sourceRoot":"","sources":["../../../../../../projects/keevo-components/src/lib/components/kv-avatar/kv-avatar.component.ts","../../../../../../projects/keevo-components/src/lib/components/kv-avatar/kv-avatar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  Input,\r\n  Output,\r\n  ViewChild,\r\n} from '@angular/core';\r\n\r\nimport { ImagensService } from '../../api/services/imagens.service';\r\nimport { NotificationService } from '../../api/services/notification.service';\r\n\r\n@Component({\r\n  selector: 'kv-avatar',\r\n  templateUrl: './kv-avatar.component.html',\r\n  styleUrls: ['./kv-avatar.component.scss']\r\n})\r\nexport class KvAvatarComponent {\r\n  @Input() imageUrl!: string;\r\n  @Input() borderColor: string = '#002542';\r\n  @Input() btnsColor: string = '#002542';\r\n  @Input() width: number = 135;\r\n  @Input() height: number = 135;\r\n  @Output() imageUrlChange = new EventEmitter<string>();\r\n  @Output() removerFotoEvent = new EventEmitter<void>();\r\n  @Output() onModalOpen = new EventEmitter<void>();\r\n  \r\n  existeLogo = false;\r\n\r\n  @Input() btnAlterarFoto: boolean = false;\r\n\r\n  showCropModal: boolean = false;\r\n  imageLoaded: boolean = false;\r\n  imageX: number = 0;\r\n  imageY: number = 0;\r\n  startX: number = 0;\r\n  startY: number = 0;\r\n  valueZoom: number = 50;\r\n  scaleFactor: number = 1;\r\n\r\n  selectedImage: string = '';\r\n\r\n  @ViewChild('cropCanvas') cropCanvas!: ElementRef<HTMLCanvasElement>;\r\n  @ViewChild('fileInput') fileInput!: ElementRef;\r\n\r\n  constructor(public imageService: ImagensService, private notificationService: NotificationService ) { }\r\n\r\n  getImageSrc(): string {\r\n    if (this.imageUrl && (this.imageUrl.startsWith('data:image') || this.imageUrl.startsWith('http') || this.imageUrl.startsWith('https'))) {\r\n      this.existeLogo = true;\r\n      return this.imageUrl;\r\n    } else if (this.imageUrl) {\r\n      this.existeLogo = true;\r\n      return 'data:image/jpg;base64,' + this.imageUrl;\r\n    } else {\r\n      this.existeLogo = false;\r\n      return this.imageService.userDefaultImage();\r\n    }\r\n  }\r\n\r\n  openFile() {\r\n    const inputElement: HTMLInputElement | null = document.getElementById('fotoEscolhida') as HTMLInputElement;\r\n    if (inputElement) {\r\n      inputElement.click();\r\n    }\r\n  }\r\n\r\n  selectFotoSelecionada(event: any) {\r\n    const file = event.target.files[0];\r\n    if (file) {\r\n      const reader = new FileReader();\r\n      reader.readAsDataURL(file);\r\n      reader.onload = () => {\r\n        this.selectedImage = reader.result as string;\r\n        this.existeLogo = true;\r\n        this.openCropModal();\r\n      };\r\n    }\r\n  }\r\n\r\n  questionRemoverFoto(){\r\n    const msg = '<h3>Você tem certeza que deseja retirar a foto desse usuário?</h3>';\r\n\r\n    this.notificationService.question({\r\n      type: 'question',\r\n      message: msg,\r\n      accept: (data:any) =>\r\n      {\r\n        this.removerFoto()\r\n      },\r\n      reject: (data:any) => {\r\n\r\n      }\r\n    })\r\n  }\r\n\r\n  removerFoto() {\r\n    this.imageUrl = '';\r\n    this.removerFotoEvent.emit();\r\n    this.existeLogo = false;\r\n    this.imageUrlChange.emit(this.imageUrl);\r\n    this.fileInput.nativeElement.value = '';\r\n  }\r\n\r\n  handleImageError(event: any) {\r\n    event.target.src = this.imageService.userDefaultImage();\r\n  }\r\n\r\n  openCropModal() {\r\n    this.onModalOpen.emit();\r\n    this.showCropModal = true;\r\n    setTimeout(() => {\r\n      const canvas = this.cropCanvas.nativeElement;\r\n      const ctx = canvas.getContext('2d');\r\n      const img = new Image();\r\n      img.src = this.selectedImage;\r\n      img.onload = () => {\r\n        this.imageLoaded = true;\r\n        this.imageX = (canvas.width - img.width * this.scaleFactor) / 2;\r\n        this.imageY = (canvas.height - img.height * this.scaleFactor) / 2;\r\n  \r\n        canvas.width = 500;\r\n        canvas.height = 500;\r\n        ctx?.clearRect(0, 0, canvas.width, canvas.height);\r\n        ctx?.drawImage(img, this.imageX, this.imageY, img.width * this.scaleFactor, img.height * this.scaleFactor);\r\n        this.drawCropArea(ctx);\r\n        this.initializeImageMove(canvas, ctx, img);\r\n        this.initializeMouseWheel(canvas, ctx, img);\r\n      };\r\n    }, 0);\r\n  }\r\n\r\n  drawCropArea(ctx: CanvasRenderingContext2D | null) {\r\n    if (ctx) {\r\n      const centerX = ctx.canvas.width / 2;\r\n      const centerY = ctx.canvas.height / 2;\r\n      const radius = 100; // Raio da área de recorte\r\n  \r\n      ctx.beginPath();\r\n      ctx.arc(centerX, centerY, radius, 0, Math.PI * 2, true);\r\n      ctx.strokeStyle = 'transparent';\r\n      ctx.lineWidth = 2;\r\n      ctx.stroke();\r\n      ctx.closePath();\r\n    }\r\n  }\r\n\r\n  initializeImageMove(canvas: HTMLCanvasElement, ctx: CanvasRenderingContext2D | null, img: HTMLImageElement) {\r\n    let isDragging = false;\r\n\r\n    canvas.style.cursor = 'grab';\r\n\r\n    canvas.onmousedown = (e) => {\r\n      isDragging = true;\r\n      canvas.style.cursor = 'grabbing'; \r\n      this.startX = e.offsetX - this.imageX;\r\n      this.startY = e.offsetY - this.imageY;\r\n    };\r\n\r\n    canvas.onmousemove = (e) => {\r\n      if (isDragging) {\r\n        this.imageX = e.offsetX - this.startX;\r\n        this.imageY = e.offsetY - this.startY;\r\n        ctx?.clearRect(0, 0, canvas.width, canvas.height);\r\n        ctx?.drawImage(img, this.imageX, this.imageY, img.width * this.scaleFactor, img.height * this.scaleFactor);\r\n        this.drawCropArea(ctx);\r\n      }\r\n    };\r\n\r\n    canvas.onmouseup = () => {\r\n      isDragging = false;\r\n      canvas.style.cursor = 'grab';\r\n    };\r\n\r\n    canvas.onmouseout = () => {\r\n      isDragging = false;\r\n      canvas.style.cursor = 'grab';\r\n    };\r\n  }\r\n\r\n  initializeMouseWheel(canvas: HTMLCanvasElement, ctx: CanvasRenderingContext2D | null, img: HTMLImageElement) {\r\n    canvas.onwheel = (e) => {\r\n      e.preventDefault();\r\n      const delta = e.deltaY > 0 ? -0.1 : 0.1;\r\n      this.scaleFactor = Math.min(Math.max(this.scaleFactor + delta, 0.1), 5); // limita o fator de escala entre 0.1 e 5\r\n      ctx?.clearRect(0, 0, canvas.width, canvas.height);\r\n      ctx?.drawImage(img, this.imageX, this.imageY, img.width * this.scaleFactor, img.height * this.scaleFactor);\r\n      this.drawCropArea(ctx);\r\n      this.valueZoom = this.scaleFactor * 50;\r\n    };\r\n  }\r\n\r\n  cropImage() {\r\n    const canvas = this.cropCanvas.nativeElement;\r\n    const ctx = canvas.getContext('2d');\r\n    if (ctx) {\r\n      const centerX = canvas.width / 2;\r\n      const centerY = canvas.height / 2;\r\n      const radius = 100;\r\n      const imageData = ctx.getImageData(centerX - radius, centerY - radius, radius * 2, radius * 2);\r\n      const newCanvas = document.createElement('canvas');\r\n      const newCtx = newCanvas.getContext('2d');\r\n      newCanvas.width = radius * 2;\r\n      newCanvas.height = radius * 2;\r\n      newCtx?.putImageData(imageData, 0, 0);\r\n      this.imageUrl = newCanvas.toDataURL();\r\n      this.imageUrlChange.emit(this.imageUrl);\r\n      this.closeCropModal();\r\n    }\r\n  }  \r\n\r\n  onZoomChange(event: any) {\r\n    const canvas = this.cropCanvas.nativeElement;\r\n    const ctx = canvas.getContext('2d');\r\n    const img = new Image();\r\n    img.src = this.selectedImage;\r\n    img.onload = () => {\r\n      ctx?.clearRect(0, 0, canvas.width, canvas.height);\r\n      this.scaleFactor = event.value / 50;\r\n      ctx?.drawImage(img, this.imageX, this.imageY, img.width * this.scaleFactor, img.height * this.scaleFactor);\r\n      this.drawCropArea(ctx);\r\n    };\r\n  }\r\n\r\n  closeCropModal() {\r\n    this.showCropModal = false;\r\n    this.valueZoom = 50;\r\n    this.imageLoaded = false;\r\n  }\r\n  \r\n}\r\n","<div class=\"image-container\">\r\n  <img [src]=\"getImageSrc() || imageService.userDefaultImage()\" alt=\"Foto\" class=\"container-foto\" [style.border-color]=\"borderColor\" [style.width.px]=\"width\" [style.height.px]=\"height\" (error)=\"handleImageError($event)\" (click)=\"openFile()\">\r\n  <div class=\"btn\">\r\n    <input #fileInput *ngIf=\"btnAlterarFoto\" id=\"fotoEscolhida\" type=\"file\" accept=\"image/*\" style=\"display:none\" (change)=\"selectFotoSelecionada($any($event))\">\r\n    <button *ngIf=\"btnAlterarFoto && !existeLogo\" class=\"botao-alterar-foto border-circle\" [style.background-color]=\"btnsColor\" (click)=\"openFile()\">\r\n      <i class=\"material-symbols-outlined\">photo_camera</i>\r\n    </button>\r\n    \r\n    <button *ngIf=\"btnAlterarFoto && existeLogo\" [style.background-color]=\"btnsColor\" class=\"botao-excluir-foto border-circle\" (click)=\"questionRemoverFoto()\">\r\n      <i class=\"material-symbols-outlined\">delete</i>\r\n    </button>\r\n  </div>\r\n</div>\r\n\r\n<div *ngIf=\"showCropModal\" class=\"modal\">\r\n  <div class=\"modal-content\">\r\n    <div class=\"crop-container\">\r\n      <canvas #cropCanvas class=\"crop-canvas\"></canvas>\r\n      <div class=\"crop-border\"></div>\r\n    </div>\r\n\r\n    <div class=\"w-full mt-2\">\r\n      <kv-label label=\"Zoom\" style=\"text-align: left;\"/>\r\n      <p-slider [(ngModel)]=\"valueZoom\" (onChange)=\"onZoomChange($event)\"></p-slider>\r\n    </div>\r\n      \r\n    <div class=\"button-container\">  \r\n      <kv-button label=\"Cancelar\" severity=\"tertiary\" icon=\"close\" (click)=\"closeCropModal()\"></kv-button>\r\n      <kv-button label=\"Recortar\" severity=\"primary\" icon=\"crop\" (click)=\"cropImage()\" class=\"ml-2\"></kv-button>\r\n    </div>\r\n  </div>\r\n</div>\r\n\r\n\r\n"]}
140
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"kv-avatar.component.js","sourceRoot":"","sources":["../../../../../../projects/keevo-components/src/lib/components/kv-avatar/kv-avatar.component.ts","../../../../../../projects/keevo-components/src/lib/components/kv-avatar/kv-avatar.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ComponentRef,\r\n  ElementRef,\r\n  EventEmitter,\r\n  Input,\r\n  Output,\r\n  ViewChild,\r\n} from '@angular/core';\r\n\r\nimport { ImagensService } from '../../api/services/imagens.service';\r\nimport { NotificationService } from '../../api/services/notification.service';\r\nimport {  BaseComponentCrud } from 'projects/keevo-components/src/public-api';\r\nimport { DialogService, DynamicDialogRef } from 'primeng/dynamicdialog';\r\n// import { KvCropImageComponent } from './kv-crop-image/kv-crop-image.component';\r\n\r\n@Component({\r\n  selector: 'kv-avatar',\r\n  templateUrl: './kv-avatar.component.html',\r\n  styleUrls: ['./kv-avatar.component.scss']\r\n})\r\nexport class KvAvatarComponent extends BaseComponentCrud {\r\n  @Input() imageUrl!: string;\r\n  @Input() borderColor: string = '#002542';\r\n  @Input() btnsColor: string = '#002542';\r\n  @Input() width: number = 135;\r\n  @Input() height: number = 135;\r\n  @Output() imageUrlChange = new EventEmitter<string>();\r\n  @Output() removerFotoEvent = new EventEmitter<void>();\r\n  @Output() onModalOpen = new EventEmitter<void>();\r\n  @Input() btnAlterarFoto: boolean = false;\r\n  \r\n  existeLogo = false;\r\n  selectedImage: string = '';\r\n\r\n\r\n  @ViewChild('fileInput') fileInput!: ElementRef;\r\n\r\n  constructor(public imageService: ImagensService, \r\n              override notificationService: NotificationService, \r\n              override dialogService: DialogService,\r\n              public dynamicDialogRef: DynamicDialogRef\r\n   ) { super(dialogService, notificationService) \r\n    \r\n   }\r\n\r\n  getImageSrc(): string {\r\n    if (this.imageUrl && (this.imageUrl.startsWith('data:image') || this.imageUrl.startsWith('http') || this.imageUrl.startsWith('https'))) {\r\n      this.existeLogo = true;\r\n      return this.imageUrl;\r\n    } else if (this.imageUrl) {\r\n      this.existeLogo = true;\r\n      return 'data:image/jpg;base64,' + this.imageUrl;\r\n    } else {\r\n      this.existeLogo = false;\r\n      return this.imageService.userDefaultImage();\r\n    }\r\n  }\r\n\r\n  openFile() {\r\n    const inputElement: HTMLInputElement | null = document.getElementById('fotoEscolhida') as HTMLInputElement;\r\n    if (inputElement) {\r\n      inputElement.click();\r\n    }\r\n  }\r\n\r\n  selectFotoSelecionada(event: any) {\r\n    const file = event.target.files[0];\r\n    if (file) {\r\n      const reader = new FileReader();\r\n      reader.readAsDataURL(file);\r\n      reader.onload = () => {\r\n        this.selectedImage = reader.result as string;\r\n        this.existeLogo = true;\r\n        // this.abrirModalRecortarFoto();\r\n      };\r\n    }\r\n  }\r\n\r\n  questionRemoverFoto(){\r\n    const msg = '<h3>Você tem certeza que deseja retirar a foto desse usuário?</h3>';\r\n\r\n    this.notificationService.question({\r\n      type: 'question',\r\n      message: msg,\r\n      accept: (data:any) =>\r\n      {\r\n        this.removerFoto()\r\n      },\r\n      reject: (data:any) => {\r\n\r\n      }\r\n    })\r\n  }\r\n\r\n  removerFoto() {\r\n    this.imageUrl = '';\r\n    this.removerFotoEvent.emit();\r\n    this.existeLogo = false;\r\n    this.imageUrlChange.emit(this.imageUrl);\r\n    this.fileInput.nativeElement.value = '';\r\n  }\r\n\r\n  handleImageError(event: any) {\r\n    event.target.src = this.imageService.userDefaultImage();\r\n  }\r\n\r\n  // abrirModalRecortarFoto() {\r\n  //   this.openDialog(\r\n  //     KvCropImageComponent,\r\n  //     () => {\r\n  //       this.imageUrl = this.receberDados();\r\n  //       this.imageUrlChange.emit(this.imageUrl);\r\n  //     },\r\n  //     {\r\n  //       maximizable: false,\r\n  //       popup: true,\r\n  //       width: '60%',\r\n  //       header: 'Recortar',\r\n  //       id:{imagemSelecionada: this.selectedImage, imagemCortada: ''}\r\n  //     }\r\n      \r\n  //   )\r\n  //   const arr: Map<DynamicDialogRef<any>, ComponentRef<any>> = this.dialogService.dialogComponentRefMap\r\n  //   const entries = arr.entries();\r\n  //   const firstEntry = entries.next().value;\r\n  //   const [firstKey, firstValue] = firstEntry;\r\n  //   const instance = this.dialogService.getInstance(firstKey)\r\n  //   instance.config.showHeader = false\r\n  //   instance.config.contentStyle = {'border-radius': '12px'}\r\n  // }\r\n\r\n  receberDados(){\r\n    const arr: Map<DynamicDialogRef<any>, ComponentRef<any>> = this.dialogService.dialogComponentRefMap\r\n    const entries = arr.entries();\r\n    const firstEntry = entries.next().value;\r\n    const [firstKey, firstValue] = firstEntry;\r\n    const instance = this.dialogService.getInstance(firstKey)\r\n\r\n    return instance.config.data.id.imagemCortada\r\n  }  \r\n}\r\n","<div class=\"image-container\">\r\n  <img [src]=\"getImageSrc() || imageService.userDefaultImage()\" alt=\"Foto\" class=\"container-foto\" [style.border-color]=\"borderColor\" [style.width.px]=\"width\" [style.height.px]=\"height\" (error)=\"handleImageError($event)\" (click)=\"openFile()\">\r\n  <div class=\"btn\">\r\n    <input #fileInput *ngIf=\"btnAlterarFoto\" id=\"fotoEscolhida\" type=\"file\" accept=\"image/*\" style=\"display:none\" (change)=\"selectFotoSelecionada($any($event))\">\r\n    <button *ngIf=\"btnAlterarFoto && !existeLogo\" class=\"botao-alterar-foto border-circle\" [style.background-color]=\"btnsColor\" (click)=\"openFile()\">\r\n      <i class=\"material-symbols-outlined\">photo_camera</i>\r\n    </button>\r\n    \r\n    <button *ngIf=\"btnAlterarFoto && existeLogo\" [style.background-color]=\"btnsColor\" class=\"botao-excluir-foto border-circle\" (click)=\"questionRemoverFoto()\">\r\n      <i class=\"material-symbols-outlined\">delete</i>\r\n    </button>\r\n  </div>\r\n</div>\r\n"]}
@@ -7,7 +7,9 @@ import { KvAvatarComponent } from "./kv-avatar.component";
7
7
  import { FormsModule, ReactiveFormsModule } from '@angular/forms';
8
8
  import { KvButtonModule } from '../kv-button/kv-button.module';
9
9
  import { KvLabelModule } from '../kv-label/kv-label.module';
10
+ import { KvModalModule } from "../kv-modal/kv-modal.module";
10
11
  import * as i0 from "@angular/core";
12
+ // import { KvCropImageComponent } from './kv-crop-image/kv-crop-image.component';
11
13
  export class KvAvatarModule {
12
14
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvAvatarModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
13
15
  static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.8", ngImport: i0, type: KvAvatarModule, declarations: [KvAvatarComponent], imports: [CommonModule,
@@ -17,7 +19,8 @@ export class KvAvatarModule {
17
19
  FormsModule,
18
20
  ReactiveFormsModule,
19
21
  KvButtonModule,
20
- KvLabelModule], exports: [KvAvatarComponent] }); }
22
+ KvLabelModule,
23
+ KvModalModule], exports: [KvAvatarComponent] }); }
21
24
  static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvAvatarModule, imports: [CommonModule,
22
25
  ButtonModule,
23
26
  FileUploadModule,
@@ -25,13 +28,15 @@ export class KvAvatarModule {
25
28
  FormsModule,
26
29
  ReactiveFormsModule,
27
30
  KvButtonModule,
28
- KvLabelModule] }); }
31
+ KvLabelModule,
32
+ KvModalModule] }); }
29
33
  }
30
34
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImport: i0, type: KvAvatarModule, decorators: [{
31
35
  type: NgModule,
32
36
  args: [{
33
37
  declarations: [
34
- KvAvatarComponent
38
+ KvAvatarComponent,
39
+ // KvCropImageComponent
35
40
  ],
36
41
  imports: [
37
42
  CommonModule,
@@ -41,11 +46,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.8", ngImpor
41
46
  FormsModule,
42
47
  ReactiveFormsModule,
43
48
  KvButtonModule,
44
- KvLabelModule
49
+ KvLabelModule,
50
+ KvModalModule,
45
51
  ],
46
52
  exports: [
47
53
  KvAvatarComponent
48
54
  ]
49
55
  }]
50
56
  }] });
51
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia3YtYXZhdGFyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tlZXZvLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2t2LWF2YXRhci9rdi1hdmF0YXIubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM5QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDdEQsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFOUMsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDMUQsT0FBTyxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUMvRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sNkJBQTZCLENBQUM7O0FBb0I1RCxNQUFNLE9BQU8sY0FBYzs4R0FBZCxjQUFjOytHQUFkLGNBQWMsaUJBaEJ2QixpQkFBaUIsYUFHakIsWUFBWTtZQUNaLFlBQVk7WUFDWixnQkFBZ0I7WUFDaEIsWUFBWTtZQUNaLFdBQVc7WUFDWCxtQkFBbUI7WUFDbkIsY0FBYztZQUNkLGFBQWEsYUFHYixpQkFBaUI7K0dBR1IsY0FBYyxZQWJ2QixZQUFZO1lBQ1osWUFBWTtZQUNaLGdCQUFnQjtZQUNoQixZQUFZO1lBQ1osV0FBVztZQUNYLG1CQUFtQjtZQUNuQixjQUFjO1lBQ2QsYUFBYTs7MkZBTUosY0FBYztrQkFsQjFCLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFO3dCQUNaLGlCQUFpQjtxQkFDbEI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLFlBQVk7d0JBQ1osWUFBWTt3QkFDWixnQkFBZ0I7d0JBQ2hCLFlBQVk7d0JBQ1osV0FBVzt3QkFDWCxtQkFBbUI7d0JBQ25CLGNBQWM7d0JBQ2QsYUFBYTtxQkFDZDtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsaUJBQWlCO3FCQUNsQjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJ1dHRvbk1vZHVsZSB9IGZyb20gJ3ByaW1lbmcvYnV0dG9uJztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgRmlsZVVwbG9hZE1vZHVsZSB9IGZyb20gJ3ByaW1lbmcvZmlsZXVwbG9hZCc7XHJcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHsgU2xpZGVyTW9kdWxlIH0gZnJvbSAncHJpbWVuZy9zbGlkZXInO1xyXG5cclxuaW1wb3J0IHsgS3ZBdmF0YXJDb21wb25lbnQgfSBmcm9tIFwiLi9rdi1hdmF0YXIuY29tcG9uZW50XCI7XHJcbmltcG9ydCB7IEZvcm1zTW9kdWxlLCBSZWFjdGl2ZUZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xyXG5pbXBvcnQgeyBLdkJ1dHRvbk1vZHVsZSB9IGZyb20gJy4uL2t2LWJ1dHRvbi9rdi1idXR0b24ubW9kdWxlJztcclxuaW1wb3J0IHsgS3ZMYWJlbE1vZHVsZSB9IGZyb20gJy4uL2t2LWxhYmVsL2t2LWxhYmVsLm1vZHVsZSc7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGRlY2xhcmF0aW9uczogW1xyXG4gICAgS3ZBdmF0YXJDb21wb25lbnRcclxuICBdLFxyXG4gIGltcG9ydHM6IFtcclxuICAgIENvbW1vbk1vZHVsZSxcclxuICAgIEJ1dHRvbk1vZHVsZSxcclxuICAgIEZpbGVVcGxvYWRNb2R1bGUsXHJcbiAgICBTbGlkZXJNb2R1bGUsXHJcbiAgICBGb3Jtc01vZHVsZSxcclxuICAgIFJlYWN0aXZlRm9ybXNNb2R1bGUsXHJcbiAgICBLdkJ1dHRvbk1vZHVsZSxcclxuICAgIEt2TGFiZWxNb2R1bGVcclxuICBdLFxyXG4gIGV4cG9ydHM6IFtcclxuICAgIEt2QXZhdGFyQ29tcG9uZW50XHJcbiAgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgS3ZBdmF0YXJNb2R1bGUgeyB9XHJcbiJdfQ==
57
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia3YtYXZhdGFyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tlZXZvLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2t2LWF2YXRhci9rdi1hdmF0YXIubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM5QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDdEQsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFOUMsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDMUQsT0FBTyxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUMvRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFDNUQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLDZCQUE2QixDQUFDOztBQUM1RCxrRkFBa0Y7QUF1QmxGLE1BQU0sT0FBTyxjQUFjOzhHQUFkLGNBQWM7K0dBQWQsY0FBYyxpQkFuQnZCLGlCQUFpQixhQUlqQixZQUFZO1lBQ1osWUFBWTtZQUNaLGdCQUFnQjtZQUNoQixZQUFZO1lBQ1osV0FBVztZQUNYLG1CQUFtQjtZQUNuQixjQUFjO1lBQ2QsYUFBYTtZQUNiLGFBQWEsYUFJYixpQkFBaUI7K0dBR1IsY0FBYyxZQWZ2QixZQUFZO1lBQ1osWUFBWTtZQUNaLGdCQUFnQjtZQUNoQixZQUFZO1lBQ1osV0FBVztZQUNYLG1CQUFtQjtZQUNuQixjQUFjO1lBQ2QsYUFBYTtZQUNiLGFBQWE7OzJGQU9KLGNBQWM7a0JBckIxQixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRTt3QkFDWixpQkFBaUI7d0JBQ2pCLHVCQUF1QjtxQkFDeEI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLFlBQVk7d0JBQ1osWUFBWTt3QkFDWixnQkFBZ0I7d0JBQ2hCLFlBQVk7d0JBQ1osV0FBVzt3QkFDWCxtQkFBbUI7d0JBQ25CLGNBQWM7d0JBQ2QsYUFBYTt3QkFDYixhQUFhO3FCQUVoQjtvQkFDQyxPQUFPLEVBQUU7d0JBQ1AsaUJBQWlCO3FCQUNsQjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJ1dHRvbk1vZHVsZSB9IGZyb20gJ3ByaW1lbmcvYnV0dG9uJztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgRmlsZVVwbG9hZE1vZHVsZSB9IGZyb20gJ3ByaW1lbmcvZmlsZXVwbG9hZCc7XHJcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHsgU2xpZGVyTW9kdWxlIH0gZnJvbSAncHJpbWVuZy9zbGlkZXInO1xyXG5cclxuaW1wb3J0IHsgS3ZBdmF0YXJDb21wb25lbnQgfSBmcm9tIFwiLi9rdi1hdmF0YXIuY29tcG9uZW50XCI7XHJcbmltcG9ydCB7IEZvcm1zTW9kdWxlLCBSZWFjdGl2ZUZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xyXG5pbXBvcnQgeyBLdkJ1dHRvbk1vZHVsZSB9IGZyb20gJy4uL2t2LWJ1dHRvbi9rdi1idXR0b24ubW9kdWxlJztcclxuaW1wb3J0IHsgS3ZMYWJlbE1vZHVsZSB9IGZyb20gJy4uL2t2LWxhYmVsL2t2LWxhYmVsLm1vZHVsZSc7XHJcbmltcG9ydCB7IEt2TW9kYWxNb2R1bGUgfSBmcm9tIFwiLi4va3YtbW9kYWwva3YtbW9kYWwubW9kdWxlXCI7XHJcbi8vIGltcG9ydCB7IEt2Q3JvcEltYWdlQ29tcG9uZW50IH0gZnJvbSAnLi9rdi1jcm9wLWltYWdlL2t2LWNyb3AtaW1hZ2UuY29tcG9uZW50JztcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgZGVjbGFyYXRpb25zOiBbXHJcbiAgICBLdkF2YXRhckNvbXBvbmVudCxcclxuICAgIC8vIEt2Q3JvcEltYWdlQ29tcG9uZW50XHJcbiAgXSxcclxuICBpbXBvcnRzOiBbXHJcbiAgICBDb21tb25Nb2R1bGUsXHJcbiAgICBCdXR0b25Nb2R1bGUsXHJcbiAgICBGaWxlVXBsb2FkTW9kdWxlLFxyXG4gICAgU2xpZGVyTW9kdWxlLFxyXG4gICAgRm9ybXNNb2R1bGUsXHJcbiAgICBSZWFjdGl2ZUZvcm1zTW9kdWxlLFxyXG4gICAgS3ZCdXR0b25Nb2R1bGUsXHJcbiAgICBLdkxhYmVsTW9kdWxlLFxyXG4gICAgS3ZNb2RhbE1vZHVsZSxcclxuXHJcbl0sXHJcbiAgZXhwb3J0czogW1xyXG4gICAgS3ZBdmF0YXJDb21wb25lbnRcclxuICBdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBLdkF2YXRhck1vZHVsZSB7IH1cclxuIl19