@jooler/inputs 0.0.51 → 0.0.52
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/ag-grid-select-mixin.mjs +73 -0
- package/esm2022/lib/choose-enum/choose-enum.component.mjs +57 -42
- package/esm2022/lib/choose-enum-renderer/choose-enum-renderer.component.mjs +35 -21
- package/esm2022/lib/enum-helper.model.mjs +14 -0
- package/fesm2022/inputs.mjs +153 -214
- package/fesm2022/inputs.mjs.map +1 -1
- package/lib/ag-grid-select-mixin.d.ts +22 -0
- package/lib/choose-enum/choose-enum.component.d.ts +12 -7
- package/lib/choose-enum-renderer/choose-enum-renderer.component.d.ts +7 -9
- package/lib/enum-helper.model.d.ts +8 -0
- package/package.json +1 -1
- package/esm2022/lib/custom-theme.mjs +0 -104
- package/esm2022/lib/models/enum-helper-functions.mjs +0 -57
- package/esm2022/lib/models/enum-helper.model.mjs +0 -2
- package/lib/custom-theme.d.ts +0 -8
- package/lib/models/enum-helper-functions.d.ts +0 -5
- package/lib/models/enum-helper.model.d.ts +0 -6
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
export class AgGridSelectMixin {
|
|
2
|
+
params;
|
|
3
|
+
key;
|
|
4
|
+
value;
|
|
5
|
+
rowId;
|
|
6
|
+
isEdit;
|
|
7
|
+
index;
|
|
8
|
+
arrayKey = 'entries';
|
|
9
|
+
rowLevelFG;
|
|
10
|
+
width;
|
|
11
|
+
selectedItemId;
|
|
12
|
+
agInit(params) {
|
|
13
|
+
this.initializeRenderer(params);
|
|
14
|
+
}
|
|
15
|
+
initializeRenderer(params) {
|
|
16
|
+
this.params = params;
|
|
17
|
+
this.width = params.width;
|
|
18
|
+
this.key = params.context.createKey(params.columnApi, params.column);
|
|
19
|
+
this.value = params.value;
|
|
20
|
+
this.rowId = params.node.id;
|
|
21
|
+
this.index = params.node.rowIndex;
|
|
22
|
+
if (params.context.arrayKey) {
|
|
23
|
+
this.arrayKey = params.context.arrayKey;
|
|
24
|
+
}
|
|
25
|
+
this.setRowLevelFG();
|
|
26
|
+
}
|
|
27
|
+
setRowLevelFG() {
|
|
28
|
+
this.index = this.params.node.rowIndex;
|
|
29
|
+
let tableFG = this.params.context.formGroup;
|
|
30
|
+
let fa = tableFG.get(this.arrayKey);
|
|
31
|
+
let rowLevelFG = fa.at(this.index);
|
|
32
|
+
this.rowLevelFG = rowLevelFG;
|
|
33
|
+
}
|
|
34
|
+
getFormControl() {
|
|
35
|
+
let fc = this.rowLevelFG.get(this.key);
|
|
36
|
+
return fc;
|
|
37
|
+
}
|
|
38
|
+
updateValue(params, value) {
|
|
39
|
+
this.setRowLevelFG();
|
|
40
|
+
this.getFormControl().setValue(value);
|
|
41
|
+
let rowNode = params.node;
|
|
42
|
+
rowNode.setDataValue(this.key, value);
|
|
43
|
+
}
|
|
44
|
+
// $event here is an object.
|
|
45
|
+
onSelection($event) {
|
|
46
|
+
this.selectedItemId = $event?.id;
|
|
47
|
+
this.updateValue(this.params, $event?.id);
|
|
48
|
+
if (this.params.onSelection instanceof Function) {
|
|
49
|
+
const params = {
|
|
50
|
+
object: $event,
|
|
51
|
+
rowData: this.params.node.data,
|
|
52
|
+
value: $event.id,
|
|
53
|
+
rowNode: this.params.node,
|
|
54
|
+
};
|
|
55
|
+
this.params.onSelection(params);
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
onEnumSelected($event) {
|
|
59
|
+
this.updateValue(this.params, $event);
|
|
60
|
+
if (this.params.onSelection instanceof Function) {
|
|
61
|
+
const params = {
|
|
62
|
+
rowData: this.params.node.data,
|
|
63
|
+
value: $event,
|
|
64
|
+
rowNode: this.params.node,
|
|
65
|
+
};
|
|
66
|
+
this.params.onSelection(params);
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
refresh(param) {
|
|
70
|
+
return false;
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWctZ3JpZC1zZWxlY3QtbWl4aW4uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9pbnB1dHMvc3JjL2xpYi9hZy1ncmlkLXNlbGVjdC1taXhpbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFJQSxNQUFNLE9BQU8saUJBQWlCO0lBQzVCLE1BQU0sQ0FBTTtJQUNaLEdBQUcsQ0FBUztJQUNaLEtBQUssQ0FBQztJQUNOLEtBQUssQ0FBUztJQUNkLE1BQU0sQ0FBVTtJQUNoQixLQUFLLENBQVM7SUFDZCxRQUFRLEdBQVcsU0FBUyxDQUFDO0lBQzdCLFVBQVUsQ0FBWTtJQUN0QixLQUFLLENBQVM7SUFDZCxjQUFjLENBQVM7SUFFdkIsTUFBTSxDQUFDLE1BQU07UUFDWCxJQUFJLENBQUMsa0JBQWtCLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDbEMsQ0FBQztJQUVELGtCQUFrQixDQUFDLE1BQU07UUFDdkIsSUFBSSxDQUFDLE1BQU0sR0FBRyxNQUFNLENBQUM7UUFDckIsSUFBSSxDQUFDLEtBQUssR0FBRyxNQUFNLENBQUMsS0FBSyxDQUFDO1FBQzFCLElBQUksQ0FBQyxHQUFHLEdBQUcsTUFBTSxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLFNBQVMsRUFBRSxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDckUsSUFBSSxDQUFDLEtBQUssR0FBRyxNQUFNLENBQUMsS0FBSyxDQUFDO1FBQzFCLElBQUksQ0FBQyxLQUFLLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUM7UUFDNUIsSUFBSSxDQUFDLEtBQUssR0FBRyxNQUFNLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQztRQUNsQyxJQUFJLE1BQU0sQ0FBQyxPQUFPLENBQUMsUUFBUSxFQUFFO1lBQzNCLElBQUksQ0FBQyxRQUFRLEdBQUcsTUFBTSxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUM7U0FDekM7UUFDRCxJQUFJLENBQUMsYUFBYSxFQUFFLENBQUM7SUFDdkIsQ0FBQztJQUVELGFBQWE7UUFDWCxJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQztRQUN2QyxJQUFJLE9BQU8sR0FBYyxJQUFJLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUM7UUFDdkQsSUFBSSxFQUFFLEdBQWMsT0FBTyxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFjLENBQUM7UUFDNUQsSUFBSSxVQUFVLEdBQUcsRUFBRSxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFjLENBQUM7UUFDaEQsSUFBSSxDQUFDLFVBQVUsR0FBRyxVQUFVLENBQUM7SUFDL0IsQ0FBQztJQUVELGNBQWM7UUFDWixJQUFJLEVBQUUsR0FBZ0IsSUFBSSxDQUFDLFVBQVUsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBZ0IsQ0FBQztRQUNuRSxPQUFPLEVBQUUsQ0FBQztJQUNaLENBQUM7SUFFRCxXQUFXLENBQUMsTUFBTSxFQUFFLEtBQW9CO1FBQ3RDLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQztRQUNyQixJQUFJLENBQUMsY0FBYyxFQUFFLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ3RDLElBQUksT0FBTyxHQUFZLE1BQU0sQ0FBQyxJQUFJLENBQUM7UUFDbkMsT0FBTyxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsR0FBRyxFQUFFLEtBQUssQ0FBQyxDQUFDO0lBQ3hDLENBQUM7SUFFRCw0QkFBNEI7SUFDNUIsV0FBVyxDQUFDLE1BQVc7UUFDckIsSUFBSSxDQUFDLGNBQWMsR0FBRyxNQUFNLEVBQUUsRUFBRSxDQUFDO1FBQ2pDLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxNQUFNLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFDMUMsSUFBSSxJQUFJLENBQUMsTUFBTSxDQUFDLFdBQVcsWUFBWSxRQUFRLEVBQUU7WUFDL0MsTUFBTSxNQUFNLEdBQUc7Z0JBQ2IsTUFBTSxFQUFFLE1BQU07Z0JBQ2QsT0FBTyxFQUFFLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLElBQUk7Z0JBQzlCLEtBQUssRUFBRSxNQUFNLENBQUMsRUFBRTtnQkFDaEIsT0FBTyxFQUFFLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSTthQUMxQixDQUFDO1lBQ0YsSUFBSSxDQUFDLE1BQU0sQ0FBQyxXQUFXLENBQUMsTUFBTSxDQUFDLENBQUM7U0FDakM7SUFDSCxDQUFDO0lBRUQsY0FBYyxDQUFDLE1BQWM7UUFDM0IsSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFLE1BQU0sQ0FBQyxDQUFDO1FBQ3RDLElBQUksSUFBSSxDQUFDLE1BQU0sQ0FBQyxXQUFXLFlBQVksUUFBUSxFQUFFO1lBQy9DLE1BQU0sTUFBTSxHQUFHO2dCQUNiLE9BQU8sRUFBRSxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJO2dCQUM5QixLQUFLLEVBQUUsTUFBTTtnQkFDYixPQUFPLEVBQUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJO2FBQzFCLENBQUM7WUFDRixJQUFJLENBQUMsTUFBTSxDQUFDLFdBQVcsQ0FBQyxNQUFNLENBQUMsQ0FBQztTQUNqQztJQUNILENBQUM7SUFFRCxPQUFPLENBQUMsS0FBSztRQUNYLE9BQU8sS0FBSyxDQUFDO0lBQ2YsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRm9ybUFycmF5LCBGb3JtQ29udHJvbCwgRm9ybUdyb3VwIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgSUNlbGxSZW5kZXJlckFuZ3VsYXJDb21wIH0gZnJvbSAnYWctZ3JpZC1hbmd1bGFyJztcbmltcG9ydCB7IFJvd05vZGUgfSBmcm9tICdhZy1ncmlkLWNvbW11bml0eSc7XG5cbmV4cG9ydCBjbGFzcyBBZ0dyaWRTZWxlY3RNaXhpbiBpbXBsZW1lbnRzIElDZWxsUmVuZGVyZXJBbmd1bGFyQ29tcCB7XG4gIHBhcmFtczogYW55O1xuICBrZXk6IHN0cmluZztcbiAgdmFsdWU7XG4gIHJvd0lkOiBudW1iZXI7XG4gIGlzRWRpdDogYm9vbGVhbjtcbiAgaW5kZXg6IG51bWJlcjtcbiAgYXJyYXlLZXk6IHN0cmluZyA9ICdlbnRyaWVzJztcbiAgcm93TGV2ZWxGRzogRm9ybUdyb3VwO1xuICB3aWR0aDogbnVtYmVyO1xuICBzZWxlY3RlZEl0ZW1JZDogbnVtYmVyO1xuXG4gIGFnSW5pdChwYXJhbXMpOiB2b2lkIHtcbiAgICB0aGlzLmluaXRpYWxpemVSZW5kZXJlcihwYXJhbXMpO1xuICB9XG5cbiAgaW5pdGlhbGl6ZVJlbmRlcmVyKHBhcmFtcykge1xuICAgIHRoaXMucGFyYW1zID0gcGFyYW1zO1xuICAgIHRoaXMud2lkdGggPSBwYXJhbXMud2lkdGg7XG4gICAgdGhpcy5rZXkgPSBwYXJhbXMuY29udGV4dC5jcmVhdGVLZXkocGFyYW1zLmNvbHVtbkFwaSwgcGFyYW1zLmNvbHVtbik7XG4gICAgdGhpcy52YWx1ZSA9IHBhcmFtcy52YWx1ZTtcbiAgICB0aGlzLnJvd0lkID0gcGFyYW1zLm5vZGUuaWQ7XG4gICAgdGhpcy5pbmRleCA9IHBhcmFtcy5ub2RlLnJvd0luZGV4O1xuICAgIGlmIChwYXJhbXMuY29udGV4dC5hcnJheUtleSkge1xuICAgICAgdGhpcy5hcnJheUtleSA9IHBhcmFtcy5jb250ZXh0LmFycmF5S2V5O1xuICAgIH1cbiAgICB0aGlzLnNldFJvd0xldmVsRkcoKTtcbiAgfVxuXG4gIHNldFJvd0xldmVsRkcoKSB7XG4gICAgdGhpcy5pbmRleCA9IHRoaXMucGFyYW1zLm5vZGUucm93SW5kZXg7XG4gICAgbGV0IHRhYmxlRkc6IEZvcm1Hcm91cCA9IHRoaXMucGFyYW1zLmNvbnRleHQuZm9ybUdyb3VwO1xuICAgIGxldCBmYTogRm9ybUFycmF5ID0gdGFibGVGRy5nZXQodGhpcy5hcnJheUtleSkgYXMgRm9ybUFycmF5O1xuICAgIGxldCByb3dMZXZlbEZHID0gZmEuYXQodGhpcy5pbmRleCkgYXMgRm9ybUdyb3VwO1xuICAgIHRoaXMucm93TGV2ZWxGRyA9IHJvd0xldmVsRkc7XG4gIH1cblxuICBnZXRGb3JtQ29udHJvbCgpIHtcbiAgICBsZXQgZmM6IEZvcm1Db250cm9sID0gdGhpcy5yb3dMZXZlbEZHLmdldCh0aGlzLmtleSkgYXMgRm9ybUNvbnRyb2w7XG4gICAgcmV0dXJuIGZjO1xuICB9XG5cbiAgdXBkYXRlVmFsdWUocGFyYW1zLCB2YWx1ZTogbnVtYmVyIHwgbnVsbCkge1xuICAgIHRoaXMuc2V0Um93TGV2ZWxGRygpO1xuICAgIHRoaXMuZ2V0Rm9ybUNvbnRyb2woKS5zZXRWYWx1ZSh2YWx1ZSk7XG4gICAgbGV0IHJvd05vZGU6IFJvd05vZGUgPSBwYXJhbXMubm9kZTtcbiAgICByb3dOb2RlLnNldERhdGFWYWx1ZSh0aGlzLmtleSwgdmFsdWUpO1xuICB9XG5cbiAgLy8gJGV2ZW50IGhlcmUgaXMgYW4gb2JqZWN0LlxuICBvblNlbGVjdGlvbigkZXZlbnQ6IGFueSkge1xuICAgIHRoaXMuc2VsZWN0ZWRJdGVtSWQgPSAkZXZlbnQ/LmlkO1xuICAgIHRoaXMudXBkYXRlVmFsdWUodGhpcy5wYXJhbXMsICRldmVudD8uaWQpO1xuICAgIGlmICh0aGlzLnBhcmFtcy5vblNlbGVjdGlvbiBpbnN0YW5jZW9mIEZ1bmN0aW9uKSB7XG4gICAgICBjb25zdCBwYXJhbXMgPSB7XG4gICAgICAgIG9iamVjdDogJGV2ZW50LFxuICAgICAgICByb3dEYXRhOiB0aGlzLnBhcmFtcy5ub2RlLmRhdGEsXG4gICAgICAgIHZhbHVlOiAkZXZlbnQuaWQsXG4gICAgICAgIHJvd05vZGU6IHRoaXMucGFyYW1zLm5vZGUsXG4gICAgICB9O1xuICAgICAgdGhpcy5wYXJhbXMub25TZWxlY3Rpb24ocGFyYW1zKTtcbiAgICB9XG4gIH1cblxuICBvbkVudW1TZWxlY3RlZCgkZXZlbnQ6IG51bWJlcikge1xuICAgIHRoaXMudXBkYXRlVmFsdWUodGhpcy5wYXJhbXMsICRldmVudCk7XG4gICAgaWYgKHRoaXMucGFyYW1zLm9uU2VsZWN0aW9uIGluc3RhbmNlb2YgRnVuY3Rpb24pIHtcbiAgICAgIGNvbnN0IHBhcmFtcyA9IHtcbiAgICAgICAgcm93RGF0YTogdGhpcy5wYXJhbXMubm9kZS5kYXRhLFxuICAgICAgICB2YWx1ZTogJGV2ZW50LFxuICAgICAgICByb3dOb2RlOiB0aGlzLnBhcmFtcy5ub2RlLFxuICAgICAgfTtcbiAgICAgIHRoaXMucGFyYW1zLm9uU2VsZWN0aW9uKHBhcmFtcyk7XG4gICAgfVxuICB9XG5cbiAgcmVmcmVzaChwYXJhbSk6IGJvb2xlYW4ge1xuICAgIHJldHVybiBmYWxzZTtcbiAgfVxufVxuIl19
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { Component, EventEmitter, forwardRef, Input, Output, } from '@angular/core';
|
|
2
2
|
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
|
-
import { EnumHelperBaseClass } from '
|
|
3
|
+
import { EnumHelperBaseClass } from '@jooler/shared-general-components';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
import * as i1 from "@angular/common";
|
|
6
6
|
import * as i2 from "@ng-select/ng-select";
|
|
@@ -13,13 +13,11 @@ export class ChooseEnumComponent {
|
|
|
13
13
|
clearable = true;
|
|
14
14
|
customColors;
|
|
15
15
|
enumChoices;
|
|
16
|
-
virtualScroll = false;
|
|
17
16
|
getValuesArrayFromEnum = EnumHelperBaseClass.getEnumOptionsFromEnumClass;
|
|
18
|
-
|
|
17
|
+
valuesToDisable = [];
|
|
18
|
+
valuesToHide = [];
|
|
19
19
|
isChip = true;
|
|
20
20
|
isDropdownDisabled = false;
|
|
21
|
-
isItemHidden;
|
|
22
|
-
isItemDisabled;
|
|
23
21
|
isMultiple;
|
|
24
22
|
label = 'label';
|
|
25
23
|
labelTextAlign = 'left';
|
|
@@ -30,49 +28,63 @@ export class ChooseEnumComponent {
|
|
|
30
28
|
percentWidth = false;
|
|
31
29
|
selectedItem;
|
|
32
30
|
width;
|
|
31
|
+
isReadOnly = false;
|
|
32
|
+
virtualScroll = false;
|
|
33
33
|
change = new EventEmitter();
|
|
34
34
|
close = new EventEmitter();
|
|
35
35
|
constructor() { }
|
|
36
|
-
|
|
36
|
+
ngOnInit() {
|
|
37
37
|
if (this.getValuesArrayFromEnum != null) {
|
|
38
38
|
this.items = this.getValuesArrayFromEnum(this.enumChoices, this.customColors, this.allowAllCapsValues);
|
|
39
39
|
}
|
|
40
|
-
if (this.
|
|
41
|
-
|
|
42
|
-
for (let index of this.indexesToDisable) {
|
|
43
|
-
this.items[index].disabled = true;
|
|
44
|
-
}
|
|
45
|
-
}
|
|
40
|
+
if (this.valuesToDisable.length > 0) {
|
|
41
|
+
this.disabledItems();
|
|
46
42
|
}
|
|
47
|
-
if (this.
|
|
48
|
-
|
|
49
|
-
for (let index of this.indexesToDisable) {
|
|
50
|
-
let itemIndex = this.items.findIndex((item) => item.value == index);
|
|
51
|
-
this.items.splice(itemIndex, 1);
|
|
52
|
-
}
|
|
53
|
-
}
|
|
43
|
+
if (this.valuesToHide.length > 0) {
|
|
44
|
+
this.hideItems();
|
|
54
45
|
}
|
|
46
|
+
this.sortAndReorderItems();
|
|
55
47
|
}
|
|
56
|
-
|
|
48
|
+
ngOnChanges() {
|
|
57
49
|
if (this.getValuesArrayFromEnum != null) {
|
|
58
50
|
this.items = this.getValuesArrayFromEnum(this.enumChoices, this.customColors, this.allowAllCapsValues);
|
|
59
51
|
}
|
|
60
|
-
if (this.
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
52
|
+
if (this.valuesToDisable.length > 0) {
|
|
53
|
+
this.disabledItems();
|
|
54
|
+
}
|
|
55
|
+
if (this.valuesToHide.length > 0) {
|
|
56
|
+
this.hideItems();
|
|
57
|
+
}
|
|
58
|
+
this.sortAndReorderItems();
|
|
59
|
+
}
|
|
60
|
+
disabledItems() {
|
|
61
|
+
for (let value of this.valuesToDisable) {
|
|
62
|
+
let index = this.items.findIndex(enumOption => enumOption.value == value);
|
|
63
|
+
if (index >= 0) {
|
|
64
|
+
this.items[index].disabled = true;
|
|
65
|
+
}
|
|
66
|
+
else {
|
|
67
|
+
throw Error('Index was not found for an enum element in the valuesToDisable array provided.');
|
|
65
68
|
}
|
|
66
69
|
}
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
70
|
+
}
|
|
71
|
+
hideItems() {
|
|
72
|
+
for (let value of this.valuesToHide) {
|
|
73
|
+
let index = this.items.findIndex(enumOption => enumOption.value == value);
|
|
74
|
+
if (index >= 0) {
|
|
75
|
+
this.items.splice(index, 1);
|
|
76
|
+
}
|
|
77
|
+
else {
|
|
78
|
+
throw Error('Index was not found for an enum element in the valuesToHide array provided.');
|
|
73
79
|
}
|
|
74
80
|
}
|
|
75
81
|
}
|
|
82
|
+
sortAndReorderItems() {
|
|
83
|
+
const nonDisabledItems = this.items.filter(item => !item.disabled);
|
|
84
|
+
const disabledItems = this.items.filter(item => item.disabled);
|
|
85
|
+
nonDisabledItems.sort((a, b) => a.label.localeCompare(b.label));
|
|
86
|
+
this.items = [...nonDisabledItems, ...disabledItems];
|
|
87
|
+
}
|
|
76
88
|
writeValue(type) {
|
|
77
89
|
if (type != undefined) {
|
|
78
90
|
this.selectedItem = type;
|
|
@@ -94,6 +106,7 @@ export class ChooseEnumComponent {
|
|
|
94
106
|
this.close.emit();
|
|
95
107
|
}
|
|
96
108
|
onSelectedItemChanged() {
|
|
109
|
+
this.propogateTouch();
|
|
97
110
|
this.propagateChange(this.selectedItem);
|
|
98
111
|
this.change.emit(this.selectedItem);
|
|
99
112
|
}
|
|
@@ -102,6 +115,7 @@ export class ChooseEnumComponent {
|
|
|
102
115
|
}
|
|
103
116
|
clear() {
|
|
104
117
|
this.selectedItem = null;
|
|
118
|
+
this.propogateTouch();
|
|
105
119
|
}
|
|
106
120
|
setStyles() {
|
|
107
121
|
let style = {
|
|
@@ -117,17 +131,18 @@ export class ChooseEnumComponent {
|
|
|
117
131
|
textAlign: this.labelTextAlign,
|
|
118
132
|
fontWeight: this.labelTextFontWeight,
|
|
119
133
|
fontSize: this.labelTextFontSize + 'rem',
|
|
134
|
+
padding: '0.4rem',
|
|
120
135
|
};
|
|
121
136
|
return style;
|
|
122
137
|
}
|
|
123
138
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ChooseEnumComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
124
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ChooseEnumComponent, selector: "choose-enum", inputs: { appendTo: "appendTo", allowAllCapsValues: "allowAllCapsValues", clearable: "clearable", customColors: "customColors", enumChoices: "enumChoices",
|
|
139
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ChooseEnumComponent, selector: "choose-enum", inputs: { appendTo: "appendTo", allowAllCapsValues: "allowAllCapsValues", clearable: "clearable", customColors: "customColors", enumChoices: "enumChoices", getValuesArrayFromEnum: "getValuesArrayFromEnum", valuesToDisable: "valuesToDisable", valuesToHide: "valuesToHide", isChip: "isChip", isDropdownDisabled: "isDropdownDisabled", isMultiple: "isMultiple", label: "label", labelTextAlign: "labelTextAlign", labelTextFontWeight: "labelTextFontWeight", labelTextFontSize: "labelTextFontSize", paddingTop: "paddingTop", placeholder: "placeholder", percentWidth: "percentWidth", selectedItem: "selectedItem", width: "width", isReadOnly: "isReadOnly", virtualScroll: "virtualScroll" }, outputs: { change: "change", close: "close" }, providers: [
|
|
125
140
|
{
|
|
126
141
|
provide: NG_VALUE_ACCESSOR,
|
|
127
142
|
useExisting: forwardRef(() => ChooseEnumComponent),
|
|
128
143
|
multi: true,
|
|
129
144
|
},
|
|
130
|
-
], usesOnChanges: true, ngImport: i0, template: "<div
|
|
145
|
+
], usesOnChanges: true, ngImport: i0, template: "<div>\r\n <ng-select [ngStyle]=\"setStyles()\" (blur)=\"updateBlur()\" bindLabel=\"label\" bindValue=\"value\" [items]=\"items\"\r\n [virtualScroll]=\"virtualScroll\" [placeholder]=\"placeholder\" (change)=\"onSelectedItemChanged()\"\r\n [(ngModel)]=\"selectedItem\" [multiple]=\"isMultiple\" [disabled]=\"isDropdownDisabled\" [readonly]=\"isReadOnly\"\r\n [clearable]=\"clearable\" (clear)=\"clear()\" [appendTo]=\"appendTo\" dropdownPosition=\"bottom\">\r\n <ng-template ng-label-tmp let-item=\"item\" let-clear=\"clear\">\r\n <ng-container *ngIf=\"isChip\">\r\n <ng-container [ngTemplateOutlet]=\"chip\"\r\n [ngTemplateOutletContext]=\"{ item: item, showCross: clearable, clear: clear }\">\r\n </ng-container>\r\n </ng-container>\r\n <div [ngStyle]=\"setLabelStyle()\" *ngIf=\"!isChip\">{{ item.label }}</div>\r\n </ng-template>\r\n <ng-template ng-option-tmp let-item=\"item\" let-index=\"index\" let-search=\"searchTerm\" let-clear=\"clear\">\r\n <div [ngClass]=\"{ disabled: item.disabled }\">\r\n <div *ngIf=\"isChip\" class=\"chip\">\r\n <ng-container [ngTemplateOutlet]=\"chip\"\r\n [ngTemplateOutletContext]=\"{ item: item, showCross: false, clear: clear }\">\r\n </ng-container>\r\n </div>\r\n <div [ngStyle]=\"setLabelStyle()\" *ngIf=\"!isChip\">{{ item.label }}</div>\r\n </div>\r\n </ng-template>\r\n </ng-select>\r\n</div>\r\n\r\n<ng-template #chip let-showCross=\"showCross\" let-item=\"item\" let-clear=\"clear\">\r\n <ng-chip [enumClass]=\"enumChoices\" [withCross]=\"showCross\" [enumValue]=\"item.value\" [customColors]=\"customColors\"\r\n [item]=\"item\" [clear]=\"clear\">\r\n </ng-chip>\r\n</ng-template>", styles: [".disabled{cursor:not-allowed}.disabled .chip{filter:opacity(.3)}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i2.NgSelectComponent, selector: "ng-select", inputs: ["bindLabel", "bindValue", "markFirst", "placeholder", "notFoundText", "typeToSearchText", "addTagText", "loadingText", "clearAllText", "appearance", "dropdownPosition", "appendTo", "loading", "closeOnSelect", "hideSelected", "selectOnTab", "openOnEnter", "maxSelectedItems", "groupBy", "groupValue", "bufferAmount", "virtualScroll", "selectableGroup", "selectableGroupAsModel", "searchFn", "trackByFn", "clearOnBackspace", "labelForId", "inputAttrs", "tabIndex", "readonly", "searchWhileComposing", "minTermLength", "editableSearchTerm", "keyDownFn", "typeahead", "multiple", "addTag", "searchable", "clearable", "isOpen", "items", "compareWith", "clearSearchOnAdd", "deselectOnClick"], outputs: ["blur", "focus", "change", "open", "close", "search", "clear", "add", "remove", "scroll", "scrollToEnd"] }, { kind: "directive", type: i2.NgOptionTemplateDirective, selector: "[ng-option-tmp]" }, { kind: "directive", type: i2.NgLabelTemplateDirective, selector: "[ng-label-tmp]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i4.NgChipComponent, selector: "ng-chip", inputs: ["backgroundColor", "size", "clear", "customColors", "enumClass", "enumValue", "inputType", "item", "isClickable", "label", "width", "withCross"] }] });
|
|
131
146
|
}
|
|
132
147
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ChooseEnumComponent, decorators: [{
|
|
133
148
|
type: Component,
|
|
@@ -137,7 +152,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
137
152
|
useExisting: forwardRef(() => ChooseEnumComponent),
|
|
138
153
|
multi: true,
|
|
139
154
|
},
|
|
140
|
-
], template: "<div
|
|
155
|
+
], template: "<div>\r\n <ng-select [ngStyle]=\"setStyles()\" (blur)=\"updateBlur()\" bindLabel=\"label\" bindValue=\"value\" [items]=\"items\"\r\n [virtualScroll]=\"virtualScroll\" [placeholder]=\"placeholder\" (change)=\"onSelectedItemChanged()\"\r\n [(ngModel)]=\"selectedItem\" [multiple]=\"isMultiple\" [disabled]=\"isDropdownDisabled\" [readonly]=\"isReadOnly\"\r\n [clearable]=\"clearable\" (clear)=\"clear()\" [appendTo]=\"appendTo\" dropdownPosition=\"bottom\">\r\n <ng-template ng-label-tmp let-item=\"item\" let-clear=\"clear\">\r\n <ng-container *ngIf=\"isChip\">\r\n <ng-container [ngTemplateOutlet]=\"chip\"\r\n [ngTemplateOutletContext]=\"{ item: item, showCross: clearable, clear: clear }\">\r\n </ng-container>\r\n </ng-container>\r\n <div [ngStyle]=\"setLabelStyle()\" *ngIf=\"!isChip\">{{ item.label }}</div>\r\n </ng-template>\r\n <ng-template ng-option-tmp let-item=\"item\" let-index=\"index\" let-search=\"searchTerm\" let-clear=\"clear\">\r\n <div [ngClass]=\"{ disabled: item.disabled }\">\r\n <div *ngIf=\"isChip\" class=\"chip\">\r\n <ng-container [ngTemplateOutlet]=\"chip\"\r\n [ngTemplateOutletContext]=\"{ item: item, showCross: false, clear: clear }\">\r\n </ng-container>\r\n </div>\r\n <div [ngStyle]=\"setLabelStyle()\" *ngIf=\"!isChip\">{{ item.label }}</div>\r\n </div>\r\n </ng-template>\r\n </ng-select>\r\n</div>\r\n\r\n<ng-template #chip let-showCross=\"showCross\" let-item=\"item\" let-clear=\"clear\">\r\n <ng-chip [enumClass]=\"enumChoices\" [withCross]=\"showCross\" [enumValue]=\"item.value\" [customColors]=\"customColors\"\r\n [item]=\"item\" [clear]=\"clear\">\r\n </ng-chip>\r\n</ng-template>", styles: [".disabled{cursor:not-allowed}.disabled .chip{filter:opacity(.3)}\n"] }]
|
|
141
156
|
}], ctorParameters: function () { return []; }, propDecorators: { appendTo: [{
|
|
142
157
|
type: Input
|
|
143
158
|
}], allowAllCapsValues: [{
|
|
@@ -148,20 +163,16 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
148
163
|
type: Input
|
|
149
164
|
}], enumChoices: [{
|
|
150
165
|
type: Input
|
|
151
|
-
}], virtualScroll: [{
|
|
152
|
-
type: Input
|
|
153
166
|
}], getValuesArrayFromEnum: [{
|
|
154
167
|
type: Input
|
|
155
|
-
}],
|
|
168
|
+
}], valuesToDisable: [{
|
|
169
|
+
type: Input
|
|
170
|
+
}], valuesToHide: [{
|
|
156
171
|
type: Input
|
|
157
172
|
}], isChip: [{
|
|
158
173
|
type: Input
|
|
159
174
|
}], isDropdownDisabled: [{
|
|
160
175
|
type: Input
|
|
161
|
-
}], isItemHidden: [{
|
|
162
|
-
type: Input
|
|
163
|
-
}], isItemDisabled: [{
|
|
164
|
-
type: Input
|
|
165
176
|
}], isMultiple: [{
|
|
166
177
|
type: Input
|
|
167
178
|
}], label: [{
|
|
@@ -182,9 +193,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
182
193
|
type: Input
|
|
183
194
|
}], width: [{
|
|
184
195
|
type: Input
|
|
196
|
+
}], isReadOnly: [{
|
|
197
|
+
type: Input
|
|
198
|
+
}], virtualScroll: [{
|
|
199
|
+
type: Input
|
|
185
200
|
}], change: [{
|
|
186
201
|
type: Output
|
|
187
202
|
}], close: [{
|
|
188
203
|
type: Output
|
|
189
204
|
}] } });
|
|
190
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"choose-enum.component.js","sourceRoot":"","sources":["../../../../../projects/inputs/src/lib/choose-enum/choose-enum.component.ts","../../../../../projects/inputs/src/lib/choose-enum/choose-enum.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  EventEmitter,\r\n  forwardRef,\r\n  Input,\r\n  OnChanges,\r\n  OnInit,\r\n  Output,\r\n} from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { EnumHelperBaseClass } from '../models/enum-helper-functions';\r\n\r\n@Component({\r\n  selector: 'choose-enum',\r\n  templateUrl: './choose-enum.component.html',\r\n  styleUrls: ['./choose-enum.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => ChooseEnumComponent),\r\n      multi: true,\r\n    },\r\n  ],\r\n})\r\nexport class ChooseEnumComponent\r\n  implements OnInit, OnChanges, ControlValueAccessor\r\n{\r\n  items: any[];\r\n  @Input() appendTo: string = 'body';\r\n  @Input() allowAllCapsValues: boolean = false;\r\n  @Input() clearable: boolean = true;\r\n  @Input() customColors: string[];\r\n  @Input() enumChoices: any;\r\n  @Input() virtualScroll:boolean = false;\r\n  @Input() getValuesArrayFromEnum: Function =\r\n    EnumHelperBaseClass.getEnumOptionsFromEnumClass;\r\n  @Input() indexesToDisable: number[] = [];\r\n  @Input() isChip: boolean = true;\r\n  @Input() isDropdownDisabled: boolean = false;\r\n  @Input() isItemHidden: boolean;\r\n  @Input() isItemDisabled: boolean;\r\n  @Input() isMultiple: boolean;\r\n  @Input() label: string = 'label';\r\n  @Input() labelTextAlign: string = 'left';\r\n  @Input() labelTextFontWeight: string;\r\n  @Input() labelTextFontSize: string;\r\n  @Input() paddingTop: number;\r\n  @Input() placeholder: string;\r\n  @Input() percentWidth: boolean = false;\r\n  @Input() selectedItem: any;\r\n  @Input() width: number;\r\n  @Output() change = new EventEmitter();\r\n  @Output() close = new EventEmitter();\r\n\r\n  constructor() {}\r\n\r\n  ngOnChanges() {\r\n    if (this.getValuesArrayFromEnum != null) {\r\n      this.items = this.getValuesArrayFromEnum(\r\n        this.enumChoices,\r\n        this.customColors,\r\n        this.allowAllCapsValues\r\n      );\r\n    }\r\n    if (this.isItemDisabled == true) {\r\n      if (this.indexesToDisable.length > 0) {\r\n        for (let index of this.indexesToDisable) {\r\n          this.items[index].disabled = true;\r\n        }\r\n      }\r\n    }\r\n    if (this.isItemHidden == true) {\r\n      if (this.indexesToDisable.length > 0) {\r\n        for (let index of this.indexesToDisable) {\r\n          let itemIndex = this.items.findIndex((item) => item.value == index);\r\n          this.items.splice(itemIndex, 1);\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  ngOnInit() {\r\n    if (this.getValuesArrayFromEnum != null) {\r\n      this.items = this.getValuesArrayFromEnum(\r\n        this.enumChoices,\r\n        this.customColors,\r\n        this.allowAllCapsValues\r\n      );\r\n    }\r\n\r\n    if (this.isItemDisabled == true) {\r\n      if (this.indexesToDisable.length > 0) {\r\n        for (let index of this.indexesToDisable) {\r\n          this.items[index].disabled = true;\r\n        }\r\n      }\r\n    }\r\n    if (this.isItemHidden == true) {\r\n      if (this.indexesToDisable.length > 0) {\r\n        for (let index of this.indexesToDisable) {\r\n          let itemIndex = this.items.findIndex((item) => item.value == index);\r\n          this.items.splice(itemIndex, 1);\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  writeValue(type: number) {\r\n    if (type != undefined) {\r\n      this.selectedItem = type;\r\n    } else if (type == null) {\r\n      this.selectedItem = type;\r\n    }\r\n  }\r\n\r\n  public registerOnChange(fn: any) {\r\n    this.propagateChange = fn;\r\n  }\r\n\r\n  public registerOnTouched(fn: any) {\r\n    this.propogateTouch = fn;\r\n  }\r\n\r\n  private propagateChange = (_: any) => {};\r\n  private propogateTouch = () => {};\r\n\r\n  updateBlur() {\r\n    this.propogateTouch();\r\n    this.close.emit();\r\n  }\r\n\r\n  onSelectedItemChanged() {\r\n    this.propagateChange(this.selectedItem);\r\n    this.change.emit(this.selectedItem);\r\n  }\r\n\r\n  setDisabledState(isDisabled: boolean) {\r\n    this.isDropdownDisabled = isDisabled;\r\n  }\r\n\r\n  clear() {\r\n    this.selectedItem = null;\r\n  }\r\n\r\n  setStyles() {\r\n    let style = {\r\n      paddingTop: this.paddingTop + 'rem',\r\n    };\r\n    if (this.width) {\r\n      style['width'] = this.width + 'rem';\r\n    }\r\n    return style;\r\n  }\r\n\r\n  setLabelStyle() {\r\n    let style = {\r\n      textAlign: this.labelTextAlign,\r\n      fontWeight: this.labelTextFontWeight,\r\n      fontSize: this.labelTextFontSize + 'rem',\r\n    };\r\n    return style;\r\n  }\r\n}\r\n","<div class=\"select\">\r\n  <ng-select\r\n    [ngStyle]=\"setStyles()\"\r\n    (blur)=\"updateBlur()\"\r\n    bindLabel=\"label\"\r\n    bindValue=\"value\"\r\n    [items]=\"items\"\r\n    [placeholder]=\"placeholder\"\r\n    (change)=\"onSelectedItemChanged()\"\r\n    [(ngModel)]=\"selectedItem\"\r\n    [multiple]=\"isMultiple\"\r\n    [disabled]=\"isDropdownDisabled\"\r\n    [clearable]=\"clearable\"\r\n    [virtualScroll]=\"virtualScroll\"\r\n    [clearAllText]=\"'clear everything'\"\r\n    (clear)=\"clear()\"\r\n    [appendTo]=\"appendTo\"\r\n    dropdownPosition=\"bottom\">\r\n    <ng-template\r\n      class=\"template\"\r\n      ng-option-tmp\r\n      ng-label-tmp\r\n      let-item=\"item\"\r\n      let-index=\"index\"\r\n      let-search=\"searchTerm\">\r\n      <div *ngIf=\"isChip\">\r\n        <ng-chip [enumClass]=\"enumChoices\" [enumValue]=\"item.value\" [customColors]=\"customColors\">\r\n        </ng-chip>\r\n      </div>\r\n      <div [ngStyle]=\"setLabelStyle()\" *ngIf=\"!isChip\">{{ item.label }}</div>\r\n    </ng-template>\r\n  </ng-select>\r\n</div>\r\n"]}
|
|
205
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"choose-enum.component.js","sourceRoot":"","sources":["../../../../../projects/inputs/src/lib/choose-enum/choose-enum.component.ts","../../../../../projects/inputs/src/lib/choose-enum/choose-enum.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  EventEmitter,\r\n  forwardRef,\r\n  Input,\r\n  OnChanges,\r\n  OnInit,\r\n  Output,\r\n} from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { EnumHelperBaseClass } from '@jooler/shared-general-components';\r\nimport { EnumOption } from '../enum-helper.model';\r\n\r\n@Component({\r\n  selector: 'choose-enum',\r\n  templateUrl: './choose-enum.component.html',\r\n  styleUrls: ['./choose-enum.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => ChooseEnumComponent),\r\n      multi: true,\r\n    },\r\n  ],\r\n})\r\nexport class ChooseEnumComponent implements OnInit, OnChanges, ControlValueAccessor {\r\n  items: EnumOption[];\r\n  @Input() appendTo: string = 'body';\r\n  @Input() allowAllCapsValues: boolean = false;\r\n  @Input() clearable: boolean = true;\r\n  @Input() customColors: string[];\r\n  @Input() enumChoices: any;\r\n  @Input() getValuesArrayFromEnum: Function = EnumHelperBaseClass.getEnumOptionsFromEnumClass;\r\n  @Input() valuesToDisable: number[] = [];\r\n  @Input() valuesToHide: number[] = [];\r\n  @Input() isChip: boolean = true;\r\n  @Input() isDropdownDisabled: boolean = false;\r\n  @Input() isMultiple: boolean;\r\n  @Input() label: string = 'label';\r\n  @Input() labelTextAlign: string = 'left';\r\n  @Input() labelTextFontWeight: string;\r\n  @Input() labelTextFontSize: string;\r\n  @Input() paddingTop: number;\r\n  @Input() placeholder: string;\r\n  @Input() percentWidth: boolean = false;\r\n  @Input() selectedItem: any;\r\n  @Input() width: number;\r\n  @Input() isReadOnly: boolean = false;\r\n  @Input() virtualScroll: boolean = false;\r\n  @Output() change = new EventEmitter();\r\n  @Output() close = new EventEmitter();\r\n\r\n  constructor() { }\r\n\r\n  ngOnInit() {\r\n    if (this.getValuesArrayFromEnum != null) {\r\n      this.items = this.getValuesArrayFromEnum(\r\n        this.enumChoices,\r\n        this.customColors,\r\n        this.allowAllCapsValues\r\n      );\r\n    }\r\n    if (this.valuesToDisable.length > 0) {\r\n      this.disabledItems();\r\n    }\r\n    if (this.valuesToHide.length > 0) {\r\n      this.hideItems();\r\n    }\r\n    this.sortAndReorderItems();\r\n  }\r\n\r\n  ngOnChanges() {\r\n    if (this.getValuesArrayFromEnum != null) {\r\n      this.items = this.getValuesArrayFromEnum(\r\n        this.enumChoices,\r\n        this.customColors,\r\n        this.allowAllCapsValues\r\n      );\r\n    }\r\n    if (this.valuesToDisable.length > 0) {\r\n      this.disabledItems();\r\n    }\r\n    if (this.valuesToHide.length > 0) {\r\n      this.hideItems();\r\n    }\r\n    this.sortAndReorderItems();\r\n  }\r\n\r\n  disabledItems() {\r\n    for (let value of this.valuesToDisable) {\r\n      let index: number = this.items.findIndex(enumOption => enumOption.value == value);\r\n      if (index >= 0) {\r\n        this.items[index].disabled = true;\r\n      } else {\r\n        throw Error(\r\n          'Index was not found for an enum element in the valuesToDisable array provided.'\r\n        );\r\n      }\r\n    }\r\n  }\r\n\r\n  hideItems() {\r\n    for (let value of this.valuesToHide) {\r\n      let index: number = this.items.findIndex(enumOption => enumOption.value == value);\r\n      if (index >= 0) {\r\n        this.items.splice(index, 1);\r\n      } else {\r\n        throw Error('Index was not found for an enum element in the valuesToHide array provided.');\r\n      }\r\n    }\r\n  }\r\n\r\n  sortAndReorderItems(): void {\r\n    const nonDisabledItems = this.items.filter(item => !item.disabled);\r\n    const disabledItems = this.items.filter(item => item.disabled);\r\n    nonDisabledItems.sort((a, b) => a.label.localeCompare(b.label));\r\n    this.items = [...nonDisabledItems, ...disabledItems];\r\n  }\r\n\r\n  writeValue(type: number) {\r\n    if (type != undefined) {\r\n      this.selectedItem = type;\r\n    } else if (type == null) {\r\n      this.selectedItem = type;\r\n    }\r\n  }\r\n\r\n  public registerOnChange(fn: any) {\r\n    this.propagateChange = fn;\r\n  }\r\n\r\n  public registerOnTouched(fn: any) {\r\n    this.propogateTouch = fn;\r\n  }\r\n\r\n  private propagateChange = (_: any) => { };\r\n  private propogateTouch = () => { };\r\n\r\n  updateBlur() {\r\n    this.propogateTouch();\r\n    this.close.emit();\r\n  }\r\n\r\n  onSelectedItemChanged() {\r\n    this.propogateTouch();\r\n    this.propagateChange(this.selectedItem);\r\n    this.change.emit(this.selectedItem);\r\n  }\r\n\r\n  setDisabledState(isDisabled: boolean) {\r\n    this.isDropdownDisabled = isDisabled;\r\n  }\r\n\r\n  clear() {\r\n    this.selectedItem = null;\r\n    this.propogateTouch();\r\n  }\r\n\r\n  setStyles() {\r\n    let style = {\r\n      paddingTop: this.paddingTop + 'rem',\r\n    };\r\n    if (this.width) {\r\n      style['width'] = this.width + 'rem';\r\n    }\r\n    return style;\r\n  }\r\n\r\n  setLabelStyle() {\r\n    let style = {\r\n      textAlign: this.labelTextAlign,\r\n      fontWeight: this.labelTextFontWeight,\r\n      fontSize: this.labelTextFontSize + 'rem',\r\n      padding: '0.4rem',\r\n    };\r\n    return style;\r\n  }\r\n}\r\n","<div>\r\n  <ng-select [ngStyle]=\"setStyles()\" (blur)=\"updateBlur()\" bindLabel=\"label\" bindValue=\"value\" [items]=\"items\"\r\n    [virtualScroll]=\"virtualScroll\" [placeholder]=\"placeholder\" (change)=\"onSelectedItemChanged()\"\r\n    [(ngModel)]=\"selectedItem\" [multiple]=\"isMultiple\" [disabled]=\"isDropdownDisabled\" [readonly]=\"isReadOnly\"\r\n    [clearable]=\"clearable\" (clear)=\"clear()\" [appendTo]=\"appendTo\" dropdownPosition=\"bottom\">\r\n    <ng-template ng-label-tmp let-item=\"item\" let-clear=\"clear\">\r\n      <ng-container *ngIf=\"isChip\">\r\n        <ng-container [ngTemplateOutlet]=\"chip\"\r\n          [ngTemplateOutletContext]=\"{ item: item, showCross: clearable, clear: clear }\">\r\n        </ng-container>\r\n      </ng-container>\r\n      <div [ngStyle]=\"setLabelStyle()\" *ngIf=\"!isChip\">{{ item.label }}</div>\r\n    </ng-template>\r\n    <ng-template ng-option-tmp let-item=\"item\" let-index=\"index\" let-search=\"searchTerm\" let-clear=\"clear\">\r\n      <div [ngClass]=\"{ disabled: item.disabled }\">\r\n        <div *ngIf=\"isChip\" class=\"chip\">\r\n          <ng-container [ngTemplateOutlet]=\"chip\"\r\n            [ngTemplateOutletContext]=\"{ item: item, showCross: false, clear: clear }\">\r\n          </ng-container>\r\n        </div>\r\n        <div [ngStyle]=\"setLabelStyle()\" *ngIf=\"!isChip\">{{ item.label }}</div>\r\n      </div>\r\n    </ng-template>\r\n  </ng-select>\r\n</div>\r\n\r\n<ng-template #chip let-showCross=\"showCross\" let-item=\"item\" let-clear=\"clear\">\r\n  <ng-chip [enumClass]=\"enumChoices\" [withCross]=\"showCross\" [enumValue]=\"item.value\" [customColors]=\"customColors\"\r\n    [item]=\"item\" [clear]=\"clear\">\r\n  </ng-chip>\r\n</ng-template>"]}
|
|
@@ -1,31 +1,45 @@
|
|
|
1
1
|
import { Component } from '@angular/core';
|
|
2
|
+
import { AgGridSelectMixin } from '../ag-grid-select-mixin';
|
|
2
3
|
import * as i0 from "@angular/core";
|
|
3
|
-
import * as i1 from "
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
this.enumValue = params.value;
|
|
14
|
-
this.key = params.context.createKey(params.columnApi, params.column);
|
|
4
|
+
import * as i1 from "@angular/common";
|
|
5
|
+
import * as i2 from "@angular/forms";
|
|
6
|
+
import * as i3 from "../choose-enum/choose-enum.component";
|
|
7
|
+
export class ChooseEnumRendererComponent extends AgGridSelectMixin {
|
|
8
|
+
valuesToDisable = [];
|
|
9
|
+
valuesToHide = [];
|
|
10
|
+
isChip = true;
|
|
11
|
+
clearable = true;
|
|
12
|
+
constructor() {
|
|
13
|
+
super();
|
|
15
14
|
}
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
15
|
+
agInit(params) {
|
|
16
|
+
super.agInit(params);
|
|
17
|
+
if (params.valuesToDisable != null) {
|
|
18
|
+
this.valuesToDisable = params.valuesToDisable;
|
|
19
|
+
}
|
|
20
|
+
if (params.valuesToHide != null) {
|
|
21
|
+
this.valuesToHide = params.valuesToHide;
|
|
22
|
+
}
|
|
23
|
+
if (params.isChip != null) {
|
|
24
|
+
this.isChip = params.isChip;
|
|
25
|
+
}
|
|
26
|
+
if (params.clearable != null) {
|
|
27
|
+
this.clearable = params.clearable;
|
|
28
|
+
}
|
|
20
29
|
}
|
|
21
|
-
|
|
22
|
-
|
|
30
|
+
get showError() {
|
|
31
|
+
if (this.rowLevelFG.get(this.key).errors && this.rowLevelFG.get(this.key).touched) {
|
|
32
|
+
return true;
|
|
33
|
+
}
|
|
34
|
+
else {
|
|
35
|
+
return false;
|
|
36
|
+
}
|
|
23
37
|
}
|
|
24
38
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ChooseEnumRendererComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
25
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ChooseEnumRendererComponent, selector: "choose-enum-renderer", ngImport: i0, template: "<choose-enum [
|
|
39
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ChooseEnumRendererComponent, selector: "choose-enum-renderer", usesInheritance: true, ngImport: i0, template: "<div class=\"all\" [ngClass]=\"{ single: !showError, double: showError }\" *ngIf=\"rowLevelFG\" [formGroup]=\"rowLevelFG\">\r\n <choose-enum [clearable]=\"clearable\" [formControlName]=\"key\" [appendTo]=\"'body'\" [label]=\"params.label\"\r\n [labelTextAlign]=\"params.labelTextAlign\" [labelTextFontWeight]=\"params.labelTextFontWeight\"\r\n [labelTextFontSize]=\"params.labelTextFontSize\" [selectedItem]=\"params.value\" [valuesToHide]=\"valuesToHide\"\r\n [valuesToDisable]=\"valuesToDisable\" [isDropdownDisabled]=\"params.isDropdownDisabled\"\r\n [enumChoices]=\"params.enumChoices\" [placeholder]=\"params.placeholder\" [width]=\"params.width\" [isChip]=\"isChip\"\r\n [paddingTop]=\"params.paddingTop\" [customColors]=\"params.customColors\" (change)=\"onEnumSelected($event)\">\r\n </choose-enum>\r\n</div>", styles: [".all{display:grid;gap:.5rem;align-items:center;margin:auto}.single{grid-template-columns:auto}.double{grid-template-columns:auto max-content}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: i3.ChooseEnumComponent, selector: "choose-enum", inputs: ["appendTo", "allowAllCapsValues", "clearable", "customColors", "enumChoices", "getValuesArrayFromEnum", "valuesToDisable", "valuesToHide", "isChip", "isDropdownDisabled", "isMultiple", "label", "labelTextAlign", "labelTextFontWeight", "labelTextFontSize", "paddingTop", "placeholder", "percentWidth", "selectedItem", "width", "isReadOnly", "virtualScroll"], outputs: ["change", "close"] }] });
|
|
26
40
|
}
|
|
27
41
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ChooseEnumRendererComponent, decorators: [{
|
|
28
42
|
type: Component,
|
|
29
|
-
args: [{ selector: 'choose-enum-renderer', template: "<choose-enum [
|
|
43
|
+
args: [{ selector: 'choose-enum-renderer', template: "<div class=\"all\" [ngClass]=\"{ single: !showError, double: showError }\" *ngIf=\"rowLevelFG\" [formGroup]=\"rowLevelFG\">\r\n <choose-enum [clearable]=\"clearable\" [formControlName]=\"key\" [appendTo]=\"'body'\" [label]=\"params.label\"\r\n [labelTextAlign]=\"params.labelTextAlign\" [labelTextFontWeight]=\"params.labelTextFontWeight\"\r\n [labelTextFontSize]=\"params.labelTextFontSize\" [selectedItem]=\"params.value\" [valuesToHide]=\"valuesToHide\"\r\n [valuesToDisable]=\"valuesToDisable\" [isDropdownDisabled]=\"params.isDropdownDisabled\"\r\n [enumChoices]=\"params.enumChoices\" [placeholder]=\"params.placeholder\" [width]=\"params.width\" [isChip]=\"isChip\"\r\n [paddingTop]=\"params.paddingTop\" [customColors]=\"params.customColors\" (change)=\"onEnumSelected($event)\">\r\n </choose-enum>\r\n</div>", styles: [".all{display:grid;gap:.5rem;align-items:center;margin:auto}.single{grid-template-columns:auto}.double{grid-template-columns:auto max-content}\n"] }]
|
|
30
44
|
}], ctorParameters: function () { return []; } });
|
|
31
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
45
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hvb3NlLWVudW0tcmVuZGVyZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvaW5wdXRzL3NyYy9saWIvY2hvb3NlLWVudW0tcmVuZGVyZXIvY2hvb3NlLWVudW0tcmVuZGVyZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvaW5wdXRzL3NyYy9saWIvY2hvb3NlLWVudW0tcmVuZGVyZXIvY2hvb3NlLWVudW0tcmVuZGVyZXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMxQyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQzs7Ozs7QUFTNUQsTUFBTSxPQUFPLDJCQUE0QixTQUFRLGlCQUFpQjtJQUNoRSxlQUFlLEdBQWEsRUFBRSxDQUFDO0lBQy9CLFlBQVksR0FBYSxFQUFFLENBQUM7SUFDNUIsTUFBTSxHQUFZLElBQUksQ0FBQztJQUN2QixTQUFTLEdBQVksSUFBSSxDQUFDO0lBRTFCO1FBQ0UsS0FBSyxFQUFFLENBQUM7SUFDVixDQUFDO0lBRUQsTUFBTSxDQUFDLE1BQVc7UUFDaEIsS0FBSyxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUNyQixJQUFJLE1BQU0sQ0FBQyxlQUFlLElBQUksSUFBSSxFQUFFO1lBQ2xDLElBQUksQ0FBQyxlQUFlLEdBQUcsTUFBTSxDQUFDLGVBQWUsQ0FBQztTQUMvQztRQUNELElBQUksTUFBTSxDQUFDLFlBQVksSUFBSSxJQUFJLEVBQUU7WUFDL0IsSUFBSSxDQUFDLFlBQVksR0FBRyxNQUFNLENBQUMsWUFBWSxDQUFDO1NBQ3pDO1FBQ0QsSUFBSSxNQUFNLENBQUMsTUFBTSxJQUFJLElBQUksRUFBRTtZQUN6QixJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQyxNQUFNLENBQUM7U0FDN0I7UUFDRCxJQUFJLE1BQU0sQ0FBQyxTQUFTLElBQUksSUFBSSxFQUFFO1lBQzVCLElBQUksQ0FBQyxTQUFTLEdBQUcsTUFBTSxDQUFDLFNBQVMsQ0FBQztTQUNuQztJQUNILENBQUM7SUFFRCxJQUFJLFNBQVM7UUFDWCxJQUFJLElBQUksQ0FBQyxVQUFVLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxNQUFNLElBQUksSUFBSSxDQUFDLFVBQVUsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLE9BQU8sRUFBRTtZQUNqRixPQUFPLElBQUksQ0FBQztTQUNiO2FBQU07WUFDTCxPQUFPLEtBQUssQ0FBQztTQUNkO0lBQ0gsQ0FBQzt3R0FoQ1UsMkJBQTJCOzRGQUEzQiwyQkFBMkIsbUZDVnhDLDIxQkFRTTs7NEZERU8sMkJBQTJCO2tCQVB2QyxTQUFTOytCQUNFLHNCQUFzQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBBZ0dyaWRTZWxlY3RNaXhpbiB9IGZyb20gJy4uL2FnLWdyaWQtc2VsZWN0LW1peGluJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnY2hvb3NlLWVudW0tcmVuZGVyZXInLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9jaG9vc2UtZW51bS1yZW5kZXJlci5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbXHJcbiAgICAnLi9jaG9vc2UtZW51bS1yZW5kZXJlci5jb21wb25lbnQuc2NzcycsXHJcbiAgXSxcclxufSlcclxuZXhwb3J0IGNsYXNzIENob29zZUVudW1SZW5kZXJlckNvbXBvbmVudCBleHRlbmRzIEFnR3JpZFNlbGVjdE1peGluIHtcclxuICB2YWx1ZXNUb0Rpc2FibGU6IG51bWJlcltdID0gW107XHJcbiAgdmFsdWVzVG9IaWRlOiBudW1iZXJbXSA9IFtdO1xyXG4gIGlzQ2hpcDogYm9vbGVhbiA9IHRydWU7XHJcbiAgY2xlYXJhYmxlOiBib29sZWFuID0gdHJ1ZTtcclxuXHJcbiAgY29uc3RydWN0b3IoKSB7XHJcbiAgICBzdXBlcigpO1xyXG4gIH1cclxuXHJcbiAgYWdJbml0KHBhcmFtczogYW55KTogdm9pZCB7XHJcbiAgICBzdXBlci5hZ0luaXQocGFyYW1zKTtcclxuICAgIGlmIChwYXJhbXMudmFsdWVzVG9EaXNhYmxlICE9IG51bGwpIHtcclxuICAgICAgdGhpcy52YWx1ZXNUb0Rpc2FibGUgPSBwYXJhbXMudmFsdWVzVG9EaXNhYmxlO1xyXG4gICAgfVxyXG4gICAgaWYgKHBhcmFtcy52YWx1ZXNUb0hpZGUgIT0gbnVsbCkge1xyXG4gICAgICB0aGlzLnZhbHVlc1RvSGlkZSA9IHBhcmFtcy52YWx1ZXNUb0hpZGU7XHJcbiAgICB9XHJcbiAgICBpZiAocGFyYW1zLmlzQ2hpcCAhPSBudWxsKSB7XHJcbiAgICAgIHRoaXMuaXNDaGlwID0gcGFyYW1zLmlzQ2hpcDtcclxuICAgIH1cclxuICAgIGlmIChwYXJhbXMuY2xlYXJhYmxlICE9IG51bGwpIHtcclxuICAgICAgdGhpcy5jbGVhcmFibGUgPSBwYXJhbXMuY2xlYXJhYmxlO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgZ2V0IHNob3dFcnJvcigpIHtcclxuICAgIGlmICh0aGlzLnJvd0xldmVsRkcuZ2V0KHRoaXMua2V5KS5lcnJvcnMgJiYgdGhpcy5yb3dMZXZlbEZHLmdldCh0aGlzLmtleSkudG91Y2hlZCkge1xyXG4gICAgICByZXR1cm4gdHJ1ZTtcclxuICAgIH0gZWxzZSB7XHJcbiAgICAgIHJldHVybiBmYWxzZTtcclxuICAgIH1cclxuICB9XHJcbn1cclxuIiwiPGRpdiBjbGFzcz1cImFsbFwiIFtuZ0NsYXNzXT1cInsgc2luZ2xlOiAhc2hvd0Vycm9yLCBkb3VibGU6IHNob3dFcnJvciB9XCIgKm5nSWY9XCJyb3dMZXZlbEZHXCIgW2Zvcm1Hcm91cF09XCJyb3dMZXZlbEZHXCI+XHJcbiAgICA8Y2hvb3NlLWVudW0gW2NsZWFyYWJsZV09XCJjbGVhcmFibGVcIiBbZm9ybUNvbnRyb2xOYW1lXT1cImtleVwiIFthcHBlbmRUb109XCInYm9keSdcIiBbbGFiZWxdPVwicGFyYW1zLmxhYmVsXCJcclxuICAgICAgICBbbGFiZWxUZXh0QWxpZ25dPVwicGFyYW1zLmxhYmVsVGV4dEFsaWduXCIgW2xhYmVsVGV4dEZvbnRXZWlnaHRdPVwicGFyYW1zLmxhYmVsVGV4dEZvbnRXZWlnaHRcIlxyXG4gICAgICAgIFtsYWJlbFRleHRGb250U2l6ZV09XCJwYXJhbXMubGFiZWxUZXh0Rm9udFNpemVcIiBbc2VsZWN0ZWRJdGVtXT1cInBhcmFtcy52YWx1ZVwiIFt2YWx1ZXNUb0hpZGVdPVwidmFsdWVzVG9IaWRlXCJcclxuICAgICAgICBbdmFsdWVzVG9EaXNhYmxlXT1cInZhbHVlc1RvRGlzYWJsZVwiIFtpc0Ryb3Bkb3duRGlzYWJsZWRdPVwicGFyYW1zLmlzRHJvcGRvd25EaXNhYmxlZFwiXHJcbiAgICAgICAgW2VudW1DaG9pY2VzXT1cInBhcmFtcy5lbnVtQ2hvaWNlc1wiIFtwbGFjZWhvbGRlcl09XCJwYXJhbXMucGxhY2Vob2xkZXJcIiBbd2lkdGhdPVwicGFyYW1zLndpZHRoXCIgW2lzQ2hpcF09XCJpc0NoaXBcIlxyXG4gICAgICAgIFtwYWRkaW5nVG9wXT1cInBhcmFtcy5wYWRkaW5nVG9wXCIgW2N1c3RvbUNvbG9yc109XCJwYXJhbXMuY3VzdG9tQ29sb3JzXCIgKGNoYW5nZSk9XCJvbkVudW1TZWxlY3RlZCgkZXZlbnQpXCI+XHJcbiAgICA8L2Nob29zZS1lbnVtPlxyXG48L2Rpdj4iXX0=
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
export class EnumOption {
|
|
2
|
+
value;
|
|
3
|
+
label;
|
|
4
|
+
color;
|
|
5
|
+
description;
|
|
6
|
+
disabled;
|
|
7
|
+
constructor(value, label, color, disabled = false) {
|
|
8
|
+
this.value = value;
|
|
9
|
+
this.label = label;
|
|
10
|
+
this.color = color;
|
|
11
|
+
this.disabled = disabled;
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW51bS1oZWxwZXIubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9pbnB1dHMvc3JjL2xpYi9lbnVtLWhlbHBlci5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLE9BQU8sVUFBVTtJQUNyQixLQUFLLENBQVM7SUFDZCxLQUFLLENBQVM7SUFDZCxLQUFLLENBQVM7SUFDZCxXQUFXLENBQVU7SUFDckIsUUFBUSxDQUFXO0lBRW5CLFlBQVksS0FBYSxFQUFFLEtBQWEsRUFBRSxLQUFhLEVBQUUsV0FBb0IsS0FBSztRQUNoRixJQUFJLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQztRQUNuQixJQUFJLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQztRQUNuQixJQUFJLENBQUMsS0FBSyxHQUFHLEtBQUssQ0FBQztRQUNuQixJQUFJLENBQUMsUUFBUSxHQUFHLFFBQVEsQ0FBQztJQUMzQixDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgY2xhc3MgRW51bU9wdGlvbiB7XG4gIHZhbHVlOiBudW1iZXI7XG4gIGxhYmVsOiBzdHJpbmc7XG4gIGNvbG9yOiBzdHJpbmc7XG4gIGRlc2NyaXB0aW9uPzogc3RyaW5nO1xuICBkaXNhYmxlZD86IGJvb2xlYW47XG5cbiAgY29uc3RydWN0b3IodmFsdWU6IG51bWJlciwgbGFiZWw6IHN0cmluZywgY29sb3I6IHN0cmluZywgZGlzYWJsZWQ6IGJvb2xlYW4gPSBmYWxzZSkge1xuICAgIHRoaXMudmFsdWUgPSB2YWx1ZTtcbiAgICB0aGlzLmxhYmVsID0gbGFiZWw7XG4gICAgdGhpcy5jb2xvciA9IGNvbG9yO1xuICAgIHRoaXMuZGlzYWJsZWQgPSBkaXNhYmxlZDtcbiAgfVxufVxuIl19
|