@mediusinc/mng-commons 5.3.0-rc.0 → 5.3.0-rc.2
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/components/pages/error/error.page.component.d.ts +3 -0
- package/core/components/pages/not-found/not-found.page.component.d.ts +3 -0
- package/core/data-list/filter-metadata.model.d.ts +20 -0
- package/core/enum/enum-helpers.d.ts +5 -0
- package/core/helpers/number.d.ts +5 -0
- package/core/helpers/type-helpers.d.ts +1 -0
- package/core/index.d.ts +3 -1
- package/core/provide.d.ts +3 -2
- package/core/services/{local-storage-config.service.d.ts → commons-storage.service.d.ts} +4 -3
- package/core/services/commons.service.d.ts +24 -0
- package/core/services/tokens/module-config.token.d.ts +30 -8
- package/esm2022/core/components/pages/error/error.page.component.mjs +4 -1
- package/esm2022/core/components/pages/not-found/not-found.page.component.mjs +4 -1
- package/esm2022/core/data-list/data-list-params-helpers.mjs +3 -1
- package/esm2022/core/data-list/filter-metadata.model.mjs +2 -0
- package/esm2022/core/enum/enum-helpers.mjs +10 -1
- package/esm2022/core/helpers/date.mjs +2 -2
- package/esm2022/core/helpers/number.mjs +19 -0
- package/esm2022/core/helpers/type-helpers.mjs +1 -1
- package/esm2022/core/index.mjs +4 -2
- package/esm2022/core/pipes/boolean.pipe.mjs +7 -1
- package/esm2022/core/pipes/enum.pipe.mjs +16 -5
- package/esm2022/core/provide.mjs +6 -5
- package/esm2022/core/router/route-builder.mjs +8 -1
- package/esm2022/core/security/permission.guard.mjs +2 -2
- package/esm2022/core/security/permission.service.mjs +2 -2
- package/esm2022/core/services/commons-storage.service.mjs +31 -0
- package/esm2022/core/services/commons.service.mjs +25 -1
- package/esm2022/core/services/tokens/module-config.token.mjs +1 -1
- package/esm2022/filter/descriptors/filter-lookup.descriptor.mjs +2 -3
- package/esm2022/filter/descriptors/filter.descriptor.mjs +76 -31
- package/esm2022/filter/models/filter.model.mjs +6 -1
- package/esm2022/form/components/date-range/date-range.component.mjs +45 -14
- package/esm2022/form/components/dropdown/dropdown.component.mjs +77 -93
- package/esm2022/form/components/number-range/number-range.component.mjs +29 -12
- package/esm2022/table/api/descriptors/column.descriptor.mjs +2 -1
- package/esm2022/table/api/descriptors/table.descriptor.mjs +11 -20
- package/esm2022/table/api/models/table-columns.model.mjs +1 -1
- package/esm2022/table/api/models/table.model.mjs +1 -1
- package/esm2022/table/components/column-filter/column-filter.component.mjs +396 -0
- package/esm2022/table/components/filter/filter-active-tag/filter-active-tag.component.mjs +52 -0
- package/esm2022/table/components/filter/filter-form/filter-form.component.mjs +197 -0
- package/esm2022/table/components/filter/filter-overlay-with-tag/filter-overlay-with-tag.component.mjs +135 -0
- package/esm2022/table/components/table/table.component.mjs +39 -30
- package/esm2022/table/helpers/filters.mjs +297 -0
- package/esm2022/table/index.mjs +13 -2
- package/esm2022/table/models/filter.model.mjs +2 -0
- package/esm2022/table/pipes/filter-value.pipe.mjs +77 -0
- package/esm2022/table/provide.mjs +19 -0
- package/esm2022/table/services/data-list.service.mjs +1 -1
- package/esm2022/table/services/table-feature-config.token.mjs +3 -0
- package/esm2022/tableview/action/components/editor/injector-context/action-editor-injector-context.component.mjs +2 -2
- package/esm2022/tableview/action/components/localization/data-language-dropdown.component.mjs +2 -2
- package/esm2022/tableview/api/editor/descriptors/field.descriptor.mjs +1 -1
- package/esm2022/tableview/api/editor/models/editor-fields.model.mjs +1 -1
- package/esm2022/tableview/api/tableview/descriptors/tableview.descriptor.mjs +11 -13
- package/esm2022/tableview/editor/components/formly/fields/formly-field-dropdown/formly-field-dropdown.component.mjs +2 -2
- package/esm2022/tableview/tableview/components/tableview/tableview.component.mjs +3 -4
- package/fesm2022/mediusinc-mng-commons-core.mjs +103 -17
- package/fesm2022/mediusinc-mng-commons-core.mjs.map +1 -1
- package/fesm2022/mediusinc-mng-commons-filter.mjs +81 -32
- package/fesm2022/mediusinc-mng-commons-filter.mjs.map +1 -1
- package/fesm2022/mediusinc-mng-commons-form.mjs +149 -117
- package/fesm2022/mediusinc-mng-commons-form.mjs.map +1 -1
- package/fesm2022/mediusinc-mng-commons-table-api.mjs +11 -19
- package/fesm2022/mediusinc-mng-commons-table-api.mjs.map +1 -1
- package/fesm2022/mediusinc-mng-commons-table.mjs +836 -363
- package/fesm2022/mediusinc-mng-commons-table.mjs.map +1 -1
- package/fesm2022/mediusinc-mng-commons-tableview-api.mjs +10 -12
- package/fesm2022/mediusinc-mng-commons-tableview-api.mjs.map +1 -1
- package/fesm2022/mediusinc-mng-commons-tableview.mjs +5 -5
- package/fesm2022/mediusinc-mng-commons-tableview.mjs.map +1 -1
- package/filter/descriptors/filter.descriptor.d.ts +60 -16
- package/filter/models/filter.model.d.ts +4 -0
- package/form/components/date-range/date-range.component.d.ts +9 -3
- package/form/components/dropdown/dropdown.component.d.ts +6 -7
- package/form/components/number-range/number-range.component.d.ts +8 -4
- package/i18n/en.json +40 -0
- package/i18n/sl.json +40 -0
- package/package.json +7 -7
- package/table/api/descriptors/table.descriptor.d.ts +7 -7
- package/table/api/models/table-columns.model.d.ts +3 -3
- package/table/api/models/table.model.d.ts +0 -12
- package/table/components/{column-filter-full/column-filter-full.component.d.ts → column-filter/column-filter.component.d.ts} +23 -38
- package/table/components/filter/filter-active-tag/filter-active-tag.component.d.ts +20 -0
- package/table/components/filter/filter-form/filter-form.component.d.ts +53 -0
- package/table/components/filter/filter-overlay-with-tag/filter-overlay-with-tag.component.d.ts +35 -0
- package/table/components/table/table.component.d.ts +11 -8
- package/table/helpers/filters.d.ts +31 -0
- package/table/index.d.ts +10 -1
- package/table/models/filter.model.d.ts +24 -0
- package/table/pipes/filter-value.pipe.d.ts +19 -0
- package/table/provide.d.ts +8 -0
- package/table/services/data-list.service.d.ts +3 -2
- package/table/services/table-feature-config.token.d.ts +6 -0
- package/tableview/api/editor/descriptors/field.descriptor.d.ts +3 -3
- package/tableview/api/editor/models/editor-fields.model.d.ts +4 -4
- package/tableview/api/tableview/descriptors/tableview.descriptor.d.ts +8 -6
- package/version-info.json +5 -5
- package/esm2022/core/services/local-storage-config.service.mjs +0 -29
- package/esm2022/table/components/column-filter-full/column-filter-full.component.mjs +0 -655
|
@@ -1,12 +1,11 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, DestroyRef, Injector, booleanAttribute, computed, effect, forwardRef, inject, input, output, signal, viewChild } from '@angular/core';
|
|
2
|
-
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
2
|
+
import { takeUntilDestroyed, toObservable } from '@angular/core/rxjs-interop';
|
|
3
3
|
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 { of, switchMap } from 'rxjs';
|
|
8
|
-
import {
|
|
9
|
-
import { CommonsInternalError, LoggerService, fromSubscribeError, getErrorLogLevel, toObservable } from '@mediusinc/mng-commons/core';
|
|
7
|
+
import { combineLatest, map, of, switchMap, tap } from 'rxjs';
|
|
8
|
+
import { CommonsInternalError, LoggerService, toObservable as commonsToObservable, fromSubscribeError, getErrorLogLevel } from '@mediusinc/mng-commons/core';
|
|
10
9
|
import * as i0 from "@angular/core";
|
|
11
10
|
import * as i1 from "primeng/dropdown";
|
|
12
11
|
import * as i2 from "primeng/multiselect";
|
|
@@ -42,6 +41,7 @@ export class DropdownComponent {
|
|
|
42
41
|
this.changeValueOnBlur = input(false, { transform: booleanAttribute });
|
|
43
42
|
this.loadingInput = input(false, { alias: 'loading', transform: booleanAttribute });
|
|
44
43
|
this.disabledInput = input(false, { alias: 'disabled', transform: booleanAttribute });
|
|
44
|
+
this.appendTo = input('body');
|
|
45
45
|
this.valueChange = output();
|
|
46
46
|
this.blur = output();
|
|
47
47
|
this.primeDropdown = viewChild(Dropdown);
|
|
@@ -93,9 +93,30 @@ export class DropdownComponent {
|
|
|
93
93
|
effect(() => {
|
|
94
94
|
this._value = this.ngModelValue();
|
|
95
95
|
});
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
96
|
+
combineLatest([toObservable(this.dataProvider), toObservable(this.options)])
|
|
97
|
+
.pipe(tap(() => this._loading.set(true)), switchMap(([dataProvider, options]) => {
|
|
98
|
+
if (dataProvider) {
|
|
99
|
+
this.dataProviderService = dataProvider.serviceType ? this.injector.get(dataProvider.serviceType) : null;
|
|
100
|
+
return commonsToObservable(dataProvider.lookup({ limit: 50 }, this.dataProviderService));
|
|
101
|
+
}
|
|
102
|
+
else {
|
|
103
|
+
return of(options ?? []);
|
|
104
|
+
}
|
|
105
|
+
}), switchMap(items => this.transformItems(items)), takeUntilDestroyed())
|
|
106
|
+
.subscribe({
|
|
107
|
+
next: res => {
|
|
108
|
+
this.items.set(res);
|
|
109
|
+
this._loading.set(false);
|
|
110
|
+
this.selectFirstItem();
|
|
111
|
+
this.adjustValueOnItemsValuePropertyTypeMismatch();
|
|
112
|
+
},
|
|
113
|
+
error: err => {
|
|
114
|
+
this.items.set([]);
|
|
115
|
+
this._loading.set(false);
|
|
116
|
+
const error = fromSubscribeError(err, 'DropdownComponentError');
|
|
117
|
+
this.logger.log(error, getErrorLogLevel(error));
|
|
118
|
+
}
|
|
119
|
+
});
|
|
99
120
|
}
|
|
100
121
|
registerOnChange(fn) {
|
|
101
122
|
this.onChangeFn = fn;
|
|
@@ -155,76 +176,6 @@ export class DropdownComponent {
|
|
|
155
176
|
this.propagateValueChange(primeMultiselect.value);
|
|
156
177
|
}
|
|
157
178
|
}
|
|
158
|
-
setDataProviderAndOptions() {
|
|
159
|
-
const dataProvider = this.dataProvider();
|
|
160
|
-
const options = this.options();
|
|
161
|
-
if (dataProvider) {
|
|
162
|
-
this._loading.set(true);
|
|
163
|
-
this.dataProviderService = dataProvider.serviceType ? this.injector.get(dataProvider.serviceType) : null;
|
|
164
|
-
toObservable(dataProvider.lookup({ limit: 50 }, this.dataProviderService))
|
|
165
|
-
.pipe(switchMap(items => {
|
|
166
|
-
if (this.optionsLabelTranslate()) {
|
|
167
|
-
const translationKeys = items.map(item => (typeof item === 'object' && this.optionsLabelPropertyInit()
|
|
168
|
-
? item[this.optionsLabelPropertyInit()]
|
|
169
|
-
: item));
|
|
170
|
-
if (translationKeys.length === 0) {
|
|
171
|
-
return of([]);
|
|
172
|
-
}
|
|
173
|
-
return this.translate.stream(translationKeys).pipe(map(translations => items.map(item => {
|
|
174
|
-
if (typeof item === 'object' && this.optionsLabelPropertyInit()) {
|
|
175
|
-
const label = item[this.optionsLabelPropertyInit()];
|
|
176
|
-
const translation = translations[label];
|
|
177
|
-
if (translation) {
|
|
178
|
-
return { ...item, [this.optionsLabelProperty()]: translation };
|
|
179
|
-
}
|
|
180
|
-
return { ...item };
|
|
181
|
-
}
|
|
182
|
-
else {
|
|
183
|
-
const translation = translations[item];
|
|
184
|
-
return {
|
|
185
|
-
[this.optionsLabelProperty()]: translation ?? item,
|
|
186
|
-
[this.optionsValueProperty()]: item
|
|
187
|
-
};
|
|
188
|
-
}
|
|
189
|
-
})));
|
|
190
|
-
}
|
|
191
|
-
else {
|
|
192
|
-
return of(items);
|
|
193
|
-
}
|
|
194
|
-
}), takeUntilDestroyed(this.destroyRef))
|
|
195
|
-
.subscribe({
|
|
196
|
-
next: res => {
|
|
197
|
-
this.items.set(res);
|
|
198
|
-
this._loading.set(false);
|
|
199
|
-
this.selectFirstItem();
|
|
200
|
-
this.adjustValueOnItemsValuePropertyTypeMismatch();
|
|
201
|
-
},
|
|
202
|
-
error: err => {
|
|
203
|
-
this._loading.set(false);
|
|
204
|
-
const error = fromSubscribeError(err, 'DropdownComponentError');
|
|
205
|
-
this.logger.log(error, getErrorLogLevel(error));
|
|
206
|
-
}
|
|
207
|
-
});
|
|
208
|
-
}
|
|
209
|
-
else {
|
|
210
|
-
toObservable(options ?? [])
|
|
211
|
-
.pipe(takeUntilDestroyed(this.destroyRef))
|
|
212
|
-
.subscribe({
|
|
213
|
-
next: qr => {
|
|
214
|
-
this.items.set(qr);
|
|
215
|
-
this._loading.set(false);
|
|
216
|
-
this.selectFirstItem();
|
|
217
|
-
this.adjustValueOnItemsValuePropertyTypeMismatch();
|
|
218
|
-
},
|
|
219
|
-
error: err => {
|
|
220
|
-
this.items.set([]);
|
|
221
|
-
this._loading.set(false);
|
|
222
|
-
const error = fromSubscribeError(err, 'DropdownComponentError');
|
|
223
|
-
this.logger.log(error, getErrorLogLevel(error));
|
|
224
|
-
}
|
|
225
|
-
});
|
|
226
|
-
}
|
|
227
|
-
}
|
|
228
179
|
selectFirstItem() {
|
|
229
180
|
if (this.firstTimeSettingItems && this.items().length > 0 && this.selectFirstItemInput() && !this._value) {
|
|
230
181
|
const optionsValueProperty = this.optionsValueProperty();
|
|
@@ -234,24 +185,57 @@ export class DropdownComponent {
|
|
|
234
185
|
this.propagateValueChange(value);
|
|
235
186
|
}
|
|
236
187
|
}
|
|
188
|
+
transformItems(items) {
|
|
189
|
+
if (this.optionsLabelTranslate()) {
|
|
190
|
+
const translationKeys = items.map(item => (typeof item === 'object' && this.optionsLabelPropertyInit() ? item[this.optionsLabelPropertyInit()] : item));
|
|
191
|
+
if (translationKeys.length === 0) {
|
|
192
|
+
return of([]);
|
|
193
|
+
}
|
|
194
|
+
return this.translate.stream(translationKeys).pipe(map(translations => items.map(item => {
|
|
195
|
+
if (typeof item === 'object' && this.optionsLabelPropertyInit()) {
|
|
196
|
+
const label = item[this.optionsLabelPropertyInit()];
|
|
197
|
+
const translation = translations[label];
|
|
198
|
+
if (translation) {
|
|
199
|
+
return { ...item, [this.optionsLabelProperty()]: translation };
|
|
200
|
+
}
|
|
201
|
+
return { ...item };
|
|
202
|
+
}
|
|
203
|
+
else {
|
|
204
|
+
const translation = translations[item];
|
|
205
|
+
return {
|
|
206
|
+
[this.optionsLabelProperty()]: translation ?? item,
|
|
207
|
+
[this.optionsValueProperty()]: item
|
|
208
|
+
};
|
|
209
|
+
}
|
|
210
|
+
})));
|
|
211
|
+
}
|
|
212
|
+
else {
|
|
213
|
+
return of(items);
|
|
214
|
+
}
|
|
215
|
+
}
|
|
237
216
|
adjustValueOnItemsValuePropertyTypeMismatch(setNgModelValue = false) {
|
|
238
217
|
const optionsValueProp = this.optionsValueProperty();
|
|
239
|
-
if (optionsValueProp &&
|
|
240
|
-
this._value
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
247
|
-
|
|
218
|
+
if (optionsValueProp && this._value != null && this.items().length > 0 && this.items()[0][optionsValueProp] != null) {
|
|
219
|
+
if (Array.isArray(this._value)) {
|
|
220
|
+
if (this._value.length > 0 && typeof this.items()[0][optionsValueProp] !== typeof this._value[0]) {
|
|
221
|
+
const stringValues = this._value.map(v => v.toString());
|
|
222
|
+
const selectedOptions = this.items().filter(i => i[optionsValueProp] != null && stringValues.includes(i[optionsValueProp].toString()));
|
|
223
|
+
if (selectedOptions.length > 0) {
|
|
224
|
+
this.ngModelValue.set(selectedOptions.map(i => i[optionsValueProp]));
|
|
225
|
+
return;
|
|
226
|
+
}
|
|
227
|
+
}
|
|
248
228
|
}
|
|
249
|
-
else if (
|
|
250
|
-
//
|
|
251
|
-
this.
|
|
229
|
+
else if (typeof this.items()[0][optionsValueProp] !== typeof this._value) {
|
|
230
|
+
// types dont match, search and compare by string
|
|
231
|
+
const selectedOption = this.items().find(i => i[optionsValueProp] != null && i[optionsValueProp].toString() === this._value.toString());
|
|
232
|
+
if (selectedOption) {
|
|
233
|
+
this.ngModelValue.set(selectedOption[optionsValueProp]);
|
|
234
|
+
return;
|
|
235
|
+
}
|
|
252
236
|
}
|
|
253
237
|
}
|
|
254
|
-
|
|
238
|
+
if (setNgModelValue) {
|
|
255
239
|
// force write to ngModelValue anyway
|
|
256
240
|
this.ngModelValue.set(this._value);
|
|
257
241
|
}
|
|
@@ -262,10 +246,10 @@ export class DropdownComponent {
|
|
|
262
246
|
this.valueChange.emit(value);
|
|
263
247
|
}
|
|
264
248
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.5", ngImport: i0, type: DropdownComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
265
|
-
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 } }, 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 [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=\"
|
|
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()\"\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 >\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 }); }
|
|
266
250
|
}
|
|
267
251
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.5", ngImport: i0, type: DropdownComponent, decorators: [{
|
|
268
252
|
type: Component,
|
|
269
|
-
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 [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=\"
|
|
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()\"\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 >\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" }]
|
|
270
254
|
}], ctorParameters: () => [] });
|
|
271
|
-
//# 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    OnInit,\n    booleanAttribute,\n    computed,\n    effect,\n    forwardRef,\n    inject,\n    input,\n    output,\n    signal,\n    viewChild\n} from '@angular/core';\nimport {takeUntilDestroyed} 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, of, switchMap} from 'rxjs';\nimport {map} from 'rxjs/operators';\n\nimport {CommonsInternalError, ILookupDataProvider, LoggerService, fromSubscribeError, getErrorLogLevel, toObservable} 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, OnInit {\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>>();\n    public options = input<Observable<Array<any>> | 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\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\n    ngOnInit() {\n        this.setDataProviderAndOptions();\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 setDataProviderAndOptions() {\n        const dataProvider = this.dataProvider();\n        const options = this.options();\n        if (dataProvider) {\n            this._loading.set(true);\n            this.dataProviderService = dataProvider.serviceType ? this.injector.get<any>(dataProvider.serviceType) : null;\n\n            toObservable(dataProvider.lookup({limit: 50}, this.dataProviderService))\n                .pipe(\n                    switchMap(items => {\n                        if (this.optionsLabelTranslate()) {\n                            const translationKeys: string[] = items.map(\n                                item =>\n                                    (typeof item === 'object' && this.optionsLabelPropertyInit()\n                                        ? (item[this.optionsLabelPropertyInit() as keyof object] as string)\n                                        : 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                    takeUntilDestroyed(this.destroyRef)\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._loading.set(false);\n                        const error = fromSubscribeError(err, 'DropdownComponentError');\n                        this.logger.log(error, getErrorLogLevel(error));\n                    }\n                });\n        } else {\n            toObservable(options ?? [])\n                .pipe(takeUntilDestroyed(this.destroyRef))\n                .subscribe({\n                    next: qr => {\n                        this.items.set(qr);\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\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 adjustValueOnItemsValuePropertyTypeMismatch(setNgModelValue = false) {\n        const optionsValueProp = this.optionsValueProperty();\n        if (\n            optionsValueProp &&\n            this._value &&\n            this.items().length > 0 &&\n            this.items()[0][optionsValueProp] != null &&\n            typeof this.items()[0][optionsValueProp] !== typeof this._value\n        ) {\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            } else if (setNgModelValue) {\n                // force write to ngModelValue anyway\n                this.ngModelValue.set(this._value);\n            }\n        } else 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=\"body\">\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"]}
|
|
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>>();\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        >\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"]}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { NgClass } from '@angular/common';
|
|
2
|
+
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, booleanAttribute, effect, forwardRef, inject, input, output } from '@angular/core';
|
|
2
3
|
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
3
|
-
import { FormBuilder, NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';
|
|
4
|
+
import { FormBuilder, FormsModule, NG_VALIDATORS, NG_VALUE_ACCESSOR, ReactiveFormsModule, Validators } from '@angular/forms';
|
|
4
5
|
import { InputNumberModule } from 'primeng/inputnumber';
|
|
5
6
|
import { merge } from 'rxjs';
|
|
6
7
|
import * as i0 from "@angular/core";
|
|
@@ -11,6 +12,11 @@ export const NUMBER_RANGE_VALUE_ACCESSOR = {
|
|
|
11
12
|
useExisting: forwardRef(() => NumberRangeComponent),
|
|
12
13
|
multi: true
|
|
13
14
|
};
|
|
15
|
+
export const NUMBER_RANGE_VALIDATOR = {
|
|
16
|
+
provide: NG_VALIDATORS,
|
|
17
|
+
useExisting: forwardRef(() => NumberRangeComponent),
|
|
18
|
+
multi: true
|
|
19
|
+
};
|
|
14
20
|
export class NumberRangeComponent {
|
|
15
21
|
get fromCtrl() {
|
|
16
22
|
return this.fromToFormControl.get('from');
|
|
@@ -20,23 +26,26 @@ export class NumberRangeComponent {
|
|
|
20
26
|
}
|
|
21
27
|
constructor() {
|
|
22
28
|
this.formBuilder = inject(FormBuilder);
|
|
29
|
+
this.cdr = inject(ChangeDetectorRef);
|
|
23
30
|
this.placeholder = input();
|
|
24
31
|
this.useGrouping = input(true);
|
|
25
32
|
this.minFractionDigits = input();
|
|
26
33
|
this.maxFractionDigits = input();
|
|
34
|
+
this.required = input(false, { transform: booleanAttribute });
|
|
27
35
|
this.disabled = input(false, {
|
|
28
36
|
transform: booleanAttribute
|
|
29
37
|
});
|
|
30
|
-
this.className = input();
|
|
31
38
|
this.keyDown = output();
|
|
32
39
|
this.fromToFormControl = this.formBuilder.group({
|
|
33
|
-
from: [],
|
|
34
|
-
to: []
|
|
40
|
+
from: [null, Validators.required],
|
|
41
|
+
to: [null, Validators.required]
|
|
35
42
|
});
|
|
36
43
|
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
37
44
|
this.onChangeFn = () => { };
|
|
38
45
|
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
39
46
|
this.onTouchedFn = () => { };
|
|
47
|
+
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
48
|
+
this.onValidatorChangeFn = () => { };
|
|
40
49
|
effect(() => {
|
|
41
50
|
this.setDisabledState(this.disabled());
|
|
42
51
|
});
|
|
@@ -72,8 +81,18 @@ export class NumberRangeComponent {
|
|
|
72
81
|
else if (typeof obj === 'string' || typeof obj === 'number') {
|
|
73
82
|
start = this.toNumber(obj);
|
|
74
83
|
}
|
|
75
|
-
this.fromCtrl.setValue(start);
|
|
76
|
-
this.toCtrl.setValue(end);
|
|
84
|
+
this.fromCtrl.setValue(start, { emitEvent: false });
|
|
85
|
+
this.toCtrl.setValue(end, { emitEvent: false });
|
|
86
|
+
}
|
|
87
|
+
validate() {
|
|
88
|
+
if (!this.required())
|
|
89
|
+
return null;
|
|
90
|
+
if (this.fromCtrl.hasError('required') || this.toCtrl.hasError('required')) {
|
|
91
|
+
return {
|
|
92
|
+
required: true
|
|
93
|
+
};
|
|
94
|
+
}
|
|
95
|
+
return null;
|
|
77
96
|
}
|
|
78
97
|
onKeyDown(event) {
|
|
79
98
|
this.keyDown.emit(event);
|
|
@@ -95,12 +114,10 @@ export class NumberRangeComponent {
|
|
|
95
114
|
this.onChangeFn([fromDate, toDate]);
|
|
96
115
|
}
|
|
97
116
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.5", ngImport: i0, type: NumberRangeComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
98
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.0.5", type: NumberRangeComponent, isStandalone: true, selector: "mng-number-range", inputs: { placeholder: { classPropertyName: "placeholder", publicName: "placeholder", isSignal: true, isRequired: false, transformFunction: null }, useGrouping: { classPropertyName: "useGrouping", publicName: "useGrouping", isSignal: true, isRequired: false, transformFunction: null }, minFractionDigits: { classPropertyName: "minFractionDigits", publicName: "minFractionDigits", isSignal: true, isRequired: false, transformFunction: null }, maxFractionDigits: { classPropertyName: "maxFractionDigits", publicName: "maxFractionDigits", isSignal: true, isRequired: false, transformFunction: null },
|
|
117
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.0.5", type: NumberRangeComponent, isStandalone: true, selector: "mng-number-range", inputs: { placeholder: { classPropertyName: "placeholder", publicName: "placeholder", isSignal: true, isRequired: false, transformFunction: null }, useGrouping: { classPropertyName: "useGrouping", publicName: "useGrouping", isSignal: true, isRequired: false, transformFunction: null }, minFractionDigits: { classPropertyName: "minFractionDigits", publicName: "minFractionDigits", isSignal: true, isRequired: false, transformFunction: null }, maxFractionDigits: { classPropertyName: "maxFractionDigits", publicName: "maxFractionDigits", isSignal: true, isRequired: false, transformFunction: null }, required: { classPropertyName: "required", publicName: "required", isSignal: true, isRequired: false, transformFunction: null }, disabled: { classPropertyName: "disabled", publicName: "disabled", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { keyDown: "keyDown" }, providers: [NUMBER_RANGE_VALUE_ACCESSOR, NUMBER_RANGE_VALIDATOR], ngImport: i0, template: "<div class=\"flex gap-2\">\n <p-inputNumber\n [formControl]=\"fromCtrl\"\n [placeholder]=\"placeholder()\"\n [useGrouping]=\"useGrouping()\"\n [minFractionDigits]=\"minFractionDigits()\"\n [maxFractionDigits]=\"maxFractionDigits()\"\n [max]=\"toCtrl.value\"\n (onKeyDown)=\"onKeyDown($event)\"\n (onBlur)=\"onBlur()\" />\n <p-inputNumber\n [formControl]=\"toCtrl\"\n [placeholder]=\"placeholder()\"\n [useGrouping]=\"useGrouping()\"\n [minFractionDigits]=\"minFractionDigits()\"\n [maxFractionDigits]=\"maxFractionDigits()\"\n [min]=\"fromCtrl.value\"\n (onKeyDown)=\"onKeyDown($event)\"\n (onBlur)=\"onBlur()\" />\n</div>\n", dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: InputNumberModule }, { kind: "component", type: i2.InputNumber, selector: "p-inputNumber", inputs: ["showButtons", "format", "buttonLayout", "inputId", "styleClass", "style", "placeholder", "size", "maxlength", "tabindex", "title", "ariaLabelledBy", "ariaLabel", "ariaRequired", "name", "required", "autocomplete", "min", "max", "incrementButtonClass", "decrementButtonClass", "incrementButtonIcon", "decrementButtonIcon", "readonly", "step", "allowEmpty", "locale", "localeMatcher", "mode", "currency", "currencyDisplay", "useGrouping", "variant", "minFractionDigits", "maxFractionDigits", "prefix", "suffix", "inputStyle", "inputStyleClass", "showClear", "autofocus", "disabled"], outputs: ["onInput", "onFocus", "onBlur", "onKeyDown", "onClear"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
99
118
|
}
|
|
100
119
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.5", ngImport: i0, type: NumberRangeComponent, decorators: [{
|
|
101
120
|
type: Component,
|
|
102
|
-
args: [{ standalone: true, selector: 'mng-number-range', providers: [NUMBER_RANGE_VALUE_ACCESSOR], imports: [ReactiveFormsModule, InputNumberModule], changeDetection: ChangeDetectionStrategy.OnPush,
|
|
103
|
-
'[class]': 'className()'
|
|
104
|
-
}, template: "<div class=\"flex gap-2\">\n <p-inputNumber\n [formControl]=\"fromCtrl\"\n [placeholder]=\"placeholder()\"\n [useGrouping]=\"useGrouping()\"\n [minFractionDigits]=\"minFractionDigits()\"\n [maxFractionDigits]=\"maxFractionDigits()\"\n [max]=\"toCtrl.value\"\n (onKeyDown)=\"onKeyDown($event)\"\n (onBlur)=\"onBlur()\" />\n <p-inputNumber\n [formControl]=\"toCtrl\"\n [placeholder]=\"placeholder()\"\n [useGrouping]=\"useGrouping()\"\n [minFractionDigits]=\"minFractionDigits()\"\n [maxFractionDigits]=\"maxFractionDigits()\"\n [min]=\"fromCtrl.value\"\n (onKeyDown)=\"onKeyDown($event)\"\n (onBlur)=\"onBlur()\" />\n</div>\n" }]
|
|
121
|
+
args: [{ standalone: true, selector: 'mng-number-range', providers: [NUMBER_RANGE_VALUE_ACCESSOR, NUMBER_RANGE_VALIDATOR], imports: [FormsModule, ReactiveFormsModule, InputNumberModule, NgClass], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"flex gap-2\">\n <p-inputNumber\n [formControl]=\"fromCtrl\"\n [placeholder]=\"placeholder()\"\n [useGrouping]=\"useGrouping()\"\n [minFractionDigits]=\"minFractionDigits()\"\n [maxFractionDigits]=\"maxFractionDigits()\"\n [max]=\"toCtrl.value\"\n (onKeyDown)=\"onKeyDown($event)\"\n (onBlur)=\"onBlur()\" />\n <p-inputNumber\n [formControl]=\"toCtrl\"\n [placeholder]=\"placeholder()\"\n [useGrouping]=\"useGrouping()\"\n [minFractionDigits]=\"minFractionDigits()\"\n [maxFractionDigits]=\"maxFractionDigits()\"\n [min]=\"fromCtrl.value\"\n (onKeyDown)=\"onKeyDown($event)\"\n (onBlur)=\"onBlur()\" />\n</div>\n" }]
|
|
105
122
|
}], ctorParameters: () => [] });
|
|
106
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"number-range.component.js","sourceRoot":"","sources":["../../../../../form/src/components/number-range/number-range.component.ts","../../../../../form/src/components/number-range/number-range.component.html"],"names":[],"mappings":"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","sourcesContent":["import {ChangeDetectionStrategy, Component, ExistingProvider, booleanAttribute, effect, forwardRef, inject, input, output} from '@angular/core';\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\nimport {ControlValueAccessor, FormBuilder, FormControl, FormGroup, NG_VALUE_ACCESSOR, ReactiveFormsModule} from '@angular/forms';\n\nimport {InputNumberModule} from 'primeng/inputnumber';\nimport {merge} from 'rxjs';\n\nimport {Nullable} from '@mediusinc/mng-commons/core';\n\nexport const NUMBER_RANGE_VALUE_ACCESSOR: ExistingProvider = {\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => NumberRangeComponent),\n    multi: true\n};\n\n@Component({\n    standalone: true,\n    selector: 'mng-number-range',\n    templateUrl: './number-range.component.html',\n    providers: [NUMBER_RANGE_VALUE_ACCESSOR],\n    imports: [ReactiveFormsModule, InputNumberModule],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    host: {\n        '[class]': 'className()'\n    }\n})\nexport class NumberRangeComponent implements ControlValueAccessor {\n    private readonly formBuilder = inject(FormBuilder);\n\n    public placeholder = input<string>();\n    public useGrouping = input<boolean>(true);\n    public minFractionDigits = input<number>();\n    public maxFractionDigits = input<number>();\n    public disabled = input(false, {\n        transform: booleanAttribute\n    });\n    public className = input<string>();\n\n    public keyDown = output<KeyboardEvent>();\n\n    private fromToFormControl: FormGroup = this.formBuilder.group({\n        from: [],\n        to: []\n    });\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    public get fromCtrl() {\n        return this.fromToFormControl.get('from') as FormControl;\n    }\n\n    public get toCtrl() {\n        return this.fromToFormControl.get('to') as FormControl;\n    }\n\n    constructor() {\n        effect(() => {\n            this.setDisabledState(this.disabled());\n        });\n\n        merge(this.fromCtrl.valueChanges, this.toCtrl.valueChanges)\n            .pipe(takeUntilDestroyed())\n            .subscribe(() => this.onValueChange());\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        if (isDisabled && this.fromToFormControl?.enabled) {\n            this.fromToFormControl.disable();\n        } else if (!isDisabled && this.fromToFormControl?.disabled) {\n            this.fromToFormControl.enable();\n        }\n    }\n\n    writeValue(obj: any): void {\n        let start: number | null = null;\n        let end: number | null = null;\n\n        if (Array.isArray(obj)) {\n            if (obj.length > 0 && (typeof obj[0] === 'string' || typeof obj[0] === 'number')) {\n                start = this.toNumber(obj[0]);\n            }\n            if (obj.length > 1 && (typeof obj[1] === 'string' || typeof obj[1] === 'number')) {\n                end = this.toNumber(obj[1]);\n            }\n        } else if (typeof obj === 'string' || typeof obj === 'number') {\n            start = this.toNumber(obj);\n        }\n\n        this.fromCtrl.setValue(start);\n        this.toCtrl.setValue(end);\n    }\n\n    onKeyDown(event: KeyboardEvent) {\n        this.keyDown.emit(event);\n    }\n\n    onBlur() {\n        this.onTouchedFn();\n    }\n\n    private toNumber(val: Nullable<string | number>) {\n        if (val == null || typeof val === 'number') {\n            return val ?? null;\n        }\n        val = val.replaceAll(',', '');\n        const numVal = parseFloat(val);\n        return isNaN(numVal) ? null : numVal;\n    }\n\n    private onValueChange() {\n        const fromDate = this.fromCtrl.value as Date;\n        const toDate = this.toCtrl.value as Date;\n        this.onChangeFn([fromDate, toDate]);\n    }\n}\n","<div class=\"flex gap-2\">\n    <p-inputNumber\n        [formControl]=\"fromCtrl\"\n        [placeholder]=\"placeholder()\"\n        [useGrouping]=\"useGrouping()\"\n        [minFractionDigits]=\"minFractionDigits()\"\n        [maxFractionDigits]=\"maxFractionDigits()\"\n        [max]=\"toCtrl.value\"\n        (onKeyDown)=\"onKeyDown($event)\"\n        (onBlur)=\"onBlur()\" />\n    <p-inputNumber\n        [formControl]=\"toCtrl\"\n        [placeholder]=\"placeholder()\"\n        [useGrouping]=\"useGrouping()\"\n        [minFractionDigits]=\"minFractionDigits()\"\n        [maxFractionDigits]=\"maxFractionDigits()\"\n        [min]=\"fromCtrl.value\"\n        (onKeyDown)=\"onKeyDown($event)\"\n        (onBlur)=\"onBlur()\" />\n</div>\n"]}
|
|
123
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"number-range.component.js","sourceRoot":"","sources":["../../../../../form/src/components/number-range/number-range.component.ts","../../../../../form/src/components/number-range/number-range.component.html"],"names":[],"mappings":"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","sourcesContent":["import {NgClass} from '@angular/common';\nimport {ChangeDetectionStrategy, ChangeDetectorRef, Component, ExistingProvider, booleanAttribute, effect, forwardRef, inject, input, output} from '@angular/core';\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\nimport {\n    ControlValueAccessor,\n    FormBuilder,\n    FormControl,\n    FormGroup,\n    FormsModule,\n    NG_VALIDATORS,\n    NG_VALUE_ACCESSOR,\n    ReactiveFormsModule,\n    ValidationErrors,\n    Validator,\n    Validators\n} from '@angular/forms';\n\nimport {InputNumberModule} from 'primeng/inputnumber';\nimport {merge} from 'rxjs';\n\nimport {Nullable} from '@mediusinc/mng-commons/core';\n\nexport const NUMBER_RANGE_VALUE_ACCESSOR: ExistingProvider = {\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => NumberRangeComponent),\n    multi: true\n};\n\nexport const NUMBER_RANGE_VALIDATOR: ExistingProvider = {\n    provide: NG_VALIDATORS,\n    useExisting: forwardRef(() => NumberRangeComponent),\n    multi: true\n};\n\n@Component({\n    standalone: true,\n    selector: 'mng-number-range',\n    templateUrl: './number-range.component.html',\n    providers: [NUMBER_RANGE_VALUE_ACCESSOR, NUMBER_RANGE_VALIDATOR],\n    imports: [FormsModule, ReactiveFormsModule, InputNumberModule, NgClass],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class NumberRangeComponent implements ControlValueAccessor, Validator {\n    private readonly formBuilder = inject(FormBuilder);\n    private readonly cdr = inject(ChangeDetectorRef);\n\n    public placeholder = input<string>();\n    public useGrouping = input<boolean>(true);\n    public minFractionDigits = input<number>();\n    public maxFractionDigits = input<number>();\n    public required = input(false, {transform: booleanAttribute});\n    public disabled = input(false, {\n        transform: booleanAttribute\n    });\n    public keyDown = output<KeyboardEvent>();\n\n    private fromToFormControl: FormGroup = this.formBuilder.group({\n        from: [null, Validators.required],\n        to: [null, Validators.required]\n    });\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    // eslint-disable-next-line @typescript-eslint/no-empty-function\n    private onValidatorChangeFn: any = () => {};\n\n    public get fromCtrl() {\n        return this.fromToFormControl.get('from') as FormControl;\n    }\n\n    public get toCtrl() {\n        return this.fromToFormControl.get('to') as FormControl;\n    }\n\n    constructor() {\n        effect(() => {\n            this.setDisabledState(this.disabled());\n        });\n\n        merge(this.fromCtrl.valueChanges, this.toCtrl.valueChanges)\n            .pipe(takeUntilDestroyed())\n            .subscribe(() => this.onValueChange());\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        if (isDisabled && this.fromToFormControl?.enabled) {\n            this.fromToFormControl.disable();\n        } else if (!isDisabled && this.fromToFormControl?.disabled) {\n            this.fromToFormControl.enable();\n        }\n    }\n\n    writeValue(obj: any): void {\n        let start: number | null = null;\n        let end: number | null = null;\n\n        if (Array.isArray(obj)) {\n            if (obj.length > 0 && (typeof obj[0] === 'string' || typeof obj[0] === 'number')) {\n                start = this.toNumber(obj[0]);\n            }\n            if (obj.length > 1 && (typeof obj[1] === 'string' || typeof obj[1] === 'number')) {\n                end = this.toNumber(obj[1]);\n            }\n        } else if (typeof obj === 'string' || typeof obj === 'number') {\n            start = this.toNumber(obj);\n        }\n\n        this.fromCtrl.setValue(start, {emitEvent: false});\n        this.toCtrl.setValue(end, {emitEvent: false});\n    }\n\n    validate(): ValidationErrors | null {\n        if (!this.required()) return null;\n\n        if (this.fromCtrl.hasError('required') || this.toCtrl.hasError('required')) {\n            return {\n                required: true\n            };\n        }\n\n        return null;\n    }\n\n    onKeyDown(event: KeyboardEvent) {\n        this.keyDown.emit(event);\n    }\n\n    onBlur() {\n        this.onTouchedFn();\n    }\n\n    private toNumber(val: Nullable<string | number>) {\n        if (val == null || typeof val === 'number') {\n            return val ?? null;\n        }\n        val = val.replaceAll(',', '');\n        const numVal = parseFloat(val);\n        return isNaN(numVal) ? null : numVal;\n    }\n\n    private onValueChange() {\n        const fromDate = this.fromCtrl.value as Date;\n        const toDate = this.toCtrl.value as Date;\n        this.onChangeFn([fromDate, toDate]);\n    }\n}\n","<div class=\"flex gap-2\">\n    <p-inputNumber\n        [formControl]=\"fromCtrl\"\n        [placeholder]=\"placeholder()\"\n        [useGrouping]=\"useGrouping()\"\n        [minFractionDigits]=\"minFractionDigits()\"\n        [maxFractionDigits]=\"maxFractionDigits()\"\n        [max]=\"toCtrl.value\"\n        (onKeyDown)=\"onKeyDown($event)\"\n        (onBlur)=\"onBlur()\" />\n    <p-inputNumber\n        [formControl]=\"toCtrl\"\n        [placeholder]=\"placeholder()\"\n        [useGrouping]=\"useGrouping()\"\n        [minFractionDigits]=\"minFractionDigits()\"\n        [maxFractionDigits]=\"maxFractionDigits()\"\n        [min]=\"fromCtrl.value\"\n        (onKeyDown)=\"onKeyDown($event)\"\n        (onBlur)=\"onBlur()\" />\n</div>\n"]}
|