@jooler/inputs 0.0.50 → 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.
Files changed (92) hide show
  1. package/{esm2020 → esm2022}/inputs.mjs +4 -4
  2. package/esm2022/lib/add-asterisk.directive.mjs +42 -0
  3. package/esm2022/lib/ag-grid-select-mixin.mjs +73 -0
  4. package/esm2022/lib/choose-enum/choose-enum.component.mjs +205 -0
  5. package/esm2022/lib/choose-enum-renderer/choose-enum-renderer.component.mjs +45 -0
  6. package/esm2022/lib/choose-general-item/choose-general-item.component.mjs +149 -0
  7. package/esm2022/lib/choose-general-item/choose-general-item.service.mjs +45 -0
  8. package/esm2022/lib/choose-general-item-renderer/choose-general-item-renderer.component.mjs +37 -0
  9. package/esm2022/lib/choose-line-type/choose-line-type.component.mjs +53 -0
  10. package/esm2022/lib/choose-yes-or-no/choose-yes-or-no.component.mjs +69 -0
  11. package/esm2022/lib/choose-yes-or-no-renderer/choose-yes-or-no-renderer.component.mjs +33 -0
  12. package/{esm2020 → esm2022}/lib/dropdown-actions/dropdown-action-type.model.mjs +5 -5
  13. package/esm2022/lib/dropdown-actions/dropdown-actions.component.mjs +75 -0
  14. package/{esm2020 → esm2022}/lib/dropdown-actions/label-and-route.model.mjs +1 -1
  15. package/{esm2020 → esm2022}/lib/editable-savable-input/dynamicPipe.mjs +20 -20
  16. package/{esm2020 → esm2022}/lib/editable-savable-input/dynamicPipeMapping.mjs +4 -4
  17. package/esm2022/lib/editable-savable-input/editable-savable-input.component.mjs +128 -0
  18. package/esm2022/lib/enum-helper.model.mjs +14 -0
  19. package/esm2022/lib/formcontrol-validation-msg.directive.mjs +150 -0
  20. package/esm2022/lib/general-input-renderer/custom-decimal-point-two-digits.directive.mjs +63 -0
  21. package/esm2022/lib/general-input-renderer/general-input-renderer.component.mjs +50 -0
  22. package/{esm2020 → esm2022}/lib/inputs.module.mjs +122 -122
  23. package/{esm2020 → esm2022}/lib/models/label-and-field.model.mjs +5 -3
  24. package/esm2022/lib/models/line-type-model-helper.mjs +51 -0
  25. package/{esm2020 → esm2022}/lib/models/line-type.model.mjs +5 -5
  26. package/esm2022/lib/models/yes-or-no.model.mjs +6 -0
  27. package/esm2022/lib/primary-colors.mjs +12 -0
  28. package/esm2022/lib/services/validation-message.service.mjs +111 -0
  29. package/esm2022/lib/show-table-errors/show-table-errors.component.mjs +25 -0
  30. package/{esm2020 → esm2022}/public-api.mjs +23 -23
  31. package/fesm2022/inputs.mjs +1494 -0
  32. package/fesm2022/inputs.mjs.map +1 -0
  33. package/index.d.ts +5 -5
  34. package/lib/add-asterisk.directive.d.ts +12 -12
  35. package/lib/ag-grid-select-mixin.d.ts +22 -0
  36. package/lib/choose-enum/choose-enum.component.d.ts +57 -51
  37. package/lib/choose-enum-renderer/choose-enum-renderer.component.d.ts +13 -15
  38. package/lib/choose-general-item/choose-general-item.component.d.ts +49 -49
  39. package/lib/choose-general-item/choose-general-item.service.d.ts +18 -18
  40. package/lib/choose-general-item-renderer/choose-general-item-renderer.component.d.ts +15 -15
  41. package/lib/choose-line-type/choose-line-type.component.d.ts +19 -19
  42. package/lib/choose-yes-or-no/choose-yes-or-no.component.d.ts +24 -24
  43. package/lib/choose-yes-or-no-renderer/choose-yes-or-no-renderer.component.d.ts +16 -16
  44. package/lib/dropdown-actions/dropdown-action-type.model.d.ts +4 -4
  45. package/lib/dropdown-actions/dropdown-actions.component.d.ts +22 -22
  46. package/lib/dropdown-actions/label-and-route.model.d.ts +4 -4
  47. package/lib/editable-savable-input/dynamicPipe.d.ts +7 -7
  48. package/lib/editable-savable-input/dynamicPipeMapping.d.ts +5 -5
  49. package/lib/editable-savable-input/editable-savable-input.component.d.ts +37 -37
  50. package/lib/enum-helper.model.d.ts +8 -0
  51. package/lib/formcontrol-validation-msg.directive.d.ts +25 -25
  52. package/lib/general-input-renderer/custom-decimal-point-two-digits.directive.d.ts +13 -13
  53. package/lib/general-input-renderer/general-input-renderer.component.d.ts +15 -15
  54. package/lib/inputs.module.d.ts +29 -29
  55. package/lib/models/label-and-field.model.d.ts +4 -4
  56. package/lib/models/line-type-model-helper.d.ts +12 -12
  57. package/lib/models/line-type.model.d.ts +4 -4
  58. package/lib/models/yes-or-no.model.d.ts +5 -5
  59. package/lib/primary-colors.d.ts +11 -11
  60. package/lib/services/validation-message.service.d.ts +50 -50
  61. package/lib/show-table-errors/show-table-errors.component.d.ts +11 -11
  62. package/package.json +10 -16
  63. package/public-api.d.ts +20 -20
  64. package/esm2020/lib/add-asterisk.directive.mjs +0 -41
  65. package/esm2020/lib/choose-enum/choose-enum.component.mjs +0 -176
  66. package/esm2020/lib/choose-enum-renderer/choose-enum-renderer.component.mjs +0 -26
  67. package/esm2020/lib/choose-general-item/choose-general-item.component.mjs +0 -133
  68. package/esm2020/lib/choose-general-item/choose-general-item.service.mjs +0 -43
  69. package/esm2020/lib/choose-general-item-renderer/choose-general-item-renderer.component.mjs +0 -32
  70. package/esm2020/lib/choose-line-type/choose-line-type.component.mjs +0 -52
  71. package/esm2020/lib/choose-yes-or-no/choose-yes-or-no.component.mjs +0 -69
  72. package/esm2020/lib/choose-yes-or-no-renderer/choose-yes-or-no-renderer.component.mjs +0 -27
  73. package/esm2020/lib/custom-theme.mjs +0 -104
  74. package/esm2020/lib/dropdown-actions/dropdown-actions.component.mjs +0 -72
  75. package/esm2020/lib/editable-savable-input/editable-savable-input.component.mjs +0 -123
  76. package/esm2020/lib/formcontrol-validation-msg.directive.mjs +0 -144
  77. package/esm2020/lib/general-input-renderer/custom-decimal-point-two-digits.directive.mjs +0 -61
  78. package/esm2020/lib/general-input-renderer/general-input-renderer.component.mjs +0 -45
  79. package/esm2020/lib/models/enum-helper-functions.mjs +0 -57
  80. package/esm2020/lib/models/enum-helper.model.mjs +0 -2
  81. package/esm2020/lib/models/line-type-model-helper.mjs +0 -47
  82. package/esm2020/lib/models/yes-or-no.model.mjs +0 -3
  83. package/esm2020/lib/primary-colors.mjs +0 -12
  84. package/esm2020/lib/services/validation-message.service.mjs +0 -106
  85. package/esm2020/lib/show-table-errors/show-table-errors.component.mjs +0 -23
  86. package/fesm2015/inputs.mjs +0 -1475
  87. package/fesm2015/inputs.mjs.map +0 -1
  88. package/fesm2020/inputs.mjs +0 -1471
  89. package/fesm2020/inputs.mjs.map +0 -1
  90. package/lib/custom-theme.d.ts +0 -8
  91. package/lib/models/enum-helper-functions.d.ts +0 -5
  92. package/lib/models/enum-helper.model.d.ts +0 -6
@@ -0,0 +1,149 @@
1
+ import { Component, EventEmitter, forwardRef, Input, Output } from '@angular/core';
2
+ import { NG_VALUE_ACCESSOR } from '@angular/forms';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "./choose-general-item.service";
5
+ import * as i2 from "@angular/common";
6
+ import * as i3 from "@ng-select/ng-select";
7
+ import * as i4 from "@angular/forms";
8
+ import * as i5 from "@jooler/shared-general-components";
9
+ export class ChooseGeneralItemComponent {
10
+ _ChooseGeneralItemService;
11
+ change = new EventEmitter();
12
+ items;
13
+ label;
14
+ appendTo;
15
+ placeholder;
16
+ apiPath;
17
+ isMultiple;
18
+ hideSelectedItem;
19
+ objects;
20
+ showLabel;
21
+ separator;
22
+ width = 20;
23
+ fontWeight;
24
+ fontSize;
25
+ isChip = false;
26
+ isTypeDate;
27
+ chipColor = 'black';
28
+ chipTextColor = 'white';
29
+ chipWidth = 11;
30
+ selectedItemId;
31
+ disabled;
32
+ useFullObject = false;
33
+ constructor(_ChooseGeneralItemService) {
34
+ this._ChooseGeneralItemService = _ChooseGeneralItemService;
35
+ }
36
+ ngOnInit() {
37
+ if (!this.items)
38
+ this.getData();
39
+ }
40
+ writeValue(item) {
41
+ if (item != undefined) {
42
+ this.selectedItemId = item;
43
+ }
44
+ else if (item == null) {
45
+ this.selectedItemId = item;
46
+ }
47
+ }
48
+ registerOnChange(fn) {
49
+ this.propagateChange = fn;
50
+ }
51
+ registerOnTouched(fn) {
52
+ this.propogateTouch = fn;
53
+ }
54
+ propagateChange = (_) => { };
55
+ propogateTouch = () => { };
56
+ updateBlur() {
57
+ this.propogateTouch();
58
+ }
59
+ onSelectedItemChanged($event) {
60
+ this.propagateChange(this.useFullObject ? $event : this.selectedItemId);
61
+ this.change.emit(this.useFullObject ? $event : this.selectedItemId);
62
+ }
63
+ getData() {
64
+ if (this.apiPath) {
65
+ this._ChooseGeneralItemService.getData(this.apiPath).subscribe({
66
+ next: (response) => {
67
+ this.items = response;
68
+ },
69
+ error: (error) => console.error("error", error)
70
+ });
71
+ }
72
+ }
73
+ setWidth() {
74
+ let style = {
75
+ width: this.width + "rem"
76
+ };
77
+ return style;
78
+ }
79
+ setFontStyles() {
80
+ let fontStyle = {
81
+ fontWeight: this.fontWeight,
82
+ fontSize: this.fontSize + "rem",
83
+ };
84
+ return fontStyle;
85
+ }
86
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ChooseGeneralItemComponent, deps: [{ token: i1.ChooseGeneralItemService }], target: i0.ɵɵFactoryTarget.Component });
87
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ChooseGeneralItemComponent, selector: "choose-general-item", inputs: { items: "items", label: "label", appendTo: "appendTo", placeholder: "placeholder", apiPath: "apiPath", isMultiple: "isMultiple", hideSelectedItem: "hideSelectedItem", objects: "objects", showLabel: "showLabel", separator: "separator", width: "width", fontWeight: "fontWeight", fontSize: "fontSize", isChip: "isChip", isTypeDate: "isTypeDate", chipColor: "chipColor", chipTextColor: "chipTextColor", chipWidth: "chipWidth", selectedItemId: "selectedItemId", disabled: "disabled", useFullObject: "useFullObject" }, outputs: { change: "change" }, providers: [
88
+ {
89
+ provide: NG_VALUE_ACCESSOR,
90
+ useExisting: forwardRef(() => ChooseGeneralItemComponent),
91
+ multi: true,
92
+ },
93
+ ], ngImport: i0, template: "<div class=\"select\">\r\n <ng-select [hideSelected]=\"hideSelectedItem\" [closeOnSelect]=\"!isMultiple\" [ngStyle]=\"setWidth()\" class=\"component\"\r\n [disabled]=\"disabled\" [appendTo]=\"appendTo\" dropdownPosition=\"bottom\" (blur)=\"updateBlur()\" [bindLabel]=\"label\"\r\n bindValue=\"id\" [compareWith]=\"\" [items]=\"items\" [placeholder]=\"placeholder\"\r\n (change)=\"onSelectedItemChanged($event)\" [(ngModel)]=\"selectedItemId\" [multiple]=\"isMultiple\">\r\n <ng-template *ngIf=\"!isChip\" class=\"template\" ng-option-tmp ng-label-tmp let-item=\"item\" let-index=\"index\"\r\n let-search=\"searchTerm\">\r\n <span [ngStyle]=\"setFontStyles()\" *ngFor=\"let object of objects let isLast = last\">\r\n <span *ngIf=\"showLabel && !isTypeDate\">\r\n {{object.label}}: {{item[object.field]}} {{isLast ? \"\" : separator}}\r\n </span>\r\n <span *ngIf=\"showLabel && isTypeDate\">\r\n {{object.label}}: {{item[object.field]| date: 'mediumDate'}} {{isLast ? \"\" : separator}}\r\n </span>\r\n <span *ngIf=\"!showLabel && isTypeDate\">\r\n {{item[object.field]| date: 'mediumDate'}} {{isLast ? \"\" : separator}}\r\n </span>\r\n <span *ngIf=\"!showLabel && !isTypeDate\">{{item[object.field]}}{{isLast ? \"\" : separator}}\r\n </span>\r\n </span>\r\n </ng-template>\r\n <ng-template *ngIf=\"isChip\" ng-label-tmp let-item=\"item\" let-clear=\"clear\">\r\n <ng-chip (mousedown)=\"$event.stopPropagation()\" [clear]=\"clear\" [withCross]=\"isMultiple\" [item]=\"item\"\r\n class=\"chip\" [backgroundColor]=\"chipColor\" [label]=\"item[objects[0].field]\"\r\n [width]=\"chipWidth\">\r\n </ng-chip>\r\n </ng-template>\r\n <ng-template *ngIf=\"isChip\" ng-option-tmp let-clear=\"clear\" let-item=\"item\">\r\n <ng-chip (mousedown)=\"$event.stopPropagation()\" [clear]=\"clear\" [withCross]=\"false\" [item]=\"item\"\r\n class=\"chip\" [backgroundColor]=\"chipColor\" [label]=\"item[objects[0].field]\"\r\n [width]=\"chipWidth\">\r\n </ng-chip>\r\n </ng-template>\r\n </ng-select>\r\n</div>", styles: [""], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i3.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: i3.NgOptionTemplateDirective, selector: "[ng-option-tmp]" }, { kind: "directive", type: i3.NgLabelTemplateDirective, selector: "[ng-label-tmp]" }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i5.NgChipComponent, selector: "ng-chip", inputs: ["backgroundColor", "size", "clear", "customColors", "enumClass", "enumValue", "inputType", "item", "isClickable", "label", "width", "withCross"] }, { kind: "pipe", type: i2.DatePipe, name: "date" }] });
94
+ }
95
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ChooseGeneralItemComponent, decorators: [{
96
+ type: Component,
97
+ args: [{ selector: 'choose-general-item', providers: [
98
+ {
99
+ provide: NG_VALUE_ACCESSOR,
100
+ useExisting: forwardRef(() => ChooseGeneralItemComponent),
101
+ multi: true,
102
+ },
103
+ ], template: "<div class=\"select\">\r\n <ng-select [hideSelected]=\"hideSelectedItem\" [closeOnSelect]=\"!isMultiple\" [ngStyle]=\"setWidth()\" class=\"component\"\r\n [disabled]=\"disabled\" [appendTo]=\"appendTo\" dropdownPosition=\"bottom\" (blur)=\"updateBlur()\" [bindLabel]=\"label\"\r\n bindValue=\"id\" [compareWith]=\"\" [items]=\"items\" [placeholder]=\"placeholder\"\r\n (change)=\"onSelectedItemChanged($event)\" [(ngModel)]=\"selectedItemId\" [multiple]=\"isMultiple\">\r\n <ng-template *ngIf=\"!isChip\" class=\"template\" ng-option-tmp ng-label-tmp let-item=\"item\" let-index=\"index\"\r\n let-search=\"searchTerm\">\r\n <span [ngStyle]=\"setFontStyles()\" *ngFor=\"let object of objects let isLast = last\">\r\n <span *ngIf=\"showLabel && !isTypeDate\">\r\n {{object.label}}: {{item[object.field]}} {{isLast ? \"\" : separator}}\r\n </span>\r\n <span *ngIf=\"showLabel && isTypeDate\">\r\n {{object.label}}: {{item[object.field]| date: 'mediumDate'}} {{isLast ? \"\" : separator}}\r\n </span>\r\n <span *ngIf=\"!showLabel && isTypeDate\">\r\n {{item[object.field]| date: 'mediumDate'}} {{isLast ? \"\" : separator}}\r\n </span>\r\n <span *ngIf=\"!showLabel && !isTypeDate\">{{item[object.field]}}{{isLast ? \"\" : separator}}\r\n </span>\r\n </span>\r\n </ng-template>\r\n <ng-template *ngIf=\"isChip\" ng-label-tmp let-item=\"item\" let-clear=\"clear\">\r\n <ng-chip (mousedown)=\"$event.stopPropagation()\" [clear]=\"clear\" [withCross]=\"isMultiple\" [item]=\"item\"\r\n class=\"chip\" [backgroundColor]=\"chipColor\" [label]=\"item[objects[0].field]\"\r\n [width]=\"chipWidth\">\r\n </ng-chip>\r\n </ng-template>\r\n <ng-template *ngIf=\"isChip\" ng-option-tmp let-clear=\"clear\" let-item=\"item\">\r\n <ng-chip (mousedown)=\"$event.stopPropagation()\" [clear]=\"clear\" [withCross]=\"false\" [item]=\"item\"\r\n class=\"chip\" [backgroundColor]=\"chipColor\" [label]=\"item[objects[0].field]\"\r\n [width]=\"chipWidth\">\r\n </ng-chip>\r\n </ng-template>\r\n </ng-select>\r\n</div>" }]
104
+ }], ctorParameters: function () { return [{ type: i1.ChooseGeneralItemService }]; }, propDecorators: { change: [{
105
+ type: Output
106
+ }], items: [{
107
+ type: Input
108
+ }], label: [{
109
+ type: Input
110
+ }], appendTo: [{
111
+ type: Input
112
+ }], placeholder: [{
113
+ type: Input
114
+ }], apiPath: [{
115
+ type: Input
116
+ }], isMultiple: [{
117
+ type: Input
118
+ }], hideSelectedItem: [{
119
+ type: Input
120
+ }], objects: [{
121
+ type: Input
122
+ }], showLabel: [{
123
+ type: Input
124
+ }], separator: [{
125
+ type: Input
126
+ }], width: [{
127
+ type: Input
128
+ }], fontWeight: [{
129
+ type: Input
130
+ }], fontSize: [{
131
+ type: Input
132
+ }], isChip: [{
133
+ type: Input
134
+ }], isTypeDate: [{
135
+ type: Input
136
+ }], chipColor: [{
137
+ type: Input
138
+ }], chipTextColor: [{
139
+ type: Input
140
+ }], chipWidth: [{
141
+ type: Input
142
+ }], selectedItemId: [{
143
+ type: Input
144
+ }], disabled: [{
145
+ type: Input
146
+ }], useFullObject: [{
147
+ type: Input
148
+ }] } });
149
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"choose-general-item.component.js","sourceRoot":"","sources":["../../../../../projects/inputs/src/lib/choose-general-item/choose-general-item.component.ts","../../../../../projects/inputs/src/lib/choose-general-item/choose-general-item.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,UAAU,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;AAC3F,OAAO,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;;;;;;;AAgBzE,MAAM,OAAO,0BAA0B;IAyB3B;IAxBA,MAAM,GAAG,IAAI,YAAY,EAAE,CAAC;IAC7B,KAAK,CAAQ;IACb,KAAK,CAAS;IACd,QAAQ,CAAS;IACjB,WAAW,CAAS;IACpB,OAAO,CAAS;IAChB,UAAU,CAAU;IACpB,gBAAgB,CAAU;IAC1B,OAAO,CAAkB;IACzB,SAAS,CAAU;IACnB,SAAS,CAAS;IAClB,KAAK,GAAW,EAAE,CAAC;IACnB,UAAU,CAAS;IACnB,QAAQ,CAAS;IACjB,MAAM,GAAY,KAAK,CAAC;IACxB,UAAU,CAAU;IACpB,SAAS,GAAW,OAAO,CAAC;IAC5B,aAAa,GAAW,OAAO,CAAC;IAChC,SAAS,GAAW,EAAE,CAAC;IACvB,cAAc,CAAoB;IAClC,QAAQ,CAAU;IAClB,aAAa,GAAY,KAAK,CAAC;IAExC,YACU,yBAAmD;QAAnD,8BAAyB,GAAzB,yBAAyB,CAA0B;IACzD,CAAC;IAEL,QAAQ;QACN,IAAI,CAAC,IAAI,CAAC,KAAK;YACb,IAAI,CAAC,OAAO,EAAE,CAAC;IACnB,CAAC;IAED,UAAU,CAAC,IAAS;QAClB,IAAI,IAAI,IAAI,SAAS,EAAE;YACrB,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;SAC5B;aACI,IAAI,IAAI,IAAI,IAAI,EAAE;YACrB,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;SAC5B;IACH,CAAC;IAEM,gBAAgB,CAAC,EAAO;QAC7B,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;IAC5B,CAAC;IAEM,iBAAiB,CAAC,EAAO;QAC9B,IAAI,CAAC,cAAc,GAAG,EAAE,CAAC;IAC3B,CAAC;IAEO,eAAe,GAAG,CAAC,CAAM,EAAE,EAAE,GAAG,CAAC,CAAC;IAClC,cAAc,GAAG,GAAG,EAAE,GAAG,CAAC,CAAC;IAEnC,UAAU;QACR,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAED,qBAAqB,CAAC,MAAM;QAC1B,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QACxE,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;IACtE,CAAC;IAED,OAAO;QACL,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,IAAI,CAAC,yBAAyB,CAAC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,SAAS,CAAC;gBAC7D,IAAI,EAAE,CAAC,QAAe,EAAE,EAAE;oBACxB,IAAI,CAAC,KAAK,GAAG,QAAQ,CAAC;gBACxB,CAAC;gBACD,KAAK,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,OAAO,EAAE,KAAK,CAAC;aAChD,CAAC,CAAA;SACH;IACH,CAAC;IAED,QAAQ;QACN,IAAI,KAAK,GAAG;YACV,KAAK,EAAE,IAAI,CAAC,KAAK,GAAG,KAAK;SAC1B,CAAA;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IAED,aAAa;QACX,IAAI,SAAS,GAAG;YACd,UAAU,EAAE,IAAI,CAAC,UAAU;YAC3B,QAAQ,EAAE,IAAI,CAAC,QAAQ,GAAG,KAAK;SAChC,CAAA;QACD,OAAO,SAAS,CAAC;IACnB,CAAC;wGAtFU,0BAA0B;4FAA1B,0BAA0B,ulBAR1B;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,0BAA0B,CAAC;gBACzD,KAAK,EAAE,IAAI;aACZ;SACF,0BCfH,w0EAkCM;;4FDjBO,0BAA0B;kBAZtC,SAAS;+BACE,qBAAqB,aAGpB;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,2BAA2B,CAAC;4BACzD,KAAK,EAAE,IAAI;yBACZ;qBACF;+GAGS,MAAM;sBAAf,MAAM;gBACE,KAAK;sBAAb,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,gBAAgB;sBAAxB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,aAAa;sBAArB,KAAK","sourcesContent":["import { Component, EventEmitter, forwardRef, Input, OnInit, Output } from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { LabelAndField } from '../models/label-and-field.model';\r\nimport { ChooseGeneralItemService } from './choose-general-item.service';\r\n\r\n@Component({\r\n  selector: 'choose-general-item',\r\n  templateUrl: './choose-general-item.component.html',\r\n  styleUrls: ['./choose-general-item.component.scss'],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => ChooseGeneralItemComponent),\r\n      multi: true,\r\n    },\r\n  ],\r\n})\r\nexport class ChooseGeneralItemComponent implements OnInit, ControlValueAccessor {\r\n  @Output() change = new EventEmitter();\r\n  @Input() items: any[];\r\n  @Input() label: string;\r\n  @Input() appendTo: string;\r\n  @Input() placeholder: string;\r\n  @Input() apiPath: string;\r\n  @Input() isMultiple: boolean;\r\n  @Input() hideSelectedItem: boolean;\r\n  @Input() objects: LabelAndField[];\r\n  @Input() showLabel: boolean;\r\n  @Input() separator: string;\r\n  @Input() width: number = 20;\r\n  @Input() fontWeight: number;\r\n  @Input() fontSize: number;\r\n  @Input() isChip: Boolean = false;\r\n  @Input() isTypeDate: boolean;\r\n  @Input() chipColor: string = 'black';\r\n  @Input() chipTextColor: string = 'white';\r\n  @Input() chipWidth: number = 11;\r\n  @Input() selectedItemId: number | number[];\r\n  @Input() disabled: boolean;\r\n  @Input() useFullObject: boolean = false;\r\n\r\n  constructor(\r\n    private _ChooseGeneralItemService: ChooseGeneralItemService\r\n  ) { }\r\n\r\n  ngOnInit(): void {\r\n    if (!this.items)\r\n      this.getData();\r\n  }\r\n\r\n  writeValue(item: any) {\r\n    if (item != undefined) {\r\n      this.selectedItemId = item;\r\n    }\r\n    else if (item == null) {\r\n      this.selectedItemId = item;\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  }\r\n\r\n  onSelectedItemChanged($event) {\r\n    this.propagateChange(this.useFullObject ? $event : this.selectedItemId);\r\n    this.change.emit(this.useFullObject ? $event : this.selectedItemId);\r\n  }\r\n\r\n  getData() {\r\n    if (this.apiPath) {\r\n      this._ChooseGeneralItemService.getData(this.apiPath).subscribe({\r\n        next: (response: any[]) => {\r\n          this.items = response;\r\n        },\r\n        error: (error) => console.error(\"error\", error)\r\n      })\r\n    }\r\n  }\r\n\r\n  setWidth() {\r\n    let style = {\r\n      width: this.width + \"rem\"\r\n    }\r\n    return style;\r\n  }\r\n\r\n  setFontStyles() {\r\n    let fontStyle = {\r\n      fontWeight: this.fontWeight,\r\n      fontSize: this.fontSize + \"rem\",\r\n    }\r\n    return fontStyle;\r\n  }\r\n}\r\n","<div class=\"select\">\r\n    <ng-select [hideSelected]=\"hideSelectedItem\" [closeOnSelect]=\"!isMultiple\" [ngStyle]=\"setWidth()\" class=\"component\"\r\n        [disabled]=\"disabled\" [appendTo]=\"appendTo\" dropdownPosition=\"bottom\" (blur)=\"updateBlur()\" [bindLabel]=\"label\"\r\n        bindValue=\"id\" [compareWith]=\"\" [items]=\"items\" [placeholder]=\"placeholder\"\r\n        (change)=\"onSelectedItemChanged($event)\" [(ngModel)]=\"selectedItemId\" [multiple]=\"isMultiple\">\r\n        <ng-template *ngIf=\"!isChip\" class=\"template\" ng-option-tmp ng-label-tmp let-item=\"item\" let-index=\"index\"\r\n            let-search=\"searchTerm\">\r\n            <span [ngStyle]=\"setFontStyles()\" *ngFor=\"let object of objects let isLast = last\">\r\n                <span *ngIf=\"showLabel && !isTypeDate\">\r\n                    {{object.label}}: {{item[object.field]}} {{isLast ? \"\" : separator}}\r\n                </span>\r\n                <span *ngIf=\"showLabel && isTypeDate\">\r\n                    {{object.label}}: {{item[object.field]| date: 'mediumDate'}} {{isLast ? \"\" : separator}}\r\n                </span>\r\n                <span *ngIf=\"!showLabel && isTypeDate\">\r\n                    {{item[object.field]| date: 'mediumDate'}} {{isLast ? \"\" : separator}}\r\n                </span>\r\n                <span *ngIf=\"!showLabel && !isTypeDate\">{{item[object.field]}}{{isLast ? \"\" : separator}}\r\n                </span>\r\n            </span>\r\n        </ng-template>\r\n        <ng-template *ngIf=\"isChip\" ng-label-tmp let-item=\"item\" let-clear=\"clear\">\r\n            <ng-chip (mousedown)=\"$event.stopPropagation()\" [clear]=\"clear\" [withCross]=\"isMultiple\" [item]=\"item\"\r\n                class=\"chip\" [backgroundColor]=\"chipColor\" [label]=\"item[objects[0].field]\"\r\n                [width]=\"chipWidth\">\r\n            </ng-chip>\r\n        </ng-template>\r\n        <ng-template *ngIf=\"isChip\" ng-option-tmp let-clear=\"clear\" let-item=\"item\">\r\n            <ng-chip (mousedown)=\"$event.stopPropagation()\" [clear]=\"clear\" [withCross]=\"false\" [item]=\"item\"\r\n                class=\"chip\" [backgroundColor]=\"chipColor\" [label]=\"item[objects[0].field]\"\r\n                [width]=\"chipWidth\">\r\n            </ng-chip>\r\n        </ng-template>\r\n    </ng-select>\r\n</div>"]}
@@ -0,0 +1,45 @@
1
+ import { Inject, Injectable } from '@angular/core';
2
+ import { HttpHeaders } from '@angular/common/http';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "@angular/common/http";
5
+ // import { environment } from '../../environments/environment';
6
+ export class ChooseGeneralItemService {
7
+ http;
8
+ env;
9
+ // baseUrl: string = environment.apiURL;
10
+ constructor(http, env) {
11
+ this.http = http;
12
+ this.env = env;
13
+ } //we have an issue with this line of code...can we meet to resolve it!
14
+ getHeaders() {
15
+ const token = localStorage.getItem("token");
16
+ const httpHeaders = new HttpHeaders({
17
+ 'Content-Type': "application/json",
18
+ 'Authorization': 'Token ' + token
19
+ });
20
+ return { headers: httpHeaders };
21
+ }
22
+ getAuthenticationHeadersWithQueryParams(params) {
23
+ const token = localStorage.getItem("token");
24
+ const httpHeaders = new HttpHeaders({
25
+ 'Content-Type': "application/json",
26
+ 'Authorization': 'Token ' + token
27
+ });
28
+ return { headers: httpHeaders, params: params };
29
+ }
30
+ getData(apiPath) {
31
+ return this.http.get(`${this.env.apiURL}${apiPath}`, this.getHeaders());
32
+ }
33
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ChooseGeneralItemService, deps: [{ token: i1.HttpClient }, { token: 'env' }], target: i0.ɵɵFactoryTarget.Injectable });
34
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ChooseGeneralItemService, providedIn: 'root' });
35
+ }
36
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ChooseGeneralItemService, decorators: [{
37
+ type: Injectable,
38
+ args: [{
39
+ providedIn: 'root'
40
+ }]
41
+ }], ctorParameters: function () { return [{ type: i1.HttpClient }, { type: undefined, decorators: [{
42
+ type: Inject,
43
+ args: ['env']
44
+ }] }]; } });
45
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hvb3NlLWdlbmVyYWwtaXRlbS5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvaW5wdXRzL3NyYy9saWIvY2hvb3NlLWdlbmVyYWwtaXRlbS9jaG9vc2UtZ2VuZXJhbC1pdGVtLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLE1BQU0sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbkQsT0FBTyxFQUFjLFdBQVcsRUFBRSxNQUFNLHNCQUFzQixDQUFDOzs7QUFFL0QsZ0VBQWdFO0FBS2hFLE1BQU0sT0FBTyx3QkFBd0I7SUFHZjtJQUF5QztJQUY3RCx3Q0FBd0M7SUFFeEMsWUFBb0IsSUFBZ0IsRUFBeUIsR0FBRztRQUE1QyxTQUFJLEdBQUosSUFBSSxDQUFZO1FBQXlCLFFBQUcsR0FBSCxHQUFHLENBQUE7SUFBSSxDQUFDLENBQUEsc0VBQXNFO0lBRTNJLFVBQVU7UUFDUixNQUFNLEtBQUssR0FBRyxZQUFZLENBQUMsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQzVDLE1BQU0sV0FBVyxHQUFHLElBQUksV0FBVyxDQUNqQztZQUNFLGNBQWMsRUFBRSxrQkFBa0I7WUFDbEMsZUFBZSxFQUFFLFFBQVEsR0FBRyxLQUFLO1NBQ2xDLENBQUMsQ0FBQztRQUNMLE9BQU8sRUFBRSxPQUFPLEVBQUUsV0FBVyxFQUFFLENBQUM7SUFDbEMsQ0FBQztJQUVELHVDQUF1QyxDQUFDLE1BQU07UUFDNUMsTUFBTSxLQUFLLEdBQUcsWUFBWSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUM1QyxNQUFNLFdBQVcsR0FBRyxJQUFJLFdBQVcsQ0FDakM7WUFDRSxjQUFjLEVBQUUsa0JBQWtCO1lBQ2xDLGVBQWUsRUFBRSxRQUFRLEdBQUcsS0FBSztTQUNsQyxDQUNGLENBQUM7UUFDRixPQUFPLEVBQUUsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLEVBQUUsTUFBTSxFQUFFLENBQUM7SUFDbEQsQ0FBQztJQUVELE9BQU8sQ0FBQyxPQUFlO1FBQ3JCLE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLE1BQU0sR0FBRyxPQUFPLEVBQUUsRUFBRSxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUMsQ0FBQztJQUMxRSxDQUFDO3dHQTVCVSx3QkFBd0IsNENBR1csS0FBSzs0R0FIeEMsd0JBQXdCLGNBRnZCLE1BQU07OzRGQUVQLHdCQUF3QjtrQkFIcEMsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkI7OzBCQUl3QyxNQUFNOzJCQUFDLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3QsIEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgSHR0cENsaWVudCwgSHR0cEhlYWRlcnMgfSBmcm9tICdAYW5ndWxhci9jb21tb24vaHR0cCc7XHJcbmltcG9ydCB7IE9ic2VydmFibGUgfSBmcm9tICdyeGpzJztcclxuLy8gaW1wb3J0IHsgZW52aXJvbm1lbnQgfSBmcm9tICcuLi8uLi9lbnZpcm9ubWVudHMvZW52aXJvbm1lbnQnO1xyXG5cclxuQEluamVjdGFibGUoe1xyXG4gIHByb3ZpZGVkSW46ICdyb290J1xyXG59KVxyXG5leHBvcnQgY2xhc3MgQ2hvb3NlR2VuZXJhbEl0ZW1TZXJ2aWNlIHtcclxuICAvLyBiYXNlVXJsOiBzdHJpbmcgPSBlbnZpcm9ubWVudC5hcGlVUkw7XHJcblxyXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgaHR0cDogSHR0cENsaWVudCwgQEluamVjdCgnZW52JykgcHJpdmF0ZSBlbnYpIHsgfS8vd2UgaGF2ZSBhbiBpc3N1ZSB3aXRoIHRoaXMgbGluZSBvZiBjb2RlLi4uY2FuIHdlIG1lZXQgdG8gcmVzb2x2ZSBpdCFcclxuXHJcbiAgZ2V0SGVhZGVycygpIHtcclxuICAgIGNvbnN0IHRva2VuID0gbG9jYWxTdG9yYWdlLmdldEl0ZW0oXCJ0b2tlblwiKTtcclxuICAgIGNvbnN0IGh0dHBIZWFkZXJzID0gbmV3IEh0dHBIZWFkZXJzKFxyXG4gICAgICB7XHJcbiAgICAgICAgJ0NvbnRlbnQtVHlwZSc6IFwiYXBwbGljYXRpb24vanNvblwiLFxyXG4gICAgICAgICdBdXRob3JpemF0aW9uJzogJ1Rva2VuICcgKyB0b2tlblxyXG4gICAgICB9KTtcclxuICAgIHJldHVybiB7IGhlYWRlcnM6IGh0dHBIZWFkZXJzIH07XHJcbiAgfVxyXG5cclxuICBnZXRBdXRoZW50aWNhdGlvbkhlYWRlcnNXaXRoUXVlcnlQYXJhbXMocGFyYW1zKSB7XHJcbiAgICBjb25zdCB0b2tlbiA9IGxvY2FsU3RvcmFnZS5nZXRJdGVtKFwidG9rZW5cIik7XHJcbiAgICBjb25zdCBodHRwSGVhZGVycyA9IG5ldyBIdHRwSGVhZGVycyhcclxuICAgICAge1xyXG4gICAgICAgICdDb250ZW50LVR5cGUnOiBcImFwcGxpY2F0aW9uL2pzb25cIixcclxuICAgICAgICAnQXV0aG9yaXphdGlvbic6ICdUb2tlbiAnICsgdG9rZW5cclxuICAgICAgfVxyXG4gICAgKTtcclxuICAgIHJldHVybiB7IGhlYWRlcnM6IGh0dHBIZWFkZXJzLCBwYXJhbXM6IHBhcmFtcyB9O1xyXG4gIH1cclxuXHJcbiAgZ2V0RGF0YShhcGlQYXRoOiBzdHJpbmcpOiBPYnNlcnZhYmxlPGFueT4ge1xyXG4gICAgcmV0dXJuIHRoaXMuaHR0cC5nZXQoYCR7dGhpcy5lbnYuYXBpVVJMfSR7YXBpUGF0aH1gLCB0aGlzLmdldEhlYWRlcnMoKSk7XHJcbiAgfVxyXG59XHJcbiJdfQ==
@@ -0,0 +1,37 @@
1
+ import { Component } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "../choose-general-item/choose-general-item.component";
4
+ export class ChooseGeneralItemRendererComponent {
5
+ params;
6
+ formControlValue;
7
+ key;
8
+ itemId;
9
+ rowId;
10
+ constructor() { }
11
+ agInit(params) {
12
+ this.params = params;
13
+ this.itemId = params.data.id;
14
+ this.key = params.context.createKey(params.columnApi, params.column);
15
+ this.rowId = params.node.id;
16
+ }
17
+ onCellDataChanged($event) {
18
+ let value = $event;
19
+ this.formControlValue = this.params.context.formGroup.get("entries").at(this.rowId);
20
+ this.formControlValue.get(this.key).setValue(value);
21
+ const params = {
22
+ value: value,
23
+ rowNode: this.params.node,
24
+ };
25
+ this.params.onCellValueChanged(params);
26
+ }
27
+ refresh(params) {
28
+ return true;
29
+ }
30
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ChooseGeneralItemRendererComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
31
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ChooseGeneralItemRendererComponent, selector: "choose-general-item-renderer", ngImport: i0, template: "<choose-general-item [label]=\"params.label\" [appendTo]=\"'body'\" [placeholder]=\"params.placeholder\"\r\n [apiPath]=\"params.apiPath\" [isMultiple]=\"params.isMultiple\" [objects]=\"params.objects\"\r\n [showLabel]=\"params.showLabel\" [separator]=\"params.separator\" [width]=\"params.width\"\r\n [fontWeight]=\"params.fontWeight\" [fontSize]=\"params.fontSize\" [isChip]=\"params.isChip\"\r\n [isTypeDate]=\"params.isTypeDate\" [chipColor]=\"params.chipColor\" [chipTextColor]=\"params.chipTextColor\"\r\n [chipWidth]=\"params.chipWidth\" [selectedItemId]=\"itemId\" [disabled]=\"params.disabled\"\r\n (change)=\"onCellDataChanged($event)\">\r\n</choose-general-item>", styles: [""], dependencies: [{ kind: "component", type: i1.ChooseGeneralItemComponent, selector: "choose-general-item", inputs: ["items", "label", "appendTo", "placeholder", "apiPath", "isMultiple", "hideSelectedItem", "objects", "showLabel", "separator", "width", "fontWeight", "fontSize", "isChip", "isTypeDate", "chipColor", "chipTextColor", "chipWidth", "selectedItemId", "disabled", "useFullObject"], outputs: ["change"] }] });
32
+ }
33
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ChooseGeneralItemRendererComponent, decorators: [{
34
+ type: Component,
35
+ args: [{ selector: 'choose-general-item-renderer', template: "<choose-general-item [label]=\"params.label\" [appendTo]=\"'body'\" [placeholder]=\"params.placeholder\"\r\n [apiPath]=\"params.apiPath\" [isMultiple]=\"params.isMultiple\" [objects]=\"params.objects\"\r\n [showLabel]=\"params.showLabel\" [separator]=\"params.separator\" [width]=\"params.width\"\r\n [fontWeight]=\"params.fontWeight\" [fontSize]=\"params.fontSize\" [isChip]=\"params.isChip\"\r\n [isTypeDate]=\"params.isTypeDate\" [chipColor]=\"params.chipColor\" [chipTextColor]=\"params.chipTextColor\"\r\n [chipWidth]=\"params.chipWidth\" [selectedItemId]=\"itemId\" [disabled]=\"params.disabled\"\r\n (change)=\"onCellDataChanged($event)\">\r\n</choose-general-item>" }]
36
+ }], ctorParameters: function () { return []; } });
37
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hvb3NlLWdlbmVyYWwtaXRlbS1yZW5kZXJlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9pbnB1dHMvc3JjL2xpYi9jaG9vc2UtZ2VuZXJhbC1pdGVtLXJlbmRlcmVyL2Nob29zZS1nZW5lcmFsLWl0ZW0tcmVuZGVyZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvaW5wdXRzL3NyYy9saWIvY2hvb3NlLWdlbmVyYWwtaXRlbS1yZW5kZXJlci9jaG9vc2UtZ2VuZXJhbC1pdGVtLXJlbmRlcmVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7OztBQVExQyxNQUFNLE9BQU8sa0NBQWtDO0lBQzdDLE1BQU0sQ0FBTTtJQUNaLGdCQUFnQixDQUFDO0lBQ2pCLEdBQUcsQ0FBQztJQUNKLE1BQU0sQ0FBUztJQUNmLEtBQUssQ0FBUztJQUVkLGdCQUFnQixDQUFDO0lBRWpCLE1BQU0sQ0FBQyxNQUFXO1FBQ2hCLElBQUksQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFDO1FBQ3JCLElBQUksQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUM7UUFDN0IsSUFBSSxDQUFDLEdBQUcsR0FBRyxNQUFNLENBQUMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsU0FBUyxFQUFFLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUNyRSxJQUFJLENBQUMsS0FBSyxHQUFHLE1BQU0sQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDO0lBQzlCLENBQUM7SUFFRCxpQkFBaUIsQ0FBQyxNQUFNO1FBQ3RCLElBQUksS0FBSyxHQUFRLE1BQU0sQ0FBQztRQUN4QixJQUFJLENBQUMsZ0JBQWdCLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxTQUFTLENBQUMsQ0FBQyxFQUFFLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ3BGLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUNwRCxNQUFNLE1BQU0sR0FBRztZQUNiLEtBQUssRUFBRSxLQUFLO1lBQ1osT0FBTyxFQUFFLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSTtTQUMxQixDQUFDO1FBQ0YsSUFBSSxDQUFDLE1BQU0sQ0FBQyxrQkFBa0IsQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUN6QyxDQUFDO0lBRUQsT0FBTyxDQUFDLE1BQVc7UUFDakIsT0FBTyxJQUFJLENBQUE7SUFDYixDQUFDO3dHQTdCVSxrQ0FBa0M7NEZBQWxDLGtDQUFrQyxvRUNSL0Msb3JCQU9zQjs7NEZEQ1Qsa0NBQWtDO2tCQUw5QyxTQUFTOytCQUNFLDhCQUE4QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBJQ2VsbFJlbmRlcmVyQW5ndWxhckNvbXAgfSBmcm9tICdhZy1ncmlkLWFuZ3VsYXInO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdjaG9vc2UtZ2VuZXJhbC1pdGVtLXJlbmRlcmVyJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vY2hvb3NlLWdlbmVyYWwtaXRlbS1yZW5kZXJlci5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vY2hvb3NlLWdlbmVyYWwtaXRlbS1yZW5kZXJlci5jb21wb25lbnQuc2NzcyddXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDaG9vc2VHZW5lcmFsSXRlbVJlbmRlcmVyQ29tcG9uZW50IGltcGxlbWVudHMgSUNlbGxSZW5kZXJlckFuZ3VsYXJDb21wIHtcclxuICBwYXJhbXM6IGFueTtcclxuICBmb3JtQ29udHJvbFZhbHVlO1xyXG4gIGtleTtcclxuICBpdGVtSWQ6IG51bWJlcjtcclxuICByb3dJZDogbnVtYmVyO1xyXG5cclxuICBjb25zdHJ1Y3RvcigpIHsgfVxyXG5cclxuICBhZ0luaXQocGFyYW1zOiBhbnkpOiB2b2lkIHtcclxuICAgIHRoaXMucGFyYW1zID0gcGFyYW1zO1xyXG4gICAgdGhpcy5pdGVtSWQgPSBwYXJhbXMuZGF0YS5pZDtcclxuICAgIHRoaXMua2V5ID0gcGFyYW1zLmNvbnRleHQuY3JlYXRlS2V5KHBhcmFtcy5jb2x1bW5BcGksIHBhcmFtcy5jb2x1bW4pO1xyXG4gICAgdGhpcy5yb3dJZCA9IHBhcmFtcy5ub2RlLmlkO1xyXG4gIH1cclxuXHJcbiAgb25DZWxsRGF0YUNoYW5nZWQoJGV2ZW50KSB7XHJcbiAgICBsZXQgdmFsdWU6IGFueSA9ICRldmVudDtcclxuICAgIHRoaXMuZm9ybUNvbnRyb2xWYWx1ZSA9IHRoaXMucGFyYW1zLmNvbnRleHQuZm9ybUdyb3VwLmdldChcImVudHJpZXNcIikuYXQodGhpcy5yb3dJZCk7XHJcbiAgICB0aGlzLmZvcm1Db250cm9sVmFsdWUuZ2V0KHRoaXMua2V5KS5zZXRWYWx1ZSh2YWx1ZSk7XHJcbiAgICBjb25zdCBwYXJhbXMgPSB7XHJcbiAgICAgIHZhbHVlOiB2YWx1ZSxcclxuICAgICAgcm93Tm9kZTogdGhpcy5wYXJhbXMubm9kZSxcclxuICAgIH07XHJcbiAgICB0aGlzLnBhcmFtcy5vbkNlbGxWYWx1ZUNoYW5nZWQocGFyYW1zKTtcclxuICB9XHJcblxyXG4gIHJlZnJlc2gocGFyYW1zOiBhbnkpOiBib29sZWFuIHtcclxuICAgIHJldHVybiB0cnVlXHJcbiAgfVxyXG59XHJcbiIsIjxjaG9vc2UtZ2VuZXJhbC1pdGVtIFtsYWJlbF09XCJwYXJhbXMubGFiZWxcIiBbYXBwZW5kVG9dPVwiJ2JvZHknXCIgW3BsYWNlaG9sZGVyXT1cInBhcmFtcy5wbGFjZWhvbGRlclwiXHJcbiAgICBbYXBpUGF0aF09XCJwYXJhbXMuYXBpUGF0aFwiIFtpc011bHRpcGxlXT1cInBhcmFtcy5pc011bHRpcGxlXCIgW29iamVjdHNdPVwicGFyYW1zLm9iamVjdHNcIlxyXG4gICAgW3Nob3dMYWJlbF09XCJwYXJhbXMuc2hvd0xhYmVsXCIgW3NlcGFyYXRvcl09XCJwYXJhbXMuc2VwYXJhdG9yXCIgW3dpZHRoXT1cInBhcmFtcy53aWR0aFwiXHJcbiAgICBbZm9udFdlaWdodF09XCJwYXJhbXMuZm9udFdlaWdodFwiIFtmb250U2l6ZV09XCJwYXJhbXMuZm9udFNpemVcIiBbaXNDaGlwXT1cInBhcmFtcy5pc0NoaXBcIlxyXG4gICAgW2lzVHlwZURhdGVdPVwicGFyYW1zLmlzVHlwZURhdGVcIiBbY2hpcENvbG9yXT1cInBhcmFtcy5jaGlwQ29sb3JcIiBbY2hpcFRleHRDb2xvcl09XCJwYXJhbXMuY2hpcFRleHRDb2xvclwiXHJcbiAgICBbY2hpcFdpZHRoXT1cInBhcmFtcy5jaGlwV2lkdGhcIiBbc2VsZWN0ZWRJdGVtSWRdPVwiaXRlbUlkXCIgW2Rpc2FibGVkXT1cInBhcmFtcy5kaXNhYmxlZFwiXHJcbiAgICAoY2hhbmdlKT1cIm9uQ2VsbERhdGFDaGFuZ2VkKCRldmVudClcIj5cclxuPC9jaG9vc2UtZ2VuZXJhbC1pdGVtPiJdfQ==
@@ -0,0 +1,53 @@
1
+ import { Component, forwardRef } from '@angular/core';
2
+ import { NG_VALUE_ACCESSOR } from '@angular/forms';
3
+ import { LineTypeModelHelper } from '../models/line-type-model-helper';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "@ng-select/ng-select";
6
+ import * as i2 from "@angular/forms";
7
+ export class ChooseLineTypeComponent {
8
+ items = LineTypeModelHelper;
9
+ selectedItem;
10
+ types;
11
+ constructor() { }
12
+ ngOnInit() {
13
+ this.types = this.items.getItems();
14
+ }
15
+ writeValue(type) {
16
+ if (type != undefined || type != null) {
17
+ this.selectedItem = type;
18
+ }
19
+ }
20
+ registerOnChange(fn) {
21
+ this.propagateChange = fn;
22
+ }
23
+ registerOnTouched(fn) {
24
+ this.propogateTouch = fn;
25
+ }
26
+ propagateChange = (_) => { };
27
+ propogateTouch = () => { };
28
+ updateBlur() {
29
+ this.propogateTouch();
30
+ }
31
+ onSelectedItemChanged() {
32
+ this.propagateChange(this.selectedItem);
33
+ }
34
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ChooseLineTypeComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
35
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ChooseLineTypeComponent, selector: "choose-line-type", providers: [
36
+ {
37
+ provide: NG_VALUE_ACCESSOR,
38
+ useExisting: forwardRef(() => ChooseLineTypeComponent),
39
+ multi: true,
40
+ },
41
+ ], ngImport: i0, template: "<div class=\"select\">\r\n <ng-select class=\"type\" appendTo=\"body\" (blur)=\"updateBlur()\" bindLabel=\"label\" bindValue=\"label\" [items]=\"types\"\r\n [placeholder]=\"'Choose A Component'\" (change)=\"onSelectedItemChanged()\" [(ngModel)]=\"selectedItem\">\r\n <ng-template class=\"template\" ng-option-tmp ng-label-tmp let-item=\"item\" let-index=\"index\">\r\n {{item.label}}\r\n </ng-template>\r\n </ng-select>\r\n</div>", styles: [".type{width:250px}\n"], dependencies: [{ kind: "component", type: i1.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: i1.NgOptionTemplateDirective, selector: "[ng-option-tmp]" }, { kind: "directive", type: i1.NgLabelTemplateDirective, selector: "[ng-label-tmp]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }] });
42
+ }
43
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ChooseLineTypeComponent, decorators: [{
44
+ type: Component,
45
+ args: [{ selector: 'choose-line-type', providers: [
46
+ {
47
+ provide: NG_VALUE_ACCESSOR,
48
+ useExisting: forwardRef(() => ChooseLineTypeComponent),
49
+ multi: true,
50
+ },
51
+ ], template: "<div class=\"select\">\r\n <ng-select class=\"type\" appendTo=\"body\" (blur)=\"updateBlur()\" bindLabel=\"label\" bindValue=\"label\" [items]=\"types\"\r\n [placeholder]=\"'Choose A Component'\" (change)=\"onSelectedItemChanged()\" [(ngModel)]=\"selectedItem\">\r\n <ng-template class=\"template\" ng-option-tmp ng-label-tmp let-item=\"item\" let-index=\"index\">\r\n {{item.label}}\r\n </ng-template>\r\n </ng-select>\r\n</div>", styles: [".type{width:250px}\n"] }]
52
+ }], ctorParameters: function () { return []; } });
53
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hvb3NlLWxpbmUtdHlwZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9pbnB1dHMvc3JjL2xpYi9jaG9vc2UtbGluZS10eXBlL2Nob29zZS1saW5lLXR5cGUuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvaW5wdXRzL3NyYy9saWIvY2hvb3NlLWxpbmUtdHlwZS9jaG9vc2UtbGluZS10eXBlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFVLE1BQU0sZUFBZSxDQUFDO0FBQzlELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ25ELE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGtDQUFrQyxDQUFDOzs7O0FBY3ZFLE1BQU0sT0FBTyx1QkFBdUI7SUFDbEMsS0FBSyxHQUFHLG1CQUFtQixDQUFDO0lBQzVCLFlBQVksQ0FBTTtJQUNsQixLQUFLLENBQU07SUFFWCxnQkFBZ0IsQ0FBQztJQUVqQixRQUFRO1FBQ04sSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsRUFBRSxDQUFDO0lBQ3JDLENBQUM7SUFFRCxVQUFVLENBQUMsSUFBUztRQUNsQixJQUFJLElBQUksSUFBSSxTQUFTLElBQUksSUFBSSxJQUFJLElBQUksRUFBRTtZQUNyQyxJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksQ0FBQztTQUMxQjtJQUNILENBQUM7SUFFTSxnQkFBZ0IsQ0FBQyxFQUFPO1FBQzdCLElBQUksQ0FBQyxlQUFlLEdBQUcsRUFBRSxDQUFDO0lBQzVCLENBQUM7SUFFTSxpQkFBaUIsQ0FBQyxFQUFPO1FBQzlCLElBQUksQ0FBQyxjQUFjLEdBQUcsRUFBRSxDQUFDO0lBQzNCLENBQUM7SUFFTyxlQUFlLEdBQUcsQ0FBQyxDQUFNLEVBQUUsRUFBRSxHQUFHLENBQUMsQ0FBQztJQUNsQyxjQUFjLEdBQUcsR0FBRyxFQUFFLEdBQUcsQ0FBQyxDQUFDO0lBRW5DLFVBQVU7UUFDUixJQUFJLENBQUMsY0FBYyxFQUFFLENBQUM7SUFDeEIsQ0FBQztJQUVELHFCQUFxQjtRQUNuQixJQUFJLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsQ0FBQztJQUMxQyxDQUFDO3dHQWxDVSx1QkFBdUI7NEZBQXZCLHVCQUF1QiwyQ0FSdkI7WUFDVDtnQkFDRSxPQUFPLEVBQUUsaUJBQWlCO2dCQUMxQixXQUFXLEVBQUUsVUFBVSxDQUFDLEdBQUcsRUFBRSxDQUFDLHVCQUF1QixDQUFDO2dCQUN0RCxLQUFLLEVBQUUsSUFBSTthQUNaO1NBQ0YsMEJDZEgscWRBT007OzRGRFNPLHVCQUF1QjtrQkFabkMsU0FBUzsrQkFDRSxrQkFBa0IsYUFHakI7d0JBQ1Q7NEJBQ0UsT0FBTyxFQUFFLGlCQUFpQjs0QkFDMUIsV0FBVyxFQUFFLFVBQVUsQ0FBQyxHQUFHLEVBQUUsd0JBQXdCLENBQUM7NEJBQ3RELEtBQUssRUFBRSxJQUFJO3lCQUNaO3FCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBmb3J3YXJkUmVmLCBPbkluaXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgTkdfVkFMVUVfQUNDRVNTT1IgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XHJcbmltcG9ydCB7IExpbmVUeXBlTW9kZWxIZWxwZXIgfSBmcm9tICcuLi9tb2RlbHMvbGluZS10eXBlLW1vZGVsLWhlbHBlcic7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2Nob29zZS1saW5lLXR5cGUnLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9jaG9vc2UtbGluZS10eXBlLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9jaG9vc2UtbGluZS10eXBlLmNvbXBvbmVudC5zY3NzJ10sXHJcbiAgcHJvdmlkZXJzOiBbXHJcbiAgICB7XHJcbiAgICAgIHByb3ZpZGU6IE5HX1ZBTFVFX0FDQ0VTU09SLFxyXG4gICAgICB1c2VFeGlzdGluZzogZm9yd2FyZFJlZigoKSA9PiBDaG9vc2VMaW5lVHlwZUNvbXBvbmVudCksXHJcbiAgICAgIG11bHRpOiB0cnVlLFxyXG4gICAgfSxcclxuICBdLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgQ2hvb3NlTGluZVR5cGVDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xyXG4gIGl0ZW1zID0gTGluZVR5cGVNb2RlbEhlbHBlcjtcclxuICBzZWxlY3RlZEl0ZW06IGFueTtcclxuICB0eXBlczogYW55O1xyXG5cclxuICBjb25zdHJ1Y3RvcigpIHsgfVxyXG5cclxuICBuZ09uSW5pdCgpOiB2b2lkIHtcclxuICAgIHRoaXMudHlwZXMgPSB0aGlzLml0ZW1zLmdldEl0ZW1zKCk7XHJcbiAgfVxyXG5cclxuICB3cml0ZVZhbHVlKHR5cGU6IGFueSkge1xyXG4gICAgaWYgKHR5cGUgIT0gdW5kZWZpbmVkIHx8IHR5cGUgIT0gbnVsbCkge1xyXG4gICAgICB0aGlzLnNlbGVjdGVkSXRlbSA9IHR5cGU7XHJcbiAgICB9XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgcmVnaXN0ZXJPbkNoYW5nZShmbjogYW55KSB7XHJcbiAgICB0aGlzLnByb3BhZ2F0ZUNoYW5nZSA9IGZuO1xyXG4gIH1cclxuXHJcbiAgcHVibGljIHJlZ2lzdGVyT25Ub3VjaGVkKGZuOiBhbnkpIHtcclxuICAgIHRoaXMucHJvcG9nYXRlVG91Y2ggPSBmbjtcclxuICB9XHJcblxyXG4gIHByaXZhdGUgcHJvcGFnYXRlQ2hhbmdlID0gKF86IGFueSkgPT4geyB9O1xyXG4gIHByaXZhdGUgcHJvcG9nYXRlVG91Y2ggPSAoKSA9PiB7IH07XHJcblxyXG4gIHVwZGF0ZUJsdXIoKSB7XHJcbiAgICB0aGlzLnByb3BvZ2F0ZVRvdWNoKCk7XHJcbiAgfVxyXG5cclxuICBvblNlbGVjdGVkSXRlbUNoYW5nZWQoKSB7XHJcbiAgICB0aGlzLnByb3BhZ2F0ZUNoYW5nZSh0aGlzLnNlbGVjdGVkSXRlbSk7XHJcbiAgfVxyXG59XHJcbiIsIjxkaXYgY2xhc3M9XCJzZWxlY3RcIj5cclxuICAgIDxuZy1zZWxlY3QgY2xhc3M9XCJ0eXBlXCIgYXBwZW5kVG89XCJib2R5XCIgKGJsdXIpPVwidXBkYXRlQmx1cigpXCIgYmluZExhYmVsPVwibGFiZWxcIiBiaW5kVmFsdWU9XCJsYWJlbFwiIFtpdGVtc109XCJ0eXBlc1wiXHJcbiAgICAgICAgW3BsYWNlaG9sZGVyXT1cIidDaG9vc2UgQSBDb21wb25lbnQnXCIgKGNoYW5nZSk9XCJvblNlbGVjdGVkSXRlbUNoYW5nZWQoKVwiIFsobmdNb2RlbCldPVwic2VsZWN0ZWRJdGVtXCI+XHJcbiAgICAgICAgPG5nLXRlbXBsYXRlIGNsYXNzPVwidGVtcGxhdGVcIiBuZy1vcHRpb24tdG1wIG5nLWxhYmVsLXRtcCBsZXQtaXRlbT1cIml0ZW1cIiBsZXQtaW5kZXg9XCJpbmRleFwiPlxyXG4gICAgICAgICAgICB7e2l0ZW0ubGFiZWx9fVxyXG4gICAgICAgIDwvbmctdGVtcGxhdGU+XHJcbiAgICA8L25nLXNlbGVjdD5cclxuPC9kaXY+Il19
@@ -0,0 +1,69 @@
1
+ import { Component, Output, EventEmitter, Input, forwardRef } from '@angular/core';
2
+ import { NG_VALUE_ACCESSOR } from '@angular/forms';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "@angular/common";
5
+ import * as i2 from "@ng-select/ng-select";
6
+ import * as i3 from "@angular/forms";
7
+ export class ChooseYesOrNoComponent {
8
+ change = new EventEmitter();
9
+ items = [{ value: true, label: "Yes", color: "green" }, { value: false, label: "No", color: "red" }];
10
+ width = 200;
11
+ selectedItemValue;
12
+ placeholder = "Choose either Yes or No";
13
+ constructor() { }
14
+ ngOnInit() {
15
+ }
16
+ writeValue(item) {
17
+ if (item != undefined || item != null) {
18
+ this.selectedItemValue = item;
19
+ }
20
+ }
21
+ registerOnChange(fn) {
22
+ this.propagateChange = fn;
23
+ }
24
+ registerOnTouched(fn) {
25
+ this.propogateTouch = fn;
26
+ }
27
+ propagateChange = (_) => { };
28
+ propogateTouch = () => { };
29
+ updateBlur() {
30
+ this.propogateTouch();
31
+ }
32
+ onSelectedItemChanged() {
33
+ this.propagateChange(this.selectedItemValue);
34
+ this.change.emit(this.selectedItemValue);
35
+ }
36
+ setWidth() {
37
+ let style = {
38
+ width: this.width + "px"
39
+ };
40
+ return style;
41
+ }
42
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ChooseYesOrNoComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
43
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ChooseYesOrNoComponent, selector: "choose-yes-or-no", inputs: { width: "width", selectedItemValue: "selectedItemValue", placeholder: "placeholder" }, outputs: { change: "change" }, providers: [
44
+ {
45
+ provide: NG_VALUE_ACCESSOR,
46
+ useExisting: forwardRef(() => ChooseYesOrNoComponent),
47
+ multi: true
48
+ }
49
+ ], ngImport: i0, template: "<div class=\"select\">\r\n <ng-select [ngStyle]=\"setWidth()\" class=\"component\" appendTo=\"body\" (blur)=\"updateBlur()\" [placeholder]=\"placeholder\" bindLabel=\"label\"\r\n bindValue=\"value\" [items]=\"items\" [placeholder]=\"placeholder\" (change)=\"onSelectedItemChanged()\"\r\n [(ngModel)]=\"selectedItemValue\" >\r\n <ng-template class=\"template\" ng-option-tmp ng-label-tmp let-item=\"item\" let-index=\"index\"\r\n let-search=\"searchTerm\">\r\n <span [style.color]=\"item.color\">\r\n {{item.label}}\r\n </span>\r\n </ng-template>\r\n </ng-select>\r\n</div>\r\n", styles: [""], dependencies: [{ 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"] }] });
50
+ }
51
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ChooseYesOrNoComponent, decorators: [{
52
+ type: Component,
53
+ args: [{ selector: 'choose-yes-or-no', providers: [
54
+ {
55
+ provide: NG_VALUE_ACCESSOR,
56
+ useExisting: forwardRef(() => ChooseYesOrNoComponent),
57
+ multi: true
58
+ }
59
+ ], template: "<div class=\"select\">\r\n <ng-select [ngStyle]=\"setWidth()\" class=\"component\" appendTo=\"body\" (blur)=\"updateBlur()\" [placeholder]=\"placeholder\" bindLabel=\"label\"\r\n bindValue=\"value\" [items]=\"items\" [placeholder]=\"placeholder\" (change)=\"onSelectedItemChanged()\"\r\n [(ngModel)]=\"selectedItemValue\" >\r\n <ng-template class=\"template\" ng-option-tmp ng-label-tmp let-item=\"item\" let-index=\"index\"\r\n let-search=\"searchTerm\">\r\n <span [style.color]=\"item.color\">\r\n {{item.label}}\r\n </span>\r\n </ng-template>\r\n </ng-select>\r\n</div>\r\n" }]
60
+ }], ctorParameters: function () { return []; }, propDecorators: { change: [{
61
+ type: Output
62
+ }], width: [{
63
+ type: Input
64
+ }], selectedItemValue: [{
65
+ type: Input
66
+ }], placeholder: [{
67
+ type: Input
68
+ }] } });
69
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hvb3NlLXllcy1vci1uby5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9pbnB1dHMvc3JjL2xpYi9jaG9vc2UteWVzLW9yLW5vL2Nob29zZS15ZXMtb3Itbm8uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvaW5wdXRzL3NyYy9saWIvY2hvb3NlLXllcy1vci1uby9jaG9vc2UteWVzLW9yLW5vLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQVUsTUFBTSxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBRTNGLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDOzs7OztBQWFuRCxNQUFNLE9BQU8sc0JBQXNCO0lBRXZCLE1BQU0sR0FBRyxJQUFJLFlBQVksRUFBRSxDQUFDO0lBQ3RDLEtBQUssR0FBYyxDQUFDLEVBQUUsS0FBSyxFQUFFLElBQUksRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFLEtBQUssRUFBRSxPQUFPLEVBQUUsRUFBRSxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFLElBQUksRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFLENBQUMsQ0FBQztJQUN2RyxLQUFLLEdBQVcsR0FBRyxDQUFDO0lBQ3BCLGlCQUFpQixDQUFVO0lBQzNCLFdBQVcsR0FBVyx5QkFBeUIsQ0FBQztJQUV6RCxnQkFBZ0IsQ0FBQztJQUVqQixRQUFRO0lBQ1IsQ0FBQztJQUVELFVBQVUsQ0FBQyxJQUFhO1FBQ3RCLElBQUksSUFBSSxJQUFJLFNBQVMsSUFBSSxJQUFJLElBQUksSUFBSSxFQUFFO1lBQ3JDLElBQUksQ0FBQyxpQkFBaUIsR0FBRyxJQUFJLENBQUM7U0FDL0I7SUFDSCxDQUFDO0lBRU0sZ0JBQWdCLENBQUMsRUFBTztRQUM3QixJQUFJLENBQUMsZUFBZSxHQUFHLEVBQUUsQ0FBQztJQUM1QixDQUFDO0lBRU0saUJBQWlCLENBQUMsRUFBTztRQUM5QixJQUFJLENBQUMsY0FBYyxHQUFHLEVBQUUsQ0FBQztJQUMzQixDQUFDO0lBRU8sZUFBZSxHQUFHLENBQUMsQ0FBTSxFQUFFLEVBQUUsR0FBRyxDQUFDLENBQUM7SUFDbEMsY0FBYyxHQUFHLEdBQUcsRUFBRSxHQUFHLENBQUMsQ0FBQztJQUVuQyxVQUFVO1FBQ1IsSUFBSSxDQUFDLGNBQWMsRUFBRSxDQUFDO0lBQ3hCLENBQUM7SUFFRCxxQkFBcUI7UUFDbkIsSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQUMsaUJBQWlCLENBQUMsQ0FBQztRQUM3QyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsaUJBQWlCLENBQUMsQ0FBQztJQUMzQyxDQUFDO0lBRUQsUUFBUTtRQUNOLElBQUksS0FBSyxHQUFHO1lBQ1YsS0FBSyxFQUFFLElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSTtTQUN6QixDQUFBO1FBQ0QsT0FBTyxLQUFLLENBQUE7SUFDZCxDQUFDO3dHQTVDVSxzQkFBc0I7NEZBQXRCLHNCQUFzQiwwS0FQdEI7WUFDVDtnQkFDRSxPQUFPLEVBQUUsaUJBQWlCO2dCQUMxQixXQUFXLEVBQUUsVUFBVSxDQUFDLEdBQUcsRUFBRSxDQUFDLHNCQUFzQixDQUFDO2dCQUNyRCxLQUFLLEVBQUUsSUFBSTthQUNaO1NBQUMsMEJDYk4sc3BCQVlBOzs0RkRHYSxzQkFBc0I7a0JBWGxDLFNBQVM7K0JBQ0Usa0JBQWtCLGFBR2pCO3dCQUNUOzRCQUNFLE9BQU8sRUFBRSxpQkFBaUI7NEJBQzFCLFdBQVcsRUFBRSxVQUFVLENBQUMsR0FBRyxFQUFFLHVCQUF1QixDQUFDOzRCQUNyRCxLQUFLLEVBQUUsSUFBSTt5QkFDWjtxQkFBQzswRUFJTSxNQUFNO3NCQUFmLE1BQU07Z0JBRUUsS0FBSztzQkFBYixLQUFLO2dCQUNHLGlCQUFpQjtzQkFBekIsS0FBSztnQkFDRyxXQUFXO3NCQUFuQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBPbkluaXQsIE91dHB1dCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgZm9yd2FyZFJlZiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBZZXNPck5vIH0gZnJvbSAnLi4vbW9kZWxzL3llcy1vci1uby5tb2RlbCc7XHJcbmltcG9ydCB7IE5HX1ZBTFVFX0FDQ0VTU09SIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdjaG9vc2UteWVzLW9yLW5vJyxcclxuICB0ZW1wbGF0ZVVybDogJy4vY2hvb3NlLXllcy1vci1uby5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vY2hvb3NlLXllcy1vci1uby5jb21wb25lbnQuc2NzcyddLFxyXG4gIHByb3ZpZGVyczogW1xyXG4gICAge1xyXG4gICAgICBwcm92aWRlOiBOR19WQUxVRV9BQ0NFU1NPUixcclxuICAgICAgdXNlRXhpc3Rpbmc6IGZvcndhcmRSZWYoKCkgPT4gQ2hvb3NlWWVzT3JOb0NvbXBvbmVudCksXHJcbiAgICAgIG11bHRpOiB0cnVlXHJcbiAgICB9XVxyXG59KVxyXG5leHBvcnQgY2xhc3MgQ2hvb3NlWWVzT3JOb0NvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcblxyXG4gIEBPdXRwdXQoKSBjaGFuZ2UgPSBuZXcgRXZlbnRFbWl0dGVyKCk7XHJcbiAgaXRlbXM6IFllc09yTm9bXSA9IFt7IHZhbHVlOiB0cnVlLCBsYWJlbDogXCJZZXNcIiwgY29sb3I6IFwiZ3JlZW5cIiB9LCB7IHZhbHVlOiBmYWxzZSwgbGFiZWw6IFwiTm9cIiwgY29sb3I6IFwicmVkXCIgfV07XHJcbiAgQElucHV0KCkgd2lkdGg6IG51bWJlciA9IDIwMDtcclxuICBASW5wdXQoKSBzZWxlY3RlZEl0ZW1WYWx1ZTogYm9vbGVhbjtcclxuICBASW5wdXQoKSBwbGFjZWhvbGRlcjogc3RyaW5nID0gXCJDaG9vc2UgZWl0aGVyIFllcyBvciBOb1wiO1xyXG5cclxuICBjb25zdHJ1Y3RvcigpIHsgfVxyXG5cclxuICBuZ09uSW5pdCgpOiB2b2lkIHtcclxuICB9XHJcblxyXG4gIHdyaXRlVmFsdWUoaXRlbTogYm9vbGVhbikge1xyXG4gICAgaWYgKGl0ZW0gIT0gdW5kZWZpbmVkIHx8IGl0ZW0gIT0gbnVsbCkge1xyXG4gICAgICB0aGlzLnNlbGVjdGVkSXRlbVZhbHVlID0gaXRlbTtcclxuICAgIH1cclxuICB9XHJcblxyXG4gIHB1YmxpYyByZWdpc3Rlck9uQ2hhbmdlKGZuOiBhbnkpIHtcclxuICAgIHRoaXMucHJvcGFnYXRlQ2hhbmdlID0gZm47XHJcbiAgfVxyXG5cclxuICBwdWJsaWMgcmVnaXN0ZXJPblRvdWNoZWQoZm46IGFueSkge1xyXG4gICAgdGhpcy5wcm9wb2dhdGVUb3VjaCA9IGZuO1xyXG4gIH1cclxuXHJcbiAgcHJpdmF0ZSBwcm9wYWdhdGVDaGFuZ2UgPSAoXzogYW55KSA9PiB7IH07XHJcbiAgcHJpdmF0ZSBwcm9wb2dhdGVUb3VjaCA9ICgpID0+IHsgfTtcclxuXHJcbiAgdXBkYXRlQmx1cigpIHtcclxuICAgIHRoaXMucHJvcG9nYXRlVG91Y2goKTtcclxuICB9XHJcblxyXG4gIG9uU2VsZWN0ZWRJdGVtQ2hhbmdlZCgpIHtcclxuICAgIHRoaXMucHJvcGFnYXRlQ2hhbmdlKHRoaXMuc2VsZWN0ZWRJdGVtVmFsdWUpO1xyXG4gICAgdGhpcy5jaGFuZ2UuZW1pdCh0aGlzLnNlbGVjdGVkSXRlbVZhbHVlKTtcclxuICB9XHJcblxyXG4gIHNldFdpZHRoKCkge1xyXG4gICAgbGV0IHN0eWxlID0ge1xyXG4gICAgICB3aWR0aDogdGhpcy53aWR0aCArIFwicHhcIlxyXG4gICAgfVxyXG4gICAgcmV0dXJuIHN0eWxlXHJcbiAgfVxyXG59XHJcbiIsIjxkaXYgY2xhc3M9XCJzZWxlY3RcIj5cclxuICAgIDxuZy1zZWxlY3QgW25nU3R5bGVdPVwic2V0V2lkdGgoKVwiIGNsYXNzPVwiY29tcG9uZW50XCIgYXBwZW5kVG89XCJib2R5XCIgKGJsdXIpPVwidXBkYXRlQmx1cigpXCIgIFtwbGFjZWhvbGRlcl09XCJwbGFjZWhvbGRlclwiIGJpbmRMYWJlbD1cImxhYmVsXCJcclxuICAgICAgICBiaW5kVmFsdWU9XCJ2YWx1ZVwiIFtpdGVtc109XCJpdGVtc1wiIFtwbGFjZWhvbGRlcl09XCJwbGFjZWhvbGRlclwiIChjaGFuZ2UpPVwib25TZWxlY3RlZEl0ZW1DaGFuZ2VkKClcIlxyXG4gICAgICAgIFsobmdNb2RlbCldPVwic2VsZWN0ZWRJdGVtVmFsdWVcIiA+XHJcbiAgICAgICAgPG5nLXRlbXBsYXRlIGNsYXNzPVwidGVtcGxhdGVcIiBuZy1vcHRpb24tdG1wIG5nLWxhYmVsLXRtcCBsZXQtaXRlbT1cIml0ZW1cIiBsZXQtaW5kZXg9XCJpbmRleFwiXHJcbiAgICAgICAgICAgIGxldC1zZWFyY2g9XCJzZWFyY2hUZXJtXCI+XHJcbiAgICAgICAgICAgIDxzcGFuICBbc3R5bGUuY29sb3JdPVwiaXRlbS5jb2xvclwiPlxyXG4gICAgICAgICAgICAgICAge3tpdGVtLmxhYmVsfX1cclxuICAgICAgICAgICAgPC9zcGFuPlxyXG4gICAgICAgIDwvbmctdGVtcGxhdGU+XHJcbiAgICA8L25nLXNlbGVjdD5cclxuPC9kaXY+XHJcbiJdfQ==
@@ -0,0 +1,33 @@
1
+ import { Component } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "../choose-yes-or-no/choose-yes-or-no.component";
4
+ export class ChooseYesOrNoRendererComponent {
5
+ params;
6
+ formControlValue;
7
+ key;
8
+ booleanValue;
9
+ columnName;
10
+ rowId;
11
+ constructor() { }
12
+ agInit(params) {
13
+ this.params = params;
14
+ this.booleanValue = params.value;
15
+ this.key = params.context.createKey(params.columnApi, params.column);
16
+ this.rowId = params.node.id;
17
+ }
18
+ onCellDataChanged($event) {
19
+ let value = $event;
20
+ this.formControlValue = this.params.context.formGroup.get("entries").at(this.rowId);
21
+ this.formControlValue.get(this.key).setValue(value);
22
+ }
23
+ refresh(params) {
24
+ return false;
25
+ }
26
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ChooseYesOrNoRendererComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
27
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ChooseYesOrNoRendererComponent, selector: "choose-yes-or-no-renderer", ngImport: i0, template: "<choose-yes-or-no [selectedItemValue]=\"booleanValue\" [width]=\"params.width\" (change) =\"onCellDataChanged($event)\" [placeholder]=\"params.placeholder\" ></choose-yes-or-no>", styles: [""], dependencies: [{ kind: "component", type: i1.ChooseYesOrNoComponent, selector: "choose-yes-or-no", inputs: ["width", "selectedItemValue", "placeholder"], outputs: ["change"] }] });
28
+ }
29
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ChooseYesOrNoRendererComponent, decorators: [{
30
+ type: Component,
31
+ args: [{ selector: 'choose-yes-or-no-renderer', template: "<choose-yes-or-no [selectedItemValue]=\"booleanValue\" [width]=\"params.width\" (change) =\"onCellDataChanged($event)\" [placeholder]=\"params.placeholder\" ></choose-yes-or-no>" }]
32
+ }], ctorParameters: function () { return []; } });
33
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hvb3NlLXllcy1vci1uby1yZW5kZXJlci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9pbnB1dHMvc3JjL2xpYi9jaG9vc2UteWVzLW9yLW5vLXJlbmRlcmVyL2Nob29zZS15ZXMtb3Itbm8tcmVuZGVyZXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvaW5wdXRzL3NyYy9saWIvY2hvb3NlLXllcy1vci1uby1yZW5kZXJlci9jaG9vc2UteWVzLW9yLW5vLXJlbmRlcmVyLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxlQUFlLENBQUM7OztBQVMxQyxNQUFNLE9BQU8sOEJBQThCO0lBQ3pDLE1BQU0sQ0FBTTtJQUNaLGdCQUFnQixDQUFDO0lBQ2pCLEdBQUcsQ0FBQztJQUNKLFlBQVksQ0FBVTtJQUN0QixVQUFVLENBQVM7SUFDbkIsS0FBSyxDQUFTO0lBRWQsZ0JBQWdCLENBQUM7SUFHakIsTUFBTSxDQUFDLE1BQVc7UUFDaEIsSUFBSSxDQUFDLE1BQU0sR0FBRyxNQUFNLENBQUM7UUFDckIsSUFBSSxDQUFDLFlBQVksR0FBRyxNQUFNLENBQUMsS0FBSyxDQUFDO1FBQ2pDLElBQUksQ0FBQyxHQUFHLEdBQUcsTUFBTSxDQUFDLE9BQU8sQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLFNBQVMsRUFBRSxNQUFNLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDckUsSUFBSSxDQUFDLEtBQUssR0FBRyxNQUFNLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQztJQUM5QixDQUFDO0lBRUQsaUJBQWlCLENBQUMsTUFBTTtRQUN0QixJQUFJLEtBQUssR0FBUSxNQUFNLENBQUM7UUFDeEIsSUFBSSxDQUFDLGdCQUFnQixHQUFHLElBQUksQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFDLFNBQVMsQ0FBQyxHQUFHLENBQUMsU0FBUyxDQUFDLENBQUMsRUFBRSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUNwRixJQUFJLENBQUMsZ0JBQWdCLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDdEQsQ0FBQztJQUVELE9BQU8sQ0FBQyxNQUFXO1FBQ2pCLE9BQU8sS0FBSyxDQUFDO0lBQ2YsQ0FBQzt3R0ExQlUsOEJBQThCOzRGQUE5Qiw4QkFBOEIsaUVDVDNDLHNMQUE0Szs7NEZEUy9KLDhCQUE4QjtrQkFOMUMsU0FBUzsrQkFDRSwyQkFBMkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgSUNlbGxSZW5kZXJlckFuZ3VsYXJDb21wIH0gZnJvbSAnYWctZ3JpZC1hbmd1bGFyJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnY2hvb3NlLXllcy1vci1uby1yZW5kZXJlcicsXHJcbiAgdGVtcGxhdGVVcmw6ICcuL2Nob29zZS15ZXMtb3Itbm8tcmVuZGVyZXIuY29tcG9uZW50Lmh0bWwnLFxyXG4gIHN0eWxlVXJsczogWycuL2Nob29zZS15ZXMtb3Itbm8tcmVuZGVyZXIuY29tcG9uZW50LnNjc3MnXSxcclxuICBcclxufSlcclxuZXhwb3J0IGNsYXNzIENob29zZVllc09yTm9SZW5kZXJlckNvbXBvbmVudCBpbXBsZW1lbnRzIElDZWxsUmVuZGVyZXJBbmd1bGFyQ29tcCB7XHJcbiAgcGFyYW1zOiBhbnk7XHJcbiAgZm9ybUNvbnRyb2xWYWx1ZTtcclxuICBrZXk7XHJcbiAgYm9vbGVhblZhbHVlOiBib29sZWFuO1xyXG4gIGNvbHVtbk5hbWU6IHN0cmluZztcclxuICByb3dJZDogbnVtYmVyO1xyXG5cclxuICBjb25zdHJ1Y3RvcigpIHsgfVxyXG5cclxuIFxyXG4gIGFnSW5pdChwYXJhbXM6IGFueSkge1xyXG4gICAgdGhpcy5wYXJhbXMgPSBwYXJhbXM7XHJcbiAgICB0aGlzLmJvb2xlYW5WYWx1ZSA9IHBhcmFtcy52YWx1ZTsgXHJcbiAgICB0aGlzLmtleSA9IHBhcmFtcy5jb250ZXh0LmNyZWF0ZUtleShwYXJhbXMuY29sdW1uQXBpLCBwYXJhbXMuY29sdW1uKTtcclxuICAgIHRoaXMucm93SWQgPSBwYXJhbXMubm9kZS5pZDtcclxuICB9XHJcblxyXG4gIG9uQ2VsbERhdGFDaGFuZ2VkKCRldmVudCkge1xyXG4gICAgbGV0IHZhbHVlOiBhbnkgPSAkZXZlbnQ7XHJcbiAgICB0aGlzLmZvcm1Db250cm9sVmFsdWUgPSB0aGlzLnBhcmFtcy5jb250ZXh0LmZvcm1Hcm91cC5nZXQoXCJlbnRyaWVzXCIpLmF0KHRoaXMucm93SWQpO1xyXG4gICAgdGhpcy5mb3JtQ29udHJvbFZhbHVlLmdldCh0aGlzLmtleSkuc2V0VmFsdWUodmFsdWUpO1xyXG4gIH1cclxuXHJcbiAgcmVmcmVzaChwYXJhbXM6IGFueSk6IGJvb2xlYW4ge1xyXG4gICAgcmV0dXJuIGZhbHNlO1xyXG4gIH1cclxuXHJcbn1cclxuIiwiPGNob29zZS15ZXMtb3Itbm8gW3NlbGVjdGVkSXRlbVZhbHVlXT1cImJvb2xlYW5WYWx1ZVwiIFt3aWR0aF09XCJwYXJhbXMud2lkdGhcIiAoY2hhbmdlKSA9XCJvbkNlbGxEYXRhQ2hhbmdlZCgkZXZlbnQpXCIgICAgW3BsYWNlaG9sZGVyXT1cInBhcmFtcy5wbGFjZWhvbGRlclwiID48L2Nob29zZS15ZXMtb3Itbm8+Il19
@@ -1,6 +1,6 @@
1
- export var DropdownActionType;
2
- (function (DropdownActionType) {
3
- DropdownActionType[DropdownActionType["ADD"] = 0] = "ADD";
4
- DropdownActionType[DropdownActionType["MENU"] = 1] = "MENU";
5
- })(DropdownActionType || (DropdownActionType = {}));
1
+ export var DropdownActionType;
2
+ (function (DropdownActionType) {
3
+ DropdownActionType[DropdownActionType["ADD"] = 0] = "ADD";
4
+ DropdownActionType[DropdownActionType["MENU"] = 1] = "MENU";
5
+ })(DropdownActionType || (DropdownActionType = {}));
6
6
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcGRvd24tYWN0aW9uLXR5cGUubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9pbnB1dHMvc3JjL2xpYi9kcm9wZG93bi1hY3Rpb25zL2Ryb3Bkb3duLWFjdGlvbi10eXBlLm1vZGVsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBTixJQUFZLGtCQUdYO0FBSEQsV0FBWSxrQkFBa0I7SUFDMUIseURBQU8sQ0FBQTtJQUNQLDJEQUFRLENBQUE7QUFDWixDQUFDLEVBSFcsa0JBQWtCLEtBQWxCLGtCQUFrQixRQUc3QiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBlbnVtIERyb3Bkb3duQWN0aW9uVHlwZSB7XHJcbiAgICBBREQgPSAwLFxyXG4gICAgTUVOVSA9IDFcclxufSJdfQ==
@@ -0,0 +1,75 @@
1
+ import { Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import { DropdownActionType } from './dropdown-action-type.model';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "@angular/router";
5
+ import * as i2 from "@angular/common";
6
+ import * as i3 from "@angular/material/menu";
7
+ import * as i4 from "@fortawesome/angular-fontawesome";
8
+ export class DropdownActionsComponent {
9
+ _Router;
10
+ dropdownActionTypes = DropdownActionType;
11
+ canRoute = true;
12
+ disabled;
13
+ labelsAndRoutes = [];
14
+ route;
15
+ dropdownActionType = this.dropdownActionTypes.ADD;
16
+ addClicked = new EventEmitter();
17
+ constructor(_Router) {
18
+ this._Router = _Router;
19
+ }
20
+ ngOnInit() {
21
+ this.validateActions();
22
+ }
23
+ validateActions() {
24
+ if (this.dropdownActionType == this.dropdownActionTypes.ADD) {
25
+ if (this.canRoute) {
26
+ if (this.route == "" || this.route == undefined || this.route == null) {
27
+ throw Error("Route needs to be provided.");
28
+ }
29
+ }
30
+ else {
31
+ if (this.route) {
32
+ throw Error("Route shouldn't be provided since canRoute is false");
33
+ }
34
+ }
35
+ }
36
+ else if (this.dropdownActionType == this.dropdownActionTypes.MENU) {
37
+ if (!this.labelsAndRoutes.length) {
38
+ throw Error("A list of labels & Routes need to be provided for the actions menu.");
39
+ }
40
+ }
41
+ else {
42
+ throw Error("Dropdown Action Type is not recognized.");
43
+ }
44
+ }
45
+ onClickAdd($event) {
46
+ $event.preventDefault();
47
+ if (this.canRoute && this.route) {
48
+ this._Router.navigate([this.route]);
49
+ }
50
+ this.addClicked.emit();
51
+ }
52
+ onClickLabel(route, $event) {
53
+ $event.preventDefault();
54
+ this._Router.navigate([route]);
55
+ }
56
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DropdownActionsComponent, deps: [{ token: i1.Router }], target: i0.ɵɵFactoryTarget.Component });
57
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DropdownActionsComponent, selector: "dropdown-actions", inputs: { canRoute: "canRoute", disabled: "disabled", labelsAndRoutes: "labelsAndRoutes", route: "route", dropdownActionType: "dropdownActionType" }, outputs: { addClicked: "addClicked" }, ngImport: i0, template: "<div [ngSwitch]=\"dropdownActionType\">\r\n <a *ngSwitchCase=\"dropdownActionTypes.ADD\" [href]=\"route\"\r\n [ngClass]=\"{'action-enabled':!disabled, 'disabled': disabled}\"\r\n (click)=\"onClickAdd($event)\">\r\n <fa-icon icon=\"plus\"></fa-icon>\r\n </a>\r\n <fa-icon *ngSwitchCase=\"dropdownActionTypes.MENU\"\r\n [ngClass]=\"{'action-enabled':!disabled, 'disabled': disabled}\"\r\n class=\"menu\" [matMenuTriggerFor]=\"menu\"\r\n icon=\"ellipsis-vertical\"></fa-icon>\r\n <mat-menu #menu=\"matMenu\">\r\n <button *ngFor=\"let labelAndRoute of labelsAndRoutes\" mat-menu-item>\r\n <a [href]=\"labelAndRoute.route\"\r\n (click)=\"onClickLabel(labelAndRoute.route, $event)\">{{labelAndRoute.label}}</a>\r\n </button>\r\n </mat-menu>\r\n</div>", styles: [".action-enabled{cursor:pointer;color:#155ed4}.action-enabled:hover{color:#3178eb}.disabled{color:#676767;cursor:initial;pointer-events:none}.menu{font-size:1.8rem;display:flex;align-items:center}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i2.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "component", type: i3.MatMenu, selector: "mat-menu", exportAs: ["matMenu"] }, { kind: "component", type: i3.MatMenuItem, selector: "[mat-menu-item]", inputs: ["disabled", "disableRipple", "role"], exportAs: ["matMenuItem"] }, { kind: "directive", type: i3.MatMenuTrigger, selector: "[mat-menu-trigger-for], [matMenuTriggerFor]", exportAs: ["matMenuTrigger"] }, { kind: "component", type: i4.FaIconComponent, selector: "fa-icon", inputs: ["icon", "title", "spin", "pulse", "mask", "styles", "flip", "size", "pull", "border", "inverse", "symbol", "rotate", "fixedWidth", "classes", "transform", "a11yRole"] }] });
58
+ }
59
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DropdownActionsComponent, decorators: [{
60
+ type: Component,
61
+ args: [{ selector: 'dropdown-actions', template: "<div [ngSwitch]=\"dropdownActionType\">\r\n <a *ngSwitchCase=\"dropdownActionTypes.ADD\" [href]=\"route\"\r\n [ngClass]=\"{'action-enabled':!disabled, 'disabled': disabled}\"\r\n (click)=\"onClickAdd($event)\">\r\n <fa-icon icon=\"plus\"></fa-icon>\r\n </a>\r\n <fa-icon *ngSwitchCase=\"dropdownActionTypes.MENU\"\r\n [ngClass]=\"{'action-enabled':!disabled, 'disabled': disabled}\"\r\n class=\"menu\" [matMenuTriggerFor]=\"menu\"\r\n icon=\"ellipsis-vertical\"></fa-icon>\r\n <mat-menu #menu=\"matMenu\">\r\n <button *ngFor=\"let labelAndRoute of labelsAndRoutes\" mat-menu-item>\r\n <a [href]=\"labelAndRoute.route\"\r\n (click)=\"onClickLabel(labelAndRoute.route, $event)\">{{labelAndRoute.label}}</a>\r\n </button>\r\n </mat-menu>\r\n</div>", styles: [".action-enabled{cursor:pointer;color:#155ed4}.action-enabled:hover{color:#3178eb}.disabled{color:#676767;cursor:initial;pointer-events:none}.menu{font-size:1.8rem;display:flex;align-items:center}\n"] }]
62
+ }], ctorParameters: function () { return [{ type: i1.Router }]; }, propDecorators: { canRoute: [{
63
+ type: Input
64
+ }], disabled: [{
65
+ type: Input
66
+ }], labelsAndRoutes: [{
67
+ type: Input
68
+ }], route: [{
69
+ type: Input
70
+ }], dropdownActionType: [{
71
+ type: Input
72
+ }], addClicked: [{
73
+ type: Output
74
+ }] } });
75
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcGRvd24tYWN0aW9ucy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9pbnB1dHMvc3JjL2xpYi9kcm9wZG93bi1hY3Rpb25zL2Ryb3Bkb3duLWFjdGlvbnMuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvaW5wdXRzL3NyYy9saWIvZHJvcGRvd24tYWN0aW9ucy9kcm9wZG93bi1hY3Rpb25zLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBVSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFHL0UsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sOEJBQThCLENBQUM7Ozs7OztBQU9sRSxNQUFNLE9BQU8sd0JBQXdCO0lBU2Y7SUFScEIsbUJBQW1CLEdBQUcsa0JBQWtCLENBQUM7SUFDaEMsUUFBUSxHQUFZLElBQUksQ0FBQztJQUN6QixRQUFRLENBQVU7SUFDbEIsZUFBZSxHQUFvQixFQUFFLENBQUM7SUFDdEMsS0FBSyxDQUFTO0lBQ2Qsa0JBQWtCLEdBQXVCLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxHQUFHLENBQUM7SUFDckUsVUFBVSxHQUFHLElBQUksWUFBWSxFQUFFLENBQUM7SUFFMUMsWUFBb0IsT0FBZTtRQUFmLFlBQU8sR0FBUCxPQUFPLENBQVE7SUFBSSxDQUFDO0lBRXhDLFFBQVE7UUFDTixJQUFJLENBQUMsZUFBZSxFQUFFLENBQUM7SUFDekIsQ0FBQztJQUVELGVBQWU7UUFDYixJQUFJLElBQUksQ0FBQyxrQkFBa0IsSUFBSSxJQUFJLENBQUMsbUJBQW1CLENBQUMsR0FBRyxFQUFFO1lBQzNELElBQUksSUFBSSxDQUFDLFFBQVEsRUFBRTtnQkFDakIsSUFBSSxJQUFJLENBQUMsS0FBSyxJQUFJLEVBQUUsSUFBSSxJQUFJLENBQUMsS0FBSyxJQUFJLFNBQVMsSUFBSSxJQUFJLENBQUMsS0FBSyxJQUFJLElBQUksRUFBRTtvQkFDckUsTUFBTSxLQUFLLENBQUMsNkJBQTZCLENBQUMsQ0FBQztpQkFDNUM7YUFDRjtpQkFDSTtnQkFDSCxJQUFJLElBQUksQ0FBQyxLQUFLLEVBQUU7b0JBQ2QsTUFBTSxLQUFLLENBQUMscURBQXFELENBQUMsQ0FBQztpQkFDcEU7YUFDRjtTQUNGO2FBQ0ksSUFBSSxJQUFJLENBQUMsa0JBQWtCLElBQUksSUFBSSxDQUFDLG1CQUFtQixDQUFDLElBQUksRUFBRTtZQUNqRSxJQUFJLENBQUMsSUFBSSxDQUFDLGVBQWUsQ0FBQyxNQUFNLEVBQUU7Z0JBQ2hDLE1BQU0sS0FBSyxDQUFDLHFFQUFxRSxDQUFDLENBQUM7YUFDcEY7U0FDRjthQUNJO1lBQ0gsTUFBTSxLQUFLLENBQUMseUNBQXlDLENBQUMsQ0FBQTtTQUN2RDtJQUNILENBQUM7SUFFRCxVQUFVLENBQUMsTUFBTTtRQUNmLE1BQU0sQ0FBQyxjQUFjLEVBQUUsQ0FBQztRQUN4QixJQUFJLElBQUksQ0FBQyxRQUFRLElBQUksSUFBSSxDQUFDLEtBQUssRUFBRTtZQUMvQixJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDO1NBQ3JDO1FBQ0QsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLEVBQUUsQ0FBQztJQUN6QixDQUFDO0lBRUQsWUFBWSxDQUFDLEtBQUssRUFBRSxNQUFNO1FBQ3hCLE1BQU0sQ0FBQyxjQUFjLEVBQUUsQ0FBQztRQUN4QixJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7SUFDakMsQ0FBQzt3R0FqRFUsd0JBQXdCOzRGQUF4Qix3QkFBd0IscVBDVnJDLDIwQkFnQk07OzRGRE5PLHdCQUF3QjtrQkFMcEMsU0FBUzsrQkFDRSxrQkFBa0I7NkZBTW5CLFFBQVE7c0JBQWhCLEtBQUs7Z0JBQ0csUUFBUTtzQkFBaEIsS0FBSztnQkFDRyxlQUFlO3NCQUF2QixLQUFLO2dCQUNHLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxrQkFBa0I7c0JBQTFCLEtBQUs7Z0JBQ0ksVUFBVTtzQkFBbkIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgRXZlbnRFbWl0dGVyLCBJbnB1dCwgT25Jbml0LCBPdXRwdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgUm91dGVyIH0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcclxuaW1wb3J0IHsgTGFiZWxBbmRSb3V0ZSB9IGZyb20gJy4vbGFiZWwtYW5kLXJvdXRlLm1vZGVsJztcclxuaW1wb3J0IHsgRHJvcGRvd25BY3Rpb25UeXBlIH0gZnJvbSAnLi9kcm9wZG93bi1hY3Rpb24tdHlwZS5tb2RlbCc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICBzZWxlY3RvcjogJ2Ryb3Bkb3duLWFjdGlvbnMnLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9kcm9wZG93bi1hY3Rpb25zLmNvbXBvbmVudC5odG1sJyxcclxuICBzdHlsZVVybHM6IFsnLi9kcm9wZG93bi1hY3Rpb25zLmNvbXBvbmVudC5zY3NzJ11cclxufSlcclxuZXhwb3J0IGNsYXNzIERyb3Bkb3duQWN0aW9uc0NvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XHJcbiAgZHJvcGRvd25BY3Rpb25UeXBlcyA9IERyb3Bkb3duQWN0aW9uVHlwZTtcclxuICBASW5wdXQoKSBjYW5Sb3V0ZTogYm9vbGVhbiA9IHRydWU7XHJcbiAgQElucHV0KCkgZGlzYWJsZWQ6IGJvb2xlYW47XHJcbiAgQElucHV0KCkgbGFiZWxzQW5kUm91dGVzOiBMYWJlbEFuZFJvdXRlW10gPSBbXTtcclxuICBASW5wdXQoKSByb3V0ZTogc3RyaW5nO1xyXG4gIEBJbnB1dCgpIGRyb3Bkb3duQWN0aW9uVHlwZTogRHJvcGRvd25BY3Rpb25UeXBlID0gdGhpcy5kcm9wZG93bkFjdGlvblR5cGVzLkFERDtcclxuICBAT3V0cHV0KCkgYWRkQ2xpY2tlZCA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcclxuXHJcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBfUm91dGVyOiBSb3V0ZXIpIHsgfVxyXG5cclxuICBuZ09uSW5pdCgpOiB2b2lkIHtcclxuICAgIHRoaXMudmFsaWRhdGVBY3Rpb25zKCk7XHJcbiAgfVxyXG5cclxuICB2YWxpZGF0ZUFjdGlvbnMoKSB7XHJcbiAgICBpZiAodGhpcy5kcm9wZG93bkFjdGlvblR5cGUgPT0gdGhpcy5kcm9wZG93bkFjdGlvblR5cGVzLkFERCkge1xyXG4gICAgICBpZiAodGhpcy5jYW5Sb3V0ZSkge1xyXG4gICAgICAgIGlmICh0aGlzLnJvdXRlID09IFwiXCIgfHwgdGhpcy5yb3V0ZSA9PSB1bmRlZmluZWQgfHwgdGhpcy5yb3V0ZSA9PSBudWxsKSB7XHJcbiAgICAgICAgICB0aHJvdyBFcnJvcihcIlJvdXRlIG5lZWRzIHRvIGJlIHByb3ZpZGVkLlwiKTtcclxuICAgICAgICB9XHJcbiAgICAgIH1cclxuICAgICAgZWxzZSB7XHJcbiAgICAgICAgaWYgKHRoaXMucm91dGUpIHtcclxuICAgICAgICAgIHRocm93IEVycm9yKFwiUm91dGUgc2hvdWxkbid0IGJlIHByb3ZpZGVkIHNpbmNlIGNhblJvdXRlIGlzIGZhbHNlXCIpO1xyXG4gICAgICAgIH1cclxuICAgICAgfVxyXG4gICAgfVxyXG4gICAgZWxzZSBpZiAodGhpcy5kcm9wZG93bkFjdGlvblR5cGUgPT0gdGhpcy5kcm9wZG93bkFjdGlvblR5cGVzLk1FTlUpIHtcclxuICAgICAgaWYgKCF0aGlzLmxhYmVsc0FuZFJvdXRlcy5sZW5ndGgpIHtcclxuICAgICAgICB0aHJvdyBFcnJvcihcIkEgbGlzdCBvZiBsYWJlbHMgJiBSb3V0ZXMgbmVlZCB0byBiZSBwcm92aWRlZCBmb3IgdGhlIGFjdGlvbnMgbWVudS5cIik7XHJcbiAgICAgIH1cclxuICAgIH1cclxuICAgIGVsc2Uge1xyXG4gICAgICB0aHJvdyBFcnJvcihcIkRyb3Bkb3duIEFjdGlvbiBUeXBlIGlzIG5vdCByZWNvZ25pemVkLlwiKVxyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgb25DbGlja0FkZCgkZXZlbnQpIHtcclxuICAgICRldmVudC5wcmV2ZW50RGVmYXVsdCgpO1xyXG4gICAgaWYgKHRoaXMuY2FuUm91dGUgJiYgdGhpcy5yb3V0ZSkge1xyXG4gICAgICB0aGlzLl9Sb3V0ZXIubmF2aWdhdGUoW3RoaXMucm91dGVdKTtcclxuICAgIH1cclxuICAgIHRoaXMuYWRkQ2xpY2tlZC5lbWl0KCk7XHJcbiAgfVxyXG5cclxuICBvbkNsaWNrTGFiZWwocm91dGUsICRldmVudCkge1xyXG4gICAgJGV2ZW50LnByZXZlbnREZWZhdWx0KCk7XHJcbiAgICB0aGlzLl9Sb3V0ZXIubmF2aWdhdGUoW3JvdXRlXSk7XHJcbiAgfVxyXG59XHJcbiIsIjxkaXYgW25nU3dpdGNoXT1cImRyb3Bkb3duQWN0aW9uVHlwZVwiPlxyXG4gICAgPGEgKm5nU3dpdGNoQ2FzZT1cImRyb3Bkb3duQWN0aW9uVHlwZXMuQUREXCIgW2hyZWZdPVwicm91dGVcIlxyXG4gICAgICAgIFtuZ0NsYXNzXT1cInsnYWN0aW9uLWVuYWJsZWQnOiFkaXNhYmxlZCwgJ2Rpc2FibGVkJzogZGlzYWJsZWR9XCJcclxuICAgICAgICAoY2xpY2spPVwib25DbGlja0FkZCgkZXZlbnQpXCI+XHJcbiAgICAgICAgPGZhLWljb24gaWNvbj1cInBsdXNcIj48L2ZhLWljb24+XHJcbiAgICA8L2E+XHJcbiAgICA8ZmEtaWNvbiAqbmdTd2l0Y2hDYXNlPVwiZHJvcGRvd25BY3Rpb25UeXBlcy5NRU5VXCJcclxuICAgICAgICBbbmdDbGFzc109XCJ7J2FjdGlvbi1lbmFibGVkJzohZGlzYWJsZWQsICdkaXNhYmxlZCc6IGRpc2FibGVkfVwiXHJcbiAgICAgICAgY2xhc3M9XCJtZW51XCIgW21hdE1lbnVUcmlnZ2VyRm9yXT1cIm1lbnVcIlxyXG4gICAgICAgIGljb249XCJlbGxpcHNpcy12ZXJ0aWNhbFwiPjwvZmEtaWNvbj5cclxuICAgIDxtYXQtbWVudSAjbWVudT1cIm1hdE1lbnVcIj5cclxuICAgICAgICA8YnV0dG9uICpuZ0Zvcj1cImxldCBsYWJlbEFuZFJvdXRlIG9mIGxhYmVsc0FuZFJvdXRlc1wiIG1hdC1tZW51LWl0ZW0+XHJcbiAgICAgICAgICAgIDxhIFtocmVmXT1cImxhYmVsQW5kUm91dGUucm91dGVcIlxyXG4gICAgICAgICAgICAgICAgKGNsaWNrKT1cIm9uQ2xpY2tMYWJlbChsYWJlbEFuZFJvdXRlLnJvdXRlLCAkZXZlbnQpXCI+e3tsYWJlbEFuZFJvdXRlLmxhYmVsfX08L2E+XHJcbiAgICAgICAgPC9idXR0b24+XHJcbiAgICA8L21hdC1tZW51PlxyXG48L2Rpdj4iXX0=
@@ -1,2 +1,2 @@
1
- export {};
1
+ export {};
2
2
  //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGFiZWwtYW5kLXJvdXRlLm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvaW5wdXRzL3NyYy9saWIvZHJvcGRvd24tYWN0aW9ucy9sYWJlbC1hbmQtcm91dGUubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgTGFiZWxBbmRSb3V0ZSB7XHJcbiAgICBsYWJlbDogc3RyaW5nO1xyXG4gICAgcm91dGU6IHN0cmluZztcclxufSJdfQ==