lib-portal-angular 0.0.47 → 0.0.49

Sign up to get free protection for your applications and to get access to all the features.
@@ -0,0 +1,27 @@
1
+ import { Component } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class AppBackgroundComponent {
4
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AppBackgroundComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
5
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: AppBackgroundComponent, selector: "argenta-app-background", ngImport: i0, template: `
6
+ <div class="row row-car">
7
+ <div class="card">
8
+ <div class="card-content">
9
+ <ng-content></ng-content>
10
+ </div>
11
+ </div>
12
+ </div>
13
+ `, isInline: true, styles: [".card{border-radius:10px;padding:1rem;background-color:#fff;border:none}.row-car{margin-left:.8rem;margin-right:.8rem}\n"] }); }
14
+ }
15
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AppBackgroundComponent, decorators: [{
16
+ type: Component,
17
+ args: [{ selector: 'argenta-app-background', template: `
18
+ <div class="row row-car">
19
+ <div class="card">
20
+ <div class="card-content">
21
+ <ng-content></ng-content>
22
+ </div>
23
+ </div>
24
+ </div>
25
+ `, styles: [".card{border-radius:10px;padding:1rem;background-color:#fff;border:none}.row-car{margin-left:.8rem;margin-right:.8rem}\n"] }]
26
+ }] });
27
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwLWJhY2tncm91bmQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbGliLXBvcnRhbC1hbmd1bGFyL3NyYy9saWIvY29tcG9uZW50cy9hcHAtYmFja2dyb3VuZC9hcHAtYmFja2dyb3VuZC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUEwQjFDLE1BQU0sT0FBTyxzQkFBc0I7K0dBQXRCLHNCQUFzQjttR0FBdEIsc0JBQXNCLDhEQXRCdkI7Ozs7Ozs7O0dBUVQ7OzRGQWNVLHNCQUFzQjtrQkF4QmxDLFNBQVM7K0JBQ0Usd0JBQXdCLFlBQ3hCOzs7Ozs7OztHQVFUIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2FyZ2VudGEtYXBwLWJhY2tncm91bmQnLFxuICB0ZW1wbGF0ZTogYFxuICAgIDxkaXYgY2xhc3M9XCJyb3cgcm93LWNhclwiPlxuICAgICAgICA8ZGl2IGNsYXNzPVwiY2FyZFwiPlxuICAgICAgICAgIDxkaXYgY2xhc3M9XCJjYXJkLWNvbnRlbnRcIj5cbiAgICAgICAgICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbiAgICAgICAgICA8L2Rpdj5cbiAgICAgICAgPC9kaXY+ICAgICAgXG4gICAgPC9kaXY+XG4gIGAsXG4gIHN0eWxlczogW2AgICBcbiAgICAuY2FyZCB7XG4gICAgICBib3JkZXItcmFkaXVzOiAxMHB4O1xuICAgICAgcGFkZGluZzogMXJlbTtcbiAgICAgIGJhY2tncm91bmQtY29sb3I6ICNGRkZGRkY7IC8qIENvciBkZSBmdW5kbyBhanVzdGFkYSAqL1xuICAgICAgYm9yZGVyOiBub25lOyAvKiBSZW1vdmVyIGJvcmRhICovXG4gICAgfVxuICAgIC5yb3ctY2Fye1xuICAgICAgbWFyZ2luLWxlZnQ6IDAuOHJlbTtcbiAgICAgIG1hcmdpbi1yaWdodDogMC44cmVtO1xuICAgIH1cbiAgYF1cbn0pXG5leHBvcnQgY2xhc3MgQXBwQmFja2dyb3VuZENvbXBvbmVudCB7IH1cbiJdfQ==
@@ -0,0 +1,60 @@
1
+ import { Component, Input, Output, EventEmitter, ChangeDetectionStrategy } from '@angular/core';
2
+ import { ButtonClasses } from '../../enum/ButtonClassesEnum';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "../../service/auth-service.service";
5
+ import * as i2 from "@angular/common";
6
+ import * as i3 from "../button/button.component";
7
+ export class BasicRegistrationComponent {
8
+ constructor(authService) {
9
+ this.authService = authService;
10
+ this.cancelLabel = 'Cancelar';
11
+ this.saveLabel = 'Salvar';
12
+ this.cancelPermissions = [];
13
+ this.savePermissions = [];
14
+ this.cancelClick = new EventEmitter();
15
+ this.saveClick = new EventEmitter();
16
+ this.ButtonClasses = ButtonClasses;
17
+ }
18
+ hasPermission(permissions) {
19
+ if (!permissions || permissions.length === 0) {
20
+ return true;
21
+ }
22
+ try {
23
+ return this.authService.hasPermission(permissions);
24
+ }
25
+ catch (error) {
26
+ if (error instanceof Error) {
27
+ console.error('Permission error:', error.message);
28
+ }
29
+ else {
30
+ console.error('Unknown error occurred during permission check');
31
+ }
32
+ return true;
33
+ }
34
+ }
35
+ handleCancel(event) {
36
+ this.cancelClick.emit(event);
37
+ }
38
+ handleSave(event) {
39
+ this.saveClick.emit(event);
40
+ }
41
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: BasicRegistrationComponent, deps: [{ token: i1.AuthService }], target: i0.ɵɵFactoryTarget.Component }); }
42
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: BasicRegistrationComponent, selector: "argenta-basic-registration", inputs: { cancelLabel: "cancelLabel", saveLabel: "saveLabel", cancelPermissions: "cancelPermissions", savePermissions: "savePermissions" }, outputs: { cancelClick: "cancelClick", saveClick: "saveClick" }, ngImport: i0, template: "<div class=\"row row-car\">\n <div class=\"card\">\n <div class=\"card-content\">\n <ng-content></ng-content> <!-- Permite a inclus\u00E3o de conte\u00FAdo din\u00E2mico -->\n </div>\n <div class=\"card-footer\">\n <div class=\"button-group\">\n <argenta-custom-button\n *ngIf=\"hasPermission(cancelPermissions)\"\n [type]=\"'button'\"\n [label]=\"cancelLabel\"\n [btnClass]=\"ButtonClasses.Light\"\n (onButtonClick)=\"handleCancel($event)\"\n class=\"argenta-custom-button\">\n </argenta-custom-button>\n <argenta-custom-button\n *ngIf=\"hasPermission(savePermissions)\"\n [type]=\"'submit'\"\n [label]=\"saveLabel\"\n [btnClass]=\"ButtonClasses.Primary\"\n (onButtonClick)=\"handleSave($event)\"\n class=\"argenta-custom-button\">\n </argenta-custom-button>\n </div>\n </div>\n </div> \n</div>\n", styles: ["@charset \"UTF-8\";.card{border-radius:10px;padding:1rem;background-color:#fff;border:none}.card-footer{display:flex;justify-content:flex-end;margin-top:1rem;padding-top:1rem;border-radius:.25rem}.button-group{display:flex;gap:1rem;height:3rem}.argenta-custom-button{height:100%}.row-car{margin-left:.8rem;margin-right:.8rem}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.ButtonComponent, selector: "argenta-custom-button", inputs: ["type", "label", "btnClass", "fontSize", "disabled", "autofocus", "form", "formaction", "formenctype", "formmethod", "formnovalidate", "formtarget", "name", "value", "permissions"], outputs: ["onButtonClick"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
43
+ }
44
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: BasicRegistrationComponent, decorators: [{
45
+ type: Component,
46
+ args: [{ selector: 'argenta-basic-registration', changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"row row-car\">\n <div class=\"card\">\n <div class=\"card-content\">\n <ng-content></ng-content> <!-- Permite a inclus\u00E3o de conte\u00FAdo din\u00E2mico -->\n </div>\n <div class=\"card-footer\">\n <div class=\"button-group\">\n <argenta-custom-button\n *ngIf=\"hasPermission(cancelPermissions)\"\n [type]=\"'button'\"\n [label]=\"cancelLabel\"\n [btnClass]=\"ButtonClasses.Light\"\n (onButtonClick)=\"handleCancel($event)\"\n class=\"argenta-custom-button\">\n </argenta-custom-button>\n <argenta-custom-button\n *ngIf=\"hasPermission(savePermissions)\"\n [type]=\"'submit'\"\n [label]=\"saveLabel\"\n [btnClass]=\"ButtonClasses.Primary\"\n (onButtonClick)=\"handleSave($event)\"\n class=\"argenta-custom-button\">\n </argenta-custom-button>\n </div>\n </div>\n </div> \n</div>\n", styles: ["@charset \"UTF-8\";.card{border-radius:10px;padding:1rem;background-color:#fff;border:none}.card-footer{display:flex;justify-content:flex-end;margin-top:1rem;padding-top:1rem;border-radius:.25rem}.button-group{display:flex;gap:1rem;height:3rem}.argenta-custom-button{height:100%}.row-car{margin-left:.8rem;margin-right:.8rem}\n"] }]
47
+ }], ctorParameters: function () { return [{ type: i1.AuthService }]; }, propDecorators: { cancelLabel: [{
48
+ type: Input
49
+ }], saveLabel: [{
50
+ type: Input
51
+ }], cancelPermissions: [{
52
+ type: Input
53
+ }], savePermissions: [{
54
+ type: Input
55
+ }], cancelClick: [{
56
+ type: Output
57
+ }], saveClick: [{
58
+ type: Output
59
+ }] } });
60
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFzaWMtcmVnaXN0cmF0aW9uLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2xpYi1wb3J0YWwtYW5ndWxhci9zcmMvbGliL2NvbXBvbmVudHMvYmFzaWMtcmVnaXN0cmF0aW9uL2Jhc2ljLXJlZ2lzdHJhdGlvbi5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9saWItcG9ydGFsLWFuZ3VsYXIvc3JjL2xpYi9jb21wb25lbnRzL2Jhc2ljLXJlZ2lzdHJhdGlvbi9iYXNpYy1yZWdpc3RyYXRpb24uY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLFlBQVksRUFBRSx1QkFBdUIsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVoRyxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sOEJBQThCLENBQUM7Ozs7O0FBUTdELE1BQU0sT0FBTywwQkFBMEI7SUFVckMsWUFBb0IsV0FBd0I7UUFBeEIsZ0JBQVcsR0FBWCxXQUFXLENBQWE7UUFUbkMsZ0JBQVcsR0FBVyxVQUFVLENBQUM7UUFDakMsY0FBUyxHQUFXLFFBQVEsQ0FBQztRQUM3QixzQkFBaUIsR0FBYSxFQUFFLENBQUM7UUFDakMsb0JBQWUsR0FBYSxFQUFFLENBQUM7UUFFOUIsZ0JBQVcsR0FBd0IsSUFBSSxZQUFZLEVBQVMsQ0FBQztRQUM3RCxjQUFTLEdBQXdCLElBQUksWUFBWSxFQUFTLENBQUM7UUFDckUsa0JBQWEsR0FBRyxhQUFhLENBQUM7SUFFa0IsQ0FBQztJQUVqRCxhQUFhLENBQUMsV0FBcUI7UUFDakMsSUFBSSxDQUFDLFdBQVcsSUFBSSxXQUFXLENBQUMsTUFBTSxLQUFLLENBQUMsRUFBRTtZQUM1QyxPQUFPLElBQUksQ0FBQztTQUNiO1FBRUQsSUFBSTtZQUNGLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQyxhQUFhLENBQUMsV0FBVyxDQUFDLENBQUM7U0FDcEQ7UUFBQyxPQUFPLEtBQWMsRUFBRTtZQUN2QixJQUFJLEtBQUssWUFBWSxLQUFLLEVBQUU7Z0JBQzFCLE9BQU8sQ0FBQyxLQUFLLENBQUMsbUJBQW1CLEVBQUUsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO2FBQ25EO2lCQUFNO2dCQUNMLE9BQU8sQ0FBQyxLQUFLLENBQUMsZ0RBQWdELENBQUMsQ0FBQzthQUNqRTtZQUNELE9BQU8sSUFBSSxDQUFDO1NBQ2I7SUFDSCxDQUFDO0lBRUQsWUFBWSxDQUFDLEtBQVk7UUFDdkIsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDL0IsQ0FBQztJQUVELFVBQVUsQ0FBQyxLQUFZO1FBQ3JCLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQzdCLENBQUM7K0dBbkNVLDBCQUEwQjttR0FBMUIsMEJBQTBCLCtRQ1Z2Qyx5OEJBMkJBOzs0RkRqQmEsMEJBQTBCO2tCQU50QyxTQUFTOytCQUNFLDRCQUE0QixtQkFHckIsdUJBQXVCLENBQUMsTUFBTTtrR0FHdEMsV0FBVztzQkFBbkIsS0FBSztnQkFDRyxTQUFTO3NCQUFqQixLQUFLO2dCQUNHLGlCQUFpQjtzQkFBekIsS0FBSztnQkFDRyxlQUFlO3NCQUF2QixLQUFLO2dCQUVJLFdBQVc7c0JBQXBCLE1BQU07Z0JBQ0csU0FBUztzQkFBbEIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIE91dHB1dCwgRXZlbnRFbWl0dGVyLCBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQXV0aFNlcnZpY2UgfSBmcm9tICcuLi8uLi9zZXJ2aWNlL2F1dGgtc2VydmljZS5zZXJ2aWNlJztcbmltcG9ydCB7IEJ1dHRvbkNsYXNzZXMgfSBmcm9tICcuLi8uLi9lbnVtL0J1dHRvbkNsYXNzZXNFbnVtJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYXJnZW50YS1iYXNpYy1yZWdpc3RyYXRpb24nLFxuICB0ZW1wbGF0ZVVybDogJy4vYmFzaWMtcmVnaXN0cmF0aW9uLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vYmFzaWMtcmVnaXN0cmF0aW9uLmNvbXBvbmVudC5zY3NzJ10sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIEJhc2ljUmVnaXN0cmF0aW9uQ29tcG9uZW50IHtcbiAgQElucHV0KCkgY2FuY2VsTGFiZWw6IHN0cmluZyA9ICdDYW5jZWxhcic7XG4gIEBJbnB1dCgpIHNhdmVMYWJlbDogc3RyaW5nID0gJ1NhbHZhcic7XG4gIEBJbnB1dCgpIGNhbmNlbFBlcm1pc3Npb25zOiBzdHJpbmdbXSA9IFtdO1xuICBASW5wdXQoKSBzYXZlUGVybWlzc2lvbnM6IHN0cmluZ1tdID0gW107XG5cbiAgQE91dHB1dCgpIGNhbmNlbENsaWNrOiBFdmVudEVtaXR0ZXI8RXZlbnQ+ID0gbmV3IEV2ZW50RW1pdHRlcjxFdmVudD4oKTtcbiAgQE91dHB1dCgpIHNhdmVDbGljazogRXZlbnRFbWl0dGVyPEV2ZW50PiA9IG5ldyBFdmVudEVtaXR0ZXI8RXZlbnQ+KCk7XG4gIEJ1dHRvbkNsYXNzZXMgPSBCdXR0b25DbGFzc2VzO1xuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgYXV0aFNlcnZpY2U6IEF1dGhTZXJ2aWNlKSB7IH1cblxuICBoYXNQZXJtaXNzaW9uKHBlcm1pc3Npb25zOiBzdHJpbmdbXSk6IGJvb2xlYW4ge1xuICAgIGlmICghcGVybWlzc2lvbnMgfHwgcGVybWlzc2lvbnMubGVuZ3RoID09PSAwKSB7XG4gICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9XG5cbiAgICB0cnkge1xuICAgICAgcmV0dXJuIHRoaXMuYXV0aFNlcnZpY2UuaGFzUGVybWlzc2lvbihwZXJtaXNzaW9ucyk7XG4gICAgfSBjYXRjaCAoZXJyb3I6IHVua25vd24pIHtcbiAgICAgIGlmIChlcnJvciBpbnN0YW5jZW9mIEVycm9yKSB7XG4gICAgICAgIGNvbnNvbGUuZXJyb3IoJ1Blcm1pc3Npb24gZXJyb3I6JywgZXJyb3IubWVzc2FnZSk7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICBjb25zb2xlLmVycm9yKCdVbmtub3duIGVycm9yIG9jY3VycmVkIGR1cmluZyBwZXJtaXNzaW9uIGNoZWNrJyk7XG4gICAgICB9XG4gICAgICByZXR1cm4gdHJ1ZTtcbiAgICB9XG4gIH1cblxuICBoYW5kbGVDYW5jZWwoZXZlbnQ6IEV2ZW50KSB7XG4gICAgdGhpcy5jYW5jZWxDbGljay5lbWl0KGV2ZW50KTtcbiAgfVxuXG4gIGhhbmRsZVNhdmUoZXZlbnQ6IEV2ZW50KSB7XG4gICAgdGhpcy5zYXZlQ2xpY2suZW1pdChldmVudCk7XG4gIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJyb3cgcm93LWNhclwiPlxuICA8ZGl2IGNsYXNzPVwiY2FyZFwiPlxuICAgIDxkaXYgY2xhc3M9XCJjYXJkLWNvbnRlbnRcIj5cbiAgICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD4gPCEtLSBQZXJtaXRlIGEgaW5jbHVzw6NvIGRlIGNvbnRlw7pkbyBkaW7Dom1pY28gLS0+XG4gICAgPC9kaXY+XG4gICAgPGRpdiBjbGFzcz1cImNhcmQtZm9vdGVyXCI+XG4gICAgICA8ZGl2IGNsYXNzPVwiYnV0dG9uLWdyb3VwXCI+XG4gICAgICAgIDxhcmdlbnRhLWN1c3RvbS1idXR0b25cbiAgICAgICAgICAqbmdJZj1cImhhc1Blcm1pc3Npb24oY2FuY2VsUGVybWlzc2lvbnMpXCJcbiAgICAgICAgICBbdHlwZV09XCInYnV0dG9uJ1wiXG4gICAgICAgICAgW2xhYmVsXT1cImNhbmNlbExhYmVsXCJcbiAgICAgICAgICBbYnRuQ2xhc3NdPVwiQnV0dG9uQ2xhc3Nlcy5MaWdodFwiXG4gICAgICAgICAgKG9uQnV0dG9uQ2xpY2spPVwiaGFuZGxlQ2FuY2VsKCRldmVudClcIlxuICAgICAgICAgIGNsYXNzPVwiYXJnZW50YS1jdXN0b20tYnV0dG9uXCI+XG4gICAgICAgIDwvYXJnZW50YS1jdXN0b20tYnV0dG9uPlxuICAgICAgICA8YXJnZW50YS1jdXN0b20tYnV0dG9uXG4gICAgICAgICAgKm5nSWY9XCJoYXNQZXJtaXNzaW9uKHNhdmVQZXJtaXNzaW9ucylcIlxuICAgICAgICAgIFt0eXBlXT1cIidzdWJtaXQnXCJcbiAgICAgICAgICBbbGFiZWxdPVwic2F2ZUxhYmVsXCJcbiAgICAgICAgICBbYnRuQ2xhc3NdPVwiQnV0dG9uQ2xhc3Nlcy5QcmltYXJ5XCJcbiAgICAgICAgICAob25CdXR0b25DbGljayk9XCJoYW5kbGVTYXZlKCRldmVudClcIlxuICAgICAgICAgIGNsYXNzPVwiYXJnZW50YS1jdXN0b20tYnV0dG9uXCI+XG4gICAgICAgIDwvYXJnZW50YS1jdXN0b20tYnV0dG9uPlxuICAgICAgPC9kaXY+XG4gICAgPC9kaXY+XG4gIDwvZGl2PiAgICAgIFxuPC9kaXY+XG4iXX0=
@@ -1,4 +1,4 @@
1
- import { ChangeDetectionStrategy, Component, EventEmitter, HostListener, Input, Output } from '@angular/core';
1
+ import { Component, EventEmitter, Input, Output, ChangeDetectionStrategy } from '@angular/core';
2
2
  import { ButtonClasses } from '../../enum/ButtonClassesEnum';
3
3
  import * as i0 from "@angular/core";
4
4
  import * as i1 from "../../service/auth-service.service";
@@ -20,33 +20,40 @@ export class ButtonComponent {
20
20
  this.formtarget = null;
21
21
  this.name = null;
22
22
  this.value = null;
23
- this.marginTop = 0;
24
- this.marginBottom = 0;
25
- this.marginLeft = 0;
26
- this.marginRight = 0;
27
23
  this.permissions = [];
28
- this.clickEvent = new EventEmitter();
24
+ this.onButtonClick = new EventEmitter();
29
25
  this.isHovered = false;
30
26
  this.isActive = false;
31
27
  }
32
28
  ngOnInit() {
33
- // O componente não precisa capturar erros do serviço, apenas chama o método de verificação
29
+ this.validateInputs();
34
30
  }
35
- onMouseEnter() {
36
- this.isHovered = true;
37
- }
38
- onMouseLeave() {
39
- this.isHovered = false;
40
- this.isActive = false;
41
- }
42
- onMouseDown() {
43
- this.isActive = true;
31
+ ngOnChanges(changes) {
32
+ if (changes) {
33
+ this.validateInputs();
34
+ }
44
35
  }
45
- onMouseUp() {
46
- this.isActive = false;
36
+ validateInputs() {
37
+ const validTypes = ['button', 'submit', 'reset'];
38
+ const validClasses = Object.values(ButtonClasses);
39
+ if (!validTypes.includes(this.type)) {
40
+ throw new Error(`Invalid type: ${this.type}. Allowed values are: ${validTypes.join(', ')}`);
41
+ }
42
+ if (!validClasses.includes(this.btnClass)) {
43
+ throw new Error(`Invalid btnClass: ${this.btnClass}. Allowed values are: ${validClasses.join(', ')}`);
44
+ }
45
+ if (typeof this.disabled !== 'boolean') {
46
+ throw new Error(`Invalid disabled value: ${this.disabled}. It should be a boolean.`);
47
+ }
48
+ if (typeof this.autofocus !== 'boolean') {
49
+ throw new Error(`Invalid autofocus value: ${this.autofocus}. It should be a boolean.`);
50
+ }
51
+ if (this.permissions && !Array.isArray(this.permissions)) {
52
+ throw new Error(`Invalid permissions value: ${this.permissions}. It should be an array of strings.`);
53
+ }
47
54
  }
48
55
  onClick(event) {
49
- this.clickEvent.emit(event);
56
+ this.onButtonClick.emit(event);
50
57
  }
51
58
  get dynamicStyles() {
52
59
  return this.calculateDynamicStyles();
@@ -94,10 +101,6 @@ export class ButtonComponent {
94
101
  const activeFilter = this.isActive ? 'brightness(60%)' : hoverFilter; // Adjusted active brightness
95
102
  return {
96
103
  'font-size': this.fontSize,
97
- 'margin-top': `${this.marginTop}rem`,
98
- 'margin-bottom': `${this.marginBottom}rem`,
99
- 'margin-left': `${this.marginLeft}rem`,
100
- 'margin-right': `${this.marginRight}rem`,
101
104
  'background-color': backgroundColor,
102
105
  'color': textColor,
103
106
  'border': borderColor ? `1px solid ${borderColor}` : 'none',
@@ -122,8 +125,16 @@ export class ButtonComponent {
122
125
  return true;
123
126
  }
124
127
  }
128
+ onCancel(event) {
129
+ console.log('Cancel button clicked', event);
130
+ // Lógica para o cancelamento
131
+ }
132
+ onSave(event) {
133
+ console.log('Save button clicked', event);
134
+ // Lógica para salvar alterações
135
+ }
125
136
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ButtonComponent, deps: [{ token: i1.AuthService }], target: i0.ɵɵFactoryTarget.Component }); }
126
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ButtonComponent, selector: "argenta-custom-button", inputs: { type: "type", label: "label", btnClass: "btnClass", fontSize: "fontSize", disabled: "disabled", autofocus: "autofocus", form: "form", formaction: "formaction", formenctype: "formenctype", formmethod: "formmethod", formnovalidate: "formnovalidate", formtarget: "formtarget", name: "name", value: "value", marginTop: "marginTop", marginBottom: "marginBottom", marginLeft: "marginLeft", marginRight: "marginRight", permissions: "permissions" }, outputs: { clickEvent: "clickEvent" }, host: { listeners: { "mouseenter": "onMouseEnter()", "mouseleave": "onMouseLeave()", "mousedown": "onMouseDown()", "mouseup": "onMouseUp()" } }, ngImport: i0, template: `
137
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ButtonComponent, selector: "argenta-custom-button", inputs: { type: "type", label: "label", btnClass: "btnClass", fontSize: "fontSize", disabled: "disabled", autofocus: "autofocus", form: "form", formaction: "formaction", formenctype: "formenctype", formmethod: "formmethod", formnovalidate: "formnovalidate", formtarget: "formtarget", name: "name", value: "value", permissions: "permissions" }, outputs: { onButtonClick: "onButtonClick" }, usesOnChanges: true, ngImport: i0, template: `
127
138
  <ng-container *ngIf="hasPermission()">
128
139
  <button [type]="type"
129
140
  class="btn"
@@ -196,29 +207,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
196
207
  type: Input
197
208
  }], value: [{
198
209
  type: Input
199
- }], marginTop: [{
200
- type: Input
201
- }], marginBottom: [{
202
- type: Input
203
- }], marginLeft: [{
204
- type: Input
205
- }], marginRight: [{
206
- type: Input
207
210
  }], permissions: [{
208
211
  type: Input
209
- }], clickEvent: [{
212
+ }], onButtonClick: [{
210
213
  type: Output
211
- }], onMouseEnter: [{
212
- type: HostListener,
213
- args: ['mouseenter']
214
- }], onMouseLeave: [{
215
- type: HostListener,
216
- args: ['mouseleave']
217
- }], onMouseDown: [{
218
- type: HostListener,
219
- args: ['mousedown']
220
- }], onMouseUp: [{
221
- type: HostListener,
222
- args: ['mouseup']
223
214
  }] } });
224
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.component.js","sourceRoot":"","sources":["../../../../../../projects/lib-portal-angular/src/lib/components/button/button.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, HostListener, Input, OnInit, Output } from '@angular/core';\nimport { ButtonClasses } from '../../enum/ButtonClassesEnum';\nimport { AuthService } from '../../service/auth-service.service';\n\n@Component({\n  selector: 'argenta-custom-button',\n  template: `\n    <ng-container *ngIf=\"hasPermission()\">\n      <button [type]=\"type\"\n              class=\"btn\"\n              [ngClass]=\"btnClass\"\n              [ngStyle]=\"dynamicStyles\"\n              (click)=\"onClick($event)\"\n              [disabled]=\"disabled\"\n              [attr.autofocus]=\"autofocus ? true : null\"\n              [attr.form]=\"form\"\n              [attr.formaction]=\"formaction\"\n              [attr.formenctype]=\"formenctype\"\n              [attr.formmethod]=\"formmethod\"\n              [attr.formnovalidate]=\"formnovalidate\"\n              [attr.formtarget]=\"formtarget\"\n              [attr.name]=\"name\"\n              [attr.value]=\"value\">\n        {{ label }}\n      </button>\n    </ng-container>\n  `,\n  styles: [`\n    .btn {\n      padding: 0.5rem 1rem;\n      border-radius: 0.25rem;\n      transition: background-color 0.3s, border-color 0.3s, filter 0.3s;\n      font-family: 'Inter', sans-serif;\n      font-size: 16px;\n      font-weight: 600;\n      line-height: 24px;\n      letter-spacing: 0.005em;\n      text-align: left;\n    }\n  `],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ButtonComponent implements OnInit {\n  @Input() type: string = 'button';\n  @Input() label: string = 'Submit';\n  @Input() btnClass: ButtonClasses = ButtonClasses.Primary;\n  @Input() fontSize: string = '1rem';\n  @Input() disabled: boolean = false;\n  @Input() autofocus: boolean = false;\n  @Input() form: string | null = null;\n  @Input() formaction: string | null = null;\n  @Input() formenctype: string | null = null;\n  @Input() formmethod: string | null = null;\n  @Input() formnovalidate: boolean = false;\n  @Input() formtarget: string | null = null;\n  @Input() name: string | null = null;\n  @Input() value: string | null = null;\n  @Input() marginTop: number = 0;\n  @Input() marginBottom: number = 0;\n  @Input() marginLeft: number = 0;\n  @Input() marginRight: number = 0;\n  @Input() permissions: string[] = [];\n\n  @Output() clickEvent: EventEmitter<Event> = new EventEmitter<Event>();\n\n  private isHovered: boolean = false;\n  private isActive: boolean = false;\n\n  constructor(private authService: AuthService) { }\n\n  ngOnInit(): void {\n    // O componente não precisa capturar erros do serviço, apenas chama o método de verificação\n  }\n\n  @HostListener('mouseenter') onMouseEnter() {\n    this.isHovered = true;\n  }\n\n  @HostListener('mouseleave') onMouseLeave() {\n    this.isHovered = false;\n    this.isActive = false;\n  }\n\n  @HostListener('mousedown') onMouseDown() {\n    this.isActive = true;\n  }\n\n  @HostListener('mouseup') onMouseUp() {\n    this.isActive = false;\n  }\n\n  onClick(event: Event) {\n    this.clickEvent.emit(event);\n  }\n\n  get dynamicStyles() {\n    return this.calculateDynamicStyles();\n  }\n\n  private calculateDynamicStyles() {\n    let backgroundColor = '';\n    let textColor = '#fff'; // Default text color\n    let borderColor = '';\n\n    switch (this.btnClass) {\n      case ButtonClasses.Primary:\n        backgroundColor = '#00444C';\n        break;\n      case ButtonClasses.Secondary:\n        backgroundColor = '#2CA58D';\n        break;\n      case ButtonClasses.Success:\n        backgroundColor = '#00C853';\n        break;\n      case ButtonClasses.Danger:\n        backgroundColor = '#D32F2F';\n        break;\n      case ButtonClasses.Warning:\n        backgroundColor = '#FFC107';\n        break;\n      case ButtonClasses.Info:\n        backgroundColor = '#3EC9D6';\n        break;\n      case ButtonClasses.Light:\n        backgroundColor = '#EEF2F6';\n        textColor = '#00444C'; // Custom text color for Light\n        break;\n      case ButtonClasses.Dark:\n        backgroundColor = '#111936';\n        break;\n      case ButtonClasses.Link:\n        backgroundColor = 'transparent';\n        borderColor = '#DDE5E9';\n        textColor = '#00444C'; // Custom text color for Link\n        break;\n      default:\n        backgroundColor = '#00444C';\n        break;\n    }\n\n    const hoverFilter = this.isHovered ? 'brightness(80%)' : 'none'; // Adjusted hover brightness\n    const activeFilter = this.isActive ? 'brightness(60%)' : hoverFilter; // Adjusted active brightness\n\n    return {\n      'font-size': this.fontSize,\n      'margin-top': `${this.marginTop}rem`,\n      'margin-bottom': `${this.marginBottom}rem`,\n      'margin-left': `${this.marginLeft}rem`,\n      'margin-right': `${this.marginRight}rem`,\n      'background-color': backgroundColor,\n      'color': textColor,\n      'border': borderColor ? `1px solid ${borderColor}` : 'none',\n      'transition': 'background-color 0.3s, border-color 0.3s, filter 0.3s',\n      'filter': activeFilter\n    };\n  }\n\n  hasPermission(): boolean {\n    if (!this.permissions || this.permissions.length === 0) {\n      return true;\n    }\n\n    try {\n      return this.authService.hasPermission(this.permissions);\n    } catch (error: unknown) {\n      if (error instanceof Error) {\n        console.error('Permission error:', error.message);\n      } else {\n        console.error('Unknown error occurred during permission check');\n      }\n      return true; \n    }\n  }\n}\n"]}
215
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button.component.js","sourceRoot":"","sources":["../../../../../../projects/lib-portal-angular/src/lib/components/button/button.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, Output, OnInit, OnChanges, SimpleChanges, ChangeDetectionStrategy } from '@angular/core';\nimport { ButtonClasses } from '../../enum/ButtonClassesEnum';\nimport { AuthService } from '../../service/auth-service.service';\n\n@Component({\n  selector: 'argenta-custom-button',\n  template: `\n    <ng-container *ngIf=\"hasPermission()\">\n      <button [type]=\"type\"\n              class=\"btn\"\n              [ngClass]=\"btnClass\"\n              [ngStyle]=\"dynamicStyles\"\n              (click)=\"onClick($event)\"\n              [disabled]=\"disabled\"\n              [attr.autofocus]=\"autofocus ? true : null\"\n              [attr.form]=\"form\"\n              [attr.formaction]=\"formaction\"\n              [attr.formenctype]=\"formenctype\"\n              [attr.formmethod]=\"formmethod\"\n              [attr.formnovalidate]=\"formnovalidate\"\n              [attr.formtarget]=\"formtarget\"\n              [attr.name]=\"name\"\n              [attr.value]=\"value\">\n        {{ label }}\n      </button>\n    </ng-container>\n  `,\n  styles: [`\n    .btn {\n      padding: 0.5rem 1rem;\n      border-radius: 0.25rem;\n      transition: background-color 0.3s, border-color 0.3s, filter 0.3s;\n      font-family: 'Inter', sans-serif;\n      font-size: 16px;\n      font-weight: 600;\n      line-height: 24px;\n      letter-spacing: 0.005em;\n      text-align: left;\n    }\n  `],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class ButtonComponent implements OnInit, OnChanges {\n  @Input() type: string = 'button';\n  @Input() label: string = 'Submit';\n  @Input() btnClass: ButtonClasses = ButtonClasses.Primary;\n  @Input() fontSize: string = '1rem';\n  @Input() disabled: boolean = false;\n  @Input() autofocus: boolean = false;\n  @Input() form: string | null = null;\n  @Input() formaction: string | null = null;\n  @Input() formenctype: string | null = null;\n  @Input() formmethod: string | null = null;\n  @Input() formnovalidate: boolean = false;\n  @Input() formtarget: string | null = null;\n  @Input() name: string | null = null;\n  @Input() value: string | null = null;\n  @Input() permissions: string[] = [];\n\n  @Output() onButtonClick: EventEmitter<Event> = new EventEmitter<Event>();\n\n  private isHovered: boolean = false;\n  private isActive: boolean = false;\n\n  constructor(private authService: AuthService) { }\n\n  ngOnInit(): void {\n    this.validateInputs();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes) {\n      this.validateInputs();\n    }\n  }\n\n  private validateInputs(): void {\n    const validTypes = ['button', 'submit', 'reset'];\n    const validClasses = Object.values(ButtonClasses);\n\n    if (!validTypes.includes(this.type)) {\n      throw new Error(`Invalid type: ${this.type}. Allowed values are: ${validTypes.join(', ')}`);\n    }\n\n    if (!validClasses.includes(this.btnClass)) {\n      throw new Error(`Invalid btnClass: ${this.btnClass}. Allowed values are: ${validClasses.join(', ')}`);\n    }\n\n    if (typeof this.disabled !== 'boolean') {\n      throw new Error(`Invalid disabled value: ${this.disabled}. It should be a boolean.`);\n    }\n\n    if (typeof this.autofocus !== 'boolean') {\n      throw new Error(`Invalid autofocus value: ${this.autofocus}. It should be a boolean.`);\n    }\n\n    if (this.permissions && !Array.isArray(this.permissions)) {\n      throw new Error(`Invalid permissions value: ${this.permissions}. It should be an array of strings.`);\n    }\n  }\n\n  onClick(event: Event) {\n    this.onButtonClick.emit(event);\n  }\n\n  get dynamicStyles() {\n    return this.calculateDynamicStyles();\n  }\n\n  private calculateDynamicStyles() {\n    let backgroundColor = '';\n    let textColor = '#fff'; // Default text color\n    let borderColor = '';\n\n    switch (this.btnClass) {\n      case ButtonClasses.Primary:\n        backgroundColor = '#00444C';\n        break;\n      case ButtonClasses.Secondary:\n        backgroundColor = '#2CA58D';\n        break;\n      case ButtonClasses.Success:\n        backgroundColor = '#00C853';\n        break;\n      case ButtonClasses.Danger:\n        backgroundColor = '#D32F2F';\n        break;\n      case ButtonClasses.Warning:\n        backgroundColor = '#FFC107';\n        break;\n      case ButtonClasses.Info:\n        backgroundColor = '#3EC9D6';\n        break;\n      case ButtonClasses.Light:\n        backgroundColor = '#EEF2F6';\n        textColor = '#00444C'; // Custom text color for Light\n        break;\n      case ButtonClasses.Dark:\n        backgroundColor = '#111936';\n        break;\n      case ButtonClasses.Link:\n        backgroundColor = 'transparent';\n        borderColor = '#DDE5E9';\n        textColor = '#00444C'; // Custom text color for Link\n        break;\n      default:\n        backgroundColor = '#00444C';\n        break;\n    }\n\n    const hoverFilter = this.isHovered ? 'brightness(80%)' : 'none'; // Adjusted hover brightness\n    const activeFilter = this.isActive ? 'brightness(60%)' : hoverFilter; // Adjusted active brightness\n\n    return {\n      'font-size': this.fontSize,\n      'background-color': backgroundColor,\n      'color': textColor,\n      'border': borderColor ? `1px solid ${borderColor}` : 'none',\n      'transition': 'background-color 0.3s, border-color 0.3s, filter 0.3s',\n      'filter': activeFilter\n    };\n  }\n\n  hasPermission(): boolean {\n    if (!this.permissions || this.permissions.length === 0) {\n      return true;\n    }\n\n    try {\n      return this.authService.hasPermission(this.permissions);\n    } catch (error: unknown) {\n      if (error instanceof Error) {\n        console.error('Permission error:', error.message);\n      } else {\n        console.error('Unknown error occurred during permission check');\n      }\n      return true;\n    }\n  }\n\n  onCancel(event: Event) {\n    console.log('Cancel button clicked', event);\n    // Lógica para o cancelamento\n  }\n\n  onSave(event: Event) {\n    console.log('Save button clicked', event);\n    // Lógica para salvar alterações\n  }\n}\n"]}
@@ -3,30 +3,30 @@ import { NgModule } from '@angular/core';
3
3
  import { FormsModule, ReactiveFormsModule } from '@angular/forms';
4
4
  import { NgSelectModule } from '@ng-select/ng-select';
5
5
  import { AutofocusDirective } from '../directive/autofocus-directive/autofocus.directive';
6
+ import { LucideIconsModule } from '../icons/lucide-icons.module';
6
7
  import { AlertComponent } from './alert/alert.component';
8
+ import { AppBackgroundComponent } from './app-background/app-background.component';
7
9
  import { BadgeComponent } from './badge/badge.component';
10
+ import { BasicRegistrationComponent } from './basic-registration/basic-registration.component';
8
11
  import { ButtonComponent } from './button/button.component';
9
12
  import { CardComponent } from './card/card.component';
10
13
  import { CheckboxComponent } from './checkbox/checkbox.component';
11
14
  import { CodeHighlightComponent } from './code-highlight/code-highlight.component';
12
15
  import { ConfirmationComponent } from './confirmation/confirmation.component';
13
16
  import { CustomPaginationComponent } from './custom-pagination/custom-pagination.component';
14
- import { FormComponent } from './form/form.component';
15
17
  import { InputComponent } from './imput/input.component';
16
18
  import { MultiSelectComponent } from './multi-select/multi-select.component';
17
19
  import { RadioComponent } from './radio/radio.component';
20
+ import { SearchInputComponent } from './search-input/search-input.component';
18
21
  import { SelectComponent } from './select/select.component';
19
22
  import { DataTableComponent } from './tables/data-table.component';
20
23
  import { TextareaComponent } from './textarea/textarea.component';
21
24
  import { TreeNodeComponent } from './tree-node/tree-node.component';
22
- import { SearchInputComponent } from './search-input/search-input.component';
23
- import { LucideIconsModule } from '../icons/lucide-icons.module';
24
25
  import * as i0 from "@angular/core";
25
26
  export class ComponentsModule {
26
27
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ComponentsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
27
28
  static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: ComponentsModule, declarations: [ButtonComponent,
28
29
  CardComponent,
29
- FormComponent,
30
30
  InputComponent,
31
31
  CheckboxComponent,
32
32
  TextareaComponent,
@@ -41,13 +41,14 @@ export class ComponentsModule {
41
41
  AutofocusDirective,
42
42
  CustomPaginationComponent,
43
43
  TreeNodeComponent,
44
- SearchInputComponent], imports: [CommonModule,
44
+ SearchInputComponent,
45
+ AppBackgroundComponent,
46
+ BasicRegistrationComponent], imports: [CommonModule,
45
47
  FormsModule,
46
48
  ReactiveFormsModule,
47
49
  NgSelectModule,
48
50
  LucideIconsModule], exports: [ButtonComponent,
49
51
  CardComponent,
50
- FormComponent,
51
52
  InputComponent,
52
53
  CheckboxComponent,
53
54
  TextareaComponent,
@@ -65,7 +66,9 @@ export class ComponentsModule {
65
66
  CustomPaginationComponent,
66
67
  TreeNodeComponent,
67
68
  SearchInputComponent,
68
- LucideIconsModule] }); }
69
+ LucideIconsModule,
70
+ AppBackgroundComponent,
71
+ BasicRegistrationComponent] }); }
69
72
  static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ComponentsModule, imports: [CommonModule,
70
73
  FormsModule,
71
74
  ReactiveFormsModule,
@@ -81,7 +84,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
81
84
  declarations: [
82
85
  ButtonComponent,
83
86
  CardComponent,
84
- FormComponent,
85
87
  InputComponent,
86
88
  CheckboxComponent,
87
89
  TextareaComponent,
@@ -97,6 +99,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
97
99
  CustomPaginationComponent,
98
100
  TreeNodeComponent,
99
101
  SearchInputComponent,
102
+ AppBackgroundComponent,
103
+ BasicRegistrationComponent,
100
104
  ],
101
105
  imports: [
102
106
  CommonModule,
@@ -108,7 +112,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
108
112
  exports: [
109
113
  ButtonComponent,
110
114
  CardComponent,
111
- FormComponent,
112
115
  InputComponent,
113
116
  CheckboxComponent,
114
117
  TextareaComponent,
@@ -127,7 +130,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
127
130
  TreeNodeComponent,
128
131
  SearchInputComponent,
129
132
  LucideIconsModule,
133
+ AppBackgroundComponent,
134
+ BasicRegistrationComponent,
130
135
  ],
131
136
  }]
132
137
  }] });
133
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcG9uZW50cy5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9saWItcG9ydGFsLWFuZ3VsYXIvc3JjL2xpYi9jb21wb25lbnRzL2NvbXBvbmVudHMubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxXQUFXLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNsRSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDdEQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sc0RBQXNELENBQUM7QUFDMUYsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDNUQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQ3RELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDJDQUEyQyxDQUFDO0FBQ25GLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBQzlFLE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLGlEQUFpRCxDQUFDO0FBQzVGLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUN0RCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0seUJBQXlCLENBQUM7QUFDekQsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sdUNBQXVDLENBQUM7QUFDN0UsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwyQkFBMkIsQ0FBQztBQUM1RCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUNuRSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSwrQkFBK0IsQ0FBQztBQUNsRSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUNwRSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUM3RSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQzs7QUFzRGpFLE1BQU0sT0FBTyxnQkFBZ0I7K0dBQWhCLGdCQUFnQjtnSEFBaEIsZ0JBQWdCLGlCQWxEekIsZUFBZTtZQUNmLGFBQWE7WUFDYixhQUFhO1lBQ2IsY0FBYztZQUNkLGlCQUFpQjtZQUNqQixpQkFBaUI7WUFDakIsZUFBZTtZQUNmLGNBQWM7WUFDZCxvQkFBb0I7WUFDcEIsa0JBQWtCO1lBQ2xCLHNCQUFzQjtZQUN0QixjQUFjO1lBQ2QsY0FBYztZQUNkLHFCQUFxQjtZQUNyQixrQkFBa0I7WUFDbEIseUJBQXlCO1lBQ3pCLGlCQUFpQjtZQUNqQixvQkFBb0IsYUFHcEIsWUFBWTtZQUNaLFdBQVc7WUFDWCxtQkFBbUI7WUFDbkIsY0FBYztZQUNkLGlCQUFpQixhQUdqQixlQUFlO1lBQ2YsYUFBYTtZQUNiLGFBQWE7WUFDYixjQUFjO1lBQ2QsaUJBQWlCO1lBQ2pCLGlCQUFpQjtZQUNqQixlQUFlO1lBQ2YsY0FBYztZQUNkLG9CQUFvQjtZQUNwQixXQUFXO1lBQ1gsbUJBQW1CO1lBQ25CLGNBQWM7WUFDZCxrQkFBa0I7WUFDbEIsc0JBQXNCO1lBQ3RCLGNBQWM7WUFDZCxjQUFjO1lBQ2QscUJBQXFCO1lBQ3JCLHlCQUF5QjtZQUN6QixpQkFBaUI7WUFDakIsb0JBQW9CO1lBQ3BCLGlCQUFpQjtnSEFHUixnQkFBZ0IsWUE5QnpCLFlBQVk7WUFDWixXQUFXO1lBQ1gsbUJBQW1CO1lBQ25CLGNBQWM7WUFDZCxpQkFBaUIsRUFZakIsV0FBVztZQUNYLG1CQUFtQjtZQUNuQixjQUFjO1lBU2QsaUJBQWlCOzs0RkFHUixnQkFBZ0I7a0JBcEQ1QixRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRTt3QkFDWixlQUFlO3dCQUNmLGFBQWE7d0JBQ2IsYUFBYTt3QkFDYixjQUFjO3dCQUNkLGlCQUFpQjt3QkFDakIsaUJBQWlCO3dCQUNqQixlQUFlO3dCQUNmLGNBQWM7d0JBQ2Qsb0JBQW9CO3dCQUNwQixrQkFBa0I7d0JBQ2xCLHNCQUFzQjt3QkFDdEIsY0FBYzt3QkFDZCxjQUFjO3dCQUNkLHFCQUFxQjt3QkFDckIsa0JBQWtCO3dCQUNsQix5QkFBeUI7d0JBQ3pCLGlCQUFpQjt3QkFDakIsb0JBQW9CO3FCQUNyQjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixXQUFXO3dCQUNYLG1CQUFtQjt3QkFDbkIsY0FBYzt3QkFDZCxpQkFBaUI7cUJBQ2xCO29CQUNELE9BQU8sRUFBRTt3QkFDUCxlQUFlO3dCQUNmLGFBQWE7d0JBQ2IsYUFBYTt3QkFDYixjQUFjO3dCQUNkLGlCQUFpQjt3QkFDakIsaUJBQWlCO3dCQUNqQixlQUFlO3dCQUNmLGNBQWM7d0JBQ2Qsb0JBQW9CO3dCQUNwQixXQUFXO3dCQUNYLG1CQUFtQjt3QkFDbkIsY0FBYzt3QkFDZCxrQkFBa0I7d0JBQ2xCLHNCQUFzQjt3QkFDdEIsY0FBYzt3QkFDZCxjQUFjO3dCQUNkLHFCQUFxQjt3QkFDckIseUJBQXlCO3dCQUN6QixpQkFBaUI7d0JBQ2pCLG9CQUFvQjt3QkFDcEIsaUJBQWlCO3FCQUNsQjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRm9ybXNNb2R1bGUsIFJlYWN0aXZlRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBOZ1NlbGVjdE1vZHVsZSB9IGZyb20gJ0BuZy1zZWxlY3Qvbmctc2VsZWN0JztcbmltcG9ydCB7IEF1dG9mb2N1c0RpcmVjdGl2ZSB9IGZyb20gJy4uL2RpcmVjdGl2ZS9hdXRvZm9jdXMtZGlyZWN0aXZlL2F1dG9mb2N1cy5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgQWxlcnRDb21wb25lbnQgfSBmcm9tICcuL2FsZXJ0L2FsZXJ0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBCYWRnZUNvbXBvbmVudCB9IGZyb20gJy4vYmFkZ2UvYmFkZ2UuY29tcG9uZW50JztcbmltcG9ydCB7IEJ1dHRvbkNvbXBvbmVudCB9IGZyb20gJy4vYnV0dG9uL2J1dHRvbi5jb21wb25lbnQnO1xuaW1wb3J0IHsgQ2FyZENvbXBvbmVudCB9IGZyb20gJy4vY2FyZC9jYXJkLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBDaGVja2JveENvbXBvbmVudCB9IGZyb20gJy4vY2hlY2tib3gvY2hlY2tib3guY29tcG9uZW50JztcbmltcG9ydCB7IENvZGVIaWdobGlnaHRDb21wb25lbnQgfSBmcm9tICcuL2NvZGUtaGlnaGxpZ2h0L2NvZGUtaGlnaGxpZ2h0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBDb25maXJtYXRpb25Db21wb25lbnQgfSBmcm9tICcuL2NvbmZpcm1hdGlvbi9jb25maXJtYXRpb24uY29tcG9uZW50JztcbmltcG9ydCB7IEN1c3RvbVBhZ2luYXRpb25Db21wb25lbnQgfSBmcm9tICcuL2N1c3RvbS1wYWdpbmF0aW9uL2N1c3RvbS1wYWdpbmF0aW9uLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBGb3JtQ29tcG9uZW50IH0gZnJvbSAnLi9mb3JtL2Zvcm0uY29tcG9uZW50JztcbmltcG9ydCB7IElucHV0Q29tcG9uZW50IH0gZnJvbSAnLi9pbXB1dC9pbnB1dC5jb21wb25lbnQnO1xuaW1wb3J0IHsgTXVsdGlTZWxlY3RDb21wb25lbnQgfSBmcm9tICcuL211bHRpLXNlbGVjdC9tdWx0aS1zZWxlY3QuY29tcG9uZW50JztcbmltcG9ydCB7IFJhZGlvQ29tcG9uZW50IH0gZnJvbSAnLi9yYWRpby9yYWRpby5jb21wb25lbnQnO1xuaW1wb3J0IHsgU2VsZWN0Q29tcG9uZW50IH0gZnJvbSAnLi9zZWxlY3Qvc2VsZWN0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBEYXRhVGFibGVDb21wb25lbnQgfSBmcm9tICcuL3RhYmxlcy9kYXRhLXRhYmxlLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBUZXh0YXJlYUNvbXBvbmVudCB9IGZyb20gJy4vdGV4dGFyZWEvdGV4dGFyZWEuY29tcG9uZW50JztcbmltcG9ydCB7IFRyZWVOb2RlQ29tcG9uZW50IH0gZnJvbSAnLi90cmVlLW5vZGUvdHJlZS1ub2RlLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBTZWFyY2hJbnB1dENvbXBvbmVudCB9IGZyb20gJy4vc2VhcmNoLWlucHV0L3NlYXJjaC1pbnB1dC5jb21wb25lbnQnO1xuaW1wb3J0IHsgTHVjaWRlSWNvbnNNb2R1bGUgfSBmcm9tICcuLi9pY29ucy9sdWNpZGUtaWNvbnMubW9kdWxlJztcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbXG4gICAgQnV0dG9uQ29tcG9uZW50LFxuICAgIENhcmRDb21wb25lbnQsXG4gICAgRm9ybUNvbXBvbmVudCxcbiAgICBJbnB1dENvbXBvbmVudCxcbiAgICBDaGVja2JveENvbXBvbmVudCxcbiAgICBUZXh0YXJlYUNvbXBvbmVudCxcbiAgICBTZWxlY3RDb21wb25lbnQsXG4gICAgUmFkaW9Db21wb25lbnQsXG4gICAgTXVsdGlTZWxlY3RDb21wb25lbnQsXG4gICAgRGF0YVRhYmxlQ29tcG9uZW50LFxuICAgIENvZGVIaWdobGlnaHRDb21wb25lbnQsXG4gICAgQmFkZ2VDb21wb25lbnQsXG4gICAgQWxlcnRDb21wb25lbnQsXG4gICAgQ29uZmlybWF0aW9uQ29tcG9uZW50LFxuICAgIEF1dG9mb2N1c0RpcmVjdGl2ZSxcbiAgICBDdXN0b21QYWdpbmF0aW9uQ29tcG9uZW50LFxuICAgIFRyZWVOb2RlQ29tcG9uZW50LFxuICAgIFNlYXJjaElucHV0Q29tcG9uZW50LFxuICBdLFxuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIEZvcm1zTW9kdWxlLFxuICAgIFJlYWN0aXZlRm9ybXNNb2R1bGUsXG4gICAgTmdTZWxlY3RNb2R1bGUsXG4gICAgTHVjaWRlSWNvbnNNb2R1bGUsXG4gIF0sXG4gIGV4cG9ydHM6IFtcbiAgICBCdXR0b25Db21wb25lbnQsXG4gICAgQ2FyZENvbXBvbmVudCxcbiAgICBGb3JtQ29tcG9uZW50LFxuICAgIElucHV0Q29tcG9uZW50LFxuICAgIENoZWNrYm94Q29tcG9uZW50LFxuICAgIFRleHRhcmVhQ29tcG9uZW50LFxuICAgIFNlbGVjdENvbXBvbmVudCxcbiAgICBSYWRpb0NvbXBvbmVudCxcbiAgICBNdWx0aVNlbGVjdENvbXBvbmVudCxcbiAgICBGb3Jtc01vZHVsZSxcbiAgICBSZWFjdGl2ZUZvcm1zTW9kdWxlLFxuICAgIE5nU2VsZWN0TW9kdWxlLFxuICAgIERhdGFUYWJsZUNvbXBvbmVudCxcbiAgICBDb2RlSGlnaGxpZ2h0Q29tcG9uZW50LFxuICAgIEJhZGdlQ29tcG9uZW50LFxuICAgIEFsZXJ0Q29tcG9uZW50LFxuICAgIENvbmZpcm1hdGlvbkNvbXBvbmVudCxcbiAgICBDdXN0b21QYWdpbmF0aW9uQ29tcG9uZW50LFxuICAgIFRyZWVOb2RlQ29tcG9uZW50LFxuICAgIFNlYXJjaElucHV0Q29tcG9uZW50LFxuICAgIEx1Y2lkZUljb25zTW9kdWxlLFxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBDb21wb25lbnRzTW9kdWxlIHsgfVxuIl19
138
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcG9uZW50cy5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9saWItcG9ydGFsLWFuZ3VsYXIvc3JjL2xpYi9jb21wb25lbnRzL2NvbXBvbmVudHMubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxXQUFXLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUNsRSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDdEQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sc0RBQXNELENBQUM7QUFDMUYsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDakUsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDJDQUEyQyxDQUFDO0FBQ25GLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSxtREFBbUQsQ0FBQztBQUMvRixPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDNUQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQ3RELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDJDQUEyQyxDQUFDO0FBQ25GLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBQzlFLE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLGlEQUFpRCxDQUFDO0FBQzVGLE9B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J0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRm9ybXNNb2R1bGUsIFJlYWN0aXZlRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBOZ1NlbGVjdE1vZHVsZSB9IGZyb20gJ0BuZy1zZWxlY3Qvbmctc2VsZWN0JztcbmltcG9ydCB7IEF1dG9mb2N1c0RpcmVjdGl2ZSB9IGZyb20gJy4uL2RpcmVjdGl2ZS9hdXRvZm9jdXMtZGlyZWN0aXZlL2F1dG9mb2N1cy5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgTHVjaWRlSWNvbnNNb2R1bGUgfSBmcm9tICcuLi9pY29ucy9sdWNpZGUtaWNvbnMubW9kdWxlJztcbmltcG9ydCB7IEFsZXJ0Q29tcG9uZW50IH0gZnJvbSAnLi9hbGVydC9hbGVydC5jb21wb25lbnQnO1xuaW1wb3J0IHsgQXBwQmFja2dyb3VuZENvbXBvbmVudCB9IGZyb20gJy4vYXBwLWJhY2tncm91bmQvYXBwLWJhY2tncm91bmQuY29tcG9uZW50JztcbmltcG9ydCB7IEJhZGdlQ29tcG9uZW50IH0gZnJvbSAnLi9iYWRnZS9iYWRnZS5jb21wb25lbnQnO1xuaW1wb3J0IHsgQmFzaWNSZWdpc3RyYXRpb25Db21wb25lbnQgfSBmcm9tICcuL2Jhc2ljLXJlZ2lzdHJhdGlvbi9iYXNpYy1yZWdpc3RyYXRpb24uY29tcG9uZW50JztcbmltcG9ydCB7IEJ1dHRvbkNvbXBvbmVudCB9IGZyb20gJy4vYnV0dG9uL2J1dHRvbi5jb21wb25lbnQnO1xuaW1wb3J0IHsgQ2FyZENvbXBvbmVudCB9IGZyb20gJy4vY2FyZC9jYXJkLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBDaGVja2JveENvbXBvbmVudCB9IGZyb20gJy4vY2hlY2tib3gvY2hlY2tib3guY29tcG9uZW50JztcbmltcG9ydCB7IENvZGVIaWdobGlnaHRDb21wb25lbnQgfSBmcm9tICcuL2NvZGUtaGlnaGxpZ2h0L2NvZGUtaGlnaGxpZ2h0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBDb25maXJtYXRpb25Db21wb25lbnQgfSBmcm9tICcuL2NvbmZpcm1hdGlvbi9jb25maXJtYXRpb24uY29tcG9uZW50JztcbmltcG9ydCB7IEN1c3RvbVBhZ2luYXRpb25Db21wb25lbnQgfSBmcm9tICcuL2N1c3RvbS1wYWdpbmF0aW9uL2N1c3RvbS1wYWdpbmF0aW9uLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBJbnB1dENvbXBvbmVudCB9IGZyb20gJy4vaW1wdXQvaW5wdXQuY29tcG9uZW50JztcbmltcG9ydCB7IE11bHRpU2VsZWN0Q29tcG9uZW50IH0gZnJvbSAnLi9tdWx0aS1zZWxlY3QvbXVsdGktc2VsZWN0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBSYWRpb0NvbXBvbmVudCB9IGZyb20gJy4vcmFkaW8vcmFkaW8uY29tcG9uZW50JztcbmltcG9ydCB7IFNlYXJjaElucHV0Q29tcG9uZW50IH0gZnJvbSAnLi9zZWFyY2gtaW5wdXQvc2VhcmNoLWlucHV0LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBTZWxlY3RDb21wb25lbnQgfSBmcm9tICcuL3NlbGVjdC9zZWxlY3QuY29tcG9uZW50JztcbmltcG9ydCB7IERhdGFUYWJsZUNvbXBvbmVudCB9IGZyb20gJy4vdGFibGVzL2RhdGEtdGFibGUuY29tcG9uZW50JztcbmltcG9ydCB7IFRleHRhcmVhQ29tcG9uZW50IH0gZnJvbSAnLi90ZXh0YXJlYS90ZXh0YXJlYS5jb21wb25lbnQnO1xuaW1wb3J0IHsgVHJlZU5vZGVDb21wb25lbnQgfSBmcm9tICcuL3RyZWUtbm9kZS90cmVlLW5vZGUuY29tcG9uZW50JztcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbXG4gICAgQnV0dG9uQ29tcG9uZW50LFxuICAgIENhcmRDb21wb25lbnQsXG4gICAgSW5wdXRDb21wb25lbnQsXG4gICAgQ2hlY2tib3hDb21wb25lbnQsXG4gICAgVGV4dGFyZWFDb21wb25lbnQsXG4gICAgU2VsZWN0Q29tcG9uZW50LFxuICAgIFJhZGlvQ29tcG9uZW50LFxuICAgIE11bHRpU2VsZWN0Q29tcG9uZW50LFxuICAgIERhdGFUYWJsZUNvbXBvbmVudCxcbiAgICBDb2RlSGlnaGxpZ2h0Q29tcG9uZW50LFxuICAgIEJhZGdlQ29tcG9uZW50LFxuICAgIEFsZXJ0Q29tcG9uZW50LFxuICAgIENvbmZpcm1hdGlvbkNvbXBvbmVudCxcbiAgICBBdXRvZm9jdXNEaXJlY3RpdmUsXG4gICAgQ3VzdG9tUGFnaW5hdGlvbkNvbXBvbmVudCxcbiAgICBUcmVlTm9kZUNvbXBvbmVudCxcbiAgICBTZWFyY2hJbnB1dENvbXBvbmVudCxcbiAgICBBcHBCYWNrZ3JvdW5kQ29tcG9uZW50LFxuICAgIEJhc2ljUmVnaXN0cmF0aW9uQ29tcG9uZW50LFxuICBdLFxuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIEZvcm1zTW9kdWxlLFxuICAgIFJlYWN0aXZlRm9ybXNNb2R1bGUsXG4gICAgTmdTZWxlY3RNb2R1bGUsXG4gICAgTHVjaWRlSWNvbnNNb2R1bGUsXG4gIF0sXG4gIGV4cG9ydHM6IFtcbiAgICBCdXR0b25Db21wb25lbnQsXG4gICAgQ2FyZENvbXBvbmVudCxcbiAgICBJbnB1dENvbXBvbmVudCxcbiAgICBDaGVja2JveENvbXBvbmVudCxcbiAgICBUZXh0YXJlYUNvbXBvbmVudCxcbiAgICBTZWxlY3RDb21wb25lbnQsXG4gICAgUmFkaW9Db21wb25lbnQsXG4gICAgTXVsdGlTZWxlY3RDb21wb25lbnQsXG4gICAgRm9ybXNNb2R1bGUsXG4gICAgUmVhY3RpdmVGb3Jtc01vZHVsZSxcbiAgICBOZ1NlbGVjdE1vZHVsZSxcbiAgICBEYXRhVGFibGVDb21wb25lbnQsXG4gICAgQ29kZUhpZ2hsaWdodENvbXBvbmVudCxcbiAgICBCYWRnZUNvbXBvbmVudCxcbiAgICBBbGVydENvbXBvbmVudCxcbiAgICBDb25maXJtYXRpb25Db21wb25lbnQsXG4gICAgQ3VzdG9tUGFnaW5hdGlvbkNvbXBvbmVudCxcbiAgICBUcmVlTm9kZUNvbXBvbmVudCxcbiAgICBTZWFyY2hJbnB1dENvbXBvbmVudCxcbiAgICBMdWNpZGVJY29uc01vZHVsZSxcbiAgICBBcHBCYWNrZ3JvdW5kQ29tcG9uZW50LFxuICAgIEJhc2ljUmVnaXN0cmF0aW9uQ29tcG9uZW50LFxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBDb21wb25lbnRzTW9kdWxlIHsgfVxuIl19
@@ -40,11 +40,11 @@ export class CustomPaginationComponent {
40
40
  this.destroy$.complete();
41
41
  }
42
42
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CustomPaginationComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
43
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: CustomPaginationComponent, selector: "custom-pagination", inputs: { totalItems: "totalItems", itemsPerPage: "itemsPerPage", currentPage: "currentPage", showPageInfo: "showPageInfo" }, outputs: { pageChange: "pageChange" }, ngImport: i0, template: "<nav *ngIf=\"totalPages > 0\">\n <ul class=\"pagination\">\n <li class=\"page-item\" [class.disabled]=\"currentPage === 1\">\n <a class=\"page-link\" (click)=\"changePage(1)\">&laquo;&laquo;</a>\n </li>\n <li class=\"page-item\" [class.disabled]=\"currentPage === 1\">\n <a class=\"page-link\" (click)=\"changePage(currentPage - 1)\">&laquo;</a>\n </li>\n <li class=\"page-item\" *ngFor=\"let page of pages\" [class.active]=\"page === currentPage\">\n <a class=\"page-link\" (click)=\"changePage(page)\">{{ page }}</a>\n </li>\n <li class=\"page-item\" [class.disabled]=\"currentPage === totalPages\">\n <a class=\"page-link\" (click)=\"changePage(currentPage + 1)\">&raquo;</a>\n </li>\n <li class=\"page-item\" [class.disabled]=\"currentPage === totalPages\">\n <a class=\"page-link\" (click)=\"changePage(totalPages)\">&raquo;&raquo;</a>\n </li>\n </ul>\n</nav>\n", styles: [".pagination{display:flex;list-style:none;padding:0;margin:1rem 0;justify-content:center;align-items:center}.page-item{margin:0 .25rem}.page-item.disabled .page-link{cursor:not-allowed;opacity:.5}.page-item.active .page-link{background-color:#00444c;color:#fff}.page-item .page-link{padding:.5rem .75rem;border:1px solid #dee2e6;border-radius:.25rem;text-decoration:none;color:#00444c;cursor:pointer;transition:background-color .2s}.page-item .page-link:hover{background-color:#2ca58d}.page-info{margin-left:1rem;font-size:1rem;color:#00444c;font-weight:700}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
43
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: CustomPaginationComponent, selector: "custom-pagination", inputs: { totalItems: "totalItems", itemsPerPage: "itemsPerPage", currentPage: "currentPage", showPageInfo: "showPageInfo" }, outputs: { pageChange: "pageChange" }, ngImport: i0, template: "<nav *ngIf=\"totalPages > 0\">\n <ul class=\"pagination\">\n <li class=\"page-item\" [class.disabled]=\"currentPage === 1\">\n <a class=\"page-link\" (click)=\"changePage(1)\">&laquo;&laquo;</a>\n </li>\n <li class=\"page-item\" [class.disabled]=\"currentPage === 1\">\n <a class=\"page-link\" (click)=\"changePage(currentPage - 1)\">&laquo;</a>\n </li>\n <li class=\"page-item\" *ngFor=\"let page of pages\" [class.active]=\"page === currentPage\">\n <a class=\"page-link\" (click)=\"changePage(page)\">{{ page }}</a>\n </li>\n <li class=\"page-item\" [class.disabled]=\"currentPage === totalPages\">\n <a class=\"page-link\" (click)=\"changePage(currentPage + 1)\">&raquo;</a>\n </li>\n <li class=\"page-item\" [class.disabled]=\"currentPage === totalPages\">\n <a class=\"page-link\" (click)=\"changePage(totalPages)\">&raquo;&raquo;</a>\n </li>\n </ul>\n</nav>\n", styles: ["@charset \"UTF-8\";.pagination{display:flex;list-style:none;padding:0;margin:1rem 0;justify-content:center;align-items:center}.page-item{margin:0 .25rem}.page-item.disabled .page-link{cursor:not-allowed;opacity:.5}.page-item.active .page-link{background-color:#00444c;color:#fff}.page-item .page-link{padding:.5rem .75rem;border:1px solid #dee2e6;border-radius:.25rem;text-decoration:none;color:#00444c;cursor:pointer;transition:background-color .2s}.page-item .page-link:hover{background-color:#e5e5e5}.page-info{margin-left:1rem;font-size:1rem;color:#00444c;font-weight:700}\n"], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] }); }
44
44
  }
45
45
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CustomPaginationComponent, decorators: [{
46
46
  type: Component,
47
- args: [{ selector: 'custom-pagination', template: "<nav *ngIf=\"totalPages > 0\">\n <ul class=\"pagination\">\n <li class=\"page-item\" [class.disabled]=\"currentPage === 1\">\n <a class=\"page-link\" (click)=\"changePage(1)\">&laquo;&laquo;</a>\n </li>\n <li class=\"page-item\" [class.disabled]=\"currentPage === 1\">\n <a class=\"page-link\" (click)=\"changePage(currentPage - 1)\">&laquo;</a>\n </li>\n <li class=\"page-item\" *ngFor=\"let page of pages\" [class.active]=\"page === currentPage\">\n <a class=\"page-link\" (click)=\"changePage(page)\">{{ page }}</a>\n </li>\n <li class=\"page-item\" [class.disabled]=\"currentPage === totalPages\">\n <a class=\"page-link\" (click)=\"changePage(currentPage + 1)\">&raquo;</a>\n </li>\n <li class=\"page-item\" [class.disabled]=\"currentPage === totalPages\">\n <a class=\"page-link\" (click)=\"changePage(totalPages)\">&raquo;&raquo;</a>\n </li>\n </ul>\n</nav>\n", styles: [".pagination{display:flex;list-style:none;padding:0;margin:1rem 0;justify-content:center;align-items:center}.page-item{margin:0 .25rem}.page-item.disabled .page-link{cursor:not-allowed;opacity:.5}.page-item.active .page-link{background-color:#00444c;color:#fff}.page-item .page-link{padding:.5rem .75rem;border:1px solid #dee2e6;border-radius:.25rem;text-decoration:none;color:#00444c;cursor:pointer;transition:background-color .2s}.page-item .page-link:hover{background-color:#2ca58d}.page-info{margin-left:1rem;font-size:1rem;color:#00444c;font-weight:700}\n"] }]
47
+ args: [{ selector: 'custom-pagination', template: "<nav *ngIf=\"totalPages > 0\">\n <ul class=\"pagination\">\n <li class=\"page-item\" [class.disabled]=\"currentPage === 1\">\n <a class=\"page-link\" (click)=\"changePage(1)\">&laquo;&laquo;</a>\n </li>\n <li class=\"page-item\" [class.disabled]=\"currentPage === 1\">\n <a class=\"page-link\" (click)=\"changePage(currentPage - 1)\">&laquo;</a>\n </li>\n <li class=\"page-item\" *ngFor=\"let page of pages\" [class.active]=\"page === currentPage\">\n <a class=\"page-link\" (click)=\"changePage(page)\">{{ page }}</a>\n </li>\n <li class=\"page-item\" [class.disabled]=\"currentPage === totalPages\">\n <a class=\"page-link\" (click)=\"changePage(currentPage + 1)\">&raquo;</a>\n </li>\n <li class=\"page-item\" [class.disabled]=\"currentPage === totalPages\">\n <a class=\"page-link\" (click)=\"changePage(totalPages)\">&raquo;&raquo;</a>\n </li>\n </ul>\n</nav>\n", styles: ["@charset \"UTF-8\";.pagination{display:flex;list-style:none;padding:0;margin:1rem 0;justify-content:center;align-items:center}.page-item{margin:0 .25rem}.page-item.disabled .page-link{cursor:not-allowed;opacity:.5}.page-item.active .page-link{background-color:#00444c;color:#fff}.page-item .page-link{padding:.5rem .75rem;border:1px solid #dee2e6;border-radius:.25rem;text-decoration:none;color:#00444c;cursor:pointer;transition:background-color .2s}.page-item .page-link:hover{background-color:#e5e5e5}.page-info{margin-left:1rem;font-size:1rem;color:#00444c;font-weight:700}\n"] }]
48
48
  }], propDecorators: { totalItems: [{
49
49
  type: Input
50
50
  }], itemsPerPage: [{
@@ -18,12 +18,7 @@ export class InputComponent {
18
18
  this.required = false;
19
19
  this.pattern = null;
20
20
  this.autofocus = false;
21
- this.marginTop = 0;
22
- this.marginBottom = 0;
23
- this.marginLeft = 0;
24
- this.marginRight = 0;
25
21
  this.labelFontWeight = 400;
26
- this.permissions = [];
27
22
  this.inputEvent = new EventEmitter();
28
23
  this.changeEvent = new EventEmitter();
29
24
  this.focusEvent = new EventEmitter();
@@ -65,7 +60,7 @@ export class InputComponent {
65
60
  this.disabled = isDisabled;
66
61
  }
67
62
  hasPermission() {
68
- if (this.permissions.length === 0) {
63
+ if (!this.permissions || this.permissions.length === 0) {
69
64
  return true;
70
65
  }
71
66
  try {
@@ -100,19 +95,14 @@ export class InputComponent {
100
95
  this.subscriptions.forEach(sub => sub.unsubscribe());
101
96
  }
102
97
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: InputComponent, deps: [{ token: i1.AuthService }], target: i0.ɵɵFactoryTarget.Component }); }
103
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: InputComponent, selector: "argenta-custom-input", inputs: { label: "label", placeholder: "placeholder", id: "id", type: "type", disabled: "disabled", readonly: "readonly", maxlength: "maxlength", minlength: "minlength", required: "required", pattern: "pattern", autofocus: "autofocus", marginTop: "marginTop", marginBottom: "marginBottom", marginLeft: "marginLeft", marginRight: "marginRight", labelFontWeight: "labelFontWeight", permissions: "permissions" }, outputs: { inputEvent: "inputEvent", changeEvent: "changeEvent", focusEvent: "focusEvent", blurEvent: "blurEvent", keyupEvent: "keyupEvent", keydownEvent: "keydownEvent", keypressEvent: "keypressEvent" }, providers: [
98
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: InputComponent, selector: "argenta-custom-input", inputs: { label: "label", placeholder: "placeholder", id: "id", type: "type", disabled: "disabled", readonly: "readonly", maxlength: "maxlength", minlength: "minlength", required: "required", pattern: "pattern", autofocus: "autofocus", labelFontWeight: "labelFontWeight", permissions: "permissions" }, outputs: { inputEvent: "inputEvent", changeEvent: "changeEvent", focusEvent: "focusEvent", blurEvent: "blurEvent", keyupEvent: "keyupEvent", keydownEvent: "keydownEvent", keypressEvent: "keypressEvent" }, providers: [
104
99
  {
105
100
  provide: NG_VALUE_ACCESSOR,
106
101
  useExisting: forwardRef(() => InputComponent),
107
102
  multi: true
108
103
  }
109
104
  ], ngImport: i0, template: `
110
- <div *ngIf="hasPermission()" class="form-group" [ngStyle]="{
111
- 'margin-top': marginTop + 'rem',
112
- 'margin-bottom': marginBottom + 'rem',
113
- 'margin-left': marginLeft + 'rem',
114
- 'margin-right': marginRight + 'rem'
115
- }">
105
+ <div *ngIf="hasPermission()" class="form-group">
116
106
  <label [for]="id" [ngStyle]="getLabelStyles()">{{ label }}</label>
117
107
  <input [type]="type"
118
108
  class="form-control custom-input"
@@ -139,12 +129,7 @@ export class InputComponent {
139
129
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: InputComponent, decorators: [{
140
130
  type: Component,
141
131
  args: [{ selector: 'argenta-custom-input', template: `
142
- <div *ngIf="hasPermission()" class="form-group" [ngStyle]="{
143
- 'margin-top': marginTop + 'rem',
144
- 'margin-bottom': marginBottom + 'rem',
145
- 'margin-left': marginLeft + 'rem',
146
- 'margin-right': marginRight + 'rem'
147
- }">
132
+ <div *ngIf="hasPermission()" class="form-group">
148
133
  <label [for]="id" [ngStyle]="getLabelStyles()">{{ label }}</label>
149
134
  <input [type]="type"
150
135
  class="form-control custom-input"
@@ -195,14 +180,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
195
180
  type: Input
196
181
  }], autofocus: [{
197
182
  type: Input
198
- }], marginTop: [{
199
- type: Input
200
- }], marginBottom: [{
201
- type: Input
202
- }], marginLeft: [{
203
- type: Input
204
- }], marginRight: [{
205
- type: Input
206
183
  }], labelFontWeight: [{
207
184
  type: Input
208
185
  }], permissions: [{
@@ -222,4 +199,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
222
199
  }], keypressEvent: [{
223
200
  type: Output
224
201
  }] } });
225
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.component.js","sourceRoot":"","sources":["../../../../../../projects/lib-portal-angular/src/lib/components/imput/input.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, forwardRef, Input, OnDestroy, Output } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { Subscription } from 'rxjs';\nimport { AuthService } from '../../service/auth-service.service';\n\n@Component({\n  selector: 'argenta-custom-input',\n  template: `\n    <div *ngIf=\"hasPermission()\" class=\"form-group\" [ngStyle]=\"{\n      'margin-top': marginTop + 'rem',\n      'margin-bottom': marginBottom + 'rem',\n      'margin-left': marginLeft + 'rem',\n      'margin-right': marginRight + 'rem'\n    }\">\n      <label [for]=\"id\" [ngStyle]=\"getLabelStyles()\">{{ label }}</label>\n      <input [type]=\"type\"\n             class=\"form-control custom-input\"\n             [id]=\"id\"\n             [placeholder]=\"placeholder\"\n             [(ngModel)]=\"value\"\n             (input)=\"onInput($event)\"\n             (change)=\"onChange($event)\"\n             (focus)=\"onFocus($event)\"\n             (blur)=\"onBlur($event)\"\n             (keyup)=\"keyupEvent.emit($event)\"\n             (keydown)=\"keydownEvent.emit($event)\"\n             (keypress)=\"keypressEvent.emit($event)\"\n             [disabled]=\"disabled\"\n             [readonly]=\"readonly\"\n             [attr.maxlength]=\"maxlength\"\n             [attr.minlength]=\"minlength\"\n             [required]=\"required\"\n             [attr.pattern]=\"pattern\"\n             [autofocus]=\"autofocus\">\n    </div>\n  `,\n  styles: [`\n    .form-group {\n      font-family: Inter;\n      font-size: 1rem;\n      font-weight: bold;\n    }\n    .form-check-input {\n      font-family: Inter;\n      color: #333;\n      font-size: 0.9rem;\n    }\n    .form-check-label {\n      width: 623px;\n      height: 19px;\n      top: 1608px;\n      left: 133px;\n      gap: 0px;\n      opacity: 0px;\n      font-family: Inter;\n      font-size: 16px;\n      line-height: 19.36px;\n      text-align: left;\n    }\n  `],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => InputComponent),\n      multi: true\n    }\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class InputComponent implements ControlValueAccessor, OnDestroy {\n  @Input() label: string = 'Default Label';\n  @Input() placeholder: string = '';\n  @Input() id: string = 'inputId';\n  @Input() type: string = 'text';\n  @Input() disabled: boolean = false;\n  @Input() readonly: boolean = false;\n  @Input() maxlength: number | null = null;\n  @Input() minlength: number | null = null;\n  @Input() required: boolean = false;\n  @Input() pattern: string | null = null;\n  @Input() autofocus: boolean = false;\n\n  @Input() marginTop: number = 0;\n  @Input() marginBottom: number = 0;\n  @Input() marginLeft: number = 0;\n  @Input() marginRight: number = 0;\n  @Input() labelFontWeight: number = 400;\n\n  @Input() permissions: string[] = [];\n\n  @Output() inputEvent: EventEmitter<Event> = new EventEmitter<Event>();\n  @Output() changeEvent: EventEmitter<Event> = new EventEmitter<Event>();\n  @Output() focusEvent: EventEmitter<FocusEvent> = new EventEmitter<FocusEvent>();\n  @Output() blurEvent: EventEmitter<FocusEvent> = new EventEmitter<FocusEvent>();\n  @Output() keyupEvent: EventEmitter<KeyboardEvent> = new EventEmitter<KeyboardEvent>();\n  @Output() keydownEvent: EventEmitter<KeyboardEvent> = new EventEmitter<KeyboardEvent>();\n  @Output() keypressEvent: EventEmitter<KeyboardEvent> = new EventEmitter<KeyboardEvent>();\n\n  private onChangeCallback: (_: any) => void = () => { };\n  private onTouchedCallback: () => void = () => { };\n\n  value: string = '';\n\n  private subscriptions: Subscription[] = [];\n\n  constructor(private authService: AuthService) { }\n\n  onInput(event: Event) {\n    const inputElement = event.target as HTMLInputElement;\n    this.value = inputElement.value;\n    this.onChangeCallback(this.value);\n    this.inputEvent.emit(event);\n  }\n\n  onChange(event: Event) {\n    this.changeEvent.emit(event);\n  }\n\n  onFocus(event: FocusEvent) {\n    this.focusEvent.emit(event);\n  }\n\n  onBlur(event: FocusEvent) {\n    this.onTouchedCallback();\n    this.blurEvent.emit(event);\n  }\n\n  writeValue(value: any): void {\n    this.value = value;\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChangeCallback = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouchedCallback = fn;\n  }\n\n  setDisabledState?(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  hasPermission(): boolean {\n    if (this.permissions.length === 0) {\n      return true;\n    }\n\n    try {\n      return this.authService.hasPermission(this.permissions);\n    } catch (error: unknown) {\n      if (error instanceof Error) {\n        console.error('Permission error:', error.message);\n      } else {\n        console.error('Unknown error occurred during permission check');\n      }\n      return true;\n    }\n  }\n\n  getLabelStyles() {\n    return {\n      'font-weight': this.labelFontWeight,\n      'width': '623px',\n      'height': '19px',\n      'top': '1608px',\n      'left': '133px',\n      'gap': '0px',\n      'opacity': '0px',\n      'font-family': 'Inter',\n      'font-size': '16px',\n      'line-height': '19.36px',\n      'text-align': 'left'\n    };\n  }\n\n  ngOnDestroy(): void {\n    this.subscriptions.forEach(sub => sub.unsubscribe());\n  }\n}\n"]}
202
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input.component.js","sourceRoot":"","sources":["../../../../../../projects/lib-portal-angular/src/lib/components/imput/input.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, forwardRef, Input, OnDestroy, Output } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { Subscription } from 'rxjs';\nimport { AuthService } from '../../service/auth-service.service';\n\n@Component({\n  selector: 'argenta-custom-input',\n  template: `\n    <div *ngIf=\"hasPermission()\" class=\"form-group\">\n      <label [for]=\"id\" [ngStyle]=\"getLabelStyles()\">{{ label }}</label>\n      <input [type]=\"type\"\n             class=\"form-control custom-input\"\n             [id]=\"id\"\n             [placeholder]=\"placeholder\"\n             [(ngModel)]=\"value\"\n             (input)=\"onInput($event)\"\n             (change)=\"onChange($event)\"\n             (focus)=\"onFocus($event)\"\n             (blur)=\"onBlur($event)\"\n             (keyup)=\"keyupEvent.emit($event)\"\n             (keydown)=\"keydownEvent.emit($event)\"\n             (keypress)=\"keypressEvent.emit($event)\"\n             [disabled]=\"disabled\"\n             [readonly]=\"readonly\"\n             [attr.maxlength]=\"maxlength\"\n             [attr.minlength]=\"minlength\"\n             [required]=\"required\"\n             [attr.pattern]=\"pattern\"\n             [autofocus]=\"autofocus\">\n    </div>\n  `,\n  styles: [`\n    .form-group {\n      font-family: Inter;\n      font-size: 1rem;\n      font-weight: bold;\n    }\n    .form-check-input {\n      font-family: Inter;\n      color: #333;\n      font-size: 0.9rem;\n    }\n    .form-check-label {\n      width: 623px;\n      height: 19px;\n      top: 1608px;\n      left: 133px;\n      gap: 0px;\n      opacity: 0px;\n      font-family: Inter;\n      font-size: 16px;\n      line-height: 19.36px;\n      text-align: left;\n    }\n  `],\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => InputComponent),\n      multi: true\n    }\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class InputComponent implements ControlValueAccessor, OnDestroy {\n  @Input() label: string = 'Default Label';\n  @Input() placeholder: string = '';\n  @Input() id: string = 'inputId';\n  @Input() type: string = 'text';\n  @Input() disabled: boolean = false;\n  @Input() readonly: boolean = false;\n  @Input() maxlength: number | null = null;\n  @Input() minlength: number | null = null;\n  @Input() required: boolean = false;\n  @Input() pattern: string | null = null;\n  @Input() autofocus: boolean = false;\n\n  @Input() labelFontWeight: number = 400;\n\n  @Input() permissions: string[] | undefined;\n\n  @Output() inputEvent: EventEmitter<Event> = new EventEmitter<Event>();\n  @Output() changeEvent: EventEmitter<Event> = new EventEmitter<Event>();\n  @Output() focusEvent: EventEmitter<FocusEvent> = new EventEmitter<FocusEvent>();\n  @Output() blurEvent: EventEmitter<FocusEvent> = new EventEmitter<FocusEvent>();\n  @Output() keyupEvent: EventEmitter<KeyboardEvent> = new EventEmitter<KeyboardEvent>();\n  @Output() keydownEvent: EventEmitter<KeyboardEvent> = new EventEmitter<KeyboardEvent>();\n  @Output() keypressEvent: EventEmitter<KeyboardEvent> = new EventEmitter<KeyboardEvent>();\n\n  private onChangeCallback: (_: any) => void = () => { };\n  private onTouchedCallback: () => void = () => { };\n\n  value: string = '';\n\n  private subscriptions: Subscription[] = [];\n\n  constructor(private authService: AuthService) { }\n\n  onInput(event: Event) {\n    const inputElement = event.target as HTMLInputElement;\n    this.value = inputElement.value;\n    this.onChangeCallback(this.value);\n    this.inputEvent.emit(event);\n  }\n\n  onChange(event: Event) {\n    this.changeEvent.emit(event);\n  }\n\n  onFocus(event: FocusEvent) {\n    this.focusEvent.emit(event);\n  }\n\n  onBlur(event: FocusEvent) {\n    this.onTouchedCallback();\n    this.blurEvent.emit(event);\n  }\n\n  writeValue(value: any): void {\n    this.value = value;\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChangeCallback = fn;\n  }\n\n  registerOnTouched(fn: any): void {\n    this.onTouchedCallback = fn;\n  }\n\n  setDisabledState?(isDisabled: boolean): void {\n    this.disabled = isDisabled;\n  }\n\n  hasPermission(): boolean {\n    if (!this.permissions || this.permissions.length === 0) {\n      return true;\n    }\n\n    try {\n      return this.authService.hasPermission(this.permissions);\n    } catch (error: unknown) {\n      if (error instanceof Error) {\n        console.error('Permission error:', error.message);\n      } else {\n        console.error('Unknown error occurred during permission check');\n      }\n      return true;\n    }\n  }\n\n  getLabelStyles() {\n    return {\n      'font-weight': this.labelFontWeight,\n      'width': '623px',\n      'height': '19px',\n      'top': '1608px',\n      'left': '133px',\n      'gap': '0px',\n      'opacity': '0px',\n      'font-family': 'Inter',\n      'font-size': '16px',\n      'line-height': '19.36px',\n      'text-align': 'left'\n    };\n  }\n\n  ngOnDestroy(): void {\n    this.subscriptions.forEach(sub => sub.unsubscribe());\n  }\n}\n"]}