@jooler/inputs 0.0.51 → 0.0.53

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.
Files changed (50) hide show
  1. package/esm2022/lib/ag-grid-select-mixin.mjs +73 -0
  2. package/esm2022/lib/choose-enum/choose-enum.component.mjs +57 -42
  3. package/esm2022/lib/choose-enum-renderer/choose-enum-renderer.component.mjs +35 -21
  4. package/esm2022/lib/custom-colors/bom-production-type.enum.mjs +11 -0
  5. package/esm2022/lib/custom-colors/enum-custom-color-mapping.mjs +32 -0
  6. package/esm2022/lib/custom-colors/enum-custom-colors.mjs +21 -0
  7. package/esm2022/lib/custom-colors/sales-order-status.enum.mjs +27 -0
  8. package/esm2022/lib/enum-custom-label-mapping.mjs +32 -0
  9. package/esm2022/lib/enum-helper-functions.mjs +85 -0
  10. package/esm2022/lib/enum-helper.model.mjs +14 -0
  11. package/esm2022/lib/enum-models/bill-status.model.mjs +25 -0
  12. package/esm2022/lib/enum-models/charge-level.enum.mjs +6 -0
  13. package/esm2022/lib/enum-models/custom-order-request-status.enum.mjs +29 -0
  14. package/esm2022/lib/enum-models/invitation-status.model.mjs +15 -0
  15. package/esm2022/lib/enum-models/invoice-status.model.mjs +15 -0
  16. package/esm2022/lib/enum-models/locker-transfer-status.enum.mjs +11 -0
  17. package/esm2022/lib/enum-models/priority.model.mjs +13 -0
  18. package/esm2022/lib/enum-models/quotation-status.model.mjs +19 -0
  19. package/esm2022/lib/enum-models/request-status.model.mjs +15 -0
  20. package/esm2022/lib/enum-string-class-map.mjs +26 -0
  21. package/esm2022/lib/json/enum-custom-label-mappings.json +10 -0
  22. package/esm2022/lib/primary-colors.mjs +9 -1
  23. package/fesm2022/inputs.mjs +523 -96
  24. package/fesm2022/inputs.mjs.map +1 -1
  25. package/lib/ag-grid-select-mixin.d.ts +22 -0
  26. package/lib/choose-enum/choose-enum.component.d.ts +12 -7
  27. package/lib/choose-enum-renderer/choose-enum-renderer.component.d.ts +7 -9
  28. package/lib/custom-colors/bom-production-type.enum.d.ts +5 -0
  29. package/lib/custom-colors/enum-custom-color-mapping.d.ts +11 -0
  30. package/lib/custom-colors/enum-custom-colors.d.ts +2 -0
  31. package/lib/custom-colors/sales-order-status.enum.d.ts +13 -0
  32. package/lib/enum-custom-label-mapping.d.ts +7 -0
  33. package/lib/enum-helper-functions.d.ts +7 -0
  34. package/lib/enum-helper.model.d.ts +8 -0
  35. package/lib/enum-models/bill-status.model.d.ts +12 -0
  36. package/lib/enum-models/charge-level.enum.d.ts +4 -0
  37. package/lib/enum-models/custom-order-request-status.enum.d.ts +14 -0
  38. package/lib/enum-models/invitation-status.model.d.ts +7 -0
  39. package/lib/enum-models/invoice-status.model.d.ts +13 -0
  40. package/lib/enum-models/locker-transfer-status.enum.d.ts +5 -0
  41. package/lib/enum-models/priority.model.d.ts +6 -0
  42. package/lib/enum-models/quotation-status.model.d.ts +9 -0
  43. package/lib/enum-models/request-status.model.d.ts +7 -0
  44. package/lib/enum-string-class-map.d.ts +3 -0
  45. package/lib/primary-colors.d.ts +8 -0
  46. package/package.json +1 -1
  47. package/esm2022/lib/models/enum-helper-functions.mjs +0 -57
  48. package/esm2022/lib/models/enum-helper.model.mjs +0 -2
  49. package/lib/models/enum-helper-functions.d.ts +0 -5
  50. 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 '../models/enum-helper-functions';
3
+ import { EnumHelperBaseClass } from '../enum-helper-functions';
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
- indexesToDisable = [];
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
- ngOnChanges() {
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.isItemDisabled == true) {
41
- if (this.indexesToDisable.length > 0) {
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.isItemHidden == true) {
48
- if (this.indexesToDisable.length > 0) {
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
- ngOnInit() {
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.isItemDisabled == true) {
61
- if (this.indexesToDisable.length > 0) {
62
- for (let index of this.indexesToDisable) {
63
- this.items[index].disabled = true;
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
- if (this.isItemHidden == true) {
68
- if (this.indexesToDisable.length > 0) {
69
- for (let index of this.indexesToDisable) {
70
- let itemIndex = this.items.findIndex((item) => item.value == index);
71
- this.items.splice(itemIndex, 1);
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", virtualScroll: "virtualScroll", getValuesArrayFromEnum: "getValuesArrayFromEnum", indexesToDisable: "indexesToDisable", isChip: "isChip", isDropdownDisabled: "isDropdownDisabled", isItemHidden: "isItemHidden", isItemDisabled: "isItemDisabled", isMultiple: "isMultiple", label: "label", labelTextAlign: "labelTextAlign", labelTextFontWeight: "labelTextFontWeight", labelTextFontSize: "labelTextFontSize", paddingTop: "paddingTop", placeholder: "placeholder", percentWidth: "percentWidth", selectedItem: "selectedItem", width: "width" }, outputs: { change: "change", close: "close" }, providers: [
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 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", styles: [".select{width:100%}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { 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"] }] });
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 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", styles: [".select{width:100%}\n"] }]
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
- }], indexesToDisable: [{
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 { EnumOption } from '../enum-helper.model';\r\nimport { EnumHelperBaseClass } from '../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 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 "../choose-enum/choose-enum.component";
4
- export class ChooseEnumRendererComponent {
5
- params;
6
- formControlValue;
7
- key;
8
- enumValue;
9
- rowId;
10
- constructor() { }
11
- agInit(params) {
12
- this.params = params;
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
- onCellDataChanged($event) {
17
- let value = $event;
18
- this.formControlValue = this.params.context.formGroup.get("entries").at(this.params.node.rowIndex);
19
- this.formControlValue?.get(this.key).setValue(value);
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
- refresh(params) {
22
- return false;
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 [label]=\"params.label\" [appendTo]=\"'body'\" [isItemHidden]=\"params.isItemHidden\"\r\n [isItemDisabled]=\"params.isItemDisabled\" [labelTextAlign]=\"params.labelTextAlign\"\r\n [labelTextFontWeight]=\"params.labelTextFontWeight\" [labelTextFontSize]=\"params.labelTextFontSize\"\r\n [selectedItem]=\"params.value\" [indexesToDisable]=\"params.indexesToDisable\"\r\n [isDropdownDisabled]=\"params.isDropdownDisabled\" [getValuesArrayFromEnum]=\"params.getLabelAndColorFromEnumValue\"\r\n [enumChoices]=\"params.enumChoices\" [placeholder]=\"params.placeholder\" [width]=\"params.width\"\r\n [isChip]=\"params.isChip\" [paddingTop]=\"params.paddingTop\" [allowAllCapsValues]=\"params.allowAllCapsValues\"\r\n (change)=\"onCellDataChanged($event)\">\r\n</choose-enum>", styles: [""], dependencies: [{ kind: "component", type: i1.ChooseEnumComponent, selector: "choose-enum", inputs: ["appendTo", "allowAllCapsValues", "clearable", "customColors", "enumChoices", "virtualScroll", "getValuesArrayFromEnum", "indexesToDisable", "isChip", "isDropdownDisabled", "isItemHidden", "isItemDisabled", "isMultiple", "label", "labelTextAlign", "labelTextFontWeight", "labelTextFontSize", "paddingTop", "placeholder", "percentWidth", "selectedItem", "width"], outputs: ["change", "close"] }] });
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 [label]=\"params.label\" [appendTo]=\"'body'\" [isItemHidden]=\"params.isItemHidden\"\r\n [isItemDisabled]=\"params.isItemDisabled\" [labelTextAlign]=\"params.labelTextAlign\"\r\n [labelTextFontWeight]=\"params.labelTextFontWeight\" [labelTextFontSize]=\"params.labelTextFontSize\"\r\n [selectedItem]=\"params.value\" [indexesToDisable]=\"params.indexesToDisable\"\r\n [isDropdownDisabled]=\"params.isDropdownDisabled\" [getValuesArrayFromEnum]=\"params.getLabelAndColorFromEnumValue\"\r\n [enumChoices]=\"params.enumChoices\" [placeholder]=\"params.placeholder\" [width]=\"params.width\"\r\n [isChip]=\"params.isChip\" [paddingTop]=\"params.paddingTop\" [allowAllCapsValues]=\"params.allowAllCapsValues\"\r\n (change)=\"onCellDataChanged($event)\">\r\n</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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hvb3NlLWVudW0tcmVuZGVyZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvaW5wdXRzL3NyYy9saWIvY2hvb3NlLWVudW0tcmVuZGVyZXIvY2hvb3NlLWVudW0tcmVuZGVyZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvaW5wdXRzL3NyYy9saWIvY2hvb3NlLWVudW0tcmVuZGVyZXIvY2hvb3NlLWVudW0tcmVuZGVyZXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7O0FBUTFDLE1BQU0sT0FBTywyQkFBMkI7SUFDdEMsTUFBTSxDQUFNO0lBQ1osZ0JBQWdCLENBQUM7SUFDakIsR0FBRyxDQUFDO0lBQ0osU0FBUyxDQUFTO0lBQ2xCLEtBQUssQ0FBUztJQUVkLGdCQUFnQixDQUFDO0lBRWpCLE1BQU0sQ0FBQyxNQUFXO1FBQ2hCLElBQUksQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFDO1FBQ3JCLElBQUksQ0FBQyxTQUFTLEdBQUcsTUFBTSxDQUFDLEtBQUssQ0FBQztRQUM5QixJQUFJLENBQUMsR0FBRyxHQUFHLE1BQU0sQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxTQUFTLEVBQUUsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQ3ZFLENBQUM7SUFFRCxpQkFBaUIsQ0FBQyxNQUFNO1FBQ3RCLElBQUksS0FBSyxHQUFRLE1BQU0sQ0FBQztRQUN4QixJQUFJLENBQUMsZ0JBQWdCLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxTQUFTLENBQUMsQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUM7UUFDbkcsSUFBSSxDQUFDLGdCQUFnQixFQUFFLEdBQUcsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBRXZELENBQUM7SUFFRCxPQUFPLENBQUMsTUFBVztRQUNqQixPQUFPLEtBQUssQ0FBQztJQUNmLENBQUM7d0dBeEJVLDJCQUEyQjs0RkFBM0IsMkJBQTJCLDREQ1J4QyxteUJBUWM7OzRGREFELDJCQUEyQjtrQkFMdkMsU0FBUzsrQkFDRSxzQkFBc0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgSUNlbGxSZW5kZXJlckFuZ3VsYXJDb21wIH0gZnJvbSAnYWctZ3JpZC1hbmd1bGFyJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnY2hvb3NlLWVudW0tcmVuZGVyZXInLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9jaG9vc2UtZW51bS1yZW5kZXJlci5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vY2hvb3NlLWVudW0tcmVuZGVyZXIuY29tcG9uZW50LnNjc3MnXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgQ2hvb3NlRW51bVJlbmRlcmVyQ29tcG9uZW50IGltcGxlbWVudHMgSUNlbGxSZW5kZXJlckFuZ3VsYXJDb21wIHtcclxuICBwYXJhbXM6IGFueTtcclxuICBmb3JtQ29udHJvbFZhbHVlO1xyXG4gIGtleTtcclxuICBlbnVtVmFsdWU6IG51bWJlcjtcclxuICByb3dJZDogbnVtYmVyO1xyXG5cclxuICBjb25zdHJ1Y3RvcigpIHsgfVxyXG5cclxuICBhZ0luaXQocGFyYW1zOiBhbnkpIHtcclxuICAgIHRoaXMucGFyYW1zID0gcGFyYW1zO1xyXG4gICAgdGhpcy5lbnVtVmFsdWUgPSBwYXJhbXMudmFsdWU7XHJcbiAgICB0aGlzLmtleSA9IHBhcmFtcy5jb250ZXh0LmNyZWF0ZUtleShwYXJhbXMuY29sdW1uQXBpLCBwYXJhbXMuY29sdW1uKTtcclxuICB9XHJcblxyXG4gIG9uQ2VsbERhdGFDaGFuZ2VkKCRldmVudCkge1xyXG4gICAgbGV0IHZhbHVlOiBhbnkgPSAkZXZlbnQ7XHJcbiAgICB0aGlzLmZvcm1Db250cm9sVmFsdWUgPSB0aGlzLnBhcmFtcy5jb250ZXh0LmZvcm1Hcm91cC5nZXQoXCJlbnRyaWVzXCIpLmF0KHRoaXMucGFyYW1zLm5vZGUucm93SW5kZXgpO1xyXG4gICAgdGhpcy5mb3JtQ29udHJvbFZhbHVlPy5nZXQodGhpcy5rZXkpLnNldFZhbHVlKHZhbHVlKTtcclxuXHJcbiAgfVxyXG5cclxuICByZWZyZXNoKHBhcmFtczogYW55KTogYm9vbGVhbiB7XHJcbiAgICByZXR1cm4gZmFsc2U7XHJcbiAgfVxyXG59XHJcbiIsIjxjaG9vc2UtZW51bSBbbGFiZWxdPVwicGFyYW1zLmxhYmVsXCIgW2FwcGVuZFRvXT1cIidib2R5J1wiIFtpc0l0ZW1IaWRkZW5dPVwicGFyYW1zLmlzSXRlbUhpZGRlblwiXHJcbiAgICBbaXNJdGVtRGlzYWJsZWRdPVwicGFyYW1zLmlzSXRlbURpc2FibGVkXCIgW2xhYmVsVGV4dEFsaWduXT1cInBhcmFtcy5sYWJlbFRleHRBbGlnblwiXHJcbiAgICBbbGFiZWxUZXh0Rm9udFdlaWdodF09XCJwYXJhbXMubGFiZWxUZXh0Rm9udFdlaWdodFwiIFtsYWJlbFRleHRGb250U2l6ZV09XCJwYXJhbXMubGFiZWxUZXh0Rm9udFNpemVcIlxyXG4gICAgW3NlbGVjdGVkSXRlbV09XCJwYXJhbXMudmFsdWVcIiBbaW5kZXhlc1RvRGlzYWJsZV09XCJwYXJhbXMuaW5kZXhlc1RvRGlzYWJsZVwiXHJcbiAgICBbaXNEcm9wZG93bkRpc2FibGVkXT1cInBhcmFtcy5pc0Ryb3Bkb3duRGlzYWJsZWRcIiBbZ2V0VmFsdWVzQXJyYXlGcm9tRW51bV09XCJwYXJhbXMuZ2V0TGFiZWxBbmRDb2xvckZyb21FbnVtVmFsdWVcIlxyXG4gICAgW2VudW1DaG9pY2VzXT1cInBhcmFtcy5lbnVtQ2hvaWNlc1wiIFtwbGFjZWhvbGRlcl09XCJwYXJhbXMucGxhY2Vob2xkZXJcIiBbd2lkdGhdPVwicGFyYW1zLndpZHRoXCJcclxuICAgIFtpc0NoaXBdPVwicGFyYW1zLmlzQ2hpcFwiIFtwYWRkaW5nVG9wXT1cInBhcmFtcy5wYWRkaW5nVG9wXCIgW2FsbG93QWxsQ2Fwc1ZhbHVlc109XCJwYXJhbXMuYWxsb3dBbGxDYXBzVmFsdWVzXCJcclxuICAgIChjaGFuZ2UpPVwib25DZWxsRGF0YUNoYW5nZWQoJGV2ZW50KVwiPlxyXG48L2Nob29zZS1lbnVtPiJdfQ==
45
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hvb3NlLWVudW0tcmVuZGVyZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvaW5wdXRzL3NyYy9saWIvY2hvb3NlLWVudW0tcmVuZGVyZXIvY2hvb3NlLWVudW0tcmVuZGVyZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvaW5wdXRzL3NyYy9saWIvY2hvb3NlLWVudW0tcmVuZGVyZXIvY2hvb3NlLWVudW0tcmVuZGVyZXIuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMxQyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQzs7Ozs7QUFTNUQsTUFBTSxPQUFPLDJCQUE0QixTQUFRLGlCQUFpQjtJQUNoRSxlQUFlLEdBQWEsRUFBRSxDQUFDO0lBQy9CLFlBQVksR0FBYSxFQUFFLENBQUM7SUFDNUIsTUFBTSxHQUFZLElBQUksQ0FBQztJQUN2QixTQUFTLEdBQVksSUFBSSxDQUFDO0lBRTFCO1FBQ0UsS0FBSyxFQUFFLENBQUM7SUFDVixDQUFDO0lBRUQsTUFBTSxDQUFDLE1BQVc7UUFDaEIsS0FBSyxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUNyQixJQUFJLE1BQU0sQ0FBQyxlQUFlLElBQUksSUFBSSxFQUFFO1lBQ2xDLElBQUksQ0FBQyxlQUFlLEdBQUcsTUFBTSxDQUFDLGVBQWUsQ0FBQztTQUMvQztRQUNELElBQUksTUFBTSxDQUFDLFlBQVksSUFBSSxJQUFJLEVBQUU7WUFDL0IsSUFBSSxDQUFDLFlBQVksR0FBRyxNQUFNLENBQUMsWUFBWSxDQUFDO1NBQ3pDO1FBQ0QsSUFBSSxNQUFNLENBQUMsTUFBTSxJQUFJLElBQUksRUFBRTtZQUN6QixJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQyxNQUFNLENBQUM7U0FDN0I7UUFDRCxJQUFJLE1BQU0sQ0FBQyxTQUFTLElBQUksSUFBSSxFQUFFO1lBQzVCLElBQUksQ0FBQyxTQUFTLEdBQUcsTUFBTSxDQUFDLFNBQVMsQ0FBQztTQUNuQztJQUNILENBQUM7SUFFRCxJQUFJLFNBQVM7UUFDWCxJQUFJLElBQUksQ0FBQyxVQUFVLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxNQUFNLElBQUksSUFBSSxDQUFDLFVBQVUsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLE9BQU8sRUFBRTtZQUNqRixPQUFPLElBQUksQ0FBQztTQUNiO2FBQU07WUFDTCxPQUFPLEtBQUssQ0FBQztTQUNkO0lBQ0gsQ0FBQzt3R0FoQ1UsMkJBQTJCOzRGQUEzQiwyQkFBMkIsbUZDVnhDLDIxQkFRTTs7NEZERU8sMkJBQTJCO2tCQVB2QyxTQUFTOytCQUNFLHNCQUFzQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBBZ0dyaWRTZWxlY3RNaXhpbiB9IGZyb20gJy4uL2FnLWdyaWQtc2VsZWN0LW1peGluJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnY2hvb3NlLWVudW0tcmVuZGVyZXInLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9jaG9vc2UtZW51bS1yZW5kZXJlci5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbXHJcbiAgICAnLi9jaG9vc2UtZW51bS1yZW5kZXJlci5jb21wb25lbnQuc2NzcycsXHJcbiAgXSxcclxufSlcclxuZXhwb3J0IGNsYXNzIENob29zZUVudW1SZW5kZXJlckNvbXBvbmVudCBleHRlbmRzIEFnR3JpZFNlbGVjdE1peGluIHtcclxuICB2YWx1ZXNUb0Rpc2FibGU6IG51bWJlcltdID0gW107XHJcbiAgdmFsdWVzVG9IaWRlOiBudW1iZXJbXSA9IFtdO1xyXG4gIGlzQ2hpcDogYm9vbGVhbiA9IHRydWU7XHJcbiAgY2xlYXJhYmxlOiBib29sZWFuID0gdHJ1ZTtcclxuXHJcbiAgY29uc3RydWN0b3IoKSB7XHJcbiAgICBzdXBlcigpO1xyXG4gIH1cclxuXHJcbiAgYWdJbml0KHBhcmFtczogYW55KTogdm9pZCB7XHJcbiAgICBzdXBlci5hZ0luaXQocGFyYW1zKTtcclxuICAgIGlmIChwYXJhbXMudmFsdWVzVG9EaXNhYmxlICE9IG51bGwpIHtcclxuICAgICAgdGhpcy52YWx1ZXNUb0Rpc2FibGUgPSBwYXJhbXMudmFsdWVzVG9EaXNhYmxlO1xyXG4gICAgfVxyXG4gICAgaWYgKHBhcmFtcy52YWx1ZXNUb0hpZGUgIT0gbnVsbCkge1xyXG4gICAgICB0aGlzLnZhbHVlc1RvSGlkZSA9IHBhcmFtcy52YWx1ZXNUb0hpZGU7XHJcbiAgICB9XHJcbiAgICBpZiAocGFyYW1zLmlzQ2hpcCAhPSBudWxsKSB7XHJcbiAgICAgIHRoaXMuaXNDaGlwID0gcGFyYW1zLmlzQ2hpcDtcclxuICAgIH1cclxuICAgIGlmIChwYXJhbXMuY2xlYXJhYmxlICE9IG51bGwpIHtcclxuICAgICAgdGhpcy5jbGVhcmFibGUgPSBwYXJhbXMuY2xlYXJhYmxlO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgZ2V0IHNob3dFcnJvcigpIHtcclxuICAgIGlmICh0aGlzLnJvd0xldmVsRkcuZ2V0KHRoaXMua2V5KS5lcnJvcnMgJiYgdGhpcy5yb3dMZXZlbEZHLmdldCh0aGlzLmtleSkudG91Y2hlZCkge1xyXG4gICAgICByZXR1cm4gdHJ1ZTtcclxuICAgIH0gZWxzZSB7XHJcbiAgICAgIHJldHVybiBmYWxzZTtcclxuICAgIH1cclxuICB9XHJcbn1cclxuIiwiPGRpdiBjbGFzcz1cImFsbFwiIFtuZ0NsYXNzXT1cInsgc2luZ2xlOiAhc2hvd0Vycm9yLCBkb3VibGU6IHNob3dFcnJvciB9XCIgKm5nSWY9XCJyb3dMZXZlbEZHXCIgW2Zvcm1Hcm91cF09XCJyb3dMZXZlbEZHXCI+XHJcbiAgICA8Y2hvb3NlLWVudW0gW2NsZWFyYWJsZV09XCJjbGVhcmFibGVcIiBbZm9ybUNvbnRyb2xOYW1lXT1cImtleVwiIFthcHBlbmRUb109XCInYm9keSdcIiBbbGFiZWxdPVwicGFyYW1zLmxhYmVsXCJcclxuICAgICAgICBbbGFiZWxUZXh0QWxpZ25dPVwicGFyYW1zLmxhYmVsVGV4dEFsaWduXCIgW2xhYmVsVGV4dEZvbnRXZWlnaHRdPVwicGFyYW1zLmxhYmVsVGV4dEZvbnRXZWlnaHRcIlxyXG4gICAgICAgIFtsYWJlbFRleHRGb250U2l6ZV09XCJwYXJhbXMubGFiZWxUZXh0Rm9udFNpemVcIiBbc2VsZWN0ZWRJdGVtXT1cInBhcmFtcy52YWx1ZVwiIFt2YWx1ZXNUb0hpZGVdPVwidmFsdWVzVG9IaWRlXCJcclxuICAgICAgICBbdmFsdWVzVG9EaXNhYmxlXT1cInZhbHVlc1RvRGlzYWJsZVwiIFtpc0Ryb3Bkb3duRGlzYWJsZWRdPVwicGFyYW1zLmlzRHJvcGRvd25EaXNhYmxlZFwiXHJcbiAgICAgICAgW2VudW1DaG9pY2VzXT1cInBhcmFtcy5lbnVtQ2hvaWNlc1wiIFtwbGFjZWhvbGRlcl09XCJwYXJhbXMucGxhY2Vob2xkZXJcIiBbd2lkdGhdPVwicGFyYW1zLndpZHRoXCIgW2lzQ2hpcF09XCJpc0NoaXBcIlxyXG4gICAgICAgIFtwYWRkaW5nVG9wXT1cInBhcmFtcy5wYWRkaW5nVG9wXCIgW2N1c3RvbUNvbG9yc109XCJwYXJhbXMuY3VzdG9tQ29sb3JzXCIgKGNoYW5nZSk9XCJvbkVudW1TZWxlY3RlZCgkZXZlbnQpXCI+XHJcbiAgICA8L2Nob29zZS1lbnVtPlxyXG48L2Rpdj4iXX0=
@@ -0,0 +1,11 @@
1
+ import { PrimaryColors } from "../primary-colors";
2
+ export var BOMProductionType;
3
+ (function (BOMProductionType) {
4
+ BOMProductionType[BOMProductionType["MANUFACTURED_IN_HOUSE"] = 0] = "MANUFACTURED_IN_HOUSE";
5
+ BOMProductionType[BOMProductionType["PARTIALLY_MANUFACTURED_IN_HOUSE"] = 1] = "PARTIALLY_MANUFACTURED_IN_HOUSE";
6
+ })(BOMProductionType || (BOMProductionType = {}));
7
+ export const bomProductionTypeColors = Object.values({
8
+ [BOMProductionType.MANUFACTURED_IN_HOUSE]: PrimaryColors.$primaryLimeGreenColor,
9
+ [BOMProductionType.PARTIALLY_MANUFACTURED_IN_HOUSE]: PrimaryColors.$primaryBlueColor,
10
+ });
11
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYm9tLXByb2R1Y3Rpb24tdHlwZS5lbnVtLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvaW5wdXRzL3NyYy9saWIvY3VzdG9tLWNvbG9ycy9ib20tcHJvZHVjdGlvbi10eXBlLmVudW0udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBRWxELE1BQU0sQ0FBTixJQUFZLGlCQUdYO0FBSEQsV0FBWSxpQkFBaUI7SUFDM0IsMkZBQXlCLENBQUE7SUFDekIsK0dBQW1DLENBQUE7QUFDckMsQ0FBQyxFQUhXLGlCQUFpQixLQUFqQixpQkFBaUIsUUFHNUI7QUFFRCxNQUFNLENBQUMsTUFBTSx1QkFBdUIsR0FBRyxNQUFNLENBQUMsTUFBTSxDQUFDO0lBQ25ELENBQUMsaUJBQWlCLENBQUMscUJBQXFCLENBQUMsRUFBRSxhQUFhLENBQUMsc0JBQXNCO0lBQy9FLENBQUMsaUJBQWlCLENBQUMsK0JBQStCLENBQUMsRUFBRSxhQUFhLENBQUMsaUJBQWlCO0NBQ3JGLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFByaW1hcnlDb2xvcnMgfSBmcm9tIFwiLi4vcHJpbWFyeS1jb2xvcnNcIjtcblxuZXhwb3J0IGVudW0gQk9NUHJvZHVjdGlvblR5cGUge1xuICBNQU5VRkFDVFVSRURfSU5fSE9VU0UgPSAwLFxuICBQQVJUSUFMTFlfTUFOVUZBQ1RVUkVEX0lOX0hPVVNFID0gMSxcbn1cblxuZXhwb3J0IGNvbnN0IGJvbVByb2R1Y3Rpb25UeXBlQ29sb3JzID0gT2JqZWN0LnZhbHVlcyh7XG4gIFtCT01Qcm9kdWN0aW9uVHlwZS5NQU5VRkFDVFVSRURfSU5fSE9VU0VdOiBQcmltYXJ5Q29sb3JzLiRwcmltYXJ5TGltZUdyZWVuQ29sb3IsXG4gIFtCT01Qcm9kdWN0aW9uVHlwZS5QQVJUSUFMTFlfTUFOVUZBQ1RVUkVEX0lOX0hPVVNFXTogUHJpbWFyeUNvbG9ycy4kcHJpbWFyeUJsdWVDb2xvcixcbn0pO1xuIl19
@@ -0,0 +1,32 @@
1
+ import { enumClassMap } from '../enum-string-class-map';
2
+ import { enumCustomColors } from './enum-custom-colors';
3
+ export class EnumCustomColorMapping {
4
+ enumClass;
5
+ colors;
6
+ constructor(enumClass, colors) {
7
+ this.enumClass = enumClass;
8
+ if (this.validateColors(enumClass, colors)) {
9
+ this.colors = colors;
10
+ }
11
+ else {
12
+ throw new Error(`The length of your custom colors list does not match the enum class provided.`);
13
+ }
14
+ }
15
+ validateColors(enumClass, colors) {
16
+ // Get the total number of enum values by counting keys
17
+ const enumValues = Object.keys(enumClass).filter(key => isNaN(Number(key))).length;
18
+ return colors.length === enumValues;
19
+ }
20
+ }
21
+ // Function to create EnumCustomColorMapping instances from JSON array
22
+ function createEnumCustomColorMappings(mappings) {
23
+ return mappings.map(json => {
24
+ const enumClass = enumClassMap[json.enumClass];
25
+ if (!enumClass) {
26
+ throw new Error(`Enum class "${json.enumClass}" not found.`);
27
+ }
28
+ return new EnumCustomColorMapping(enumClass, json.colors);
29
+ });
30
+ }
31
+ export const enumCustomColorMappings = createEnumCustomColorMappings(enumCustomColors);
32
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW51bS1jdXN0b20tY29sb3ItbWFwcGluZy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2lucHV0cy9zcmMvbGliL2N1c3RvbS1jb2xvcnMvZW51bS1jdXN0b20tY29sb3ItbWFwcGluZy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7QUFDeEQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFPeEQsTUFBTSxPQUFPLHNCQUFzQjtJQUNqQyxTQUFTLENBQU07SUFDZixNQUFNLENBQVc7SUFFakIsWUFBWSxTQUFjLEVBQUUsTUFBZ0I7UUFDMUMsSUFBSSxDQUFDLFNBQVMsR0FBRyxTQUFTLENBQUM7UUFDM0IsSUFBSSxJQUFJLENBQUMsY0FBYyxDQUFDLFNBQVMsRUFBRSxNQUFNLENBQUMsRUFBRTtZQUMxQyxJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQztTQUN0QjthQUFNO1lBQ0wsTUFBTSxJQUFJLEtBQUssQ0FDYiwrRUFBK0UsQ0FDaEYsQ0FBQztTQUNIO0lBQ0gsQ0FBQztJQUVPLGNBQWMsQ0FBQyxTQUFjLEVBQUUsTUFBZ0I7UUFDckQsdURBQXVEO1FBQ3ZELE1BQU0sVUFBVSxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDO1FBQ25GLE9BQU8sTUFBTSxDQUFDLE1BQU0sS0FBSyxVQUFVLENBQUM7SUFDdEMsQ0FBQztDQUNGO0FBRUQsc0VBQXNFO0FBQ3RFLFNBQVMsNkJBQTZCLENBQ3BDLFFBQW1DO0lBRW5DLE9BQU8sUUFBUSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsRUFBRTtRQUN6QixNQUFNLFNBQVMsR0FBRyxZQUFZLENBQUMsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBQy9DLElBQUksQ0FBQyxTQUFTLEVBQUU7WUFDZCxNQUFNLElBQUksS0FBSyxDQUFDLGVBQWUsSUFBSSxDQUFDLFNBQVMsY0FBYyxDQUFDLENBQUM7U0FDOUQ7UUFDRCxPQUFPLElBQUksc0JBQXNCLENBQUMsU0FBUyxFQUFFLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUM1RCxDQUFDLENBQUMsQ0FBQztBQUNMLENBQUM7QUFFRCxNQUFNLENBQUMsTUFBTSx1QkFBdUIsR0FBRyw2QkFBNkIsQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgZW51bUNsYXNzTWFwIH0gZnJvbSAnLi4vZW51bS1zdHJpbmctY2xhc3MtbWFwJztcbmltcG9ydCB7IGVudW1DdXN0b21Db2xvcnMgfSBmcm9tICcuL2VudW0tY3VzdG9tLWNvbG9ycyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgSUVudW1DdXN0b21Db2xvck1hcHBpbmcge1xuICBlbnVtQ2xhc3M6IGFueTtcbiAgY29sb3JzOiBzdHJpbmdbXTtcbn1cblxuZXhwb3J0IGNsYXNzIEVudW1DdXN0b21Db2xvck1hcHBpbmcge1xuICBlbnVtQ2xhc3M6IGFueTtcbiAgY29sb3JzOiBzdHJpbmdbXTtcblxuICBjb25zdHJ1Y3RvcihlbnVtQ2xhc3M6IGFueSwgY29sb3JzOiBzdHJpbmdbXSkge1xuICAgIHRoaXMuZW51bUNsYXNzID0gZW51bUNsYXNzO1xuICAgIGlmICh0aGlzLnZhbGlkYXRlQ29sb3JzKGVudW1DbGFzcywgY29sb3JzKSkge1xuICAgICAgdGhpcy5jb2xvcnMgPSBjb2xvcnM7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgICAgYFRoZSBsZW5ndGggb2YgeW91ciBjdXN0b20gY29sb3JzIGxpc3QgZG9lcyBub3QgbWF0Y2ggdGhlIGVudW0gY2xhc3MgcHJvdmlkZWQuYFxuICAgICAgKTtcbiAgICB9XG4gIH1cblxuICBwcml2YXRlIHZhbGlkYXRlQ29sb3JzKGVudW1DbGFzczogYW55LCBjb2xvcnM6IHN0cmluZ1tdKTogYm9vbGVhbiB7XG4gICAgLy8gR2V0IHRoZSB0b3RhbCBudW1iZXIgb2YgZW51bSB2YWx1ZXMgYnkgY291bnRpbmcga2V5c1xuICAgIGNvbnN0IGVudW1WYWx1ZXMgPSBPYmplY3Qua2V5cyhlbnVtQ2xhc3MpLmZpbHRlcihrZXkgPT4gaXNOYU4oTnVtYmVyKGtleSkpKS5sZW5ndGg7XG4gICAgcmV0dXJuIGNvbG9ycy5sZW5ndGggPT09IGVudW1WYWx1ZXM7XG4gIH1cbn1cblxuLy8gRnVuY3Rpb24gdG8gY3JlYXRlIEVudW1DdXN0b21Db2xvck1hcHBpbmcgaW5zdGFuY2VzIGZyb20gSlNPTiBhcnJheVxuZnVuY3Rpb24gY3JlYXRlRW51bUN1c3RvbUNvbG9yTWFwcGluZ3MoXG4gIG1hcHBpbmdzOiBJRW51bUN1c3RvbUNvbG9yTWFwcGluZ1tdXG4pOiBFbnVtQ3VzdG9tQ29sb3JNYXBwaW5nW10ge1xuICByZXR1cm4gbWFwcGluZ3MubWFwKGpzb24gPT4ge1xuICAgIGNvbnN0IGVudW1DbGFzcyA9IGVudW1DbGFzc01hcFtqc29uLmVudW1DbGFzc107XG4gICAgaWYgKCFlbnVtQ2xhc3MpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihgRW51bSBjbGFzcyBcIiR7anNvbi5lbnVtQ2xhc3N9XCIgbm90IGZvdW5kLmApO1xuICAgIH1cbiAgICByZXR1cm4gbmV3IEVudW1DdXN0b21Db2xvck1hcHBpbmcoZW51bUNsYXNzLCBqc29uLmNvbG9ycyk7XG4gIH0pO1xufVxuXG5leHBvcnQgY29uc3QgZW51bUN1c3RvbUNvbG9yTWFwcGluZ3MgPSBjcmVhdGVFbnVtQ3VzdG9tQ29sb3JNYXBwaW5ncyhlbnVtQ3VzdG9tQ29sb3JzKTtcbiJdfQ==
@@ -0,0 +1,21 @@
1
+ import { billStatusColors } from "../enum-models/bill-status.model";
2
+ import { customOrderRequestStatusColors } from "../enum-models/custom-order-request-status.enum";
3
+ import { invitationStatusColors } from "../enum-models/invitation-status.model";
4
+ import { lockerTransferStatusColors } from "../enum-models/locker-transfer-status.enum";
5
+ import { priorityColors } from "../enum-models/priority.model";
6
+ import { quotationStatusColors } from "../enum-models/quotation-status.model";
7
+ import { requestStatusColors } from "../enum-models/request-status.model";
8
+ import { bomProductionTypeColors } from "./bom-production-type.enum";
9
+ import { salesOrderStatusColors } from "./sales-order-status.enum";
10
+ export const enumCustomColors = [
11
+ { enumClass: 'CustomOrderRequestStatus', colors: customOrderRequestStatusColors },
12
+ { enumClass: 'Priority', colors: priorityColors },
13
+ { enumClass: 'QuotationStatus', colors: quotationStatusColors },
14
+ { enumClass: 'LockerTransferStatus', colors: lockerTransferStatusColors },
15
+ { enumClass: 'BillStatus', colors: billStatusColors },
16
+ { enumClass: 'SalesOrderStatus', colors: salesOrderStatusColors },
17
+ { enumClass: 'RequestStatus', colors: requestStatusColors },
18
+ { enumClass: 'InvitationStatus', colors: invitationStatusColors },
19
+ { enumClass: 'BOMProductionType', colors: bomProductionTypeColors },
20
+ ];
21
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW51bS1jdXN0b20tY29sb3JzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvaW5wdXRzL3NyYy9saWIvY3VzdG9tLWNvbG9ycy9lbnVtLWN1c3RvbS1jb2xvcnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sa0NBQWtDLENBQUM7QUFDcEUsT0FBTyxFQUFFLDhCQUE4QixFQUFFLE1BQU0saURBQWlELENBQUM7QUFDakcsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sd0NBQXdDLENBQUM7QUFDaEYsT0FBTyxFQUFFLDBCQUEwQixFQUFFLE1BQU0sNENBQTRDLENBQUM7QUFDeEYsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBQy9ELE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBQzlFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHFDQUFxQyxDQUFDO0FBQzFFLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBRXJFLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBR25FLE1BQU0sQ0FBQyxNQUFNLGdCQUFnQixHQUE4QjtJQUN6RCxFQUFFLFNBQVMsRUFBRSwwQkFBMEIsRUFBRSxNQUFNLEVBQUUsOEJBQThCLEVBQUU7SUFDakYsRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSxjQUFjLEVBQUU7SUFDakQsRUFBRSxTQUFTLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxFQUFFLHFCQUFxQixFQUFFO0lBQy9ELEVBQUUsU0FBUyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sRUFBRSwwQkFBMEIsRUFBRTtJQUN6RSxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsTUFBTSxFQUFFLGdCQUFnQixFQUFFO0lBQ3JELEVBQUUsU0FBUyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sRUFBRSxzQkFBc0IsRUFBRTtJQUNqRSxFQUFFLFNBQVMsRUFBRSxlQUFlLEVBQUUsTUFBTSxFQUFFLG1CQUFtQixFQUFFO0lBQzNELEVBQUUsU0FBUyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sRUFBRSxzQkFBc0IsRUFBRTtJQUNqRSxFQUFFLFNBQVMsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLEVBQUUsdUJBQXVCLEVBQUU7Q0FDcEUsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGJpbGxTdGF0dXNDb2xvcnMgfSBmcm9tIFwiLi4vZW51bS1tb2RlbHMvYmlsbC1zdGF0dXMubW9kZWxcIjtcbmltcG9ydCB7IGN1c3RvbU9yZGVyUmVxdWVzdFN0YXR1c0NvbG9ycyB9IGZyb20gXCIuLi9lbnVtLW1vZGVscy9jdXN0b20tb3JkZXItcmVxdWVzdC1zdGF0dXMuZW51bVwiO1xuaW1wb3J0IHsgaW52aXRhdGlvblN0YXR1c0NvbG9ycyB9IGZyb20gXCIuLi9lbnVtLW1vZGVscy9pbnZpdGF0aW9uLXN0YXR1cy5tb2RlbFwiO1xuaW1wb3J0IHsgbG9ja2VyVHJhbnNmZXJTdGF0dXNDb2xvcnMgfSBmcm9tIFwiLi4vZW51bS1tb2RlbHMvbG9ja2VyLXRyYW5zZmVyLXN0YXR1cy5lbnVtXCI7XG5pbXBvcnQgeyBwcmlvcml0eUNvbG9ycyB9IGZyb20gXCIuLi9lbnVtLW1vZGVscy9wcmlvcml0eS5tb2RlbFwiO1xuaW1wb3J0IHsgcXVvdGF0aW9uU3RhdHVzQ29sb3JzIH0gZnJvbSBcIi4uL2VudW0tbW9kZWxzL3F1b3RhdGlvbi1zdGF0dXMubW9kZWxcIjtcbmltcG9ydCB7IHJlcXVlc3RTdGF0dXNDb2xvcnMgfSBmcm9tIFwiLi4vZW51bS1tb2RlbHMvcmVxdWVzdC1zdGF0dXMubW9kZWxcIjtcbmltcG9ydCB7IGJvbVByb2R1Y3Rpb25UeXBlQ29sb3JzIH0gZnJvbSBcIi4vYm9tLXByb2R1Y3Rpb24tdHlwZS5lbnVtXCI7XG5pbXBvcnQgeyBJRW51bUN1c3RvbUNvbG9yTWFwcGluZyB9IGZyb20gXCIuL2VudW0tY3VzdG9tLWNvbG9yLW1hcHBpbmdcIjtcbmltcG9ydCB7IHNhbGVzT3JkZXJTdGF0dXNDb2xvcnMgfSBmcm9tIFwiLi9zYWxlcy1vcmRlci1zdGF0dXMuZW51bVwiO1xuXG5cbmV4cG9ydCBjb25zdCBlbnVtQ3VzdG9tQ29sb3JzOiBJRW51bUN1c3RvbUNvbG9yTWFwcGluZ1tdID0gW1xuICB7IGVudW1DbGFzczogJ0N1c3RvbU9yZGVyUmVxdWVzdFN0YXR1cycsIGNvbG9yczogY3VzdG9tT3JkZXJSZXF1ZXN0U3RhdHVzQ29sb3JzIH0sXG4gIHsgZW51bUNsYXNzOiAnUHJpb3JpdHknLCBjb2xvcnM6IHByaW9yaXR5Q29sb3JzIH0sXG4gIHsgZW51bUNsYXNzOiAnUXVvdGF0aW9uU3RhdHVzJywgY29sb3JzOiBxdW90YXRpb25TdGF0dXNDb2xvcnMgfSxcbiAgeyBlbnVtQ2xhc3M6ICdMb2NrZXJUcmFuc2ZlclN0YXR1cycsIGNvbG9yczogbG9ja2VyVHJhbnNmZXJTdGF0dXNDb2xvcnMgfSxcbiAgeyBlbnVtQ2xhc3M6ICdCaWxsU3RhdHVzJywgY29sb3JzOiBiaWxsU3RhdHVzQ29sb3JzIH0sXG4gIHsgZW51bUNsYXNzOiAnU2FsZXNPcmRlclN0YXR1cycsIGNvbG9yczogc2FsZXNPcmRlclN0YXR1c0NvbG9ycyB9LFxuICB7IGVudW1DbGFzczogJ1JlcXVlc3RTdGF0dXMnLCBjb2xvcnM6IHJlcXVlc3RTdGF0dXNDb2xvcnMgfSxcbiAgeyBlbnVtQ2xhc3M6ICdJbnZpdGF0aW9uU3RhdHVzJywgY29sb3JzOiBpbnZpdGF0aW9uU3RhdHVzQ29sb3JzIH0sXG4gIHsgZW51bUNsYXNzOiAnQk9NUHJvZHVjdGlvblR5cGUnLCBjb2xvcnM6IGJvbVByb2R1Y3Rpb25UeXBlQ29sb3JzIH0sXG5dO1xuIl19
@@ -0,0 +1,27 @@
1
+ import { PrimaryColors } from "../primary-colors";
2
+ export var SalesOrderStatus;
3
+ (function (SalesOrderStatus) {
4
+ SalesOrderStatus[SalesOrderStatus["DRAFT"] = 0] = "DRAFT";
5
+ SalesOrderStatus[SalesOrderStatus["PENDING_APPROVAL"] = 1] = "PENDING_APPROVAL";
6
+ SalesOrderStatus[SalesOrderStatus["APPROVED"] = 2] = "APPROVED";
7
+ SalesOrderStatus[SalesOrderStatus["TO_DELIVER_AND_TO_BILL"] = 3] = "TO_DELIVER_AND_TO_BILL";
8
+ SalesOrderStatus[SalesOrderStatus["TO_BILL"] = 4] = "TO_BILL";
9
+ SalesOrderStatus[SalesOrderStatus["PARTIALLY_DELIVERED_AND_PARTIALLY_BILLED"] = 5] = "PARTIALLY_DELIVERED_AND_PARTIALLY_BILLED";
10
+ SalesOrderStatus[SalesOrderStatus["PARTIALLY_DELIVERED_AND_TO_BILL"] = 6] = "PARTIALLY_DELIVERED_AND_TO_BILL";
11
+ SalesOrderStatus[SalesOrderStatus["COMPLETED"] = 7] = "COMPLETED";
12
+ SalesOrderStatus[SalesOrderStatus["CANCELED"] = 8] = "CANCELED";
13
+ SalesOrderStatus[SalesOrderStatus["CLOSED"] = 9] = "CLOSED";
14
+ })(SalesOrderStatus || (SalesOrderStatus = {}));
15
+ export const salesOrderStatusColors = Object.values({
16
+ [SalesOrderStatus.DRAFT]: PrimaryColors.$primaryBlueColor,
17
+ [SalesOrderStatus.PENDING_APPROVAL]: PrimaryColors.$primaryYellowColor,
18
+ [SalesOrderStatus.APPROVED]: PrimaryColors.$primaryTealColor,
19
+ [SalesOrderStatus.TO_DELIVER_AND_TO_BILL]: PrimaryColors.$primaryPurpleColor,
20
+ [SalesOrderStatus.TO_BILL]: PrimaryColors.$primaryPinkColor,
21
+ [SalesOrderStatus.PARTIALLY_DELIVERED_AND_PARTIALLY_BILLED]: PrimaryColors.$primaryOrangeColor,
22
+ [SalesOrderStatus.PARTIALLY_DELIVERED_AND_TO_BILL]: PrimaryColors.$primaryNavyBlueColor,
23
+ [SalesOrderStatus.COMPLETED]: PrimaryColors.$primaryLimeGreenColor,
24
+ [SalesOrderStatus.CANCELED]: PrimaryColors.$primaryGrayColor,
25
+ [SalesOrderStatus.CLOSED]: PrimaryColors.$primaryCarbonColor,
26
+ });
27
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2FsZXMtb3JkZXItc3RhdHVzLmVudW0uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9pbnB1dHMvc3JjL2xpYi9jdXN0b20tY29sb3JzL3NhbGVzLW9yZGVyLXN0YXR1cy5lbnVtLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQztBQUVsRCxNQUFNLENBQU4sSUFBWSxnQkFXWDtBQVhELFdBQVksZ0JBQWdCO0lBQzFCLHlEQUFTLENBQUE7SUFDVCwrRUFBb0IsQ0FBQTtJQUNwQiwrREFBWSxDQUFBO0lBQ1osMkZBQTBCLENBQUE7SUFDMUIsNkRBQVcsQ0FBQTtJQUNYLCtIQUE0QyxDQUFBO0lBQzVDLDZHQUFtQyxDQUFBO0lBQ25DLGlFQUFhLENBQUE7SUFDYiwrREFBWSxDQUFBO0lBQ1osMkRBQVUsQ0FBQTtBQUNaLENBQUMsRUFYVyxnQkFBZ0IsS0FBaEIsZ0JBQWdCLFFBVzNCO0FBRUQsTUFBTSxDQUFDLE1BQU0sc0JBQXNCLEdBQUcsTUFBTSxDQUFDLE1BQU0sQ0FBQztJQUNsRCxDQUFDLGdCQUFnQixDQUFDLEtBQUssQ0FBQyxFQUFFLGFBQWEsQ0FBQyxpQkFBaUI7SUFDekQsQ0FBQyxnQkFBZ0IsQ0FBQyxnQkFBZ0IsQ0FBQyxFQUFFLGFBQWEsQ0FBQyxtQkFBbUI7SUFDdEUsQ0FBQyxnQkFBZ0IsQ0FBQyxRQUFRLENBQUMsRUFBRSxhQUFhLENBQUMsaUJBQWlCO0lBQzVELENBQUMsZ0JBQWdCLENBQUMsc0JBQXNCLENBQUMsRUFBRSxhQUFhLENBQUMsbUJBQW1CO0lBQzVFLENBQUMsZ0JBQWdCLENBQUMsT0FBTyxDQUFDLEVBQUUsYUFBYSxDQUFDLGlCQUFpQjtJQUMzRCxDQUFDLGdCQUFnQixDQUFDLHdDQUF3QyxDQUFDLEVBQUUsYUFBYSxDQUFDLG1CQUFtQjtJQUM5RixDQUFDLGdCQUFnQixDQUFDLCtCQUErQixDQUFDLEVBQUUsYUFBYSxDQUFDLHFCQUFxQjtJQUN2RixDQUFDLGdCQUFnQixDQUFDLFNBQVMsQ0FBQyxFQUFFLGFBQWEsQ0FBQyxzQkFBc0I7SUFDbEUsQ0FBQyxnQkFBZ0IsQ0FBQyxRQUFRLENBQUMsRUFBRSxhQUFhLENBQUMsaUJBQWlCO0lBQzVELENBQUMsZ0JBQWdCLENBQUMsTUFBTSxDQUFDLEVBQUUsYUFBYSxDQUFDLG1CQUFtQjtDQUM3RCxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQcmltYXJ5Q29sb3JzIH0gZnJvbSBcIi4uL3ByaW1hcnktY29sb3JzXCI7XG5cbmV4cG9ydCBlbnVtIFNhbGVzT3JkZXJTdGF0dXMge1xuICBEUkFGVCA9IDAsXG4gIFBFTkRJTkdfQVBQUk9WQUwgPSAxLFxuICBBUFBST1ZFRCA9IDIsXG4gIFRPX0RFTElWRVJfQU5EX1RPX0JJTEwgPSAzLFxuICBUT19CSUxMID0gNCxcbiAgUEFSVElBTExZX0RFTElWRVJFRF9BTkRfUEFSVElBTExZX0JJTExFRCA9IDUsXG4gIFBBUlRJQUxMWV9ERUxJVkVSRURfQU5EX1RPX0JJTEwgPSA2LFxuICBDT01QTEVURUQgPSA3LFxuICBDQU5DRUxFRCA9IDgsXG4gIENMT1NFRCA9IDksXG59XG5cbmV4cG9ydCBjb25zdCBzYWxlc09yZGVyU3RhdHVzQ29sb3JzID0gT2JqZWN0LnZhbHVlcyh7XG4gIFtTYWxlc09yZGVyU3RhdHVzLkRSQUZUXTogUHJpbWFyeUNvbG9ycy4kcHJpbWFyeUJsdWVDb2xvcixcbiAgW1NhbGVzT3JkZXJTdGF0dXMuUEVORElOR19BUFBST1ZBTF06IFByaW1hcnlDb2xvcnMuJHByaW1hcnlZZWxsb3dDb2xvcixcbiAgW1NhbGVzT3JkZXJTdGF0dXMuQVBQUk9WRURdOiBQcmltYXJ5Q29sb3JzLiRwcmltYXJ5VGVhbENvbG9yLFxuICBbU2FsZXNPcmRlclN0YXR1cy5UT19ERUxJVkVSX0FORF9UT19CSUxMXTogUHJpbWFyeUNvbG9ycy4kcHJpbWFyeVB1cnBsZUNvbG9yLFxuICBbU2FsZXNPcmRlclN0YXR1cy5UT19CSUxMXTogUHJpbWFyeUNvbG9ycy4kcHJpbWFyeVBpbmtDb2xvcixcbiAgW1NhbGVzT3JkZXJTdGF0dXMuUEFSVElBTExZX0RFTElWRVJFRF9BTkRfUEFSVElBTExZX0JJTExFRF06IFByaW1hcnlDb2xvcnMuJHByaW1hcnlPcmFuZ2VDb2xvcixcbiAgW1NhbGVzT3JkZXJTdGF0dXMuUEFSVElBTExZX0RFTElWRVJFRF9BTkRfVE9fQklMTF06IFByaW1hcnlDb2xvcnMuJHByaW1hcnlOYXZ5Qmx1ZUNvbG9yLFxuICBbU2FsZXNPcmRlclN0YXR1cy5DT01QTEVURURdOiBQcmltYXJ5Q29sb3JzLiRwcmltYXJ5TGltZUdyZWVuQ29sb3IsXG4gIFtTYWxlc09yZGVyU3RhdHVzLkNBTkNFTEVEXTogUHJpbWFyeUNvbG9ycy4kcHJpbWFyeUdyYXlDb2xvcixcbiAgW1NhbGVzT3JkZXJTdGF0dXMuQ0xPU0VEXTogUHJpbWFyeUNvbG9ycy4kcHJpbWFyeUNhcmJvbkNvbG9yLFxufSk7XG4iXX0=