ngx-histaff-alpha 3.8.3 → 3.8.5
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/app/app-pipes/translate.pipe.mjs +7 -2
- package/esm2022/lib/app/components/dialog-state/dialog-state.component.mjs +3 -3
- package/esm2022/lib/app/libraries/alert/alert/alert.component.mjs +3 -3
- package/esm2022/lib/app/libraries/core-confirm-dialog/core-confirm-dialog/core-confirm-dialog.component.mjs +3 -3
- package/esm2022/lib/app/libraries/core-filter-kit/core-filter-kit.component.mjs +22 -16
- package/esm2022/lib/app/libraries/core-navigation-tracker/core-navigation-tracker/core-navigation-tracker.component.mjs +42 -36
- package/esm2022/lib/app/libraries/core-oauth-callback/core-oauth-callback.component.mjs +24 -0
- package/esm2022/lib/app/libraries/core-org-tree/core-org-tree/core-org-tree.component.mjs +3 -3
- package/esm2022/lib/app/libraries/core-page-view/core-page-view/core-page-view.component.mjs +12 -9
- package/esm2022/lib/app/libraries/core-page-view/enum-interfaces.mjs +1 -1
- package/esm2022/lib/app/libraries/core-pagination-full/core-pagination-full/core-pagination-full.component.mjs +3 -3
- package/esm2022/lib/app/libraries/core-shift-sticker/core-shift-sticker.component.mjs +3 -3
- package/esm2022/lib/app/libraries/tooltip/tooltip.component.mjs +3 -3
- package/esm2022/lib/app/services/auth.service.mjs +33 -1
- package/esm2022/lib/app/services/developer-validation.service.mjs +102 -0
- package/esm2022/lib/app/services/layout.service.mjs +2 -1
- package/esm2022/public-api.mjs +2 -1
- package/fesm2022/ngx-histaff-alpha.mjs +231 -60
- package/fesm2022/ngx-histaff-alpha.mjs.map +1 -1
- package/lib/app/app-pipes/translate.pipe.d.ts +1 -1
- package/lib/app/libraries/core-filter-kit/core-filter-kit.component.d.ts +1 -0
- package/lib/app/libraries/core-navigation-tracker/core-navigation-tracker/core-navigation-tracker.component.d.ts +5 -1
- package/lib/app/libraries/core-oauth-callback/core-oauth-callback.component.d.ts +8 -0
- package/lib/app/libraries/core-page-view/core-page-view/core-page-view.component.d.ts +4 -1
- package/lib/app/libraries/core-page-view/enum-interfaces.d.ts +1 -1
- package/lib/app/services/auth.service.d.ts +2 -0
- package/lib/app/services/developer-validation.service.d.ts +17 -0
- package/lib/app/services/layout.service.d.ts +1 -0
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
|
@@ -6,7 +6,12 @@ export class TranslatePipe {
|
|
|
6
6
|
this.MultiLanguageService = MultiLanguageService;
|
|
7
7
|
}
|
|
8
8
|
transform(key, lang) {
|
|
9
|
-
|
|
9
|
+
if (!!key) {
|
|
10
|
+
return this.MultiLanguageService.trans(key, lang);
|
|
11
|
+
}
|
|
12
|
+
else {
|
|
13
|
+
return '';
|
|
14
|
+
}
|
|
10
15
|
}
|
|
11
16
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: TranslatePipe, deps: [{ token: i1.MultiLanguageService }], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
12
17
|
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "17.2.3", ngImport: i0, type: TranslatePipe, isStandalone: true, name: "translate" }); }
|
|
@@ -18,4 +23,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
|
|
|
18
23
|
standalone: true
|
|
19
24
|
}]
|
|
20
25
|
}], ctorParameters: () => [{ type: i1.MultiLanguageService }] });
|
|
21
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNsYXRlLnBpcGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtaGlzdGFmZi1hbHBoYS9zcmMvbGliL2FwcC9hcHAtcGlwZXMvdHJhbnNsYXRlLnBpcGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLElBQUksRUFBaUIsTUFBTSxlQUFlLENBQUM7OztBQU9wRCxNQUFNLE9BQU8sYUFBYTtJQUV4QixZQUNVLG9CQUEwQztRQUExQyx5QkFBb0IsR0FBcEIsb0JBQW9CLENBQXNCO0lBQ2pELENBQUM7SUFFSixTQUFTLENBQUMsR0FBdUIsRUFBRSxJQUFZO1FBQzdDLElBQUksQ0FBQyxDQUFDLEdBQUcsRUFBRTtZQUNULE9BQU8sSUFBSSxDQUFDLG9CQUFvQixDQUFDLEtBQUssQ0FBQyxHQUFHLEVBQUUsSUFBSSxDQUFDLENBQUM7U0FDbkQ7YUFBTTtZQUNMLE9BQU8sRUFBRSxDQUFDO1NBQ1g7SUFFSCxDQUFDOzhHQWJVLGFBQWE7NEdBQWIsYUFBYTs7MkZBQWIsYUFBYTtrQkFKekIsSUFBSTttQkFBQztvQkFDSixJQUFJLEVBQUUsV0FBVztvQkFDakIsVUFBVSxFQUFFLElBQUk7aUJBQ2pCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGlwZSwgUGlwZVRyYW5zZm9ybSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBNdWx0aUxhbmd1YWdlU2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzL211bHRpLWxhbmd1YWdlLnNlcnZpY2UnO1xyXG5cclxuQFBpcGUoe1xyXG4gIG5hbWU6ICd0cmFuc2xhdGUnLFxyXG4gIHN0YW5kYWxvbmU6IHRydWVcclxufSlcclxuZXhwb3J0IGNsYXNzIFRyYW5zbGF0ZVBpcGUgaW1wbGVtZW50cyBQaXBlVHJhbnNmb3JtIHtcclxuXHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBwcml2YXRlIE11bHRpTGFuZ3VhZ2VTZXJ2aWNlOiBNdWx0aUxhbmd1YWdlU2VydmljZVxyXG4gICkge31cclxuXHJcbiAgdHJhbnNmb3JtKGtleTogc3RyaW5nIHwgdW5kZWZpbmVkLCBsYW5nOiBzdHJpbmcpOiBzdHJpbmcge1xyXG4gICAgaWYgKCEha2V5KSB7XHJcbiAgICAgIHJldHVybiB0aGlzLk11bHRpTGFuZ3VhZ2VTZXJ2aWNlLnRyYW5zKGtleSwgbGFuZyk7XHJcbiAgICB9IGVsc2Uge1xyXG4gICAgICByZXR1cm4gJyc7XHJcbiAgICB9XHJcbiAgICBcclxuICB9XHJcblxyXG59XHJcbiJdfQ==
|
|
@@ -23,16 +23,16 @@ export class DialogStateComponent extends BaseComponent {
|
|
|
23
23
|
this.ds.dialogStateOpen$.next(false);
|
|
24
24
|
}
|
|
25
25
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: DialogStateComponent, deps: [{ token: i1.MultiLanguageService }, { token: i2.DialogService }, { token: i3.DomService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
26
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.3", type: DialogStateComponent, isStandalone: true, selector: "app-dialog-state", viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div #container class=\"dialog-state-container
|
|
26
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.3", type: DialogStateComponent, isStandalone: true, selector: "app-dialog-state", viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div #container class=\"dialog-state-container inter-font\">\r\n <div class=\"header w-100 d-flex d-flex-between\">\r\n <span>Dialog State</span>\r\n <i class=\"feather-x\" (click)=\"close()\"></i>\r\n </div>\r\n <div class=\"container container-fluid\">\r\n <div class=\"row\">\r\n <div class=\"col-md-4 label\">busy</div>\r\n <div class=\"col-md-8 font-bold\">{{ ds.busy }}</div>\r\n </div>\r\n <div class=\"row\">\r\n <div class=\"col-md-4 label\">showConfirmDialog</div>\r\n <div class=\"col-md-8 font-bold\">{{ ds.showConfirmDialog$.value }}</div>\r\n </div>\r\n <div class=\"row\">\r\n <div class=\"col-md-4 label\">dialogConfirmed</div>\r\n <div class=\"col-md-8 font-bold\">{{ ds.dialogConfirmed$.value }}</div>\r\n </div>\r\n <div class=\"row\">\r\n <div class=\"col-md-4 label\">title</div>\r\n <div class=\"col-md-8 font-bold\">{{ ds.title$.value | translate: lang}}</div>\r\n </div>\r\n <div class=\"row\">\r\n <div class=\"col-md-4 label\">body</div>\r\n <div class=\"col-md-8 font-bold\">{{ ds.body$.value | translate: lang}}</div>\r\n </div>\r\n <div class=\"row\">\r\n <div class=\"col-md-4 label\">okButtonText</div>\r\n <div class=\"col-md-8 font-bold\">{{ ds.okButtonText$.value | translate: lang}}</div>\r\n </div>\r\n <div class=\"row\">\r\n <div class=\"col-md-4 label\">cancelButtonText</div>\r\n <div class=\"col-md-8 font-bold\">{{ ds.cancelButtonText$.value | translate: lang}}</div>\r\n </div>\r\n <div class=\"row\">\r\n <div class=\"col-md-4 label\">instanceNumber</div>\r\n <div class=\"col-md-8 font-bold\">{{ ds.dialogConfirmed$.value?.instanceNumber }}</div>\r\n </div>\r\n\r\n </div>\r\n</div>\r\n\r\n<!--\r\n busy!: boolean;\r\n showConfirmDialog$ = new BehaviorSubject<boolean | undefined>(undefined);\r\n canDeactivate$ = new Subject<boolean>;\r\n dialogConfirmed$ = new BehaviorSubject<IDialogConfirmModel | undefined>(undefined);\r\n title$ = new Subject<EnumTranslateKey>;\r\n body$ = new Subject<EnumTranslateKey>;\r\n okButtonText$ = new Subject<EnumTranslateKey>;\r\n cancelButtonText$ = new Subject<EnumTranslateKey>;\r\n showCancelOnly$ = new Subject<boolean>;\r\n informationLines$ = new Subject<string[]>;\r\n-->", styles: [".dialog-state-container{--z-index: 999;--height: 250px;position:fixed;display:block;padding:var(--size-layout-block-cell-spacing);background-color:#faebd7;border-radius:20px;top:calc(100vh - var(--height) - var(--size-layout-block-cell-spacing));right:var(--size-layout-block-cell-spacing);z-index:var(--z-index);width:640px;height:var(--height)}.dialog-state-container header i{font-size:28px;color:#848484}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "pipe", type: TranslatePipe, name: "translate" }] }); }
|
|
27
27
|
}
|
|
28
28
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: DialogStateComponent, decorators: [{
|
|
29
29
|
type: Component,
|
|
30
30
|
args: [{ selector: 'app-dialog-state', standalone: true, imports: [
|
|
31
31
|
CommonModule,
|
|
32
32
|
TranslatePipe
|
|
33
|
-
], template: "<div #container class=\"dialog-state-container
|
|
33
|
+
], template: "<div #container class=\"dialog-state-container inter-font\">\r\n <div class=\"header w-100 d-flex d-flex-between\">\r\n <span>Dialog State</span>\r\n <i class=\"feather-x\" (click)=\"close()\"></i>\r\n </div>\r\n <div class=\"container container-fluid\">\r\n <div class=\"row\">\r\n <div class=\"col-md-4 label\">busy</div>\r\n <div class=\"col-md-8 font-bold\">{{ ds.busy }}</div>\r\n </div>\r\n <div class=\"row\">\r\n <div class=\"col-md-4 label\">showConfirmDialog</div>\r\n <div class=\"col-md-8 font-bold\">{{ ds.showConfirmDialog$.value }}</div>\r\n </div>\r\n <div class=\"row\">\r\n <div class=\"col-md-4 label\">dialogConfirmed</div>\r\n <div class=\"col-md-8 font-bold\">{{ ds.dialogConfirmed$.value }}</div>\r\n </div>\r\n <div class=\"row\">\r\n <div class=\"col-md-4 label\">title</div>\r\n <div class=\"col-md-8 font-bold\">{{ ds.title$.value | translate: lang}}</div>\r\n </div>\r\n <div class=\"row\">\r\n <div class=\"col-md-4 label\">body</div>\r\n <div class=\"col-md-8 font-bold\">{{ ds.body$.value | translate: lang}}</div>\r\n </div>\r\n <div class=\"row\">\r\n <div class=\"col-md-4 label\">okButtonText</div>\r\n <div class=\"col-md-8 font-bold\">{{ ds.okButtonText$.value | translate: lang}}</div>\r\n </div>\r\n <div class=\"row\">\r\n <div class=\"col-md-4 label\">cancelButtonText</div>\r\n <div class=\"col-md-8 font-bold\">{{ ds.cancelButtonText$.value | translate: lang}}</div>\r\n </div>\r\n <div class=\"row\">\r\n <div class=\"col-md-4 label\">instanceNumber</div>\r\n <div class=\"col-md-8 font-bold\">{{ ds.dialogConfirmed$.value?.instanceNumber }}</div>\r\n </div>\r\n\r\n </div>\r\n</div>\r\n\r\n<!--\r\n busy!: boolean;\r\n showConfirmDialog$ = new BehaviorSubject<boolean | undefined>(undefined);\r\n canDeactivate$ = new Subject<boolean>;\r\n dialogConfirmed$ = new BehaviorSubject<IDialogConfirmModel | undefined>(undefined);\r\n title$ = new Subject<EnumTranslateKey>;\r\n body$ = new Subject<EnumTranslateKey>;\r\n okButtonText$ = new Subject<EnumTranslateKey>;\r\n cancelButtonText$ = new Subject<EnumTranslateKey>;\r\n showCancelOnly$ = new Subject<boolean>;\r\n informationLines$ = new Subject<string[]>;\r\n-->", styles: [".dialog-state-container{--z-index: 999;--height: 250px;position:fixed;display:block;padding:var(--size-layout-block-cell-spacing);background-color:#faebd7;border-radius:20px;top:calc(100vh - var(--height) - var(--size-layout-block-cell-spacing));right:var(--size-layout-block-cell-spacing);z-index:var(--z-index);width:640px;height:var(--height)}.dialog-state-container header i{font-size:28px;color:#848484}\n"] }]
|
|
34
34
|
}], ctorParameters: () => [{ type: i1.MultiLanguageService }, { type: i2.DialogService }, { type: i3.DomService }], propDecorators: { container: [{
|
|
35
35
|
type: ViewChild,
|
|
36
36
|
args: ['container']
|
|
37
37
|
}] } });
|
|
38
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9nLXN0YXRlLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1oaXN0YWZmLWFscGhhL3NyYy9saWIvYXBwL2NvbXBvbmVudHMvZGlhbG9nLXN0YXRlL2RpYWxvZy1zdGF0ZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtaGlzdGFmZi1hbHBoYS9zcmMvbGliL2FwcC9jb21wb25lbnRzL2RpYWxvZy1zdGF0ZS9kaWFsb2ctc3RhdGUuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFpQixTQUFTLEVBQXNCLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUd4RixPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sb0RBQW9ELENBQUM7QUFFbkYsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQzs7Ozs7QUFZL0QsTUFBTSxPQUFPLG9CQUFxQixTQUFRLGFBQWE7SUFJckQsWUFDa0IsR0FBeUIsRUFDbEMsRUFBaUIsRUFDaEIsVUFBc0I7UUFDMUIsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFBO1FBSEUsUUFBRyxHQUFILEdBQUcsQ0FBc0I7UUFDbEMsT0FBRSxHQUFGLEVBQUUsQ0FBZTtRQUNoQixlQUFVLEdBQVYsVUFBVSxDQUFZO0lBQ2YsQ0FBQztJQUVsQixlQUFlO1FBQ2IsVUFBVSxDQUFDLEdBQUcsRUFBRTtZQUNkLE1BQU0sQ0FBQyxHQUFHLElBQUksQ0FBQyxVQUFVLENBQUMsWUFBWSxFQUFFLENBQUM7WUFDekMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxhQUFhLENBQUMsS0FBSyxDQUFDLFdBQVcsQ0FBQyxXQUFXLEVBQUUsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDO1FBQ3JFLENBQUMsQ0FBQyxDQUFBO0lBQ0osQ0FBQztJQUVELEtBQUs7UUFDSCxJQUFJLENBQUMsRUFBRSxDQUFDLGdCQUFnQixDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUN2QyxDQUFDOzhHQW5CVSxvQkFBb0I7a0dBQXBCLG9CQUFvQiwyTUNsQmpDLHk4RUFxREcsbWREekNDLFlBQVksMEJBQ1osYUFBYTs7MkZBS0osb0JBQW9CO2tCQVZoQyxTQUFTOytCQUNFLGtCQUFrQixjQUNoQixJQUFJLFdBQ1A7d0JBQ1AsWUFBWTt3QkFDWixhQUFhO3FCQUNkOzhJQU11QixTQUFTO3NCQUFoQyxTQUFTO3VCQUFDLFdBQVciLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBZnRlclZpZXdJbml0LCBDb21wb25lbnQsIEVsZW1lbnRSZWYsIE9uSW5pdCwgVmlld0NoaWxkIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IERpYWxvZ1NlcnZpY2UgfSBmcm9tICcuLi8uLi9zZXJ2aWNlcy9kaWFsb2cuc2VydmljZSc7XHJcbmltcG9ydCB7IERvbVNlcnZpY2UgfSBmcm9tICcuLi8uLi9saWJyYXJpZXMvc2VydmljZXMvZG9tLnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBCYXNlQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vbGlicmFyaWVzL2Jhc2UtY29tcG9uZW50L2Jhc2UvYmFzZS5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBNdWx0aUxhbmd1YWdlU2VydmljZSB9IGZyb20gJy4uLy4uL3NlcnZpY2VzL211bHRpLWxhbmd1YWdlLnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBUcmFuc2xhdGVQaXBlIH0gZnJvbSAnLi4vLi4vYXBwLXBpcGVzL3RyYW5zbGF0ZS5waXBlJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnYXBwLWRpYWxvZy1zdGF0ZScsXHJcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcclxuICBpbXBvcnRzOiBbXHJcbiAgICBDb21tb25Nb2R1bGUsXHJcbiAgICBUcmFuc2xhdGVQaXBlXHJcbiAgXSxcclxuICB0ZW1wbGF0ZVVybDogJy4vZGlhbG9nLXN0YXRlLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9kaWFsb2ctc3RhdGUuY29tcG9uZW50LnNjc3MnXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgRGlhbG9nU3RhdGVDb21wb25lbnQgZXh0ZW5kcyBCYXNlQ29tcG9uZW50IGltcGxlbWVudHMgQWZ0ZXJWaWV3SW5pdCB7XHJcblxyXG4gIEBWaWV3Q2hpbGQoJ2NvbnRhaW5lcicpIGNvbnRhaW5lciE6IEVsZW1lbnRSZWY8YW55PjtcclxuXHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBwdWJsaWMgb3ZlcnJpZGUgbWxzOiBNdWx0aUxhbmd1YWdlU2VydmljZSxcclxuICAgIHB1YmxpYyBkczogRGlhbG9nU2VydmljZSwgXHJcbiAgICBwcml2YXRlIGRvbVNlcnZpY2U6IERvbVNlcnZpY2VcclxuICAgICkgeyBzdXBlcihtbHMpIH1cclxuXHJcbiAgbmdBZnRlclZpZXdJbml0KCk6IHZvaWQge1xyXG4gICAgc2V0VGltZW91dCgoKSA9PiB7XHJcbiAgICAgIGNvbnN0IHogPSB0aGlzLmRvbVNlcnZpY2UuZ2V0TWF4WkluZGV4KCk7XHJcbiAgICAgIHRoaXMuY29udGFpbmVyLm5hdGl2ZUVsZW1lbnQuc3R5bGUuc2V0UHJvcGVydHkoJy0tei1pbmRleCcsIHogKyAxKTtcclxuICAgIH0pXHJcbiAgfVxyXG5cclxuICBjbG9zZSgpOiB2b2lkIHtcclxuICAgIHRoaXMuZHMuZGlhbG9nU3RhdGVPcGVuJC5uZXh0KGZhbHNlKTtcclxuICB9XHJcblxyXG59XHJcbiIsIjxkaXYgI2NvbnRhaW5lciBjbGFzcz1cImRpYWxvZy1zdGF0ZS1jb250YWluZXIgaW50ZXItZm9udFwiPlxyXG4gICAgPGRpdiBjbGFzcz1cImhlYWRlciB3LTEwMCBkLWZsZXggZC1mbGV4LWJldHdlZW5cIj5cclxuICAgICAgICA8c3Bhbj5EaWFsb2cgU3RhdGU8L3NwYW4+XHJcbiAgICAgICAgPGkgY2xhc3M9XCJmZWF0aGVyLXhcIiAoY2xpY2spPVwiY2xvc2UoKVwiPjwvaT5cclxuICAgIDwvZGl2PlxyXG4gICAgPGRpdiBjbGFzcz1cImNvbnRhaW5lciBjb250YWluZXItZmx1aWRcIj5cclxuICAgICAgICA8ZGl2IGNsYXNzPVwicm93XCI+XHJcbiAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJjb2wtbWQtNCBsYWJlbFwiPmJ1c3k8L2Rpdj5cclxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cImNvbC1tZC04IGZvbnQtYm9sZFwiPnt7IGRzLmJ1c3kgfX08L2Rpdj5cclxuICAgICAgICA8L2Rpdj5cclxuICAgICAgICA8ZGl2IGNsYXNzPVwicm93XCI+XHJcbiAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJjb2wtbWQtNCBsYWJlbFwiPnNob3dDb25maXJtRGlhbG9nPC9kaXY+XHJcbiAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJjb2wtbWQtOCBmb250LWJvbGRcIj57eyBkcy5zaG93Q29uZmlybURpYWxvZyQudmFsdWUgfX08L2Rpdj5cclxuICAgICAgICA8L2Rpdj5cclxuICAgICAgICA8ZGl2IGNsYXNzPVwicm93XCI+XHJcbiAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJjb2wtbWQtNCBsYWJlbFwiPmRpYWxvZ0NvbmZpcm1lZDwvZGl2PlxyXG4gICAgICAgICAgICA8ZGl2IGNsYXNzPVwiY29sLW1kLTggZm9udC1ib2xkXCI+e3sgZHMuZGlhbG9nQ29uZmlybWVkJC52YWx1ZSB9fTwvZGl2PlxyXG4gICAgICAgIDwvZGl2PlxyXG4gICAgICAgIDxkaXYgY2xhc3M9XCJyb3dcIj5cclxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cImNvbC1tZC00IGxhYmVsXCI+dGl0bGU8L2Rpdj5cclxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cImNvbC1tZC04IGZvbnQtYm9sZFwiPnt7IGRzLnRpdGxlJC52YWx1ZSB8IHRyYW5zbGF0ZTogbGFuZ319PC9kaXY+XHJcbiAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgPGRpdiBjbGFzcz1cInJvd1wiPlxyXG4gICAgICAgICAgICA8ZGl2IGNsYXNzPVwiY29sLW1kLTQgbGFiZWxcIj5ib2R5PC9kaXY+XHJcbiAgICAgICAgICAgIDxkaXYgY2xhc3M9XCJjb2wtbWQtOCBmb250LWJvbGRcIj57eyBkcy5ib2R5JC52YWx1ZSB8IHRyYW5zbGF0ZTogbGFuZ319PC9kaXY+XHJcbiAgICAgICAgPC9kaXY+XHJcbiAgICAgICAgPGRpdiBjbGFzcz1cInJvd1wiPlxyXG4gICAgICAgICAgICA8ZGl2IGNsYXNzPVwiY29sLW1kLTQgbGFiZWxcIj5va0J1dHRvblRleHQ8L2Rpdj5cclxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cImNvbC1tZC04IGZvbnQtYm9sZFwiPnt7IGRzLm9rQnV0dG9uVGV4dCQudmFsdWUgfCB0cmFuc2xhdGU6IGxhbmd9fTwvZGl2PlxyXG4gICAgICAgIDwvZGl2PlxyXG4gICAgICAgIDxkaXYgY2xhc3M9XCJyb3dcIj5cclxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cImNvbC1tZC00IGxhYmVsXCI+Y2FuY2VsQnV0dG9uVGV4dDwvZGl2PlxyXG4gICAgICAgICAgICA8ZGl2IGNsYXNzPVwiY29sLW1kLTggZm9udC1ib2xkXCI+e3sgZHMuY2FuY2VsQnV0dG9uVGV4dCQudmFsdWUgfCB0cmFuc2xhdGU6IGxhbmd9fTwvZGl2PlxyXG4gICAgICAgIDwvZGl2PlxyXG4gICAgICAgIDxkaXYgY2xhc3M9XCJyb3dcIj5cclxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cImNvbC1tZC00IGxhYmVsXCI+aW5zdGFuY2VOdW1iZXI8L2Rpdj5cclxuICAgICAgICAgICAgPGRpdiBjbGFzcz1cImNvbC1tZC04IGZvbnQtYm9sZFwiPnt7IGRzLmRpYWxvZ0NvbmZpcm1lZCQudmFsdWU/Lmluc3RhbmNlTnVtYmVyIH19PC9kaXY+XHJcbiAgICAgICAgPC9kaXY+XHJcblxyXG4gICAgPC9kaXY+XHJcbjwvZGl2PlxyXG5cclxuPCEtLVxyXG4gICAgYnVzeSE6IGJvb2xlYW47XHJcbiAgICBzaG93Q29uZmlybURpYWxvZyQgPSBuZXcgQmVoYXZpb3JTdWJqZWN0PGJvb2xlYW4gfCB1bmRlZmluZWQ+KHVuZGVmaW5lZCk7XHJcbiAgICBjYW5EZWFjdGl2YXRlJCA9IG5ldyBTdWJqZWN0PGJvb2xlYW4+O1xyXG4gICAgZGlhbG9nQ29uZmlybWVkJCA9IG5ldyBCZWhhdmlvclN1YmplY3Q8SURpYWxvZ0NvbmZpcm1Nb2RlbCB8IHVuZGVmaW5lZD4odW5kZWZpbmVkKTtcclxuICAgIHRpdGxlJCA9IG5ldyBTdWJqZWN0PEVudW1UcmFuc2xhdGVLZXk+O1xyXG4gICAgYm9keSQgPSBuZXcgU3ViamVjdDxFbnVtVHJhbnNsYXRlS2V5PjtcclxuICAgIG9rQnV0dG9uVGV4dCQgPSBuZXcgU3ViamVjdDxFbnVtVHJhbnNsYXRlS2V5PjtcclxuICAgIGNhbmNlbEJ1dHRvblRleHQkID0gbmV3IFN1YmplY3Q8RW51bVRyYW5zbGF0ZUtleT47XHJcbiAgICBzaG93Q2FuY2VsT25seSQgPSBuZXcgU3ViamVjdDxib29sZWFuPjtcclxuICAgIGluZm9ybWF0aW9uTGluZXMkID0gbmV3IFN1YmplY3Q8c3RyaW5nW10+O1xyXG4tLT4iXX0=
|
|
@@ -80,11 +80,11 @@ export class AlertComponent {
|
|
|
80
80
|
this.subscriptions.map(x => x.unsubscribe());
|
|
81
81
|
}
|
|
82
82
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: AlertComponent, deps: [{ token: i1.Router }, { token: i2.AlertService }, { token: i3.DomService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
83
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.3", type: AlertComponent, isStandalone: true, selector: "core-alert", inputs: { id: "id", fade: "fade" }, viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true }], ngImport: i0, template: "<div class=\"core-alert-container
|
|
83
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.3", type: AlertComponent, isStandalone: true, selector: "core-alert", inputs: { id: "id", fade: "fade" }, viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true }], ngImport: i0, template: "<div class=\"core-alert-container inter-font\" #container>\r\n <div class=\"wrapper w-100\">\r\n <div *ngFor=\"let alert of alerts\" class=\"{{cssClass(alert)}}\">\r\n <div [innerHTML]=\"alert.message\"></div>\r\n <button type=\"button\" class=\"btn-close\" (click)=\"removeAlert(alert)\"></button>\r\n </div>\r\n </div>\r\n</div>", styles: [".core-alert-container{display:block!important;height:var(--size-header-height)!important;text-align:end!important;position:fixed!important;top:0!important;right:0!important;--z-index: 1;z-index:var(--z-index)}@keyframes fadeIn{0%{opacity:0;transform:translate(-100%)}0%{opacity:1;transform:translate(0)}}.core-alert-container .wrapper{display:block!important;position:relative!important;text-align:end!important;height:var(--size-header-height)!important}.core-alert-container .wrapper .alert-success,.core-alert-container .wrapper .alert-danger,.core-alert-container .wrapper .alert-info,.core-alert-container .wrapper .alert-warning{animation:fadeIn .5s ease-in-out}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] }); }
|
|
84
84
|
}
|
|
85
85
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: AlertComponent, decorators: [{
|
|
86
86
|
type: Component,
|
|
87
|
-
args: [{ selector: 'core-alert', standalone: true, imports: [CommonModule], template: "<div class=\"core-alert-container
|
|
87
|
+
args: [{ selector: 'core-alert', standalone: true, imports: [CommonModule], template: "<div class=\"core-alert-container inter-font\" #container>\r\n <div class=\"wrapper w-100\">\r\n <div *ngFor=\"let alert of alerts\" class=\"{{cssClass(alert)}}\">\r\n <div [innerHTML]=\"alert.message\"></div>\r\n <button type=\"button\" class=\"btn-close\" (click)=\"removeAlert(alert)\"></button>\r\n </div>\r\n </div>\r\n</div>", styles: [".core-alert-container{display:block!important;height:var(--size-header-height)!important;text-align:end!important;position:fixed!important;top:0!important;right:0!important;--z-index: 1;z-index:var(--z-index)}@keyframes fadeIn{0%{opacity:0;transform:translate(-100%)}0%{opacity:1;transform:translate(0)}}.core-alert-container .wrapper{display:block!important;position:relative!important;text-align:end!important;height:var(--size-header-height)!important}.core-alert-container .wrapper .alert-success,.core-alert-container .wrapper .alert-danger,.core-alert-container .wrapper .alert-info,.core-alert-container .wrapper .alert-warning{animation:fadeIn .5s ease-in-out}\n"] }]
|
|
88
88
|
}], ctorParameters: () => [{ type: i1.Router }, { type: i2.AlertService }, { type: i3.DomService }], propDecorators: { id: [{
|
|
89
89
|
type: Input
|
|
90
90
|
}], fade: [{
|
|
@@ -93,4 +93,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
|
|
|
93
93
|
type: ViewChild,
|
|
94
94
|
args: ['container']
|
|
95
95
|
}] } });
|
|
96
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"alert.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/alert/alert/alert.component.ts","../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/alert/alert/alert.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, AfterViewInit, OnDestroy, Input, ViewChild, ElementRef } from '@angular/core';\r\nimport { Router, NavigationStart } from '@angular/router';\r\nimport { Subscription, switchMap } from 'rxjs';\r\n\r\nimport { IAlert, EnumAlertType } from './alert.model';\r\nimport { AlertService } from '../alert.service';\r\nimport { DomService } from '../../services/dom.service';\r\nimport { CommonModule } from '@angular/common';\r\n\r\n@Component({\r\n    selector: 'core-alert',\r\n    standalone: true,\r\n    imports: [CommonModule],\r\n    templateUrl: './alert.component.html',\r\n    styleUrls: ['./alert.component.scss']\r\n})\r\nexport class AlertComponent implements OnInit, AfterViewInit, OnDestroy {\r\n    @Input() id = 'default-alert';\r\n    @Input() fade = true;\r\n\r\n    @ViewChild('container') container!: ElementRef;\r\n\r\n    alerts: IAlert[] = [];\r\n\r\n    subscriptions: Subscription[] = [];\r\n\r\n    constructor(\r\n        private router: Router,\r\n        private alertService: AlertService,\r\n        private domService: DomService\r\n    ) { }\r\n\r\n    ngOnInit() {\r\n        // subscribe to new alert notifications\r\n\r\n        this.subscriptions.push(\r\n            this.alertService.alerts$.subscribe(x => this.alerts = x)\r\n        )\r\n\r\n        // clear alerts on location change\r\n        this.subscriptions.push(\r\n            this.router.events.subscribe(event => {\r\n                if (event instanceof NavigationStart) {\r\n                    this.alertService.clear(this.id);\r\n                }\r\n            })\r\n        );\r\n    }\r\n\r\n    ngAfterViewInit(): void {\r\n        setTimeout(() => {\r\n            this.container!.nativeElement.style.setProperty('--z-index', this.domService.getMaxZIndex() + 1)\r\n\r\n            this.subscriptions.push(\r\n                this.alertService.alerts$.pipe(\r\n                    switchMap(x => this.alertService.alerts$)\r\n                )\r\n                    .subscribe(x => {\r\n    \r\n                        this.alerts = x;\r\n                        this.container!.nativeElement.style.setProperty('--z-index', this.domService.getMaxZIndex() + 1)\r\n    \r\n                        // auto close alert if required\r\n                        x.map(alert => {\r\n                            if (!!alert.autoClose) {\r\n                                setTimeout(() => this.removeAlert(alert), alert.timeClose);\r\n                            }\r\n                        })\r\n                    })\r\n            );\r\n    \r\n        })\r\n    }\r\n\r\n    removeAlert(alert: IAlert) {\r\n        // check if already removed to prevent error on auto close\r\n        if (!this.alerts.includes(alert)) return;\r\n\r\n        // fade out alert if this.fade === true\r\n        const timeout = this.fade ? 250 : 0;\r\n        alert.fade = this.fade;\r\n\r\n        setTimeout(() => {\r\n            // filter alert out of array\r\n            const newAlerts = this.alerts.filter(x => x.id !== alert.id);\r\n            this.alertService.alerts$.next(newAlerts);\r\n        }, timeout);\r\n    }\r\n\r\n    cssClass(alert: IAlert) {\r\n        if (!alert) return;\r\n\r\n        const classes = ['alert', 'alert-dismissible'];\r\n\r\n        const alertTypeClass = {\r\n            [EnumAlertType.Success]: 'alert-success',\r\n            [EnumAlertType.Error]: 'alert-danger',\r\n            [EnumAlertType.Info]: 'alert-info',\r\n            [EnumAlertType.Warning]: 'alert-warning'\r\n        }\r\n\r\n        if (alert.type !== undefined) {\r\n            classes.push(alertTypeClass[alert.type]);\r\n        }\r\n\r\n        if (alert.fade) {\r\n            classes.push('fade');\r\n        }\r\n\r\n        return classes.join(' ');\r\n    }\r\n\r\n    ngOnDestroy() {\r\n        // unsubscribe to avoid memory leaks\r\n        this.subscriptions.map(x => x.unsubscribe());\r\n    }\r\n}","<div class=\"core-alert-container roboto-font\" #container>\r\n    <div class=\"wrapper w-100\">\r\n        <div *ngFor=\"let alert of alerts\" class=\"{{cssClass(alert)}}\">\r\n            <div [innerHTML]=\"alert.message\"></div>\r\n            <button type=\"button\" class=\"btn-close\" (click)=\"removeAlert(alert)\"></button>\r\n        </div>\r\n    </div>\r\n</div>"]}
|
|
96
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"alert.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/alert/alert/alert.component.ts","../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/alert/alert/alert.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAoC,KAAK,EAAE,SAAS,EAAc,MAAM,eAAe,CAAC;AAC1G,OAAO,EAAU,eAAe,EAAE,MAAM,iBAAiB,CAAC;AAC1D,OAAO,EAAgB,SAAS,EAAE,MAAM,MAAM,CAAC;AAE/C,OAAO,EAAU,aAAa,EAAE,MAAM,eAAe,CAAC;AAGtD,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;;;;;;AAS/C,MAAM,OAAO,cAAc;IAUvB,YACY,MAAc,EACd,YAA0B,EAC1B,UAAsB;QAFtB,WAAM,GAAN,MAAM,CAAQ;QACd,iBAAY,GAAZ,YAAY,CAAc;QAC1B,eAAU,GAAV,UAAU,CAAY;QAZzB,OAAE,GAAG,eAAe,CAAC;QACrB,SAAI,GAAG,IAAI,CAAC;QAIrB,WAAM,GAAa,EAAE,CAAC;QAEtB,kBAAa,GAAmB,EAAE,CAAC;IAM/B,CAAC;IAEL,QAAQ;QACJ,uCAAuC;QAEvC,IAAI,CAAC,aAAa,CAAC,IAAI,CACnB,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAC5D,CAAA;QAED,kCAAkC;QAClC,IAAI,CAAC,aAAa,CAAC,IAAI,CACnB,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE;YACjC,IAAI,KAAK,YAAY,eAAe,EAAE;gBAClC,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;aACpC;QACL,CAAC,CAAC,CACL,CAAC;IACN,CAAC;IAED,eAAe;QACX,UAAU,CAAC,GAAG,EAAE;YACZ,IAAI,CAAC,SAAU,CAAC,aAAa,CAAC,KAAK,CAAC,WAAW,CAAC,WAAW,EAAE,IAAI,CAAC,UAAU,CAAC,YAAY,EAAE,GAAG,CAAC,CAAC,CAAA;YAEhG,IAAI,CAAC,aAAa,CAAC,IAAI,CACnB,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,IAAI,CAC1B,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,CAC5C;iBACI,SAAS,CAAC,CAAC,CAAC,EAAE;gBAEX,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;gBAChB,IAAI,CAAC,SAAU,CAAC,aAAa,CAAC,KAAK,CAAC,WAAW,CAAC,WAAW,EAAE,IAAI,CAAC,UAAU,CAAC,YAAY,EAAE,GAAG,CAAC,CAAC,CAAA;gBAEhG,+BAA+B;gBAC/B,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE;oBACV,IAAI,CAAC,CAAC,KAAK,CAAC,SAAS,EAAE;wBACnB,UAAU,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC,CAAC;qBAC9D;gBACL,CAAC,CAAC,CAAA;YACN,CAAC,CAAC,CACT,CAAC;QAEN,CAAC,CAAC,CAAA;IACN,CAAC;IAED,WAAW,CAAC,KAAa;QACrB,0DAA0D;QAC1D,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC;YAAE,OAAO;QAEzC,uCAAuC;QACvC,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QACpC,KAAK,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC;QAEvB,UAAU,CAAC,GAAG,EAAE;YACZ,4BAA4B;YAC5B,MAAM,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,KAAK,CAAC,EAAE,CAAC,CAAC;YAC7D,IAAI,CAAC,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QAC9C,CAAC,EAAE,OAAO,CAAC,CAAC;IAChB,CAAC;IAED,QAAQ,CAAC,KAAa;QAClB,IAAI,CAAC,KAAK;YAAE,OAAO;QAEnB,MAAM,OAAO,GAAG,CAAC,OAAO,EAAE,mBAAmB,CAAC,CAAC;QAE/C,MAAM,cAAc,GAAG;YACnB,CAAC,aAAa,CAAC,OAAO,CAAC,EAAE,eAAe;YACxC,CAAC,aAAa,CAAC,KAAK,CAAC,EAAE,cAAc;YACrC,CAAC,aAAa,CAAC,IAAI,CAAC,EAAE,YAAY;YAClC,CAAC,aAAa,CAAC,OAAO,CAAC,EAAE,eAAe;SAC3C,CAAA;QAED,IAAI,KAAK,CAAC,IAAI,KAAK,SAAS,EAAE;YAC1B,OAAO,CAAC,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC;SAC5C;QAED,IAAI,KAAK,CAAC,IAAI,EAAE;YACZ,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;SACxB;QAED,OAAO,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAC7B,CAAC;IAED,WAAW;QACP,oCAAoC;QACpC,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC;IACjD,CAAC;8GAnGQ,cAAc;kGAAd,cAAc,kNChB3B,sXAOM,utBDKQ,YAAY;;2FAIb,cAAc;kBAP1B,SAAS;+BACI,YAAY,cACV,IAAI,WACP,CAAC,YAAY,CAAC;+HAKd,EAAE;sBAAV,KAAK;gBACG,IAAI;sBAAZ,KAAK;gBAEkB,SAAS;sBAAhC,SAAS;uBAAC,WAAW","sourcesContent":["import { Component, OnInit, AfterViewInit, OnDestroy, Input, ViewChild, ElementRef } from '@angular/core';\r\nimport { Router, NavigationStart } from '@angular/router';\r\nimport { Subscription, switchMap } from 'rxjs';\r\n\r\nimport { IAlert, EnumAlertType } from './alert.model';\r\nimport { AlertService } from '../alert.service';\r\nimport { DomService } from '../../services/dom.service';\r\nimport { CommonModule } from '@angular/common';\r\n\r\n@Component({\r\n    selector: 'core-alert',\r\n    standalone: true,\r\n    imports: [CommonModule],\r\n    templateUrl: './alert.component.html',\r\n    styleUrls: ['./alert.component.scss']\r\n})\r\nexport class AlertComponent implements OnInit, AfterViewInit, OnDestroy {\r\n    @Input() id = 'default-alert';\r\n    @Input() fade = true;\r\n\r\n    @ViewChild('container') container!: ElementRef;\r\n\r\n    alerts: IAlert[] = [];\r\n\r\n    subscriptions: Subscription[] = [];\r\n\r\n    constructor(\r\n        private router: Router,\r\n        private alertService: AlertService,\r\n        private domService: DomService\r\n    ) { }\r\n\r\n    ngOnInit() {\r\n        // subscribe to new alert notifications\r\n\r\n        this.subscriptions.push(\r\n            this.alertService.alerts$.subscribe(x => this.alerts = x)\r\n        )\r\n\r\n        // clear alerts on location change\r\n        this.subscriptions.push(\r\n            this.router.events.subscribe(event => {\r\n                if (event instanceof NavigationStart) {\r\n                    this.alertService.clear(this.id);\r\n                }\r\n            })\r\n        );\r\n    }\r\n\r\n    ngAfterViewInit(): void {\r\n        setTimeout(() => {\r\n            this.container!.nativeElement.style.setProperty('--z-index', this.domService.getMaxZIndex() + 1)\r\n\r\n            this.subscriptions.push(\r\n                this.alertService.alerts$.pipe(\r\n                    switchMap(x => this.alertService.alerts$)\r\n                )\r\n                    .subscribe(x => {\r\n    \r\n                        this.alerts = x;\r\n                        this.container!.nativeElement.style.setProperty('--z-index', this.domService.getMaxZIndex() + 1)\r\n    \r\n                        // auto close alert if required\r\n                        x.map(alert => {\r\n                            if (!!alert.autoClose) {\r\n                                setTimeout(() => this.removeAlert(alert), alert.timeClose);\r\n                            }\r\n                        })\r\n                    })\r\n            );\r\n    \r\n        })\r\n    }\r\n\r\n    removeAlert(alert: IAlert) {\r\n        // check if already removed to prevent error on auto close\r\n        if (!this.alerts.includes(alert)) return;\r\n\r\n        // fade out alert if this.fade === true\r\n        const timeout = this.fade ? 250 : 0;\r\n        alert.fade = this.fade;\r\n\r\n        setTimeout(() => {\r\n            // filter alert out of array\r\n            const newAlerts = this.alerts.filter(x => x.id !== alert.id);\r\n            this.alertService.alerts$.next(newAlerts);\r\n        }, timeout);\r\n    }\r\n\r\n    cssClass(alert: IAlert) {\r\n        if (!alert) return;\r\n\r\n        const classes = ['alert', 'alert-dismissible'];\r\n\r\n        const alertTypeClass = {\r\n            [EnumAlertType.Success]: 'alert-success',\r\n            [EnumAlertType.Error]: 'alert-danger',\r\n            [EnumAlertType.Info]: 'alert-info',\r\n            [EnumAlertType.Warning]: 'alert-warning'\r\n        }\r\n\r\n        if (alert.type !== undefined) {\r\n            classes.push(alertTypeClass[alert.type]);\r\n        }\r\n\r\n        if (alert.fade) {\r\n            classes.push('fade');\r\n        }\r\n\r\n        return classes.join(' ');\r\n    }\r\n\r\n    ngOnDestroy() {\r\n        // unsubscribe to avoid memory leaks\r\n        this.subscriptions.map(x => x.unsubscribe());\r\n    }\r\n}","<div class=\"core-alert-container inter-font\" #container>\r\n    <div class=\"wrapper w-100\">\r\n        <div *ngFor=\"let alert of alerts\" class=\"{{cssClass(alert)}}\">\r\n            <div [innerHTML]=\"alert.message\"></div>\r\n            <button type=\"button\" class=\"btn-close\" (click)=\"removeAlert(alert)\"></button>\r\n        </div>\r\n    </div>\r\n</div>"]}
|
|
@@ -64,7 +64,7 @@ export class CoreConfirmDialogComponent extends BaseComponent {
|
|
|
64
64
|
this.dialogService.reason$.next('');
|
|
65
65
|
}
|
|
66
66
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: CoreConfirmDialogComponent, deps: [{ token: i1.MultiLanguageService }, { token: i2.DialogService }, { token: i3.RoutingService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
67
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.3", type: CoreConfirmDialogComponent, isStandalone: true, selector: "core-confirm-dialog", inputs: { showingUp: "showingUp" }, viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div #container class=\"core-confirm-dialog-container
|
|
67
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.3", type: CoreConfirmDialogComponent, isStandalone: true, selector: "core-confirm-dialog", inputs: { showingUp: "showingUp" }, viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div #container class=\"core-confirm-dialog-container inter-font\">\r\n <div class=\"modal-container\" *ngIf=\"show\">\r\n <div class=\"modal-content\">\r\n <div class=\"modal fade show\" style=\"display: block;\">\r\n <div class=\"modal-dialog\">\r\n <div class=\"modal-content\">\r\n <div class=\"modal-header\">\r\n\r\n <core-page-header [title]=\"title\" [hideButtonGroup]=\"true\"></core-page-header>\r\n\r\n <button type=\"button\" class=\"close\" [ngStyle]=\"{\r\n border: 'none',\r\n background: 'transparent',\r\n fontSize: '28px'\r\n }\">\r\n <span (click)=\"close()\">\u00D7</span>\r\n </button>\r\n </div>\r\n <div class=\"modal-body\">{{ body | translate: lang }}</div>\r\n <ul *ngIf=\"!!informationLines?.length\">\r\n <li *ngFor=\"let line of informationLines\">\r\n {{ line }}\r\n </li>\r\n </ul>\r\n <div class=\"p15 d-flex d-flex-center\">\r\n <textarea [(ngModel)]=\"reason\" (ngModelChange)=\"onReasonEvent($event)\" class=\"form-control hidden-input\" [class.shown]=\"showingUp === true\" [rows]=\"'5'\" [ngStyle]=\"{ height: 'unset' }\"></textarea>\r\n </div>\r\n <div class=\"modal-footer\">\r\n <button (click)=\"onConfirm()\" type=\"button\" class=\"btn btn-secondary\" *ngIf=\"!!!showCancelOnly\">{{ okButtonText | translate: lang }}</button>\r\n <button (click)=\"close()\" type=\"button\" class=\"btn btn-primary\">{{ cancelButtonText | translate: lang }}</button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n</div>", styles: [".core-confirm-dialog-container{--z-index: 9999999999;position:absolute;z-index:var(--z-index);font-size:13px}.core-confirm-dialog-container .hidden-input{display:none}.core-confirm-dialog-container .shown{display:block}.core-confirm-dialog-container .modal-header{padding-top:0;padding-bottom:0}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i4.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i5.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: 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: CorePageHeaderComponent, selector: "core-page-header", inputs: ["instanceNumber", "shownItems", "title", "hideButtonGroup"], outputs: ["buttonClick"] }] }); }
|
|
68
68
|
}
|
|
69
69
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: CoreConfirmDialogComponent, decorators: [{
|
|
70
70
|
type: Component,
|
|
@@ -73,11 +73,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
|
|
|
73
73
|
TranslatePipe,
|
|
74
74
|
FormsModule,
|
|
75
75
|
CorePageHeaderComponent
|
|
76
|
-
], template: "<div #container class=\"core-confirm-dialog-container
|
|
76
|
+
], template: "<div #container class=\"core-confirm-dialog-container inter-font\">\r\n <div class=\"modal-container\" *ngIf=\"show\">\r\n <div class=\"modal-content\">\r\n <div class=\"modal fade show\" style=\"display: block;\">\r\n <div class=\"modal-dialog\">\r\n <div class=\"modal-content\">\r\n <div class=\"modal-header\">\r\n\r\n <core-page-header [title]=\"title\" [hideButtonGroup]=\"true\"></core-page-header>\r\n\r\n <button type=\"button\" class=\"close\" [ngStyle]=\"{\r\n border: 'none',\r\n background: 'transparent',\r\n fontSize: '28px'\r\n }\">\r\n <span (click)=\"close()\">\u00D7</span>\r\n </button>\r\n </div>\r\n <div class=\"modal-body\">{{ body | translate: lang }}</div>\r\n <ul *ngIf=\"!!informationLines?.length\">\r\n <li *ngFor=\"let line of informationLines\">\r\n {{ line }}\r\n </li>\r\n </ul>\r\n <div class=\"p15 d-flex d-flex-center\">\r\n <textarea [(ngModel)]=\"reason\" (ngModelChange)=\"onReasonEvent($event)\" class=\"form-control hidden-input\" [class.shown]=\"showingUp === true\" [rows]=\"'5'\" [ngStyle]=\"{ height: 'unset' }\"></textarea>\r\n </div>\r\n <div class=\"modal-footer\">\r\n <button (click)=\"onConfirm()\" type=\"button\" class=\"btn btn-secondary\" *ngIf=\"!!!showCancelOnly\">{{ okButtonText | translate: lang }}</button>\r\n <button (click)=\"close()\" type=\"button\" class=\"btn btn-primary\">{{ cancelButtonText | translate: lang }}</button>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n </div>\r\n</div>", styles: [".core-confirm-dialog-container{--z-index: 9999999999;position:absolute;z-index:var(--z-index);font-size:13px}.core-confirm-dialog-container .hidden-input{display:none}.core-confirm-dialog-container .shown{display:block}.core-confirm-dialog-container .modal-header{padding-top:0;padding-bottom:0}\n"] }]
|
|
77
77
|
}], ctorParameters: () => [{ type: i1.MultiLanguageService }, { type: i2.DialogService }, { type: i3.RoutingService }], propDecorators: { showingUp: [{
|
|
78
78
|
type: Input
|
|
79
79
|
}], container: [{
|
|
80
80
|
type: ViewChild,
|
|
81
81
|
args: ['container']
|
|
82
82
|
}] } });
|
|
83
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-confirm-dialog.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-confirm-dialog/core-confirm-dialog/core-confirm-dialog.component.ts","../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-confirm-dialog/core-confirm-dialog/core-confirm-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, AfterViewInit, ViewChild, OnDestroy, Input } from '@angular/core';\r\n\r\nimport { DialogService } from '../../../services/dialog.service';\r\nimport { BaseComponent } from '../../base-component/base/base.component';\r\nimport { MultiLanguageService } from '../../../services/multi-language.service';\r\nimport { EnumTranslateKey } from \"alpha-global-constants\";\r\nimport { RoutingService } from '../../../services/routing.service';\r\nimport { CommonModule } from '@angular/common';\r\nimport { TranslatePipe } from '../../../app-pipes/translate.pipe';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { CorePageHeaderComponent } from '../../core-page-header/core-page-header/core-page-header.component';\r\n\r\n@Component({\r\n  selector: 'core-confirm-dialog',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    TranslatePipe,\r\n    FormsModule,\r\n    CorePageHeaderComponent\r\n  ],\r\n  templateUrl: './core-confirm-dialog.component.html',\r\n  styleUrls: ['./core-confirm-dialog.component.scss']\r\n})\r\nexport class CoreConfirmDialogComponent extends BaseComponent implements AfterViewInit, OnDestroy {\r\n  @Input() showingUp!: boolean;\r\n  @ViewChild('container') container!: ElementRef;\r\n\r\n  show!: boolean | undefined;\r\n\r\n  okButtonText: EnumTranslateKey = EnumTranslateKey.UI_CORE_CONFIRM_DIALOG_BUTTON_SURE; // DEFAULT\r\n  cancelButtonText: EnumTranslateKey = EnumTranslateKey.UI_CORE_CONFIRM_DIALOG_BUTTON_CANCEL; // DEFAULT\r\n  title!: EnumTranslateKey;\r\n  body!: EnumTranslateKey;\r\n  showCancelOnly!: boolean;\r\n  informationLines!: string[];\r\n  reason: string = '';\r\n\r\n\r\n  constructor(\r\n    public override mls: MultiLanguageService,\r\n    private dialogService: DialogService,\r\n    private routingService: RoutingService\r\n  ) {\r\n    super(mls);\r\n\r\n    this.subscriptions.push(\r\n      this.dialogService.showConfirmDialog$.subscribe(x => {\r\n        this.show = x\r\n        // Stop navigating property to show opacity 1 while showConfirmDialog$ changes \r\n        this.routingService.navigating$.next(false)\r\n      })\r\n    )\r\n    this.subscriptions.push(\r\n      this.dialogService.title$.subscribe(x => this.title = x)\r\n    )\r\n    this.subscriptions.push(\r\n      this.dialogService.body$.subscribe(x => this.body = x)\r\n    )\r\n    this.subscriptions.push(\r\n      this.dialogService.okButtonText$.subscribe(x => this.okButtonText = x)\r\n    )\r\n    this.subscriptions.push(\r\n      this.dialogService.cancelButtonText$.subscribe(x => this.cancelButtonText = x)\r\n    )\r\n    this.subscriptions.push(\r\n      this.dialogService.showCancelOnly$.subscribe(x => this.showCancelOnly = x)\r\n    )\r\n    this.subscriptions.push(\r\n      this.dialogService.informationLines$.subscribe(x => this.informationLines = x)\r\n    )\r\n    this.subscriptions.push(\r\n      dialogService.reason$.subscribe(x => this.reason = x)\r\n    )\r\n    this.subscriptions.push(\r\n      dialogService.showingUp$.subscribe(x => this.showingUp = x)\r\n    )\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    var textareaInput = document.querySelectorAll(\"textarea.showingUp\");\r\n    textareaInput.forEach((textarea) =>{\r\n      textarea.textContent = \"\"\r\n    })\r\n  }\r\n\r\n  close(): void {\r\n    this.dialogService.showConfirmDialog$.next(false);\r\n\r\n    // Clear the other states\r\n    this.dialogService.resetService()\r\n  }\r\n\r\n  onConfirm(): void {\r\n    this.dialogService.showConfirmDialog$.next(false);\r\n    this.dialogService.canDeactivate$.next(true);\r\n    this.dialogService.dialogConfirmed$.next({\r\n      ...this.dialogService.dialogConfirmed$.value!,\r\n      confirmed: true\r\n    });\r\n  }\r\n\r\n  onReasonEvent(e: any){\r\n    if(!!e){\r\n      this.dialogService.reason$.next(this.reason)\r\n    }\r\n  }\r\n  override ngOnDestroy(): void {\r\n    this.subscriptions.map(x => x?.unsubscribe());\r\n    this.dialogService.resetService();\r\n    this.dialogService.reason$.next('')\r\n  }\r\n\r\n}\r\n","<div #container class=\"core-confirm-dialog-container roboto-font\">\r\n    <div class=\"modal-container\" *ngIf=\"show\">\r\n        <div class=\"modal-content\">\r\n            <div class=\"modal fade show\" style=\"display: block;\">\r\n                <div class=\"modal-dialog\">\r\n                    <div class=\"modal-content\">\r\n                        <div class=\"modal-header\">\r\n\r\n                            <core-page-header [title]=\"title\" [hideButtonGroup]=\"true\"></core-page-header>\r\n\r\n                            <button type=\"button\" class=\"close\" [ngStyle]=\"{\r\n                                border: 'none',\r\n                                background: 'transparent',\r\n                                fontSize: '28px'\r\n                            }\">\r\n                                <span (click)=\"close()\">×</span>\r\n                            </button>\r\n                        </div>\r\n                        <div class=\"modal-body\">{{ body | translate: lang }}</div>\r\n                        <ul *ngIf=\"!!informationLines?.length\">\r\n                            <li *ngFor=\"let line of informationLines\">\r\n                                {{ line }}\r\n                            </li>\r\n                        </ul>\r\n                        <div class=\"p15 d-flex d-flex-center\">\r\n                            <textarea [(ngModel)]=\"reason\" (ngModelChange)=\"onReasonEvent($event)\" class=\"form-control hidden-input\" [class.shown]=\"showingUp === true\" [rows]=\"'5'\" [ngStyle]=\"{ height: 'unset' }\"></textarea>\r\n                        </div>\r\n                        <div class=\"modal-footer\">\r\n                            <button (click)=\"onConfirm()\" type=\"button\" class=\"btn btn-secondary\" *ngIf=\"!!!showCancelOnly\">{{ okButtonText | translate: lang }}</button>\r\n                            <button (click)=\"close()\" type=\"button\" class=\"btn btn-primary\">{{ cancelButtonText | translate: lang }}</button>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</div>"]}
|
|
83
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-confirm-dialog.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-confirm-dialog/core-confirm-dialog/core-confirm-dialog.component.ts","../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-confirm-dialog/core-confirm-dialog/core-confirm-dialog.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, AfterViewInit, ViewChild, OnDestroy, Input } from '@angular/core';\r\n\r\nimport { DialogService } from '../../../services/dialog.service';\r\nimport { BaseComponent } from '../../base-component/base/base.component';\r\nimport { MultiLanguageService } from '../../../services/multi-language.service';\r\nimport { EnumTranslateKey } from \"alpha-global-constants\";\r\nimport { RoutingService } from '../../../services/routing.service';\r\nimport { CommonModule } from '@angular/common';\r\nimport { TranslatePipe } from '../../../app-pipes/translate.pipe';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { CorePageHeaderComponent } from '../../core-page-header/core-page-header/core-page-header.component';\r\n\r\n@Component({\r\n  selector: 'core-confirm-dialog',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    TranslatePipe,\r\n    FormsModule,\r\n    CorePageHeaderComponent\r\n  ],\r\n  templateUrl: './core-confirm-dialog.component.html',\r\n  styleUrls: ['./core-confirm-dialog.component.scss']\r\n})\r\nexport class CoreConfirmDialogComponent extends BaseComponent implements AfterViewInit, OnDestroy {\r\n  @Input() showingUp!: boolean;\r\n  @ViewChild('container') container!: ElementRef;\r\n\r\n  show!: boolean | undefined;\r\n\r\n  okButtonText: EnumTranslateKey = EnumTranslateKey.UI_CORE_CONFIRM_DIALOG_BUTTON_SURE; // DEFAULT\r\n  cancelButtonText: EnumTranslateKey = EnumTranslateKey.UI_CORE_CONFIRM_DIALOG_BUTTON_CANCEL; // DEFAULT\r\n  title!: EnumTranslateKey;\r\n  body!: EnumTranslateKey;\r\n  showCancelOnly!: boolean;\r\n  informationLines!: string[];\r\n  reason: string = '';\r\n\r\n\r\n  constructor(\r\n    public override mls: MultiLanguageService,\r\n    private dialogService: DialogService,\r\n    private routingService: RoutingService\r\n  ) {\r\n    super(mls);\r\n\r\n    this.subscriptions.push(\r\n      this.dialogService.showConfirmDialog$.subscribe(x => {\r\n        this.show = x\r\n        // Stop navigating property to show opacity 1 while showConfirmDialog$ changes \r\n        this.routingService.navigating$.next(false)\r\n      })\r\n    )\r\n    this.subscriptions.push(\r\n      this.dialogService.title$.subscribe(x => this.title = x)\r\n    )\r\n    this.subscriptions.push(\r\n      this.dialogService.body$.subscribe(x => this.body = x)\r\n    )\r\n    this.subscriptions.push(\r\n      this.dialogService.okButtonText$.subscribe(x => this.okButtonText = x)\r\n    )\r\n    this.subscriptions.push(\r\n      this.dialogService.cancelButtonText$.subscribe(x => this.cancelButtonText = x)\r\n    )\r\n    this.subscriptions.push(\r\n      this.dialogService.showCancelOnly$.subscribe(x => this.showCancelOnly = x)\r\n    )\r\n    this.subscriptions.push(\r\n      this.dialogService.informationLines$.subscribe(x => this.informationLines = x)\r\n    )\r\n    this.subscriptions.push(\r\n      dialogService.reason$.subscribe(x => this.reason = x)\r\n    )\r\n    this.subscriptions.push(\r\n      dialogService.showingUp$.subscribe(x => this.showingUp = x)\r\n    )\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    var textareaInput = document.querySelectorAll(\"textarea.showingUp\");\r\n    textareaInput.forEach((textarea) =>{\r\n      textarea.textContent = \"\"\r\n    })\r\n  }\r\n\r\n  close(): void {\r\n    this.dialogService.showConfirmDialog$.next(false);\r\n\r\n    // Clear the other states\r\n    this.dialogService.resetService()\r\n  }\r\n\r\n  onConfirm(): void {\r\n    this.dialogService.showConfirmDialog$.next(false);\r\n    this.dialogService.canDeactivate$.next(true);\r\n    this.dialogService.dialogConfirmed$.next({\r\n      ...this.dialogService.dialogConfirmed$.value!,\r\n      confirmed: true\r\n    });\r\n  }\r\n\r\n  onReasonEvent(e: any){\r\n    if(!!e){\r\n      this.dialogService.reason$.next(this.reason)\r\n    }\r\n  }\r\n  override ngOnDestroy(): void {\r\n    this.subscriptions.map(x => x?.unsubscribe());\r\n    this.dialogService.resetService();\r\n    this.dialogService.reason$.next('')\r\n  }\r\n\r\n}\r\n","<div #container class=\"core-confirm-dialog-container inter-font\">\r\n    <div class=\"modal-container\" *ngIf=\"show\">\r\n        <div class=\"modal-content\">\r\n            <div class=\"modal fade show\" style=\"display: block;\">\r\n                <div class=\"modal-dialog\">\r\n                    <div class=\"modal-content\">\r\n                        <div class=\"modal-header\">\r\n\r\n                            <core-page-header [title]=\"title\" [hideButtonGroup]=\"true\"></core-page-header>\r\n\r\n                            <button type=\"button\" class=\"close\" [ngStyle]=\"{\r\n                                border: 'none',\r\n                                background: 'transparent',\r\n                                fontSize: '28px'\r\n                            }\">\r\n                                <span (click)=\"close()\">×</span>\r\n                            </button>\r\n                        </div>\r\n                        <div class=\"modal-body\">{{ body | translate: lang }}</div>\r\n                        <ul *ngIf=\"!!informationLines?.length\">\r\n                            <li *ngFor=\"let line of informationLines\">\r\n                                {{ line }}\r\n                            </li>\r\n                        </ul>\r\n                        <div class=\"p15 d-flex d-flex-center\">\r\n                            <textarea [(ngModel)]=\"reason\" (ngModelChange)=\"onReasonEvent($event)\" class=\"form-control hidden-input\" [class.shown]=\"showingUp === true\" [rows]=\"'5'\" [ngStyle]=\"{ height: 'unset' }\"></textarea>\r\n                        </div>\r\n                        <div class=\"modal-footer\">\r\n                            <button (click)=\"onConfirm()\" type=\"button\" class=\"btn btn-secondary\" *ngIf=\"!!!showCancelOnly\">{{ okButtonText | translate: lang }}</button>\r\n                            <button (click)=\"close()\" type=\"button\" class=\"btn btn-primary\">{{ cancelButtonText | translate: lang }}</button>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</div>"]}
|
|
@@ -19,27 +19,21 @@ export class CoreFilterKitComponent extends BaseComponent {
|
|
|
19
19
|
this.renderer = renderer;
|
|
20
20
|
this.statusOptions$ = new BehaviorSubject([]);
|
|
21
21
|
this.onChange = new EventEmitter();
|
|
22
|
+
this.eventListeners = []; // Store cleanup functions for events
|
|
22
23
|
}
|
|
23
24
|
onParamKitValueChange(data) {
|
|
24
25
|
this.onChange.emit(data);
|
|
25
26
|
}
|
|
26
27
|
listenerSetup() {
|
|
27
|
-
let offset = {
|
|
28
|
-
dx: 0,
|
|
29
|
-
dy: 0,
|
|
30
|
-
};
|
|
28
|
+
let offset = { dx: 0, dy: 0, };
|
|
31
29
|
const containerElement = this.container.nativeElement;
|
|
32
30
|
const headerElement = this.header.nativeElement;
|
|
33
31
|
if (!this.relativeMode) {
|
|
34
32
|
containerElement.style.setProperty('z-index', this.domService.getMaxZIndex() + 1);
|
|
35
33
|
}
|
|
36
34
|
const handleMouseDown = (e) => {
|
|
37
|
-
// important!
|
|
38
35
|
e.preventDefault();
|
|
39
|
-
const startPos = {
|
|
40
|
-
x: e.clientX - offset.dx,
|
|
41
|
-
y: e.clientY - offset.dy,
|
|
42
|
-
};
|
|
36
|
+
const startPos = { x: e.clientX - offset.dx, y: e.clientY - offset.dy };
|
|
43
37
|
const handleMouseMove = (e) => {
|
|
44
38
|
// How far the mouse has been moved
|
|
45
39
|
const dx = e.clientX - startPos.x;
|
|
@@ -55,8 +49,13 @@ export class CoreFilterKitComponent extends BaseComponent {
|
|
|
55
49
|
document.removeEventListener('mousemove', handleMouseMove);
|
|
56
50
|
document.removeEventListener('mouseup', handleMouseUp);
|
|
57
51
|
};
|
|
58
|
-
|
|
59
|
-
|
|
52
|
+
if (!this.relativeMode) {
|
|
53
|
+
document.addEventListener('mousemove', handleMouseMove, { passive: true });
|
|
54
|
+
document.addEventListener('mouseup', handleMouseUp, { passive: true });
|
|
55
|
+
// Store the cleanup functions
|
|
56
|
+
this.eventListeners.push(() => document.removeEventListener('mousemove', handleMouseMove));
|
|
57
|
+
this.eventListeners.push(() => document.removeEventListener('mouseup', handleMouseUp));
|
|
58
|
+
}
|
|
60
59
|
};
|
|
61
60
|
var handleTouchStart = (e) => {
|
|
62
61
|
const touch = e.touches[0];
|
|
@@ -83,12 +82,15 @@ export class CoreFilterKitComponent extends BaseComponent {
|
|
|
83
82
|
if (!this.relativeMode) {
|
|
84
83
|
headerElement.addEventListener('mousedown', handleMouseDown);
|
|
85
84
|
headerElement.addEventListener('touchstart', handleTouchStart);
|
|
85
|
+
// Store cleanup functions for the added event listeners
|
|
86
|
+
this.eventListeners.push(() => headerElement.removeEventListener('mousedown', handleMouseDown));
|
|
87
|
+
this.eventListeners.push(() => headerElement.removeEventListener('touchstart', handleTouchStart));
|
|
86
88
|
}
|
|
87
89
|
}
|
|
88
90
|
ngAfterViewInit() {
|
|
89
91
|
setTimeout(() => {
|
|
90
92
|
this.listenerSetup();
|
|
91
|
-
this.filterKitService.open$.pipe(debounceTime(200)).subscribe(x => {
|
|
93
|
+
this.subscriptions.push(this.filterKitService.open$.pipe(debounceTime(200)).subscribe(x => {
|
|
92
94
|
if (!!x) {
|
|
93
95
|
this.listenerFn = this.renderer.listen('window', 'click', (e) => {
|
|
94
96
|
if (this.container && !!!this.container.nativeElement.contains(e.target)) {
|
|
@@ -100,8 +102,8 @@ export class CoreFilterKitComponent extends BaseComponent {
|
|
|
100
102
|
if (this.listenerFn)
|
|
101
103
|
this.listenerFn();
|
|
102
104
|
}
|
|
103
|
-
|
|
104
|
-
|
|
105
|
+
}));
|
|
106
|
+
this.subscriptions.push(this.filterKitService.open$.subscribe(x => this.open = x));
|
|
105
107
|
this.top = this.layoutService.headerHeight + this.layoutService.corePageHeaderHeight;
|
|
106
108
|
});
|
|
107
109
|
}
|
|
@@ -110,9 +112,13 @@ export class CoreFilterKitComponent extends BaseComponent {
|
|
|
110
112
|
this.filterKitService.open$.next(false);
|
|
111
113
|
}
|
|
112
114
|
ngOnDestroy() {
|
|
113
|
-
|
|
115
|
+
// Unsubscribe from all subscriptions
|
|
116
|
+
this.subscriptions?.forEach(x => x?.unsubscribe());
|
|
117
|
+
// Call listenerFn to remove the event listener set by renderer.listen
|
|
114
118
|
if (this.listenerFn)
|
|
115
119
|
this.listenerFn();
|
|
120
|
+
// Clean up the custom event listeners
|
|
121
|
+
this.eventListeners.forEach(cleanup => cleanup());
|
|
116
122
|
}
|
|
117
123
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: CoreFilterKitComponent, deps: [{ token: i1.MultiLanguageService }, { token: i2.DomService }, { token: i3.FilterKitService }, { token: i4.LayoutService }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
118
124
|
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.3", type: CoreFilterKitComponent, isStandalone: true, selector: "core-filter-kit", inputs: { relativeMode: "relativeMode", enableTimeZoneConverterForDateTimePeriodParameters: "enableTimeZoneConverterForDateTimePeriodParameters", datePeriodComparisonFor: "datePeriodComparisonFor", datePeriodComparisonForLabelKey: "datePeriodComparisonForLabelKey", statusInclusionFor: "statusInclusionFor", statusInclusionForLabelKey: "statusInclusionForLabelKey", statusOptionsApi: "statusOptionsApi", showOrgParam: "showOrgParam", showOrgParamDropdown: "showOrgParamDropdown", hideDatePeriodComparison: "hideDatePeriodComparison", hideStatusInclusion: "hideStatusInclusion", hideGeneralSearch: "hideGeneralSearch", statusOptions$: "statusOptions$" }, outputs: { onChange: "onChange" }, viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true }, { propertyName: "header", first: true, predicate: ["header"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div #container class=\"core-filter-kit-container\" [class.d-none]=\"!open\" [ngStyle]=\"{\r\n top: top + 'px'\r\n}\">\r\n <div class=\"p-relative\">\r\n <div #header class=\"header\" [ngStyle]=\"{\r\n cursor: relativeMode ? 'auto' : 'move'\r\n }\">\r\n <span>{{ 'UI.COMPONENT_TITLE_FILTER_KIT' | translate: lang | uppercase }}</span>\r\n @if (!relativeMode) {\r\n <i class=\"feather-x\" (click)=\"onClose($event)\"></i>\r\n }\r\n </div>\r\n <core-common-param-kit \r\n [hiddenMode]=\"true\"\r\n [datePeriodComparisonFor]=\"datePeriodComparisonFor\"\r\n [enableTimeZoneConverterForDateTimePeriodParameters]=\"enableTimeZoneConverterForDateTimePeriodParameters\"\r\n [datePeriodComparisonForLabelKey]=\"datePeriodComparisonForLabelKey\"\r\n [statusInclusionFor]=\"statusInclusionFor\" \r\n [statusInclusionForLabelKey]=\"statusInclusionForLabelKey\"\r\n [statusOptionsApi]=\"statusOptionsApi\" \r\n [statusOptions$]=\"statusOptions$\" \r\n [showOrgParam]=\"showOrgParam\"\r\n [showOrgParamDropdown]=\"showOrgParamDropdown\"\r\n [hideGeneralSearch]=\"hideGeneralSearch\" \r\n [hideDatePeriodComparison]=\"hideDatePeriodComparison\"\r\n [hideStatusInclusion]=\"hideStatusInclusion\"\r\n (onChange)=\"onParamKitValueChange($event)\"\r\n ></core-common-param-kit>\r\n </div>\r\n</div>", styles: [".core-filter-kit-container{background-color:#fff;width:420px;position:fixed;display:block;z-index:9;right:120px;box-shadow:.4rem 0 2rem #0000002e;border-radius:2px}.core-filter-kit-container .header{padding:15px;display:block;height:50px}.core-filter-kit-container .header i{color:gray;font-size:24px;float:right;cursor:pointer;transform:translate(6px,-6px)}\n"], dependencies: [{ kind: "directive", type: NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: CoreCommonParamKitComponent, selector: "core-common-param-kit", inputs: ["hiddenMode", "enableTimeZoneConverterForDateTimePeriodParameters", "datePeriodComparisonFor", "datePeriodComparisonForLabelKey", "statusInclusionFor", "statusInclusionForLabelKey", "statusOptionsApi", "showOrgParam", "showOrgParamDropdown", "hideDatePeriodComparison", "hideStatusInclusion", "hideGeneralSearch", "statusOptions$"], outputs: ["onChange"] }, { kind: "pipe", type: TranslatePipe, name: "translate" }, { kind: "pipe", type: UpperCasePipe, name: "uppercase" }] }); }
|
|
@@ -160,4 +166,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
|
|
|
160
166
|
}], onChange: [{
|
|
161
167
|
type: Output
|
|
162
168
|
}] } });
|
|
163
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-filter-kit.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-filter-kit/core-filter-kit.component.ts","../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-filter-kit/core-filter-kit.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ElementRef, EventEmitter, Input, OnDestroy, Output, Renderer2, ViewChild } from '@angular/core';\r\nimport { CoreCommonParamKitComponent, ICoreCommonParamKitEventEmitterData } from '../core-common-param-kit/core-common-param-kit/core-common-param-kit.component';\r\nimport { api, EnumTranslateKey } from 'alpha-global-constants';\r\nimport { BehaviorSubject, debounceTime } from 'rxjs';\r\nimport { ICoreChecklistOption } from '../core-checklist/core-checklist/core-checklist.component';\r\nimport { DomService } from '../services/dom.service';\r\nimport { TranslatePipe } from '../../app-pipes/translate.pipe';\r\nimport { BaseComponent } from '../base-component/base/base.component';\r\nimport { MultiLanguageService } from '../../services/multi-language.service';\r\nimport { NgStyle, UpperCasePipe } from '@angular/common';\r\nimport { FilterKitService } from '../../services/filter-kit.service';\r\nimport { LayoutService } from '../../services/layout.service';\r\n\r\n@Component({\r\n  selector: 'core-filter-kit',\r\n  standalone: true,\r\n  imports: [\r\n    NgStyle,\r\n    CoreCommonParamKitComponent,\r\n    TranslatePipe,\r\n    UpperCasePipe\r\n  ],\r\n  templateUrl: './core-filter-kit.component.html',\r\n  styleUrl: './core-filter-kit.component.scss'\r\n})\r\nexport class CoreFilterKitComponent extends BaseComponent implements AfterViewInit, OnDestroy {\r\n\r\n  @ViewChild('container') container!: ElementRef<any>;\r\n  @ViewChild('header') header!: ElementRef<any>;\r\n\r\n  @Input() relativeMode!: boolean;\r\n  @Input() enableTimeZoneConverterForDateTimePeriodParameters!: boolean;\r\n  @Input() datePeriodComparisonFor!: string;\r\n  @Input() datePeriodComparisonForLabelKey!: EnumTranslateKey;\r\n  @Input() statusInclusionFor!: string;\r\n  @Input() statusInclusionForLabelKey!: EnumTranslateKey;\r\n  @Input() statusOptionsApi!: api;\r\n  @Input() showOrgParam!: boolean;\r\n  @Input() showOrgParamDropdown!: boolean;\r\n  @Input() hideDatePeriodComparison!: boolean;\r\n  @Input() hideStatusInclusion!: boolean;\r\n  @Input() hideGeneralSearch!: boolean;\r\n  @Input() statusOptions$ = new BehaviorSubject<ICoreChecklistOption[]>([]);\r\n  @Output() onChange = new EventEmitter<ICoreCommonParamKitEventEmitterData>();\r\n\r\n  open!: boolean;\r\n  top!: number;\r\n  right!: number;\r\n\r\n  listenerFn!: () => void;\r\n\r\n  constructor(\r\n    public override mls: MultiLanguageService,\r\n    private domService: DomService,\r\n    private filterKitService: FilterKitService,\r\n    private layoutService: LayoutService,\r\n    private renderer: Renderer2,\r\n  ) {\r\n    super(mls);\r\n  }\r\n\r\n  onParamKitValueChange(data: ICoreCommonParamKitEventEmitterData): void {\r\n    this.onChange.emit(data);\r\n  }\r\n\r\n  listenerSetup(): void {\r\n    let offset = {\r\n      dx: 0,\r\n      dy: 0,\r\n    };\r\n\r\n    const containerElement = this.container.nativeElement;\r\n    const headerElement = this.header.nativeElement;\r\n\r\n    if (!this.relativeMode) {\r\n      containerElement.style.setProperty('z-index', this.domService.getMaxZIndex() + 1)\r\n    }\r\n\r\n    const handleMouseDown = (e: any) => {\r\n\r\n      // important!\r\n      e.preventDefault();\r\n\r\n      const startPos = {\r\n        x: e.clientX - offset.dx,\r\n        y: e.clientY - offset.dy,\r\n      };\r\n\r\n      const handleMouseMove = (e: any) => {\r\n\r\n        // How far the mouse has been moved\r\n        const dx = e.clientX - startPos.x;\r\n        const dy = e.clientY - startPos.y;\r\n\r\n        // Set the position of element\r\n        requestAnimationFrame(() => {\r\n          containerElement.style.transform = `translate(${dx}px, ${dy}px)`;\r\n        });\r\n\r\n        // Reassign the position of mouse\r\n        offset = { dx, dy };\r\n      };\r\n\r\n      var handleMouseUp = () => {\r\n        document.removeEventListener('mousemove', handleMouseMove);\r\n        document.removeEventListener('mouseup', handleMouseUp);\r\n      };\r\n\r\n      document.addEventListener('mousemove', handleMouseMove, { passive: true });\r\n      document.addEventListener('mouseup', handleMouseUp, { passive: true });\r\n    };\r\n\r\n    var handleTouchStart = (e: any) => {\r\n\r\n      const touch = e.touches[0];\r\n\r\n      const startPos = {\r\n        x: touch.clientX - offset.dx,\r\n        y: touch.clientY - offset.dy,\r\n      };\r\n\r\n      var handleTouchMove = (e: any) => {\r\n\r\n        const touch = e.touches[0];\r\n        const dx = touch.clientX - startPos.x;\r\n        const dy = touch.clientY - startPos.y;\r\n        requestAnimationFrame(() => {\r\n          containerElement.style.transform = `translate(${dx}px, ${dy}px)`;\r\n        });\r\n        offset = { dx, dy };\r\n      };\r\n\r\n      const handleTouchEnd = () => {\r\n        document.removeEventListener('touchmove', handleTouchMove);\r\n        document.removeEventListener('touchend', handleTouchEnd);\r\n      };\r\n\r\n      document.addEventListener('touchmove', handleTouchMove, { passive: true });\r\n      document.addEventListener('touchend', handleTouchEnd, { passive: true });\r\n\r\n    };\r\n\r\n    if (!this.relativeMode) {\r\n      headerElement.addEventListener('mousedown', handleMouseDown);\r\n      headerElement.addEventListener('touchstart', handleTouchStart);\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    setTimeout(() => {\r\n      this.listenerSetup();\r\n\r\n      this.filterKitService.open$.pipe(debounceTime(200)).subscribe(x => {\r\n        if (!!x) {\r\n          this.listenerFn = this.renderer.listen('window', 'click', (e: Event) => {\r\n            if (this.container && !!!this.container.nativeElement.contains(e.target)) {\r\n              this.filterKitService.open$.next(false);\r\n            }\r\n          });\r\n        } else {\r\n          if (this.listenerFn) this.listenerFn();\r\n        }\r\n        this.filterKitService.open$.subscribe(x => this.open = x)\r\n      })\r\n\r\n      this.top = this.layoutService.headerHeight + this.layoutService.corePageHeaderHeight;\r\n\r\n    })\r\n  }\r\n\r\n  onClose(e: any) {\r\n    e.preventDefault();\r\n    this.filterKitService.open$.next(false);\r\n  }\r\n\r\n  override ngOnDestroy(): void {\r\n    this.subscriptions?.forEach(x => x?.unsubscribe);\r\n    if (this.listenerFn) this.listenerFn();\r\n  }\r\n\r\n}\r\n","<div #container class=\"core-filter-kit-container\" [class.d-none]=\"!open\" [ngStyle]=\"{\r\n    top: top + 'px'\r\n}\">\r\n    <div class=\"p-relative\">\r\n        <div #header class=\"header\" [ngStyle]=\"{\r\n            cursor: relativeMode ? 'auto' : 'move'\r\n        }\">\r\n            <span>{{ 'UI.COMPONENT_TITLE_FILTER_KIT' | translate: lang | uppercase }}</span>\r\n            @if (!relativeMode) {\r\n                <i class=\"feather-x\" (click)=\"onClose($event)\"></i>\r\n            }\r\n        </div>\r\n        <core-common-param-kit \r\n            [hiddenMode]=\"true\"\r\n            [datePeriodComparisonFor]=\"datePeriodComparisonFor\"\r\n            [enableTimeZoneConverterForDateTimePeriodParameters]=\"enableTimeZoneConverterForDateTimePeriodParameters\"\r\n            [datePeriodComparisonForLabelKey]=\"datePeriodComparisonForLabelKey\"\r\n            [statusInclusionFor]=\"statusInclusionFor\" \r\n            [statusInclusionForLabelKey]=\"statusInclusionForLabelKey\"\r\n            [statusOptionsApi]=\"statusOptionsApi\" \r\n            [statusOptions$]=\"statusOptions$\" \r\n            [showOrgParam]=\"showOrgParam\"\r\n            [showOrgParamDropdown]=\"showOrgParamDropdown\"\r\n            [hideGeneralSearch]=\"hideGeneralSearch\" \r\n            [hideDatePeriodComparison]=\"hideDatePeriodComparison\"\r\n            [hideStatusInclusion]=\"hideStatusInclusion\"\r\n            (onChange)=\"onParamKitValueChange($event)\"\r\n        ></core-common-param-kit>\r\n    </div>\r\n</div>"]}
|
|
169
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-filter-kit.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-filter-kit/core-filter-kit.component.ts","../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-filter-kit/core-filter-kit.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ElementRef, EventEmitter, Input, OnDestroy, Output, Renderer2, ViewChild } from '@angular/core';\r\nimport { CoreCommonParamKitComponent, ICoreCommonParamKitEventEmitterData } from '../core-common-param-kit/core-common-param-kit/core-common-param-kit.component';\r\nimport { api, EnumTranslateKey } from 'alpha-global-constants';\r\nimport { BehaviorSubject, debounceTime } from 'rxjs';\r\nimport { ICoreChecklistOption } from '../core-checklist/core-checklist/core-checklist.component';\r\nimport { DomService } from '../services/dom.service';\r\nimport { TranslatePipe } from '../../app-pipes/translate.pipe';\r\nimport { BaseComponent } from '../base-component/base/base.component';\r\nimport { MultiLanguageService } from '../../services/multi-language.service';\r\nimport { NgStyle, UpperCasePipe } from '@angular/common';\r\nimport { FilterKitService } from '../../services/filter-kit.service';\r\nimport { LayoutService } from '../../services/layout.service';\r\n\r\n@Component({\r\n  selector: 'core-filter-kit',\r\n  standalone: true,\r\n  imports: [\r\n    NgStyle,\r\n    CoreCommonParamKitComponent,\r\n    TranslatePipe,\r\n    UpperCasePipe\r\n  ],\r\n  templateUrl: './core-filter-kit.component.html',\r\n  styleUrl: './core-filter-kit.component.scss'\r\n})\r\nexport class CoreFilterKitComponent extends BaseComponent implements AfterViewInit, OnDestroy {\r\n\r\n  @ViewChild('container') container!: ElementRef<any>;\r\n  @ViewChild('header') header!: ElementRef<any>;\r\n\r\n  @Input() relativeMode!: boolean;\r\n  @Input() enableTimeZoneConverterForDateTimePeriodParameters!: boolean;\r\n  @Input() datePeriodComparisonFor!: string;\r\n  @Input() datePeriodComparisonForLabelKey!: EnumTranslateKey;\r\n  @Input() statusInclusionFor!: string;\r\n  @Input() statusInclusionForLabelKey!: EnumTranslateKey;\r\n  @Input() statusOptionsApi!: api;\r\n  @Input() showOrgParam!: boolean;\r\n  @Input() showOrgParamDropdown!: boolean;\r\n  @Input() hideDatePeriodComparison!: boolean;\r\n  @Input() hideStatusInclusion!: boolean;\r\n  @Input() hideGeneralSearch!: boolean;\r\n  @Input() statusOptions$ = new BehaviorSubject<ICoreChecklistOption[]>([]);\r\n  @Output() onChange = new EventEmitter<ICoreCommonParamKitEventEmitterData>();\r\n\r\n  open!: boolean;\r\n  top!: number;\r\n  right!: number;\r\n\r\n  listenerFn!: () => void;\r\n  eventListeners: (() => void)[] = [];  // Store cleanup functions for events\r\n\r\n  constructor(\r\n    public override mls: MultiLanguageService,\r\n    private domService: DomService,\r\n    private filterKitService: FilterKitService,\r\n    private layoutService: LayoutService,\r\n    private renderer: Renderer2,\r\n  ) {\r\n    super(mls);\r\n  }\r\n\r\n  onParamKitValueChange(data: ICoreCommonParamKitEventEmitterData): void {\r\n    this.onChange.emit(data);\r\n  }\r\n\r\n  listenerSetup(): void {\r\n    let offset = { dx: 0, dy: 0, };\r\n\r\n    const containerElement = this.container.nativeElement;\r\n    const headerElement = this.header.nativeElement;\r\n\r\n    if (!this.relativeMode) {\r\n      containerElement.style.setProperty('z-index', this.domService.getMaxZIndex() + 1)\r\n    }\r\n\r\n    const handleMouseDown = (e: any) => {\r\n\r\n      e.preventDefault();\r\n\r\n      const startPos = { x: e.clientX - offset.dx, y: e.clientY - offset.dy };\r\n\r\n      const handleMouseMove = (e: any) => {\r\n\r\n        // How far the mouse has been moved\r\n        const dx = e.clientX - startPos.x;\r\n        const dy = e.clientY - startPos.y;\r\n\r\n        // Set the position of element\r\n        requestAnimationFrame(() => {\r\n          containerElement.style.transform = `translate(${dx}px, ${dy}px)`;\r\n        });\r\n\r\n        // Reassign the position of mouse\r\n        offset = { dx, dy };\r\n      };\r\n\r\n      var handleMouseUp = () => {\r\n        document.removeEventListener('mousemove', handleMouseMove);\r\n        document.removeEventListener('mouseup', handleMouseUp);\r\n      };\r\n\r\n      if (!this.relativeMode) {\r\n        document.addEventListener('mousemove', handleMouseMove, { passive: true });\r\n        document.addEventListener('mouseup', handleMouseUp, { passive: true });\r\n\r\n        // Store the cleanup functions\r\n        this.eventListeners.push(() => document.removeEventListener('mousemove', handleMouseMove));\r\n        this.eventListeners.push(() => document.removeEventListener('mouseup', handleMouseUp));\r\n      }\r\n    };\r\n\r\n    var handleTouchStart = (e: any) => {\r\n\r\n      const touch = e.touches[0];\r\n\r\n      const startPos = {\r\n        x: touch.clientX - offset.dx,\r\n        y: touch.clientY - offset.dy,\r\n      };\r\n\r\n      var handleTouchMove = (e: any) => {\r\n\r\n        const touch = e.touches[0];\r\n        const dx = touch.clientX - startPos.x;\r\n        const dy = touch.clientY - startPos.y;\r\n        requestAnimationFrame(() => {\r\n          containerElement.style.transform = `translate(${dx}px, ${dy}px)`;\r\n        });\r\n        offset = { dx, dy };\r\n      };\r\n\r\n      const handleTouchEnd = () => {\r\n        document.removeEventListener('touchmove', handleTouchMove);\r\n        document.removeEventListener('touchend', handleTouchEnd);\r\n      };\r\n\r\n      document.addEventListener('touchmove', handleTouchMove, { passive: true });\r\n      document.addEventListener('touchend', handleTouchEnd, { passive: true });\r\n\r\n    };\r\n\r\n    if (!this.relativeMode) {\r\n      headerElement.addEventListener('mousedown', handleMouseDown);\r\n      headerElement.addEventListener('touchstart', handleTouchStart);\r\n\r\n      // Store cleanup functions for the added event listeners\r\n      this.eventListeners.push(() => headerElement.removeEventListener('mousedown', handleMouseDown));\r\n      this.eventListeners.push(() => headerElement.removeEventListener('touchstart', handleTouchStart));\r\n\r\n    }\r\n\r\n\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    setTimeout(() => {\r\n      this.listenerSetup();\r\n\r\n      this.subscriptions.push(\r\n        this.filterKitService.open$.pipe(debounceTime(200)).subscribe(x => {\r\n          if (!!x) {\r\n            this.listenerFn = this.renderer.listen('window', 'click', (e: Event) => {\r\n              if (this.container && !!!this.container.nativeElement.contains(e.target)) {\r\n                this.filterKitService.open$.next(false);\r\n              }\r\n            });\r\n          } else {\r\n            if (this.listenerFn) this.listenerFn();\r\n          }\r\n        })\r\n      )\r\n\r\n      this.subscriptions.push(\r\n        this.filterKitService.open$.subscribe(x => this.open = x)\r\n      )\r\n\r\n      this.top = this.layoutService.headerHeight + this.layoutService.corePageHeaderHeight;\r\n\r\n    })\r\n  }\r\n\r\n  onClose(e: any) {\r\n    e.preventDefault();\r\n    this.filterKitService.open$.next(false);\r\n  }\r\n\r\n  override ngOnDestroy(): void {\r\n\r\n    // Unsubscribe from all subscriptions\r\n    this.subscriptions?.forEach(x => x?.unsubscribe());\r\n\r\n    // Call listenerFn to remove the event listener set by renderer.listen\r\n    if (this.listenerFn) this.listenerFn();\r\n\r\n    // Clean up the custom event listeners\r\n    this.eventListeners.forEach(cleanup => cleanup());\r\n\r\n  }\r\n\r\n}\r\n","<div #container class=\"core-filter-kit-container\" [class.d-none]=\"!open\" [ngStyle]=\"{\r\n    top: top + 'px'\r\n}\">\r\n    <div class=\"p-relative\">\r\n        <div #header class=\"header\" [ngStyle]=\"{\r\n            cursor: relativeMode ? 'auto' : 'move'\r\n        }\">\r\n            <span>{{ 'UI.COMPONENT_TITLE_FILTER_KIT' | translate: lang | uppercase }}</span>\r\n            @if (!relativeMode) {\r\n                <i class=\"feather-x\" (click)=\"onClose($event)\"></i>\r\n            }\r\n        </div>\r\n        <core-common-param-kit \r\n            [hiddenMode]=\"true\"\r\n            [datePeriodComparisonFor]=\"datePeriodComparisonFor\"\r\n            [enableTimeZoneConverterForDateTimePeriodParameters]=\"enableTimeZoneConverterForDateTimePeriodParameters\"\r\n            [datePeriodComparisonForLabelKey]=\"datePeriodComparisonForLabelKey\"\r\n            [statusInclusionFor]=\"statusInclusionFor\" \r\n            [statusInclusionForLabelKey]=\"statusInclusionForLabelKey\"\r\n            [statusOptionsApi]=\"statusOptionsApi\" \r\n            [statusOptions$]=\"statusOptions$\" \r\n            [showOrgParam]=\"showOrgParam\"\r\n            [showOrgParamDropdown]=\"showOrgParamDropdown\"\r\n            [hideGeneralSearch]=\"hideGeneralSearch\" \r\n            [hideDatePeriodComparison]=\"hideDatePeriodComparison\"\r\n            [hideStatusInclusion]=\"hideStatusInclusion\"\r\n            (onChange)=\"onParamKitValueChange($event)\"\r\n        ></core-common-param-kit>\r\n    </div>\r\n</div>"]}
|