@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.
- package/_index.scss +4 -0
- package/esm2020/lib/common/forms/elder-entity-value-accessor.mjs +22 -0
- package/esm2020/lib/common/forms/elder-form-field-control-base.directive.mjs +169 -0
- package/esm2020/lib/common/forms/elder-from-field-base.mjs +94 -0
- package/esm2020/lib/common/forms/elder-from-field-entity-base.mjs +39 -0
- package/esm2020/lib/common/forms/elder-from-field-multi-entity-base.mjs +39 -0
- package/esm2020/lib/common/forms/elder-multi-entity-value-accessor.mjs +22 -0
- package/esm2020/lib/common/forms/public_api.mjs +7 -1
- package/esm2020/lib/components/forms/directives/elder-forms-directives.module.mjs +7 -1
- package/esm2020/lib/components/input/autocomplete/elder-autocomplete.directive.mjs +4 -4
- package/esm2020/lib/components/measures/directives/elder-unit-select.directive.mjs +2 -2
- package/esm2020/lib/components/select/auto/elder-auto-select-first.directive.mjs +2 -2
- package/esm2020/lib/components/select/auto/elder-select-first-util.mjs +3 -3
- package/esm2020/lib/components/select/elder-select-base.mjs +38 -27
- package/esm2020/lib/components/select/elder-select-chip.directive.mjs +19 -5
- package/esm2020/lib/components/select/elder-select-on-tab.directive.mjs +2 -2
- package/esm2020/lib/components/select/elder-select.module.mjs +23 -12
- package/esm2020/lib/components/select/multi/elder-multi-select-base.mjs +78 -39
- package/esm2020/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.mjs +115 -83
- package/esm2020/lib/components/select/multi/elder-multi-select-form-field.mjs +61 -0
- package/esm2020/lib/components/select/popup/selection-model-popup.directive.mjs +9 -4
- package/esm2020/lib/components/select/public_api.mjs +4 -1
- package/esm2020/lib/components/select/single/elder-clear-select.directive.mjs +57 -0
- package/esm2020/lib/components/select/single/elder-select/elder-select.component.mjs +455 -0
- package/esm2020/lib/components/select/single/elder-select-form-field.mjs +45 -0
- package/fesm2015/elderbyte-ngx-starter.mjs +1019 -377
- package/fesm2015/elderbyte-ngx-starter.mjs.map +1 -1
- package/fesm2020/elderbyte-ngx-starter.mjs +1012 -375
- package/fesm2020/elderbyte-ngx-starter.mjs.map +1 -1
- package/lib/{components/select → common/forms}/elder-entity-value-accessor.d.ts +10 -0
- package/lib/common/forms/elder-form-field-control-base.directive.d.ts +101 -0
- package/lib/common/forms/elder-from-field-base.d.ts +52 -0
- package/lib/common/forms/elder-from-field-entity-base.d.ts +31 -0
- package/lib/common/forms/elder-from-field-multi-entity-base.d.ts +31 -0
- package/lib/common/forms/elder-multi-entity-value-accessor.d.ts +42 -0
- package/lib/common/forms/public_api.d.ts +6 -0
- package/lib/components/input/autocomplete/elder-autocomplete.directive.d.ts +1 -1
- package/lib/components/measures/directives/elder-unit-select.directive.d.ts +1 -1
- package/lib/components/select/auto/elder-auto-select-first.directive.d.ts +1 -1
- package/lib/components/select/auto/elder-select-first-util.d.ts +1 -1
- package/lib/components/select/elder-select-base.d.ts +21 -15
- package/lib/components/select/elder-select-chip.directive.d.ts +9 -2
- package/lib/components/select/elder-select.module.d.ts +27 -24
- package/lib/components/select/multi/elder-multi-select-base.d.ts +19 -14
- package/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.d.ts +27 -12
- package/lib/components/select/multi/elder-multi-select-form-field.d.ts +33 -0
- package/lib/components/select/popup/selection-model-popup.directive.d.ts +3 -2
- package/lib/components/select/public_api.d.ts +3 -0
- package/lib/components/select/single/elder-clear-select.directive.d.ts +34 -0
- package/lib/components/select/{elder-select → single/elder-select}/elder-select.component.d.ts +24 -12
- package/lib/components/select/single/elder-select-form-field.d.ts +30 -0
- package/package.json +1 -1
- package/src/lib/components/select/multi/elder-multi-select-chips/elder-multi-select-chips.component.scss +54 -11
- package/src/lib/components/select/single/elder-select/elder-select.component.scss +114 -0
- package/theming/_elder-common.scss +48 -0
- package/esm2020/lib/components/select/elder-entity-value-accessor.mjs +0 -13
- package/esm2020/lib/components/select/elder-select/elder-select.component.mjs +0 -419
- package/src/lib/components/select/elder-select/elder-select.component.scss +0 -61
|
@@ -1,26 +1,24 @@
|
|
|
1
|
-
import { Component, ChangeDetectionStrategy,
|
|
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 {
|
|
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/
|
|
10
|
-
import * as i2 from "@angular/
|
|
11
|
-
import * as i3 from "@angular/
|
|
12
|
-
import * as i4 from "@angular/material/
|
|
13
|
-
import * as i5 from "@angular/material/
|
|
14
|
-
import * as i6 from "@angular/
|
|
15
|
-
import * as i7 from "
|
|
16
|
-
import * as i8 from "
|
|
17
|
-
import * as i9 from "
|
|
18
|
-
import * as i10 from "
|
|
19
|
-
import * as i11 from "
|
|
20
|
-
import * as i12 from "
|
|
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.
|
|
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(([
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
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?.
|
|
130
|
+
// TODO this.inputControl?.focus(options);
|
|
131
|
+
// this.customInputTemplate.focus(options)
|
|
137
132
|
}
|
|
138
133
|
blur() {
|
|
139
|
-
this.inputControl?.
|
|
134
|
+
// TODO this.inputControl?.blur();
|
|
135
|
+
// this.customInputTemplate.blur()
|
|
140
136
|
}
|
|
141
137
|
/***************************************************************************
|
|
142
138
|
* *
|
|
143
139
|
* Private methods *
|
|
144
140
|
* *
|
|
145
141
|
**************************************************************************/
|
|
146
|
-
|
|
147
|
-
if (
|
|
148
|
-
return this.
|
|
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
|
-
|
|
155
|
-
if (
|
|
156
|
-
|
|
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
|
-
|
|
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:
|
|
168
|
-
|
|
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
|