@huntsman-cancer-institute/input 16.0.1 → 17.0.1

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 (54) hide show
  1. package/date/date-base.d.ts +65 -65
  2. package/date/date-date-range.component.d.ts +32 -32
  3. package/date/date-date.component.d.ts +53 -53
  4. package/date/date-validator.d.ts +17 -17
  5. package/date/date.module.d.ts +16 -16
  6. package/dropdown/dropdown-index.d.ts +6 -6
  7. package/dropdown/dropdown-select-result.component.d.ts +23 -23
  8. package/dropdown/dropdown-select.component.d.ts +76 -76
  9. package/dropdown/dropdown.component.d.ts +40 -40
  10. package/dropdown/dropdown.module.d.ts +13 -13
  11. package/dropdown/dropdown.service.d.ts +51 -51
  12. package/dropdown/messages.d.ts +11 -11
  13. package/dropdown/select-item.d.ts +16 -16
  14. package/dropdown/template-dropdown.directive.d.ts +12 -12
  15. package/esm2022/date/date-base.mjs +114 -114
  16. package/esm2022/date/date-date-range.component.mjs +92 -92
  17. package/esm2022/date/date-date.component.mjs +189 -189
  18. package/esm2022/date/date-validator.mjs +40 -40
  19. package/esm2022/date/date.module.mjs +60 -60
  20. package/esm2022/dropdown/dropdown-index.mjs +5 -5
  21. package/esm2022/dropdown/dropdown-select-result.component.mjs +85 -85
  22. package/esm2022/dropdown/dropdown-select.component.mjs +360 -360
  23. package/esm2022/dropdown/dropdown.component.mjs +170 -170
  24. package/esm2022/dropdown/dropdown.module.mjs +50 -50
  25. package/esm2022/dropdown/dropdown.service.mjs +133 -133
  26. package/esm2022/dropdown/messages.mjs +9 -9
  27. package/esm2022/dropdown/select-item.mjs +11 -11
  28. package/esm2022/dropdown/template-dropdown.directive.mjs +26 -26
  29. package/esm2022/huntsman-cancer-institute-input.mjs +4 -4
  30. package/esm2022/index.mjs +19 -19
  31. package/esm2022/inline/inline.component.mjs +179 -179
  32. package/esm2022/inline/inline.module.mjs +28 -28
  33. package/esm2022/search/search.component.mjs +157 -157
  34. package/esm2022/search/search.module.mjs +32 -32
  35. package/esm2022/select/custom-combobox.component.mjs +531 -531
  36. package/esm2022/select/custom-multi-combobox.component.mjs +232 -232
  37. package/esm2022/select/md-multi-select.component.mjs +127 -127
  38. package/esm2022/select/md-select.component.mjs +107 -107
  39. package/esm2022/select/native-select.component.mjs +188 -188
  40. package/esm2022/select/select.module.mjs +83 -83
  41. package/fesm2022/huntsman-cancer-institute-input.mjs +2797 -2797
  42. package/fesm2022/huntsman-cancer-institute-input.mjs.map +1 -1
  43. package/index.d.ts +20 -20
  44. package/inline/inline.component.d.ts +66 -66
  45. package/inline/inline.module.d.ts +9 -9
  46. package/package.json +7 -7
  47. package/search/search.component.d.ts +42 -42
  48. package/search/search.module.d.ts +10 -10
  49. package/select/custom-combobox.component.d.ts +98 -98
  50. package/select/custom-multi-combobox.component.d.ts +50 -50
  51. package/select/md-multi-select.component.d.ts +32 -32
  52. package/select/md-select.component.d.ts +30 -30
  53. package/select/native-select.component.d.ts +37 -37
  54. package/select/select.module.d.ts +21 -21
@@ -1,194 +1,194 @@
1
- import { Component, ElementRef, EventEmitter, Injector, Input, Output, ViewChild, } from "@angular/core";
2
- import { UntypedFormControl, NG_VALUE_ACCESSOR, NgControl } from "@angular/forms";
3
- import { debounceTime } from "rxjs/operators";
4
- import { MatLegacySelect as MatSelect } from "@angular/material/legacy-select";
5
- import * as i0 from "@angular/core";
6
- import * as i1 from "@angular/common";
7
- import * as i2 from "@angular/forms";
8
- import * as i3 from "@angular/material/legacy-form-field";
9
- import * as i4 from "@angular/material/legacy-select";
10
- import * as i5 from "@angular/material/legacy-core";
11
- import * as i6 from "@angular/material/legacy-input";
12
- import * as i7 from "@angular/material/legacy-tooltip";
13
- export class CustomMultiComboBoxComponent {
14
- constructor(injector) {
15
- this.injector = injector;
16
- this.placeholder = "";
17
- this.temporaryPlaceholder = false;
18
- this.tooltip = "";
19
- this.options = [];
20
- this.includeLoadingOption = true;
21
- this.loadedOptions = [];
22
- this.isSelectOpen = false;
23
- this.forceEmitObject = false;
24
- this.appearance = "";
25
- this.outerControl = new UntypedFormControl([]);
26
- this.innerControl = new UntypedFormControl("");
27
- this.ignoreInnerControlChanges = false;
28
- this.noNgControl = false;
29
- this.selectedListItems = [];
30
- this.selectionChanged = new EventEmitter();
31
- this.onChangeFn = () => { };
32
- this.onTouchedFn = () => { };
33
- }
34
- ngAfterViewInit() {
35
- let ngControl = this.injector.get(NgControl, null);
36
- if (ngControl && ngControl.control) {
37
- this.outerControl = ngControl.control;
38
- setTimeout(() => {
39
- this.loadOnlyCurrentValue();
40
- });
41
- }
42
- else {
43
- this.noNgControl = true;
44
- }
45
- this.innerControlSubscription = this.innerControl.valueChanges.pipe(debounceTime(300)).subscribe(() => {
46
- if (!this.ignoreInnerControlChanges) {
47
- this.filterOptions();
48
- }
49
- else {
50
- this.ignoreInnerControlChanges = false;
51
- }
52
- });
53
- }
54
- ngOnChanges(changes) {
55
- if (changes.options) {
56
- let optionsChange = changes.options;
57
- if (!optionsChange.currentValue) {
58
- this.options = [];
59
- }
60
- }
61
- this.loadOnlyCurrentValue();
62
- }
63
- writeValue(obj) {
64
- this.loadOnlyCurrentValue();
65
- }
66
- registerOnChange(fn) {
67
- this.onChangeFn = fn;
68
- }
69
- registerOnTouched(fn) {
70
- this.onTouchedFn = fn;
71
- }
72
- setDisabledState(isDisabled) {
73
- if (isDisabled) {
74
- this.innerControl.disable();
75
- this.selectElement.disabled = true;
76
- }
77
- else {
78
- this.innerControl.enable();
79
- this.selectElement.disabled = false;
80
- }
81
- }
82
- onInputFocus() {
83
- this.selectElement.open();
84
- }
85
- loadOnlyCurrentValue() {
86
- this.loadedOptions = [];
87
- if (this.outerControl.value && this.outerControl.value.length) {
88
- for (let opt of this.options) {
89
- if (this.isOptInOuterValue(opt)) {
90
- this.loadedOptions.push(opt);
91
- }
92
- }
93
- }
94
- this.selectedListItems = this.loadedOptions;
95
- let currentValueLabel = "";
96
- for (let opt of this.loadedOptions) {
97
- if (currentValueLabel) {
98
- currentValueLabel += ", ";
99
- }
100
- currentValueLabel += this.displayField ? opt[this.displayField] : opt;
101
- }
102
- this.ignoreInnerControlChanges = true;
103
- this.innerControl.setValue(currentValueLabel);
104
- }
105
- filterOptions(showAll = false) {
106
- if (showAll || !this.innerControl.value) {
107
- this.loadedOptions = this.options;
108
- }
109
- else {
110
- let searchValue = this.innerControl.value.toLowerCase();
111
- this.loadedOptions = this.options.filter((opt) => {
112
- let optDisplay = (this.displayField ? opt[this.displayField] : opt).toLowerCase();
113
- return optDisplay.includes(searchValue) || this.isOptInOuterValue(opt);
114
- });
115
- }
116
- }
117
- isOptInOuterValue(opt) {
118
- let optValue = this.valueField ? opt[this.valueField] : opt;
119
- if (this.forceEmitObject) {
120
- for (let outerValOpt of this.outerControl.value) {
121
- let outerOptValue = this.valueField ? outerValOpt[this.valueField] : outerValOpt;
122
- if (optValue === outerOptValue) {
123
- return true;
124
- }
125
- }
126
- }
127
- else {
128
- return this.outerControl.value.includes(optValue);
129
- }
130
- }
131
- onOpenedChange(opened) {
132
- this.isSelectOpen = opened;
133
- if (opened) {
134
- this.onTouchedFn();
135
- this.inputElement.nativeElement.focus();
136
- this.ignoreInnerControlChanges = true;
137
- this.innerControl.setValue("");
138
- setTimeout(() => {
139
- this.filterOptions(true);
140
- this.includeLoadingOption = false;
141
- });
142
- }
143
- else {
144
- setTimeout(() => {
145
- this.loadOnlyCurrentValue();
146
- this.includeLoadingOption = true;
147
- });
148
- }
149
- }
150
- selectOptions(options) {
151
- let newVal = [];
152
- for (let opt of options) {
153
- if (opt) {
154
- newVal.push((this.valueField && !this.forceEmitObject) ? opt[this.valueField] : opt);
155
- }
156
- }
157
- if (this.noNgControl) {
158
- this.outerControl.setValue(newVal);
159
- }
160
- this.onChangeFn(newVal);
161
- this.selectionChanged.emit(newVal);
162
- if (this.isSelectOpen) {
163
- this.inputElement.nativeElement.focus();
164
- }
165
- }
166
- compareByID(itemOne, itemTwo) {
167
- if (!itemOne) {
168
- return false;
169
- }
170
- else if (!itemTwo) {
171
- return false;
172
- }
173
- else {
174
- if (this.valueField) {
175
- return itemOne[this.valueField] && itemTwo[this.valueField] && itemOne[this.valueField] === itemTwo[this.valueField];
176
- }
177
- else {
178
- return itemOne === itemTwo;
179
- }
180
- }
181
- }
182
- ngOnDestroy() {
183
- if (this.innerControlSubscription) {
184
- this.innerControlSubscription.unsubscribe();
185
- }
186
- }
187
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CustomMultiComboBoxComponent, deps: [{ token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component }); }
188
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: CustomMultiComboBoxComponent, selector: "hci-multi-combobox", inputs: { label: "label", placeholder: "placeholder", temporaryPlaceholder: "temporaryPlaceholder", tooltip: "tooltip", options: "options", valueField: "valueField", forceEmitObject: "forceEmitObject", displayField: "displayField", appearance: "appearance", initialFocus: "initialFocus", floatLabel: "floatLabel" }, outputs: { selectionChanged: "selectionChanged" }, providers: [{
189
- provide: NG_VALUE_ACCESSOR,
190
- useExisting: CustomMultiComboBoxComponent,
191
- multi: true,
1
+ import { Component, ElementRef, EventEmitter, Injector, Input, Output, ViewChild, } from "@angular/core";
2
+ import { UntypedFormControl, NG_VALUE_ACCESSOR, NgControl } from "@angular/forms";
3
+ import { debounceTime } from "rxjs/operators";
4
+ import { MatLegacySelect as MatSelect } from "@angular/material/legacy-select";
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "@angular/common";
7
+ import * as i2 from "@angular/forms";
8
+ import * as i3 from "@angular/material/legacy-form-field";
9
+ import * as i4 from "@angular/material/legacy-select";
10
+ import * as i5 from "@angular/material/legacy-core";
11
+ import * as i6 from "@angular/material/legacy-input";
12
+ import * as i7 from "@angular/material/legacy-tooltip";
13
+ export class CustomMultiComboBoxComponent {
14
+ constructor(injector) {
15
+ this.injector = injector;
16
+ this.placeholder = "";
17
+ this.temporaryPlaceholder = false;
18
+ this.tooltip = "";
19
+ this.options = [];
20
+ this.includeLoadingOption = true;
21
+ this.loadedOptions = [];
22
+ this.isSelectOpen = false;
23
+ this.forceEmitObject = false;
24
+ this.appearance = "";
25
+ this.outerControl = new UntypedFormControl([]);
26
+ this.innerControl = new UntypedFormControl("");
27
+ this.ignoreInnerControlChanges = false;
28
+ this.noNgControl = false;
29
+ this.selectedListItems = [];
30
+ this.selectionChanged = new EventEmitter();
31
+ this.onChangeFn = () => { };
32
+ this.onTouchedFn = () => { };
33
+ }
34
+ ngAfterViewInit() {
35
+ let ngControl = this.injector.get(NgControl, null);
36
+ if (ngControl && ngControl.control) {
37
+ this.outerControl = ngControl.control;
38
+ setTimeout(() => {
39
+ this.loadOnlyCurrentValue();
40
+ });
41
+ }
42
+ else {
43
+ this.noNgControl = true;
44
+ }
45
+ this.innerControlSubscription = this.innerControl.valueChanges.pipe(debounceTime(300)).subscribe(() => {
46
+ if (!this.ignoreInnerControlChanges) {
47
+ this.filterOptions();
48
+ }
49
+ else {
50
+ this.ignoreInnerControlChanges = false;
51
+ }
52
+ });
53
+ }
54
+ ngOnChanges(changes) {
55
+ if (changes.options) {
56
+ let optionsChange = changes.options;
57
+ if (!optionsChange.currentValue) {
58
+ this.options = [];
59
+ }
60
+ }
61
+ this.loadOnlyCurrentValue();
62
+ }
63
+ writeValue(obj) {
64
+ this.loadOnlyCurrentValue();
65
+ }
66
+ registerOnChange(fn) {
67
+ this.onChangeFn = fn;
68
+ }
69
+ registerOnTouched(fn) {
70
+ this.onTouchedFn = fn;
71
+ }
72
+ setDisabledState(isDisabled) {
73
+ if (isDisabled) {
74
+ this.innerControl.disable();
75
+ this.selectElement.disabled = true;
76
+ }
77
+ else {
78
+ this.innerControl.enable();
79
+ this.selectElement.disabled = false;
80
+ }
81
+ }
82
+ onInputFocus() {
83
+ this.selectElement.open();
84
+ }
85
+ loadOnlyCurrentValue() {
86
+ this.loadedOptions = [];
87
+ if (this.outerControl.value && this.outerControl.value.length) {
88
+ for (let opt of this.options) {
89
+ if (this.isOptInOuterValue(opt)) {
90
+ this.loadedOptions.push(opt);
91
+ }
92
+ }
93
+ }
94
+ this.selectedListItems = this.loadedOptions;
95
+ let currentValueLabel = "";
96
+ for (let opt of this.loadedOptions) {
97
+ if (currentValueLabel) {
98
+ currentValueLabel += ", ";
99
+ }
100
+ currentValueLabel += this.displayField ? opt[this.displayField] : opt;
101
+ }
102
+ this.ignoreInnerControlChanges = true;
103
+ this.innerControl.setValue(currentValueLabel);
104
+ }
105
+ filterOptions(showAll = false) {
106
+ if (showAll || !this.innerControl.value) {
107
+ this.loadedOptions = this.options;
108
+ }
109
+ else {
110
+ let searchValue = this.innerControl.value.toLowerCase();
111
+ this.loadedOptions = this.options.filter((opt) => {
112
+ let optDisplay = (this.displayField ? opt[this.displayField] : opt).toLowerCase();
113
+ return optDisplay.includes(searchValue) || this.isOptInOuterValue(opt);
114
+ });
115
+ }
116
+ }
117
+ isOptInOuterValue(opt) {
118
+ let optValue = this.valueField ? opt[this.valueField] : opt;
119
+ if (this.forceEmitObject) {
120
+ for (let outerValOpt of this.outerControl.value) {
121
+ let outerOptValue = this.valueField ? outerValOpt[this.valueField] : outerValOpt;
122
+ if (optValue === outerOptValue) {
123
+ return true;
124
+ }
125
+ }
126
+ }
127
+ else {
128
+ return this.outerControl.value.includes(optValue);
129
+ }
130
+ }
131
+ onOpenedChange(opened) {
132
+ this.isSelectOpen = opened;
133
+ if (opened) {
134
+ this.onTouchedFn();
135
+ this.inputElement.nativeElement.focus();
136
+ this.ignoreInnerControlChanges = true;
137
+ this.innerControl.setValue("");
138
+ setTimeout(() => {
139
+ this.filterOptions(true);
140
+ this.includeLoadingOption = false;
141
+ });
142
+ }
143
+ else {
144
+ setTimeout(() => {
145
+ this.loadOnlyCurrentValue();
146
+ this.includeLoadingOption = true;
147
+ });
148
+ }
149
+ }
150
+ selectOptions(options) {
151
+ let newVal = [];
152
+ for (let opt of options) {
153
+ if (opt) {
154
+ newVal.push((this.valueField && !this.forceEmitObject) ? opt[this.valueField] : opt);
155
+ }
156
+ }
157
+ if (this.noNgControl) {
158
+ this.outerControl.setValue(newVal);
159
+ }
160
+ this.onChangeFn(newVal);
161
+ this.selectionChanged.emit(newVal);
162
+ if (this.isSelectOpen) {
163
+ this.inputElement.nativeElement.focus();
164
+ }
165
+ }
166
+ compareByID(itemOne, itemTwo) {
167
+ if (!itemOne) {
168
+ return false;
169
+ }
170
+ else if (!itemTwo) {
171
+ return false;
172
+ }
173
+ else {
174
+ if (this.valueField) {
175
+ return itemOne[this.valueField] && itemTwo[this.valueField] && itemOne[this.valueField] === itemTwo[this.valueField];
176
+ }
177
+ else {
178
+ return itemOne === itemTwo;
179
+ }
180
+ }
181
+ }
182
+ ngOnDestroy() {
183
+ if (this.innerControlSubscription) {
184
+ this.innerControlSubscription.unsubscribe();
185
+ }
186
+ }
187
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CustomMultiComboBoxComponent, deps: [{ token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component }); }
188
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.1.2", type: CustomMultiComboBoxComponent, selector: "hci-multi-combobox", inputs: { label: "label", placeholder: "placeholder", temporaryPlaceholder: "temporaryPlaceholder", tooltip: "tooltip", options: "options", valueField: "valueField", forceEmitObject: "forceEmitObject", displayField: "displayField", appearance: "appearance", initialFocus: "initialFocus", floatLabel: "floatLabel" }, outputs: { selectionChanged: "selectionChanged" }, providers: [{
189
+ provide: NG_VALUE_ACCESSOR,
190
+ useExisting: CustomMultiComboBoxComponent,
191
+ multi: true,
192
192
  }], viewQueries: [{ propertyName: "inputElement", first: true, predicate: ["input"], descendants: true }, { propertyName: "selectElement", first: true, predicate: ["select"], descendants: true }], usesOnChanges: true, ngImport: i0, template: `
193
193
  <div class="combobox-multi-container d-flex font-sm">
194
194
  <mat-form-field [appearance]="appearance" [matTooltip]="this.tooltip" [floatLabel]="floatLabel">
@@ -218,10 +218,10 @@ export class CustomMultiComboBoxComponent {
218
218
  </div>
219
219
  </mat-form-field>
220
220
  </div>
221
- `, isInline: true, styles: [""], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { 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"] }, { kind: "directive", type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "component", type: i3.MatLegacyFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3.MatLegacyLabel, selector: "mat-label" }, { kind: "directive", type: i3.MatLegacySuffix, selector: "[matSuffix]" }, { kind: "component", type: i4.MatLegacySelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex"], exportAs: ["matSelect"] }, { kind: "component", type: i5.MatLegacyOption, selector: "mat-option", exportAs: ["matOption"] }, { kind: "directive", type: i6.MatLegacyInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", exportAs: ["matInput"] }, { kind: "directive", type: i7.MatLegacyTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }] }); }
222
- }
223
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CustomMultiComboBoxComponent, decorators: [{
224
- type: Component,
221
+ `, isInline: true, styles: [""], dependencies: [{ kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { 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"] }, { kind: "directive", type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "component", type: i3.MatLegacyFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3.MatLegacyLabel, selector: "mat-label" }, { kind: "directive", type: i3.MatLegacySuffix, selector: "[matSuffix]" }, { kind: "component", type: i4.MatLegacySelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex"], exportAs: ["matSelect"] }, { kind: "component", type: i5.MatLegacyOption, selector: "mat-option", exportAs: ["matOption"] }, { kind: "directive", type: i6.MatLegacyInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", exportAs: ["matInput"] }, { kind: "directive", type: i7.MatLegacyTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }] }); }
222
+ }
223
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.2", ngImport: i0, type: CustomMultiComboBoxComponent, decorators: [{
224
+ type: Component,
225
225
  args: [{ selector: "hci-multi-combobox", template: `
226
226
  <div class="combobox-multi-container d-flex font-sm">
227
227
  <mat-form-field [appearance]="appearance" [matTooltip]="this.tooltip" [floatLabel]="floatLabel">
@@ -251,40 +251,40 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
251
251
  </div>
252
252
  </mat-form-field>
253
253
  </div>
254
- `, providers: [{
255
- provide: NG_VALUE_ACCESSOR,
256
- useExisting: CustomMultiComboBoxComponent,
257
- multi: true,
258
- }] }]
259
- }], ctorParameters: function () { return [{ type: i0.Injector }]; }, propDecorators: { inputElement: [{
260
- type: ViewChild,
261
- args: ["input", { static: false }]
262
- }], selectElement: [{
263
- type: ViewChild,
264
- args: ["select", { static: false }]
265
- }], label: [{
266
- type: Input
267
- }], placeholder: [{
268
- type: Input
269
- }], temporaryPlaceholder: [{
270
- type: Input
271
- }], tooltip: [{
272
- type: Input
273
- }], options: [{
274
- type: Input
275
- }], valueField: [{
276
- type: Input
277
- }], forceEmitObject: [{
278
- type: Input
279
- }], displayField: [{
280
- type: Input
281
- }], appearance: [{
282
- type: Input
283
- }], initialFocus: [{
284
- type: Input
285
- }], floatLabel: [{
286
- type: Input
287
- }], selectionChanged: [{
288
- type: Output
289
- }] } });
290
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"custom-multi-combobox.component.js","sourceRoot":"","sources":["../../../../projects/input/src/select/custom-multi-combobox.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,SAAS,EAAE,UAAU,EACrB,YAAY,EACZ,QAAQ,EACR,KAAK,EAGL,MAAM,EACS,SAAS,GACzB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAwC,kBAAkB,EAAE,iBAAiB,EAAE,SAAS,EAAC,MAAM,gBAAgB,CAAC;AAEvH,OAAO,EAAC,YAAY,EAAC,MAAM,gBAAgB,CAAC;AAC5C,OAAO,EAAC,eAAe,IAAI,SAAS,EAAC,MAAM,iCAAiC,CAAC;;;;;;;;;AA2C7E,MAAM,OAAO,4BAA4B;IAiCvC,YAAoB,QAAkB;QAAlB,aAAQ,GAAR,QAAQ,CAAU;QA5BtB,gBAAW,GAAW,EAAE,CAAC;QACzB,yBAAoB,GAAY,KAAK,CAAC;QACtC,YAAO,GAAW,EAAE,CAAC;QAErB,YAAO,GAAU,EAAE,CAAC;QAC7B,yBAAoB,GAAY,IAAI,CAAC;QACrC,kBAAa,GAAU,EAAE,CAAC;QACzB,iBAAY,GAAY,KAAK,CAAC;QAGrB,oBAAe,GAAY,KAAK,CAAC;QAElC,eAAU,GAAW,EAAE,CAAC;QAIjC,iBAAY,GAAoB,IAAI,kBAAkB,CAAC,EAAE,CAAC,CAAC;QAC3D,iBAAY,GAAuB,IAAI,kBAAkB,CAAC,EAAE,CAAC,CAAC;QAC7D,8BAAyB,GAAY,KAAK,CAAC;QAE3C,gBAAW,GAAY,KAAK,CAAC;QAC9B,sBAAiB,GAAU,EAAE,CAAC;QAE3B,qBAAgB,GAAwB,IAAI,YAAY,EAAS,CAAC;QAEpE,eAAU,GAAuB,GAAG,EAAE,GAAE,CAAC,CAAC;QAC1C,gBAAW,GAAe,GAAG,EAAE,GAAE,CAAC,CAAC;IAG3C,CAAC;IAED,eAAe;QACb,IAAI,SAAS,GAAc,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;QAC9D,IAAI,SAAS,IAAI,SAAS,CAAC,OAAO,EAAE;YAClC,IAAI,CAAC,YAAY,GAAG,SAAS,CAAC,OAAO,CAAC;YACtC,UAAU,CAAC,GAAG,EAAE;gBACd,IAAI,CAAC,oBAAoB,EAAE,CAAC;YAC9B,CAAC,CAAC,CAAC;SACJ;aAAM;YACL,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;SACzB;QAED,IAAI,CAAC,wBAAwB,GAAG,IAAI,CAAC,YAAY,CAAC,YAAY,CAAC,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE;YACpG,IAAI,CAAC,IAAI,CAAC,yBAAyB,EAAE;gBACnC,IAAI,CAAC,aAAa,EAAE,CAAC;aACtB;iBAAM;gBACL,IAAI,CAAC,yBAAyB,GAAG,KAAK,CAAC;aACxC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,OAAO,EAAE;YACnB,IAAI,aAAa,GAAiB,OAAO,CAAC,OAAO,CAAC;YAClD,IAAI,CAAC,aAAa,CAAC,YAAY,EAAE;gBAC/B,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;aACnB;SACF;QAED,IAAI,CAAC,oBAAoB,EAAE,CAAC;IAC9B,CAAC;IAED,UAAU,CAAC,GAAQ;QACjB,IAAI,CAAC,oBAAoB,EAAE,CAAC;IAC9B,CAAC;IAED,gBAAgB,CAAC,EAAO;QACtB,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;IACvB,CAAC;IAED,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;IACxB,CAAC;IAED,gBAAgB,CAAC,UAAmB;QAClC,IAAI,UAAU,EAAE;YACd,IAAI,CAAC,YAAY,CAAC,OAAO,EAAE,CAAC;YAC5B,IAAI,CAAC,aAAa,CAAC,QAAQ,GAAG,IAAI,CAAC;SACpC;aAAM;YACL,IAAI,CAAC,YAAY,CAAC,MAAM,EAAE,CAAC;YAC3B,IAAI,CAAC,aAAa,CAAC,QAAQ,GAAG,KAAK,CAAC;SACrC;IACH,CAAC;IAEM,YAAY;QACjB,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;IAC5B,CAAC;IAEO,oBAAoB;QAC1B,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;QACxB,IAAI,IAAI,CAAC,YAAY,CAAC,KAAK,IAAI,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,MAAM,EAAE;YAC7D,KAAK,IAAI,GAAG,IAAI,IAAI,CAAC,OAAO,EAAE;gBAC5B,IAAI,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,EAAE;oBAC/B,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;iBAC9B;aACF;SACF;QACD,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,aAAa,CAAC;QAG5C,IAAI,iBAAiB,GAAW,EAAE,CAAC;QACnC,KAAK,IAAI,GAAG,IAAI,IAAI,CAAC,aAAa,EAAE;YAClC,IAAI,iBAAiB,EAAE;gBACrB,iBAAiB,IAAI,IAAI,CAAC;aAC3B;YACD,iBAAiB,IAAI,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC;SACvE;QACD,IAAI,CAAC,yBAAyB,GAAG,IAAI,CAAC;QACtC,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,iBAAiB,CAAC,CAAC;IAChD,CAAC;IAEO,aAAa,CAAC,UAAmB,KAAK;QAC5C,IAAI,OAAO,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE;YACvC,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,OAAO,CAAC;SACnC;aAAM;YACL,IAAI,WAAW,GAAW,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC;YAChE,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,GAAQ,EAAE,EAAE;gBACpD,IAAI,UAAU,GAAW,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,WAAW,EAAE,CAAC;gBAC1F,OAAO,UAAU,CAAC,QAAQ,CAAC,WAAW,CAAC,IAAI,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,CAAC;YACzE,CAAC,CAAC,CAAC;SACJ;IACH,CAAC;IAEO,iBAAiB,CAAC,GAAQ;QAChC,IAAI,QAAQ,GAAQ,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC;QACjE,IAAI,IAAI,CAAC,eAAe,EAAE;YACxB,KAAK,IAAI,WAAW,IAAI,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE;gBAC/C,IAAI,aAAa,GAAQ,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC;gBACtF,IAAI,QAAQ,KAAK,aAAa,EAAE;oBAC9B,OAAO,IAAI,CAAC;iBACb;aACF;SACF;aAAM;YACL,OAAO,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;SACnD;IACH,CAAC;IAEM,cAAc,CAAC,MAAe;QACnC,IAAI,CAAC,YAAY,GAAG,MAAM,CAAC;QAC3B,IAAI,MAAM,EAAE;YACV,IAAI,CAAC,WAAW,EAAE,CAAC;YAEnB,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;YACxC,IAAI,CAAC,yBAAyB,GAAG,IAAI,CAAC;YACtC,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;YAE/B,UAAU,CAAC,GAAG,EAAE;gBACd,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC;gBACzB,IAAI,CAAC,oBAAoB,GAAG,KAAK,CAAC;YACpC,CAAC,CAAC,CAAC;SACJ;aAAM;YACL,UAAU,CAAC,GAAG,EAAE;gBACd,IAAI,CAAC,oBAAoB,EAAE,CAAC;gBAC5B,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC;YACnC,CAAC,CAAC,CAAC;SACJ;IACH,CAAC;IAEM,aAAa,CAAC,OAAc;QACjC,IAAI,MAAM,GAAU,EAAE,CAAC;QACvB,KAAK,IAAI,GAAG,IAAI,OAAO,EAAE;YACvB,IAAI,GAAG,EAAE;gBACP,MAAM,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,UAAU,IAAI,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;aACtF;SACF;QACD,IAAI,IAAI,CAAC,WAAW,EAAE;YACpB,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;SACpC;QAED,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;QACxB,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAEnC,IAAI,IAAI,CAAC,YAAY,EAAE;YACrB,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;SACzC;IACH,CAAC;IAED,WAAW,CAAC,OAAO,EAAE,OAAO;QAC1B,IAAG,CAAC,OAAO,EAAE;YACX,OAAO,KAAK,CAAC;SACd;aAAM,IAAI,CAAC,OAAO,EAAE;YACnB,OAAO,KAAK,CAAC;SACd;aAAM;YACL,IAAG,IAAI,CAAC,UAAU,EAAE;gBAClB,OAAO,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,KAAK,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;aACtH;iBAAM;gBACL,OAAQ,OAAO,KAAK,OAAO,CAAC;aAC7B;SACF;IACH,CAAC;IAED,WAAW;QACT,IAAG,IAAI,CAAC,wBAAwB,EAAE;YAChC,IAAI,CAAC,wBAAwB,CAAC,WAAW,EAAE,CAAC;SAC7C;IACH,CAAC;+GAxMU,4BAA4B;mGAA5B,4BAA4B,4ZAR5B,CAAC;gBACV,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,4BAA4B;gBACzC,KAAK,EAAE,IAAI;aACZ,CAAC,gPAlCQ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA6BT;;4FASU,4BAA4B;kBAxCxC,SAAS;+BACE,oBAAoB,YACpB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA6BT,aACU,CAAC;4BACV,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,8BAA8B;4BACzC,KAAK,EAAE,IAAI;yBACZ,CAAC;+FAKoC,YAAY;sBAAjD,SAAS;uBAAC,OAAO,EAAE,EAAE,MAAM,EAAE,KAAK,EAAC;gBACG,aAAa;sBAAnD,SAAS;uBAAC,QAAQ,EAAE,EAAE,MAAM,EAAE,KAAK,EAAC;gBAErB,KAAK;sBAApB,KAAK;gBACU,WAAW;sBAA1B,KAAK;gBACU,oBAAoB;sBAAnC,KAAK;gBACU,OAAO;sBAAtB,KAAK;gBAEU,OAAO;sBAAtB,KAAK;gBAKW,UAAU;sBAA1B,KAAK;gBACW,eAAe;sBAA/B,KAAK;gBACU,YAAY;sBAA3B,KAAK;gBACU,UAAU;sBAAzB,KAAK;gBACU,YAAY;sBAA3B,KAAK;gBACU,UAAU;sBAAzB,KAAK;gBASI,gBAAgB;sBAAzB,MAAM","sourcesContent":["import {\r\n  AfterViewInit,\r\n  Component, ElementRef,\r\n  EventEmitter,\r\n  Injector,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  Output, SimpleChange,\r\n  SimpleChanges, ViewChild,\r\n} from \"@angular/core\";\r\nimport {AbstractControl, ControlValueAccessor, UntypedFormControl, NG_VALUE_ACCESSOR, NgControl} from \"@angular/forms\";\r\nimport {Subscription} from \"rxjs\";\r\nimport {debounceTime} from \"rxjs/operators\";\r\nimport {MatLegacySelect as MatSelect} from \"@angular/material/legacy-select\";\r\nimport {LegacyFloatLabelType as FloatLabelType} from \"@angular/material/legacy-form-field\";\r\n\r\n@Component({\r\n  selector: \"hci-multi-combobox\",\r\n  template: `\r\n    <div class=\"combobox-multi-container d-flex font-sm\">\r\n      <mat-form-field [appearance]=\"appearance\" [matTooltip]=\"this.tooltip\" [floatLabel]=\"floatLabel\">\r\n        <mat-label *ngIf=\"label !== undefined\">{{ label }}</mat-label>\r\n        <mat-label *ngIf=\"label === undefined\">\r\n          {{ temporaryPlaceholder ? (outerControl.value && outerControl.value.length ? '' : placeholder) : placeholder }}\r\n        </mat-label>\r\n        <input #input matInput name=\"customMultiComboBoxFilter\" class=\"ellipsis\"\r\n               (focus)=\"this.onInputFocus()\"\r\n               autocomplete=\"off\"\r\n               [placeholder]=\"temporaryPlaceholder ? (outerControl.value && outerControl.value.length ? '' : placeholder) : placeholder\"\r\n               [formControl]=\"this.innerControl\"\r\n               [attr.cdkFocusInitial]=\"initialFocus === undefined ? null : initialFocus\">\r\n        <div matSuffix class=\"hci-combobox-arrow-wrapper\">\r\n          <mat-select\r\n            #select [multiple]=\"true\"\r\n            (selectionChange)=\"this.selectOptions($event.value)\"\r\n            (openedChange)=\"this.onOpenedChange($event)\"\r\n            [(ngModel)]=\"selectedListItems\"\r\n            [compareWith]=\"compareByID\">\r\n            <mat-option *ngFor=\"let opt of this.loadedOptions\" [value]=\"opt\">\r\n              {{this.displayField ? opt[this.displayField] : opt}}\r\n            </mat-option>\r\n            <mat-option *ngIf=\"this.includeLoadingOption\">Loading...</mat-option>\r\n            <mat-option *ngIf=\"!this.includeLoadingOption && !this.options.length\">None</mat-option>\r\n          </mat-select>\r\n        </div>\r\n      </mat-form-field>\r\n    </div>\r\n  `,\r\n  providers: [{\r\n    provide: NG_VALUE_ACCESSOR,\r\n    useExisting: CustomMultiComboBoxComponent,\r\n    multi: true,\r\n  }],\r\n  styles: [``],\r\n})\r\n\r\nexport class CustomMultiComboBoxComponent implements AfterViewInit, OnChanges, OnDestroy, ControlValueAccessor {\r\n  @ViewChild(\"input\", { static: false}) inputElement: ElementRef;\r\n  @ViewChild(\"select\", { static: false}) selectElement: MatSelect;\r\n\r\n  @Input() public label: string;\r\n  @Input() public placeholder: string = \"\";\r\n  @Input() public temporaryPlaceholder: boolean = false;\r\n  @Input() public tooltip: string = \"\";\r\n\r\n  @Input() public options: any[] = [];\r\n  public includeLoadingOption: boolean = true;\r\n  public loadedOptions: any[] = [];\r\n  private isSelectOpen: boolean = false;\r\n\r\n  @Input() private valueField: string;\r\n  @Input() private forceEmitObject: boolean = false;\r\n  @Input() public displayField: string;\r\n  @Input() public appearance: string = \"\";\r\n  @Input() public initialFocus: string;\r\n  @Input() public floatLabel: FloatLabelType;\r\n\r\n  public outerControl: AbstractControl = new UntypedFormControl([]);\r\n  public innerControl: UntypedFormControl = new UntypedFormControl(\"\");\r\n  private ignoreInnerControlChanges: boolean = false;\r\n  private innerControlSubscription: Subscription;\r\n  private noNgControl: boolean = false;\r\n  public selectedListItems: any[] = [];\r\n\r\n  @Output() selectionChanged: EventEmitter<any[]> = new EventEmitter<any[]>();\r\n\r\n  private onChangeFn: (val: any) => void = () => {};\r\n  private onTouchedFn: () => void = () => {};\r\n\r\n  constructor(private injector: Injector) {\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    let ngControl: NgControl = this.injector.get(NgControl, null);\r\n    if (ngControl && ngControl.control) {\r\n      this.outerControl = ngControl.control;\r\n      setTimeout(() => {\r\n        this.loadOnlyCurrentValue();\r\n      });\r\n    } else {\r\n      this.noNgControl = true;\r\n    }\r\n\r\n    this.innerControlSubscription = this.innerControl.valueChanges.pipe(debounceTime(300)).subscribe(() => {\r\n      if (!this.ignoreInnerControlChanges) {\r\n        this.filterOptions();\r\n      } else {\r\n        this.ignoreInnerControlChanges = false;\r\n      }\r\n    });\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes.options) {\r\n      let optionsChange: SimpleChange = changes.options;\r\n      if (!optionsChange.currentValue) {\r\n        this.options = [];\r\n      }\r\n    }\r\n\r\n    this.loadOnlyCurrentValue();\r\n  }\r\n\r\n  writeValue(obj: any): void {\r\n    this.loadOnlyCurrentValue();\r\n  }\r\n\r\n  registerOnChange(fn: any): void {\r\n    this.onChangeFn = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouchedFn = fn;\r\n  }\r\n\r\n  setDisabledState(isDisabled: boolean): void {\r\n    if (isDisabled) {\r\n      this.innerControl.disable();\r\n      this.selectElement.disabled = true;\r\n    } else {\r\n      this.innerControl.enable();\r\n      this.selectElement.disabled = false;\r\n    }\r\n  }\r\n\r\n  public onInputFocus(): void {\r\n    this.selectElement.open();\r\n  }\r\n\r\n  private loadOnlyCurrentValue(): void {\r\n    this.loadedOptions = [];\r\n    if (this.outerControl.value && this.outerControl.value.length) {\r\n      for (let opt of this.options) {\r\n        if (this.isOptInOuterValue(opt)) {\r\n          this.loadedOptions.push(opt);\r\n        }\r\n      }\r\n    }\r\n    this.selectedListItems = this.loadedOptions;\r\n\r\n\r\n    let currentValueLabel: string = \"\";\r\n    for (let opt of this.loadedOptions) {\r\n      if (currentValueLabel) {\r\n        currentValueLabel += \", \";\r\n      }\r\n      currentValueLabel += this.displayField ? opt[this.displayField] : opt;\r\n    }\r\n    this.ignoreInnerControlChanges = true;\r\n    this.innerControl.setValue(currentValueLabel);\r\n  }\r\n\r\n  private filterOptions(showAll: boolean = false): void {\r\n    if (showAll || !this.innerControl.value) {\r\n      this.loadedOptions = this.options;\r\n    } else {\r\n      let searchValue: string = this.innerControl.value.toLowerCase();\r\n      this.loadedOptions = this.options.filter((opt: any) => {\r\n        let optDisplay: string = (this.displayField ? opt[this.displayField] : opt).toLowerCase();\r\n        return optDisplay.includes(searchValue) || this.isOptInOuterValue(opt);\r\n      });\r\n    }\r\n  }\r\n\r\n  private isOptInOuterValue(opt: any): boolean {\r\n    let optValue: any = this.valueField ? opt[this.valueField] : opt;\r\n    if (this.forceEmitObject) {\r\n      for (let outerValOpt of this.outerControl.value) {\r\n        let outerOptValue: any = this.valueField ? outerValOpt[this.valueField] : outerValOpt;\r\n        if (optValue === outerOptValue) {\r\n          return true;\r\n        }\r\n      }\r\n    } else {\r\n      return this.outerControl.value.includes(optValue);\r\n    }\r\n  }\r\n\r\n  public onOpenedChange(opened: boolean): void {\r\n    this.isSelectOpen = opened;\r\n    if (opened) {\r\n      this.onTouchedFn();\r\n\r\n      this.inputElement.nativeElement.focus();\r\n      this.ignoreInnerControlChanges = true;\r\n      this.innerControl.setValue(\"\");\r\n\r\n      setTimeout(() => {\r\n        this.filterOptions(true);\r\n        this.includeLoadingOption = false;\r\n      });\r\n    } else {\r\n      setTimeout(() => {\r\n        this.loadOnlyCurrentValue();\r\n        this.includeLoadingOption = true;\r\n      });\r\n    }\r\n  }\r\n\r\n  public selectOptions(options: any[]): void {\r\n    let newVal: any[] = [];\r\n    for (let opt of options) {\r\n      if (opt) {\r\n        newVal.push((this.valueField && !this.forceEmitObject) ? opt[this.valueField] : opt);\r\n      }\r\n    }\r\n    if (this.noNgControl) {\r\n      this.outerControl.setValue(newVal);\r\n    }\r\n\r\n    this.onChangeFn(newVal);\r\n    this.selectionChanged.emit(newVal);\r\n\r\n    if (this.isSelectOpen) {\r\n      this.inputElement.nativeElement.focus();\r\n    }\r\n  }\r\n\r\n  compareByID(itemOne, itemTwo) {\r\n    if(!itemOne) {\r\n      return false;\r\n    } else if (!itemTwo) {\r\n      return false;\r\n    } else {\r\n      if(this.valueField) {\r\n        return itemOne[this.valueField] && itemTwo[this.valueField] && itemOne[this.valueField] === itemTwo[this.valueField];\r\n      } else {\r\n        return  itemOne === itemTwo;\r\n      }\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    if(this.innerControlSubscription) {\r\n      this.innerControlSubscription.unsubscribe();\r\n    }\r\n  }\r\n\r\n}\r\n"]}
254
+ `, providers: [{
255
+ provide: NG_VALUE_ACCESSOR,
256
+ useExisting: CustomMultiComboBoxComponent,
257
+ multi: true,
258
+ }] }]
259
+ }], ctorParameters: () => [{ type: i0.Injector }], propDecorators: { inputElement: [{
260
+ type: ViewChild,
261
+ args: ["input", { static: false }]
262
+ }], selectElement: [{
263
+ type: ViewChild,
264
+ args: ["select", { static: false }]
265
+ }], label: [{
266
+ type: Input
267
+ }], placeholder: [{
268
+ type: Input
269
+ }], temporaryPlaceholder: [{
270
+ type: Input
271
+ }], tooltip: [{
272
+ type: Input
273
+ }], options: [{
274
+ type: Input
275
+ }], valueField: [{
276
+ type: Input
277
+ }], forceEmitObject: [{
278
+ type: Input
279
+ }], displayField: [{
280
+ type: Input
281
+ }], appearance: [{
282
+ type: Input
283
+ }], initialFocus: [{
284
+ type: Input
285
+ }], floatLabel: [{
286
+ type: Input
287
+ }], selectionChanged: [{
288
+ type: Output
289
+ }] } });
290
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"custom-multi-combobox.component.js","sourceRoot":"","sources":["../../../../projects/input/src/select/custom-multi-combobox.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  Component, ElementRef,\r\n  EventEmitter,\r\n  Injector,\r\n  Input,\r\n  OnChanges,\r\n  OnDestroy,\r\n  Output, SimpleChange,\r\n  SimpleChanges, ViewChild,\r\n} from \"@angular/core\";\r\nimport {AbstractControl, ControlValueAccessor, UntypedFormControl, NG_VALUE_ACCESSOR, NgControl} from \"@angular/forms\";\r\nimport {Subscription} from \"rxjs\";\r\nimport {debounceTime} from \"rxjs/operators\";\r\nimport {MatLegacySelect as MatSelect} from \"@angular/material/legacy-select\";\r\nimport {LegacyFloatLabelType as FloatLabelType} from \"@angular/material/legacy-form-field\";\r\n\r\n@Component({\r\n  selector: \"hci-multi-combobox\",\r\n  template: `\r\n    <div class=\"combobox-multi-container d-flex font-sm\">\r\n      <mat-form-field [appearance]=\"appearance\" [matTooltip]=\"this.tooltip\" [floatLabel]=\"floatLabel\">\r\n        <mat-label *ngIf=\"label !== undefined\">{{ label }}</mat-label>\r\n        <mat-label *ngIf=\"label === undefined\">\r\n          {{ temporaryPlaceholder ? (outerControl.value && outerControl.value.length ? '' : placeholder) : placeholder }}\r\n        </mat-label>\r\n        <input #input matInput name=\"customMultiComboBoxFilter\" class=\"ellipsis\"\r\n               (focus)=\"this.onInputFocus()\"\r\n               autocomplete=\"off\"\r\n               [placeholder]=\"temporaryPlaceholder ? (outerControl.value && outerControl.value.length ? '' : placeholder) : placeholder\"\r\n               [formControl]=\"this.innerControl\"\r\n               [attr.cdkFocusInitial]=\"initialFocus === undefined ? null : initialFocus\">\r\n        <div matSuffix class=\"hci-combobox-arrow-wrapper\">\r\n          <mat-select\r\n            #select [multiple]=\"true\"\r\n            (selectionChange)=\"this.selectOptions($event.value)\"\r\n            (openedChange)=\"this.onOpenedChange($event)\"\r\n            [(ngModel)]=\"selectedListItems\"\r\n            [compareWith]=\"compareByID\">\r\n            <mat-option *ngFor=\"let opt of this.loadedOptions\" [value]=\"opt\">\r\n              {{this.displayField ? opt[this.displayField] : opt}}\r\n            </mat-option>\r\n            <mat-option *ngIf=\"this.includeLoadingOption\">Loading...</mat-option>\r\n            <mat-option *ngIf=\"!this.includeLoadingOption && !this.options.length\">None</mat-option>\r\n          </mat-select>\r\n        </div>\r\n      </mat-form-field>\r\n    </div>\r\n  `,\r\n  providers: [{\r\n    provide: NG_VALUE_ACCESSOR,\r\n    useExisting: CustomMultiComboBoxComponent,\r\n    multi: true,\r\n  }],\r\n  styles: [``],\r\n})\r\n\r\nexport class CustomMultiComboBoxComponent implements AfterViewInit, OnChanges, OnDestroy, ControlValueAccessor {\r\n  @ViewChild(\"input\", { static: false}) inputElement: ElementRef;\r\n  @ViewChild(\"select\", { static: false}) selectElement: MatSelect;\r\n\r\n  @Input() public label: string;\r\n  @Input() public placeholder: string = \"\";\r\n  @Input() public temporaryPlaceholder: boolean = false;\r\n  @Input() public tooltip: string = \"\";\r\n\r\n  @Input() public options: any[] = [];\r\n  public includeLoadingOption: boolean = true;\r\n  public loadedOptions: any[] = [];\r\n  private isSelectOpen: boolean = false;\r\n\r\n  @Input() private valueField: string;\r\n  @Input() private forceEmitObject: boolean = false;\r\n  @Input() public displayField: string;\r\n  @Input() public appearance: string = \"\";\r\n  @Input() public initialFocus: string;\r\n  @Input() public floatLabel: FloatLabelType;\r\n\r\n  public outerControl: AbstractControl = new UntypedFormControl([]);\r\n  public innerControl: UntypedFormControl = new UntypedFormControl(\"\");\r\n  private ignoreInnerControlChanges: boolean = false;\r\n  private innerControlSubscription: Subscription;\r\n  private noNgControl: boolean = false;\r\n  public selectedListItems: any[] = [];\r\n\r\n  @Output() selectionChanged: EventEmitter<any[]> = new EventEmitter<any[]>();\r\n\r\n  private onChangeFn: (val: any) => void = () => {};\r\n  private onTouchedFn: () => void = () => {};\r\n\r\n  constructor(private injector: Injector) {\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    let ngControl: NgControl = this.injector.get(NgControl, null);\r\n    if (ngControl && ngControl.control) {\r\n      this.outerControl = ngControl.control;\r\n      setTimeout(() => {\r\n        this.loadOnlyCurrentValue();\r\n      });\r\n    } else {\r\n      this.noNgControl = true;\r\n    }\r\n\r\n    this.innerControlSubscription = this.innerControl.valueChanges.pipe(debounceTime(300)).subscribe(() => {\r\n      if (!this.ignoreInnerControlChanges) {\r\n        this.filterOptions();\r\n      } else {\r\n        this.ignoreInnerControlChanges = false;\r\n      }\r\n    });\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes.options) {\r\n      let optionsChange: SimpleChange = changes.options;\r\n      if (!optionsChange.currentValue) {\r\n        this.options = [];\r\n      }\r\n    }\r\n\r\n    this.loadOnlyCurrentValue();\r\n  }\r\n\r\n  writeValue(obj: any): void {\r\n    this.loadOnlyCurrentValue();\r\n  }\r\n\r\n  registerOnChange(fn: any): void {\r\n    this.onChangeFn = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouchedFn = fn;\r\n  }\r\n\r\n  setDisabledState(isDisabled: boolean): void {\r\n    if (isDisabled) {\r\n      this.innerControl.disable();\r\n      this.selectElement.disabled = true;\r\n    } else {\r\n      this.innerControl.enable();\r\n      this.selectElement.disabled = false;\r\n    }\r\n  }\r\n\r\n  public onInputFocus(): void {\r\n    this.selectElement.open();\r\n  }\r\n\r\n  private loadOnlyCurrentValue(): void {\r\n    this.loadedOptions = [];\r\n    if (this.outerControl.value && this.outerControl.value.length) {\r\n      for (let opt of this.options) {\r\n        if (this.isOptInOuterValue(opt)) {\r\n          this.loadedOptions.push(opt);\r\n        }\r\n      }\r\n    }\r\n    this.selectedListItems = this.loadedOptions;\r\n\r\n\r\n    let currentValueLabel: string = \"\";\r\n    for (let opt of this.loadedOptions) {\r\n      if (currentValueLabel) {\r\n        currentValueLabel += \", \";\r\n      }\r\n      currentValueLabel += this.displayField ? opt[this.displayField] : opt;\r\n    }\r\n    this.ignoreInnerControlChanges = true;\r\n    this.innerControl.setValue(currentValueLabel);\r\n  }\r\n\r\n  private filterOptions(showAll: boolean = false): void {\r\n    if (showAll || !this.innerControl.value) {\r\n      this.loadedOptions = this.options;\r\n    } else {\r\n      let searchValue: string = this.innerControl.value.toLowerCase();\r\n      this.loadedOptions = this.options.filter((opt: any) => {\r\n        let optDisplay: string = (this.displayField ? opt[this.displayField] : opt).toLowerCase();\r\n        return optDisplay.includes(searchValue) || this.isOptInOuterValue(opt);\r\n      });\r\n    }\r\n  }\r\n\r\n  private isOptInOuterValue(opt: any): boolean {\r\n    let optValue: any = this.valueField ? opt[this.valueField] : opt;\r\n    if (this.forceEmitObject) {\r\n      for (let outerValOpt of this.outerControl.value) {\r\n        let outerOptValue: any = this.valueField ? outerValOpt[this.valueField] : outerValOpt;\r\n        if (optValue === outerOptValue) {\r\n          return true;\r\n        }\r\n      }\r\n    } else {\r\n      return this.outerControl.value.includes(optValue);\r\n    }\r\n  }\r\n\r\n  public onOpenedChange(opened: boolean): void {\r\n    this.isSelectOpen = opened;\r\n    if (opened) {\r\n      this.onTouchedFn();\r\n\r\n      this.inputElement.nativeElement.focus();\r\n      this.ignoreInnerControlChanges = true;\r\n      this.innerControl.setValue(\"\");\r\n\r\n      setTimeout(() => {\r\n        this.filterOptions(true);\r\n        this.includeLoadingOption = false;\r\n      });\r\n    } else {\r\n      setTimeout(() => {\r\n        this.loadOnlyCurrentValue();\r\n        this.includeLoadingOption = true;\r\n      });\r\n    }\r\n  }\r\n\r\n  public selectOptions(options: any[]): void {\r\n    let newVal: any[] = [];\r\n    for (let opt of options) {\r\n      if (opt) {\r\n        newVal.push((this.valueField && !this.forceEmitObject) ? opt[this.valueField] : opt);\r\n      }\r\n    }\r\n    if (this.noNgControl) {\r\n      this.outerControl.setValue(newVal);\r\n    }\r\n\r\n    this.onChangeFn(newVal);\r\n    this.selectionChanged.emit(newVal);\r\n\r\n    if (this.isSelectOpen) {\r\n      this.inputElement.nativeElement.focus();\r\n    }\r\n  }\r\n\r\n  compareByID(itemOne, itemTwo) {\r\n    if(!itemOne) {\r\n      return false;\r\n    } else if (!itemTwo) {\r\n      return false;\r\n    } else {\r\n      if(this.valueField) {\r\n        return itemOne[this.valueField] && itemTwo[this.valueField] && itemOne[this.valueField] === itemTwo[this.valueField];\r\n      } else {\r\n        return  itemOne === itemTwo;\r\n      }\r\n    }\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    if(this.innerControlSubscription) {\r\n      this.innerControlSubscription.unsubscribe();\r\n    }\r\n  }\r\n\r\n}\r\n"]}