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.
- package/esm2022/lib/api/base-components/base-component-crud.mjs +17 -2
- package/esm2022/lib/api/services/breadcrumbs.service.mjs +14 -1
- package/esm2022/lib/api/services/form.service.mjs +2 -1
- package/esm2022/lib/api/types/breadcrumb.model.mjs +2 -0
- package/esm2022/lib/components/kv-avatar/kv-avatar.component.mjs +46 -132
- package/esm2022/lib/components/kv-avatar/kv-avatar.module.mjs +11 -5
- package/esm2022/lib/components/kv-inputs/kv-select-buttons/kv-select-buttons.component.mjs +3 -3
- package/esm2022/lib/components/kv-layout/layout/kv-layout.component.mjs +3 -3
- package/fesm2022/keevo-components.mjs +193 -243
- package/fesm2022/keevo-components.mjs.map +1 -1
- package/lib/api/services/breadcrumbs.service.d.ts +5 -5
- package/lib/api/services/form.service.d.ts +1 -1
- package/lib/api/types/breadcrumb.model.d.ts +5 -0
- package/lib/components/kv-avatar/kv-avatar.component.d.ts +9 -20
- package/lib/components/kv-avatar/kv-avatar.module.d.ts +2 -1
- package/package.json +1 -1
|
@@ -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(
|
|
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,
|
|
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,
|
|
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,
|
|
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 "
|
|
6
|
-
import * as i4 from "
|
|
7
|
-
import
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
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.
|
|
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.
|
|
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
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
}
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
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
|
-
|
|
150
|
-
|
|
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
|
|
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
|
|
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,
|
|
57
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia3YtYXZhdGFyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2tlZXZvLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2t2LWF2YXRhci9rdi1hdmF0YXIubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM5QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDdEQsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFOUMsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDMUQsT0FBTyxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUMvRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFDNUQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLDZCQUE2QixDQUFDOztBQUM1RCxrRkFBa0Y7QUF1QmxGLE1BQU0sT0FBTyxjQUFjOzhHQUFkLGNBQWM7K0dBQWQsY0FBYyxpQkFuQnZCLGlCQUFpQixhQUlqQixZQUFZO1lBQ1osWUFBWTtZQUNaLGdCQUFnQjtZQUNoQixZQUFZO1lBQ1osV0FBVztZQUNYLG1CQUFtQjtZQUNuQixjQUFjO1lBQ2QsYUFBYTtZQUNiLGFBQWEsYUFJYixpQkFBaUI7K0dBR1IsY0FBYyxZQWZ2QixZQUFZO1lBQ1osWUFBWTtZQUNaLGdCQUFnQjtZQUNoQixZQUFZO1lBQ1osV0FBVztZQUNYLG1CQUFtQjtZQUNuQixjQUFjO1lBQ2QsYUFBYTtZQUNiLGFBQWE7OzJGQU9KLGNBQWM7a0JBckIxQixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRTt3QkFDWixpQkFBaUI7d0JBQ2pCLHVCQUF1QjtxQkFDeEI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLFlBQVk7d0JBQ1osWUFBWTt3QkFDWixnQkFBZ0I7d0JBQ2hCLFlBQVk7d0JBQ1osV0FBVzt3QkFDWCxtQkFBbUI7d0JBQ25CLGNBQWM7d0JBQ2QsYUFBYTt3QkFDYixhQUFhO3FCQUVoQjtvQkFDQyxPQUFPLEVBQUU7d0JBQ1AsaUJBQWlCO3FCQUNsQjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEJ1dHRvbk1vZHVsZSB9IGZyb20gJ3ByaW1lbmcvYnV0dG9uJztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgRmlsZVVwbG9hZE1vZHVsZSB9IGZyb20gJ3ByaW1lbmcvZmlsZXVwbG9hZCc7XHJcbmltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHsgU2xpZGVyTW9kdWxlIH0gZnJvbSAncHJpbWVuZy9zbGlkZXInO1xyXG5cclxuaW1wb3J0IHsgS3ZBdmF0YXJDb21wb25lbnQgfSBmcm9tIFwiLi9rdi1hdmF0YXIuY29tcG9uZW50XCI7XHJcbmltcG9ydCB7IEZvcm1zTW9kdWxlLCBSZWFjdGl2ZUZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xyXG5pbXBvcnQgeyBLdkJ1dHRvbk1vZHVsZSB9IGZyb20gJy4uL2t2LWJ1dHRvbi9rdi1idXR0b24ubW9kdWxlJztcclxuaW1wb3J0IHsgS3ZMYWJlbE1vZHVsZSB9IGZyb20gJy4uL2t2LWxhYmVsL2t2LWxhYmVsLm1vZHVsZSc7XHJcbmltcG9ydCB7IEt2TW9kYWxNb2R1bGUgfSBmcm9tIFwiLi4va3YtbW9kYWwva3YtbW9kYWwubW9kdWxlXCI7XHJcbi8vIGltcG9ydCB7IEt2Q3JvcEltYWdlQ29tcG9uZW50IH0gZnJvbSAnLi9rdi1jcm9wLWltYWdlL2t2LWNyb3AtaW1hZ2UuY29tcG9uZW50JztcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgZGVjbGFyYXRpb25zOiBbXHJcbiAgICBLdkF2YXRhckNvbXBvbmVudCxcclxuICAgIC8vIEt2Q3JvcEltYWdlQ29tcG9uZW50XHJcbiAgXSxcclxuICBpbXBvcnRzOiBbXHJcbiAgICBDb21tb25Nb2R1bGUsXHJcbiAgICBCdXR0b25Nb2R1bGUsXHJcbiAgICBGaWxlVXBsb2FkTW9kdWxlLFxyXG4gICAgU2xpZGVyTW9kdWxlLFxyXG4gICAgRm9ybXNNb2R1bGUsXHJcbiAgICBSZWFjdGl2ZUZvcm1zTW9kdWxlLFxyXG4gICAgS3ZCdXR0b25Nb2R1bGUsXHJcbiAgICBLdkxhYmVsTW9kdWxlLFxyXG4gICAgS3ZNb2RhbE1vZHVsZSxcclxuXHJcbl0sXHJcbiAgZXhwb3J0czogW1xyXG4gICAgS3ZBdmF0YXJDb21wb25lbnRcclxuICBdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBLdkF2YXRhck1vZHVsZSB7IH1cclxuIl19
|