@elderbyte/ngx-starter 14.3.2 → 14.4.0-beta.3

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 (58) hide show
  1. package/_index.scss +4 -0
  2. package/esm2020/lib/common/forms/elder-entity-value-accessor.mjs +22 -0
  3. package/esm2020/lib/common/forms/elder-form-field-control-base.directive.mjs +169 -0
  4. package/esm2020/lib/common/forms/elder-from-field-base.mjs +94 -0
  5. package/esm2020/lib/common/forms/elder-from-field-entity-base.mjs +39 -0
  6. package/esm2020/lib/common/forms/elder-from-field-multi-entity-base.mjs +39 -0
  7. package/esm2020/lib/common/forms/elder-multi-entity-value-accessor.mjs +22 -0
  8. package/esm2020/lib/common/forms/public_api.mjs +7 -1
  9. package/esm2020/lib/components/forms/directives/elder-forms-directives.module.mjs +7 -1
  10. package/esm2020/lib/components/input/autocomplete/elder-autocomplete.directive.mjs +4 -4
  11. package/esm2020/lib/components/measures/directives/elder-unit-select.directive.mjs +2 -2
  12. package/esm2020/lib/components/select/auto/elder-auto-select-first.directive.mjs +2 -2
  13. package/esm2020/lib/components/select/auto/elder-select-first-util.mjs +3 -3
  14. package/esm2020/lib/components/select/elder-select-base.mjs +38 -27
  15. package/esm2020/lib/components/select/elder-select-chip.directive.mjs +19 -5
  16. package/esm2020/lib/components/select/elder-select-on-tab.directive.mjs +2 -2
  17. package/esm2020/lib/components/select/elder-select.module.mjs +23 -12
  18. package/esm2020/lib/components/select/multi/elder-multi-select-base.mjs +78 -39
  19. package/esm2020/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.mjs +115 -83
  20. package/esm2020/lib/components/select/multi/elder-multi-select-form-field.mjs +61 -0
  21. package/esm2020/lib/components/select/popup/selection-model-popup.directive.mjs +9 -4
  22. package/esm2020/lib/components/select/public_api.mjs +4 -1
  23. package/esm2020/lib/components/select/single/elder-clear-select.directive.mjs +57 -0
  24. package/esm2020/lib/components/select/single/elder-select/elder-select.component.mjs +455 -0
  25. package/esm2020/lib/components/select/single/elder-select-form-field.mjs +45 -0
  26. package/fesm2015/elderbyte-ngx-starter.mjs +1019 -377
  27. package/fesm2015/elderbyte-ngx-starter.mjs.map +1 -1
  28. package/fesm2020/elderbyte-ngx-starter.mjs +1012 -375
  29. package/fesm2020/elderbyte-ngx-starter.mjs.map +1 -1
  30. package/lib/{components/select → common/forms}/elder-entity-value-accessor.d.ts +10 -0
  31. package/lib/common/forms/elder-form-field-control-base.directive.d.ts +101 -0
  32. package/lib/common/forms/elder-from-field-base.d.ts +52 -0
  33. package/lib/common/forms/elder-from-field-entity-base.d.ts +31 -0
  34. package/lib/common/forms/elder-from-field-multi-entity-base.d.ts +31 -0
  35. package/lib/common/forms/elder-multi-entity-value-accessor.d.ts +42 -0
  36. package/lib/common/forms/public_api.d.ts +6 -0
  37. package/lib/components/input/autocomplete/elder-autocomplete.directive.d.ts +1 -1
  38. package/lib/components/measures/directives/elder-unit-select.directive.d.ts +1 -1
  39. package/lib/components/select/auto/elder-auto-select-first.directive.d.ts +1 -1
  40. package/lib/components/select/auto/elder-select-first-util.d.ts +1 -1
  41. package/lib/components/select/elder-select-base.d.ts +21 -15
  42. package/lib/components/select/elder-select-chip.directive.d.ts +9 -2
  43. package/lib/components/select/elder-select.module.d.ts +27 -24
  44. package/lib/components/select/multi/elder-multi-select-base.d.ts +19 -14
  45. package/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.d.ts +27 -12
  46. package/lib/components/select/multi/elder-multi-select-form-field.d.ts +33 -0
  47. package/lib/components/select/popup/selection-model-popup.directive.d.ts +3 -2
  48. package/lib/components/select/public_api.d.ts +3 -0
  49. package/lib/components/select/single/elder-clear-select.directive.d.ts +34 -0
  50. package/lib/components/select/{elder-select → single/elder-select}/elder-select.component.d.ts +24 -12
  51. package/lib/components/select/single/elder-select-form-field.d.ts +30 -0
  52. package/package.json +1 -1
  53. package/src/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.scss +54 -11
  54. package/src/lib/components/select/single/elder-select/elder-select.component.scss +114 -0
  55. package/theming/_elder-common.scss +48 -0
  56. package/esm2020/lib/components/select/elder-entity-value-accessor.mjs +0 -13
  57. package/esm2020/lib/components/select/elder-select/elder-select.component.mjs +0 -419
  58. package/src/lib/components/select/elder-select/elder-select.component.scss +0 -61
@@ -1,26 +1,24 @@
1
- import { Component, ChangeDetectionStrategy, ViewChild, Input, ContentChild, TemplateRef } from '@angular/core';
1
+ import { Component, ChangeDetectionStrategy, Input, ContentChild, TemplateRef, Optional, Self, forwardRef, HostBinding } from '@angular/core';
2
2
  import { ElderMultiSelectBase } from '../elder-multi-select-base';
3
3
  import { BehaviorSubject, combineLatest } from 'rxjs';
4
4
  import { map } from 'rxjs/operators';
5
5
  import { LoggerFactory } from '@elderbyte/ts-logger';
6
- import { ElderSelectChipAvatarDirective, ElderSelectChipDirective } from '../../elder-select-chip.directive';
7
- import { buildFormIntegrationProviders } from '../../../../common/forms/template-composite-control';
6
+ import { ElderSelectChipAvatarDirective, ElderSelectChipDirective, ElderSelectCustomInputDirective } from '../../elder-select-chip.directive';
7
+ import { MatFormFieldControl } from '@angular/material/form-field';
8
+ import { ELDER_SELECT_BASE } from '../../elder-select-base';
8
9
  import * as i0 from "@angular/core";
9
- import * as i1 from "@angular/common";
10
- import * as i2 from "@angular/material/form-field";
11
- import * as i3 from "@angular/material/icon";
12
- import * as i4 from "@angular/material/button";
13
- import * as i5 from "@angular/material/input";
14
- import * as i6 from "@angular/material/autocomplete";
15
- import * as i7 from "@angular/flex-layout/flex";
16
- import * as i8 from "../../../forms/directives/elder-stop-event-propagation.directive";
17
- import * as i9 from "../../../forms/directives/elder-form-field-dense.directive";
18
- import * as i10 from "../../../forms/directives/elder-form-field-no-hint.directive";
19
- import * as i11 from "../../../input/autocomplete/elder-autocomplete/elder-autocomplete.component";
20
- import * as i12 from "../../../input/autocomplete/elder-autocomplete.directive";
21
- import * as i13 from "@angular/material/chips";
22
- import * as i14 from "@ngx-translate/core";
23
- import * as i15 from "../../../../pipes/elder-truncate.pipe";
10
+ import * as i1 from "@angular/cdk/a11y";
11
+ import * as i2 from "@angular/forms";
12
+ import * as i3 from "@angular/common";
13
+ import * as i4 from "@angular/material/icon";
14
+ import * as i5 from "@angular/material/button";
15
+ import * as i6 from "@angular/flex-layout/flex";
16
+ import * as i7 from "../../../forms/directives/elder-stop-event-propagation.directive";
17
+ import * as i8 from "@angular/material/chips";
18
+ import * as i9 from "@angular/material/tooltip";
19
+ import * as i10 from "../../single/elder-select/elder-select.component";
20
+ import * as i11 from "../../single/elder-clear-select.directive";
21
+ import * as i12 from "../../../../pipes/elder-truncate.pipe";
24
22
  class ChipModel {
25
23
  constructor(value, displayText, color, removeable) {
26
24
  this.value = value;
@@ -35,8 +33,9 @@ export class ElderMultiSelectChipsComponent extends ElderMultiSelectBase {
35
33
  * Constructor *
36
34
  * *
37
35
  **************************************************************************/
38
- constructor(zone) {
39
- super(zone);
36
+ constructor(hostRef, zone, focusMonitor, ngControl) {
37
+ super(zone, hostRef, 'multi-select-chips', focusMonitor, ngControl);
38
+ this.ngControl = ngControl;
40
39
  /***************************************************************************
41
40
  * *
42
41
  * Fields *
@@ -46,20 +45,35 @@ export class ElderMultiSelectChipsComponent extends ElderMultiSelectBase {
46
45
  this.chipColorResolver$ = new BehaviorSubject((value) => undefined);
47
46
  this.selectable = true;
48
47
  this.allowRemove = true;
49
- this.chipColorEnabled = false;
48
+ this._chipColorEnabled = false;
50
49
  this.placeholder = '...';
51
50
  this.selectChips$ = combineLatest([
52
51
  this.entities$,
52
+ this.entityIds$,
53
+ this.state$,
53
54
  this.displayPropertyResolver$,
54
55
  this.chipColorResolver$
55
- ]).pipe(map(([values, dPR, cCR]) => {
56
- if (values) {
57
- return values.map(v => new ChipModel(v, dPR(v), cCR(v), this.allowRemove));
58
- }
59
- else {
60
- return [];
61
- }
62
- }));
56
+ ]).pipe(map(([entities, entityIds, state, dPR, cCR]) => this.buildChipModelsOrFallback(entities, entityIds, state, dPR, cCR)));
57
+ }
58
+ /***************************************************************************
59
+ * *
60
+ * Host Bindings *
61
+ * *
62
+ **************************************************************************/
63
+ get hostClass() {
64
+ return 'elder-multi-select';
65
+ }
66
+ get disabledClass() {
67
+ return this.disabled;
68
+ }
69
+ get errorStateClass() {
70
+ return this.errorState;
71
+ }
72
+ get requiredClass() {
73
+ return this.required;
74
+ }
75
+ get emptyClass() {
76
+ return this.empty;
63
77
  }
64
78
  /***************************************************************************
65
79
  * *
@@ -78,6 +92,18 @@ export class ElderMultiSelectChipsComponent extends ElderMultiSelectBase {
78
92
  get chipAvatarTemplate() {
79
93
  return this._chipAvatarTemplate || this.chipAvatarTemplateQuery;
80
94
  }
95
+ set customInputTemplate(template) {
96
+ this._customInputTemplate = template;
97
+ }
98
+ get customInputTemplate() {
99
+ return this._customInputTemplate || this.customInputTemplateQuery;
100
+ }
101
+ set chipColorEnabled(enabled) {
102
+ this._chipColorEnabled = enabled;
103
+ }
104
+ get chipColorEnabled() {
105
+ return this.errorState || this._chipColorEnabled;
106
+ }
81
107
  /**
82
108
  * A function which returns the color of a given label object.
83
109
  */
@@ -92,95 +118,101 @@ export class ElderMultiSelectChipsComponent extends ElderMultiSelectBase {
92
118
  this.chipColorEnabled = true;
93
119
  this.chipColorResolver$.next(fn);
94
120
  }
95
- get isOptionDisabledInternalFn() {
96
- return (option) => {
97
- if (this.isOptionDisabledFn) {
98
- return this.isOptionDisabledFn(option);
99
- }
100
- else {
101
- return false;
102
- }
103
- };
104
- }
105
- get isOptionHiddenInternalFn() {
106
- return (option) => {
107
- if (this.isAlreadyPresent(option)) {
108
- return true;
109
- }
110
- if (this.isOptionHiddenFn) {
111
- return this.isOptionHiddenFn(option);
112
- }
113
- else {
114
- return false;
115
- }
116
- };
117
- }
118
121
  /***************************************************************************
119
122
  * *
120
123
  * Public API *
121
124
  * *
122
125
  **************************************************************************/
123
- onOptionSelected(selectedValue) {
124
- if (selectedValue) {
125
- this.resetInput();
126
- this.appendEntity(selectedValue);
127
- }
128
- }
129
126
  resolveChipValue(e1) {
130
127
  return this.getEntityId(e1);
131
128
  }
132
- get compareWithFn() {
133
- return (e1, e2) => this.isEqual(e1, e2);
134
- }
135
129
  focus(options) {
136
- this.inputControl?.nativeElement?.focus(options);
130
+ // TODO this.inputControl?.focus(options);
131
+ // this.customInputTemplate.focus(options)
137
132
  }
138
133
  blur() {
139
- this.inputControl?.nativeElement?.blur();
134
+ // TODO this.inputControl?.blur();
135
+ // this.customInputTemplate.blur()
140
136
  }
141
137
  /***************************************************************************
142
138
  * *
143
139
  * Private methods *
144
140
  * *
145
141
  **************************************************************************/
146
- isAlreadyPresent(queryValue) {
147
- if (this.entities) {
148
- return this.entities.some(v => this.isEqual(v, queryValue));
149
- }
150
- else {
151
- return false;
142
+ buildChipModelsOrFallback(entities, entityIds, state, dPR, cCR) {
143
+ if (state.error) {
144
+ return this.buildChipFallbackModels(entityIds);
152
145
  }
146
+ return this.buildChipModels(entities, dPR, cCR);
147
+ }
148
+ buildChipFallbackModels(entityIds) {
149
+ return entityIds.map(id => new ChipModel({ id: id }, String(id), 'warn', this.allowRemove));
153
150
  }
154
- resetInput() {
155
- if (this.inputControl) {
156
- this.inputControl.nativeElement.value = '';
151
+ buildChipModels(entities, dPR, cCR) {
152
+ if (entities) {
153
+ return entities.map(e => new ChipModel(e, dPR(e), cCR(e), this.allowRemove));
157
154
  }
158
155
  else {
159
- this.log.error('Failed to reset inputControl since it was not found!');
156
+ return [];
160
157
  }
161
158
  }
162
159
  }
163
- ElderMultiSelectChipsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.4", ngImport: i0, type: ElderMultiSelectChipsComponent, deps: [{ token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component });
164
- ElderMultiSelectChipsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.4", type: ElderMultiSelectChipsComponent, selector: "elder-multi-select-chips", inputs: { allowRemove: "allowRemove", chipColorEnabled: "chipColorEnabled", chipTemplate: "chipTemplate", chipColorResolver: "chipColorResolver" }, providers: buildFormIntegrationProviders(ElderMultiSelectChipsComponent), queries: [{ propertyName: "chipTemplateQuery", first: true, predicate: ElderSelectChipDirective, descendants: true, read: TemplateRef, static: true }, { propertyName: "chipAvatarTemplateQuery", first: true, predicate: ElderSelectChipAvatarDirective, descendants: true, read: TemplateRef, static: true }], viewQueries: [{ propertyName: "inputControl", first: true, predicate: ["chipInput"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<mat-form-field *ngIf=\"(selectChips$ | async) as chipValues\" fxFlex\n class=\"elder-std-form-field\"\n [appearance]=\"appearance\"\n [floatLabel]=\"floatLabel\"\n [color]=\"color\"\n [elderDense]=\"dense\"\n [elderNoHint]=\"noHint\"\n>\n\n <mat-label *ngIf=\"label\">{{label | translate}}</mat-label>\n\n\n <ng-container matPrefix *ngIf=\"(mergedState$ | async) as state\">\n\n <mat-icon *ngIf=\"icon\" disabled\n class=\"leading-icon prefix-padding noselect\"\n [class.loading]=\"state.loading\"\n [color]=\"state?.error ? 'warn' : color\">\n {{icon}}\n </mat-icon>\n\n\n <mat-icon *ngIf=\"!icon && state?.error\"\n class=\"leading-icon prefix-padding noselect\"\n color=\"warn\">\n warning\n </mat-icon>\n </ng-container>\n\n <mat-chip-list [selectable]=\"chipColorEnabled\" multiple #chips>\n <mat-chip *ngFor=\"let chipModel of chipValues\"\n class=\"noselect clickable-chip\"\n [value]=\"resolveChipValue(chipModel.value)\"\n [color]=\"chipModel.color\" [selectable]=\"chipColorEnabled\" [selected]=\"chipColorEnabled\"\n [removable]=\"chipModel.removeable\"\n (removed)=\"removeEntity(chipModel.value)\"\n (click)=\"onCurrentClicked(chipModel.value)\"\n >\n <mat-chip-avatar *ngIf=\"chipAvatarTemplate\">\n <ng-container\n *ngTemplateOutlet=\"chipAvatarTemplate; context: {$implicit: chipModel}\">\n </ng-container>\n </mat-chip-avatar>\n <ng-container\n *ngTemplateOutlet=\"chipTemplate || simpleChipTemplate; context: {$implicit: chipModel}\">\n </ng-container>\n <mat-icon matChipRemove *ngIf=\"chipModel.removeable\">cancel</mat-icon>\n </mat-chip>\n\n <div fxLayout=\"row\" fxLayoutAlign=\"start center\">\n <input matInput type=\"text\" class=\"elder-chip-input\"\n [disabled]=\"disabled\"\n [required]=\"required\"\n [readonly]=\"readonly\"\n [name]=\"name + '-multi-chips-inner-input'\"\n [placeholder]=\"placeholder | translate\"\n [matChipInputFor]=\"chips\"\n [matAutocomplete]\n [elderElderAutocomplete]=\"elderAuto\" [queryFilter]=\"queryFilter\" [filters]=\"filters\" [sorts]=\"sorts\"\n autocomplete=\"off\"\n #chipInput>\n\n <button mat-icon-button type=\"button\" class=\"small-icon-button\"\n *ngIf=\"selectionPopup\"\n [disabled]=\"isLocked\"\n (click)=\"openSelectionPopup($event)\" aria-label=\"Search\"\n elderStopEventPropagation\n tabIndex=\"-1\"\n >\n <mat-icon>search</mat-icon>\n </button>\n </div>\n </mat-chip-list>\n\n <elder-autocomplete\n #elderAuto=\"elderAutocomplete\"\n [suggestionsDc]=\"suggestionsDc$ | async\"\n [valueTemplate]=\"valueTemplate\"\n [displayPropertyResolver]=\"displayPropertyResolver$ | async\"\n [isOptionDisabledFn]=\"isOptionDisabledInternalFn\"\n [isOptionHiddenFn]=\"isOptionHiddenInternalFn\"\n (optionSelected)=\"onOptionSelected($any($event))\"\n ></elder-autocomplete>\n\n <mat-hint *ngIf=\"hint\">{{hint | translate}}</mat-hint>\n\n</mat-form-field>\n\n\n<ng-template #simpleChipTemplate let-chipModel>\n {{chipModel.displayText | elderTruncate:20}}\n</ng-template>\n\n", styles: [".prefix-padding{padding-right:4px}.leading-icon{font-size:16px;width:16px;height:16px}.elder-chip-input{width:120px!important;max-width:120px!important}.small-icon-button{width:24px!important;height:24px!important;line-height:24px!important}.small-icon-button .mat-icon{width:16px!important;height:16px!important;line-height:16px!important}.small-icon-button .material-icons{font-size:16px!important}.clickable-chip{cursor:pointer}\n"], 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: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i2.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "directive", type: i2.MatLabel, selector: "mat-label" }, { kind: "directive", type: i2.MatPrefix, selector: "[matPrefix]" }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i4.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "directive", type: i5.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { kind: "directive", type: i6.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", exportAs: ["matAutocompleteTrigger"] }, { kind: "directive", type: i7.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { kind: "directive", type: i7.DefaultLayoutAlignDirective, selector: " [fxLayoutAlign], [fxLayoutAlign.xs], [fxLayoutAlign.sm], [fxLayoutAlign.md], [fxLayoutAlign.lg], [fxLayoutAlign.xl], [fxLayoutAlign.lt-sm], [fxLayoutAlign.lt-md], [fxLayoutAlign.lt-lg], [fxLayoutAlign.lt-xl], [fxLayoutAlign.gt-xs], [fxLayoutAlign.gt-sm], [fxLayoutAlign.gt-md], [fxLayoutAlign.gt-lg]", inputs: ["fxLayoutAlign", "fxLayoutAlign.xs", "fxLayoutAlign.sm", "fxLayoutAlign.md", "fxLayoutAlign.lg", "fxLayoutAlign.xl", "fxLayoutAlign.lt-sm", "fxLayoutAlign.lt-md", "fxLayoutAlign.lt-lg", "fxLayoutAlign.lt-xl", "fxLayoutAlign.gt-xs", "fxLayoutAlign.gt-sm", "fxLayoutAlign.gt-md", "fxLayoutAlign.gt-lg"] }, { kind: "directive", type: i7.DefaultFlexDirective, selector: " [fxFlex], [fxFlex.xs], [fxFlex.sm], [fxFlex.md], [fxFlex.lg], [fxFlex.xl], [fxFlex.lt-sm], [fxFlex.lt-md], [fxFlex.lt-lg], [fxFlex.lt-xl], [fxFlex.gt-xs], [fxFlex.gt-sm], [fxFlex.gt-md], [fxFlex.gt-lg]", inputs: ["fxFlex", "fxFlex.xs", "fxFlex.sm", "fxFlex.md", "fxFlex.lg", "fxFlex.xl", "fxFlex.lt-sm", "fxFlex.lt-md", "fxFlex.lt-lg", "fxFlex.lt-xl", "fxFlex.gt-xs", "fxFlex.gt-sm", "fxFlex.gt-md", "fxFlex.gt-lg"] }, { kind: "directive", type: i8.ElderStopEventPropagationDirective, selector: "[elderStopEventPropagation]" }, { kind: "directive", type: i9.ElderFormFieldDenseDirective, selector: "mat-form-field[elderDense]", inputs: ["elderDense"] }, { kind: "directive", type: i10.ElderFormFieldNoHintDirective, selector: "mat-form-field[elderNoHint]", inputs: ["elderNoHint"] }, { kind: "component", type: i11.ElderAutocompleteComponent, selector: "elder-autocomplete", inputs: ["isOptionDisabledFn", "isOptionHiddenFn", "enabled", "valueTemplate", "suggestionsDc", "displayPropertyResolver"], outputs: ["optionSelected"], exportAs: ["elderAutocomplete"] }, { kind: "directive", type: i12.ElderAutocompleteDirective, selector: "[elderElderAutocomplete]", inputs: ["queryFilter", "filters", "sorts", "elderElderAutocomplete"] }, { kind: "component", type: i13.MatChipList, selector: "mat-chip-list", inputs: ["role", "aria-describedby", "errorStateMatcher", "multiple", "compareWith", "value", "required", "placeholder", "disabled", "aria-orientation", "selectable", "tabIndex"], outputs: ["change", "valueChange"], exportAs: ["matChipList"] }, { kind: "directive", type: i13.MatChip, selector: "mat-basic-chip, [mat-basic-chip], mat-chip, [mat-chip]", inputs: ["color", "disableRipple", "tabIndex", "role", "selected", "value", "selectable", "disabled", "removable"], outputs: ["selectionChange", "destroyed", "removed"], exportAs: ["matChip"] }, { kind: "directive", type: i13.MatChipInput, selector: "input[matChipInputFor]", inputs: ["matChipInputFor", "matChipInputAddOnBlur", "matChipInputSeparatorKeyCodes", "placeholder", "id", "disabled"], outputs: ["matChipInputTokenEnd"], exportAs: ["matChipInput", "matChipInputFor"] }, { kind: "directive", type: i13.MatChipRemove, selector: "[matChipRemove]" }, { kind: "directive", type: i13.MatChipAvatar, selector: "mat-chip-avatar, [matChipAvatar]" }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i14.TranslatePipe, name: "translate" }, { kind: "pipe", type: i15.ElderTruncatePipe, name: "elderTruncate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
160
+ ElderMultiSelectChipsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.4", ngImport: i0, type: ElderMultiSelectChipsComponent, deps: [{ token: i0.ElementRef }, { token: i0.NgZone }, { token: i1.FocusMonitor }, { token: i2.NgControl, optional: true, self: true }], target: i0.ɵɵFactoryTarget.Component });
161
+ ElderMultiSelectChipsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.4", type: ElderMultiSelectChipsComponent, selector: "elder-multi-select-chips", inputs: { allowRemove: "allowRemove", chipTemplate: "chipTemplate", chipAvatarTemplate: "chipAvatarTemplate", customInputTemplate: "customInputTemplate", chipColorEnabled: "chipColorEnabled", chipColorResolver: "chipColorResolver" }, host: { properties: { "class": "this.hostClass", "class.mat-select-disabled": "this.disabledClass", "class.mat-select-invalid": "this.errorStateClass", "class.mat-select-required": "this.requiredClass", "class.mat-select-empty": "this.emptyClass" } }, providers: [
162
+ { provide: MatFormFieldControl, useExisting: ElderMultiSelectChipsComponent },
163
+ {
164
+ provide: ELDER_SELECT_BASE,
165
+ useExisting: forwardRef(() => ElderMultiSelectChipsComponent)
166
+ }
167
+ ], queries: [{ propertyName: "chipTemplateQuery", first: true, predicate: ElderSelectChipDirective, descendants: true, read: TemplateRef, static: true }, { propertyName: "chipAvatarTemplateQuery", first: true, predicate: ElderSelectChipAvatarDirective, descendants: true, read: TemplateRef, static: true }, { propertyName: "customInputTemplateQuery", first: true, predicate: ElderSelectCustomInputDirective, descendants: true, read: TemplateRef, static: true }], usesInheritance: true, ngImport: i0, template: "<div *ngIf=\"(selectChips$ | async) as chipValues\" fxFlex\n class=\"elder-form-control\"\n [matTooltip]=\"(state$ | async)?.error\"\n>\n <ng-container *ngIf=\"(mergedState$ | async) as state\">\n <div *ngIf=\"icon\" fxFlex=\"none\"\n class=\"elder-input-prefix-icon-container\"\n >\n <mat-icon *ngIf=\"icon\" disabled\n class=\"elder-select-icon elder-icon-small noselect\"\n [class.loading]=\"state.loading\"\n >\n {{icon}}\n </mat-icon>\n </div>\n </ng-container>\n\n\n <mat-chip-list [selectable]=\"chipColorEnabled\" multiple #chips>\n <mat-chip *ngFor=\"let chipModel of chipValues\"\n class=\"noselect clickable-chip\"\n [value]=\"resolveChipValue(chipModel.value)\"\n [color]=\"chipModel.color\" [selectable]=\"chipColorEnabled\" [selected]=\"chipColorEnabled\"\n [removable]=\"chipModel.removeable\"\n (removed)=\"removeEntity(chipModel.value)\"\n (click)=\"onCurrentClicked(chipModel.value)\"\n >\n <mat-chip-avatar *ngIf=\"chipAvatarTemplate\">\n <ng-container\n *ngTemplateOutlet=\"chipAvatarTemplate; context: {$implicit: chipModel}\">\n </ng-container>\n </mat-chip-avatar>\n <ng-container\n *ngTemplateOutlet=\"chipTemplate || simpleChipTemplate; context: {$implicit: chipModel}\">\n </ng-container>\n <mat-icon matChipRemove *ngIf=\"chipModel.removeable\">cancel</mat-icon>\n </mat-chip>\n\n <div fxLayout=\"row\" fxLayoutAlign=\"start center\" style=\"padding-top: 7px; padding-bottom: 7px;\">\n\n <!-- [matChipInputFor]=\"chips\" -->\n <ng-container\n *ngTemplateOutlet=\"customInputTemplate || selectInput;\">\n </ng-container>\n\n <button mat-icon-button type=\"button\" class=\"elder-icon-button-small\"\n *ngIf=\"selectionPopup\"\n [disabled]=\"isLocked\"\n (click)=\"openSelectionPopup($event)\" aria-label=\"Search\"\n elderStopEventPropagation\n tabIndex=\"-1\"\n >\n <mat-icon class=\"elder-select-icon\">search</mat-icon>\n </button>\n </div>\n </mat-chip-list>\n</div>\n\n<ng-template #selectInput>\n <elder-select autocomplete elderClearSelect\n [data]=\"dataContext$ | async\"\n [disabled]=\"!!disabled\"\n [required]=\"!!required\"\n [readonly]=\"!!readonly\"\n [placeholder]=\"placeholder\"\n (entityUpdated)=\"appendEntity($event)\"\n [displayPropertyResolver]=\"displayPropertyResolver$ | async\"\n [valueTemplate]=\"valueTemplate\"\n [queryFilter]=\"queryFilter\" [filters]=\"filters\" [sorts]=\"sorts\"\n [isOptionDisabledFn]=\"isOptionDisabledInternalFn\"\n [isOptionHiddenFn]=\"isOptionHiddenInternalFn\"\n ></elder-select>\n</ng-template>\n\n<ng-template #simpleChipTemplate let-chipModel>\n <span class=\"elder-chip-text\">{{chipModel.displayText | elderTruncate:20}}</span>\n</ng-template>\n\n", styles: [".small-icon-button{width:24px!important;height:24px!important;line-height:24px!important}.small-icon-button .mat-icon{width:16px!important;height:16px!important;line-height:16px!important}.small-icon-button .material-icons{font-size:16px!important}.clickable-chip{cursor:pointer}.elder-chip-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i4.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i5.MatButton, selector: "button[mat-button], button[mat-raised-button], button[mat-icon-button], button[mat-fab], button[mat-mini-fab], button[mat-stroked-button], button[mat-flat-button]", inputs: ["disabled", "disableRipple", "color"], exportAs: ["matButton"] }, { kind: "directive", type: i6.DefaultLayoutDirective, selector: " [fxLayout], [fxLayout.xs], [fxLayout.sm], [fxLayout.md], [fxLayout.lg], [fxLayout.xl], [fxLayout.lt-sm], [fxLayout.lt-md], [fxLayout.lt-lg], [fxLayout.lt-xl], [fxLayout.gt-xs], [fxLayout.gt-sm], [fxLayout.gt-md], [fxLayout.gt-lg]", inputs: ["fxLayout", "fxLayout.xs", "fxLayout.sm", "fxLayout.md", "fxLayout.lg", "fxLayout.xl", "fxLayout.lt-sm", "fxLayout.lt-md", "fxLayout.lt-lg", "fxLayout.lt-xl", "fxLayout.gt-xs", "fxLayout.gt-sm", "fxLayout.gt-md", "fxLayout.gt-lg"] }, { kind: "directive", type: i6.DefaultLayoutAlignDirective, selector: " [fxLayoutAlign], [fxLayoutAlign.xs], [fxLayoutAlign.sm], [fxLayoutAlign.md], [fxLayoutAlign.lg], [fxLayoutAlign.xl], [fxLayoutAlign.lt-sm], [fxLayoutAlign.lt-md], [fxLayoutAlign.lt-lg], [fxLayoutAlign.lt-xl], [fxLayoutAlign.gt-xs], [fxLayoutAlign.gt-sm], [fxLayoutAlign.gt-md], [fxLayoutAlign.gt-lg]", inputs: ["fxLayoutAlign", "fxLayoutAlign.xs", "fxLayoutAlign.sm", "fxLayoutAlign.md", "fxLayoutAlign.lg", "fxLayoutAlign.xl", "fxLayoutAlign.lt-sm", "fxLayoutAlign.lt-md", "fxLayoutAlign.lt-lg", "fxLayoutAlign.lt-xl", "fxLayoutAlign.gt-xs", "fxLayoutAlign.gt-sm", "fxLayoutAlign.gt-md", "fxLayoutAlign.gt-lg"] }, { kind: "directive", type: i6.DefaultFlexDirective, selector: " [fxFlex], [fxFlex.xs], [fxFlex.sm], [fxFlex.md], [fxFlex.lg], [fxFlex.xl], [fxFlex.lt-sm], [fxFlex.lt-md], [fxFlex.lt-lg], [fxFlex.lt-xl], [fxFlex.gt-xs], [fxFlex.gt-sm], [fxFlex.gt-md], [fxFlex.gt-lg]", inputs: ["fxFlex", "fxFlex.xs", "fxFlex.sm", "fxFlex.md", "fxFlex.lg", "fxFlex.xl", "fxFlex.lt-sm", "fxFlex.lt-md", "fxFlex.lt-lg", "fxFlex.lt-xl", "fxFlex.gt-xs", "fxFlex.gt-sm", "fxFlex.gt-md", "fxFlex.gt-lg"] }, { kind: "directive", type: i7.ElderStopEventPropagationDirective, selector: "[elderStopEventPropagation]" }, { kind: "component", type: i8.MatChipList, selector: "mat-chip-list", inputs: ["role", "aria-describedby", "errorStateMatcher", "multiple", "compareWith", "value", "required", "placeholder", "disabled", "aria-orientation", "selectable", "tabIndex"], outputs: ["change", "valueChange"], exportAs: ["matChipList"] }, { kind: "directive", type: i8.MatChip, selector: "mat-basic-chip, [mat-basic-chip], mat-chip, [mat-chip]", inputs: ["color", "disableRipple", "tabIndex", "role", "selected", "value", "selectable", "disabled", "removable"], outputs: ["selectionChange", "destroyed", "removed"], exportAs: ["matChip"] }, { kind: "directive", type: i8.MatChipRemove, selector: "[matChipRemove]" }, { kind: "directive", type: i8.MatChipAvatar, selector: "mat-chip-avatar, [matChipAvatar]" }, { kind: "directive", type: i9.MatTooltip, selector: "[matTooltip]", exportAs: ["matTooltip"] }, { kind: "component", type: i10.ElderSelectComponent, selector: "elder-select", inputs: ["nullDisplay", "autocomplete", "allowNull", "entity", "entityId", "hintProperty", "hintPropertyResolver"], outputs: ["entityIdChange", "entityIdUpdated", "entityChange", "entityUpdated"] }, { kind: "directive", type: i11.ElderClearSelectDirective, selector: "[elderClearSelect]" }, { kind: "pipe", type: i3.AsyncPipe, name: "async" }, { kind: "pipe", type: i12.ElderTruncatePipe, name: "elderTruncate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
165
168
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.4", ngImport: i0, type: ElderMultiSelectChipsComponent, decorators: [{
166
169
  type: Component,
167
- args: [{ selector: 'elder-multi-select-chips', changeDetection: ChangeDetectionStrategy.OnPush, providers: buildFormIntegrationProviders(ElderMultiSelectChipsComponent), template: "<mat-form-field *ngIf=\"(selectChips$ | async) as chipValues\" fxFlex\n class=\"elder-std-form-field\"\n [appearance]=\"appearance\"\n [floatLabel]=\"floatLabel\"\n [color]=\"color\"\n [elderDense]=\"dense\"\n [elderNoHint]=\"noHint\"\n>\n\n <mat-label *ngIf=\"label\">{{label | translate}}</mat-label>\n\n\n <ng-container matPrefix *ngIf=\"(mergedState$ | async) as state\">\n\n <mat-icon *ngIf=\"icon\" disabled\n class=\"leading-icon prefix-padding noselect\"\n [class.loading]=\"state.loading\"\n [color]=\"state?.error ? 'warn' : color\">\n {{icon}}\n </mat-icon>\n\n\n <mat-icon *ngIf=\"!icon && state?.error\"\n class=\"leading-icon prefix-padding noselect\"\n color=\"warn\">\n warning\n </mat-icon>\n </ng-container>\n\n <mat-chip-list [selectable]=\"chipColorEnabled\" multiple #chips>\n <mat-chip *ngFor=\"let chipModel of chipValues\"\n class=\"noselect clickable-chip\"\n [value]=\"resolveChipValue(chipModel.value)\"\n [color]=\"chipModel.color\" [selectable]=\"chipColorEnabled\" [selected]=\"chipColorEnabled\"\n [removable]=\"chipModel.removeable\"\n (removed)=\"removeEntity(chipModel.value)\"\n (click)=\"onCurrentClicked(chipModel.value)\"\n >\n <mat-chip-avatar *ngIf=\"chipAvatarTemplate\">\n <ng-container\n *ngTemplateOutlet=\"chipAvatarTemplate; context: {$implicit: chipModel}\">\n </ng-container>\n </mat-chip-avatar>\n <ng-container\n *ngTemplateOutlet=\"chipTemplate || simpleChipTemplate; context: {$implicit: chipModel}\">\n </ng-container>\n <mat-icon matChipRemove *ngIf=\"chipModel.removeable\">cancel</mat-icon>\n </mat-chip>\n\n <div fxLayout=\"row\" fxLayoutAlign=\"start center\">\n <input matInput type=\"text\" class=\"elder-chip-input\"\n [disabled]=\"disabled\"\n [required]=\"required\"\n [readonly]=\"readonly\"\n [name]=\"name + '-multi-chips-inner-input'\"\n [placeholder]=\"placeholder | translate\"\n [matChipInputFor]=\"chips\"\n [matAutocomplete]\n [elderElderAutocomplete]=\"elderAuto\" [queryFilter]=\"queryFilter\" [filters]=\"filters\" [sorts]=\"sorts\"\n autocomplete=\"off\"\n #chipInput>\n\n <button mat-icon-button type=\"button\" class=\"small-icon-button\"\n *ngIf=\"selectionPopup\"\n [disabled]=\"isLocked\"\n (click)=\"openSelectionPopup($event)\" aria-label=\"Search\"\n elderStopEventPropagation\n tabIndex=\"-1\"\n >\n <mat-icon>search</mat-icon>\n </button>\n </div>\n </mat-chip-list>\n\n <elder-autocomplete\n #elderAuto=\"elderAutocomplete\"\n [suggestionsDc]=\"suggestionsDc$ | async\"\n [valueTemplate]=\"valueTemplate\"\n [displayPropertyResolver]=\"displayPropertyResolver$ | async\"\n [isOptionDisabledFn]=\"isOptionDisabledInternalFn\"\n [isOptionHiddenFn]=\"isOptionHiddenInternalFn\"\n (optionSelected)=\"onOptionSelected($any($event))\"\n ></elder-autocomplete>\n\n <mat-hint *ngIf=\"hint\">{{hint | translate}}</mat-hint>\n\n</mat-form-field>\n\n\n<ng-template #simpleChipTemplate let-chipModel>\n {{chipModel.displayText | elderTruncate:20}}\n</ng-template>\n\n", styles: [".prefix-padding{padding-right:4px}.leading-icon{font-size:16px;width:16px;height:16px}.elder-chip-input{width:120px!important;max-width:120px!important}.small-icon-button{width:24px!important;height:24px!important;line-height:24px!important}.small-icon-button .mat-icon{width:16px!important;height:16px!important;line-height:16px!important}.small-icon-button .material-icons{font-size:16px!important}.clickable-chip{cursor:pointer}\n"] }]
168
- }], ctorParameters: function () { return [{ type: i0.NgZone }]; }, propDecorators: { allowRemove: [{
170
+ args: [{ selector: 'elder-multi-select-chips', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
171
+ { provide: MatFormFieldControl, useExisting: ElderMultiSelectChipsComponent },
172
+ {
173
+ provide: ELDER_SELECT_BASE,
174
+ useExisting: forwardRef(() => ElderMultiSelectChipsComponent)
175
+ }
176
+ ], template: "<div *ngIf=\"(selectChips$ | async) as chipValues\" fxFlex\n class=\"elder-form-control\"\n [matTooltip]=\"(state$ | async)?.error\"\n>\n <ng-container *ngIf=\"(mergedState$ | async) as state\">\n <div *ngIf=\"icon\" fxFlex=\"none\"\n class=\"elder-input-prefix-icon-container\"\n >\n <mat-icon *ngIf=\"icon\" disabled\n class=\"elder-select-icon elder-icon-small noselect\"\n [class.loading]=\"state.loading\"\n >\n {{icon}}\n </mat-icon>\n </div>\n </ng-container>\n\n\n <mat-chip-list [selectable]=\"chipColorEnabled\" multiple #chips>\n <mat-chip *ngFor=\"let chipModel of chipValues\"\n class=\"noselect clickable-chip\"\n [value]=\"resolveChipValue(chipModel.value)\"\n [color]=\"chipModel.color\" [selectable]=\"chipColorEnabled\" [selected]=\"chipColorEnabled\"\n [removable]=\"chipModel.removeable\"\n (removed)=\"removeEntity(chipModel.value)\"\n (click)=\"onCurrentClicked(chipModel.value)\"\n >\n <mat-chip-avatar *ngIf=\"chipAvatarTemplate\">\n <ng-container\n *ngTemplateOutlet=\"chipAvatarTemplate; context: {$implicit: chipModel}\">\n </ng-container>\n </mat-chip-avatar>\n <ng-container\n *ngTemplateOutlet=\"chipTemplate || simpleChipTemplate; context: {$implicit: chipModel}\">\n </ng-container>\n <mat-icon matChipRemove *ngIf=\"chipModel.removeable\">cancel</mat-icon>\n </mat-chip>\n\n <div fxLayout=\"row\" fxLayoutAlign=\"start center\" style=\"padding-top: 7px; padding-bottom: 7px;\">\n\n <!-- [matChipInputFor]=\"chips\" -->\n <ng-container\n *ngTemplateOutlet=\"customInputTemplate || selectInput;\">\n </ng-container>\n\n <button mat-icon-button type=\"button\" class=\"elder-icon-button-small\"\n *ngIf=\"selectionPopup\"\n [disabled]=\"isLocked\"\n (click)=\"openSelectionPopup($event)\" aria-label=\"Search\"\n elderStopEventPropagation\n tabIndex=\"-1\"\n >\n <mat-icon class=\"elder-select-icon\">search</mat-icon>\n </button>\n </div>\n </mat-chip-list>\n</div>\n\n<ng-template #selectInput>\n <elder-select autocomplete elderClearSelect\n [data]=\"dataContext$ | async\"\n [disabled]=\"!!disabled\"\n [required]=\"!!required\"\n [readonly]=\"!!readonly\"\n [placeholder]=\"placeholder\"\n (entityUpdated)=\"appendEntity($event)\"\n [displayPropertyResolver]=\"displayPropertyResolver$ | async\"\n [valueTemplate]=\"valueTemplate\"\n [queryFilter]=\"queryFilter\" [filters]=\"filters\" [sorts]=\"sorts\"\n [isOptionDisabledFn]=\"isOptionDisabledInternalFn\"\n [isOptionHiddenFn]=\"isOptionHiddenInternalFn\"\n ></elder-select>\n</ng-template>\n\n<ng-template #simpleChipTemplate let-chipModel>\n <span class=\"elder-chip-text\">{{chipModel.displayText | elderTruncate:20}}</span>\n</ng-template>\n\n", styles: [".small-icon-button{width:24px!important;height:24px!important;line-height:24px!important}.small-icon-button .mat-icon{width:16px!important;height:16px!important;line-height:16px!important}.small-icon-button .material-icons{font-size:16px!important}.clickable-chip{cursor:pointer}.elder-chip-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}\n"] }]
177
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.NgZone }, { type: i1.FocusMonitor }, { type: i2.NgControl, decorators: [{
178
+ type: Optional
179
+ }, {
180
+ type: Self
181
+ }] }]; }, propDecorators: { allowRemove: [{
169
182
  type: Input
170
- }], chipColorEnabled: [{
171
- type: Input
172
- }], inputControl: [{
173
- type: ViewChild,
174
- args: ['chipInput', { static: false }]
175
183
  }], chipTemplateQuery: [{
176
184
  type: ContentChild,
177
185
  args: [ElderSelectChipDirective, { read: TemplateRef, static: true }]
178
186
  }], chipAvatarTemplateQuery: [{
179
187
  type: ContentChild,
180
188
  args: [ElderSelectChipAvatarDirective, { read: TemplateRef, static: true }]
189
+ }], customInputTemplateQuery: [{
190
+ type: ContentChild,
191
+ args: [ElderSelectCustomInputDirective, { read: TemplateRef, static: true }]
192
+ }], hostClass: [{
193
+ type: HostBinding,
194
+ args: ['class']
195
+ }], disabledClass: [{
196
+ type: HostBinding,
197
+ args: ['class.mat-select-disabled']
198
+ }], errorStateClass: [{
199
+ type: HostBinding,
200
+ args: ['class.mat-select-invalid']
201
+ }], requiredClass: [{
202
+ type: HostBinding,
203
+ args: ['class.mat-select-required']
204
+ }], emptyClass: [{
205
+ type: HostBinding,
206
+ args: ['class.mat-select-empty']
181
207
  }], chipTemplate: [{
182
208
  type: Input
209
+ }], chipAvatarTemplate: [{
210
+ type: Input
211
+ }], customInputTemplate: [{
212
+ type: Input
213
+ }], chipColorEnabled: [{
214
+ type: Input
183
215
  }], chipColorResolver: [{
184
216
  type: Input
185
217
  }] } });
186
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-multi-select-chips.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.ts","../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, OnInit, ChangeDetectionStrategy, NgZone, ViewChild, ElementRef, Input, ContentChild, TemplateRef} from '@angular/core';\nimport {ElderMultiSelectBase} from '../elder-multi-select-base';\nimport {BehaviorSubject, combineLatest, Observable} from 'rxjs';\nimport {map} from 'rxjs/operators';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {ElderSelectChipAvatarDirective, ElderSelectChipDirective} from '../../elder-select-chip.directive';\nimport {buildFormIntegrationProviders} from '../../../../common/forms/template-composite-control';\nimport {ThemePalette} from '@angular/material/core';\n\nclass ChipModel<T> {\n  constructor(\n    public readonly value: T,\n    public readonly displayText: string,\n    public readonly color: ThemePalette,\n    public readonly removeable: boolean\n  ) {\n  }\n}\n\n\n@Component({\n  selector: 'elder-multi-select-chips',\n  templateUrl: './elder-multi-select-chips.component.html',\n  styleUrls: ['./elder-multi-select-chips.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: buildFormIntegrationProviders(ElderMultiSelectChipsComponent)\n})\nexport class ElderMultiSelectChipsComponent<TId = any, TEntity = any, TValue = any>\n  extends ElderMultiSelectBase<TId, TEntity, TValue> {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly log = LoggerFactory.getLogger(this.constructor.name);\n\n  public readonly selectChips$: Observable<ChipModel<TEntity>[]>;\n\n  private readonly chipColorResolver$ = new BehaviorSubject<(o1: any) => ThemePalette>((value: TEntity) => undefined);\n\n\n  public selectable = true;\n\n  @Input()\n  public allowRemove = true;\n\n  @Input()\n  public chipColorEnabled = false;\n\n  @ViewChild('chipInput', {static: false})\n  private inputControl: ElementRef<HTMLInputElement>;\n\n  @ContentChild(ElderSelectChipDirective, {read: TemplateRef, static: true})\n  public chipTemplateQuery: TemplateRef<any>;\n  private _chipTemplate: TemplateRef<any>;\n\n  @ContentChild(ElderSelectChipAvatarDirective, {read: TemplateRef, static: true})\n  public chipAvatarTemplateQuery: TemplateRef<any>;\n  private _chipAvatarTemplate: TemplateRef<any>;\n\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    zone: NgZone\n  ) {\n    super(zone);\n    this.placeholder = '...';\n    this.selectChips$ = combineLatest(\n      [\n        this.entities$,\n        this.displayPropertyResolver$,\n        this.chipColorResolver$\n      ]\n    ).pipe(\n      map(([values, dPR, cCR]) => {\n        if (values) {\n          return values.map(\n            v => new ChipModel<TEntity>(\n              v,\n              dPR(v),\n              cCR(v),\n              this.allowRemove\n            )\n          );\n        } else {\n          return <ChipModel<TEntity>[]>[];\n        }\n      })\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set chipTemplate(template: TemplateRef<any>) {\n    this._chipTemplate = template;\n  }\n\n  public get chipTemplate(): TemplateRef<any> {\n    return this._chipTemplate || this.chipTemplateQuery;\n  }\n\n  public set chipAvatarTemplate(template: TemplateRef<any>) {\n    this._chipAvatarTemplate = template;\n  }\n\n  public get chipAvatarTemplate(): TemplateRef<any> {\n    return this._chipAvatarTemplate || this.chipAvatarTemplateQuery;\n  }\n\n  /**\n   * A function which returns the color of a given label object.\n   */\n  @Input()\n  public set chipColorResolver(fn: (o1: any) => ThemePalette) {\n    if (!fn) {\n      this.chipColorEnabled = false;\n      return;\n    }\n    if (typeof fn !== 'function') {\n      throw new Error('chipColorResolver must be a function!');\n    }\n    this.chipColorEnabled = true;\n    this.chipColorResolver$.next(fn);\n  }\n\n  public get isOptionDisabledInternalFn(): (option: TEntity) => boolean {\n    return (option: TEntity) => {\n      if (this.isOptionDisabledFn) {\n        return this.isOptionDisabledFn(option);\n      } else {\n        return false;\n      }\n    };\n  }\n\n  public get isOptionHiddenInternalFn(): (option: TEntity) => boolean {\n    return (option: TEntity) => {\n      if (this.isAlreadyPresent(option)) {\n        return true;\n      }\n      if (this.isOptionHiddenFn) {\n        return this.isOptionHiddenFn(option);\n      } else {\n        return false;\n      }\n    };\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public onOptionSelected(selectedValue: TEntity): void {\n    if (selectedValue) {\n      this.resetInput();\n      this.appendEntity(selectedValue);\n    }\n  }\n\n  public resolveChipValue(e1: TEntity): any {\n    return this.getEntityId(e1);\n  }\n\n  public get compareWithFn(): (e1: TEntity, e2: TEntity) => boolean {\n    return (e1: TEntity, e2: TEntity) => this.isEqual(e1, e2);\n  }\n\n  public focus(options?: FocusOptions) {\n    this.inputControl?.nativeElement?.focus(options);\n  }\n\n  public blur() {\n    this.inputControl?.nativeElement?.blur();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private isAlreadyPresent(queryValue: TEntity): boolean {\n    if (this.entities) {\n      return this.entities.some(v => this.isEqual(v, queryValue));\n    } else {\n      return false;\n    }\n  }\n\n  private resetInput(): void {\n    if (this.inputControl) {\n      this.inputControl.nativeElement.value = '';\n    } else {\n      this.log.error('Failed to reset inputControl since it was not found!');\n    }\n  }\n\n}\n","<mat-form-field *ngIf=\"(selectChips$ | async) as chipValues\" fxFlex\n                class=\"elder-std-form-field\"\n                [appearance]=\"appearance\"\n                [floatLabel]=\"floatLabel\"\n                [color]=\"color\"\n                [elderDense]=\"dense\"\n                [elderNoHint]=\"noHint\"\n>\n\n  <mat-label *ngIf=\"label\">{{label | translate}}</mat-label>\n\n\n  <ng-container matPrefix *ngIf=\"(mergedState$ | async) as state\">\n\n    <mat-icon *ngIf=\"icon\" disabled\n              class=\"leading-icon prefix-padding noselect\"\n              [class.loading]=\"state.loading\"\n              [color]=\"state?.error ? 'warn' : color\">\n      {{icon}}\n    </mat-icon>\n\n\n    <mat-icon *ngIf=\"!icon && state?.error\"\n              class=\"leading-icon prefix-padding noselect\"\n              color=\"warn\">\n      warning\n    </mat-icon>\n  </ng-container>\n\n  <mat-chip-list [selectable]=\"chipColorEnabled\" multiple #chips>\n    <mat-chip *ngFor=\"let chipModel of chipValues\"\n              class=\"noselect clickable-chip\"\n              [value]=\"resolveChipValue(chipModel.value)\"\n              [color]=\"chipModel.color\" [selectable]=\"chipColorEnabled\" [selected]=\"chipColorEnabled\"\n              [removable]=\"chipModel.removeable\"\n              (removed)=\"removeEntity(chipModel.value)\"\n              (click)=\"onCurrentClicked(chipModel.value)\"\n    >\n      <mat-chip-avatar *ngIf=\"chipAvatarTemplate\">\n        <ng-container\n          *ngTemplateOutlet=\"chipAvatarTemplate; context: {$implicit: chipModel}\">\n        </ng-container>\n      </mat-chip-avatar>\n      <ng-container\n        *ngTemplateOutlet=\"chipTemplate || simpleChipTemplate; context: {$implicit: chipModel}\">\n      </ng-container>\n      <mat-icon matChipRemove *ngIf=\"chipModel.removeable\">cancel</mat-icon>\n    </mat-chip>\n\n    <div fxLayout=\"row\" fxLayoutAlign=\"start center\">\n      <input matInput type=\"text\" class=\"elder-chip-input\"\n             [disabled]=\"disabled\"\n             [required]=\"required\"\n             [readonly]=\"readonly\"\n             [name]=\"name + '-multi-chips-inner-input'\"\n             [placeholder]=\"placeholder | translate\"\n             [matChipInputFor]=\"chips\"\n             [matAutocomplete]\n             [elderElderAutocomplete]=\"elderAuto\" [queryFilter]=\"queryFilter\" [filters]=\"filters\" [sorts]=\"sorts\"\n             autocomplete=\"off\"\n             #chipInput>\n\n      <button mat-icon-button type=\"button\" class=\"small-icon-button\"\n              *ngIf=\"selectionPopup\"\n              [disabled]=\"isLocked\"\n              (click)=\"openSelectionPopup($event)\" aria-label=\"Search\"\n              elderStopEventPropagation\n              tabIndex=\"-1\"\n      >\n        <mat-icon>search</mat-icon>\n      </button>\n    </div>\n  </mat-chip-list>\n\n  <elder-autocomplete\n    #elderAuto=\"elderAutocomplete\"\n    [suggestionsDc]=\"suggestionsDc$ | async\"\n    [valueTemplate]=\"valueTemplate\"\n    [displayPropertyResolver]=\"displayPropertyResolver$ | async\"\n    [isOptionDisabledFn]=\"isOptionDisabledInternalFn\"\n    [isOptionHiddenFn]=\"isOptionHiddenInternalFn\"\n    (optionSelected)=\"onOptionSelected($any($event))\"\n  ></elder-autocomplete>\n\n  <mat-hint *ngIf=\"hint\">{{hint | translate}}</mat-hint>\n\n</mat-form-field>\n\n\n<ng-template #simpleChipTemplate let-chipModel>\n  {{chipModel.displayText | elderTruncate:20}}\n</ng-template>\n\n"]}
218
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-multi-select-chips.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.ts","../../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  OnInit,\n  ChangeDetectionStrategy,\n  NgZone,\n  ViewChild,\n  ElementRef,\n  Input,\n  ContentChild,\n  TemplateRef,\n  Optional, Self, forwardRef, OnDestroy, HostBinding\n} from '@angular/core';\nimport {ElderMultiSelectBase} from '../elder-multi-select-base';\nimport {BehaviorSubject, combineLatest, Observable, Subject} from 'rxjs';\nimport {map, takeUntil} from 'rxjs/operators';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {ElderSelectChipAvatarDirective, ElderSelectChipDirective, ElderSelectCustomInputDirective} from '../../elder-select-chip.directive';\nimport {ThemePalette} from '@angular/material/core';\nimport {NG_VALIDATORS, NgControl} from '@angular/forms';\nimport {MatFormFieldControl} from '@angular/material/form-field';\nimport {ELDER_SELECT_BASE, ElderSelectComponentState, TextResolverFn} from '../../elder-select-base';\nimport {FocusMonitor} from '@angular/cdk/a11y';\nimport {ElderSelectComponent} from '../../single/elder-select/elder-select.component';\n\nclass ChipModel<T> {\n  constructor(\n    public readonly value: T,\n    public readonly displayText: string,\n    public readonly color: ThemePalette,\n    public readonly removeable: boolean\n  ) {\n  }\n}\n\n\n@Component({\n  selector: 'elder-multi-select-chips',\n  templateUrl: './elder-multi-select-chips.component.html',\n  styleUrls: ['./elder-multi-select-chips.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {provide: MatFormFieldControl, useExisting: ElderMultiSelectChipsComponent},\n    {\n      provide: ELDER_SELECT_BASE,\n      useExisting: forwardRef(() => ElderMultiSelectChipsComponent)\n    }\n  ]\n})\nexport class ElderMultiSelectChipsComponent<TId = any, TEntity = any, TValue = any>\n  extends ElderMultiSelectBase<TId, TEntity, TValue> {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly log = LoggerFactory.getLogger(this.constructor.name);\n\n  public readonly selectChips$: Observable<ChipModel<TEntity>[]>;\n\n  private readonly chipColorResolver$ = new BehaviorSubject<(o1: any) => ThemePalette>((value: TEntity) => undefined);\n\n\n  public selectable = true;\n\n  @Input()\n  public allowRemove = true;\n\n  @ContentChild(ElderSelectChipDirective, {read: TemplateRef, static: true})\n  public chipTemplateQuery: TemplateRef<any>;\n  private _chipTemplate: TemplateRef<any>;\n\n  @ContentChild(ElderSelectChipAvatarDirective, {read: TemplateRef, static: true})\n  public chipAvatarTemplateQuery: TemplateRef<any>;\n  private _chipAvatarTemplate: TemplateRef<any>;\n\n  @ContentChild(ElderSelectCustomInputDirective, {read: TemplateRef, static: true})\n  public customInputTemplateQuery: TemplateRef<any>;\n  private _customInputTemplate: TemplateRef<any>;\n\n\n  private _chipColorEnabled = false;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    hostRef: ElementRef,\n    zone: NgZone,\n    focusMonitor: FocusMonitor,\n    @Optional() @Self() public ngControl: NgControl\n  ) {\n    super(zone, hostRef, 'multi-select-chips', focusMonitor, ngControl);\n\n    this.placeholder = '...';\n\n    this.selectChips$ = combineLatest(\n      [\n        this.entities$,\n        this.entityIds$,\n        this.state$,\n        this.displayPropertyResolver$,\n        this.chipColorResolver$\n      ]\n    ).pipe(\n      map(([entities, entityIds, state, dPR, cCR]) =>\n        this.buildChipModelsOrFallback(entities, entityIds, state, dPR, cCR)\n      )\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Host Bindings                                                           *\n   *                                                                         *\n   **************************************************************************/\n\n  @HostBinding('class') get hostClass(): string {\n    return 'elder-multi-select';\n  }\n\n  @HostBinding('class.mat-select-disabled') get disabledClass(): boolean {\n    return this.disabled;\n  }\n\n  @HostBinding('class.mat-select-invalid') get errorStateClass(): boolean {\n    return this.errorState;\n  }\n\n  @HostBinding('class.mat-select-required') get requiredClass(): boolean {\n    return this.required;\n  }\n\n  @HostBinding('class.mat-select-empty') get emptyClass(): boolean {\n    return this.empty;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set chipTemplate(template: TemplateRef<any>) {\n    this._chipTemplate = template;\n  }\n\n  public get chipTemplate(): TemplateRef<any> {\n    return this._chipTemplate || this.chipTemplateQuery;\n  }\n\n  @Input()\n  public set chipAvatarTemplate(template: TemplateRef<any>) {\n    this._chipAvatarTemplate = template;\n  }\n\n  public get chipAvatarTemplate(): TemplateRef<any> {\n    return this._chipAvatarTemplate || this.chipAvatarTemplateQuery;\n  }\n\n  @Input()\n  public set customInputTemplate(template: TemplateRef<any>) {\n    this._customInputTemplate = template;\n  }\n\n  public get customInputTemplate(): TemplateRef<any> {\n    return this._customInputTemplate || this.customInputTemplateQuery;\n  }\n\n  @Input()\n  public set chipColorEnabled(enabled: boolean) {\n    this._chipColorEnabled = enabled;\n  }\n\n  public get chipColorEnabled(): boolean {\n    return this.errorState || this._chipColorEnabled;\n  }\n\n\n  /**\n   * A function which returns the color of a given label object.\n   */\n  @Input()\n  public set chipColorResolver(fn: (o1: any) => ThemePalette) {\n    if (!fn) {\n      this.chipColorEnabled = false;\n      return;\n    }\n    if (typeof fn !== 'function') {\n      throw new Error('chipColorResolver must be a function!');\n    }\n    this.chipColorEnabled = true;\n    this.chipColorResolver$.next(fn);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public resolveChipValue(e1: TEntity): any {\n    return this.getEntityId(e1);\n  }\n\n  public focus(options?: FocusOptions) {\n    // TODO this.inputControl?.focus(options);\n    // this.customInputTemplate.focus(options)\n  }\n\n  public blur() {\n    // TODO this.inputControl?.blur();\n    // this.customInputTemplate.blur()\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  private buildChipModelsOrFallback(\n    entities: TEntity[],\n    entityIds: TId[],\n    state: ElderSelectComponentState,\n    dPR: TextResolverFn,\n    cCR: (o1: any) => ThemePalette\n  ): ChipModel<TEntity>[] {\n\n    if (state.error) {\n      return this.buildChipFallbackModels(entityIds);\n    }\n    return this.buildChipModels(entities, dPR, cCR);\n  }\n\n\n  private buildChipFallbackModels(entityIds: TId[]): ChipModel<TEntity>[] {\n    return entityIds.map(\n      id => new ChipModel<TEntity>(\n        <any>{id: id},\n        String(id),\n        'warn',\n        this.allowRemove\n      )\n    );\n  }\n\n  private buildChipModels(\n    entities: TEntity[],\n    dPR: TextResolverFn,\n    cCR: (o1: any) => ThemePalette\n  ): ChipModel<TEntity>[] {\n    if (entities) {\n      return entities.map(\n        e => new ChipModel<TEntity>(\n          e,\n          dPR(e),\n          cCR(e),\n          this.allowRemove\n        )\n      );\n    } else {\n      return <ChipModel<TEntity>[]>[];\n    }\n  }\n\n}\n","<div *ngIf=\"(selectChips$ | async) as chipValues\" fxFlex\n                class=\"elder-form-control\"\n     [matTooltip]=\"(state$ | async)?.error\"\n>\n  <ng-container *ngIf=\"(mergedState$ | async) as state\">\n    <div *ngIf=\"icon\" fxFlex=\"none\"\n         class=\"elder-input-prefix-icon-container\"\n    >\n      <mat-icon *ngIf=\"icon\" disabled\n                class=\"elder-select-icon elder-icon-small noselect\"\n                [class.loading]=\"state.loading\"\n                >\n        {{icon}}\n      </mat-icon>\n    </div>\n  </ng-container>\n\n\n  <mat-chip-list [selectable]=\"chipColorEnabled\" multiple #chips>\n    <mat-chip *ngFor=\"let chipModel of chipValues\"\n              class=\"noselect clickable-chip\"\n              [value]=\"resolveChipValue(chipModel.value)\"\n              [color]=\"chipModel.color\" [selectable]=\"chipColorEnabled\" [selected]=\"chipColorEnabled\"\n              [removable]=\"chipModel.removeable\"\n              (removed)=\"removeEntity(chipModel.value)\"\n              (click)=\"onCurrentClicked(chipModel.value)\"\n    >\n      <mat-chip-avatar *ngIf=\"chipAvatarTemplate\">\n        <ng-container\n          *ngTemplateOutlet=\"chipAvatarTemplate; context: {$implicit: chipModel}\">\n        </ng-container>\n      </mat-chip-avatar>\n      <ng-container\n        *ngTemplateOutlet=\"chipTemplate || simpleChipTemplate; context: {$implicit: chipModel}\">\n      </ng-container>\n      <mat-icon matChipRemove *ngIf=\"chipModel.removeable\">cancel</mat-icon>\n    </mat-chip>\n\n    <div fxLayout=\"row\" fxLayoutAlign=\"start center\" style=\"padding-top: 7px; padding-bottom: 7px;\">\n\n      <!-- [matChipInputFor]=\"chips\" -->\n      <ng-container\n        *ngTemplateOutlet=\"customInputTemplate || selectInput;\">\n      </ng-container>\n\n      <button mat-icon-button type=\"button\" class=\"elder-icon-button-small\"\n              *ngIf=\"selectionPopup\"\n              [disabled]=\"isLocked\"\n              (click)=\"openSelectionPopup($event)\" aria-label=\"Search\"\n              elderStopEventPropagation\n              tabIndex=\"-1\"\n      >\n        <mat-icon class=\"elder-select-icon\">search</mat-icon>\n      </button>\n    </div>\n  </mat-chip-list>\n</div>\n\n<ng-template #selectInput>\n  <elder-select autocomplete elderClearSelect\n                [data]=\"dataContext$ | async\"\n                [disabled]=\"!!disabled\"\n                [required]=\"!!required\"\n                [readonly]=\"!!readonly\"\n                [placeholder]=\"placeholder\"\n                (entityUpdated)=\"appendEntity($event)\"\n                [displayPropertyResolver]=\"displayPropertyResolver$ | async\"\n                [valueTemplate]=\"valueTemplate\"\n                [queryFilter]=\"queryFilter\" [filters]=\"filters\" [sorts]=\"sorts\"\n                [isOptionDisabledFn]=\"isOptionDisabledInternalFn\"\n                [isOptionHiddenFn]=\"isOptionHiddenInternalFn\"\n  ></elder-select>\n</ng-template>\n\n<ng-template #simpleChipTemplate let-chipModel>\n  <span class=\"elder-chip-text\">{{chipModel.displayText | elderTruncate:20}}</span>\n</ng-template>\n\n"]}
@@ -0,0 +1,61 @@
1
+ import { Directive, ViewChild } from '@angular/core';
2
+ import { ElderSelectValueDirective } from '../elder-select-value.directive';
3
+ import { ElderFromFieldMultiEntityBase } from '../../../common/forms/elder-from-field-multi-entity-base';
4
+ import { ElderSelectChipAvatarDirective, ElderSelectChipDirective } from '../elder-select-chip.directive';
5
+ import { ElderSelectBase } from '../elder-select-base';
6
+ import { ElderMultiSelectChipsComponent } from './elder-multi-select-chips/elder-multi-select-chips.component';
7
+ import { SelectionModelPopupDirective } from '../popup/selection-model-popup.directive';
8
+ import * as i0 from "@angular/core";
9
+ export class ElderMultiSelectFormField extends ElderFromFieldMultiEntityBase {
10
+ /***************************************************************************
11
+ * *
12
+ * Constructor *
13
+ * *
14
+ **************************************************************************/
15
+ constructor(initSelectFn) {
16
+ super();
17
+ this.applyToControl(initSelectFn);
18
+ }
19
+ /***************************************************************************
20
+ * *
21
+ * Life Cycle *
22
+ * *
23
+ **************************************************************************/
24
+ ngAfterViewInit() {
25
+ const control = this.formFieldControl$.getValue();
26
+ if (control instanceof ElderSelectBase) {
27
+ if (this.selectValueTemplate) {
28
+ control.valueTemplate = this.selectValueTemplate.templateRef;
29
+ }
30
+ if (this.selectionModelPopupDirective) {
31
+ control.selectionPopup = this.selectionModelPopupDirective;
32
+ }
33
+ }
34
+ if (control instanceof ElderMultiSelectChipsComponent) {
35
+ if (this.selectChipDirective) {
36
+ control.chipTemplate = this.selectChipDirective.templateRef;
37
+ }
38
+ if (this.selectChipAvatarDirective) {
39
+ control.chipAvatarTemplate = this.selectChipAvatarDirective.templateRef;
40
+ }
41
+ }
42
+ }
43
+ }
44
+ ElderMultiSelectFormField.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.4", ngImport: i0, type: ElderMultiSelectFormField, deps: "invalid", target: i0.ɵɵFactoryTarget.Directive });
45
+ ElderMultiSelectFormField.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.0.4", type: ElderMultiSelectFormField, viewQueries: [{ propertyName: "selectValueTemplate", first: true, predicate: ElderSelectValueDirective, descendants: true }, { propertyName: "selectionModelPopupDirective", first: true, predicate: SelectionModelPopupDirective, descendants: true }, { propertyName: "selectChipDirective", first: true, predicate: ElderSelectChipDirective, descendants: true }, { propertyName: "selectChipAvatarDirective", first: true, predicate: ElderSelectChipAvatarDirective, descendants: true }], usesInheritance: true, ngImport: i0 });
46
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.4", ngImport: i0, type: ElderMultiSelectFormField, decorators: [{
47
+ type: Directive
48
+ }], ctorParameters: function () { return [{ type: undefined }]; }, propDecorators: { selectValueTemplate: [{
49
+ type: ViewChild,
50
+ args: [ElderSelectValueDirective]
51
+ }], selectionModelPopupDirective: [{
52
+ type: ViewChild,
53
+ args: [SelectionModelPopupDirective]
54
+ }], selectChipDirective: [{
55
+ type: ViewChild,
56
+ args: [ElderSelectChipDirective]
57
+ }], selectChipAvatarDirective: [{
58
+ type: ViewChild,
59
+ args: [ElderSelectChipAvatarDirective]
60
+ }] } });
61
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItbXVsdGktc2VsZWN0LWZvcm0tZmllbGQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9lbGRlcmJ5dGUvbmd4LXN0YXJ0ZXIvc3JjL2xpYi9jb21wb25lbnRzL3NlbGVjdC9tdWx0aS9lbGRlci1tdWx0aS1zZWxlY3QtZm9ybS1maWVsZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQWdCLFNBQVMsRUFBRSxTQUFTLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDbEUsT0FBTyxFQUFDLHlCQUF5QixFQUFDLE1BQU0saUNBQWlDLENBQUM7QUFHMUUsT0FBTyxFQUFDLDZCQUE2QixFQUFDLE1BQU0sMERBQTBELENBQUM7QUFDdkcsT0FBTyxFQUFDLDhCQUE4QixFQUFFLHdCQUF3QixFQUFDLE1BQU0sZ0NBQWdDLENBQUM7QUFDeEcsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLHNCQUFzQixDQUFDO0FBQ3JELE9BQU8sRUFBQyw4QkFBOEIsRUFBQyxNQUFNLCtEQUErRCxDQUFDO0FBQzdHLE9BQU8sRUFBQyw0QkFBNEIsRUFBQyxNQUFNLDBDQUEwQyxDQUFDOztBQUd0RixNQUFNLE9BQWdCLHlCQUNwQixTQUFRLDZCQUErRjtJQXFCdkc7Ozs7Z0ZBSTRFO0lBRTVFLFlBQ0UsWUFBNkU7UUFFN0UsS0FBSyxFQUFFLENBQUM7UUFDUixJQUFJLENBQUMsY0FBYyxDQUFDLFlBQVksQ0FBQyxDQUFDO0lBQ3BDLENBQUM7SUFFRDs7OztnRkFJNEU7SUFFckUsZUFBZTtRQUNwQixNQUFNLE9BQU8sR0FBRyxJQUFJLENBQUMsaUJBQWlCLENBQUMsUUFBUSxFQUFFLENBQUM7UUFFbEQsSUFBSSxPQUFPLFlBQVksZUFBZSxFQUFFO1lBQ3RDLElBQUksSUFBSSxDQUFDLG1CQUFtQixFQUFFO2dCQUM1QixPQUFPLENBQUMsYUFBYSxHQUFHLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxXQUFXLENBQUM7YUFDOUQ7WUFDRCxJQUFJLElBQUksQ0FBQyw0QkFBNEIsRUFBRTtnQkFDckMsT0FBTyxDQUFDLGNBQWMsR0FBRyxJQUFJLENBQUMsNEJBQTRCLENBQUM7YUFDNUQ7U0FDRjtRQUVELElBQUksT0FBTyxZQUFZLDhCQUE4QixFQUFFO1lBQ3JELElBQUksSUFBSSxDQUFDLG1CQUFtQixFQUFFO2dCQUM1QixPQUFPLENBQUMsWUFBWSxHQUFHLElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxXQUFXLENBQUM7YUFDN0Q7WUFDRCxJQUFJLElBQUksQ0FBQyx5QkFBeUIsRUFBRTtnQkFDbEMsT0FBTyxDQUFDLGtCQUFrQixHQUFHLElBQUksQ0FBQyx5QkFBeUIsQ0FBQyxXQUFXLENBQUM7YUFDekU7U0FDRjtJQUNILENBQUM7O3NIQTdEbUIseUJBQXlCOzBHQUF6Qix5QkFBeUIsK0VBVWxDLHlCQUF5QiwrRkFHekIsNEJBQTRCLHNGQUc1Qix3QkFBd0IsNEZBR3hCLDhCQUE4QjsyRkFuQnJCLHlCQUF5QjtrQkFEOUMsU0FBUzs2RkFZRCxtQkFBbUI7c0JBRHpCLFNBQVM7dUJBQUMseUJBQXlCO2dCQUk3Qiw0QkFBNEI7c0JBRGxDLFNBQVM7dUJBQUMsNEJBQTRCO2dCQUloQyxtQkFBbUI7c0JBRHpCLFNBQVM7dUJBQUMsd0JBQXdCO2dCQUk1Qix5QkFBeUI7c0JBRC9CLFNBQVM7dUJBQUMsOEJBQThCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtBZnRlclZpZXdJbml0LCBEaXJlY3RpdmUsIFZpZXdDaGlsZH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0VsZGVyU2VsZWN0VmFsdWVEaXJlY3RpdmV9IGZyb20gJy4uL2VsZGVyLXNlbGVjdC12YWx1ZS5kaXJlY3RpdmUnO1xuaW1wb3J0IHtFbGRlckFwcGx5Q29udHJvbEZufSBmcm9tICcuLi8uLi8uLi9jb21tb24vZm9ybXMvZWxkZXItZnJvbS1maWVsZC1iYXNlJztcbmltcG9ydCB7RWxkZXJNdWx0aVNlbGVjdEJhc2V9IGZyb20gJy4vZWxkZXItbXVsdGktc2VsZWN0LWJhc2UnO1xuaW1wb3J0IHtFbGRlckZyb21GaWVsZE11bHRpRW50aXR5QmFzZX0gZnJvbSAnLi4vLi4vLi4vY29tbW9uL2Zvcm1zL2VsZGVyLWZyb20tZmllbGQtbXVsdGktZW50aXR5LWJhc2UnO1xuaW1wb3J0IHtFbGRlclNlbGVjdENoaXBBdmF0YXJEaXJlY3RpdmUsIEVsZGVyU2VsZWN0Q2hpcERpcmVjdGl2ZX0gZnJvbSAnLi4vZWxkZXItc2VsZWN0LWNoaXAuZGlyZWN0aXZlJztcbmltcG9ydCB7RWxkZXJTZWxlY3RCYXNlfSBmcm9tICcuLi9lbGRlci1zZWxlY3QtYmFzZSc7XG5pbXBvcnQge0VsZGVyTXVsdGlTZWxlY3RDaGlwc0NvbXBvbmVudH0gZnJvbSAnLi9lbGRlci1tdWx0aS1zZWxlY3QtY2hpcHMvZWxkZXItbXVsdGktc2VsZWN0LWNoaXBzLmNvbXBvbmVudCc7XG5pbXBvcnQge1NlbGVjdGlvbk1vZGVsUG9wdXBEaXJlY3RpdmV9IGZyb20gJy4uL3BvcHVwL3NlbGVjdGlvbi1tb2RlbC1wb3B1cC5kaXJlY3RpdmUnO1xuXG5ARGlyZWN0aXZlKClcbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBFbGRlck11bHRpU2VsZWN0Rm9ybUZpZWxkPFRFbnRpdHksIFRJZCwgVFZhbHVlID0gVEVudGl0eSB8IFRJZD5cbiAgZXh0ZW5kcyBFbGRlckZyb21GaWVsZE11bHRpRW50aXR5QmFzZTxURW50aXR5LCBUSWQsIFRWYWx1ZSwgRWxkZXJNdWx0aVNlbGVjdEJhc2U8VElkLCBURW50aXR5LCBUVmFsdWU+PlxuICBpbXBsZW1lbnRzIEFmdGVyVmlld0luaXQge1xuXG4gIC8qKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKipcbiAgICogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiBGaWVsZHMgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICoqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqL1xuXG4gIEBWaWV3Q2hpbGQoRWxkZXJTZWxlY3RWYWx1ZURpcmVjdGl2ZSlcbiAgcHVibGljIHNlbGVjdFZhbHVlVGVtcGxhdGU6IEVsZGVyU2VsZWN0VmFsdWVEaXJlY3RpdmU7XG5cbiAgQFZpZXdDaGlsZChTZWxlY3Rpb25Nb2RlbFBvcHVwRGlyZWN0aXZlKVxuICBwdWJsaWMgc2VsZWN0aW9uTW9kZWxQb3B1cERpcmVjdGl2ZTogU2VsZWN0aW9uTW9kZWxQb3B1cERpcmVjdGl2ZTtcblxuICBAVmlld0NoaWxkKEVsZGVyU2VsZWN0Q2hpcERpcmVjdGl2ZSlcbiAgcHVibGljIHNlbGVjdENoaXBEaXJlY3RpdmU6IEVsZGVyU2VsZWN0Q2hpcERpcmVjdGl2ZTtcblxuICBAVmlld0NoaWxkKEVsZGVyU2VsZWN0Q2hpcEF2YXRhckRpcmVjdGl2ZSlcbiAgcHVibGljIHNlbGVjdENoaXBBdmF0YXJEaXJlY3RpdmU6IEVsZGVyU2VsZWN0Q2hpcEF2YXRhckRpcmVjdGl2ZTtcblxuICAvKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogQ29uc3RydWN0b3IgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi9cblxuICBwcm90ZWN0ZWQgY29uc3RydWN0b3IoXG4gICAgaW5pdFNlbGVjdEZuOiBFbGRlckFwcGx5Q29udHJvbEZuPEVsZGVyTXVsdGlTZWxlY3RCYXNlPFRJZCwgVEVudGl0eSwgVFZhbHVlPj5cbiAgKSB7XG4gICAgc3VwZXIoKTtcbiAgICB0aGlzLmFwcGx5VG9Db250cm9sKGluaXRTZWxlY3RGbik7XG4gIH1cblxuICAvKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqXG4gICAqICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICpcbiAgICogTGlmZSBDeWNsZSAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgKlxuICAgKiAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAqXG4gICAqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKioqKi9cblxuICBwdWJsaWMgbmdBZnRlclZpZXdJbml0KCk6IHZvaWQge1xuICAgIGNvbnN0IGNvbnRyb2wgPSB0aGlzLmZvcm1GaWVsZENvbnRyb2wkLmdldFZhbHVlKCk7XG5cbiAgICBpZiAoY29udHJvbCBpbnN0YW5jZW9mIEVsZGVyU2VsZWN0QmFzZSkge1xuICAgICAgaWYgKHRoaXMuc2VsZWN0VmFsdWVUZW1wbGF0ZSkge1xuICAgICAgICBjb250cm9sLnZhbHVlVGVtcGxhdGUgPSB0aGlzLnNlbGVjdFZhbHVlVGVtcGxhdGUudGVtcGxhdGVSZWY7XG4gICAgICB9XG4gICAgICBpZiAodGhpcy5zZWxlY3Rpb25Nb2RlbFBvcHVwRGlyZWN0aXZlKSB7XG4gICAgICAgIGNvbnRyb2wuc2VsZWN0aW9uUG9wdXAgPSB0aGlzLnNlbGVjdGlvbk1vZGVsUG9wdXBEaXJlY3RpdmU7XG4gICAgICB9XG4gICAgfVxuXG4gICAgaWYgKGNvbnRyb2wgaW5zdGFuY2VvZiBFbGRlck11bHRpU2VsZWN0Q2hpcHNDb21wb25lbnQpIHtcbiAgICAgIGlmICh0aGlzLnNlbGVjdENoaXBEaXJlY3RpdmUpIHtcbiAgICAgICAgY29udHJvbC5jaGlwVGVtcGxhdGUgPSB0aGlzLnNlbGVjdENoaXBEaXJlY3RpdmUudGVtcGxhdGVSZWY7XG4gICAgICB9XG4gICAgICBpZiAodGhpcy5zZWxlY3RDaGlwQXZhdGFyRGlyZWN0aXZlKSB7XG4gICAgICAgIGNvbnRyb2wuY2hpcEF2YXRhclRlbXBsYXRlID0gdGhpcy5zZWxlY3RDaGlwQXZhdGFyRGlyZWN0aXZlLnRlbXBsYXRlUmVmO1xuICAgICAgfVxuICAgIH1cbiAgfVxufVxuIl19