zek 14.2.47 → 14.2.49
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/components/types.mjs +1 -1
- 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/index.mjs +2 -1
- 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/progress/index.mjs +3 -0
- package/esm2020/lib/modules/progress/module.mjs +26 -0
- package/esm2020/lib/modules/progress/progress.mjs +100 -0
- 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/esm2020/lib/utils/convert.mjs +7 -1
- package/esm2020/lib/utils/math-helper.mjs +2 -2
- package/fesm2015/zek.mjs +397 -40
- package/fesm2015/zek.mjs.map +1 -1
- package/fesm2020/zek.mjs +397 -40
- package/fesm2020/zek.mjs.map +1 -1
- package/lib/components/base.component.d.ts +3 -2
- package/lib/components/types.d.ts +1 -0
- 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/index.d.ts +1 -0
- 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/progress/index.d.ts +2 -0
- package/lib/modules/progress/module.d.ts +9 -0
- package/lib/modules/progress/progress.d.ts +32 -0
- package/lib/modules/readonly/readonly.directive.d.ts +3 -2
- package/lib/utils/convert.d.ts +1 -0
- package/lib/utils/math-helper.d.ts +1 -1
- package/package.json +1 -1
|
@@ -0,0 +1,100 @@
|
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
import { Convert, MathHelper, ObjectHelper } from '../../utils';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/common";
|
|
5
|
+
function toPercent(v) {
|
|
6
|
+
let n = MathHelper.round(Convert.toNumber(v));
|
|
7
|
+
if (n > 100) {
|
|
8
|
+
return 100;
|
|
9
|
+
}
|
|
10
|
+
else if (n < 0) {
|
|
11
|
+
return 0;
|
|
12
|
+
}
|
|
13
|
+
return n;
|
|
14
|
+
}
|
|
15
|
+
export class ZekProgress {
|
|
16
|
+
constructor() {
|
|
17
|
+
this._max = 100;
|
|
18
|
+
this._value = 0;
|
|
19
|
+
this._normalizedValue = 0;
|
|
20
|
+
this._showValue = false;
|
|
21
|
+
this._striped = false;
|
|
22
|
+
this._animated = false;
|
|
23
|
+
this._label = null;
|
|
24
|
+
this._height = null;
|
|
25
|
+
}
|
|
26
|
+
get max() {
|
|
27
|
+
return this._max;
|
|
28
|
+
}
|
|
29
|
+
set max(v) {
|
|
30
|
+
this._max = toPercent(v);
|
|
31
|
+
}
|
|
32
|
+
get value() {
|
|
33
|
+
return this._value;
|
|
34
|
+
}
|
|
35
|
+
set value(v) {
|
|
36
|
+
this._value = Convert.toNumber(v);
|
|
37
|
+
this._normalizedValue = toPercent(this._value);
|
|
38
|
+
}
|
|
39
|
+
get showValue() {
|
|
40
|
+
return this._showValue;
|
|
41
|
+
}
|
|
42
|
+
set showValue(v) {
|
|
43
|
+
this._showValue = Convert.toBoolean(v);
|
|
44
|
+
}
|
|
45
|
+
get striped() {
|
|
46
|
+
return this._striped;
|
|
47
|
+
}
|
|
48
|
+
set striped(v) {
|
|
49
|
+
this._striped = Convert.toBoolean(v);
|
|
50
|
+
}
|
|
51
|
+
get animated() {
|
|
52
|
+
return this._animated;
|
|
53
|
+
}
|
|
54
|
+
set animated(v) {
|
|
55
|
+
this._animated = Convert.toBoolean(v);
|
|
56
|
+
}
|
|
57
|
+
get label() {
|
|
58
|
+
return this._label;
|
|
59
|
+
}
|
|
60
|
+
set label(v) {
|
|
61
|
+
if (this.label)
|
|
62
|
+
this._label = v;
|
|
63
|
+
}
|
|
64
|
+
get height() {
|
|
65
|
+
return this._height;
|
|
66
|
+
}
|
|
67
|
+
set height(v) {
|
|
68
|
+
if (ObjectHelper.isDefined(v)) {
|
|
69
|
+
this._height = Convert.toNumber(v);
|
|
70
|
+
}
|
|
71
|
+
else {
|
|
72
|
+
this._height = null;
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
get background() {
|
|
76
|
+
return this._background;
|
|
77
|
+
}
|
|
78
|
+
set background(v) {
|
|
79
|
+
this._background = v;
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
ZekProgress.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: ZekProgress, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
83
|
+
ZekProgress.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: ZekProgress, selector: "zek-progress", inputs: { max: "max", striped: "striped", animated: "animated", label: "label", height: "height", background: "background" }, ngImport: i0, template: "<div class=\"progress\">\r\n <div class=\"progress-bar\" role=\"progressbar\"\r\n [class.progress-bar-striped]=\"striped || animated\"\r\n [class.progress-bar-animated]=\"animated\"\r\n [style.height.px]=\"height\"\r\n [style.width.%]=\"_normalizedValue\"\r\n [attr.aria-valuenow]=\"_normalizedValue\"\r\n aria-valuemin=\"0\"\r\n [attr.aria-valuemax]=\"max\">\r\n <ng-container *ngIf=\"showValue\">{{_normalizedValue}}%</ng-container>\r\n {{label}}\r\n </div>\r\n</div>", styles: [":host{display:block}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
|
|
84
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: ZekProgress, decorators: [{
|
|
85
|
+
type: Component,
|
|
86
|
+
args: [{ selector: 'zek-progress', template: "<div class=\"progress\">\r\n <div class=\"progress-bar\" role=\"progressbar\"\r\n [class.progress-bar-striped]=\"striped || animated\"\r\n [class.progress-bar-animated]=\"animated\"\r\n [style.height.px]=\"height\"\r\n [style.width.%]=\"_normalizedValue\"\r\n [attr.aria-valuenow]=\"_normalizedValue\"\r\n aria-valuemin=\"0\"\r\n [attr.aria-valuemax]=\"max\">\r\n <ng-container *ngIf=\"showValue\">{{_normalizedValue}}%</ng-container>\r\n {{label}}\r\n </div>\r\n</div>", styles: [":host{display:block}\n"] }]
|
|
87
|
+
}], propDecorators: { max: [{
|
|
88
|
+
type: Input
|
|
89
|
+
}], striped: [{
|
|
90
|
+
type: Input
|
|
91
|
+
}], animated: [{
|
|
92
|
+
type: Input
|
|
93
|
+
}], label: [{
|
|
94
|
+
type: Input
|
|
95
|
+
}], height: [{
|
|
96
|
+
type: Input
|
|
97
|
+
}], background: [{
|
|
98
|
+
type: Input
|
|
99
|
+
}] } });
|
|
100
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"progress.js","sourceRoot":"","sources":["../../../../../../projects/zek/src/lib/modules/progress/progress.ts","../../../../../../projects/zek/src/lib/modules/progress/progress.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input } from '@angular/core';\r\nimport { BooleanInput, NumberInput } from '../../components';\r\nimport { Convert, MathHelper, ObjectHelper } from '../../utils';\r\n\r\nfunction toPercent(v: NumberInput) {\r\n    let n = MathHelper.round(Convert.toNumber(v));\r\n    if (n > 100) {\r\n        return 100;\r\n    } else if (n < 0) {\r\n        return 0;\r\n    }\r\n    return n\r\n}\r\n\r\n\r\n@Component({\r\n    selector: 'zek-progress',\r\n    templateUrl: './progress.html',\r\n    styles: [':host { display: block; }']\r\n})\r\nexport class ZekProgress {\r\n\r\n    private _max: number = 100;\r\n    @Input() get max(): number {\r\n        return this._max;\r\n    }\r\n    set max(v: NumberInput) {\r\n        this._max = toPercent(v);\r\n    }\r\n\r\n\r\n    private _value: number = 0;\r\n    get value(): number {\r\n        return this._value;\r\n    }\r\n    set value(v: NumberInput) {\r\n        this._value = Convert.toNumber(v);\r\n        this._normalizedValue = toPercent(this._value);\r\n    }\r\n\r\n    _normalizedValue: number = 0;\r\n\r\n\r\n\r\n    private _showValue: boolean = false;\r\n    get showValue(): boolean {\r\n        return this._showValue;\r\n    }\r\n    set showValue(v: BooleanInput) {\r\n        this._showValue = Convert.toBoolean(v);\r\n    }\r\n\r\n\r\n    private _striped: boolean = false;\r\n    @Input()\r\n    get striped(): boolean {\r\n        return this._striped;\r\n    }\r\n    set striped(v: BooleanInput) {\r\n        this._striped = Convert.toBoolean(v);\r\n    }\r\n\r\n    private _animated: boolean = false;\r\n    @Input()\r\n    get animated(): boolean {\r\n        return this._animated;\r\n    }\r\n    set animated(v: BooleanInput) {\r\n        this._animated = Convert.toBoolean(v);\r\n    }\r\n\r\n    private _label: string | null | undefined = null;\r\n    @Input()\r\n    get label() {\r\n        return this._label;\r\n    }\r\n    set label(v: string | null | undefined) {\r\n        if (this.label)\r\n            this._label = v;\r\n    }\r\n\r\n\r\n\r\n    private _height: number | null = null;\r\n    @Input()\r\n    get height() {\r\n        return this._height;\r\n    }\r\n    set height(v: NumberInput) {\r\n        if (ObjectHelper.isDefined(v)) {\r\n            this._height = Convert.toNumber(v);\r\n        }\r\n        else {\r\n            this._height = null;\r\n        }\r\n    }\r\n\r\n\r\n\r\n\r\n    type: 'primary' | 'secondary' | 'success' | 'danger' | 'warning' | 'info' | 'light' | 'dark' | 'body' | 'white' | 'transparent' | null | undefined;\r\n\r\n\r\n    private _background: 'primary' | 'secondary' | 'success' | 'danger' | 'warning' | 'info' | 'light' | 'dark' | 'body' | 'white' | 'transparent' | null | undefined;\r\n    @Input()\r\n    get background() {\r\n        return this._background;\r\n    }\r\n    set background(v: 'primary' | 'secondary' | 'success' | 'danger' | 'warning' | 'info' | 'light' | 'dark' | 'body' | 'white' | 'transparent' | null | undefined) {\r\n        this._background = v;\r\n    }\r\n}","<div class=\"progress\">\r\n    <div class=\"progress-bar\" role=\"progressbar\"\r\n        [class.progress-bar-striped]=\"striped || animated\"\r\n        [class.progress-bar-animated]=\"animated\"\r\n        [style.height.px]=\"height\"\r\n        [style.width.%]=\"_normalizedValue\"\r\n        [attr.aria-valuenow]=\"_normalizedValue\"\r\n        aria-valuemin=\"0\"\r\n        [attr.aria-valuemax]=\"max\">\r\n        <ng-container *ngIf=\"showValue\">{{_normalizedValue}}%</ng-container>\r\n        {{label}}\r\n    </div>\r\n</div>"]}
|
|
@@ -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":"AAAA,OAAO,EAAE,SAAS,EAAc,UAAU,EAAE,KAAK,EAAa,MAAM,eAAe,CAAC;AACpF,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACnD,OAAO,EAAgB,eAAe,EAAE,MAAM,kBAAkB,CAAC;AACjE,OAAO,EAAE,WAAW,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC;;;AAInD,IAAI,QAAQ,GAAG,CAAC,CAAC;AAGjB,MAAM,0CAA0C,GAAQ;IACpD,OAAO,EAAE,iBAAiB;IAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,iBAAiB,CAAC;IAChD,KAAK,EAAE,IAAI;CACd,CAAC;AAQF,MAAM,OAAO,iBAAkB,SAAQ,eAAe;IAClD,YAAY,QAAmB,EAAE,UAAsB;QACnD,KAAK,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAC;QAGxB,cAAS,GAAW,cAAc,EAAE,QAAQ,EAAE,CAAC;QACvD,0CAA0C;QACjC,OAAE,GAAW,IAAI,CAAC,SAAS,CAAC;QAM5B,QAAG,GAA4F,SAAS,CAAC;QAa1G,iBAAY,GAAG,EAAE,CAAC;QAYlB,WAAM,GAAG,EAAE,CAAC;QAWZ,cAAS,GAAG,IAAI,CAAC;QAGjB,cAAS,GAAU,EAAE,CAAC;QAWtB,UAAK,GAAkB,EAAE,CAAC;QAClC,eAAU,GAAoB,EAAE,CAAC;QAQjC,UAAK,GAAG,EAAE,CAAC;IArEX,CAAC;IAaD,IACI,WAAW;QACX,OAAO,IAAI,CAAC,YAAY,CAAC;IAC7B,CAAC;IACD,IAAI,WAAW,CAAC,KAAgC;QAC5C,IAAI,KAAK;YACL,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;;YAE1B,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;IAC/B,CAAC;IAGD,IACI,KAAK;QACL,OAAO,IAAI,CAAC,MAAM,CAAC;IACvB,CAAC;IACD,IAAI,KAAK,CAAC,KAAgC;QACtC,IAAI,KAAK;YACL,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;;YAEpB,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;IACzB,CAAC;IAKD,IACI,QAAQ;QACR,OAAO,IAAI,CAAC,SAAS,CAAC;IAC1B,CAAC;IACD,IAAI,QAAQ,CAAC,KAAmB;QAC5B,IAAI,CAAC,SAAS,GAAG,OAAO,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;IAC9C,CAAC;IAMD,IAAa,IAAI;QACb,OAAO,IAAI,CAAC,KAAK,CAAC;IACtB,CAAC;IACD,IAAI,IAAI,CAAC,KAA+B;QACpC,IAAI,IAAI,CAAC,KAAK,KAAK,KAAK,EAAE;YACtB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;YACnB,IAAI,CAAC,aAAa,EAAE,CAAC;SACxB;IACL,CAAC;IAGD,aAAa;QACT,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QACvC,IAAI,IAAI,CAAC,aAAa,EAAE;YACpB,IAAI,CAAC,cAAc,EAAE,CAAC;SACzB;IACL,CAAC;IAMQ,cAAc;QACnB,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE;YAC3B,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;SAC1C;IACL,CAAC;IAGQ,IAAI;QACT,IAAI,CAAC,cAAc,EAAE,CAAC;IAC1B,CAAC;IAGO,cAAc;QAClB,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;QACrB,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE;YAC3B,IAAI,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,SAAS,EAAE;gBACnC,KAAK,MAAM,IAAI,IAAI,IAAI,CAAC,KAAK,EAAE;oBAC3B,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,KAAK,EAAE,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC;iBACzI;aACJ;iBAAM;gBACH,KAAK,MAAM,IAAI,IAAI,IAAI,CAAC,KAAK,EAAE;oBAC3B,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,GAAG,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC;iBAClG;aACJ;SACJ;IACL,CAAC;IAED;;;OAGG;IACK,oBAAoB,CAAC,KAAkB;QAC3C,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;QAEpB,IAAI,IAAI,CAAC,QAAQ,IAAI,KAAK,EAAE;YACxB,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;gBACvB,MAAM,IAAI,KAAK,CAAC,oBAAoB,CAAC,CAAC;aACzC;YAED,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE;gBAC3B,IAAI,SAAS,GAAU,EAAE,CAAC;gBAC1B,IAAI,IAAI,CAAC,UAAU,EAAE;oBACjB,KAAK,MAAM,YAAY,IAAI,KAAK,EAAE;wBAC9B,IAAI,KAAK,GAAG,WAAW,CAAC,WAAW,CAAC,YAAY,EAAE,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;wBAC/E,SAAS,GAAG,SAAS,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;qBACvC;iBACJ;qBAAM;oBACH,KAAK,MAAM,YAAY,IAAI,KAAK,EAAE;wBAC9B,IAAI,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,YAAY,CAAC,CAAC;wBACvD,SAAS,GAAG,SAAS,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;qBACvC;iBACJ;gBAED,IAAI,CAAC,SAAS,GAAG,WAAW,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;aACpD;SACJ;aAAM;YACH,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE;gBAC3B,IAAI,IAAI,CAAC,UAAU,EAAE;oBACjB,IAAI,CAAC,SAAS,GAAG,WAAW,CAAC,WAAW,CAAC,KAAK,EAAE,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;iBAChF;qBAAM;oBACH,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,KAAK,CAAC,CAAC;iBACxD;aACJ;SACJ;QAED,KAAK,MAAM,IAAI,IAAI,IAAI,CAAC,UAAU,EAAE;YAChC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;SACrD;QACD,IAAI,CAAC,SAAS,EAAE,CAAC;IACrB,CAAC;IAKD,aAAa,CAAC,CAAM;QAChB,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YACvC,IAAI,CAAC,CAAC,CAAC,OAAO,EAAE;gBACZ,CAAC,CAAC,OAAO,GAAG,IAAI,CAAC;gBAEjB,IAAI,IAAI,CAAC,QAAQ,EAAE;oBACf,IAAI,GAAG,GAAG,EAAE,CAAC;oBACb,KAAK,MAAM,IAAI,IAAI,IAAI,CAAC,UAAU,EAAE;wBAChC,IAAI,IAAI,CAAC,OAAO,EAAE;4BACd,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;yBACtB;qBACJ;oBAED,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;oBACrB,oBAAoB;iBACvB;qBACI;oBACD,qBAAqB;oBACrB,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;iBAC1B;aACJ;iBAAM;gBACH,CAAC,CAAC,OAAO,GAAG,KAAK,CAAC;gBAClB,IAAI,IAAI,CAAC,QAAQ,EAAE;oBACf,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE;wBAC5B,IAAI,CAAC,UAAU,CAAE,IAAI,CAAC,MAAgB,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;qBACpE;iBACJ;qBAAM;oBACH,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;iBACzB;aACJ;SACJ;IACL,CAAC;IAGO,SAAS;QACb,IAAI,KAAK,GAAG,IAAI,CAAC,gBAAgB,IAAI,IAAI,CAAC,SAAS,IAAI,EAAE,CAAC;QAC1D,IAAI,KAAK,EAAE;YACP,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,SAAS,IAAI,CAAC,KAAK,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;SACxG;aAAM;YACH,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;SAC1C;IACL,CAAC;;8GA/LQ,iBAAiB;kGAAjB,iBAAiB,4PAHf,CAAC,0CAA0C,CAAC,iDCnB3D,6zBAaM;2FDSO,iBAAiB;kBAN7B,SAAS;+BACI,yBAAyB,aAExB,CAAC,0CAA0C,CAAC;yHAU9C,EAAE;sBAAV,KAAK;gBAEG,UAAU;sBAAlB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBAEG,GAAG;sBAAX,KAAK;gBAIF,WAAW;sBADd,KAAK;gBAaF,KAAK;sBADR,KAAK;gBAeF,QAAQ;sBADX,KAAK;gBAYO,IAAI;sBAAhB,KAAK","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>"]}
|
|
@@ -167,4 +167,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
|
|
|
167
167
|
}], value: [{
|
|
168
168
|
type: Input
|
|
169
169
|
}] } });
|
|
170
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select2.component.js","sourceRoot":"","sources":["../../../../../../projects/zek/src/lib/modules/select2/select2.component.ts","../../../../../../projects/zek/src/lib/modules/select2/select2.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnDestroy, OnInit, Output } from '@angular/core';\r\nimport { RandomHelper, StringHelper } from '../../utils';\r\n\r\n@Component({\r\n  selector: 'zek-select2,[zek-select2]',\r\n  templateUrl: './select2.component.html',\r\n  styleUrls: ['./select2.component.css']\r\n\r\n})\r\n\r\nexport class Select2Component implements OnDestroy {\r\n  filter?: string | null;\r\n  text?: string | null;\r\n\r\n  readonly elementId = RandomHelper.randomHex();\r\n\r\n  private _data: Array<any> = [];\r\n  @Input() get data(): Array<any> {\r\n    return this._data;\r\n  }\r\n  set data(value: Array<any>) {\r\n    if (this._data !== value) {\r\n      this._data = value;\r\n      this.findAndSetItem();\r\n      this.filterData();\r\n    }\r\n  }\r\n  filteredData: Array<any> = [];\r\n\r\n  @Input() textField: any;\r\n  @Input() valueField: any;\r\n  @Input() placeholder: string = ''\r\n\r\n  @Output() selectedItemChange = new EventEmitter<any>();\r\n  private _selectedItem: any;\r\n  get selectedItem(): any {\r\n    return this._selectedItem;\r\n  }\r\n\r\n  @Output() valueChange = new EventEmitter<any>();\r\n  private _value: any;\r\n  @Input() get value() {\r\n    return this._value;\r\n  }\r\n  set value(v: any) {\r\n    if (this._value !== v) {\r\n      this._value = v;\r\n      this.findAndSetItem();\r\n    }\r\n  }\r\n\r\n  private findAndSetItem() {\r\n    let foundItem = null;\r\n    if (this._value === undefined || this._value === null || !this.data) {\r\n\r\n    } else if (this.valueField === undefined || this.valueField === null || this.valueField === '') {\r\n      foundItem = this.data.find(x => x === this._value);\r\n    } else {\r\n      foundItem = this.data.find(x => x[this.valueField] === this._value);\r\n    }\r\n\r\n    this._selectedItem = foundItem;\r\n    this.setText();\r\n  }\r\n\r\n\r\n\r\n\r\n  // private _dropdown: any;\r\n  // public get dropdown(): any {\r\n  //     if (!this._dropdown) {\r\n  //         let el = document.getElementById('btn-' + this.elementId);\r\n  //         this._dropdown = new bootstrap.Dropdown(el);\r\n  //     }\r\n  //     return this._dropdown;\r\n  // }\r\n  // public set dropdown(v: any) {\r\n  //     this._dropdown = v;\r\n  // }\r\n\r\n  ngOnDestroy() {\r\n    // this.dropdown?.dispose();\r\n    // this.dropdown = null;\r\n  }\r\n\r\n\r\n  onTextChange(text: string) {\r\n    this.filter = StringHelper.tryTrim(text);\r\n    this.filterData();\r\n  }\r\n\r\n  private filterData() {\r\n    if (this.filter && this.filter !== '') {\r\n      let searchString = this.filter;\r\n      if (this.textField === undefined || this.textField === null) {\r\n        this.filteredData = this.data.filter(item => item.toLowerCase().indexOf(searchString.toLowerCase()) !== -1);\r\n      } else {\r\n        this.filteredData = this.data.filter(item => item[this.textField].toLowerCase().indexOf(searchString.toLowerCase()) !== -1);\r\n      }\r\n    }\r\n    else// if (this.filter === undefined || this.filter === null || this.filter === '') \r\n    {\r\n      this.filteredData = this.data;\r\n    }\r\n  }\r\n\r\n  onFocus(e: FocusEvent) {\r\n    // if (this.dropdown){\r\n    //   this.dropdown.show();\r\n    // }\r\n    // let dropdown = document.getElementById(`dropdown-menu-container-${this.elementId}`);\r\n    // console.log(dropdown);\r\n\r\n    // if (dropdown) {\r\n    //   console.log(dropdown.classList);\r\n\r\n    //   if (!dropdown.classList.contains('show')) {\r\n    //     let el = document.getElementById(`input-${this.elementId}`);\r\n    //     if (el) {\r\n    //       el.click();\r\n    //     }\r\n    //   }\r\n    // }\r\n\r\n\r\n\r\n    // let inputId = 'input-' + this.elementId;\r\n    // let el = document.getElementById(inputId);\r\n    // if (el) {\r\n\r\n    //   if (!el.classList.contains('show')) {\r\n    //     this.dropdown?.show();\r\n    //   }\r\n\r\n    // let menuId = '#dropdown-menu-' + this.elementId + ' ' + 'a';\r\n    // el.addEventListener('keydown', function (e) {\r\n    //   if (e.key == 'ArrowDown') {\r\n    //     (document.querySelectorAll(menuId)[0] as any).focus();\r\n    //   }\r\n    // });\r\n    // }\r\n  }\r\n  inputUnfocused() {\r\n    // this.expanded = false;\r\n  }\r\n\r\n  private setText() {\r\n    if (this._selectedItem === undefined || this._selectedItem === null) {\r\n      this.text = null;\r\n    }\r\n    else if (this.textField === undefined || this.textField === null) {\r\n      this.text = this._selectedItem;\r\n    } else {\r\n      this.text = this._selectedItem[this.textField];\r\n    }\r\n  }\r\n\r\n  selectItem(item: any) {\r\n\r\n    if (this._selectedItem !== item) {\r\n      this._selectedItem = item;\r\n      this.selectedItemChange.emit(item);\r\n\r\n      this.setText();\r\n\r\n      //set value\r\n      let v;\r\n      if (this.valueField === undefined || this.valueField === null || this.valueField === '') {\r\n        // this.value = v\r\n        v = item;\r\n      } else {\r\n        // this.value = v[this.valueField];\r\n        v = item[this.valueField];\r\n      }\r\n\r\n      //if value not equals then emit valueChange\r\n      if (this._value !== v) {\r\n        this._value = v;\r\n        this.valueChange.emit(v);\r\n      }\r\n    }\r\n  }\r\n\r\n\r\n}\r\n","<div class=\"input-group position-relative\" id=\"dropdown-menu-container-{{elementId}}\">\r\n  <input type=\"text\" class=\"form-control\" placeholder=\"{{placeholder}}\" data-bs-toggle=\"dropdown\" id=\"input-{{elementId}}\" [(ngModel)]=\"text\" (ngModelChange)=\"onTextChange($event)\" (focus)=\"onFocus($event)\" (blur)=\"inputUnfocused()\">\r\n  <button class=\"btn btn-outline-secondary dropdown-toggle\" id=\"btn-{{elementId}}\" type=\"button\" data-bs-toggle=\"dropdown\" aria-expanded=\"false\" data-bs-reference=\"parent\"></button>\r\n  <ul class=\"dropdown-menu dropdown-menu-start w-100 scrollable-menu\" id=\"dropdown-menu-{{elementId}}\">\r\n    <ng-container *ngIf=\"textField\">\r\n      <li *ngFor=\"let entry of filteredData\">\r\n        <a href=\"javascript:void(0)\" (click)=\"selectItem(entry)\" class=\"dropdown-item\">{{entry[textField]}}</a>\r\n      </li>\r\n    </ng-container>\r\n    <ng-container *ngIf=\"!textField\">\r\n      <li *ngFor=\"let entry of filteredData\">\r\n        <a href=\"javascript:void(0)\" (click)=\"selectItem(entry)\" class=\"dropdown-item\">{{textField}}</a>\r\n      </li>\r\n    </ng-container>\r\n  </ul>\r\n</div>\r\n<!-- <kendo-autocomplete\r\n  [data]=\"data\"\r\n  [filterable]=\"true\"\r\n  (valueChange)=\"valueChange($event)\"\r\n  (filterChange)=\"filterChange($event)\"\r\n  (open)=\"open()\"\r\n  (close)=\"close()\"\r\n  (focus)=\"focus()\"\r\n  (blur)=\"blur()\">\r\n</kendo-autocomplete> -->"]}
|
|
170
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select2.component.js","sourceRoot":"","sources":["../../../../../../projects/zek/src/lib/modules/select2/select2.component.ts","../../../../../../projects/zek/src/lib/modules/select2/select2.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnDestroy, OnInit, Output } from '@angular/core';\r\nimport { RandomHelper, StringHelper } from '../../utils';\r\n\r\n@Component({\r\n    selector: 'zek-select2,[zek-select2]',\r\n    templateUrl: './select2.component.html',\r\n    styleUrls: ['./select2.component.css']\r\n\r\n})\r\n\r\nexport class Select2Component implements OnDestroy {\r\n    filter?: string | null;\r\n    text?: string | null;\r\n\r\n    readonly elementId = RandomHelper.randomHex();\r\n\r\n    private _data: Array<any> = [];\r\n    @Input()\r\n    get data(): Array<any> {\r\n        return this._data;\r\n    }\r\n    set data(value: Array<any>) {\r\n        if (this._data !== value) {\r\n            this._data = value;\r\n            this.findAndSetItem();\r\n            this.filterData();\r\n        }\r\n    }\r\n    filteredData: Array<any> = [];\r\n\r\n    @Input() textField: any;\r\n    @Input() valueField: any;\r\n    @Input() placeholder: string = ''\r\n\r\n    @Output() selectedItemChange = new EventEmitter<any>();\r\n    private _selectedItem: any;\r\n    get selectedItem(): any {\r\n        return this._selectedItem;\r\n    }\r\n\r\n    @Output() valueChange = new EventEmitter<any>();\r\n    private _value: any;\r\n    @Input()\r\n    get value() {\r\n        return this._value;\r\n    }\r\n    set value(v: any) {\r\n        if (this._value !== v) {\r\n            this._value = v;\r\n            this.findAndSetItem();\r\n        }\r\n    }\r\n\r\n    private findAndSetItem() {\r\n        let foundItem = null;\r\n        if (this._value === undefined || this._value === null || !this.data) {\r\n\r\n        } else if (this.valueField === undefined || this.valueField === null || this.valueField === '') {\r\n            foundItem = this.data.find(x => x === this._value);\r\n        } else {\r\n            foundItem = this.data.find(x => x[this.valueField] === this._value);\r\n        }\r\n\r\n        this._selectedItem = foundItem;\r\n        this.setText();\r\n    }\r\n\r\n\r\n\r\n\r\n    // private _dropdown: any;\r\n    // public get dropdown(): any {\r\n    //     if (!this._dropdown) {\r\n    //         let el = document.getElementById('btn-' + this.elementId);\r\n    //         this._dropdown = new bootstrap.Dropdown(el);\r\n    //     }\r\n    //     return this._dropdown;\r\n    // }\r\n    // public set dropdown(v: any) {\r\n    //     this._dropdown = v;\r\n    // }\r\n\r\n    ngOnDestroy() {\r\n        // this.dropdown?.dispose();\r\n        // this.dropdown = null;\r\n    }\r\n\r\n\r\n    onTextChange(text: string) {\r\n        this.filter = StringHelper.tryTrim(text);\r\n        this.filterData();\r\n    }\r\n\r\n    private filterData() {\r\n        if (this.filter && this.filter !== '') {\r\n            let searchString = this.filter;\r\n            if (this.textField === undefined || this.textField === null) {\r\n                this.filteredData = this.data.filter(item => item.toLowerCase().indexOf(searchString.toLowerCase()) !== -1);\r\n            } else {\r\n                this.filteredData = this.data.filter(item => item[this.textField].toLowerCase().indexOf(searchString.toLowerCase()) !== -1);\r\n            }\r\n        }\r\n        else// if (this.filter === undefined || this.filter === null || this.filter === '') \r\n        {\r\n            this.filteredData = this.data;\r\n        }\r\n    }\r\n\r\n    onFocus(e: FocusEvent) {\r\n        // if (this.dropdown){\r\n        //   this.dropdown.show();\r\n        // }\r\n        // let dropdown = document.getElementById(`dropdown-menu-container-${this.elementId}`);\r\n        // console.log(dropdown);\r\n\r\n        // if (dropdown) {\r\n        //   console.log(dropdown.classList);\r\n\r\n        //   if (!dropdown.classList.contains('show')) {\r\n        //     let el = document.getElementById(`input-${this.elementId}`);\r\n        //     if (el) {\r\n        //       el.click();\r\n        //     }\r\n        //   }\r\n        // }\r\n\r\n\r\n\r\n        // let inputId = 'input-' + this.elementId;\r\n        // let el = document.getElementById(inputId);\r\n        // if (el) {\r\n\r\n        //   if (!el.classList.contains('show')) {\r\n        //     this.dropdown?.show();\r\n        //   }\r\n\r\n        // let menuId = '#dropdown-menu-' + this.elementId + ' ' + 'a';\r\n        // el.addEventListener('keydown', function (e) {\r\n        //   if (e.key == 'ArrowDown') {\r\n        //     (document.querySelectorAll(menuId)[0] as any).focus();\r\n        //   }\r\n        // });\r\n        // }\r\n    }\r\n    inputUnfocused() {\r\n        // this.expanded = false;\r\n    }\r\n\r\n    private setText() {\r\n        if (this._selectedItem === undefined || this._selectedItem === null) {\r\n            this.text = null;\r\n        }\r\n        else if (this.textField === undefined || this.textField === null) {\r\n            this.text = this._selectedItem;\r\n        } else {\r\n            this.text = this._selectedItem[this.textField];\r\n        }\r\n    }\r\n\r\n    selectItem(item: any) {\r\n\r\n        if (this._selectedItem !== item) {\r\n            this._selectedItem = item;\r\n            this.selectedItemChange.emit(item);\r\n\r\n            this.setText();\r\n\r\n            //set value\r\n            let v;\r\n            if (this.valueField === undefined || this.valueField === null || this.valueField === '') {\r\n                // this.value = v\r\n                v = item;\r\n            } else {\r\n                // this.value = v[this.valueField];\r\n                v = item[this.valueField];\r\n            }\r\n\r\n            //if value not equals then emit valueChange\r\n            if (this._value !== v) {\r\n                this._value = v;\r\n                this.valueChange.emit(v);\r\n            }\r\n        }\r\n    }\r\n\r\n\r\n}\r\n","<div class=\"input-group position-relative\" id=\"dropdown-menu-container-{{elementId}}\">\r\n  <input type=\"text\" class=\"form-control\" placeholder=\"{{placeholder}}\" data-bs-toggle=\"dropdown\" id=\"input-{{elementId}}\" [(ngModel)]=\"text\" (ngModelChange)=\"onTextChange($event)\" (focus)=\"onFocus($event)\" (blur)=\"inputUnfocused()\">\r\n  <button class=\"btn btn-outline-secondary dropdown-toggle\" id=\"btn-{{elementId}}\" type=\"button\" data-bs-toggle=\"dropdown\" aria-expanded=\"false\" data-bs-reference=\"parent\"></button>\r\n  <ul class=\"dropdown-menu dropdown-menu-start w-100 scrollable-menu\" id=\"dropdown-menu-{{elementId}}\">\r\n    <ng-container *ngIf=\"textField\">\r\n      <li *ngFor=\"let entry of filteredData\">\r\n        <a href=\"javascript:void(0)\" (click)=\"selectItem(entry)\" class=\"dropdown-item\">{{entry[textField]}}</a>\r\n      </li>\r\n    </ng-container>\r\n    <ng-container *ngIf=\"!textField\">\r\n      <li *ngFor=\"let entry of filteredData\">\r\n        <a href=\"javascript:void(0)\" (click)=\"selectItem(entry)\" class=\"dropdown-item\">{{textField}}</a>\r\n      </li>\r\n    </ng-container>\r\n  </ul>\r\n</div>\r\n<!-- <kendo-autocomplete\r\n  [data]=\"data\"\r\n  [filterable]=\"true\"\r\n  (valueChange)=\"valueChange($event)\"\r\n  (filterChange)=\"filterChange($event)\"\r\n  (open)=\"open()\"\r\n  (close)=\"close()\"\r\n  (focus)=\"focus()\"\r\n  (blur)=\"blur()\">\r\n</kendo-autocomplete> -->"]}
|
|
@@ -129,4 +129,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
|
|
|
129
129
|
}], value: [{
|
|
130
130
|
type: Input
|
|
131
131
|
}] } });
|
|
132
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select2-multiple.component.js","sourceRoot":"","sources":["../../../../../../projects/zek/src/lib/modules/select2-multiple/select2-multiple.component.ts","../../../../../../projects/zek/src/lib/modules/select2-multiple/select2-multiple.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnDestroy, OnInit, Output } from '@angular/core';\r\nimport { RandomHelper, StringHelper } from '../../utils';\r\n//declare let bootstrap: any;\r\n\r\n\r\n@Component({\r\n  selector: 'zek-select2-multiple,[zek-select2-multiple]',\r\n  templateUrl: './select2-multiple.component.html'\r\n})\r\n\r\nexport class Select2MultipleComponent {\r\n  filter?: string | null;\r\n  text?: string | null;\r\n\r\n  readonly elementId = RandomHelper.randomHex();\r\n\r\n  private _data: Array<any> = [];\r\n  @Input() get data(): Array<any> {\r\n    return this._data;\r\n  }\r\n  set data(value: Array<any>) {\r\n    if (this._data !== value) {\r\n      this._data = value;\r\n      this.findAndSetItems();\r\n      this.filterData();\r\n    }\r\n  }\r\n  filteredData: Array<any> = [];\r\n\r\n  @Input() textField: any;\r\n  @Input() valueField: any;\r\n  @Input() placeholder: string = ''\r\n\r\n  @Output() selectedItemChange = new EventEmitter<any>();\r\n  private _selectedItems: Array<any> = [];\r\n  get selectedItems(): Array<any> {\r\n    return this._selectedItems;\r\n  }\r\n\r\n  @Output() valueChange = new EventEmitter<any>();\r\n  private _value?: Array<any> | null;\r\n  @Input() get value() {\r\n    return this._value;\r\n  }\r\n  set value(v: any) {\r\n    if (this._value !== v) {\r\n      this._value = v;\r\n      this.findAndSetItems();\r\n    }\r\n  }\r\n\r\n  private findAndSetItems() {\r\n    this._data?.forEach(x => x.selected = false);\r\n    this._selectedItems = [];\r\n    let foundItems: Array<any> = [];\r\n    if (this._value === undefined || this._value === null || !this.data) {\r\n\r\n    } else if (this.valueField === undefined || this.valueField === null || this.valueField === '') {\r\n      foundItems = this.data.filter(x => this._value?.includes(x));\r\n    } else {\r\n      foundItems = this.data.filter(x => this._value?.includes(x[this.valueField]));\r\n    }\r\n    \r\n    if (foundItems.length > 0) {\r\n      foundItems.forEach(x => x.selected = true);\r\n      this._selectedItems = foundItems;\r\n    }\r\n    this.setText();\r\n  }\r\n\r\n\r\n\r\n  onTextChange(text: string) {\r\n    this.filter = StringHelper.tryTrim(text);\r\n    this.filterData();\r\n  }\r\n\r\n  private filterData() {\r\n    if (this.filter && this.filter !== '') {\r\n      let searchString = this.filter;\r\n      if (this.textField === undefined || this.textField === null) {\r\n        this.filteredData = this.data.filter(item => item.toLowerCase().indexOf(searchString.toLowerCase()) !== -1);\r\n      } else {\r\n        this.filteredData = this.data.filter(item => item[this.textField].toLowerCase().indexOf(searchString.toLowerCase()) !== -1);\r\n      }\r\n    }\r\n    else {\r\n      this.filteredData = this.data;\r\n    }\r\n  }\r\n\r\n  onFocus(e: FocusEvent) {\r\n    this.filter = '';\r\n    this.text = '';\r\n    this.filterData();\r\n  }\r\n  inputUnfocused() {\r\n    this.setText();\r\n  }\r\n\r\n  private setText() {\r\n    if (this.textField === undefined || this.textField === null) {\r\n      this.text = this._selectedItems.join(', ');\r\n    } else {\r\n      this.text = this._selectedItems.map(x => x[this.textField]).join(', ');\r\n    }\r\n  }\r\n\r\n  selectItem(item: any) {\r\n    item.selected = !item.selected;\r\n\r\n    if (item.selected) {\r\n      this._selectedItems.push(item);\r\n    } else {\r\n      this._selectedItems = this._selectedItems.filter(x => x !== item);\r\n    }\r\n\r\n    this.selectedItemChange.emit(item);\r\n    this.setText();\r\n\r\n    let v: Array<any> | null;\r\n    if (this.valueField === undefined || this.valueField === null || this.valueField === '') {\r\n      v = this._selectedItems ? this._selectedItems : null;\r\n    } else {\r\n      v = this._selectedItems ? this._selectedItems.map(x => x[this.valueField]) : null;\r\n    }\r\n\r\n    this._value = v;\r\n    this.valueChange.emit(v);\r\n  }\r\n\r\n\r\n}\r\n","<div class=\"input-group position-relative\" id=\"dropdown-menu-container-{{elementId}}\">\r\n  <input type=\"text\" class=\"form-control\" placeholder=\"{{placeholder}}\" data-bs-toggle=\"dropdown\" data-bs-auto-close=\"outside\" id=\"input-{{elementId}}\" [(ngModel)]=\"text\" (ngModelChange)=\"onTextChange($event)\" (focus)=\"onFocus($event)\" (blur)=\"inputUnfocused()\">\r\n  <button class=\"btn btn-outline-secondary dropdown-toggle\" id=\"btn-{{elementId}}\" type=\"button\" data-bs-toggle=\"dropdown\" aria-expanded=\"false\" data-bs-reference=\"parent\"></button>\r\n  <ul class=\"dropdown-menu dropdown-menu-start w-100 scrollable-menu\" id=\"dropdown-menu-{{elementId}}\">\r\n    <ng-container *ngIf=\"textField\">\r\n      <li *ngFor=\"let item of filteredData\">\r\n        <a href=\"javascript:void(0)\" (click)=\"selectItem(item)\" class=\"dropdown-item\">\r\n          <span *ngIf=\"item.selected\"><i class=\"far fa-check-square\"></i></span>\r\n          <span *ngIf=\"!item.selected\"><i class=\"far fa-square\"></i></span>\r\n          {{item[textField]}}\r\n        </a>\r\n      </li>\r\n    </ng-container>\r\n    <ng-container *ngIf=\"!textField\">\r\n      <li *ngFor=\"let item of filteredData\">\r\n        <a href=\"javascript:void(0)\" (click)=\"selectItem(item)\" class=\"dropdown-item\">\r\n          <span *ngIf=\"item.selected\"><i class=\"far fa-check-square\"></i></span>\r\n          <span *ngIf=\"!item.selected\"><i class=\"far fa-square\"></i></span>\r\n          {{item}}\r\n        </a>\r\n      </li>\r\n    </ng-container>\r\n  </ul>\r\n</div>"]}
|
|
132
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select2-multiple.component.js","sourceRoot":"","sources":["../../../../../../projects/zek/src/lib/modules/select2-multiple/select2-multiple.component.ts","../../../../../../projects/zek/src/lib/modules/select2-multiple/select2-multiple.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnDestroy, OnInit, Output } from '@angular/core';\r\nimport { RandomHelper, StringHelper } from '../../utils';\r\n//declare let bootstrap: any;\r\n\r\n\r\n@Component({\r\n    selector: 'zek-select2-multiple,[zek-select2-multiple]',\r\n    templateUrl: './select2-multiple.component.html'\r\n})\r\n\r\nexport class Select2MultipleComponent {\r\n    filter?: string | null;\r\n    text?: string | null;\r\n\r\n    readonly elementId = RandomHelper.randomHex();\r\n\r\n    private _data: Array<any> = [];\r\n    @Input()\r\n    get data(): Array<any> {\r\n        return this._data;\r\n    }\r\n    set data(value: Array<any>) {\r\n        if (this._data !== value) {\r\n            this._data = value;\r\n            this.findAndSetItems();\r\n            this.filterData();\r\n        }\r\n    }\r\n    filteredData: Array<any> = [];\r\n\r\n    @Input() textField: any;\r\n    @Input() valueField: any;\r\n    @Input() placeholder: string = ''\r\n\r\n    @Output() selectedItemChange = new EventEmitter<any>();\r\n    private _selectedItems: Array<any> = [];\r\n    get selectedItems(): Array<any> {\r\n        return this._selectedItems;\r\n    }\r\n\r\n    @Output() valueChange = new EventEmitter<any>();\r\n    private _value?: Array<any> | null;\r\n    @Input()\r\n    get value() {\r\n        return this._value;\r\n    }\r\n    set value(v: any) {\r\n        if (this._value !== v) {\r\n            this._value = v;\r\n            this.findAndSetItems();\r\n        }\r\n    }\r\n\r\n    private findAndSetItems() {\r\n        this._data?.forEach(x => x.selected = false);\r\n        this._selectedItems = [];\r\n        let foundItems: Array<any> = [];\r\n        if (this._value === undefined || this._value === null || !this.data) {\r\n\r\n        } else if (this.valueField === undefined || this.valueField === null || this.valueField === '') {\r\n            foundItems = this.data.filter(x => this._value?.includes(x));\r\n        } else {\r\n            foundItems = this.data.filter(x => this._value?.includes(x[this.valueField]));\r\n        }\r\n\r\n        if (foundItems.length > 0) {\r\n            foundItems.forEach(x => x.selected = true);\r\n            this._selectedItems = foundItems;\r\n        }\r\n        this.setText();\r\n    }\r\n\r\n\r\n\r\n    onTextChange(text: string) {\r\n        this.filter = StringHelper.tryTrim(text);\r\n        this.filterData();\r\n    }\r\n\r\n    private filterData() {\r\n        if (this.filter && this.filter !== '') {\r\n            let searchString = this.filter;\r\n            if (this.textField === undefined || this.textField === null) {\r\n                this.filteredData = this.data.filter(item => item.toLowerCase().indexOf(searchString.toLowerCase()) !== -1);\r\n            } else {\r\n                this.filteredData = this.data.filter(item => item[this.textField].toLowerCase().indexOf(searchString.toLowerCase()) !== -1);\r\n            }\r\n        }\r\n        else {\r\n            this.filteredData = this.data;\r\n        }\r\n    }\r\n\r\n    onFocus(e: FocusEvent) {\r\n        this.filter = '';\r\n        this.text = '';\r\n        this.filterData();\r\n    }\r\n    inputUnfocused() {\r\n        this.setText();\r\n    }\r\n\r\n    private setText() {\r\n        if (this.textField === undefined || this.textField === null) {\r\n            this.text = this._selectedItems.join(', ');\r\n        } else {\r\n            this.text = this._selectedItems.map(x => x[this.textField]).join(', ');\r\n        }\r\n    }\r\n\r\n    selectItem(item: any) {\r\n        item.selected = !item.selected;\r\n\r\n        if (item.selected) {\r\n            this._selectedItems.push(item);\r\n        } else {\r\n            this._selectedItems = this._selectedItems.filter(x => x !== item);\r\n        }\r\n\r\n        this.selectedItemChange.emit(item);\r\n        this.setText();\r\n\r\n        let v: Array<any> | null;\r\n        if (this.valueField === undefined || this.valueField === null || this.valueField === '') {\r\n            v = this._selectedItems ? this._selectedItems : null;\r\n        } else {\r\n            v = this._selectedItems ? this._selectedItems.map(x => x[this.valueField]) : null;\r\n        }\r\n\r\n        this._value = v;\r\n        this.valueChange.emit(v);\r\n    }\r\n\r\n\r\n}\r\n","<div class=\"input-group position-relative\" id=\"dropdown-menu-container-{{elementId}}\">\r\n  <input type=\"text\" class=\"form-control\" placeholder=\"{{placeholder}}\" data-bs-toggle=\"dropdown\" data-bs-auto-close=\"outside\" id=\"input-{{elementId}}\" [(ngModel)]=\"text\" (ngModelChange)=\"onTextChange($event)\" (focus)=\"onFocus($event)\" (blur)=\"inputUnfocused()\">\r\n  <button class=\"btn btn-outline-secondary dropdown-toggle\" id=\"btn-{{elementId}}\" type=\"button\" data-bs-toggle=\"dropdown\" aria-expanded=\"false\" data-bs-reference=\"parent\"></button>\r\n  <ul class=\"dropdown-menu dropdown-menu-start w-100 scrollable-menu\" id=\"dropdown-menu-{{elementId}}\">\r\n    <ng-container *ngIf=\"textField\">\r\n      <li *ngFor=\"let item of filteredData\">\r\n        <a href=\"javascript:void(0)\" (click)=\"selectItem(item)\" class=\"dropdown-item\">\r\n          <span *ngIf=\"item.selected\"><i class=\"far fa-check-square\"></i></span>\r\n          <span *ngIf=\"!item.selected\"><i class=\"far fa-square\"></i></span>\r\n          {{item[textField]}}\r\n        </a>\r\n      </li>\r\n    </ng-container>\r\n    <ng-container *ngIf=\"!textField\">\r\n      <li *ngFor=\"let item of filteredData\">\r\n        <a href=\"javascript:void(0)\" (click)=\"selectItem(item)\" class=\"dropdown-item\">\r\n          <span *ngIf=\"item.selected\"><i class=\"far fa-check-square\"></i></span>\r\n          <span *ngIf=\"!item.selected\"><i class=\"far fa-square\"></i></span>\r\n          {{item}}\r\n        </a>\r\n      </li>\r\n    </ng-container>\r\n  </ul>\r\n</div>"]}
|
|
@@ -62,4 +62,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
|
|
|
62
62
|
}], step: [{
|
|
63
63
|
type: Input
|
|
64
64
|
}] } });
|
|
65
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
65
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2l6YXJkLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3play9zcmMvbGliL21vZHVsZXMvd2l6YXJkL3dpemFyZC93aXphcmQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvemVrL3NyYy9saWIvbW9kdWxlcy93aXphcmQvd2l6YXJkL3dpemFyZC5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQzs7OztBQU1qRCxNQUFNLE9BQU8sZUFBZTtJQUo1QjtRQU1JLGFBQVEsR0FBRyxDQUFDLENBQUM7UUFDYixlQUFVLEdBQXlDO1lBQy9DLEVBQUUsSUFBSSxFQUFFLENBQUMsRUFBRSxRQUFRLEVBQUUsQ0FBQyxFQUFFO1NBQzNCLENBQUM7UUFFTSxXQUFNLEdBQVcsQ0FBQyxDQUFDO1FBZW5CLFVBQUssR0FBVyxDQUFDLENBQUM7S0FtQzdCO0lBakRHLElBQ0ksS0FBSztRQUNMLE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQztJQUN2QixDQUFDO0lBQ0QsSUFBSSxLQUFLLENBQUMsQ0FBUztRQUNmLElBQUksQ0FBQyxHQUFHLENBQUM7WUFBRSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBRWpCLElBQUksSUFBSSxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUU7WUFDbkIsSUFBSSxDQUFDLE1BQU0sR0FBRyxDQUFDLENBQUM7WUFDaEIsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO1NBQ2Y7SUFDTCxDQUFDO0lBSUQsSUFDSSxJQUFJO1FBQ0osT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDO0lBQ3RCLENBQUM7SUFDRCxJQUFJLElBQUksQ0FBQyxDQUFTO1FBQ2QsSUFBSSxDQUFDLEdBQUcsQ0FBQztZQUFFLENBQUMsR0FBRyxDQUFDLENBQUM7YUFDWixJQUFJLENBQUMsR0FBRyxJQUFJLENBQUMsS0FBSztZQUFFLENBQUMsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDO1FBRXhDLElBQUksSUFBSSxDQUFDLEtBQUssS0FBSyxDQUFDLEVBQUU7WUFDbEIsSUFBSSxDQUFDLEtBQUssR0FBRyxDQUFDLENBQUM7WUFFZixJQUFJLEtBQUssR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxJQUFJLEtBQUssSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQzdELElBQUksS0FBSyxFQUFFO2dCQUNQLElBQUksQ0FBQyxRQUFRLEdBQUcsS0FBSyxDQUFDLFFBQVEsQ0FBQzthQUNsQztTQUNKO0lBQ0wsQ0FBQztJQUdPLElBQUk7UUFDUixJQUFJLENBQUMsVUFBVSxHQUFHLEVBQUUsQ0FBQztRQUNyQixJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxFQUFFLElBQUksRUFBRSxDQUFDLEVBQUUsUUFBUSxFQUFFLENBQUMsRUFBRSxDQUFDLENBQUM7UUFFL0MsS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQyxFQUFFLEVBQUU7WUFDakMsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsRUFBRSxJQUFJLEVBQUUsQ0FBQyxHQUFHLENBQUMsRUFBRSxRQUFRLEVBQUUsSUFBSSxDQUFDLEtBQUssQ0FBQyxHQUFHLEdBQUcsQ0FBQyxJQUFJLENBQUMsS0FBSyxHQUFHLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQztTQUMzRjtJQUNMLENBQUM7SUFFRCxRQUFRO1FBQ0osSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO0lBQ2hCLENBQUM7SUFDRCxJQUFJO1FBQ0EsSUFBSSxDQUFDLElBQUksRUFBRSxDQUFDO0lBQ2hCLENBQUM7OzRHQXhEUSxlQUFlO2dHQUFmLGVBQWUsNEZDTjVCLDZuQkFPTTsyRkRETyxlQUFlO2tCQUozQixTQUFTOytCQUNJLFlBQVk7OEJBWWxCLEtBQUs7c0JBRFIsS0FBSztnQkFnQkYsSUFBSTtzQkFEUCxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICAgIHNlbGVjdG9yOiAnemVrLXdpemFyZCcsXHJcbiAgICB0ZW1wbGF0ZVVybDogJy4vd2l6YXJkLmNvbXBvbmVudC5odG1sJ1xyXG59KVxyXG5leHBvcnQgY2xhc3MgV2l6YXJkQ29tcG9uZW50IHtcclxuXHJcbiAgICBwcm9ncmVzcyA9IDA7XHJcbiAgICBzdGVwc0FycmF5OiB7IHN0ZXA6IG51bWJlciwgcHJvZ3Jlc3M6IG51bWJlciB9W10gPSBbXHJcbiAgICAgICAgeyBzdGVwOiAxLCBwcm9ncmVzczogMCB9XHJcbiAgICBdO1xyXG5cclxuICAgIHByaXZhdGUgX3N0ZXBzOiBudW1iZXIgPSAxO1xyXG4gICAgQElucHV0KClcclxuICAgIGdldCBzdGVwcygpOiBudW1iZXIge1xyXG4gICAgICAgIHJldHVybiB0aGlzLl9zdGVwcztcclxuICAgIH1cclxuICAgIHNldCBzdGVwcyh2OiBudW1iZXIpIHtcclxuICAgICAgICBpZiAodiA8IDEpIHYgPSAxO1xyXG5cclxuICAgICAgICBpZiAodGhpcy5fc3RlcHMgIT09IHYpIHtcclxuICAgICAgICAgICAgdGhpcy5fc3RlcHMgPSB2O1xyXG4gICAgICAgICAgICB0aGlzLmluaXQoKTtcclxuICAgICAgICB9XHJcbiAgICB9XHJcblxyXG5cclxuICAgIHByaXZhdGUgX3N0ZXA6IG51bWJlciA9IDE7XHJcbiAgICBASW5wdXQoKVxyXG4gICAgZ2V0IHN0ZXAoKTogbnVtYmVyIHtcclxuICAgICAgICByZXR1cm4gdGhpcy5fc3RlcDtcclxuICAgIH1cclxuICAgIHNldCBzdGVwKHY6IG51bWJlcikge1xyXG4gICAgICAgIGlmICh2IDwgMSkgdiA9IDE7XHJcbiAgICAgICAgZWxzZSBpZiAodiA+IHRoaXMuc3RlcHMpIHYgPSB0aGlzLnN0ZXBzO1xyXG5cclxuICAgICAgICBpZiAodGhpcy5fc3RlcCAhPT0gdikge1xyXG4gICAgICAgICAgICB0aGlzLl9zdGVwID0gdjtcclxuXHJcbiAgICAgICAgICAgIGxldCBmb3VuZCA9IHRoaXMuc3RlcHNBcnJheS5maW5kKHggPT4geC5zdGVwID09PSB0aGlzLl9zdGVwKTtcclxuICAgICAgICAgICAgaWYgKGZvdW5kKSB7XHJcbiAgICAgICAgICAgICAgICB0aGlzLnByb2dyZXNzID0gZm91bmQucHJvZ3Jlc3M7XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICB9XHJcbiAgICB9XHJcblxyXG5cclxuICAgIHByaXZhdGUgaW5pdCgpIHtcclxuICAgICAgICB0aGlzLnN0ZXBzQXJyYXkgPSBbXTtcclxuICAgICAgICB0aGlzLnN0ZXBzQXJyYXkucHVzaCh7IHN0ZXA6IDEsIHByb2dyZXNzOiAwIH0pO1xyXG5cclxuICAgICAgICBmb3IgKGxldCBpID0gMTsgaSA8IHRoaXMuc3RlcHM7IGkrKykge1xyXG4gICAgICAgICAgICB0aGlzLnN0ZXBzQXJyYXkucHVzaCh7IHN0ZXA6IGkgKyAxLCBwcm9ncmVzczogTWF0aC5yb3VuZCgxMDAgLyAodGhpcy5zdGVwcyAtIDEpICogaSkgfSk7XHJcbiAgICAgICAgfVxyXG4gICAgfVxyXG5cclxuICAgIHByZXZpb3VzKCkge1xyXG4gICAgICAgIHRoaXMuc3RlcC0tO1xyXG4gICAgfVxyXG4gICAgbmV4dCgpIHtcclxuICAgICAgICB0aGlzLnN0ZXArKztcclxuICAgIH1cclxufSIsIjxkaXYgY2xhc3M9XCJwb3NpdGlvbi1yZWxhdGl2ZSBtLTRcIj5cclxuICA8ZGl2IGNsYXNzPVwicHJvZ3Jlc3NcIiBzdHlsZT1cImhlaWdodDogMXB4O1wiPlxyXG4gICAgPGRpdiBjbGFzcz1cInByb2dyZXNzLWJhclwiIHJvbGU9XCJwcm9ncmVzc2JhclwiIFtzdHlsZS53aWR0aC4lXT1cInByb2dyZXNzXCIgW2F0dHIuYXJpYS12YWx1ZW5vd109XCJwcm9ncmVzc1wiIGFyaWEtdmFsdWVtaW49XCIwXCIgYXJpYS12YWx1ZW1heD1cIjEwMFwiPjwvZGl2PlxyXG4gIDwvZGl2PlxyXG4gIDwhLS0gbGVmdDogMzMlIWltcG9ydGFudCAtLT5cclxuICA8IS0tIFtzdHlsZS5sZWZ0LiVdPVwiaXRlbS5wcm9ncmVzc1wiIC0tPlxyXG4gIDxidXR0b24gKm5nRm9yPVwibGV0IGl0ZW0gb2Ygc3RlcHNBcnJheVwiIFthdHRyLnN0eWxlXT1cIignd2lkdGg6MnJlbTsgaGVpZ2h0OjJyZW07IGxlZnQ6JyArIGl0ZW0ucHJvZ3Jlc3MgKyAnJSFpbXBvcnRhbnQnKSB8IHNhZmU6J3N0eWxlJ1wiIHR5cGU9XCJidXR0b25cIiBjbGFzcz1cInBvc2l0aW9uLWFic29sdXRlIHRvcC0wIHRyYW5zbGF0ZS1taWRkbGUgYnRuIGJ0bi1zbSBidG4tcHJpbWFyeSByb3VuZGVkLXBpbGxcIj57eyBpdGVtLnN0ZXAgfX08L2J1dHRvbj5cclxuPC9kaXY+Il19
|
|
@@ -13,5 +13,11 @@ export class Convert {
|
|
|
13
13
|
}
|
|
14
14
|
return false;
|
|
15
15
|
}
|
|
16
|
+
static toNumber(value) {
|
|
17
|
+
if (typeof value !== 'undefined' && value !== null && value !== '') {
|
|
18
|
+
return +value;
|
|
19
|
+
}
|
|
20
|
+
return 0;
|
|
21
|
+
}
|
|
16
22
|
}
|
|
17
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
23
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udmVydC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3play9zcmMvbGliL3V0aWxzL2NvbnZlcnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxPQUFPLE9BQU87SUFDaEIsTUFBTSxDQUFDLFNBQVMsQ0FBQyxLQUFVO1FBQ3ZCLElBQUksT0FBTyxLQUFLLEtBQUssV0FBVyxJQUFJLEtBQUssS0FBSyxJQUFJLElBQUksS0FBSyxLQUFLLEVBQUUsRUFBRTtZQUNoRSxRQUFRLEdBQUcsS0FBSyxFQUFFLENBQUMsV0FBVyxFQUFFLEVBQUU7Z0JBQzlCLEtBQUssTUFBTSxDQUFDO2dCQUNaLEtBQUssS0FBSyxDQUFDO2dCQUNYLEtBQUssR0FBRyxDQUFDO2dCQUNULEtBQUssSUFBSTtvQkFDTCxPQUFPLElBQUksQ0FBQztnQkFFaEI7b0JBQ0ksT0FBTyxLQUFLLENBQUM7YUFDcEI7U0FDSjtRQUVELE9BQU8sS0FBSyxDQUFDO0lBQ2pCLENBQUM7SUFFRCxNQUFNLENBQUMsUUFBUSxDQUFDLEtBQVU7UUFDdEIsSUFBSSxPQUFPLEtBQUssS0FBSyxXQUFXLElBQUksS0FBSyxLQUFLLElBQUksSUFBSSxLQUFLLEtBQUssRUFBRSxFQUFFO1lBQ2hFLE9BQU8sQ0FBQyxLQUFLLENBQUM7U0FDakI7UUFFRCxPQUFPLENBQUMsQ0FBQztJQUNiLENBQUM7Q0FDSiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjbGFzcyBDb252ZXJ0IHtcclxuICAgIHN0YXRpYyB0b0Jvb2xlYW4odmFsdWU6IGFueSkge1xyXG4gICAgICAgIGlmICh0eXBlb2YgdmFsdWUgIT09ICd1bmRlZmluZWQnICYmIHZhbHVlICE9PSBudWxsICYmIHZhbHVlICE9PSAnJykge1xyXG4gICAgICAgICAgICBzd2l0Y2ggKGAke3ZhbHVlfWAudG9VcHBlckNhc2UoKSkge1xyXG4gICAgICAgICAgICAgICAgY2FzZSBcIlRSVUVcIjpcclxuICAgICAgICAgICAgICAgIGNhc2UgXCJZRVNcIjpcclxuICAgICAgICAgICAgICAgIGNhc2UgXCIxXCI6XHJcbiAgICAgICAgICAgICAgICBjYXNlIFwiT05cIjpcclxuICAgICAgICAgICAgICAgICAgICByZXR1cm4gdHJ1ZTtcclxuXHJcbiAgICAgICAgICAgICAgICBkZWZhdWx0OlxyXG4gICAgICAgICAgICAgICAgICAgIHJldHVybiBmYWxzZTtcclxuICAgICAgICAgICAgfVxyXG4gICAgICAgIH1cclxuXHJcbiAgICAgICAgcmV0dXJuIGZhbHNlO1xyXG4gICAgfVxyXG5cclxuICAgIHN0YXRpYyB0b051bWJlcih2YWx1ZTogYW55KXtcclxuICAgICAgICBpZiAodHlwZW9mIHZhbHVlICE9PSAndW5kZWZpbmVkJyAmJiB2YWx1ZSAhPT0gbnVsbCAmJiB2YWx1ZSAhPT0gJycpIHtcclxuICAgICAgICAgICAgcmV0dXJuICt2YWx1ZTtcclxuICAgICAgICB9XHJcblxyXG4gICAgICAgIHJldHVybiAwO1xyXG4gICAgfVxyXG59Il19
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
export class MathHelper {
|
|
2
|
-
round(value, decimals = 0) {
|
|
2
|
+
static round(value, decimals = 0) {
|
|
3
3
|
return Math.round(Number(value) * Math.pow(10, decimals)) / (Math.pow(10, decimals));
|
|
4
4
|
}
|
|
5
5
|
;
|
|
6
6
|
}
|
|
7
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWF0aC1oZWxwZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy96ZWsvc3JjL2xpYi91dGlscy9tYXRoLWhlbHBlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLE9BQU8sVUFBVTtJQUNwQixNQUFNLENBQUMsS0FBSyxDQUFDLEtBQWEsRUFBRSxXQUFtQixDQUFDO1FBQzNDLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxFQUFFLEVBQUUsUUFBUSxDQUFDLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsRUFBRSxFQUFFLFFBQVEsQ0FBQyxDQUFDLENBQUM7SUFDekYsQ0FBQztJQUFBLENBQUM7Q0FFTCIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjbGFzcyBNYXRoSGVscGVyIHtcclxuICAgc3RhdGljIHJvdW5kKHZhbHVlOiBudW1iZXIsIGRlY2ltYWxzOiBudW1iZXIgPSAwKTogbnVtYmVyIHtcclxuICAgICAgICByZXR1cm4gTWF0aC5yb3VuZChOdW1iZXIodmFsdWUpICogTWF0aC5wb3coMTAsIGRlY2ltYWxzKSkgLyAoTWF0aC5wb3coMTAsIGRlY2ltYWxzKSk7XHJcbiAgICB9O1xyXG5cclxufSJdfQ==
|