zek 14.2.47 → 14.2.48
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/esm2020/lib/components/base.component.mjs +3 -2
- package/esm2020/lib/modules/alert/alert/alert.component.mjs +1 -1
- package/esm2020/lib/modules/bb/bb-modal-base.component.mjs +9 -2
- package/esm2020/lib/modules/bb/bb-modal-toolbar.mjs +9 -2
- package/esm2020/lib/modules/bb/bb.component.mjs +30 -5
- package/esm2020/lib/modules/card/card/card.component.mjs +1 -1
- package/esm2020/lib/modules/edit-toolbar/edit-toolbar.component.mjs +23 -4
- package/esm2020/lib/modules/grid-toolbar/grid-toolbar/grid-toolbar.component.mjs +72 -11
- package/esm2020/lib/modules/list-toolbar/list-toolbar.component.mjs +44 -7
- package/esm2020/lib/modules/modal/modal/modal.component.mjs +72 -8
- package/esm2020/lib/modules/page-title/page-title.component.mjs +11 -1
- package/esm2020/lib/modules/pager/pager/pager.component.mjs +9 -2
- package/esm2020/lib/modules/password/password.component.mjs +9 -2
- package/esm2020/lib/modules/readonly/readonly.directive.mjs +5 -5
- package/esm2020/lib/modules/select/select.mjs +1 -1
- package/esm2020/lib/modules/select2/select2.component.mjs +1 -1
- package/esm2020/lib/modules/select2-multiple/select2-multiple.component.mjs +1 -1
- package/esm2020/lib/modules/wizard/wizard/wizard.component.mjs +1 -1
- package/fesm2015/zek.mjs +272 -38
- package/fesm2015/zek.mjs.map +1 -1
- package/fesm2020/zek.mjs +272 -38
- package/fesm2020/zek.mjs.map +1 -1
- package/lib/components/base.component.d.ts +3 -2
- package/lib/modules/bb/bb-modal-base.component.d.ts +4 -2
- package/lib/modules/bb/bb-modal-toolbar.d.ts +4 -1
- package/lib/modules/bb/bb.component.d.ts +13 -4
- package/lib/modules/edit-toolbar/edit-toolbar.component.d.ts +10 -3
- package/lib/modules/grid-toolbar/grid-toolbar/grid-toolbar.component.d.ts +31 -10
- package/lib/modules/list-toolbar/list-toolbar.component.d.ts +19 -6
- package/lib/modules/modal/modal/modal.component.d.ts +31 -11
- package/lib/modules/page-title/page-title.component.d.ts +4 -1
- package/lib/modules/pager/pager/pager.component.d.ts +4 -1
- package/lib/modules/password/password.component.d.ts +4 -1
- package/lib/modules/readonly/readonly.directive.d.ts +3 -2
- package/package.json +1 -1
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { Component, Output, EventEmitter, Input } from '@angular/core';
|
|
2
2
|
import { PrintType } from '../../models/print.model';
|
|
3
|
+
import { Convert } from '../../utils';
|
|
3
4
|
import * as i0 from "@angular/core";
|
|
4
5
|
import * as i1 from "@angular/router";
|
|
5
6
|
import * as i2 from "@angular/common";
|
|
@@ -8,18 +9,54 @@ export class ListToolbarComponent {
|
|
|
8
9
|
constructor(router) {
|
|
9
10
|
this.router = router;
|
|
10
11
|
this.printType = PrintType;
|
|
11
|
-
this.
|
|
12
|
-
this.
|
|
13
|
-
this.
|
|
14
|
-
this.
|
|
15
|
-
this.
|
|
16
|
-
this.
|
|
12
|
+
this._isFiltered = false;
|
|
13
|
+
this._showCreate = true;
|
|
14
|
+
this._showFilter = true;
|
|
15
|
+
this._showPrint = false;
|
|
16
|
+
this._showSum = false;
|
|
17
|
+
this._showExport = false;
|
|
17
18
|
this.onRefresh = new EventEmitter();
|
|
18
19
|
this.onFilter = new EventEmitter();
|
|
19
20
|
this.onPrint = new EventEmitter();
|
|
20
21
|
this.onSum = new EventEmitter();
|
|
21
22
|
this.onExport = new EventEmitter();
|
|
22
23
|
}
|
|
24
|
+
get isFiltered() {
|
|
25
|
+
return this._isFiltered;
|
|
26
|
+
}
|
|
27
|
+
set isFiltered(v) {
|
|
28
|
+
this._isFiltered = Convert.toBoolean(v);
|
|
29
|
+
}
|
|
30
|
+
get showCreate() {
|
|
31
|
+
return this._showCreate;
|
|
32
|
+
}
|
|
33
|
+
set showCreate(v) {
|
|
34
|
+
this._showCreate = Convert.toBoolean(v);
|
|
35
|
+
}
|
|
36
|
+
get showFilter() {
|
|
37
|
+
return this._showFilter;
|
|
38
|
+
}
|
|
39
|
+
set showFilter(v) {
|
|
40
|
+
this._showFilter = Convert.toBoolean(v);
|
|
41
|
+
}
|
|
42
|
+
get showPrint() {
|
|
43
|
+
return this._showPrint;
|
|
44
|
+
}
|
|
45
|
+
set showPrint(v) {
|
|
46
|
+
this._showPrint = Convert.toBoolean(v);
|
|
47
|
+
}
|
|
48
|
+
get showSum() {
|
|
49
|
+
return this._showSum;
|
|
50
|
+
}
|
|
51
|
+
set showSum(v) {
|
|
52
|
+
this._showSum = Convert.toBoolean(v);
|
|
53
|
+
}
|
|
54
|
+
get showExport() {
|
|
55
|
+
return this._showExport;
|
|
56
|
+
}
|
|
57
|
+
set showExport(v) {
|
|
58
|
+
this._showExport = Convert.toBoolean(v);
|
|
59
|
+
}
|
|
23
60
|
refresh() {
|
|
24
61
|
this.onRefresh.emit();
|
|
25
62
|
}
|
|
@@ -68,4 +105,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
|
|
|
68
105
|
}], onExport: [{
|
|
69
106
|
type: Output
|
|
70
107
|
}] } });
|
|
71
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list-toolbar.component.js","sourceRoot":"","sources":["../../../../../../projects/zek/src/lib/modules/list-toolbar/list-toolbar.component.ts","../../../../../../projects/zek/src/lib/modules/list-toolbar/list-toolbar.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAGvE,OAAO,EAAE,SAAS,EAAE,MAAM,0BAA0B,CAAC;;;;;AAMrD,MAAM,OAAO,oBAAoB;IAC7B,YAA6B,MAAc;QAAd,WAAM,GAAN,MAAM,CAAQ;QAG3C,cAAS,GAAG,SAAS,CAAC;QAEb,eAAU,GAAY,KAAK,CAAC;QAE5B,eAAU,GAAG,IAAI,CAAC;QAElB,eAAU,GAAG,IAAI,CAAC;QAElB,cAAS,GAAG,KAAK,CAAC;QAElB,YAAO,GAAG,KAAK,CAAC;QAEhB,eAAU,GAAG,KAAK,CAAC;QAElB,cAAS,GAAG,IAAI,YAAY,EAAE,CAAC;QAE/B,aAAQ,GAAG,IAAI,YAAY,EAAE,CAAC;QAiBxC,YAAO,GAAG,IAAI,YAAY,EAAa,CAAC;QAMxC,UAAK,GAAG,IAAI,YAAY,EAAE,CAAC;QAO3B,aAAQ,GAAG,IAAI,YAAY,EAAU,CAAC;IAhDtC,CAAC;IAoBD,OAAO;QACH,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;IAC1B,CAAC;IAED,MAAM;QACF,MAAM,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QAC1C,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,GAAG,EAAE,QAAQ,EAAE,EAAE,SAAS,EAAE,GAAG,GAAG,WAAW,EAAE,CAAC,CAAC,CAAC;IAC5E,CAAC;IAGD,MAAM;QACF,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;IACzB,CAAC;IAID,KAAK,CAAC,SAAqB;QACvB,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IACjC,CAAC;IAID,GAAG;QACC,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;IACtB,CAAC;IAKD,WAAW;QACP,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAC1B,CAAC;;iHArDQ,oBAAoB;qGAApB,oBAAoB,6UCTjC,w9FAgCM;2FDvBO,oBAAoB;kBAJhC,SAAS;+BACI,kBAAkB;6FASnB,UAAU;sBAAlB,KAAK;gBAEG,UAAU;sBAAlB,KAAK;gBAEG,UAAU;sBAAlB,KAAK;gBAEG,SAAS;sBAAjB,KAAK;gBAEG,OAAO;sBAAf,KAAK;gBAEG,UAAU;sBAAlB,KAAK;gBAEI,SAAS;sBAAlB,MAAM;gBAEG,QAAQ;sBAAjB,MAAM;gBAiBP,OAAO;sBADN,MAAM;gBAOP,KAAK;sBADJ,MAAM;gBAQP,QAAQ;sBADP,MAAM","sourcesContent":["import { Component, Output, EventEmitter, Input } from '@angular/core';\r\nimport { Router } from '@angular/router';\r\n\r\nimport { PrintType } from '../../models/print.model';\r\n\r\n@Component({\r\n    selector: 'zek-list-toolbar',\r\n    templateUrl: './list-toolbar.component.html'\r\n})\r\nexport class ListToolbarComponent {\r\n    constructor(private readonly router: Router) {\r\n    }\r\n\r\n    printType = PrintType;\r\n\r\n    @Input() isFiltered: boolean = false;\r\n\r\n    @Input() showCreate = true;\r\n\r\n    @Input() showFilter = true;\r\n\r\n    @Input() showPrint = false;\r\n\r\n    @Input() showSum = false;\r\n\r\n    @Input() showExport = false;\r\n\r\n    @Output() onRefresh = new EventEmitter();\r\n\r\n    @Output() onFilter = new EventEmitter();\r\n\r\n    refresh() {\r\n        this.onRefresh.emit();\r\n    }\r\n\r\n    create() {\r\n        const url = this.router.url.split(';')[0];\r\n        this.router.navigate([url, 'create', { returnUrl: url + ';filter=1' }]);\r\n    }\r\n\r\n\r\n    filter() {\r\n        this.onFilter.emit();\r\n    }\r\n\r\n    @Output()\r\n    onPrint = new EventEmitter<PrintType>();\r\n    print(printType?: PrintType) {\r\n        this.onPrint.emit(printType);\r\n    }\r\n\r\n    @Output()\r\n    onSum = new EventEmitter();\r\n    sum() {\r\n        this.onSum.emit();\r\n    }\r\n\r\n\r\n    @Output()\r\n    onExport = new EventEmitter<number>();\r\n    exportExcel() {\r\n        this.onExport.emit(1);\r\n    }\r\n}","<div class=\"btn-toolbar\" role=\"toolbar\" aria-label=\"Toolbar\">\r\n    <div class=\"btn-group me-2\" role=\"group\" aria-label=\"Action group\">\r\n        <button *ngIf=\"showCreate\" type=\"button\" class=\"btn btn-primary\" (click)=\"create()\"><i class=\"fa-solid fa-plus\"></i> {{ 'Action.Create' | translate }}</button>\r\n    </div>\r\n    <div class=\"btn-group me-2\" role=\"group\" aria-label=\"Filter group\">\r\n        <button *ngIf=\"showFilter\" type=\"button\" class=\"btn btn-secondary\" [ngClass]=\"{'btn-outline-success': isFiltered, 'btn-secondary': !isFiltered }\" (click)=\"filter()\" data-bs-toggle0=\"modal\" data-bs-backdrop0=\"static\" data-bs-target0=\"#filter-modal\"><i class=\"fa-solid fa-filter\"></i> {{ 'Action.Filter' | translate }}</button>\r\n        <button type=\"button\" class=\"btn btn-secondary\" title=\"{{ 'Action.Refresh' | translate }}\" (click)=\"refresh()\"><i class=\"fa-solid fa-rotate\"></i></button>\r\n    </div>\r\n    <div *ngIf=\"showPrint\" class=\"btn-group me-2\" role=\"group\" aria-label=\"Print group\">\r\n        <button type=\"button\" class=\"btn btn-secondary\" (click)=\"print(printType.Pdf)\"><i class=\"fa-solid fa-print\"></i> {{ 'Action.Print' | translate }}</button>\r\n        <div class=\"btn-group\" role=\"group\">\r\n            <button type=\"button\" class=\"btn btn-secondary dropdown-toggle dropdown-toggle-split\" data-bs-toggle=\"dropdown\" aria-expanded=\"false\">\r\n                <span class=\"visually-hidden\">Toggle Dropdown</span>\r\n            </button>\r\n            <ul class=\"dropdown-menu\">\r\n                <li><button type=\"button\" class=\"dropdown-item\" (click)=\"print(printType.Show)\"><i class=\"fa-solid fa-print\"></i> {{ 'Action.Print' | translate }}</button></li>\r\n                <li><button type=\"button\" class=\"dropdown-item\" (click)=\"print(printType.Pdf)\"><i class=\"fa-solid fa-file-pdf\"></i> {{ 'Action.Print' | translate }} PDF</button></li>\r\n            </ul>\r\n        </div>\r\n    </div>\r\n    <div *ngIf=\"showSum\" class=\"btn-group me-2\" role=\"group\" aria-label=\"Sum group\">\r\n        <button type=\"button\" class=\"btn btn-secondary\" (click)=\"sum()\"><i class=\"fa-solid fa-sigma\"></i> {{ 'Action.Sum' | translate }}</button>\r\n    </div>\r\n    <div *ngIf=\"showExport\" class=\"btn-group me-2\" role=\"group\" aria-label=\"Export group\">\r\n        <div class=\"btn-group\" role=\"group\">\r\n            <button id=\"btn-group-export\" type=\"button\" class=\"btn btn-secondary dropdown-toggle\" data-bs-toggle=\"dropdown\" aria-expanded=\"false\"><i class=\"fa-solid fa-download\"></i> {{ 'Action.Export' | translate }}</button>\r\n            <ul class=\"dropdown-menu\" aria-labelledby=\"btn-group-export\">\r\n                <li><a class=\"dropdown-item\" href=\"javascript:void(0)\" (click)=\"exportExcel()\"><i class=\"fa-solid fa-file-excel\"></i> Excel</a></li>\r\n            </ul>\r\n        </div>\r\n    </div>\r\n    <ng-content></ng-content>\r\n</div>"]}
|
|
108
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list-toolbar.component.js","sourceRoot":"","sources":["../../../../../../projects/zek/src/lib/modules/list-toolbar/list-toolbar.component.ts","../../../../../../projects/zek/src/lib/modules/list-toolbar/list-toolbar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Output, EventEmitter, Input } from '@angular/core';\r\nimport { Router } from '@angular/router';\r\nimport { BooleanInput } from '../../components';\r\n\r\nimport { PrintType } from '../../models/print.model';\r\nimport { Convert } from '../../utils';\r\n\r\n@Component({\r\n    selector: 'zek-list-toolbar',\r\n    templateUrl: './list-toolbar.component.html'\r\n})\r\nexport class ListToolbarComponent {\r\n    constructor(private readonly router: Router) {\r\n    }\r\n\r\n    printType = PrintType;\r\n    \r\n    private _isFiltered = false;\r\n    @Input()\r\n    get isFiltered() {\r\n        return this._isFiltered;\r\n    }\r\n    set isFiltered(v: BooleanInput) {\r\n        this._isFiltered = Convert.toBoolean(v);\r\n    }\r\n\r\n\r\n    private _showCreate = true;\r\n    @Input()\r\n    get showCreate() {\r\n        return this._showCreate;\r\n    }\r\n    set showCreate(v: BooleanInput) {\r\n        this._showCreate = Convert.toBoolean(v);\r\n    }\r\n\r\n\r\n\r\n\r\n    private _showFilter = true;\r\n    @Input()\r\n    get showFilter() {\r\n        return this._showFilter;\r\n    }\r\n    set showFilter(v: BooleanInput) {\r\n        this._showFilter = Convert.toBoolean(v);\r\n    }\r\n\r\n\r\n    private _showPrint = false;\r\n    @Input()\r\n    get showPrint() {\r\n        return this._showPrint;\r\n    }\r\n    set showPrint(v: BooleanInput) {\r\n        this._showPrint = Convert.toBoolean(v);\r\n    }\r\n\r\n\r\n\r\n\r\n    private _showSum = false;\r\n    @Input()\r\n    get showSum() {\r\n        return this._showSum;\r\n    }\r\n    set showSum(v: BooleanInput) {\r\n        this._showSum = Convert.toBoolean(v);\r\n    }\r\n\r\n\r\n    private _showExport: boolean = false;\r\n    @Input()\r\n    get showExport(): boolean {\r\n        return this._showExport;\r\n    }\r\n    set showExport(v: BooleanInput) {\r\n        this._showExport = Convert.toBoolean(v);\r\n    }\r\n\r\n\r\n    @Output() onRefresh = new EventEmitter();\r\n\r\n    @Output() onFilter = new EventEmitter();\r\n\r\n    refresh() {\r\n        this.onRefresh.emit();\r\n    }\r\n\r\n    create() {\r\n        const url = this.router.url.split(';')[0];\r\n        this.router.navigate([url, 'create', { returnUrl: url + ';filter=1' }]);\r\n    }\r\n\r\n\r\n    filter() {\r\n        this.onFilter.emit();\r\n    }\r\n\r\n    @Output()\r\n    onPrint = new EventEmitter<PrintType>();\r\n    print(printType?: PrintType) {\r\n        this.onPrint.emit(printType);\r\n    }\r\n\r\n    @Output()\r\n    onSum = new EventEmitter();\r\n    sum() {\r\n        this.onSum.emit();\r\n    }\r\n\r\n\r\n    @Output()\r\n    onExport = new EventEmitter<number>();\r\n    exportExcel() {\r\n        this.onExport.emit(1);\r\n    }\r\n}","<div class=\"btn-toolbar\" role=\"toolbar\" aria-label=\"Toolbar\">\r\n    <div class=\"btn-group me-2\" role=\"group\" aria-label=\"Action group\">\r\n        <button *ngIf=\"showCreate\" type=\"button\" class=\"btn btn-primary\" (click)=\"create()\"><i class=\"fa-solid fa-plus\"></i> {{ 'Action.Create' | translate }}</button>\r\n    </div>\r\n    <div class=\"btn-group me-2\" role=\"group\" aria-label=\"Filter group\">\r\n        <button *ngIf=\"showFilter\" type=\"button\" class=\"btn btn-secondary\" [ngClass]=\"{'btn-outline-success': isFiltered, 'btn-secondary': !isFiltered }\" (click)=\"filter()\" data-bs-toggle0=\"modal\" data-bs-backdrop0=\"static\" data-bs-target0=\"#filter-modal\"><i class=\"fa-solid fa-filter\"></i> {{ 'Action.Filter' | translate }}</button>\r\n        <button type=\"button\" class=\"btn btn-secondary\" title=\"{{ 'Action.Refresh' | translate }}\" (click)=\"refresh()\"><i class=\"fa-solid fa-rotate\"></i></button>\r\n    </div>\r\n    <div *ngIf=\"showPrint\" class=\"btn-group me-2\" role=\"group\" aria-label=\"Print group\">\r\n        <button type=\"button\" class=\"btn btn-secondary\" (click)=\"print(printType.Pdf)\"><i class=\"fa-solid fa-print\"></i> {{ 'Action.Print' | translate }}</button>\r\n        <div class=\"btn-group\" role=\"group\">\r\n            <button type=\"button\" class=\"btn btn-secondary dropdown-toggle dropdown-toggle-split\" data-bs-toggle=\"dropdown\" aria-expanded=\"false\">\r\n                <span class=\"visually-hidden\">Toggle Dropdown</span>\r\n            </button>\r\n            <ul class=\"dropdown-menu\">\r\n                <li><button type=\"button\" class=\"dropdown-item\" (click)=\"print(printType.Show)\"><i class=\"fa-solid fa-print\"></i> {{ 'Action.Print' | translate }}</button></li>\r\n                <li><button type=\"button\" class=\"dropdown-item\" (click)=\"print(printType.Pdf)\"><i class=\"fa-solid fa-file-pdf\"></i> {{ 'Action.Print' | translate }} PDF</button></li>\r\n            </ul>\r\n        </div>\r\n    </div>\r\n    <div *ngIf=\"showSum\" class=\"btn-group me-2\" role=\"group\" aria-label=\"Sum group\">\r\n        <button type=\"button\" class=\"btn btn-secondary\" (click)=\"sum()\"><i class=\"fa-solid fa-sigma\"></i> {{ 'Action.Sum' | translate }}</button>\r\n    </div>\r\n    <div *ngIf=\"showExport\" class=\"btn-group me-2\" role=\"group\" aria-label=\"Export group\">\r\n        <div class=\"btn-group\" role=\"group\">\r\n            <button id=\"btn-group-export\" type=\"button\" class=\"btn btn-secondary dropdown-toggle\" data-bs-toggle=\"dropdown\" aria-expanded=\"false\"><i class=\"fa-solid fa-download\"></i> {{ 'Action.Export' | translate }}</button>\r\n            <ul class=\"dropdown-menu\" aria-labelledby=\"btn-group-export\">\r\n                <li><a class=\"dropdown-item\" href=\"javascript:void(0)\" (click)=\"exportExcel()\"><i class=\"fa-solid fa-file-excel\"></i> Excel</a></li>\r\n            </ul>\r\n        </div>\r\n    </div>\r\n    <ng-content></ng-content>\r\n</div>"]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { Component, Output, EventEmitter, Input } from '@angular/core';
|
|
2
2
|
import { CoreComponent } from '../../../components';
|
|
3
|
-
import { BootstrapHelper, ComponentType, handler, RandomHelper } from '../../../utils';
|
|
3
|
+
import { BootstrapHelper, ComponentType, Convert, handler, RandomHelper } from '../../../utils';
|
|
4
4
|
import { ValidEventArgs } from '../../../models/valid-event-args.model';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
6
6
|
import * as i1 from "@ngx-translate/core";
|
|
@@ -10,16 +10,20 @@ export class ModalComponent extends CoreComponent {
|
|
|
10
10
|
constructor(translate) {
|
|
11
11
|
super();
|
|
12
12
|
this.translate = translate;
|
|
13
|
-
this.
|
|
14
|
-
this.
|
|
15
|
-
this.
|
|
16
|
-
this.
|
|
13
|
+
this._showOk = true;
|
|
14
|
+
this._disabledOk = false;
|
|
15
|
+
this._showCancel = true;
|
|
16
|
+
this._autoHide = true;
|
|
17
17
|
this.onShown = new EventEmitter();
|
|
18
18
|
this.onHidden = new EventEmitter();
|
|
19
19
|
this.onOk = new EventEmitter();
|
|
20
20
|
this.componentType = ComponentType.Primary;
|
|
21
|
-
this.
|
|
22
|
-
this.
|
|
21
|
+
this._large = false;
|
|
22
|
+
this._xl = false;
|
|
23
|
+
this._scrollable = false;
|
|
24
|
+
this._fullscreen = false;
|
|
25
|
+
this._showHeader = true;
|
|
26
|
+
this._showFooter = true;
|
|
23
27
|
this.onValidating = new EventEmitter(false);
|
|
24
28
|
this.elementId = RandomHelper.randomHex();
|
|
25
29
|
}
|
|
@@ -53,6 +57,66 @@ export class ModalComponent extends CoreComponent {
|
|
|
53
57
|
}
|
|
54
58
|
}, 1);
|
|
55
59
|
}
|
|
60
|
+
get showOk() {
|
|
61
|
+
return this._showOk;
|
|
62
|
+
}
|
|
63
|
+
set showOk(v) {
|
|
64
|
+
this._showOk = Convert.toBoolean(v);
|
|
65
|
+
}
|
|
66
|
+
get disabledOk() {
|
|
67
|
+
return this._disabledOk;
|
|
68
|
+
}
|
|
69
|
+
set disabledOk(v) {
|
|
70
|
+
this._disabledOk = Convert.toBoolean(v);
|
|
71
|
+
}
|
|
72
|
+
get showCancel() {
|
|
73
|
+
return this._showCancel;
|
|
74
|
+
}
|
|
75
|
+
set showCancel(v) {
|
|
76
|
+
this._showCancel = Convert.toBoolean(v);
|
|
77
|
+
}
|
|
78
|
+
get autoHide() {
|
|
79
|
+
return this._autoHide;
|
|
80
|
+
}
|
|
81
|
+
set autoHide(v) {
|
|
82
|
+
this._autoHide = Convert.toBoolean(v);
|
|
83
|
+
}
|
|
84
|
+
get large() {
|
|
85
|
+
return this._large;
|
|
86
|
+
}
|
|
87
|
+
set large(v) {
|
|
88
|
+
this._large = Convert.toBoolean(v);
|
|
89
|
+
}
|
|
90
|
+
get xl() {
|
|
91
|
+
return this._xl;
|
|
92
|
+
}
|
|
93
|
+
set xl(v) {
|
|
94
|
+
this._xl = Convert.toBoolean(v);
|
|
95
|
+
}
|
|
96
|
+
get scrollable() {
|
|
97
|
+
return this._scrollable;
|
|
98
|
+
}
|
|
99
|
+
set scrollable(v) {
|
|
100
|
+
this._scrollable = Convert.toBoolean(v);
|
|
101
|
+
}
|
|
102
|
+
get fullscreen() {
|
|
103
|
+
return this._fullscreen;
|
|
104
|
+
}
|
|
105
|
+
set fullscreen(v) {
|
|
106
|
+
this._fullscreen = Convert.toBoolean(v);
|
|
107
|
+
}
|
|
108
|
+
get showHeader() {
|
|
109
|
+
return this._showHeader;
|
|
110
|
+
}
|
|
111
|
+
set showHeader(v) {
|
|
112
|
+
this._showHeader = Convert.toBoolean(v);
|
|
113
|
+
}
|
|
114
|
+
get showFooter() {
|
|
115
|
+
return this._showFooter;
|
|
116
|
+
}
|
|
117
|
+
set showFooter(v) {
|
|
118
|
+
this._showFooter = Convert.toBoolean(v);
|
|
119
|
+
}
|
|
56
120
|
// public get modal(): any {
|
|
57
121
|
// if (!this._modal) {
|
|
58
122
|
// this.getModal();
|
|
@@ -240,4 +304,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
|
|
|
240
304
|
type: Component,
|
|
241
305
|
args: [{ selector: 'zek-restore-modal', template: "<div (keydown.enter)=\"keyDown($event)\" class=\"modal fade\" data-bs-backdrop=\"static\" id=\"modal-{{elementId}}\" tabindex=\"-1\" attr.aria-labelledby=\"modal-lable-{{elementId}}\" aria-hidden=\"true\">\r\n <div class=\"modal-dialog\" [class.modal-lg]=\"large\" [class.modal-xl]=\"xl\" [class.modal-dialog-scrollable]=\"scrollable\" [class.modal-fullscreen]=\"fullscreen\">\r\n <div class=\"modal-content\">\r\n <div class=\"modal-header\" *ngIf=\"showHeader\">\r\n <ng-content select=\"header\"></ng-content>\r\n <h5 class=\"modal-title\" id=\"modal-lable-{{elementId}}\">{{title}}</h5>\r\n <button type=\"button\" class=\"btn-close\" data-bs-dismiss=\"modal\" aria-label=\"Close\"></button>\r\n </div>\r\n <div class=\"modal-body\">\r\n {{text}}\r\n <ng-content></ng-content>\r\n </div>\r\n <div class=\"modal-footer\" *ngIf=\"showFooter\">\r\n <ng-content select=\"footer\"></ng-content>\r\n <button [class.visually-hidden]=\"!showOk\" [disabled]=\"disabledOk\" type=\"button\" class=\"btn {{cssButton()}}\" id=\"modal-ok-button-{{elementId}}\" (click)=\"ok()\"><i *ngIf=\"icon\" class=\"{{ icon }}\"></i> {{ okButtonText }}</button>\r\n <button [class.visually-hidden]=\"!showCancel\" type=\"button\" class=\"btn btn-secondary\" id=\"modal-cancel-button-{{elementId}}\" data-bs-dismiss=\"modal\"><i class=\"fa-solid fa-ban\"></i> {{ 'Action.Cancel' | translate }}</button>\r\n </div>\r\n </div>\r\n </div>\r\n</div>" }]
|
|
242
306
|
}], ctorParameters: function () { return [{ type: i1.TranslateService }]; } });
|
|
243
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.component.js","sourceRoot":"","sources":["../../../../../../../projects/zek/src/lib/modules/modal/modal/modal.component.ts","../../../../../../../projects/zek/src/lib/modules/modal/modal/modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Output, EventEmitter, Input } from '@angular/core';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { CoreComponent } from '../../../components';\r\nimport { BootstrapHelper, ComponentType, handler, RandomHelper } from '../../../utils';\r\nimport { ValidEventArgs } from '../../../models/valid-event-args.model';\r\n\r\ndeclare let bootstrap: any;\r\nlet nextUniqueId = 0;\r\n\r\n\r\n\r\n@Component({\r\n    selector: 'zek-modal',\r\n    templateUrl: './modal.component.html'\r\n})\r\nexport class ModalComponent extends CoreComponent {\r\n    constructor(private readonly translate: TranslateService) {\r\n        super();\r\n        this.elementId = RandomHelper.randomHex();\r\n    }\r\n    override async destroy() {\r\n        await super.destroy();\r\n        this._modal?.dispose();\r\n        this._modal = null;\r\n\r\n        if (this.hiddenHandler) {\r\n            handler.removeListener(this.hiddenHandler);\r\n        }\r\n        if (this.shownHandler) {\r\n            handler.removeListener(this.shownHandler);\r\n        }\r\n    }\r\n    override init() {\r\n        super.init()\r\n        if (!this.okButtonText) {\r\n            this.translate.get('Action.Ok').subscribe(text => {\r\n                this.okButtonText = text;\r\n            });\r\n        }\r\n\r\n        setTimeout(() => {\r\n            let modalEl = this.getModalElement();\r\n            if (modalEl) {\r\n                this.shownHandler = handler.addListener(modalEl, 'shown.bs.modal', () => {\r\n                    this.onShown.emit();\r\n                });\r\n\r\n                this.hiddenHandler = handler.addListener(modalEl, 'hidden.bs.modal', () => {\r\n                    this.onHidden.emit();\r\n                });\r\n            }\r\n        }, 1);\r\n    }\r\n\r\n\r\n\r\n    shownHandler?: number | null;\r\n    hiddenHandler?: number | null;\r\n\r\n    @Input() model: any;\r\n    readonly elementId: string;\r\n\r\n    @Input() showOk = true;\r\n\r\n    @Input() disabledOk = false;\r\n\r\n    @Input() showCancel = true;\r\n\r\n    @Input() autoHide = true;\r\n\r\n    @Input() title?: string | null;\r\n\r\n    @Input() text?: string | null;\r\n\r\n    @Input() icon?: string | null;\r\n\r\n    @Input() okButtonText?: string | null;\r\n\r\n    @Output() onShown = new EventEmitter<any>();\r\n\r\n    @Output() onHidden = new EventEmitter<any>();\r\n\r\n    @Output() onOk = new EventEmitter<any>();\r\n\r\n    @Input() componentType = ComponentType.Primary;\r\n\r\n    @Input() large?: boolean;\r\n\r\n    @Input() xl?: boolean;\r\n\r\n    @Input() scrollable?: boolean;\r\n    \r\n    @Input() fullscreen?: boolean;\r\n\r\n    @Input() showHeader = true;\r\n\r\n    @Input() showFooter = true;\r\n\r\n    @Output() onValidating = new EventEmitter<ValidEventArgs>(false);\r\n    // @Input() xxl: boolean;\r\n\r\n    private _modal: any;\r\n    // public get modal(): any {\r\n    //     if (!this._modal) {\r\n    //         this.getModal();\r\n    //     }\r\n    //     return this._modal;\r\n    // }\r\n    // public set modal(v: any) {\r\n    //     this._modal = v;\r\n    // }\r\n\r\n    protected getModalElement() {\r\n        return document.getElementById('modal-' + this.elementId);\r\n    }\r\n    protected getModal() {\r\n        let modalEl = this.getModalElement();\r\n        return new bootstrap.Modal(modalEl, { backdrop: 'static' });\r\n    }\r\n\r\n\r\n\r\n\r\n    cssButton(): string {\r\n        return BootstrapHelper.cssButton(this.componentType);\r\n    }\r\n\r\n    // private isShown = false;\r\n    show(model?: any) {\r\n        if (!model) model = {};\r\n        this.model = model;\r\n\r\n        // this.modal?.show();\r\n\r\n\r\n        if (!this._modal) {\r\n            this._modal = this.getModal();\r\n        }\r\n        if (this._modal) {\r\n            this._modal.show();\r\n            // this.isShown = true;\r\n        }\r\n    }\r\n\r\n    hide() {\r\n        // this.modal?.hide();\r\n\r\n        // if (this.isShown) {\r\n        //     if (this._modal) {\r\n        //         this._modal.hide();\r\n        //         this.isShown = false;\r\n        //     }\r\n        // } else {\r\n\r\n        // }\r\n\r\n        if (this._modal) {\r\n            this._modal.hide();\r\n        }\r\n        else {\r\n            let btn = document.getElementById('modal-cancel-button-' + this.elementId);\r\n            if (btn) {\r\n                btn.click();\r\n            }\r\n        }\r\n    }\r\n\r\n    ok() {\r\n        let event = new ValidEventArgs();\r\n        this.onValidating.emit(event);\r\n        if (!event.valid) return;\r\n\r\n        if (this.autoHide)\r\n            this.hide();\r\n\r\n        this.onOk.emit(this.model);\r\n    }\r\n\r\n    keyDown(e: Event) {\r\n        e.preventDefault();\r\n        this.ok();\r\n    }\r\n}\r\n\r\n@Component({\r\n    selector: 'zek-delete-modal',\r\n    templateUrl: './modal.component.html'\r\n})\r\nexport class DeleteModalComponent extends ModalComponent {\r\n    constructor(translate: TranslateService) {\r\n        super(translate);\r\n        this.icon = 'fas fa-fas fa-trash';\r\n        translate.get('Action.Delete').subscribe((res: string) => this.title = res);\r\n        translate.get('Alert.DeleteQuestion').subscribe((res: string) => this.text = res);\r\n        this.componentType = ComponentType.Delete;\r\n    }\r\n}\r\n\r\n@Component({\r\n    selector: 'zek-approve-modal',\r\n    templateUrl: './modal.component.html'\r\n})\r\nexport class ApproveModalComponent extends ModalComponent {\r\n    constructor(translate: TranslateService) {\r\n        super(translate);\r\n        this.icon = 'fas fa-thumbs-up';\r\n        translate.get('Action.Approve').subscribe((res: string) => this.title = res);\r\n        translate.get('Alert.ApproveQuestion').subscribe((res: string) => this.text = res);\r\n        this.componentType = ComponentType.Success;\r\n    }\r\n}\r\n@Component({\r\n    selector: 'zek-submit-modal',\r\n    templateUrl: './modal.component.html'\r\n})\r\nexport class SubmitModalComponent extends ModalComponent {\r\n    constructor(translate: TranslateService) {\r\n        super(translate);\r\n        this.icon = 'fas fa-thumbs-up';\r\n        translate.get('Action.Submit').subscribe((res: string) => this.title = res);\r\n        translate.get('Alert.SubmitQuestion').subscribe((res: string) => this.text = res);\r\n        this.componentType = ComponentType.Success;\r\n    }\r\n}\r\n@Component({\r\n    selector: 'zek-disapprove-modal',\r\n    templateUrl: './modal.component.html'\r\n})\r\nexport class DisapproveModalComponent extends ModalComponent {\r\n    constructor(translate: TranslateService) {\r\n        super(translate);\r\n        this.icon = 'fas fa-thumbs-down';\r\n        translate.get('Action.Disapprove').subscribe((res: string) => this.title = res);\r\n        translate.get('Alert.DisapproveQuestion').subscribe((res: string) => this.text = res);\r\n        this.componentType = ComponentType.Delete;\r\n    }\r\n}\r\n\r\n@Component({\r\n    selector: 'zek-restore-modal',\r\n    templateUrl: './modal.component.html'\r\n})\r\nexport class RestoreModalComponent extends ModalComponent {\r\n    constructor(translate: TranslateService) {\r\n        super(translate);\r\n        this.icon = 'fas fa-redo';\r\n        translate.get('Action.Restore').subscribe((res: string) => this.title = res);\r\n        translate.get('Action.RestoreQuestion').subscribe((res: string) => this.text = res);\r\n        this.componentType = ComponentType.Success;\r\n    }\r\n}","<div (keydown.enter)=\"keyDown($event)\" class=\"modal fade\" data-bs-backdrop=\"static\" id=\"modal-{{elementId}}\" tabindex=\"-1\" attr.aria-labelledby=\"modal-lable-{{elementId}}\" aria-hidden=\"true\">\r\n    <div class=\"modal-dialog\" [class.modal-lg]=\"large\" [class.modal-xl]=\"xl\" [class.modal-dialog-scrollable]=\"scrollable\" [class.modal-fullscreen]=\"fullscreen\">\r\n        <div class=\"modal-content\">\r\n            <div class=\"modal-header\" *ngIf=\"showHeader\">\r\n                <ng-content select=\"header\"></ng-content>\r\n                <h5 class=\"modal-title\" id=\"modal-lable-{{elementId}}\">{{title}}</h5>\r\n                <button type=\"button\" class=\"btn-close\" data-bs-dismiss=\"modal\" aria-label=\"Close\"></button>\r\n            </div>\r\n            <div class=\"modal-body\">\r\n                {{text}}\r\n                <ng-content></ng-content>\r\n            </div>\r\n            <div class=\"modal-footer\" *ngIf=\"showFooter\">\r\n                <ng-content select=\"footer\"></ng-content>\r\n                <button [class.visually-hidden]=\"!showOk\" [disabled]=\"disabledOk\" type=\"button\" class=\"btn {{cssButton()}}\" id=\"modal-ok-button-{{elementId}}\" (click)=\"ok()\"><i *ngIf=\"icon\" class=\"{{ icon }}\"></i> {{ okButtonText }}</button>\r\n                <button [class.visually-hidden]=\"!showCancel\" type=\"button\" class=\"btn btn-secondary\" id=\"modal-cancel-button-{{elementId}}\" data-bs-dismiss=\"modal\"><i class=\"fa-solid fa-ban\"></i> {{ 'Action.Cancel' | translate }}</button>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</div>"]}
|
|
307
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"modal.component.js","sourceRoot":"","sources":["../../../../../../../projects/zek/src/lib/modules/modal/modal/modal.component.ts","../../../../../../../projects/zek/src/lib/modules/modal/modal/modal.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Output, EventEmitter, Input } from '@angular/core';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { BooleanInput, CoreComponent } from '../../../components';\r\nimport { BootstrapHelper, ComponentType, Convert, handler, RandomHelper } from '../../../utils';\r\nimport { ValidEventArgs } from '../../../models/valid-event-args.model';\r\n\r\ndeclare let bootstrap: any;\r\nlet nextUniqueId = 0;\r\n\r\n\r\n\r\n@Component({\r\n    selector: 'zek-modal',\r\n    templateUrl: './modal.component.html'\r\n})\r\nexport class ModalComponent extends CoreComponent {\r\n    constructor(private readonly translate: TranslateService) {\r\n        super();\r\n        this.elementId = RandomHelper.randomHex();\r\n    }\r\n    override async destroy() {\r\n        await super.destroy();\r\n        this._modal?.dispose();\r\n        this._modal = null;\r\n\r\n        if (this.hiddenHandler) {\r\n            handler.removeListener(this.hiddenHandler);\r\n        }\r\n        if (this.shownHandler) {\r\n            handler.removeListener(this.shownHandler);\r\n        }\r\n    }\r\n    override init() {\r\n        super.init()\r\n        if (!this.okButtonText) {\r\n            this.translate.get('Action.Ok').subscribe(text => {\r\n                this.okButtonText = text;\r\n            });\r\n        }\r\n\r\n        setTimeout(() => {\r\n            let modalEl = this.getModalElement();\r\n            if (modalEl) {\r\n                this.shownHandler = handler.addListener(modalEl, 'shown.bs.modal', () => {\r\n                    this.onShown.emit();\r\n                });\r\n\r\n                this.hiddenHandler = handler.addListener(modalEl, 'hidden.bs.modal', () => {\r\n                    this.onHidden.emit();\r\n                });\r\n            }\r\n        }, 1);\r\n    }\r\n\r\n\r\n\r\n    shownHandler?: number | null;\r\n    hiddenHandler?: number | null;\r\n\r\n    @Input() model: any;\r\n    readonly elementId: string;\r\n\r\n\r\n    private _showOk: boolean = true;\r\n    @Input()\r\n    get showOk(): boolean {\r\n        return this._showOk;\r\n    }\r\n    set showOk(v: BooleanInput) {\r\n        this._showOk = Convert.toBoolean(v);\r\n    }\r\n\r\n    private _disabledOk: boolean = false;\r\n    @Input()\r\n    get disabledOk(): boolean {\r\n        return this._disabledOk;\r\n    }\r\n    set disabledOk(v: BooleanInput) {\r\n        this._disabledOk = Convert.toBoolean(v);\r\n    }\r\n\r\n    private _showCancel: boolean = true;\r\n    @Input()\r\n    get showCancel(): boolean {\r\n        return this._showCancel;\r\n    }\r\n    set showCancel(v: BooleanInput) {\r\n        this._showCancel = Convert.toBoolean(v);\r\n    }\r\n\r\n\r\n    private _autoHide: boolean = true;\r\n    @Input()\r\n    get autoHide(): boolean {\r\n        return this._autoHide;\r\n    }\r\n    set autoHide(v: BooleanInput) {\r\n        this._autoHide = Convert.toBoolean(v);\r\n    }\r\n\r\n\r\n    @Input() title?: string | null;\r\n\r\n    @Input() text?: string | null;\r\n\r\n    @Input() icon?: string | null;\r\n\r\n    @Input() okButtonText?: string | null;\r\n\r\n    @Output() onShown = new EventEmitter<any>();\r\n\r\n    @Output() onHidden = new EventEmitter<any>();\r\n\r\n    @Output() onOk = new EventEmitter<any>();\r\n\r\n    @Input() componentType = ComponentType.Primary;\r\n\r\n\r\n\r\n\r\n    private _large: boolean = false;\r\n    @Input()\r\n    get large(): boolean {\r\n        return this._large;\r\n    }\r\n    set large(v: BooleanInput) {\r\n        this._large = Convert.toBoolean(v);\r\n    }\r\n\r\n    private _xl: boolean = false;\r\n    @Input()\r\n    get xl(): boolean {\r\n        return this._xl;\r\n    }\r\n    set xl(v: BooleanInput) {\r\n        this._xl = Convert.toBoolean(v);\r\n    }\r\n\r\n\r\n    private _scrollable: boolean = false;\r\n    @Input()\r\n    get scrollable(): boolean {\r\n        return this._scrollable;\r\n    }\r\n    set scrollable(v: BooleanInput) {\r\n        this._scrollable = Convert.toBoolean(v);\r\n    }\r\n\r\n    private _fullscreen: boolean = false;\r\n    @Input()\r\n    get fullscreen(): boolean {\r\n        return this._fullscreen;\r\n    }\r\n    set fullscreen(v: BooleanInput) {\r\n        this._fullscreen = Convert.toBoolean(v);\r\n    }\r\n\r\n    private _showHeader: boolean = true;\r\n    @Input()\r\n    get showHeader(): boolean {\r\n        return this._showHeader;\r\n    }\r\n    set showHeader(v: BooleanInput) {\r\n        this._showHeader = Convert.toBoolean(v);\r\n    }\r\n\r\n    private _showFooter: boolean = true;\r\n    @Input()\r\n    get showFooter(): boolean {\r\n        return this._showFooter;\r\n    }\r\n    set showFooter(v: BooleanInput) {\r\n        this._showFooter = Convert.toBoolean(v);\r\n    }\r\n\r\n\r\n\r\n\r\n    @Output() onValidating = new EventEmitter<ValidEventArgs>(false);\r\n    // @Input() xxl: boolean;\r\n\r\n    private _modal: any;\r\n    // public get modal(): any {\r\n    //     if (!this._modal) {\r\n    //         this.getModal();\r\n    //     }\r\n    //     return this._modal;\r\n    // }\r\n    // public set modal(v: any) {\r\n    //     this._modal = v;\r\n    // }\r\n\r\n    protected getModalElement() {\r\n        return document.getElementById('modal-' + this.elementId);\r\n    }\r\n    protected getModal() {\r\n        let modalEl = this.getModalElement();\r\n        return new bootstrap.Modal(modalEl, { backdrop: 'static' });\r\n    }\r\n\r\n\r\n\r\n\r\n    cssButton(): string {\r\n        return BootstrapHelper.cssButton(this.componentType);\r\n    }\r\n\r\n    // private isShown = false;\r\n    show(model?: any) {\r\n        if (!model) model = {};\r\n        this.model = model;\r\n\r\n        // this.modal?.show();\r\n\r\n\r\n        if (!this._modal) {\r\n            this._modal = this.getModal();\r\n        }\r\n        if (this._modal) {\r\n            this._modal.show();\r\n            // this.isShown = true;\r\n        }\r\n    }\r\n\r\n    hide() {\r\n        // this.modal?.hide();\r\n\r\n        // if (this.isShown) {\r\n        //     if (this._modal) {\r\n        //         this._modal.hide();\r\n        //         this.isShown = false;\r\n        //     }\r\n        // } else {\r\n\r\n        // }\r\n\r\n        if (this._modal) {\r\n            this._modal.hide();\r\n        }\r\n        else {\r\n            let btn = document.getElementById('modal-cancel-button-' + this.elementId);\r\n            if (btn) {\r\n                btn.click();\r\n            }\r\n        }\r\n    }\r\n\r\n    ok() {\r\n        let event = new ValidEventArgs();\r\n        this.onValidating.emit(event);\r\n        if (!event.valid) return;\r\n\r\n        if (this.autoHide)\r\n            this.hide();\r\n\r\n        this.onOk.emit(this.model);\r\n    }\r\n\r\n    keyDown(e: Event) {\r\n        e.preventDefault();\r\n        this.ok();\r\n    }\r\n}\r\n\r\n@Component({\r\n    selector: 'zek-delete-modal',\r\n    templateUrl: './modal.component.html'\r\n})\r\nexport class DeleteModalComponent extends ModalComponent {\r\n    constructor(translate: TranslateService) {\r\n        super(translate);\r\n        this.icon = 'fas fa-fas fa-trash';\r\n        translate.get('Action.Delete').subscribe((res: string) => this.title = res);\r\n        translate.get('Alert.DeleteQuestion').subscribe((res: string) => this.text = res);\r\n        this.componentType = ComponentType.Delete;\r\n    }\r\n}\r\n\r\n@Component({\r\n    selector: 'zek-approve-modal',\r\n    templateUrl: './modal.component.html'\r\n})\r\nexport class ApproveModalComponent extends ModalComponent {\r\n    constructor(translate: TranslateService) {\r\n        super(translate);\r\n        this.icon = 'fas fa-thumbs-up';\r\n        translate.get('Action.Approve').subscribe((res: string) => this.title = res);\r\n        translate.get('Alert.ApproveQuestion').subscribe((res: string) => this.text = res);\r\n        this.componentType = ComponentType.Success;\r\n    }\r\n}\r\n@Component({\r\n    selector: 'zek-submit-modal',\r\n    templateUrl: './modal.component.html'\r\n})\r\nexport class SubmitModalComponent extends ModalComponent {\r\n    constructor(translate: TranslateService) {\r\n        super(translate);\r\n        this.icon = 'fas fa-thumbs-up';\r\n        translate.get('Action.Submit').subscribe((res: string) => this.title = res);\r\n        translate.get('Alert.SubmitQuestion').subscribe((res: string) => this.text = res);\r\n        this.componentType = ComponentType.Success;\r\n    }\r\n}\r\n@Component({\r\n    selector: 'zek-disapprove-modal',\r\n    templateUrl: './modal.component.html'\r\n})\r\nexport class DisapproveModalComponent extends ModalComponent {\r\n    constructor(translate: TranslateService) {\r\n        super(translate);\r\n        this.icon = 'fas fa-thumbs-down';\r\n        translate.get('Action.Disapprove').subscribe((res: string) => this.title = res);\r\n        translate.get('Alert.DisapproveQuestion').subscribe((res: string) => this.text = res);\r\n        this.componentType = ComponentType.Delete;\r\n    }\r\n}\r\n\r\n@Component({\r\n    selector: 'zek-restore-modal',\r\n    templateUrl: './modal.component.html'\r\n})\r\nexport class RestoreModalComponent extends ModalComponent {\r\n    constructor(translate: TranslateService) {\r\n        super(translate);\r\n        this.icon = 'fas fa-redo';\r\n        translate.get('Action.Restore').subscribe((res: string) => this.title = res);\r\n        translate.get('Action.RestoreQuestion').subscribe((res: string) => this.text = res);\r\n        this.componentType = ComponentType.Success;\r\n    }\r\n}","<div (keydown.enter)=\"keyDown($event)\" class=\"modal fade\" data-bs-backdrop=\"static\" id=\"modal-{{elementId}}\" tabindex=\"-1\" attr.aria-labelledby=\"modal-lable-{{elementId}}\" aria-hidden=\"true\">\r\n    <div class=\"modal-dialog\" [class.modal-lg]=\"large\" [class.modal-xl]=\"xl\" [class.modal-dialog-scrollable]=\"scrollable\" [class.modal-fullscreen]=\"fullscreen\">\r\n        <div class=\"modal-content\">\r\n            <div class=\"modal-header\" *ngIf=\"showHeader\">\r\n                <ng-content select=\"header\"></ng-content>\r\n                <h5 class=\"modal-title\" id=\"modal-lable-{{elementId}}\">{{title}}</h5>\r\n                <button type=\"button\" class=\"btn-close\" data-bs-dismiss=\"modal\" aria-label=\"Close\"></button>\r\n            </div>\r\n            <div class=\"modal-body\">\r\n                {{text}}\r\n                <ng-content></ng-content>\r\n            </div>\r\n            <div class=\"modal-footer\" *ngIf=\"showFooter\">\r\n                <ng-content select=\"footer\"></ng-content>\r\n                <button [class.visually-hidden]=\"!showOk\" [disabled]=\"disabledOk\" type=\"button\" class=\"btn {{cssButton()}}\" id=\"modal-ok-button-{{elementId}}\" (click)=\"ok()\"><i *ngIf=\"icon\" class=\"{{ icon }}\"></i> {{ okButtonText }}</button>\r\n                <button [class.visually-hidden]=\"!showCancel\" type=\"button\" class=\"btn btn-secondary\" id=\"modal-cancel-button-{{elementId}}\" data-bs-dismiss=\"modal\"><i class=\"fa-solid fa-ban\"></i> {{ 'Action.Cancel' | translate }}</button>\r\n            </div>\r\n        </div>\r\n    </div>\r\n</div>"]}
|
|
@@ -1,8 +1,18 @@
|
|
|
1
1
|
import { Component, Input } from '@angular/core';
|
|
2
|
+
import { Convert } from '../../utils';
|
|
2
3
|
import * as i0 from "@angular/core";
|
|
3
4
|
import * as i1 from "@angular/common";
|
|
4
5
|
import * as i2 from "@ngx-translate/core";
|
|
5
6
|
export class PageTitleComponent {
|
|
7
|
+
constructor() {
|
|
8
|
+
this._isEditPage = true;
|
|
9
|
+
}
|
|
10
|
+
get isEditPage() {
|
|
11
|
+
return this._isEditPage;
|
|
12
|
+
}
|
|
13
|
+
set isEditPage(v) {
|
|
14
|
+
this._isEditPage = Convert.toBoolean(v);
|
|
15
|
+
}
|
|
6
16
|
}
|
|
7
17
|
PageTitleComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: PageTitleComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
8
18
|
PageTitleComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: PageTitleComponent, selector: "zek-page-title", inputs: { icon: "icon", title: "title", isEditPage: "isEditPage", modelId: "modelId" }, ngImport: i0, template: "<h1 class=\"h2 pt-3 pb-2 mb-3 border-bottom\">\r\n <i *ngIf=\"icon\" class=\"{{icon}}\"></i><ng-container *ngIf=\"icon\"> </ng-container>{{ title }} <ng-container *ngIf=\"isEditPage\">\r\n <small class=\"text-muted\" *ngIf=\"modelId && modelId > 0 else elseBlock\">[<ng-container>{{ 'Action.Edit' | translate }}</ng-container>]</small>\r\n <ng-template #elseBlock>\r\n <small class=\"text-muted\">[<ng-container>{{ 'Action.Create' | translate }}</ng-container>]</small>\r\n </ng-template>\r\n </ng-container>\r\n</h1>", dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "pipe", type: i2.TranslatePipe, name: "translate" }] });
|
|
@@ -18,4 +28,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
|
|
|
18
28
|
}], modelId: [{
|
|
19
29
|
type: Input
|
|
20
30
|
}] } });
|
|
21
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
31
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFnZS10aXRsZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy96ZWsvc3JjL2xpYi9tb2R1bGVzL3BhZ2UtdGl0bGUvcGFnZS10aXRsZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy96ZWsvc3JjL2xpYi9tb2R1bGVzL3BhZ2UtdGl0bGUvcGFnZS10aXRsZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUVqRCxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sYUFBYSxDQUFDOzs7O0FBTXRDLE1BQU0sT0FBTyxrQkFBa0I7SUFKL0I7UUFVWSxnQkFBVyxHQUFZLElBQUksQ0FBQztLQVd2QztJQVZHLElBQ0ksVUFBVTtRQUNWLE9BQU8sSUFBSSxDQUFDLFdBQVcsQ0FBQztJQUM1QixDQUFDO0lBQ0QsSUFBSSxVQUFVLENBQUMsQ0FBZTtRQUMxQixJQUFJLENBQUMsV0FBVyxHQUFHLE9BQU8sQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDNUMsQ0FBQzs7K0dBYlEsa0JBQWtCO21HQUFsQixrQkFBa0IsOElDUi9CLHVqQkFPSzsyRkRDUSxrQkFBa0I7a0JBSjlCLFNBQVM7K0JBQ0ksZ0JBQWdCOzhCQUlqQixJQUFJO3NCQUFaLEtBQUs7Z0JBRUcsS0FBSztzQkFBYixLQUFLO2dCQUtGLFVBQVU7c0JBRGIsS0FBSztnQkFRRyxPQUFPO3NCQUFmLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEJvb2xlYW5JbnB1dCB9IGZyb20gJy4uLy4uL2NvbXBvbmVudHMnO1xyXG5pbXBvcnQgeyBDb252ZXJ0IH0gZnJvbSAnLi4vLi4vdXRpbHMnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogJ3play1wYWdlLXRpdGxlJyxcclxuICAgIHRlbXBsYXRlVXJsOiAnLi9wYWdlLXRpdGxlLmNvbXBvbmVudC5odG1sJ1xyXG59KVxyXG5leHBvcnQgY2xhc3MgUGFnZVRpdGxlQ29tcG9uZW50IHtcclxuICAgIEBJbnB1dCgpIGljb24/OiBzdHJpbmc7XHJcblxyXG4gICAgQElucHV0KCkgdGl0bGU/OiBzdHJpbmc7XHJcblxyXG5cclxuICAgIHByaXZhdGUgX2lzRWRpdFBhZ2U6IGJvb2xlYW4gPSB0cnVlO1xyXG4gICAgQElucHV0KClcclxuICAgIGdldCBpc0VkaXRQYWdlKCk6IGJvb2xlYW4ge1xyXG4gICAgICAgIHJldHVybiB0aGlzLl9pc0VkaXRQYWdlO1xyXG4gICAgfVxyXG4gICAgc2V0IGlzRWRpdFBhZ2UodjogQm9vbGVhbklucHV0KSB7XHJcbiAgICAgICAgdGhpcy5faXNFZGl0UGFnZSA9IENvbnZlcnQudG9Cb29sZWFuKHYpO1xyXG4gICAgfVxyXG5cclxuICAgIEBJbnB1dCgpIG1vZGVsSWQ/OiBudW1iZXIgfCBudWxsO1xyXG5cclxufSIsIjxoMSBjbGFzcz1cImgyIHB0LTMgcGItMiBtYi0zIGJvcmRlci1ib3R0b21cIj5cclxuICAgIDxpICpuZ0lmPVwiaWNvblwiIGNsYXNzPVwie3tpY29ufX1cIj48L2k+PG5nLWNvbnRhaW5lciAqbmdJZj1cImljb25cIj4mbmJzcDs8L25nLWNvbnRhaW5lcj57eyB0aXRsZSB9fSZuYnNwOzxuZy1jb250YWluZXIgKm5nSWY9XCJpc0VkaXRQYWdlXCI+XHJcbiAgICAgICAgPHNtYWxsIGNsYXNzPVwidGV4dC1tdXRlZFwiICpuZ0lmPVwibW9kZWxJZCAmJiBtb2RlbElkID4gMCBlbHNlIGVsc2VCbG9ja1wiPls8bmctY29udGFpbmVyPnt7ICdBY3Rpb24uRWRpdCcgfCB0cmFuc2xhdGUgfX08L25nLWNvbnRhaW5lcj5dPC9zbWFsbD5cclxuICAgICAgICA8bmctdGVtcGxhdGUgI2Vsc2VCbG9jaz5cclxuICAgICAgICAgICAgPHNtYWxsIGNsYXNzPVwidGV4dC1tdXRlZFwiPls8bmctY29udGFpbmVyPnt7ICdBY3Rpb24uQ3JlYXRlJyB8IHRyYW5zbGF0ZSB9fTwvbmctY29udGFpbmVyPl08L3NtYWxsPlxyXG4gICAgICAgIDwvbmctdGVtcGxhdGU+XHJcbiAgICA8L25nLWNvbnRhaW5lcj5cclxuPC9oMT4iXX0=
|
|
@@ -1,16 +1,23 @@
|
|
|
1
1
|
import { Component, Input, Output, EventEmitter } from '@angular/core';
|
|
2
2
|
import { Pager } from '../../../models';
|
|
3
|
+
import { Convert } from '../../../utils';
|
|
3
4
|
import * as i0 from "@angular/core";
|
|
4
5
|
import * as i1 from "@angular/common";
|
|
5
6
|
import * as i2 from "@ngx-translate/core";
|
|
6
7
|
export class PagerComponent {
|
|
7
8
|
constructor() {
|
|
8
9
|
this.pager = new Pager();
|
|
9
|
-
this.
|
|
10
|
+
this._showPageSize = true;
|
|
10
11
|
this.pagerAlign = 'start';
|
|
11
12
|
this.onPageChange = new EventEmitter();
|
|
12
13
|
this.onPageSizeChange = new EventEmitter();
|
|
13
14
|
}
|
|
15
|
+
get showPageSize() {
|
|
16
|
+
return this._showPageSize;
|
|
17
|
+
}
|
|
18
|
+
set showPageSize(v) {
|
|
19
|
+
this._showPageSize = Convert.toBoolean(v);
|
|
20
|
+
}
|
|
14
21
|
setPage(page) {
|
|
15
22
|
// if (!this.pager) return;
|
|
16
23
|
if (page === this.pager.pageNumber)
|
|
@@ -40,4 +47,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
|
|
|
40
47
|
}], onPageSizeChange: [{
|
|
41
48
|
type: Output
|
|
42
49
|
}] } });
|
|
43
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
50
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pager.component.js","sourceRoot":"","sources":["../../../../../../../projects/zek/src/lib/modules/pager/pager/pager.component.ts","../../../../../../../projects/zek/src/lib/modules/pager/pager/pager.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAEvE,OAAO,EAAE,KAAK,EAAE,MAAM,iBAAiB,CAAC;AACxC,OAAO,EAAE,OAAO,EAAE,MAAM,gBAAgB,CAAC;;;;AAOzC,MAAM,OAAO,cAAc;IAL3B;QAMa,UAAK,GAAG,IAAI,KAAK,EAAE,CAAC;QAErB,kBAAa,GAAY,IAAI,CAAC;QAS7B,eAAU,GAAG,OAAO,CAAC;QAkBpB,iBAAY,GAAG,IAAI,YAAY,EAAU,CAAC;QAE1C,qBAAgB,GAAG,IAAI,YAAY,EAAU,CAAC;KAC3D;IA7BG,IACI,YAAY;QACZ,OAAO,IAAI,CAAC,aAAa,CAAC;IAC9B,CAAC;IACD,IAAI,YAAY,CAAC,CAAe;QAC5B,IAAI,CAAC,aAAa,GAAG,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;IAC9C,CAAC;IAKD,OAAO,CAAC,IAAY;QAChB,2BAA2B;QAE3B,IAAI,IAAI,KAAK,IAAI,CAAC,KAAK,CAAC,UAAU;YAC9B,OAAO;QACX,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IACjC,CAAC;IACD,WAAW,CAAC,QAAgB;QACxB,2BAA2B;QAE3B,IAAI,QAAQ,KAAK,IAAI,CAAC,KAAK,CAAC,QAAQ;YAChC,OAAO;QACX,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IACzC,CAAC;;2GA5BQ,cAAc;+FAAd,cAAc,sNCV3B,swHAgDM;2FDtCO,cAAc;kBAL1B,SAAS;+BACI,WAAW;8BAKZ,KAAK;sBAAb,KAAK;gBAIF,YAAY;sBADf,KAAK;gBAQG,UAAU;sBAAlB,KAAK;gBAkBI,YAAY;sBAArB,MAAM;gBAEG,gBAAgB;sBAAzB,MAAM","sourcesContent":["import { Component, Input, Output, EventEmitter } from '@angular/core';\r\nimport { BooleanInput } from '../../../components';\r\nimport { Pager } from '../../../models';\r\nimport { Convert } from '../../../utils';\r\n\r\n@Component({\r\n    selector: 'zek-pager',\r\n    templateUrl: './pager.component.html',\r\n    styles: [':host { display: block; }']\r\n})\r\nexport class PagerComponent {\r\n    @Input() pager = new Pager();\r\n\r\n    private _showPageSize: boolean = true;\r\n    @Input()\r\n    get showPageSize(): boolean {\r\n        return this._showPageSize;\r\n    }\r\n    set showPageSize(v: BooleanInput) {\r\n        this._showPageSize = Convert.toBoolean(v);\r\n    }\r\n\r\n    @Input() pagerAlign = 'start';\r\n\r\n\r\n    setPage(page: number) {\r\n        // if (!this.pager) return;\r\n\r\n        if (page === this.pager.pageNumber)\r\n            return;\r\n        this.onPageChange.emit(page);\r\n    }\r\n    setPageSize(pageSize: number) {\r\n        // if (!this.pager) return;\r\n\r\n        if (pageSize === this.pager.pageSize)\r\n            return;\r\n        this.onPageSizeChange.emit(pageSize);\r\n    }\r\n\r\n    @Output() onPageChange = new EventEmitter<number>();\r\n\r\n    @Output() onPageSizeChange = new EventEmitter<number>();\r\n}","<div *ngIf=\"pager\" class=\"row\">\r\n    <div [ngClass]=\"{ 'col-sm-8': showPageSize, 'col-sm-12': !showPageSize}\">\r\n        <nav aria-label=\"Pagination\">\r\n            <ul class=\"pagination\" [ngClass]=\"{ 'justify-content-center': pagerAlign === 'center', 'justify-content-end': pagerAlign === 'end'}\">\r\n                <li [class.disabled]=\"pager.isFirstPage\" class=\"page-item\">\r\n                    <a class=\"page-link\" (click)=\"setPage(1)\" href=\"javascript:void(0)\" [attr.aria-disabled]=\"pager.isFirstPage ? 'true' : null\" aria-label=\"First\">\r\n                        <span aria-hidden=\"true\">&laquo;&laquo;</span>\r\n                    </a>\r\n                </li>\r\n                <li [class.disabled]=\"!pager.hasPreviousPage\" class=\"page-item\">\r\n                    <a class=\"page-link\" (click)=\"setPage(pager.pageNumber - 1)\" href=\"javascript:void(0)\" [attr.aria-disabled]=\"!pager.hasPreviousPage ? 'true' : null\" aria-label=\"Previous\">\r\n                        <span aria-hidden=\"true\">&laquo;</span>\r\n                    </a>\r\n                </li>\r\n                <li *ngFor=\"let page of pager.pages\" [class.active]=\"page === pager.pageNumber\" class=\"page-item\"><a class=\"page-link\" (click)=\"setPage(page)\" href=\"javascript:void(0)\">{{page}}</a></li>\r\n                <li [class.disabled]=\"!pager.hasNextPage\" class=\"page-item\">\r\n                    <a class=\"page-link\" (click)=\"setPage(pager.pageNumber + 1)\" href=\"javascript:void(0)\" [attr.aria-disabled]=\"!pager.hasNextPage ? 'true' : null\" aria-label=\"Next\">\r\n                        <span aria-hidden=\"true\">&raquo;</span>\r\n                    </a>\r\n                </li>\r\n                <li [class.disabled]=\"pager.isLastPage\" class=\"page-item\">\r\n                    <a class=\"page-link\" (click)=\"setPage(pager.pageCount)\" href=\"javascript:void(0)\" [attr.aria-disabled]=\"pager.isLastPage ? 'true' : null\" aria-label=\"Last\">\r\n                        <span aria-hidden=\"true\">&raquo;&raquo;</span>\r\n                    </a>\r\n                </li>\r\n            </ul>\r\n        </nav>\r\n    </div>\r\n    <div class=\"col-sm-4\" *ngIf=\"showPageSize\">\r\n        <div class=\"float-end\">\r\n            <div class=\"dropdown\">\r\n                <button class=\"btn btn-secondary dropdown-toggle\" type=\"button\" id=\"page-size-button\" data-bs-toggle=\"dropdown\" aria-expanded=\"false\">\r\n                    {{pager.pageSize}}\r\n                </button>\r\n                <ul class=\"dropdown-menu dropdown-menu-end\" aria-labelledby=\"page-size-button\">\r\n                    <li><h6 class=\"dropdown-header\">{{ 'Pagination.PageSize' | translate }}</h6></li>\r\n                    <li><a class=\"dropdown-item\" [class.active]=\"pager.pageSize === 10\" (click)=\"setPageSize(10)\" href=\"javascript:void(0)\">10</a></li>\r\n                    <li><a class=\"dropdown-item\" [class.active]=\"pager.pageSize === 20\" (click)=\"setPageSize(20)\" href=\"javascript:void(0)\">20</a></li>\r\n                    <li><a class=\"dropdown-item\" [class.active]=\"pager.pageSize === 50\" (click)=\"setPageSize(50)\" href=\"javascript:void(0)\">50</a></li>\r\n                    <li><a class=\"dropdown-item\" [class.active]=\"pager.pageSize === 100\" (click)=\"setPageSize(100)\" href=\"javascript:void(0)\">100</a></li>\r\n                    <li><a class=\"dropdown-item\" [class.active]=\"pager.pageSize === 500\" (click)=\"setPageSize(500)\" href=\"javascript:void(0)\">500</a></li>\r\n                </ul>\r\n            </div>\r\n        </div>\r\n        <div class=\"float-end mt-2\">\r\n            {{pager.firstItemOnPage}} - {{pager.lastItemOnPage}} of {{pager.totalItemCount}} &nbsp;\r\n        </div>\r\n    </div>\r\n</div>"]}
|
|
@@ -1,16 +1,23 @@
|
|
|
1
1
|
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import { Convert } from '../../utils';
|
|
2
3
|
import * as i0 from "@angular/core";
|
|
3
4
|
import * as i1 from "@angular/forms";
|
|
4
5
|
import * as i2 from "../validator/field-validator.component";
|
|
5
6
|
export class PasswordComponent {
|
|
6
7
|
constructor() {
|
|
7
8
|
this.name = 'Password';
|
|
8
|
-
this.
|
|
9
|
+
this._required = false;
|
|
9
10
|
this.minlength = null;
|
|
10
11
|
this.maxlength = null;
|
|
11
12
|
this.onChange = new EventEmitter();
|
|
12
13
|
this._type = 'password';
|
|
13
14
|
}
|
|
15
|
+
get required() {
|
|
16
|
+
return this._required;
|
|
17
|
+
}
|
|
18
|
+
set required(v) {
|
|
19
|
+
this._required = Convert.toBoolean(v);
|
|
20
|
+
}
|
|
14
21
|
get type() {
|
|
15
22
|
return this._type;
|
|
16
23
|
}
|
|
@@ -37,4 +44,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
|
|
|
37
44
|
type: Output,
|
|
38
45
|
args: ['modelChange']
|
|
39
46
|
}] } });
|
|
40
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
47
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGFzc3dvcmQuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvemVrL3NyYy9saWIvbW9kdWxlcy9wYXNzd29yZC9wYXNzd29yZC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy96ZWsvc3JjL2xpYi9tb2R1bGVzL3Bhc3N3b3JkL3Bhc3N3b3JkLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFdkUsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLGFBQWEsQ0FBQzs7OztBQU10QyxNQUFNLE9BQU8saUJBQWlCO0lBSjlCO1FBS2EsU0FBSSxHQUFHLFVBQVUsQ0FBQztRQUVuQixjQUFTLEdBQVksS0FBSyxDQUFDO1FBUzFCLGNBQVMsR0FBMkIsSUFBSSxDQUFDO1FBQ3pDLGNBQVMsR0FBMkIsSUFBSSxDQUFDO1FBRzNCLGFBQVEsR0FBRyxJQUFJLFlBQVksRUFBRSxDQUFDO1FBRTdDLFVBQUssR0FBRyxVQUFVLENBQUM7S0FROUI7SUF0QkcsSUFDSSxRQUFRO1FBQ1IsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDO0lBQzFCLENBQUM7SUFDRCxJQUFJLFFBQVEsQ0FBQyxDQUFlO1FBQ3hCLElBQUksQ0FBQyxTQUFTLEdBQUcsT0FBTyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUMxQyxDQUFDO0lBU0QsSUFBSSxJQUFJO1FBQ0osT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDO0lBQ3RCLENBQUM7SUFFRCxRQUFRO1FBQ0osSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsS0FBSyxLQUFLLFVBQVUsQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxVQUFVLENBQUM7SUFDakUsQ0FBQzs7OEdBekJRLGlCQUFpQjtrR0FBakIsaUJBQWlCLDBNQ1I5Qiw0a0JBUU07MkZEQU8saUJBQWlCO2tCQUo3QixTQUFTOytCQUNJLGNBQWM7OEJBSWYsSUFBSTtzQkFBWixLQUFLO2dCQUlGLFFBQVE7c0JBRFgsS0FBSztnQkFRRyxTQUFTO3NCQUFqQixLQUFLO2dCQUNHLFNBQVM7c0JBQWpCLEtBQUs7Z0JBRUcsS0FBSztzQkFBYixLQUFLO2dCQUNpQixRQUFRO3NCQUE5QixNQUFNO3VCQUFDLGFBQWEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBCb29sZWFuSW5wdXQgfSBmcm9tICcuLi8uLi9jb21wb25lbnRzJztcclxuaW1wb3J0IHsgQ29udmVydCB9IGZyb20gJy4uLy4uL3V0aWxzJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gICAgc2VsZWN0b3I6ICd6ZWstcGFzc3dvcmQnLFxyXG4gICAgdGVtcGxhdGVVcmw6ICcuL3Bhc3N3b3JkLmNvbXBvbmVudC5odG1sJ1xyXG59KVxyXG5leHBvcnQgY2xhc3MgUGFzc3dvcmRDb21wb25lbnQge1xyXG4gICAgQElucHV0KCkgbmFtZSA9ICdQYXNzd29yZCc7XHJcblxyXG4gICAgcHJpdmF0ZSBfcmVxdWlyZWQ6IGJvb2xlYW4gPSBmYWxzZTtcclxuICAgIEBJbnB1dCgpXHJcbiAgICBnZXQgcmVxdWlyZWQoKTogYm9vbGVhbiB7XHJcbiAgICAgICAgcmV0dXJuIHRoaXMuX3JlcXVpcmVkO1xyXG4gICAgfVxyXG4gICAgc2V0IHJlcXVpcmVkKHY6IEJvb2xlYW5JbnB1dCkge1xyXG4gICAgICAgIHRoaXMuX3JlcXVpcmVkID0gQ29udmVydC50b0Jvb2xlYW4odik7XHJcbiAgICB9XHJcblxyXG4gICAgQElucHV0KCkgbWlubGVuZ3RoOiBudW1iZXIgfCBzdHJpbmcgfCBudWxsID0gbnVsbDtcclxuICAgIEBJbnB1dCgpIG1heGxlbmd0aDogbnVtYmVyIHwgc3RyaW5nIHwgbnVsbCA9IG51bGw7XHJcblxyXG4gICAgQElucHV0KCkgbW9kZWw/OiBzdHJpbmcgfCBudWxsO1xyXG4gICAgQE91dHB1dCgnbW9kZWxDaGFuZ2UnKSBvbkNoYW5nZSA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcclxuXHJcbiAgICBwcml2YXRlIF90eXBlID0gJ3Bhc3N3b3JkJztcclxuICAgIGdldCB0eXBlKCkge1xyXG4gICAgICAgIHJldHVybiB0aGlzLl90eXBlO1xyXG4gICAgfVxyXG5cclxuICAgIHNob3dIaWRlKCkge1xyXG4gICAgICAgIHRoaXMuX3R5cGUgPSB0aGlzLl90eXBlID09PSAncGFzc3dvcmQnID8gJ3RleHQnIDogJ3Bhc3N3b3JkJztcclxuICAgIH1cclxufSIsIjxkaXYgY2xhc3M9XCJpbnB1dC1ncm91cCBoYXMtdmFsaWRhdGlvblwiPlxyXG4gICAgPGlucHV0IHR5cGU9XCJ7e3R5cGV9fVwiIGNsYXNzPVwiZm9ybS1jb250cm9sXCIgbmFtZT1cInt7bmFtZX19XCIgaWQ9XCJ7e25hbWV9fVwiIFthdHRyLmFyaWEtZGVzY3JpYmVkYnldPVwibmFtZSsnLXNob3cnXCJcclxuICAgIFtyZXF1aXJlZF09XCJyZXF1aXJlZFwiIFttaW5sZW5ndGhdPVwibWlubGVuZ3RoXCIgW21heGxlbmd0aF09XCJtYXhsZW5ndGhcIlxyXG4gICAgW25nTW9kZWxdPVwibW9kZWxcIiAobmdNb2RlbENoYW5nZSk9XCJvbkNoYW5nZS5lbWl0KCRldmVudClcIlxyXG4gICAgI3Bhc3N3b3JkPVwibmdNb2RlbFwiXHJcbiAgICA+XHJcbiAgICA8YnV0dG9uIGNsYXNzPVwiYnRuIGJ0bi1vdXRsaW5lLXNlY29uZGFyeVwiIHR5cGU9XCJidXR0b25cIiBpZD1cInt7bmFtZX19LXNob3dcIiAoY2xpY2spPVwic2hvd0hpZGUoKVwiPjxpIGNsYXNzPVwiZmEtc29saWQgZmEtZXllXCI+PC9pPjwvYnV0dG9uPlxyXG4gICAgPGRpdiB6ZWstZmllbGQtdmFsaWRhdG9yIFtmaWVsZF09XCJwYXNzd29yZFwiPjwvZGl2PlxyXG48L2Rpdj4iXX0=
|
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
import { Directive, Input } from '@angular/core';
|
|
2
|
+
import { Convert } from '../../utils';
|
|
2
3
|
import * as i0 from "@angular/core";
|
|
3
4
|
export class ReadOnlyDirective {
|
|
4
5
|
constructor() {
|
|
5
|
-
this.
|
|
6
|
+
this._readonly = false;
|
|
6
7
|
}
|
|
7
|
-
|
|
8
|
-
this.
|
|
8
|
+
readonly(v) {
|
|
9
|
+
this._readonly = Convert.toBoolean(v);
|
|
9
10
|
}
|
|
10
|
-
;
|
|
11
11
|
}
|
|
12
12
|
ReadOnlyDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: ReadOnlyDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
13
13
|
ReadOnlyDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.0", type: ReadOnlyDirective, selector: "[readonly],[readOnly]", inputs: { readonly: "readonly" }, host: { properties: { "attr.readonly": "_isReadonly ? \"\" : null" } }, ngImport: i0 });
|
|
@@ -22,4 +22,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
|
|
|
22
22
|
}], propDecorators: { readonly: [{
|
|
23
23
|
type: Input
|
|
24
24
|
}] } });
|
|
25
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
25
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVhZG9ubHkuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvemVrL3NyYy9saWIvbW9kdWxlcy9yZWFkb25seS9yZWFkb25seS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFakQsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLGFBQWEsQ0FBQzs7QUFRdEMsTUFBTSxPQUFPLGlCQUFpQjtJQU45QjtRQU9JLGNBQVMsR0FBRyxLQUFLLENBQUM7S0FJckI7SUFIWSxRQUFRLENBQUMsQ0FBZTtRQUM3QixJQUFJLENBQUMsU0FBUyxHQUFHLE9BQU8sQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDMUMsQ0FBQzs7OEdBSlEsaUJBQWlCO2tHQUFqQixpQkFBaUI7MkZBQWpCLGlCQUFpQjtrQkFON0IsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsdUJBQXVCO29CQUNqQyxJQUFJLEVBQUU7d0JBQ0YsaUJBQWlCLEVBQUUseUJBQXlCO3FCQUMvQztpQkFDSjs4QkFHWSxRQUFRO3NCQUFoQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBJbnB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBCb29sZWFuSW5wdXQgfSBmcm9tICcuLi8uLi9jb21wb25lbnRzJztcclxuaW1wb3J0IHsgQ29udmVydCB9IGZyb20gJy4uLy4uL3V0aWxzJztcclxuXHJcbkBEaXJlY3RpdmUoe1xyXG4gICAgc2VsZWN0b3I6ICdbcmVhZG9ubHldLFtyZWFkT25seV0nLFxyXG4gICAgaG9zdDoge1xyXG4gICAgICAgICdbYXR0ci5yZWFkb25seV0nOiAnX2lzUmVhZG9ubHkgPyBcIlwiIDogbnVsbCdcclxuICAgIH1cclxufSlcclxuZXhwb3J0IGNsYXNzIFJlYWRPbmx5RGlyZWN0aXZlIHtcclxuICAgIF9yZWFkb25seSA9IGZhbHNlO1xyXG4gICAgQElucHV0KCkgcmVhZG9ubHkodjogQm9vbGVhbklucHV0KSB7XHJcbiAgICAgICAgdGhpcy5fcmVhZG9ubHkgPSBDb252ZXJ0LnRvQm9vbGVhbih2KTtcclxuICAgIH1cclxufSJdfQ==
|
|
@@ -195,4 +195,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
|
|
|
195
195
|
}], data: [{
|
|
196
196
|
type: Input
|
|
197
197
|
}] } });
|
|
198
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.js","sourceRoot":"","sources":["../../../../../../projects/zek/src/lib/modules/select/select.ts","../../../../../../projects/zek/src/lib/modules/select/select.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, forwardRef, Input, Renderer2 } from '@angular/core';\r\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { BooleanInput, CoreUiComponent } from '../../components';\r\nimport { ArrayHelper, Convert } from '../../utils';\r\nimport { KeyPairOption } from './model';\r\n\r\n\r\nlet uniqueId = 0;\r\n\r\n\r\nconst ZEK_SELECT_MULTIPLE_CONTROL_VALUE_ACCESSOR: any = {\r\n    provide: NG_VALUE_ACCESSOR,\r\n    useExisting: forwardRef(() => ZekSelectMultiple),\r\n    multi: true,\r\n};\r\n\r\n@Component({\r\n    selector: 'zek-select,[zek-select]',\r\n    templateUrl: './select.html',\r\n    providers: [ZEK_SELECT_MULTIPLE_CONTROL_VALUE_ACCESSOR],\r\n})\r\n\r\nexport class ZekSelectMultiple extends CoreUiComponent {\r\n    constructor(renderer: Renderer2, elementRef: ElementRef) {\r\n        super(renderer, elementRef);\r\n    }\r\n\r\n    private _uniqueId: string = `zek-select-${++uniqueId}`;\r\n    /** The unique ID for the radio button. */\r\n    @Input() id: string = this._uniqueId;\r\n\r\n    @Input() valueField?: string | null;\r\n    @Input() textField?: string | null;\r\n    @Input() checkedTextField?: string | null;\r\n\r\n    @Input() css: 'primary' | 'secondary' | 'success' | 'danger ' | 'warning' | 'info' | 'light' | 'dark' = 'primary';\r\n\r\n\r\n    @Input()\r\n    get placeholder(): string {\r\n        return this._placeholder;\r\n    }\r\n    set placeholder(value: string | null | undefined) {\r\n        if (value)\r\n            this._placeholder = value;\r\n        else\r\n            this._placeholder = '';\r\n    }\r\n    private _placeholder = '';\r\n\r\n    @Input()\r\n    get label(): string {\r\n        return this._label;\r\n    }\r\n    set label(value: string | null | undefined) {\r\n        if (value)\r\n            this._label = value;\r\n        else\r\n            this._label = '';\r\n    }\r\n    private _label = '';\r\n\r\n\r\n\r\n    @Input()\r\n    get multiple() {\r\n        return this._multiple;\r\n    }\r\n    set multiple(value: BooleanInput) {\r\n        this._multiple = Convert.toBoolean(value);\r\n    }\r\n    private _multiple = true;\r\n\r\n\r\n    private _selected: any[] = [];\r\n\r\n    @Input() get data() {\r\n        return this._data;\r\n    }\r\n    set data(value: any[] | null | undefined) {\r\n        if (this._data !== value) {\r\n            this._data = value;\r\n            this.onDataChanged();\r\n        }\r\n    }\r\n    private _data?: any[] | null = [];\r\n    normalized: KeyPairOption[] = [];\r\n    onDataChanged() {\r\n        this._setSelectionByValue(this._value);\r\n        if (this.isInitialized) {\r\n            this._normalizeData();\r\n        }\r\n    }\r\n\r\n    _text = '';\r\n\r\n\r\n\r\n    override onValueChanged() {\r\n        if (Array.isArray(this._data)) {\r\n            this._setSelectionByValue(this._value);\r\n        }\r\n    }\r\n\r\n\r\n    override init(): void {\r\n        this._normalizeData();\r\n    }\r\n\r\n\r\n    private _normalizeData() {\r\n        this.normalized = [];\r\n        if (Array.isArray(this._data)) {\r\n            if (this.valueField && this.textField) {\r\n                for (const item of this._data) {\r\n                    this.normalized.push({ key: item[this.valueField], value: item[this.textField], checked: this._selected.includes(item), item: item });\r\n                }\r\n            } else {\r\n                for (const item of this._data) {\r\n                    this.normalized.push({ key: item, value: item, checked: this._selected.includes(item), item });\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Sets the selected option based on a value. If no option can be\r\n     * found with the designated value, the select trigger is cleared.\r\n     */\r\n    private _setSelectionByValue(value: any | any[]): void {\r\n        this._selected = [];\r\n\r\n        if (this.multiple && value) {\r\n            if (!Array.isArray(value)) {\r\n                throw new Error(\"value is not array\");\r\n            }\r\n\r\n            if (Array.isArray(this._data)) {\r\n                let notUnique: any[] = [];\r\n                if (this.valueField) {\r\n                    for (const currentValue of value) {\r\n                        let items = ArrayHelper.filterByKey(currentValue, this.valueField, this._data);\r\n                        notUnique = notUnique.concat(items);\r\n                    }\r\n                } else {\r\n                    for (const currentValue of value) {\r\n                        let items = this._data.filter(x => x === currentValue);\r\n                        notUnique = notUnique.concat(items);\r\n                    }\r\n                }\r\n\r\n                this._selected = ArrayHelper.distinct(notUnique);\r\n            }\r\n        } else {\r\n            if (Array.isArray(this._data)) {\r\n                if (this.valueField) {\r\n                    this._selected = ArrayHelper.filterByKey(value, this.valueField, this._data);\r\n                } else {\r\n                    this._selected = this._data.filter(x => x === value);\r\n                }\r\n            }\r\n        }\r\n\r\n        for (const norm of this.normalized) {\r\n            norm.checked = this._selected.includes(norm.item);\r\n        }\r\n        this._initText();\r\n    }\r\n\r\n\r\n\r\n\r\n    toggleChecked(v: any) {\r\n        if (v && !this.disabled && !this.readonly) {\r\n            if (!v.checked) {\r\n                v.checked = true;\r\n\r\n                if (this.multiple) {\r\n                    let tmp = [];\r\n                    for (const item of this.normalized) {\r\n                        if (item.checked) {\r\n                            tmp.push(item.key);\r\n                        }\r\n                    }\r\n\r\n                    this.setNgModel(tmp);\r\n                    // this.value = tmp;\r\n                }\r\n                else {\r\n                    //this.value = v.key;\r\n                    this.setNgModel(v.key);\r\n                }\r\n            } else {\r\n                v.checked = false;\r\n                if (this.multiple) {\r\n                    if (Array.isArray(this._value)) {\r\n                        this.setNgModel((this._value as any[]).filter(x => x !== v.key));\r\n                    }\r\n                } else {\r\n                    this.setNgModel(null);\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n\r\n    private _initText() {\r\n        let field = this.checkedTextField || this.textField || '';\r\n        if (field) {\r\n            this._text = this._selected.filter(x => x !== undefined && x !== null).map(x => x[field]).join(', ');\r\n        } else {\r\n            this._text = this._selected.join(', ');\r\n        }\r\n    }\r\n}\r\n","<div class=\"dropdown\" id=\"dropdown-{{id}}\">\r\n    <button class=\"btn btn-{{css}} dropdown-toggle\" type=\"button\" data-bs-toggle=\"dropdown\" aria-expanded=\"false\">\r\n        {{label}} <ng-container *ngIf=\"!_text\">{{placeholder}}</ng-container> {{_text}}\r\n    </button>\r\n    <ul class=\"dropdown-menu\">\r\n        <ng-container *ngIf=\"normalized\">\r\n            <li><a class=\"dropdown-item\" href=\"javascript:void(0)\" *ngFor=\"let item of normalized\" (click)=\"toggleChecked(item)\">\r\n                    <span *ngIf=\"item.checked\"><i class=\"fa-regular fa-square-check\"></i></span>\r\n                    <span *ngIf=\"!item.checked\"><i class=\"fa-regular fa-square\"></i></span>\r\n                    {{item.value}}\r\n                </a></li>\r\n        </ng-container>\r\n    </ul>\r\n</div>"]}
|
|
198
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.js","sourceRoot":"","sources":["../../../../../../projects/zek/src/lib/modules/select/select.ts","../../../../../../projects/zek/src/lib/modules/select/select.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, forwardRef, Input, Renderer2 } from '@angular/core';\r\nimport { NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { BooleanInput, CoreUiComponent } from '../../components';\r\nimport { ArrayHelper, Convert } from '../../utils';\r\nimport { KeyPairOption } from './model';\r\n\r\n\r\nlet uniqueId = 0;\r\n\r\n\r\nconst ZEK_SELECT_MULTIPLE_CONTROL_VALUE_ACCESSOR: any = {\r\n    provide: NG_VALUE_ACCESSOR,\r\n    useExisting: forwardRef(() => ZekSelectMultiple),\r\n    multi: true,\r\n};\r\n\r\n@Component({\r\n    selector: 'zek-select,[zek-select]',\r\n    templateUrl: './select.html',\r\n    providers: [ZEK_SELECT_MULTIPLE_CONTROL_VALUE_ACCESSOR],\r\n})\r\n\r\nexport class ZekSelectMultiple extends CoreUiComponent {\r\n    constructor(renderer: Renderer2, elementRef: ElementRef) {\r\n        super(renderer, elementRef);\r\n    }\r\n\r\n    private _uniqueId: string = `zek-select-${++uniqueId}`;\r\n    /** The unique ID for the radio button. */\r\n    @Input() id: string = this._uniqueId;\r\n\r\n    @Input() valueField?: string | null;\r\n    @Input() textField?: string | null;\r\n    @Input() checkedTextField?: string | null;\r\n\r\n    @Input() css: 'primary' | 'secondary' | 'success' | 'danger ' | 'warning' | 'info' | 'light' | 'dark' = 'primary';\r\n\r\n\r\n    @Input()\r\n    get placeholder(): string {\r\n        return this._placeholder;\r\n    }\r\n    set placeholder(value: string | null | undefined) {\r\n        if (value)\r\n            this._placeholder = value;\r\n        else\r\n            this._placeholder = '';\r\n    }\r\n    private _placeholder = '';\r\n\r\n    @Input()\r\n    get label(): string {\r\n        return this._label;\r\n    }\r\n    set label(value: string | null | undefined) {\r\n        if (value)\r\n            this._label = value;\r\n        else\r\n            this._label = '';\r\n    }\r\n    private _label = '';\r\n\r\n\r\n\r\n    @Input()\r\n    get multiple() {\r\n        return this._multiple;\r\n    }\r\n    set multiple(value: BooleanInput) {\r\n        this._multiple = Convert.toBoolean(value);\r\n    }\r\n    private _multiple = true;\r\n\r\n\r\n    private _selected: any[] = [];\r\n\r\n    @Input()\r\n    get data() {\r\n        return this._data;\r\n    }\r\n    set data(value: any[] | null | undefined) {\r\n        if (this._data !== value) {\r\n            this._data = value;\r\n            this.onDataChanged();\r\n        }\r\n    }\r\n    private _data?: any[] | null = [];\r\n    normalized: KeyPairOption[] = [];\r\n    onDataChanged() {\r\n        this._setSelectionByValue(this._value);\r\n        if (this.isInitialized) {\r\n            this._normalizeData();\r\n        }\r\n    }\r\n\r\n    _text = '';\r\n\r\n\r\n\r\n    override onValueChanged() {\r\n        if (Array.isArray(this._data)) {\r\n            this._setSelectionByValue(this._value);\r\n        }\r\n    }\r\n\r\n\r\n    override init(): void {\r\n        this._normalizeData();\r\n    }\r\n\r\n\r\n    private _normalizeData() {\r\n        this.normalized = [];\r\n        if (Array.isArray(this._data)) {\r\n            if (this.valueField && this.textField) {\r\n                for (const item of this._data) {\r\n                    this.normalized.push({ key: item[this.valueField], value: item[this.textField], checked: this._selected.includes(item), item: item });\r\n                }\r\n            } else {\r\n                for (const item of this._data) {\r\n                    this.normalized.push({ key: item, value: item, checked: this._selected.includes(item), item });\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Sets the selected option based on a value. If no option can be\r\n     * found with the designated value, the select trigger is cleared.\r\n     */\r\n    private _setSelectionByValue(value: any | any[]): void {\r\n        this._selected = [];\r\n\r\n        if (this.multiple && value) {\r\n            if (!Array.isArray(value)) {\r\n                throw new Error(\"value is not array\");\r\n            }\r\n\r\n            if (Array.isArray(this._data)) {\r\n                let notUnique: any[] = [];\r\n                if (this.valueField) {\r\n                    for (const currentValue of value) {\r\n                        let items = ArrayHelper.filterByKey(currentValue, this.valueField, this._data);\r\n                        notUnique = notUnique.concat(items);\r\n                    }\r\n                } else {\r\n                    for (const currentValue of value) {\r\n                        let items = this._data.filter(x => x === currentValue);\r\n                        notUnique = notUnique.concat(items);\r\n                    }\r\n                }\r\n\r\n                this._selected = ArrayHelper.distinct(notUnique);\r\n            }\r\n        } else {\r\n            if (Array.isArray(this._data)) {\r\n                if (this.valueField) {\r\n                    this._selected = ArrayHelper.filterByKey(value, this.valueField, this._data);\r\n                } else {\r\n                    this._selected = this._data.filter(x => x === value);\r\n                }\r\n            }\r\n        }\r\n\r\n        for (const norm of this.normalized) {\r\n            norm.checked = this._selected.includes(norm.item);\r\n        }\r\n        this._initText();\r\n    }\r\n\r\n\r\n\r\n\r\n    toggleChecked(v: any) {\r\n        if (v && !this.disabled && !this.readonly) {\r\n            if (!v.checked) {\r\n                v.checked = true;\r\n\r\n                if (this.multiple) {\r\n                    let tmp = [];\r\n                    for (const item of this.normalized) {\r\n                        if (item.checked) {\r\n                            tmp.push(item.key);\r\n                        }\r\n                    }\r\n\r\n                    this.setNgModel(tmp);\r\n                    // this.value = tmp;\r\n                }\r\n                else {\r\n                    //this.value = v.key;\r\n                    this.setNgModel(v.key);\r\n                }\r\n            } else {\r\n                v.checked = false;\r\n                if (this.multiple) {\r\n                    if (Array.isArray(this._value)) {\r\n                        this.setNgModel((this._value as any[]).filter(x => x !== v.key));\r\n                    }\r\n                } else {\r\n                    this.setNgModel(null);\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n\r\n    private _initText() {\r\n        let field = this.checkedTextField || this.textField || '';\r\n        if (field) {\r\n            this._text = this._selected.filter(x => x !== undefined && x !== null).map(x => x[field]).join(', ');\r\n        } else {\r\n            this._text = this._selected.join(', ');\r\n        }\r\n    }\r\n}\r\n","<div class=\"dropdown\" id=\"dropdown-{{id}}\">\r\n    <button class=\"btn btn-{{css}} dropdown-toggle\" type=\"button\" data-bs-toggle=\"dropdown\" aria-expanded=\"false\">\r\n        {{label}} <ng-container *ngIf=\"!_text\">{{placeholder}}</ng-container> {{_text}}\r\n    </button>\r\n    <ul class=\"dropdown-menu\">\r\n        <ng-container *ngIf=\"normalized\">\r\n            <li><a class=\"dropdown-item\" href=\"javascript:void(0)\" *ngFor=\"let item of normalized\" (click)=\"toggleChecked(item)\">\r\n                    <span *ngIf=\"item.checked\"><i class=\"fa-regular fa-square-check\"></i></span>\r\n                    <span *ngIf=\"!item.checked\"><i class=\"fa-regular fa-square\"></i></span>\r\n                    {{item.value}}\r\n                </a></li>\r\n        </ng-container>\r\n    </ul>\r\n</div>"]}
|