@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
|
@@ -83,6 +83,54 @@
|
|
|
83
83
|
}
|
|
84
84
|
}
|
|
85
85
|
|
|
86
|
+
/******************************
|
|
87
|
+
Material Form Controls
|
|
88
|
+
*******************************/
|
|
89
|
+
|
|
90
|
+
.elder-icon-button-small {
|
|
91
|
+
width: 18px !important;
|
|
92
|
+
height: 18px !important;
|
|
93
|
+
line-height: 18px !important;
|
|
94
|
+
|
|
95
|
+
.mat-icon {
|
|
96
|
+
width: 18px !important;
|
|
97
|
+
height: 18px !important;
|
|
98
|
+
line-height: 18px !important;
|
|
99
|
+
}
|
|
100
|
+
.material-icons {
|
|
101
|
+
font-size: 18px !important;
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
.elder-input-prefix-icon-container {
|
|
106
|
+
height: 18px !important;
|
|
107
|
+
min-width: 24px !important;
|
|
108
|
+
padding-right: 3px;
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
.elder-icon-small-container {
|
|
112
|
+
height: 24px !important;
|
|
113
|
+
min-width: 24px !important;
|
|
114
|
+
padding: 3px;
|
|
115
|
+
}
|
|
116
|
+
|
|
117
|
+
.elder-icon-small {
|
|
118
|
+
width: 18px !important;
|
|
119
|
+
height: 18px !important;
|
|
120
|
+
line-height: 18px !important;
|
|
121
|
+
font-size: 18px !important;
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
/******************************
|
|
125
|
+
Material Form Controls
|
|
126
|
+
*******************************/
|
|
127
|
+
|
|
128
|
+
.elder-form-control {
|
|
129
|
+
width: 180px;
|
|
130
|
+
overflow: hidden; // This allows flex items to shrink (min/max is not defaulting auto)
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
|
|
86
134
|
/******************************
|
|
87
135
|
Material Form Field
|
|
88
136
|
*******************************/
|
|
@@ -1,13 +0,0 @@
|
|
|
1
|
-
export function isElderEntityValueAccessor(object) {
|
|
2
|
-
if (!object) {
|
|
3
|
-
return false;
|
|
4
|
-
}
|
|
5
|
-
const vac = object;
|
|
6
|
-
return 'entity' in vac // This might be undefined
|
|
7
|
-
&& 'entityId' in vac // This might be undefined
|
|
8
|
-
&& vac.entityIdChange !== undefined
|
|
9
|
-
&& vac.entityChange !== undefined
|
|
10
|
-
&& vac.updateValueByEntity !== undefined
|
|
11
|
-
&& vac.entityToValue !== undefined;
|
|
12
|
-
}
|
|
13
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWxkZXItZW50aXR5LXZhbHVlLWFjY2Vzc29yLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWxkZXJieXRlL25neC1zdGFydGVyL3NyYy9saWIvY29tcG9uZW50cy9zZWxlY3QvZWxkZXItZW50aXR5LXZhbHVlLWFjY2Vzc29yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXlDQSxNQUFNLFVBQVUsMEJBQTBCLENBQUMsTUFBVztJQUVwRCxJQUFJLENBQUMsTUFBTSxFQUFFO1FBQUUsT0FBTyxLQUFLLENBQUM7S0FBRTtJQUU5QixNQUFNLEdBQUcsR0FBRyxNQUFrRCxDQUFDO0lBRS9ELE9BQU8sUUFBUSxJQUFJLEdBQUcsQ0FBQywwQkFBMEI7V0FDNUMsVUFBVSxJQUFJLEdBQUcsQ0FBQywwQkFBMEI7V0FDNUMsR0FBRyxDQUFDLGNBQWMsS0FBSyxTQUFTO1dBQ2hDLEdBQUcsQ0FBQyxZQUFZLEtBQUssU0FBUztXQUM5QixHQUFHLENBQUMsbUJBQW1CLEtBQUssU0FBUztXQUNyQyxHQUFHLENBQUMsYUFBYSxLQUFLLFNBQVMsQ0FBQztBQUN2QyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtPYnNlcnZhYmxlfSBmcm9tICdyeGpzJztcblxuZXhwb3J0IGludGVyZmFjZSBJRWxkZXJFbnRpdHlWYWx1ZUFjY2Vzc29yPFRFbnRpdHksIFRJZCwgVFZhbHVlPiB7XG5cbiAgLyoqXG4gICAqIEdldHMgb3Igc2V0cyB0aGUgZW50aXR5XG4gICAqL1xuICBlbnRpdHk6IFRFbnRpdHk7XG5cbiAgLyoqXG4gICAqIEdldHMgb3Igc2V0cyB0aGUgZW50aXR5IGlkXG4gICAqL1xuICBlbnRpdHlJZDogVElkO1xuXG4gIC8qKlxuICAgKiBFbWl0cyB3aGVuIHRoZSBlbnRpdHkgaWQgaGFzIGNoYW5nZWQuXG4gICAqL1xuICBlbnRpdHlJZENoYW5nZTogT2JzZXJ2YWJsZTxUSWQ+O1xuXG4gIC8qKlxuICAgKiBFbWl0cyB3aGVuIHRoZSBlbnRpdHkgaGFzIGNoYW5nZWQuXG4gICAqL1xuICBlbnRpdHlDaGFuZ2U6IE9ic2VydmFibGU8VEVudGl0eT47XG5cbiAgLyoqXG4gICAqIFVwZGF0ZSB0aGUgY29udHJvbCB2YWx1ZSBieSB0aGUgZ2l2ZW4gZW50aXR5XG4gICAqIGFuZCBlbWl0IGEgdmFsdWUtdXBkYXRlZCBldmVudCB3aGljaCBzaW11bGF0ZXNcbiAgICogYSB1c2VyIGFjdGlvbi5cbiAgICogQHBhcmFtIGVudGl0eVxuICAgKi9cbiAgdXBkYXRlVmFsdWVCeUVudGl0eShlbnRpdHk6IFRFbnRpdHkpOiB2b2lkO1xuXG4gIC8qKlxuICAgKiBDb252ZXJ0IGFuIGVudGl0eSB0byBhIHZhbHVlIGZvciB0aGlzIGNvbnRyb2wuXG4gICAqIEBwYXJhbSBlbnRpdHlcbiAgICovXG4gIGVudGl0eVRvVmFsdWUoZW50aXR5OiBURW50aXR5KTogVFZhbHVlO1xuXG59XG5cblxuZXhwb3J0IGZ1bmN0aW9uIGlzRWxkZXJFbnRpdHlWYWx1ZUFjY2Vzc29yKG9iamVjdDogYW55KTogb2JqZWN0IGlzIElFbGRlckVudGl0eVZhbHVlQWNjZXNzb3I8YW55LCBhbnksIGFueT4ge1xuXG4gIGlmICghb2JqZWN0KSB7IHJldHVybiBmYWxzZTsgfVxuXG4gIGNvbnN0IHZhYyA9IG9iamVjdCBhcyBJRWxkZXJFbnRpdHlWYWx1ZUFjY2Vzc29yPGFueSwgYW55LCBhbnk+O1xuXG4gIHJldHVybiAnZW50aXR5JyBpbiB2YWMgLy8gVGhpcyBtaWdodCBiZSB1bmRlZmluZWRcbiAgICAmJiAnZW50aXR5SWQnIGluIHZhYyAvLyBUaGlzIG1pZ2h0IGJlIHVuZGVmaW5lZFxuICAgICYmIHZhYy5lbnRpdHlJZENoYW5nZSAhPT0gdW5kZWZpbmVkXG4gICAgJiYgdmFjLmVudGl0eUNoYW5nZSAhPT0gdW5kZWZpbmVkXG4gICAgJiYgdmFjLnVwZGF0ZVZhbHVlQnlFbnRpdHkgIT09IHVuZGVmaW5lZFxuICAgICYmIHZhYy5lbnRpdHlUb1ZhbHVlICE9PSB1bmRlZmluZWQ7XG59XG4iXX0=
|
|
@@ -1,419 +0,0 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, forwardRef, Input, Output, ViewChild, } from '@angular/core';
|
|
2
|
-
import { buildFormIntegrationProviders } from '../../../common/forms/template-composite-control';
|
|
3
|
-
import { LoggerFactory } from '@elderbyte/ts-logger';
|
|
4
|
-
import { BehaviorSubject, combineLatest, EMPTY, Subject } from 'rxjs';
|
|
5
|
-
import { map, takeUntil, tap, skip, filter, switchMap, take, timeout, catchError } from 'rxjs/operators';
|
|
6
|
-
import { coerceBooleanProperty } from '@angular/cdk/coercion';
|
|
7
|
-
import { ELDER_SELECT_BASE, ElderSelectBase, ElderSelectComponentState } from '../elder-select-base';
|
|
8
|
-
import { ElderSelectFirstUtil } from '../auto/elder-select-first-util';
|
|
9
|
-
import * as i0 from "@angular/core";
|
|
10
|
-
import * as i1 from "@angular/common";
|
|
11
|
-
import * as i2 from "@angular/forms";
|
|
12
|
-
import * as i3 from "@angular/material/form-field";
|
|
13
|
-
import * as i4 from "@angular/material/icon";
|
|
14
|
-
import * as i5 from "@angular/material/button";
|
|
15
|
-
import * as i6 from "@angular/material/input";
|
|
16
|
-
import * as i7 from "@angular/material/autocomplete";
|
|
17
|
-
import * as i8 from "@angular/flex-layout/flex";
|
|
18
|
-
import * as i9 from "../../forms/directives/elder-stop-event-propagation.directive";
|
|
19
|
-
import * as i10 from "../../forms/directives/elder-form-field-dense.directive";
|
|
20
|
-
import * as i11 from "../../forms/directives/elder-form-field-no-hint.directive";
|
|
21
|
-
import * as i12 from "../../input/autocomplete/elder-autocomplete/elder-autocomplete.component";
|
|
22
|
-
import * as i13 from "../../input/autocomplete/elder-autocomplete.directive";
|
|
23
|
-
import * as i14 from "../elder-select-on-tab.directive";
|
|
24
|
-
import * as i15 from "@ngx-translate/core";
|
|
25
|
-
class EntityContext {
|
|
26
|
-
constructor(value, hintText, displayText) {
|
|
27
|
-
this.value = value;
|
|
28
|
-
this.hintText = hintText;
|
|
29
|
-
this.displayText = displayText;
|
|
30
|
-
}
|
|
31
|
-
}
|
|
32
|
-
/**
|
|
33
|
-
* The elder-select control allows to select a single
|
|
34
|
-
* entity.
|
|
35
|
-
*
|
|
36
|
-
* Primary focus is on easy usage for common scenarios:
|
|
37
|
-
*
|
|
38
|
-
* - Integrated into angular forms and validation
|
|
39
|
-
* - Support entity id handling, input / output is the entity id vs full value.
|
|
40
|
-
*
|
|
41
|
-
*/
|
|
42
|
-
export class ElderSelectComponent extends ElderSelectBase {
|
|
43
|
-
/***************************************************************************
|
|
44
|
-
* *
|
|
45
|
-
* Constructor *
|
|
46
|
-
* *
|
|
47
|
-
**************************************************************************/
|
|
48
|
-
constructor(zone) {
|
|
49
|
-
super(zone);
|
|
50
|
-
/***************************************************************************
|
|
51
|
-
* *
|
|
52
|
-
* Fields *
|
|
53
|
-
* *
|
|
54
|
-
**************************************************************************/
|
|
55
|
-
this.logger = LoggerFactory.getLogger(this.constructor.name);
|
|
56
|
-
this.hintPropertyResolver$ = new BehaviorSubject((value) => null);
|
|
57
|
-
this._allowNull = false;
|
|
58
|
-
/**
|
|
59
|
-
* String to display for the 'nothing' / null value.
|
|
60
|
-
*/
|
|
61
|
-
this.nullDisplay = '-';
|
|
62
|
-
this._entity$ = new BehaviorSubject(undefined);
|
|
63
|
-
this._autocomplete = false;
|
|
64
|
-
this.unsubscribe$ = new Subject();
|
|
65
|
-
this.entityIdChange = this.valueChange.pipe(map(v => this.entityIdFromValue(v)));
|
|
66
|
-
this.entityChange = this._entity$.pipe(skip(1) // Skip the initial or current value
|
|
67
|
-
);
|
|
68
|
-
this.entityIdUpdated = this.valueUpdated.pipe(map(value => this.entityIdFromValue(value)));
|
|
69
|
-
this.entityUpdated = this.entityIdUpdated.pipe(switchMap(entityId => this.awaitEntityWithId(entityId, this.timeoutAfterMs)), catchError(err => {
|
|
70
|
-
this.logger.warn(`awaitEntityWithId -> timed out after: ${this.timeoutAfterMs}`, err);
|
|
71
|
-
return EMPTY;
|
|
72
|
-
}));
|
|
73
|
-
this.entityWrapped$ = combineLatest([
|
|
74
|
-
this._entity$,
|
|
75
|
-
this.displayPropertyResolver$,
|
|
76
|
-
this.hintPropertyResolver$
|
|
77
|
-
]).pipe(map(([value, dPR, hPR]) => new EntityContext(value, hPR(value), dPR(value))));
|
|
78
|
-
this.inputText$ = this.entityWrapped$.pipe(takeUntil(this.unsubscribe$), tap(valueContext => this.entityContext = valueContext), map(valueContext => {
|
|
79
|
-
if (valueContext.value) {
|
|
80
|
-
return valueContext.displayText;
|
|
81
|
-
}
|
|
82
|
-
else {
|
|
83
|
-
return null;
|
|
84
|
-
}
|
|
85
|
-
}));
|
|
86
|
-
}
|
|
87
|
-
/***************************************************************************
|
|
88
|
-
* *
|
|
89
|
-
* Life Cycle *
|
|
90
|
-
* *
|
|
91
|
-
**************************************************************************/
|
|
92
|
-
ngOnInit() {
|
|
93
|
-
}
|
|
94
|
-
ngOnDestroy() {
|
|
95
|
-
this.unsubscribe$.next();
|
|
96
|
-
this.unsubscribe$.complete();
|
|
97
|
-
this.autoCleanUp();
|
|
98
|
-
}
|
|
99
|
-
/***************************************************************************
|
|
100
|
-
* *
|
|
101
|
-
* Behaviour Properties *
|
|
102
|
-
* *
|
|
103
|
-
**************************************************************************/
|
|
104
|
-
set autocomplete(value) {
|
|
105
|
-
this._autocomplete = coerceBooleanProperty(value);
|
|
106
|
-
}
|
|
107
|
-
get autocomplete() {
|
|
108
|
-
return this._autocomplete;
|
|
109
|
-
}
|
|
110
|
-
/**
|
|
111
|
-
* Allows the user to select 'nothing' / null.
|
|
112
|
-
*/
|
|
113
|
-
set allowNull(val) {
|
|
114
|
-
this._allowNull = coerceBooleanProperty(val);
|
|
115
|
-
}
|
|
116
|
-
get allowNull() {
|
|
117
|
-
return this._allowNull;
|
|
118
|
-
}
|
|
119
|
-
/***************************************************************************
|
|
120
|
-
* *
|
|
121
|
-
* Properties *
|
|
122
|
-
* *
|
|
123
|
-
**************************************************************************/
|
|
124
|
-
set entity(entity) {
|
|
125
|
-
this._entity$.next(entity);
|
|
126
|
-
this.writeValueInternal(this.entityToValue(entity));
|
|
127
|
-
}
|
|
128
|
-
get entity() {
|
|
129
|
-
return this._entity$.getValue();
|
|
130
|
-
}
|
|
131
|
-
/**
|
|
132
|
-
* Gets the current entity as observable stream. (BehaviourSubject)
|
|
133
|
-
*/
|
|
134
|
-
get entity$() {
|
|
135
|
-
return this._entity$.asObservable();
|
|
136
|
-
}
|
|
137
|
-
set entityId(id) {
|
|
138
|
-
if (this.valueAsId) {
|
|
139
|
-
this.writeValueInternal(id);
|
|
140
|
-
}
|
|
141
|
-
else {
|
|
142
|
-
this.selectEntityById(id);
|
|
143
|
-
}
|
|
144
|
-
}
|
|
145
|
-
get entityId() {
|
|
146
|
-
return this.entityIdFromValue(this.value);
|
|
147
|
-
}
|
|
148
|
-
set hintProperty(property) {
|
|
149
|
-
this.hintPropertyResolver = (value => this.propertyStringValue(value, property));
|
|
150
|
-
}
|
|
151
|
-
set hintPropertyResolver(resolver) {
|
|
152
|
-
this.hintPropertyResolver$.next(resolver);
|
|
153
|
-
}
|
|
154
|
-
/***************************************************************************
|
|
155
|
-
* *
|
|
156
|
-
* Public API *
|
|
157
|
-
* *
|
|
158
|
-
**************************************************************************/
|
|
159
|
-
onInputBlur(event) {
|
|
160
|
-
const input = event.target;
|
|
161
|
-
if (this.entityContext.value) {
|
|
162
|
-
input.value = this.entityContext.displayText;
|
|
163
|
-
}
|
|
164
|
-
else {
|
|
165
|
-
input.value = null;
|
|
166
|
-
}
|
|
167
|
-
}
|
|
168
|
-
onInputFocus(autoTrigger) {
|
|
169
|
-
if (!this._autocomplete) {
|
|
170
|
-
this.openPanel(autoTrigger);
|
|
171
|
-
}
|
|
172
|
-
}
|
|
173
|
-
get isOptionDisabledInternalFn() {
|
|
174
|
-
return (option) => {
|
|
175
|
-
if (!this.isEntitySelected(option)) {
|
|
176
|
-
if (this.isOptionDisabledFn) {
|
|
177
|
-
return this.isOptionDisabledFn(option);
|
|
178
|
-
}
|
|
179
|
-
else {
|
|
180
|
-
return false;
|
|
181
|
-
}
|
|
182
|
-
}
|
|
183
|
-
return true;
|
|
184
|
-
};
|
|
185
|
-
}
|
|
186
|
-
get isOptionHiddenInternalFn() {
|
|
187
|
-
return (option) => {
|
|
188
|
-
if (this.isOptionHiddenFn) {
|
|
189
|
-
return this.isOptionHiddenFn(option);
|
|
190
|
-
}
|
|
191
|
-
else {
|
|
192
|
-
return false;
|
|
193
|
-
}
|
|
194
|
-
};
|
|
195
|
-
}
|
|
196
|
-
togglePanel(autoTrigger) {
|
|
197
|
-
if (autoTrigger.autocomplete.isOpen) {
|
|
198
|
-
autoTrigger.closePanel();
|
|
199
|
-
}
|
|
200
|
-
else {
|
|
201
|
-
this.openPanel(autoTrigger);
|
|
202
|
-
}
|
|
203
|
-
}
|
|
204
|
-
openPanel(autoTrigger) {
|
|
205
|
-
if (this.isLocked) {
|
|
206
|
-
this.logger.debug('Prevented opening autocomplete since select is locked!', autoTrigger);
|
|
207
|
-
return;
|
|
208
|
-
}
|
|
209
|
-
this.logger.debug('Requesting to open auto-complete panel...', autoTrigger);
|
|
210
|
-
if (this.suggestionsDc) {
|
|
211
|
-
try {
|
|
212
|
-
this.suggestionsDc.start(this.sorts, this.filters);
|
|
213
|
-
}
|
|
214
|
-
catch (err) {
|
|
215
|
-
this.logger.error('Failed to start DC!', err);
|
|
216
|
-
this.updateState(ElderSelectComponentState.error(err));
|
|
217
|
-
}
|
|
218
|
-
}
|
|
219
|
-
autoTrigger.openPanel();
|
|
220
|
-
}
|
|
221
|
-
onInputClicked(autoTrigger) {
|
|
222
|
-
// this.logger.debug('onInputClicked, locked: ' + this.isLocked + ', autocomplete: ' + this.autocomplete, autoTrigger);
|
|
223
|
-
if (this.isLocked || this.autocomplete) {
|
|
224
|
-
return;
|
|
225
|
-
}
|
|
226
|
-
this.togglePanel(autoTrigger);
|
|
227
|
-
}
|
|
228
|
-
onOptionSelected(selectedValue) {
|
|
229
|
-
if (this.isLocked) {
|
|
230
|
-
this.logger.warn('Prevented selection option since this select is locked!');
|
|
231
|
-
return;
|
|
232
|
-
}
|
|
233
|
-
if (this.isEntitySelected(selectedValue)) {
|
|
234
|
-
this.writeValueInternal(null); // HACK: Ensure we trigger view redraw
|
|
235
|
-
}
|
|
236
|
-
this.updateValueByEntity(selectedValue);
|
|
237
|
-
}
|
|
238
|
-
openSelectionPopup(event) {
|
|
239
|
-
if (this.selectionPopup) {
|
|
240
|
-
this.selectionPopup.choose((e) => this.getEntityId(e), [], // TODO Or use current entity?
|
|
241
|
-
this.filters, this.sorts, false).subscribe((selection) => {
|
|
242
|
-
this.updateValueByEntity(selection[0]);
|
|
243
|
-
});
|
|
244
|
-
}
|
|
245
|
-
else {
|
|
246
|
-
this.logger.warn('Cant open selection browser popup, since [SelectionModelPopupDirective] was not found!');
|
|
247
|
-
}
|
|
248
|
-
}
|
|
249
|
-
clear(event) {
|
|
250
|
-
this.updateValue(null);
|
|
251
|
-
}
|
|
252
|
-
forceReloadFirst() {
|
|
253
|
-
this.value = null; // valueId is set to null automatically
|
|
254
|
-
ElderSelectFirstUtil.trySelectFirst(this);
|
|
255
|
-
}
|
|
256
|
-
updateValueByEntity(entity) {
|
|
257
|
-
this._entity$.next(entity);
|
|
258
|
-
this.updateValue(this.entityToValue(entity));
|
|
259
|
-
}
|
|
260
|
-
focus(options) {
|
|
261
|
-
this.inputRef?.nativeElement?.focus(options);
|
|
262
|
-
}
|
|
263
|
-
blur() {
|
|
264
|
-
this.inputRef?.nativeElement?.blur();
|
|
265
|
-
}
|
|
266
|
-
/***************************************************************************
|
|
267
|
-
* *
|
|
268
|
-
* Abstract Implementation *
|
|
269
|
-
* *
|
|
270
|
-
**************************************************************************/
|
|
271
|
-
/**
|
|
272
|
-
* Occurs when the suggestions data-context has changed
|
|
273
|
-
*/
|
|
274
|
-
onSuggestionsDcChanged(data) {
|
|
275
|
-
if (this.valueAsId) {
|
|
276
|
-
this.selectEntityById(this.entityId);
|
|
277
|
-
}
|
|
278
|
-
}
|
|
279
|
-
/***************************************************************************
|
|
280
|
-
* *
|
|
281
|
-
* Private Methods *
|
|
282
|
-
* *
|
|
283
|
-
**************************************************************************/
|
|
284
|
-
valuesEquals(a, b) {
|
|
285
|
-
return this.entityIdFromValue(a) === this.entityIdFromValue(b);
|
|
286
|
-
}
|
|
287
|
-
awaitEntityWithId(entityId, timeoutMs) {
|
|
288
|
-
return this.entity$.pipe(filter(entity => this.getEntityId(entity) === entityId), take(1), timeout(timeoutMs));
|
|
289
|
-
}
|
|
290
|
-
isEntitySelected(entity) {
|
|
291
|
-
return this.getEntityId(entity) === this.entityId;
|
|
292
|
-
}
|
|
293
|
-
entityIdFromValue(value) {
|
|
294
|
-
if (this.valueAsId) {
|
|
295
|
-
return value;
|
|
296
|
-
}
|
|
297
|
-
else {
|
|
298
|
-
const entity = value;
|
|
299
|
-
return this.getEntityId(entity);
|
|
300
|
-
}
|
|
301
|
-
}
|
|
302
|
-
selectEntityById(id) {
|
|
303
|
-
const currentEntity = this.entity;
|
|
304
|
-
if (currentEntity && this.getEntityId(currentEntity) === id) {
|
|
305
|
-
return; // Entity already loaded
|
|
306
|
-
}
|
|
307
|
-
if (id === null || id === undefined) {
|
|
308
|
-
if (currentEntity !== null && currentEntity !== undefined) {
|
|
309
|
-
this.entity = null;
|
|
310
|
-
}
|
|
311
|
-
}
|
|
312
|
-
else {
|
|
313
|
-
if (this.suggestionsDc) {
|
|
314
|
-
const existing = this.findInDataContext(id);
|
|
315
|
-
if (existing) {
|
|
316
|
-
this.entity = existing;
|
|
317
|
-
}
|
|
318
|
-
else {
|
|
319
|
-
this.loadEntityById(id);
|
|
320
|
-
}
|
|
321
|
-
}
|
|
322
|
-
else {
|
|
323
|
-
this.logger.warn('Failed to select value by Id: ' + id + ' - DataContext not available.');
|
|
324
|
-
}
|
|
325
|
-
}
|
|
326
|
-
}
|
|
327
|
-
loadEntityById(id) {
|
|
328
|
-
this.suggestionsDc.dataSource.findById(id)
|
|
329
|
-
.subscribe(entity => {
|
|
330
|
-
this.logger.debug('Loaded missing entity by id ' + id + ':', entity);
|
|
331
|
-
this.entity = entity;
|
|
332
|
-
}, err => {
|
|
333
|
-
this.logger.error('Failed to load entity by id ' + id, err);
|
|
334
|
-
this.updateState(ElderSelectComponentState.error(err));
|
|
335
|
-
});
|
|
336
|
-
}
|
|
337
|
-
findInDataContext(id) {
|
|
338
|
-
return this.suggestionsDc.snapshot.data
|
|
339
|
-
.find(v => this.getEntityId(v) === id);
|
|
340
|
-
}
|
|
341
|
-
entityToValue(entity) {
|
|
342
|
-
if (this.valueAsId) {
|
|
343
|
-
const id = this.getEntityId(entity);
|
|
344
|
-
return id;
|
|
345
|
-
}
|
|
346
|
-
else {
|
|
347
|
-
return entity;
|
|
348
|
-
}
|
|
349
|
-
}
|
|
350
|
-
/**
|
|
351
|
-
* This method is invoked after a value has been written to this control.
|
|
352
|
-
*
|
|
353
|
-
*/
|
|
354
|
-
writeToControl(value) {
|
|
355
|
-
if (this.valueAsId) {
|
|
356
|
-
const entityId = value;
|
|
357
|
-
// Value was written as entity id, ensure we select entity by id
|
|
358
|
-
this.logger.debug('writeToControl: value was written as id: ' + entityId, value);
|
|
359
|
-
this.selectEntityById(entityId);
|
|
360
|
-
}
|
|
361
|
-
else {
|
|
362
|
-
// Value was written as entity, ensure entity is updated
|
|
363
|
-
const currentEntity = this.entity;
|
|
364
|
-
const newEntity = value;
|
|
365
|
-
this.logger.debug('writeToControl: value was written as entity: ' + JSON.stringify(newEntity), value);
|
|
366
|
-
if (!this.isEqual(currentEntity, newEntity)) {
|
|
367
|
-
this._entity$.next(newEntity);
|
|
368
|
-
}
|
|
369
|
-
else {
|
|
370
|
-
this.logger.warn('Ignored written entity as it is already set to entity$!');
|
|
371
|
-
}
|
|
372
|
-
}
|
|
373
|
-
super.writeToControl(value);
|
|
374
|
-
}
|
|
375
|
-
}
|
|
376
|
-
ElderSelectComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.4", ngImport: i0, type: ElderSelectComponent, deps: [{ token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Component });
|
|
377
|
-
ElderSelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.4", type: ElderSelectComponent, selector: "elder-select", inputs: { nullDisplay: "nullDisplay", autocomplete: "autocomplete", allowNull: "allowNull", entity: "entity", entityId: "entityId", hintProperty: "hintProperty", hintPropertyResolver: "hintPropertyResolver" }, outputs: { entityIdChange: "entityIdChange", entityIdUpdated: "entityIdUpdated", entityChange: "entityChange", entityUpdated: "entityUpdated" }, providers: [
|
|
378
|
-
{
|
|
379
|
-
provide: ELDER_SELECT_BASE,
|
|
380
|
-
useExisting: forwardRef(() => ElderSelectComponent)
|
|
381
|
-
},
|
|
382
|
-
...buildFormIntegrationProviders(ElderSelectComponent)
|
|
383
|
-
], viewQueries: [{ propertyName: "inputRef", first: true, predicate: ["input"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<mat-form-field *ngIf=\"(entityWrapped$ | async) as entityWrapper\" 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 clickable-icon\"\n [class.loading]=\"state.loading\"\n [color]=\"state?.error ? 'warn' : color\"\n (click)=\"onCurrentClicked(entity)\"\n >\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 <!-- A dynamic input -->\n <input #input\n matInput type=\"text\" fxFlex=\"grow\"\n [disabled]=\"disabled\"\n [required]=\"required\"\n [readonly]=\"readonly || !autocomplete\"\n [name]=\"name + '-inner-input'\"\n [placeholder]=\"placeholder | translate\"\n [matAutocomplete] #autoTrigger=\"matAutocompleteTrigger\"\n [elderElderAutocomplete]=\"elderAuto\" [queryFilter]=\"queryFilter\" [filters]=\"filters\" [sorts]=\"sorts\"\n elderSelectOnTab\n [class.select]=\"!autocomplete\"\n [ngModel]=\"inputText$ | async\" [ngModelOptions]=\"{standalone: true, updateOn: 'submit'}\"\n (blur)=\"onInputBlur($event)\"\n (focus)=\"onInputFocus(autoTrigger)\"\n >\n\n <!-- This breaks stuff: [displayWith]=\"displayPropertyResolver$ | async\" -->\n\n <elder-autocomplete\n #elderAuto=\"elderAutocomplete\"\n [suggestionsDc]=\"suggestionsDc$ | async\"\n [valueTemplate]=\"valueTemplate\"\n [enabled]=\"autocomplete\"\n [displayPropertyResolver]=\"displayPropertyResolver$ | async\"\n [isOptionDisabledFn]=\"isOptionDisabledInternalFn\"\n [isOptionHiddenFn]=\"isOptionHiddenInternalFn\"\n (optionSelected)=\"onOptionSelected($any($event))\"\n ></elder-autocomplete>\n\n\n <ng-container matSuffix>\n\n <mat-icon\n *ngIf=\"!selectionPopup && !autocomplete\" class=\"select-arrow suffix-icon noselect\"\n (click)=\"onInputClicked(autoTrigger)\">\n arrow_drop_down\n </mat-icon>\n\n <button mat-icon-button type=\"button\" class=\"suffix-icon\"\n *ngIf=\"selectionPopup && (!entityWrapper.value || !allowNull)\"\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\n <button mat-icon-button type=\"button\" class=\"suffix-icon\"\n *ngIf=\"entityWrapper.value && allowNull\"\n [disabled]=\"isLocked\"\n (click)=\"clear($event)\" aria-label=\"Clear\"\n elderStopEventPropagation\n tabIndex=\"-1\"\n >\n <mat-icon>close</mat-icon>\n </button>\n\n </ng-container>\n\n <mat-hint *ngIf=\"entityWrapper.hintText\">{{entityWrapper.hintText}}</mat-hint>\n\n</mat-form-field>\n\n\n\n", styles: [".prefix-container{width:24px;height:16px}@-webkit-keyframes shrink{0%{transform:scale(1)}to{transform:scale(.75)}}@keyframes shrink{0%{transform:scale(1)}to{transform:scale(.75)}}.loading{animation:shrink .3s ease-in-out infinite alternate;-webkit-animation:shrink .3s ease-in-out infinite alternate}.prefix-padding{padding-right:4px}.leading-icon,.suffix-icon,.suffix-icon .mat-icon{font-size:16px;width:16px;height:16px}.clickable-icon{cursor:pointer}.full-width{width:100%}.select{cursor:pointer;width:162px}.select-arrow{font-size:18px;width:18px;height:18px;cursor:pointer}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i3.MatHint, selector: "mat-hint", inputs: ["align", "id"] }, { kind: "directive", type: i3.MatLabel, selector: "mat-label" }, { kind: "directive", type: i3.MatPrefix, selector: "[matPrefix]" }, { kind: "directive", type: i3.MatSuffix, selector: "[matSuffix]" }, { 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.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: i7.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", exportAs: ["matAutocompleteTrigger"] }, { kind: "directive", type: i8.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: i9.ElderStopEventPropagationDirective, selector: "[elderStopEventPropagation]" }, { kind: "directive", type: i10.ElderFormFieldDenseDirective, selector: "mat-form-field[elderDense]", inputs: ["elderDense"] }, { kind: "directive", type: i11.ElderFormFieldNoHintDirective, selector: "mat-form-field[elderNoHint]", inputs: ["elderNoHint"] }, { kind: "component", type: i12.ElderAutocompleteComponent, selector: "elder-autocomplete", inputs: ["isOptionDisabledFn", "isOptionHiddenFn", "enabled", "valueTemplate", "suggestionsDc", "displayPropertyResolver"], outputs: ["optionSelected"], exportAs: ["elderAutocomplete"] }, { kind: "directive", type: i13.ElderAutocompleteDirective, selector: "[elderElderAutocomplete]", inputs: ["queryFilter", "filters", "sorts", "elderElderAutocomplete"] }, { kind: "directive", type: i14.ElderSelectOnTabDirective, selector: "[elderSelectOnTab]" }, { kind: "pipe", type: i1.AsyncPipe, name: "async" }, { kind: "pipe", type: i15.TranslatePipe, name: "translate" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
384
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.4", ngImport: i0, type: ElderSelectComponent, decorators: [{
|
|
385
|
-
type: Component,
|
|
386
|
-
args: [{ selector: 'elder-select', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
|
387
|
-
{
|
|
388
|
-
provide: ELDER_SELECT_BASE,
|
|
389
|
-
useExisting: forwardRef(() => ElderSelectComponent)
|
|
390
|
-
},
|
|
391
|
-
...buildFormIntegrationProviders(ElderSelectComponent)
|
|
392
|
-
], template: "<mat-form-field *ngIf=\"(entityWrapped$ | async) as entityWrapper\" 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 clickable-icon\"\n [class.loading]=\"state.loading\"\n [color]=\"state?.error ? 'warn' : color\"\n (click)=\"onCurrentClicked(entity)\"\n >\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 <!-- A dynamic input -->\n <input #input\n matInput type=\"text\" fxFlex=\"grow\"\n [disabled]=\"disabled\"\n [required]=\"required\"\n [readonly]=\"readonly || !autocomplete\"\n [name]=\"name + '-inner-input'\"\n [placeholder]=\"placeholder | translate\"\n [matAutocomplete] #autoTrigger=\"matAutocompleteTrigger\"\n [elderElderAutocomplete]=\"elderAuto\" [queryFilter]=\"queryFilter\" [filters]=\"filters\" [sorts]=\"sorts\"\n elderSelectOnTab\n [class.select]=\"!autocomplete\"\n [ngModel]=\"inputText$ | async\" [ngModelOptions]=\"{standalone: true, updateOn: 'submit'}\"\n (blur)=\"onInputBlur($event)\"\n (focus)=\"onInputFocus(autoTrigger)\"\n >\n\n <!-- This breaks stuff: [displayWith]=\"displayPropertyResolver$ | async\" -->\n\n <elder-autocomplete\n #elderAuto=\"elderAutocomplete\"\n [suggestionsDc]=\"suggestionsDc$ | async\"\n [valueTemplate]=\"valueTemplate\"\n [enabled]=\"autocomplete\"\n [displayPropertyResolver]=\"displayPropertyResolver$ | async\"\n [isOptionDisabledFn]=\"isOptionDisabledInternalFn\"\n [isOptionHiddenFn]=\"isOptionHiddenInternalFn\"\n (optionSelected)=\"onOptionSelected($any($event))\"\n ></elder-autocomplete>\n\n\n <ng-container matSuffix>\n\n <mat-icon\n *ngIf=\"!selectionPopup && !autocomplete\" class=\"select-arrow suffix-icon noselect\"\n (click)=\"onInputClicked(autoTrigger)\">\n arrow_drop_down\n </mat-icon>\n\n <button mat-icon-button type=\"button\" class=\"suffix-icon\"\n *ngIf=\"selectionPopup && (!entityWrapper.value || !allowNull)\"\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\n <button mat-icon-button type=\"button\" class=\"suffix-icon\"\n *ngIf=\"entityWrapper.value && allowNull\"\n [disabled]=\"isLocked\"\n (click)=\"clear($event)\" aria-label=\"Clear\"\n elderStopEventPropagation\n tabIndex=\"-1\"\n >\n <mat-icon>close</mat-icon>\n </button>\n\n </ng-container>\n\n <mat-hint *ngIf=\"entityWrapper.hintText\">{{entityWrapper.hintText}}</mat-hint>\n\n</mat-form-field>\n\n\n\n", styles: [".prefix-container{width:24px;height:16px}@-webkit-keyframes shrink{0%{transform:scale(1)}to{transform:scale(.75)}}@keyframes shrink{0%{transform:scale(1)}to{transform:scale(.75)}}.loading{animation:shrink .3s ease-in-out infinite alternate;-webkit-animation:shrink .3s ease-in-out infinite alternate}.prefix-padding{padding-right:4px}.leading-icon,.suffix-icon,.suffix-icon .mat-icon{font-size:16px;width:16px;height:16px}.clickable-icon{cursor:pointer}.full-width{width:100%}.select{cursor:pointer;width:162px}.select-arrow{font-size:18px;width:18px;height:18px;cursor:pointer}\n"] }]
|
|
393
|
-
}], ctorParameters: function () { return [{ type: i0.NgZone }]; }, propDecorators: { inputRef: [{
|
|
394
|
-
type: ViewChild,
|
|
395
|
-
args: ['input']
|
|
396
|
-
}], nullDisplay: [{
|
|
397
|
-
type: Input
|
|
398
|
-
}], entityIdChange: [{
|
|
399
|
-
type: Output
|
|
400
|
-
}], entityIdUpdated: [{
|
|
401
|
-
type: Output
|
|
402
|
-
}], entityChange: [{
|
|
403
|
-
type: Output
|
|
404
|
-
}], entityUpdated: [{
|
|
405
|
-
type: Output
|
|
406
|
-
}], autocomplete: [{
|
|
407
|
-
type: Input
|
|
408
|
-
}], allowNull: [{
|
|
409
|
-
type: Input
|
|
410
|
-
}], entity: [{
|
|
411
|
-
type: Input
|
|
412
|
-
}], entityId: [{
|
|
413
|
-
type: Input
|
|
414
|
-
}], hintProperty: [{
|
|
415
|
-
type: Input
|
|
416
|
-
}], hintPropertyResolver: [{
|
|
417
|
-
type: Input
|
|
418
|
-
}] } });
|
|
419
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"elder-select.component.js","sourceRoot":"","sources":["../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/select/elder-select/elder-select.component.ts","../../../../../../../../projects/elderbyte/ngx-starter/src/lib/components/select/elder-select/elder-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component, ElementRef, forwardRef,\n  Input, NgZone,\n  OnDestroy,\n  OnInit,\n  Output, ViewChild,\n} from '@angular/core';\nimport {buildFormIntegrationProviders} from '../../../common/forms/template-composite-control';\nimport {LoggerFactory} from '@elderbyte/ts-logger';\nimport {IDataContext} from '../../../common/data/data-context/data-context';\nimport {BehaviorSubject, combineLatest, EMPTY, Observable, Subject} from 'rxjs';\nimport {\n  map,\n  takeUntil,\n  tap, skip, filter, startWith, withLatestFrom, switchMap, take, timeout, catchError\n} from 'rxjs/operators';\nimport {coerceBooleanProperty} from '@angular/cdk/coercion';\nimport {MatAutocompleteTrigger} from '@angular/material/autocomplete';\nimport {ELDER_SELECT_BASE, ElderSelectBase, ElderSelectComponentState, TextResolverFn} from '../elder-select-base';\nimport {IElderEntityValueAccessor} from '../elder-entity-value-accessor';\nimport {ElderSelectFirstUtil} from '../auto/elder-select-first-util';\n\nclass EntityContext<T> {\n  constructor(\n    public readonly value: T,\n    public readonly hintText: string,\n    public readonly displayText: string\n  ) {\n  }\n}\n\n\n/**\n * The elder-select control allows to select a single\n * entity.\n *\n * Primary focus is on easy usage for common scenarios:\n *\n * - Integrated into angular forms and validation\n * - Support entity id handling, input / output is the entity id vs full value.\n *\n */\n@Component({\n  selector: 'elder-select',\n  templateUrl: './elder-select.component.html',\n  styleUrls: ['./elder-select.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: ELDER_SELECT_BASE,\n      useExisting: forwardRef(() => ElderSelectComponent)\n    },\n    ...buildFormIntegrationProviders(ElderSelectComponent)\n  ]\n})\nexport class ElderSelectComponent<TEntity = any, TId = any, TValue = TEntity | TId>\n  extends ElderSelectBase<TId, TEntity, TValue>\n  implements IElderEntityValueAccessor<TEntity, TId, TValue>, OnInit, OnDestroy {\n\n  /***************************************************************************\n   *                                                                         *\n   * Fields                                                                  *\n   *                                                                         *\n   **************************************************************************/\n\n  private readonly logger = LoggerFactory.getLogger(this.constructor.name);\n\n  private readonly hintPropertyResolver$ = new BehaviorSubject<TextResolverFn>((value: TEntity) => null);\n\n  private _allowNull = false;\n\n  @ViewChild('input')\n  public inputRef: ElementRef<HTMLInputElement>;\n\n  /**\n   * String to display for the 'nothing' / null value.\n   */\n  @Input()\n  public nullDisplay = '-';\n\n  @Output()\n  public readonly entityIdChange: Observable<TId>;\n\n  /**\n   * Similar to entity-id change, but emits only when the user\n   * has updated the value.\n   */\n  @Output()\n  public readonly entityIdUpdated: Observable<TId>;\n\n  @Output()\n  public readonly entityChange: Observable<TEntity>;\n\n  /**\n   * Similar to entity change, but emits only when the user\n   * has updated the value.\n   */\n  @Output()\n  public readonly entityUpdated: Observable<TEntity>;\n\n  private readonly _entity$ = new BehaviorSubject<TEntity>(undefined);\n\n  private _autocomplete = false;\n\n  public readonly entityWrapped$: Observable<EntityContext<TEntity>>;\n\n  private readonly unsubscribe$ = new Subject<void>();\n\n  public readonly inputText$: Observable<string>;\n\n  private entityContext: EntityContext<TEntity>;\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    zone: NgZone,\n  ) {\n    super(zone);\n\n    this.entityIdChange = this.valueChange.pipe(\n      map(v => this.entityIdFromValue(v))\n    );\n\n    this.entityChange = this._entity$.pipe(\n      skip(1) // Skip the initial or current value\n    );\n\n    this.entityIdUpdated = this.valueUpdated.pipe(\n      map(value => this.entityIdFromValue(value))\n    );\n\n    this.entityUpdated = this.entityIdUpdated.pipe(\n      switchMap(entityId => this.awaitEntityWithId(entityId, this.timeoutAfterMs)),\n      catchError(err => {\n        this.logger.warn(`awaitEntityWithId -> timed out after: ${this.timeoutAfterMs}`, err);\n        return EMPTY;\n      })\n    );\n\n    this.entityWrapped$ = combineLatest(\n      [\n        this._entity$,\n        this.displayPropertyResolver$,\n        this.hintPropertyResolver$\n      ]\n    ).pipe(\n      map(([value, dPR, hPR]) => new EntityContext<TEntity>(value, hPR(value), dPR(value)))\n    );\n\n    this.inputText$ = this.entityWrapped$.pipe(\n      takeUntil(this.unsubscribe$),\n      tap(valueContext => this.entityContext = valueContext),\n      map(valueContext => {\n        if (valueContext.value) {\n          return valueContext.displayText;\n        } else {\n          return null;\n        }\n      })\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Life Cycle                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public ngOnInit(): void {\n\n  }\n\n  public ngOnDestroy(): void {\n    this.unsubscribe$.next();\n    this.unsubscribe$.complete();\n    this.autoCleanUp();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Behaviour Properties                                                    *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set autocomplete(value: boolean) {\n    this._autocomplete = coerceBooleanProperty(value);\n  }\n\n  public get autocomplete(): boolean {\n    return this._autocomplete;\n  }\n\n  /**\n   * Allows the user to select 'nothing' / null.\n   */\n  @Input()\n  public set allowNull(val: boolean) {\n    this._allowNull = coerceBooleanProperty(val);\n  }\n\n  public get allowNull(): boolean {\n    return this._allowNull;\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  @Input()\n  public set entity(entity: TEntity) {\n    this._entity$.next(entity);\n    this.writeValueInternal(\n      this.entityToValue(entity)\n    );\n  }\n\n  public get entity(): TEntity {\n    return this._entity$.getValue();\n  }\n\n  /**\n   * Gets the current entity as observable stream. (BehaviourSubject)\n   */\n  public get entity$(): Observable<TEntity> {\n    return this._entity$.asObservable();\n  }\n\n  @Input()\n  public set entityId(id: TId) {\n    if (this.valueAsId) {\n      this.writeValueInternal(<any>id as TValue);\n    } else {\n      this.selectEntityById(id);\n    }\n  }\n\n  public get entityId(): TId {\n    return this.entityIdFromValue(this.value);\n  }\n\n  @Input()\n  public set hintProperty(property: string) {\n    this.hintPropertyResolver = (value => this.propertyStringValue(value, property));\n  }\n\n  @Input()\n  public set hintPropertyResolver(resolver: TextResolverFn) {\n    this.hintPropertyResolver$.next(resolver);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public onInputBlur(event: FocusEvent): void {\n    const input = event.target as HTMLInputElement;\n    if (this.entityContext.value) {\n      input.value = this.entityContext.displayText;\n    } else {\n      input.value = null;\n    }\n  }\n\n  public onInputFocus(autoTrigger: MatAutocompleteTrigger): void {\n    if (!this._autocomplete) {\n      this.openPanel(autoTrigger);\n    }\n  }\n\n  public get isOptionDisabledInternalFn(): (option: TEntity) => boolean {\n    return (option: TEntity) => {\n      if (!this.isEntitySelected(option)) {\n        if (this.isOptionDisabledFn) {\n          return this.isOptionDisabledFn(option);\n        } else {\n          return false;\n        }\n      }\n      return true;\n    };\n  }\n\n  public get isOptionHiddenInternalFn(): (option: TEntity) => boolean {\n    return (option: TEntity) => {\n      if (this.isOptionHiddenFn) {\n        return this.isOptionHiddenFn(option);\n      } else {\n        return false;\n      }\n    };\n  }\n\n\n  public togglePanel(autoTrigger: MatAutocompleteTrigger): void {\n    if (autoTrigger.autocomplete.isOpen) {\n      autoTrigger.closePanel();\n    } else {\n      this.openPanel(autoTrigger);\n    }\n  }\n\n  public openPanel(autoTrigger: MatAutocompleteTrigger): void {\n\n    if(this.isLocked){\n      this.logger.debug('Prevented opening autocomplete since select is locked!', autoTrigger);\n      return;\n    }\n\n    this.logger.debug('Requesting to open auto-complete panel...', autoTrigger);\n    if (this.suggestionsDc) {\n      try {\n        this.suggestionsDc.start(this.sorts, this.filters);\n      } catch (err) {\n        this.logger.error('Failed to start DC!', err);\n        this.updateState(ElderSelectComponentState.error(err));\n      }\n    }\n    autoTrigger.openPanel();\n  }\n\n  public onInputClicked(autoTrigger: MatAutocompleteTrigger): void {\n\n    // this.logger.debug('onInputClicked, locked: ' + this.isLocked + ', autocomplete: ' + this.autocomplete, autoTrigger);\n    if (this.isLocked || this.autocomplete) {\n      return;\n    }\n    this.togglePanel(autoTrigger);\n  }\n\n  public onOptionSelected(selectedValue: TEntity): void {\n    if(this.isLocked){\n      this.logger.warn('Prevented selection option since this select is locked!');\n      return;\n    }\n    if (this.isEntitySelected(selectedValue)) {\n      this.writeValueInternal(null); // HACK: Ensure we trigger view redraw\n    }\n    this.updateValueByEntity(selectedValue);\n  }\n\n  public openSelectionPopup(event: Event): void {\n    if (this.selectionPopup) {\n      this.selectionPopup.choose(\n        (e: TEntity) => this.getEntityId(e),\n        [], // TODO Or use current entity?\n        this.filters,\n        this.sorts,\n        false\n      ).subscribe(\n        (selection: TEntity[]) => {\n          this.updateValueByEntity(selection[0]);\n        }\n      );\n    } else {\n      this.logger.warn('Cant open selection browser popup, since [SelectionModelPopupDirective] was not found!');\n    }\n  }\n\n  public clear(event?: Event): void {\n    this.updateValue(null);\n  }\n\n  public forceReloadFirst() {\n    this.value = null; // valueId is set to null automatically\n    ElderSelectFirstUtil.trySelectFirst(this);\n  }\n\n  public updateValueByEntity(entity: TEntity): void {\n    this._entity$.next(entity);\n    this.updateValue(\n      this.entityToValue(entity)\n    );\n  }\n\n  public focus(options?: FocusOptions){\n    this.inputRef?.nativeElement?.focus(options);\n  }\n\n  public blur(){\n    this.inputRef?.nativeElement?.blur();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Abstract Implementation                                                 *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Occurs when the suggestions data-context has changed\n   */\n  protected onSuggestionsDcChanged(data: IDataContext<TEntity>): void {\n    if (this.valueAsId) {\n      this.selectEntityById(this.entityId);\n    }\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Private Methods                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  protected valuesEquals(a: TValue, b: TValue): boolean {\n    return this.entityIdFromValue(a) === this.entityIdFromValue(b);\n  }\n\n  private awaitEntityWithId(entityId: TId, timeoutMs: number): Observable<TEntity> {\n    return this.entity$.pipe(\n      filter(entity => this.getEntityId(entity) === entityId),\n      take(1),\n      timeout(timeoutMs)\n    );\n  }\n\n  private isEntitySelected(entity: TEntity): boolean {\n    return this.getEntityId(entity) === this.entityId;\n  }\n\n  private entityIdFromValue(value: TValue): TId {\n    if (this.valueAsId) {\n      return <any>value as TId;\n    } else {\n      const entity = (<any>value) as TEntity;\n      return this.getEntityId(entity);\n    }\n  }\n\n  private selectEntityById(id: TId): void {\n\n    const currentEntity = this.entity;\n    if (currentEntity && this.getEntityId(currentEntity) === id) {\n      return; // Entity already loaded\n    }\n\n    if (id === null || id === undefined) {\n      if (currentEntity !== null && currentEntity !== undefined) {\n        this.entity = null;\n      }\n    } else {\n      if (this.suggestionsDc) {\n        const existing = this.findInDataContext(id);\n        if (existing) {\n          this.entity = existing;\n        } else {\n          this.loadEntityById(id);\n        }\n      } else {\n        this.logger.warn('Failed to select value by Id: ' + id + ' - DataContext not available.');\n      }\n    }\n  }\n\n  private loadEntityById(id: TId): void {\n    this.suggestionsDc.dataSource.findById(<any>id)\n      .subscribe(\n        entity => {\n          this.logger.debug('Loaded missing entity by id ' + id + ':', entity);\n          this.entity = entity;\n        },\n        err => {\n          this.logger.error('Failed to load entity by id ' + id, err);\n          this.updateState(ElderSelectComponentState.error(err));\n        }\n      );\n  }\n\n  private findInDataContext(id: TId): TEntity | null {\n    return this.suggestionsDc.snapshot.data\n      .find(v => this.getEntityId(v) === id);\n  }\n\n  public entityToValue(entity: TEntity): TValue {\n    if (this.valueAsId) {\n      const id = this.getEntityId(entity);\n      return <any>id as TValue;\n    } else {\n      return <any>entity as TValue;\n    }\n  }\n\n  /**\n   * This method is invoked after a value has been written to this control.\n   *\n   */\n  protected writeToControl(value: TValue): void {\n    if (this.valueAsId) {\n      const entityId = <any>value as TId;\n      // Value was written as entity id, ensure we select entity by id\n      this.logger.debug('writeToControl: value was written as id: ' + entityId, value);\n      this.selectEntityById(entityId);\n    } else {\n      // Value was written as entity, ensure entity is updated\n      const currentEntity = this.entity;\n      const newEntity = <any>value as TEntity;\n      this.logger.debug('writeToControl: value was written as entity: ' + JSON.stringify(newEntity), value);\n      if (!this.isEqual(currentEntity, newEntity)) {\n        this._entity$.next(newEntity);\n      } else {\n        this.logger.warn('Ignored written entity as it is already set to entity$!');\n      }\n    }\n    super.writeToControl(value);\n  }\n}\n","<mat-form-field *ngIf=\"(entityWrapped$ | async) as entityWrapper\" 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 clickable-icon\"\n              [class.loading]=\"state.loading\"\n              [color]=\"state?.error ? 'warn' : color\"\n              (click)=\"onCurrentClicked(entity)\"\n    >\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  <!-- A dynamic input -->\n  <input #input\n    matInput type=\"text\" fxFlex=\"grow\"\n    [disabled]=\"disabled\"\n    [required]=\"required\"\n    [readonly]=\"readonly || !autocomplete\"\n    [name]=\"name + '-inner-input'\"\n    [placeholder]=\"placeholder | translate\"\n    [matAutocomplete] #autoTrigger=\"matAutocompleteTrigger\"\n    [elderElderAutocomplete]=\"elderAuto\" [queryFilter]=\"queryFilter\" [filters]=\"filters\" [sorts]=\"sorts\"\n    elderSelectOnTab\n    [class.select]=\"!autocomplete\"\n    [ngModel]=\"inputText$ | async\" [ngModelOptions]=\"{standalone: true, updateOn: 'submit'}\"\n    (blur)=\"onInputBlur($event)\"\n    (focus)=\"onInputFocus(autoTrigger)\"\n  >\n\n  <!-- This breaks stuff: [displayWith]=\"displayPropertyResolver$ | async\" -->\n\n  <elder-autocomplete\n    #elderAuto=\"elderAutocomplete\"\n    [suggestionsDc]=\"suggestionsDc$ | async\"\n    [valueTemplate]=\"valueTemplate\"\n    [enabled]=\"autocomplete\"\n    [displayPropertyResolver]=\"displayPropertyResolver$ | async\"\n    [isOptionDisabledFn]=\"isOptionDisabledInternalFn\"\n    [isOptionHiddenFn]=\"isOptionHiddenInternalFn\"\n    (optionSelected)=\"onOptionSelected($any($event))\"\n  ></elder-autocomplete>\n\n\n  <ng-container matSuffix>\n\n    <mat-icon\n      *ngIf=\"!selectionPopup && !autocomplete\" class=\"select-arrow suffix-icon noselect\"\n      (click)=\"onInputClicked(autoTrigger)\">\n      arrow_drop_down\n    </mat-icon>\n\n    <button mat-icon-button type=\"button\" class=\"suffix-icon\"\n            *ngIf=\"selectionPopup && (!entityWrapper.value || !allowNull)\"\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\n    <button mat-icon-button type=\"button\" class=\"suffix-icon\"\n            *ngIf=\"entityWrapper.value && allowNull\"\n            [disabled]=\"isLocked\"\n            (click)=\"clear($event)\" aria-label=\"Clear\"\n            elderStopEventPropagation\n            tabIndex=\"-1\"\n    >\n      <mat-icon>close</mat-icon>\n    </button>\n\n  </ng-container>\n\n  <mat-hint *ngIf=\"entityWrapper.hintText\">{{entityWrapper.hintText}}</mat-hint>\n\n</mat-form-field>\n\n\n\n"]}
|