@mediusinc/mng-commons 5.4.0-rc.3 → 5.4.0-rc.5
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/core/data-list/data-list-params-helpers.d.ts +1 -1
- package/core/data-list/data-list.model.d.ts +1 -0
- package/core/helpers/type-helpers.d.ts +12 -0
- package/esm2022/core/data-list/data-list-params-helpers.mjs +29 -5
- package/esm2022/core/data-list/data-list.model.mjs +1 -1
- package/esm2022/core/helpers/type-helpers.mjs +1 -1
- package/esm2022/filter/descriptors/filter-generic.descriptor.mjs +21 -0
- package/esm2022/filter/descriptors/filter-lookup.descriptor.mjs +1 -1
- package/esm2022/filter/descriptors/filter.descriptor.mjs +40 -1
- package/esm2022/filter/index.mjs +3 -1
- package/esm2022/filter/models/filter-generic-property.model.mjs +2 -0
- package/esm2022/form/components/dropdown/dropdown.component.mjs +159 -10
- package/esm2022/table/api/descriptors/table.descriptor.mjs +51 -2
- package/esm2022/table/components/column-filter/column-filter.component.mjs +2 -2
- package/esm2022/table/components/filter/filter-active-tag/filter-active-tag.component.mjs +4 -1
- package/esm2022/table/components/filter/filter-form/filter-form.component.mjs +42 -9
- package/esm2022/table/components/filter/filter-overlay-with-tag/filter-overlay-with-tag.component.mjs +95 -11
- package/esm2022/table/components/table/table.component.mjs +57 -13
- package/esm2022/table/helpers/filters.mjs +32 -2
- package/esm2022/table/services/table-feature-config.token.mjs +1 -1
- package/esm2022/tableview/action/components/localization/data-language-dropdown.component.mjs +2 -2
- package/esm2022/tableview/api/editor/descriptors/field-many.descriptor.mjs +11 -10
- package/esm2022/tableview/api/editor/descriptors/field.descriptor.mjs +16 -2
- package/esm2022/tableview/api/editor/models/formly-custom-field.model.mjs +2 -1
- package/esm2022/tableview/editor/components/formly/fields/formly-field-datepicker/formly-field-datepicker.component.mjs +23 -3
- package/esm2022/tableview/editor/components/formly/fields/formly-field-dropdown/formly-field-dropdown.component.mjs +2 -2
- package/esm2022/tableview/editor/components/formly/fields/formly-field-input/formly-field-input.component.mjs +3 -3
- package/esm2022/tableview/editor/components/formly/fields/formly-field-table-dialog-multiselect/formly-field-table-dialog-multiselect.component.mjs +3 -4
- package/esm2022/tableview/editor/components/formly/fields/formly-field-type.abstract.component.mjs +2 -1
- package/fesm2022/mediusinc-mng-commons-core.mjs +28 -4
- package/fesm2022/mediusinc-mng-commons-core.mjs.map +1 -1
- package/fesm2022/mediusinc-mng-commons-filter.mjs +61 -1
- package/fesm2022/mediusinc-mng-commons-filter.mjs.map +1 -1
- package/fesm2022/mediusinc-mng-commons-form.mjs +156 -7
- package/fesm2022/mediusinc-mng-commons-form.mjs.map +1 -1
- package/fesm2022/mediusinc-mng-commons-table-api.mjs +50 -1
- package/fesm2022/mediusinc-mng-commons-table-api.mjs.map +1 -1
- package/fesm2022/mediusinc-mng-commons-table.mjs +230 -45
- package/fesm2022/mediusinc-mng-commons-table.mjs.map +1 -1
- package/fesm2022/mediusinc-mng-commons-tableview-api.mjs +26 -10
- package/fesm2022/mediusinc-mng-commons-tableview-api.mjs.map +1 -1
- package/fesm2022/mediusinc-mng-commons-tableview.mjs +29 -8
- package/fesm2022/mediusinc-mng-commons-tableview.mjs.map +1 -1
- package/filter/descriptors/filter-generic.descriptor.d.ts +11 -0
- package/filter/descriptors/filter.descriptor.d.ts +21 -2
- package/filter/index.d.ts +2 -0
- package/filter/models/filter-generic-property.model.d.ts +7 -0
- package/form/components/dropdown/dropdown.component.d.ts +27 -1
- package/i18n/en.json +4 -0
- package/i18n/sl.json +4 -0
- package/package.json +1 -1
- package/table/api/descriptors/table.descriptor.d.ts +33 -1
- package/table/components/filter/filter-form/filter-form.component.d.ts +11 -2
- package/table/components/filter/filter-overlay-with-tag/filter-overlay-with-tag.component.d.ts +21 -1
- package/table/components/table/table.component.d.ts +20 -5
- package/table/helpers/filters.d.ts +9 -1
- package/table/services/table-feature-config.token.d.ts +1 -0
- package/tableview/api/editor/descriptors/field-many.descriptor.d.ts +6 -4
- package/tableview/api/editor/descriptors/field.descriptor.d.ts +10 -1
- package/version-info.json +5 -5
|
@@ -4,8 +4,8 @@ import { FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
|
4
4
|
import { TranslateModule, TranslateService } from '@ngx-translate/core';
|
|
5
5
|
import { Dropdown, DropdownModule } from 'primeng/dropdown';
|
|
6
6
|
import { MultiSelect, MultiSelectModule } from 'primeng/multiselect';
|
|
7
|
-
import { combineLatest, map, of, switchMap, tap } from 'rxjs';
|
|
8
|
-
import { CommonsInternalError, LoggerService, toObservable as commonsToObservable, fromSubscribeError, getErrorLogLevel } from '@mediusinc/mng-commons/core';
|
|
7
|
+
import { ReplaySubject, combineLatest, map, of, switchMap, take, tap } from 'rxjs';
|
|
8
|
+
import { CommonsInternalError, FilterMatchMode, LoggerService, toObservable as commonsToObservable, fromSubscribeError, getErrorLogLevel } from '@mediusinc/mng-commons/core';
|
|
9
9
|
import * as i0 from "@angular/core";
|
|
10
10
|
import * as i1 from "primeng/dropdown";
|
|
11
11
|
import * as i2 from "primeng/multiselect";
|
|
@@ -41,7 +41,10 @@ export class DropdownComponent {
|
|
|
41
41
|
this.changeValueOnBlur = input(false, { transform: booleanAttribute });
|
|
42
42
|
this.loadingInput = input(false, { alias: 'loading', transform: booleanAttribute });
|
|
43
43
|
this.disabledInput = input(false, { alias: 'disabled', transform: booleanAttribute });
|
|
44
|
+
this.allowInput = input(false, { transform: booleanAttribute });
|
|
44
45
|
this.appendTo = input('body');
|
|
46
|
+
this.inlineSearch = input(false, { transform: booleanAttribute });
|
|
47
|
+
this.searchTrim = input(undefined);
|
|
45
48
|
this.valueChange = output();
|
|
46
49
|
this.blur = output();
|
|
47
50
|
this.primeDropdown = viewChild(Dropdown);
|
|
@@ -59,6 +62,8 @@ export class DropdownComponent {
|
|
|
59
62
|
this.items = signal([]);
|
|
60
63
|
this.firstTimeSettingItems = true;
|
|
61
64
|
this.isDropdownPanelShown = false;
|
|
65
|
+
// used with custom input functionality
|
|
66
|
+
this.valueSuggestionProviderSubscription = null;
|
|
62
67
|
this.optionsLabelProperty = computed(() => {
|
|
63
68
|
if (this.optionsLabelTranslate()) {
|
|
64
69
|
// setup translation properties
|
|
@@ -105,18 +110,31 @@ export class DropdownComponent {
|
|
|
105
110
|
}), switchMap(items => this.transformItems(items)), takeUntilDestroyed())
|
|
106
111
|
.subscribe({
|
|
107
112
|
next: res => {
|
|
108
|
-
this.
|
|
113
|
+
this.setItems(res);
|
|
114
|
+
if (this.inlineSearch()) {
|
|
115
|
+
if (!this.valueSuggestionResultCacheSubject) {
|
|
116
|
+
this.valueSuggestionResultCacheSubject = new ReplaySubject(1);
|
|
117
|
+
}
|
|
118
|
+
this.valueSuggestionResultCacheSubject?.next(res);
|
|
119
|
+
}
|
|
109
120
|
this._loading.set(false);
|
|
110
|
-
this.selectFirstItem();
|
|
121
|
+
this.selectFirstItem(); // only selects first item if selectFirstItemInput is set accordingly
|
|
111
122
|
this.adjustValueOnItemsValuePropertyTypeMismatch();
|
|
112
123
|
},
|
|
113
124
|
error: err => {
|
|
114
|
-
this.
|
|
125
|
+
this.setItems([]);
|
|
115
126
|
this._loading.set(false);
|
|
116
127
|
const error = fromSubscribeError(err, 'DropdownComponentError');
|
|
117
128
|
this.logger.log(error, getErrorLogLevel(error));
|
|
118
129
|
}
|
|
119
130
|
});
|
|
131
|
+
effect(() => {
|
|
132
|
+
if (this.allowInput()) {
|
|
133
|
+
if (this.optionsLabelProperty() && !this.optionsValueProperty()) {
|
|
134
|
+
throw new CommonsInternalError(`allowInput is not supported when optionsLabelProperty is defined but optionsValueProperty is missing. Set optionsValueProperty to enable allowInput.`);
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
});
|
|
120
138
|
}
|
|
121
139
|
registerOnChange(fn) {
|
|
122
140
|
this.onChangeFn = fn;
|
|
@@ -139,7 +157,9 @@ export class DropdownComponent {
|
|
|
139
157
|
this.adjustValueOnItemsValuePropertyTypeMismatch(true);
|
|
140
158
|
}
|
|
141
159
|
onDropdownBlur(event) {
|
|
142
|
-
if
|
|
160
|
+
// if allowCustomInput is enabled, the input element might still be in focus with the
|
|
161
|
+
// dropdown panel hidden - that's why the !this.allowCustomInput() check is needed
|
|
162
|
+
if (this.isDropdownPanelShown && !this.allowInput()) {
|
|
143
163
|
// ignore this blur event
|
|
144
164
|
return;
|
|
145
165
|
}
|
|
@@ -154,6 +174,103 @@ export class DropdownComponent {
|
|
|
154
174
|
if (!this.changeValueOnBlur()) {
|
|
155
175
|
this.propagateValueChange(event.value);
|
|
156
176
|
}
|
|
177
|
+
if (this.allowInput()) {
|
|
178
|
+
const optionsLabelProperty = this.optionsLabelProperty();
|
|
179
|
+
let query = undefined;
|
|
180
|
+
if (typeof event?.value === 'string' && event?.value.trim() === '') {
|
|
181
|
+
return;
|
|
182
|
+
}
|
|
183
|
+
else if (typeof event.value === 'string') {
|
|
184
|
+
query = this.trimValue(event.value);
|
|
185
|
+
}
|
|
186
|
+
this.valueSuggestionProviderSubscription?.unsubscribe();
|
|
187
|
+
if (this.dataProvider()) {
|
|
188
|
+
if (!this.inlineSearch()) {
|
|
189
|
+
const params = {
|
|
190
|
+
limit: 10
|
|
191
|
+
};
|
|
192
|
+
if (optionsLabelProperty) {
|
|
193
|
+
params.sort = [{ property: optionsLabelProperty }];
|
|
194
|
+
}
|
|
195
|
+
if (query && query.length > 0 && optionsLabelProperty) {
|
|
196
|
+
params.filters = {
|
|
197
|
+
[optionsLabelProperty]: {
|
|
198
|
+
value: query,
|
|
199
|
+
matchMode: FilterMatchMode.StartsWith
|
|
200
|
+
}
|
|
201
|
+
};
|
|
202
|
+
}
|
|
203
|
+
this.valueSuggestionProviderSubscription = this.getLookup(params, query)
|
|
204
|
+
.pipe(takeUntilDestroyed(this.destroyRef))
|
|
205
|
+
.subscribe({
|
|
206
|
+
next: items => {
|
|
207
|
+
this.setItems(items);
|
|
208
|
+
},
|
|
209
|
+
error: err => {
|
|
210
|
+
this.setItems([]);
|
|
211
|
+
const error = fromSubscribeError(err, 'DropdownComponentError', {
|
|
212
|
+
search: query,
|
|
213
|
+
params: params
|
|
214
|
+
});
|
|
215
|
+
this.logger.log(error, getErrorLogLevel(error));
|
|
216
|
+
}
|
|
217
|
+
});
|
|
218
|
+
}
|
|
219
|
+
else if (this.valueSuggestionResultCacheSubject) {
|
|
220
|
+
this.valueSuggestionProviderSubscription = this.valueSuggestionResultCacheSubject.pipe(take(1)).subscribe(result => {
|
|
221
|
+
this.setItems(result, query);
|
|
222
|
+
});
|
|
223
|
+
}
|
|
224
|
+
}
|
|
225
|
+
else if (this.options().length > 0) {
|
|
226
|
+
this.setItems(this.options(), query);
|
|
227
|
+
}
|
|
228
|
+
}
|
|
229
|
+
}
|
|
230
|
+
/**
|
|
231
|
+
* Sets the items in the dropdown. If a query is provided, the items will be filtered by the query (using a 'starts with' filter).
|
|
232
|
+
*
|
|
233
|
+
* @param items The items to set.
|
|
234
|
+
* @param [query] The query to filter the items by.
|
|
235
|
+
*/
|
|
236
|
+
setItems(items, query) {
|
|
237
|
+
if (this.allowInput()) {
|
|
238
|
+
if (items.length > 0) {
|
|
239
|
+
// items can either be objects (with optionsValueProperty specifying a string property) or strings
|
|
240
|
+
if (typeof items[0] === 'object') {
|
|
241
|
+
if (!this.optionsValueProperty()) {
|
|
242
|
+
throw new CommonsInternalError(`allowInput is not supported when optionValueProperty is not set and the dropdown items are of type object. Set optionsValueProperty to enable allowInput.`);
|
|
243
|
+
}
|
|
244
|
+
if (typeof items[0]?.[this.optionsValueProperty()] !== 'string') {
|
|
245
|
+
throw new CommonsInternalError(`allowInput is only supported when the value property (specified with optionsValueProperty) is of type string.`);
|
|
246
|
+
}
|
|
247
|
+
}
|
|
248
|
+
else if (!(typeof items[0] === 'string' && !this.optionsLabelProperty() && !this.optionsValueProperty())) {
|
|
249
|
+
throw new CommonsInternalError(`'allowInput' is only supported for items of type string or object. For object types, ensure that the 'optionsValueProperty' is specified and represents a property of type string.`);
|
|
250
|
+
}
|
|
251
|
+
}
|
|
252
|
+
}
|
|
253
|
+
if (query) {
|
|
254
|
+
const queryLowerCase = query?.toLowerCase() ?? '';
|
|
255
|
+
const filteredItems = items.filter(i => {
|
|
256
|
+
let itemLabel = i;
|
|
257
|
+
const optionsLabelProperty = this.optionsLabelProperty();
|
|
258
|
+
if (optionsLabelProperty && typeof i === 'object') {
|
|
259
|
+
itemLabel = i[optionsLabelProperty];
|
|
260
|
+
}
|
|
261
|
+
if (itemLabel == null) {
|
|
262
|
+
return queryLowerCase == null || !queryLowerCase.length;
|
|
263
|
+
}
|
|
264
|
+
if (typeof itemLabel !== 'string') {
|
|
265
|
+
itemLabel = itemLabel.toString();
|
|
266
|
+
}
|
|
267
|
+
return itemLabel.toLowerCase().startsWith(queryLowerCase);
|
|
268
|
+
});
|
|
269
|
+
this.items.set([...filteredItems]);
|
|
270
|
+
}
|
|
271
|
+
else {
|
|
272
|
+
this.items.set([...items]);
|
|
273
|
+
}
|
|
157
274
|
}
|
|
158
275
|
onDropdownPanelShow() {
|
|
159
276
|
this.isDropdownPanelShown = true;
|
|
@@ -227,7 +344,7 @@ export class DropdownComponent {
|
|
|
227
344
|
}
|
|
228
345
|
}
|
|
229
346
|
else if (typeof this.items()[0][optionsValueProp] !== typeof this._value) {
|
|
230
|
-
// types
|
|
347
|
+
// types don't match, search and compare by string
|
|
231
348
|
const selectedOption = this.items().find(i => i[optionsValueProp] != null && i[optionsValueProp].toString() === this._value.toString());
|
|
232
349
|
if (selectedOption) {
|
|
233
350
|
this.ngModelValue.set(selectedOption[optionsValueProp]);
|
|
@@ -245,11 +362,43 @@ export class DropdownComponent {
|
|
|
245
362
|
this.onChangeFn(value);
|
|
246
363
|
this.valueChange.emit(value);
|
|
247
364
|
}
|
|
365
|
+
/**
|
|
366
|
+
* Gets the lookup from the data provider.
|
|
367
|
+
*
|
|
368
|
+
* @param params The parameters to pass to the lookup.
|
|
369
|
+
* @param [query] The search query to filter the items by.
|
|
370
|
+
*/
|
|
371
|
+
getLookup(params, query) {
|
|
372
|
+
const dataProvider = this.dataProvider();
|
|
373
|
+
if (dataProvider) {
|
|
374
|
+
return commonsToObservable(dataProvider.lookup(params, this.dataProviderService, query)).pipe(switchMap(res => {
|
|
375
|
+
return of(res ?? []);
|
|
376
|
+
}));
|
|
377
|
+
}
|
|
378
|
+
return of([]);
|
|
379
|
+
}
|
|
380
|
+
/**
|
|
381
|
+
* Trims the leading and/or trailing whitespace from the given value based on the search trimming mode.
|
|
382
|
+
*
|
|
383
|
+
* @param value - The value to be trimmed.
|
|
384
|
+
*/
|
|
385
|
+
trimValue(value) {
|
|
386
|
+
switch (this.searchTrim()) {
|
|
387
|
+
case 'start':
|
|
388
|
+
return value?.trimStart();
|
|
389
|
+
case 'end':
|
|
390
|
+
return value?.trimEnd();
|
|
391
|
+
case 'both':
|
|
392
|
+
return value?.trim();
|
|
393
|
+
default:
|
|
394
|
+
return value;
|
|
395
|
+
}
|
|
396
|
+
}
|
|
248
397
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.5", ngImport: i0, type: DropdownComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
249
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.5", type: DropdownComponent, isStandalone: true, selector: "mng-dropdown", inputs: { dataProvider: { classPropertyName: "dataProvider", publicName: "dataProvider", isSignal: true, isRequired: false, transformFunction: null }, options: { classPropertyName: "options", publicName: "options", isSignal: true, isRequired: false, transformFunction: null }, optionsTrackProperty: { classPropertyName: "optionsTrackProperty", publicName: "optionsTrackProperty", isSignal: true, isRequired: false, transformFunction: null }, optionsLabelPropertyInit: { classPropertyName: "optionsLabelPropertyInit", publicName: "optionsLabelProperty", isSignal: true, isRequired: false, transformFunction: null }, optionsLabelTranslate: { classPropertyName: "optionsLabelTranslate", publicName: "optionsLabelTranslate", isSignal: true, isRequired: false, transformFunction: null }, optionsValuePropertyInput: { classPropertyName: "optionsValuePropertyInput", publicName: "optionsValueProperty", isSignal: true, isRequired: false, transformFunction: null }, optionsDisabledProperty: { classPropertyName: "optionsDisabledProperty", publicName: "optionsDisabledProperty", isSignal: true, isRequired: false, transformFunction: null }, multiselect: { classPropertyName: "multiselect", publicName: "multiselect", isSignal: true, isRequired: false, transformFunction: null }, placeholder: { classPropertyName: "placeholder", publicName: "placeholder", isSignal: true, isRequired: false, transformFunction: null }, showClear: { classPropertyName: "showClear", publicName: "showClear", isSignal: true, isRequired: false, transformFunction: null }, selectFirstItemInput: { classPropertyName: "selectFirstItemInput", publicName: "selectFirstItem", isSignal: true, isRequired: false, transformFunction: null }, className: { classPropertyName: "className", publicName: "className", isSignal: true, isRequired: false, transformFunction: null }, dropdownClassName: { classPropertyName: "dropdownClassName", publicName: "dropdownClassName", isSignal: true, isRequired: false, transformFunction: null }, changeValueOnBlur: { classPropertyName: "changeValueOnBlur", publicName: "changeValueOnBlur", isSignal: true, isRequired: false, transformFunction: null }, loadingInput: { classPropertyName: "loadingInput", publicName: "loading", isSignal: true, isRequired: false, transformFunction: null }, disabledInput: { classPropertyName: "disabledInput", publicName: "disabled", isSignal: true, isRequired: false, transformFunction: null }, appendTo: { classPropertyName: "appendTo", publicName: "appendTo", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { valueChange: "valueChange", blur: "blur" }, providers: [DROPDOWN_VALUE_ACCESSOR], viewQueries: [{ propertyName: "primeDropdown", first: true, predicate: Dropdown, descendants: true, isSignal: true }, { propertyName: "primeMultiselect", first: true, predicate: MultiSelect, descendants: true, isSignal: true }], ngImport: i0, template: "@if (!multiselect()) {\n <p-dropdown\n [ngModel]=\"ngModelValue
|
|
398
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.0.5", type: DropdownComponent, isStandalone: true, selector: "mng-dropdown", inputs: { dataProvider: { classPropertyName: "dataProvider", publicName: "dataProvider", isSignal: true, isRequired: false, transformFunction: null }, options: { classPropertyName: "options", publicName: "options", isSignal: true, isRequired: false, transformFunction: null }, optionsTrackProperty: { classPropertyName: "optionsTrackProperty", publicName: "optionsTrackProperty", isSignal: true, isRequired: false, transformFunction: null }, optionsLabelPropertyInit: { classPropertyName: "optionsLabelPropertyInit", publicName: "optionsLabelProperty", isSignal: true, isRequired: false, transformFunction: null }, optionsLabelTranslate: { classPropertyName: "optionsLabelTranslate", publicName: "optionsLabelTranslate", isSignal: true, isRequired: false, transformFunction: null }, optionsValuePropertyInput: { classPropertyName: "optionsValuePropertyInput", publicName: "optionsValueProperty", isSignal: true, isRequired: false, transformFunction: null }, optionsDisabledProperty: { classPropertyName: "optionsDisabledProperty", publicName: "optionsDisabledProperty", isSignal: true, isRequired: false, transformFunction: null }, multiselect: { classPropertyName: "multiselect", publicName: "multiselect", isSignal: true, isRequired: false, transformFunction: null }, placeholder: { classPropertyName: "placeholder", publicName: "placeholder", isSignal: true, isRequired: false, transformFunction: null }, showClear: { classPropertyName: "showClear", publicName: "showClear", isSignal: true, isRequired: false, transformFunction: null }, selectFirstItemInput: { classPropertyName: "selectFirstItemInput", publicName: "selectFirstItem", isSignal: true, isRequired: false, transformFunction: null }, className: { classPropertyName: "className", publicName: "className", isSignal: true, isRequired: false, transformFunction: null }, dropdownClassName: { classPropertyName: "dropdownClassName", publicName: "dropdownClassName", isSignal: true, isRequired: false, transformFunction: null }, changeValueOnBlur: { classPropertyName: "changeValueOnBlur", publicName: "changeValueOnBlur", isSignal: true, isRequired: false, transformFunction: null }, loadingInput: { classPropertyName: "loadingInput", publicName: "loading", isSignal: true, isRequired: false, transformFunction: null }, disabledInput: { classPropertyName: "disabledInput", publicName: "disabled", isSignal: true, isRequired: false, transformFunction: null }, allowInput: { classPropertyName: "allowInput", publicName: "allowInput", isSignal: true, isRequired: false, transformFunction: null }, appendTo: { classPropertyName: "appendTo", publicName: "appendTo", isSignal: true, isRequired: false, transformFunction: null }, inlineSearch: { classPropertyName: "inlineSearch", publicName: "inlineSearch", isSignal: true, isRequired: false, transformFunction: null }, searchTrim: { classPropertyName: "searchTrim", publicName: "searchTrim", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { valueChange: "valueChange", blur: "blur" }, providers: [DROPDOWN_VALUE_ACCESSOR], viewQueries: [{ propertyName: "primeDropdown", first: true, predicate: Dropdown, descendants: true, isSignal: true }, { propertyName: "primeMultiselect", first: true, predicate: MultiSelect, descendants: true, isSignal: true }], ngImport: i0, template: "@if (!multiselect()) {\n <p-dropdown\n [(ngModel)]=\"ngModelValue\"\n [placeholder]=\"placeholder()\"\n [dataKey]=\"optionsTrackProperty()\"\n [optionLabel]=\"optionsLabelProperty()\"\n [optionValue]=\"optionsValueProperty()\"\n [optionDisabled]=\"optionsDisabledProperty()\"\n [options]=\"items()\"\n [showClear]=\"showClear()\"\n [editable]=\"allowInput()\"\n [styleClass]=\"className()\"\n [panelStyleClass]=\"dropdownClassName()\"\n [disabled]=\"disabled()\"\n (onBlur)=\"onDropdownBlur($event)\"\n (onChange)=\"onDropdownChange($event)\"\n (onShow)=\"onDropdownPanelShow()\"\n (onHide)=\"onDropdownPanelHide()\"\n [dropdownIcon]=\"loading() ? 'pi pi-spinner pi-spin' : 'pi pi-chevron-down'\"\n [appendTo]=\"appendTo()\">\n </p-dropdown>\n} @else {\n <p-multiSelect\n [ngModel]=\"ngModelValue()\"\n [maxSelectedLabels]=\"1\"\n [selectedItemsLabel]=\"'mngDropdown.multiselectOverMaxDisplayLimit' | translate\"\n [placeholder]=\"placeholder()\"\n [dataKey]=\"optionsTrackProperty()\"\n [optionLabel]=\"optionsLabelProperty()\"\n [optionValue]=\"optionsValueProperty()\"\n [optionDisabled]=\"optionsDisabledProperty()\"\n [options]=\"items()\"\n [styleClass]=\"className()\"\n [panelStyleClass]=\"dropdownClassName()\"\n [filter]=\"true\"\n [showToggleAll]=\"false\"\n [disabled]=\"disabled()\"\n (onChange)=\"onMultiselectChange($event)\"\n (onPanelHide)=\"onMultiselectPanelHide()\"\n (onBlur)=\"onMultiselectBlur($event)\"\n appendTo=\"body\">\n </p-multiSelect>\n}\n", dependencies: [{ kind: "ngmodule", type: DropdownModule }, { kind: "component", type: i1.Dropdown, selector: "p-dropdown", inputs: ["id", "scrollHeight", "filter", "name", "style", "panelStyle", "styleClass", "panelStyleClass", "readonly", "required", "editable", "appendTo", "tabindex", "placeholder", "loadingIcon", "filterPlaceholder", "filterLocale", "variant", "inputId", "dataKey", "filterBy", "filterFields", "autofocus", "resetFilterOnHide", "checkmark", "dropdownIcon", "loading", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "autoDisplayFirst", "group", "showClear", "emptyFilterMessage", "emptyMessage", "lazy", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "overlayOptions", "ariaFilterLabel", "ariaLabel", "ariaLabelledBy", "filterMatchMode", "maxlength", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "focusOnHover", "selectOnFocus", "autoOptionFocus", "autofocusFilter", "disabled", "itemSize", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "filterValue", "options"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onShow", "onHide", "onClear", "onLazyLoad"] }, { kind: "ngmodule", type: MultiSelectModule }, { kind: "component", type: i2.MultiSelect, selector: "p-multiSelect", inputs: ["id", "ariaLabel", "style", "styleClass", "panelStyle", "panelStyleClass", "inputId", "disabled", "readonly", "group", "filter", "filterPlaceHolder", "filterLocale", "overlayVisible", "tabindex", "variant", "appendTo", "dataKey", "name", "ariaLabelledBy", "displaySelectedLabel", "maxSelectedLabels", "selectionLimit", "selectedItemsLabel", "showToggleAll", "emptyFilterMessage", "emptyMessage", "resetFilterOnHide", "dropdownIcon", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "showHeader", "filterBy", "scrollHeight", "lazy", "virtualScroll", "loading", "virtualScrollItemSize", "loadingIcon", "virtualScrollOptions", "overlayOptions", "ariaFilterLabel", "filterMatchMode", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "autofocusFilter", "display", "autocomplete", "showClear", "autofocus", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "defaultLabel", "placeholder", "options", "filterValue", "itemSize", "selectAll", "focusOnHover", "filterFields", "selectOnFocus", "autoOptionFocus"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onClear", "onPanelShow", "onPanelHide", "onLazyLoad", "onRemove", "onSelectAllChange"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i3.TranslatePipe, name: "translate" }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
250
399
|
}
|
|
251
400
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.5", ngImport: i0, type: DropdownComponent, decorators: [{
|
|
252
401
|
type: Component,
|
|
253
|
-
args: [{ standalone: true, selector: 'mng-dropdown', providers: [DROPDOWN_VALUE_ACCESSOR], imports: [DropdownModule, MultiSelectModule, TranslateModule, FormsModule], changeDetection: ChangeDetectionStrategy.OnPush, template: "@if (!multiselect()) {\n <p-dropdown\n [ngModel]=\"ngModelValue
|
|
402
|
+
args: [{ standalone: true, selector: 'mng-dropdown', providers: [DROPDOWN_VALUE_ACCESSOR], imports: [DropdownModule, MultiSelectModule, TranslateModule, FormsModule], changeDetection: ChangeDetectionStrategy.OnPush, template: "@if (!multiselect()) {\n <p-dropdown\n [(ngModel)]=\"ngModelValue\"\n [placeholder]=\"placeholder()\"\n [dataKey]=\"optionsTrackProperty()\"\n [optionLabel]=\"optionsLabelProperty()\"\n [optionValue]=\"optionsValueProperty()\"\n [optionDisabled]=\"optionsDisabledProperty()\"\n [options]=\"items()\"\n [showClear]=\"showClear()\"\n [editable]=\"allowInput()\"\n [styleClass]=\"className()\"\n [panelStyleClass]=\"dropdownClassName()\"\n [disabled]=\"disabled()\"\n (onBlur)=\"onDropdownBlur($event)\"\n (onChange)=\"onDropdownChange($event)\"\n (onShow)=\"onDropdownPanelShow()\"\n (onHide)=\"onDropdownPanelHide()\"\n [dropdownIcon]=\"loading() ? 'pi pi-spinner pi-spin' : 'pi pi-chevron-down'\"\n [appendTo]=\"appendTo()\">\n </p-dropdown>\n} @else {\n <p-multiSelect\n [ngModel]=\"ngModelValue()\"\n [maxSelectedLabels]=\"1\"\n [selectedItemsLabel]=\"'mngDropdown.multiselectOverMaxDisplayLimit' | translate\"\n [placeholder]=\"placeholder()\"\n [dataKey]=\"optionsTrackProperty()\"\n [optionLabel]=\"optionsLabelProperty()\"\n [optionValue]=\"optionsValueProperty()\"\n [optionDisabled]=\"optionsDisabledProperty()\"\n [options]=\"items()\"\n [styleClass]=\"className()\"\n [panelStyleClass]=\"dropdownClassName()\"\n [filter]=\"true\"\n [showToggleAll]=\"false\"\n [disabled]=\"disabled()\"\n (onChange)=\"onMultiselectChange($event)\"\n (onPanelHide)=\"onMultiselectPanelHide()\"\n (onBlur)=\"onMultiselectBlur($event)\"\n appendTo=\"body\">\n </p-multiSelect>\n}\n" }]
|
|
254
403
|
}], ctorParameters: () => [] });
|
|
255
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.component.js","sourceRoot":"","sources":["../../../../../form/src/components/dropdown/dropdown.component.ts","../../../../../form/src/components/dropdown/dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    DestroyRef,\n    ExistingProvider,\n    Injector,\n    booleanAttribute,\n    computed,\n    effect,\n    forwardRef,\n    inject,\n    input,\n    output,\n    signal,\n    viewChild\n} from '@angular/core';\nimport {takeUntilDestroyed, toObservable} from '@angular/core/rxjs-interop';\nimport {ControlValueAccessor, FormsModule, NG_VALUE_ACCESSOR} from '@angular/forms';\n\nimport {TranslateModule, TranslateService} from '@ngx-translate/core';\nimport {Dropdown, DropdownChangeEvent, DropdownModule} from 'primeng/dropdown';\nimport {MultiSelect, MultiSelectBlurEvent, MultiSelectChangeEvent, MultiSelectModule} from 'primeng/multiselect';\nimport {combineLatest, map, of, switchMap, tap} from 'rxjs';\n\nimport {CommonsInternalError, ILookupDataProvider, LoggerService, toObservable as commonsToObservable, fromSubscribeError, getErrorLogLevel} from '@mediusinc/mng-commons/core';\n\nexport const DROPDOWN_VALUE_ACCESSOR: ExistingProvider = {\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => DropdownComponent),\n    multi: true\n};\n\n@Component({\n    standalone: true,\n    selector: 'mng-dropdown',\n    templateUrl: './dropdown.component.html',\n    providers: [DROPDOWN_VALUE_ACCESSOR],\n    imports: [DropdownModule, MultiSelectModule, TranslateModule, FormsModule],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class DropdownComponent implements ControlValueAccessor {\n    private readonly logger = inject(LoggerService).create('DropdownComponent');\n\n    private readonly injector = inject(Injector);\n    private readonly destroyRef = inject(DestroyRef);\n    private readonly translate = inject(TranslateService);\n\n    public dataProvider = input<ILookupDataProvider<any, any, any, any>>();\n    public options = input<Array<any>>([]);\n    public optionsTrackProperty = input<string>();\n    public optionsLabelPropertyInit = input<string | undefined>(undefined, {alias: 'optionsLabelProperty'});\n    public optionsLabelTranslate = input(false, {transform: booleanAttribute});\n    public optionsValuePropertyInput = input<string | undefined>(undefined, {alias: 'optionsValueProperty'});\n    public optionsDisabledProperty = input<string>();\n    public multiselect = input(false, {transform: booleanAttribute});\n    public placeholder = input<string>();\n    public showClear = input(false, {transform: booleanAttribute});\n    public selectFirstItemInput = input(false, {transform: booleanAttribute, alias: 'selectFirstItem'});\n    public className = input<string>();\n    public dropdownClassName = input<string>();\n    public changeValueOnBlur = input(false, {transform: booleanAttribute});\n    public loadingInput = input(false, {alias: 'loading', transform: booleanAttribute});\n    public disabledInput = input(false, {alias: 'disabled', transform: booleanAttribute});\n    public appendTo = input<string | null>('body');\n\n    public valueChange = output<any>();\n    public blur = output<Event>();\n\n    public primeDropdown = viewChild(Dropdown);\n    public primeMultiselect = viewChild(MultiSelect);\n\n    private _value?: any | null;\n    public ngModelValue = signal<undefined | null | any>(undefined);\n\n    private _loading = signal(false);\n    private _disabled = signal(false);\n    public loading = computed(() => this.loadingInput() || this._loading());\n    public disabled = computed(() => this.disabledInput() || this._disabled());\n\n    // eslint-disable-next-line @typescript-eslint/no-empty-function\n    private onChangeFn: any = () => {};\n    // eslint-disable-next-line @typescript-eslint/no-empty-function\n    private onTouchedFn: any = () => {};\n\n    private dataProviderService: any = null;\n    public items = signal<Array<any>>([]);\n    private firstTimeSettingItems = true;\n\n    private isDropdownPanelShown = false;\n\n    public optionsLabelProperty = computed(() => {\n        if (this.optionsLabelTranslate()) {\n            // setup translation properties\n            if (this.optionsLabelPropertyInit()) {\n                return `${this.optionsLabelPropertyInit()}_i18n`;\n            } else if (!this.optionsLabelPropertyInit() && !this.optionsValuePropertyInput()) {\n                return 'title_i18n';\n            } else {\n                throw new CommonsInternalError(`Invalid use with value (${this.optionsValuePropertyInput()}) and label (${this.optionsLabelPropertyInit()}) property setup.`, {\n                    name: 'DropdownComponentError'\n                });\n            }\n        }\n\n        return this.optionsLabelPropertyInit();\n    });\n    public optionsValueProperty = computed(() => {\n        if (this.optionsLabelTranslate()) {\n            // setup translation properties\n            if (!this.optionsLabelPropertyInit() && !this.optionsValuePropertyInput()) {\n                return 'value';\n            } else if (!this.optionsLabelPropertyInit()) {\n                throw new CommonsInternalError(`Invalid use with value (${this.optionsValuePropertyInput()}) and label (${this.optionsLabelPropertyInit()}) property setup.`, {\n                    name: 'DropdownComponentError'\n                });\n            }\n        }\n\n        return this.optionsValuePropertyInput();\n    });\n\n    public get value() {\n        return this._value;\n    }\n\n    constructor() {\n        effect(() => {\n            this._value = this.ngModelValue();\n        });\n\n        combineLatest([toObservable(this.dataProvider), toObservable(this.options)])\n            .pipe(\n                tap(() => this._loading.set(true)),\n                switchMap(([dataProvider, options]) => {\n                    if (dataProvider) {\n                        this.dataProviderService = dataProvider.serviceType ? this.injector.get<any>(dataProvider.serviceType) : null;\n                        return commonsToObservable(dataProvider.lookup({limit: 50}, this.dataProviderService));\n                    } else {\n                        return of(options ?? []);\n                    }\n                }),\n                switchMap(items => this.transformItems(items)),\n                takeUntilDestroyed()\n            )\n            .subscribe({\n                next: res => {\n                    this.items.set(res);\n                    this._loading.set(false);\n                    this.selectFirstItem();\n                    this.adjustValueOnItemsValuePropertyTypeMismatch();\n                },\n                error: err => {\n                    this.items.set([]);\n                    this._loading.set(false);\n                    const error = fromSubscribeError(err, 'DropdownComponentError');\n                    this.logger.log(error, getErrorLogLevel(error));\n                }\n            });\n    }\n\n    registerOnChange(fn: any): void {\n        this.onChangeFn = fn;\n    }\n\n    registerOnTouched(fn: any): void {\n        this.onTouchedFn = fn;\n    }\n\n    setDisabledState(isDisabled: boolean): void {\n        setTimeout(() => this._disabled.set(isDisabled));\n    }\n\n    writeValue(value: any): void {\n        // this check is required because angular in some cases writes null value\n        // before value accessor is initialized\n        // if form control value is of primitive type (ex: enums) then write value is not called (we think)\n        if (value == null && this._value == null) {\n            return;\n        }\n        // write value immediately - it is important so that first select is not triggered!\n        this._value = value;\n        this.adjustValueOnItemsValuePropertyTypeMismatch(true);\n    }\n\n    onDropdownBlur(event: Event) {\n        if (this.isDropdownPanelShown) {\n            // ignore this blur event\n            return;\n        }\n        const primeDropdown = this.primeDropdown();\n        if (this.changeValueOnBlur() && primeDropdown) {\n            this.propagateValueChange(primeDropdown.value);\n        }\n        this.onTouchedFn();\n        this.blur.emit(event);\n    }\n\n    onDropdownChange(event: DropdownChangeEvent) {\n        if (!this.changeValueOnBlur()) {\n            this.propagateValueChange(event.value);\n        }\n    }\n\n    onDropdownPanelShow() {\n        this.isDropdownPanelShown = true;\n    }\n\n    onDropdownPanelHide() {\n        this.isDropdownPanelShown = false;\n    }\n\n    onMultiselectChange(event: MultiSelectChangeEvent) {\n        if (!this.changeValueOnBlur()) {\n            this.propagateValueChange(event.value);\n        }\n    }\n\n    onMultiselectBlur(event: MultiSelectBlurEvent) {\n        this.onTouchedFn();\n        this.blur.emit(event.originalEvent);\n    }\n\n    onMultiselectPanelHide() {\n        const primeMultiselect = this.primeMultiselect();\n        if (this.changeValueOnBlur() && primeMultiselect) {\n            this.propagateValueChange(primeMultiselect.value);\n        }\n    }\n\n    private selectFirstItem() {\n        if (this.firstTimeSettingItems && this.items().length > 0 && this.selectFirstItemInput() && !this._value) {\n            const optionsValueProperty = this.optionsValueProperty();\n            const value = optionsValueProperty ? this.items()[0][optionsValueProperty] : this.items()[0];\n            this.ngModelValue.set(value); // set to write for input\n            this.firstTimeSettingItems = false;\n            this.propagateValueChange(value);\n        }\n    }\n\n    private transformItems(items: any[]) {\n        if (this.optionsLabelTranslate()) {\n            const translationKeys: string[] = items.map(\n                item => (typeof item === 'object' && this.optionsLabelPropertyInit() ? (item[this.optionsLabelPropertyInit() as keyof object] as string) : item) as string\n            );\n\n            if (translationKeys.length === 0) {\n                return of([]);\n            }\n\n            return this.translate.stream(translationKeys).pipe(\n                map(translations =>\n                    items.map(item => {\n                        if (typeof item === 'object' && this.optionsLabelPropertyInit()) {\n                            const label = item[this.optionsLabelPropertyInit() as keyof object] as string;\n                            const translation: string | undefined = translations[label];\n                            if (translation) {\n                                return {...item, [this.optionsLabelProperty()!]: translation};\n                            }\n                            return {...item};\n                        } else {\n                            const translation = translations[item];\n                            return {\n                                [this.optionsLabelProperty()!]: translation ?? item,\n                                [this.optionsValueProperty()!]: item\n                            };\n                        }\n                    })\n                )\n            );\n        } else {\n            return of(items);\n        }\n    }\n\n    private adjustValueOnItemsValuePropertyTypeMismatch(setNgModelValue = false) {\n        const optionsValueProp = this.optionsValueProperty();\n        if (optionsValueProp && this._value != null && this.items().length > 0 && this.items()[0][optionsValueProp] != null) {\n            if (Array.isArray(this._value)) {\n                if (this._value.length > 0 && typeof this.items()[0][optionsValueProp] !== typeof this._value[0]) {\n                    const stringValues = this._value.map(v => v.toString());\n                    const selectedOptions = this.items().filter(i => i[optionsValueProp] != null && stringValues.includes(i[optionsValueProp].toString()));\n                    if (selectedOptions.length > 0) {\n                        this.ngModelValue.set(selectedOptions.map(i => i[optionsValueProp]));\n                        return;\n                    }\n                }\n            } else if (typeof this.items()[0][optionsValueProp] !== typeof this._value) {\n                // types dont match, search and compare by string\n                const selectedOption = this.items().find(i => i[optionsValueProp] != null && i[optionsValueProp].toString() === this._value.toString());\n                if (selectedOption) {\n                    this.ngModelValue.set(selectedOption[optionsValueProp]);\n                    return;\n                }\n            }\n        }\n\n        if (setNgModelValue) {\n            // force write to ngModelValue anyway\n            this.ngModelValue.set(this._value);\n        }\n    }\n\n    private propagateValueChange(value: any) {\n        this._value = value;\n        this.onChangeFn(value);\n        this.valueChange.emit(value);\n    }\n}\n","@if (!multiselect()) {\n    <p-dropdown\n        [ngModel]=\"ngModelValue()\"\n        [placeholder]=\"placeholder()\"\n        [dataKey]=\"optionsTrackProperty()\"\n        [optionLabel]=\"optionsLabelProperty()\"\n        [optionValue]=\"optionsValueProperty()\"\n        [optionDisabled]=\"optionsDisabledProperty()\"\n        [options]=\"items()\"\n        [showClear]=\"showClear()\"\n        [styleClass]=\"className()\"\n        [panelStyleClass]=\"dropdownClassName()\"\n        [disabled]=\"disabled()\"\n        (onBlur)=\"onDropdownBlur($event)\"\n        (onChange)=\"onDropdownChange($event)\"\n        (onShow)=\"onDropdownPanelShow()\"\n        (onHide)=\"onDropdownPanelHide()\"\n        [dropdownIcon]=\"loading() ? 'pi pi-spinner pi-spin' : 'pi pi-chevron-down'\"\n        [appendTo]=\"appendTo()\">\n    </p-dropdown>\n} @else {\n    <p-multiSelect\n        [ngModel]=\"ngModelValue()\"\n        [maxSelectedLabels]=\"1\"\n        [selectedItemsLabel]=\"'mngDropdown.multiselectOverMaxDisplayLimit' | translate\"\n        [placeholder]=\"placeholder()\"\n        [dataKey]=\"optionsTrackProperty()\"\n        [optionLabel]=\"optionsLabelProperty()\"\n        [optionValue]=\"optionsValueProperty()\"\n        [optionDisabled]=\"optionsDisabledProperty()\"\n        [options]=\"items()\"\n        [styleClass]=\"className()\"\n        [panelStyleClass]=\"dropdownClassName()\"\n        [filter]=\"true\"\n        [showToggleAll]=\"false\"\n        [disabled]=\"disabled()\"\n        (onChange)=\"onMultiselectChange($event)\"\n        (onPanelHide)=\"onMultiselectPanelHide()\"\n        (onBlur)=\"onMultiselectBlur($event)\"\n        appendTo=\"body\">\n    </p-multiSelect>\n}\n"]}
|
|
404
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.component.js","sourceRoot":"","sources":["../../../../../form/src/components/dropdown/dropdown.component.ts","../../../../../form/src/components/dropdown/dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    DestroyRef,\n    ExistingProvider,\n    Injector,\n    booleanAttribute,\n    computed,\n    effect,\n    forwardRef,\n    inject,\n    input,\n    output,\n    signal,\n    viewChild\n} from '@angular/core';\nimport {takeUntilDestroyed, toObservable} from '@angular/core/rxjs-interop';\nimport {ControlValueAccessor, FormsModule, NG_VALUE_ACCESSOR} from '@angular/forms';\n\nimport {TranslateModule, TranslateService} from '@ngx-translate/core';\nimport {Dropdown, DropdownChangeEvent, DropdownModule} from 'primeng/dropdown';\nimport {MultiSelect, MultiSelectBlurEvent, MultiSelectChangeEvent, MultiSelectModule} from 'primeng/multiselect';\nimport {Observable, ReplaySubject, Subscription, combineLatest, map, of, switchMap, take, tap} from 'rxjs';\n\nimport {\n    CommonsInternalError,\n    DataListParams,\n    FilterMatchMode,\n    ILookupDataProvider,\n    LoggerService,\n    toObservable as commonsToObservable,\n    fromSubscribeError,\n    getErrorLogLevel\n} from '@mediusinc/mng-commons/core';\nimport {InputTrimType} from '@mediusinc/mng-commons/form/api';\n\nexport const DROPDOWN_VALUE_ACCESSOR: ExistingProvider = {\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => DropdownComponent),\n    multi: true\n};\n\n@Component({\n    standalone: true,\n    selector: 'mng-dropdown',\n    templateUrl: './dropdown.component.html',\n    providers: [DROPDOWN_VALUE_ACCESSOR],\n    imports: [DropdownModule, MultiSelectModule, TranslateModule, FormsModule],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class DropdownComponent implements ControlValueAccessor {\n    private readonly logger = inject(LoggerService).create('DropdownComponent');\n\n    private readonly injector = inject(Injector);\n    private readonly destroyRef = inject(DestroyRef);\n    private readonly translate = inject(TranslateService);\n\n    public dataProvider = input<ILookupDataProvider<any, any, any, any>>();\n    public options = input<Array<any>>([]);\n    public optionsTrackProperty = input<string>();\n    public optionsLabelPropertyInit = input<string | undefined>(undefined, {alias: 'optionsLabelProperty'});\n    public optionsLabelTranslate = input(false, {transform: booleanAttribute});\n    public optionsValuePropertyInput = input<string | undefined>(undefined, {alias: 'optionsValueProperty'});\n    public optionsDisabledProperty = input<string>();\n    public multiselect = input(false, {transform: booleanAttribute});\n    public placeholder = input<string>();\n    public showClear = input(false, {transform: booleanAttribute});\n    public selectFirstItemInput = input(false, {transform: booleanAttribute, alias: 'selectFirstItem'});\n    public className = input<string>();\n    public dropdownClassName = input<string>();\n    public changeValueOnBlur = input(false, {transform: booleanAttribute});\n    public loadingInput = input(false, {alias: 'loading', transform: booleanAttribute});\n    public disabledInput = input(false, {alias: 'disabled', transform: booleanAttribute});\n    public allowInput = input(false, {transform: booleanAttribute});\n    public appendTo = input<string | null>('body');\n\n    public inlineSearch = input(false, {transform: booleanAttribute});\n    public searchTrim = input<InputTrimType | undefined>(undefined);\n\n    public valueChange = output<any>();\n    public blur = output<Event>();\n\n    public primeDropdown = viewChild(Dropdown);\n    public primeMultiselect = viewChild(MultiSelect);\n\n    private _value?: any | null;\n    public ngModelValue = signal<undefined | null | any>(undefined);\n\n    private _loading = signal(false);\n    private _disabled = signal(false);\n    public loading = computed(() => this.loadingInput() || this._loading());\n    public disabled = computed(() => this.disabledInput() || this._disabled());\n\n    // eslint-disable-next-line @typescript-eslint/no-empty-function\n    private onChangeFn: any = () => {};\n    // eslint-disable-next-line @typescript-eslint/no-empty-function\n    private onTouchedFn: any = () => {};\n\n    private dataProviderService: any = null;\n    public items = signal<Array<any>>([]);\n    private firstTimeSettingItems = true;\n\n    private isDropdownPanelShown = false;\n\n    // used with custom input functionality\n    private valueSuggestionProviderSubscription: Subscription | null = null;\n    private valueSuggestionResultCacheSubject?: ReplaySubject<any>;\n\n    public optionsLabelProperty = computed(() => {\n        if (this.optionsLabelTranslate()) {\n            // setup translation properties\n            if (this.optionsLabelPropertyInit()) {\n                return `${this.optionsLabelPropertyInit()}_i18n`;\n            } else if (!this.optionsLabelPropertyInit() && !this.optionsValuePropertyInput()) {\n                return 'title_i18n';\n            } else {\n                throw new CommonsInternalError(`Invalid use with value (${this.optionsValuePropertyInput()}) and label (${this.optionsLabelPropertyInit()}) property setup.`, {\n                    name: 'DropdownComponentError'\n                });\n            }\n        }\n\n        return this.optionsLabelPropertyInit();\n    });\n    public optionsValueProperty = computed(() => {\n        if (this.optionsLabelTranslate()) {\n            // setup translation properties\n            if (!this.optionsLabelPropertyInit() && !this.optionsValuePropertyInput()) {\n                return 'value';\n            } else if (!this.optionsLabelPropertyInit()) {\n                throw new CommonsInternalError(`Invalid use with value (${this.optionsValuePropertyInput()}) and label (${this.optionsLabelPropertyInit()}) property setup.`, {\n                    name: 'DropdownComponentError'\n                });\n            }\n        }\n\n        return this.optionsValuePropertyInput();\n    });\n\n    public get value() {\n        return this._value;\n    }\n\n    constructor() {\n        effect(() => {\n            this._value = this.ngModelValue();\n        });\n\n        combineLatest([toObservable(this.dataProvider), toObservable(this.options)])\n            .pipe(\n                tap(() => this._loading.set(true)),\n                switchMap(([dataProvider, options]) => {\n                    if (dataProvider) {\n                        this.dataProviderService = dataProvider.serviceType ? this.injector.get<any>(dataProvider.serviceType) : null;\n                        return commonsToObservable(dataProvider.lookup({limit: 50}, this.dataProviderService));\n                    } else {\n                        return of(options ?? []);\n                    }\n                }),\n                switchMap(items => this.transformItems(items)),\n                takeUntilDestroyed()\n            )\n            .subscribe({\n                next: res => {\n                    this.setItems(res);\n                    if (this.inlineSearch()) {\n                        if (!this.valueSuggestionResultCacheSubject) {\n                            this.valueSuggestionResultCacheSubject = new ReplaySubject<any>(1);\n                        }\n                        this.valueSuggestionResultCacheSubject?.next(res);\n                    }\n                    this._loading.set(false);\n                    this.selectFirstItem(); // only selects first item if selectFirstItemInput is set accordingly\n                    this.adjustValueOnItemsValuePropertyTypeMismatch();\n                },\n                error: err => {\n                    this.setItems([]);\n                    this._loading.set(false);\n                    const error = fromSubscribeError(err, 'DropdownComponentError');\n                    this.logger.log(error, getErrorLogLevel(error));\n                }\n            });\n\n        effect(() => {\n            if (this.allowInput()) {\n                if (this.optionsLabelProperty() && !this.optionsValueProperty()) {\n                    throw new CommonsInternalError(\n                        `allowInput is not supported when optionsLabelProperty is defined but optionsValueProperty is missing. Set optionsValueProperty to enable allowInput.`\n                    );\n                }\n            }\n        });\n    }\n\n    registerOnChange(fn: any): void {\n        this.onChangeFn = fn;\n    }\n\n    registerOnTouched(fn: any): void {\n        this.onTouchedFn = fn;\n    }\n\n    setDisabledState(isDisabled: boolean): void {\n        setTimeout(() => this._disabled.set(isDisabled));\n    }\n\n    writeValue(value: any): void {\n        // this check is required because angular in some cases writes null value\n        // before value accessor is initialized\n        // if form control value is of primitive type (ex: enums) then write value is not called (we think)\n        if (value == null && this._value == null) {\n            return;\n        }\n        // write value immediately - it is important so that first select is not triggered!\n        this._value = value;\n        this.adjustValueOnItemsValuePropertyTypeMismatch(true);\n    }\n\n    onDropdownBlur(event: Event) {\n        // if allowCustomInput is enabled, the input element might still be in focus with the\n        // dropdown panel hidden - that's why the !this.allowCustomInput() check is needed\n        if (this.isDropdownPanelShown && !this.allowInput()) {\n            // ignore this blur event\n            return;\n        }\n        const primeDropdown = this.primeDropdown();\n        if (this.changeValueOnBlur() && primeDropdown) {\n            this.propagateValueChange(primeDropdown.value);\n        }\n        this.onTouchedFn();\n        this.blur.emit(event);\n    }\n\n    onDropdownChange(event: DropdownChangeEvent) {\n        if (!this.changeValueOnBlur()) {\n            this.propagateValueChange(event.value);\n        }\n\n        if (this.allowInput()) {\n            const optionsLabelProperty = this.optionsLabelProperty();\n            let query: string | undefined = undefined;\n\n            if (typeof event?.value === 'string' && event?.value.trim() === '') {\n                return;\n            } else if (typeof event.value === 'string') {\n                query = this.trimValue(event.value);\n            }\n\n            this.valueSuggestionProviderSubscription?.unsubscribe();\n            if (this.dataProvider()) {\n                if (!this.inlineSearch()) {\n                    const params: DataListParams = {\n                        limit: 10\n                    };\n\n                    if (optionsLabelProperty) {\n                        params.sort = [{property: optionsLabelProperty}];\n                    }\n                    if (query && query.length > 0 && optionsLabelProperty) {\n                        params.filters = {\n                            [optionsLabelProperty]: {\n                                value: query,\n                                matchMode: FilterMatchMode.StartsWith\n                            }\n                        };\n                    }\n\n                    this.valueSuggestionProviderSubscription = this.getLookup(params, query)\n                        .pipe(takeUntilDestroyed(this.destroyRef))\n                        .subscribe({\n                            next: items => {\n                                this.setItems(items);\n                            },\n                            error: err => {\n                                this.setItems([]);\n\n                                const error = fromSubscribeError(err, 'DropdownComponentError', {\n                                    search: query,\n                                    params: params\n                                });\n                                this.logger.log(error, getErrorLogLevel(error));\n                            }\n                        });\n                } else if (this.valueSuggestionResultCacheSubject) {\n                    this.valueSuggestionProviderSubscription = this.valueSuggestionResultCacheSubject.pipe(take(1)).subscribe(result => {\n                        this.setItems(result, query);\n                    });\n                }\n            } else if (this.options().length > 0) {\n                this.setItems(this.options(), query);\n            }\n        }\n    }\n\n    /**\n     * Sets the items in the dropdown. If a query is provided, the items will be filtered by the query (using a 'starts with' filter).\n     *\n     * @param items The items to set.\n     * @param [query] The query to filter the items by.\n     */\n    private setItems(items: Array<any>, query?: string) {\n        if (this.allowInput()) {\n            if (items.length > 0) {\n                // items can either be objects (with optionsValueProperty specifying a string property) or strings\n                if (typeof items[0] === 'object') {\n                    if (!this.optionsValueProperty()) {\n                        throw new CommonsInternalError(\n                            `allowInput is not supported when optionValueProperty is not set and the dropdown items are of type object. Set optionsValueProperty to enable allowInput.`\n                        );\n                    }\n                    if (typeof items[0]?.[this.optionsValueProperty()!] !== 'string') {\n                        throw new CommonsInternalError(`allowInput is only supported when the value property (specified with optionsValueProperty) is of type string.`);\n                    }\n                } else if (!(typeof items[0] === 'string' && !this.optionsLabelProperty() && !this.optionsValueProperty())) {\n                    throw new CommonsInternalError(\n                        `'allowInput' is only supported for items of type string or object. For object types, ensure that the 'optionsValueProperty' is specified and represents a property of type string.`\n                    );\n                }\n            }\n        }\n\n        if (query) {\n            const queryLowerCase = query?.toLowerCase() ?? '';\n            const filteredItems = items.filter(i => {\n                let itemLabel = i;\n                const optionsLabelProperty = this.optionsLabelProperty();\n                if (optionsLabelProperty && typeof i === 'object') {\n                    itemLabel = i[optionsLabelProperty];\n                }\n                if (itemLabel == null) {\n                    return queryLowerCase == null || !queryLowerCase.length;\n                }\n                if (typeof itemLabel !== 'string') {\n                    itemLabel = itemLabel.toString();\n                }\n                return itemLabel.toLowerCase().startsWith(queryLowerCase);\n            });\n            this.items.set([...filteredItems]);\n        } else {\n            this.items.set([...items]);\n        }\n    }\n\n    onDropdownPanelShow() {\n        this.isDropdownPanelShown = true;\n    }\n\n    onDropdownPanelHide() {\n        this.isDropdownPanelShown = false;\n    }\n\n    onMultiselectChange(event: MultiSelectChangeEvent) {\n        if (!this.changeValueOnBlur()) {\n            this.propagateValueChange(event.value);\n        }\n    }\n\n    onMultiselectBlur(event: MultiSelectBlurEvent) {\n        this.onTouchedFn();\n        this.blur.emit(event.originalEvent);\n    }\n\n    onMultiselectPanelHide() {\n        const primeMultiselect = this.primeMultiselect();\n        if (this.changeValueOnBlur() && primeMultiselect) {\n            this.propagateValueChange(primeMultiselect.value);\n        }\n    }\n\n    private selectFirstItem() {\n        if (this.firstTimeSettingItems && this.items().length > 0 && this.selectFirstItemInput() && !this._value) {\n            const optionsValueProperty = this.optionsValueProperty();\n            const value = optionsValueProperty ? this.items()[0][optionsValueProperty] : this.items()[0];\n            this.ngModelValue.set(value); // set to write for input\n            this.firstTimeSettingItems = false;\n            this.propagateValueChange(value);\n        }\n    }\n\n    private transformItems(items: any[]) {\n        if (this.optionsLabelTranslate()) {\n            const translationKeys: string[] = items.map(\n                item => (typeof item === 'object' && this.optionsLabelPropertyInit() ? (item[this.optionsLabelPropertyInit() as keyof object] as string) : item) as string\n            );\n\n            if (translationKeys.length === 0) {\n                return of([]);\n            }\n\n            return this.translate.stream(translationKeys).pipe(\n                map(translations =>\n                    items.map(item => {\n                        if (typeof item === 'object' && this.optionsLabelPropertyInit()) {\n                            const label = item[this.optionsLabelPropertyInit() as keyof object] as string;\n                            const translation: string | undefined = translations[label];\n                            if (translation) {\n                                return {...item, [this.optionsLabelProperty()!]: translation};\n                            }\n                            return {...item};\n                        } else {\n                            const translation = translations[item];\n                            return {\n                                [this.optionsLabelProperty()!]: translation ?? item,\n                                [this.optionsValueProperty()!]: item\n                            };\n                        }\n                    })\n                )\n            );\n        } else {\n            return of(items);\n        }\n    }\n\n    private adjustValueOnItemsValuePropertyTypeMismatch(setNgModelValue = false) {\n        const optionsValueProp = this.optionsValueProperty();\n        if (optionsValueProp && this._value != null && this.items().length > 0 && this.items()[0][optionsValueProp] != null) {\n            if (Array.isArray(this._value)) {\n                if (this._value.length > 0 && typeof this.items()[0][optionsValueProp] !== typeof this._value[0]) {\n                    const stringValues = this._value.map(v => v.toString());\n                    const selectedOptions = this.items().filter(i => i[optionsValueProp] != null && stringValues.includes(i[optionsValueProp].toString()));\n                    if (selectedOptions.length > 0) {\n                        this.ngModelValue.set(selectedOptions.map(i => i[optionsValueProp]));\n                        return;\n                    }\n                }\n            } else if (typeof this.items()[0][optionsValueProp] !== typeof this._value) {\n                // types don't match, search and compare by string\n                const selectedOption = this.items().find(i => i[optionsValueProp] != null && i[optionsValueProp].toString() === this._value.toString());\n                if (selectedOption) {\n                    this.ngModelValue.set(selectedOption[optionsValueProp]);\n                    return;\n                }\n            }\n        }\n\n        if (setNgModelValue) {\n            // force write to ngModelValue anyway\n            this.ngModelValue.set(this._value);\n        }\n    }\n\n    private propagateValueChange(value: any) {\n        this._value = value;\n        this.onChangeFn(value);\n        this.valueChange.emit(value);\n    }\n\n    /**\n     * Gets the lookup from the data provider.\n     *\n     * @param params The parameters to pass to the lookup.\n     * @param [query] The search query to filter the items by.\n     */\n    private getLookup(params: DataListParams, query?: string): Observable<Array<any>> {\n        const dataProvider = this.dataProvider();\n        if (dataProvider) {\n            return commonsToObservable(dataProvider.lookup(params, this.dataProviderService, query)).pipe(\n                switchMap(res => {\n                    return of(res ?? []);\n                })\n            );\n        }\n        return of([]);\n    }\n\n    /**\n     * Trims the leading and/or trailing whitespace from the given value based on the search trimming mode.\n     *\n     * @param value - The value to be trimmed.\n     */\n    private trimValue(value: string | undefined) {\n        switch (this.searchTrim()) {\n            case 'start':\n                return value?.trimStart();\n            case 'end':\n                return value?.trimEnd();\n            case 'both':\n                return value?.trim();\n            default:\n                return value;\n        }\n    }\n}\n","@if (!multiselect()) {\n    <p-dropdown\n        [(ngModel)]=\"ngModelValue\"\n        [placeholder]=\"placeholder()\"\n        [dataKey]=\"optionsTrackProperty()\"\n        [optionLabel]=\"optionsLabelProperty()\"\n        [optionValue]=\"optionsValueProperty()\"\n        [optionDisabled]=\"optionsDisabledProperty()\"\n        [options]=\"items()\"\n        [showClear]=\"showClear()\"\n        [editable]=\"allowInput()\"\n        [styleClass]=\"className()\"\n        [panelStyleClass]=\"dropdownClassName()\"\n        [disabled]=\"disabled()\"\n        (onBlur)=\"onDropdownBlur($event)\"\n        (onChange)=\"onDropdownChange($event)\"\n        (onShow)=\"onDropdownPanelShow()\"\n        (onHide)=\"onDropdownPanelHide()\"\n        [dropdownIcon]=\"loading() ? 'pi pi-spinner pi-spin' : 'pi pi-chevron-down'\"\n        [appendTo]=\"appendTo()\">\n    </p-dropdown>\n} @else {\n    <p-multiSelect\n        [ngModel]=\"ngModelValue()\"\n        [maxSelectedLabels]=\"1\"\n        [selectedItemsLabel]=\"'mngDropdown.multiselectOverMaxDisplayLimit' | translate\"\n        [placeholder]=\"placeholder()\"\n        [dataKey]=\"optionsTrackProperty()\"\n        [optionLabel]=\"optionsLabelProperty()\"\n        [optionValue]=\"optionsValueProperty()\"\n        [optionDisabled]=\"optionsDisabledProperty()\"\n        [options]=\"items()\"\n        [styleClass]=\"className()\"\n        [panelStyleClass]=\"dropdownClassName()\"\n        [filter]=\"true\"\n        [showToggleAll]=\"false\"\n        [disabled]=\"disabled()\"\n        (onChange)=\"onMultiselectChange($event)\"\n        (onPanelHide)=\"onMultiselectPanelHide()\"\n        (onBlur)=\"onMultiselectBlur($event)\"\n        appendTo=\"body\">\n    </p-multiSelect>\n}\n"]}
|