@mediusinc/mng-commons 4.0.1-rc.0 → 4.1.0-rc.0
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/esm2022/lib/components/action/action.component.mjs +4 -4
- package/esm2022/lib/components/action/editor/action-editor.component.mjs +3 -3
- package/esm2022/lib/components/action/editor/injector-context/action-editor-injector-context.component.mjs +3 -3
- package/esm2022/lib/components/action/localization/data-language-dropdown.component.mjs +3 -3
- package/esm2022/lib/components/action/route/action-route.component.mjs +3 -3
- package/esm2022/lib/components/action/table/action-table.component.mjs +3 -3
- package/esm2022/lib/components/form/autocomplete/autocomplete.component.mjs +162 -161
- package/esm2022/lib/components/form/date-range/date-range.component.mjs +31 -39
- package/esm2022/lib/components/form/dropdown/dropdown.component.mjs +94 -105
- package/esm2022/lib/components/form/editor/form-editor.component.mjs +3 -3
- package/esm2022/lib/components/form/formly/fields/formly-field-action/formly-field-action.component.mjs +3 -3
- package/esm2022/lib/components/form/formly/fields/formly-field-autocomplete/formly-field-autocomplete.component.mjs +4 -4
- package/esm2022/lib/components/form/formly/fields/formly-field-custom/formly-custom-field-base.model.mjs +3 -3
- package/esm2022/lib/components/form/formly/fields/formly-field-custom/formly-field-custom.component.mjs +3 -3
- package/esm2022/lib/components/form/formly/fields/formly-field-dropdown/formly-field-dropdown.component.mjs +3 -3
- package/esm2022/lib/components/form/formly/fields/formly-field-fieldset/formly-field-fieldset.component.mjs +3 -3
- package/esm2022/lib/components/form/formly/fields/formly-field-input/formly-field-input.component.mjs +8 -6
- package/esm2022/lib/components/form/formly/fields/formly-field-label/formly-field-label.component.mjs +3 -3
- package/esm2022/lib/components/form/formly/fields/formly-field-lookup-dialog/formly-field-lookup-dialog.component.mjs +3 -3
- package/esm2022/lib/components/form/formly/fields/formly-field-table-dialog-form/formly-field-table-dialog-form.component.mjs +3 -3
- package/esm2022/lib/components/form/formly/fields/formly-field-table-dialog-multiselect/formly-field-table-dialog-multiselect.component.mjs +3 -3
- package/esm2022/lib/components/form/formly/fields/formly-field-tabs/formly-field-tabs.component.mjs +3 -3
- package/esm2022/lib/components/form/formly/wrappers/formly-field-no-label-wrapper/formly-field-no-label-wrapper.component.mjs +3 -3
- package/esm2022/lib/components/form/formly/wrappers/formly-field-wrapper/formly-field-wrapper.component.mjs +8 -82
- package/esm2022/lib/components/layout/breadcrumb.component.mjs +3 -3
- package/esm2022/lib/components/layout/footer.component.mjs +3 -3
- package/esm2022/lib/components/layout/main-layout.component.mjs +3 -3
- package/esm2022/lib/components/layout/menu-item.component.mjs +4 -4
- package/esm2022/lib/components/layout/menu.component.mjs +3 -3
- package/esm2022/lib/components/layout/services/main-layout.component.service.mjs +3 -3
- package/esm2022/lib/components/layout/topbar-user.component.mjs +3 -3
- package/esm2022/lib/components/layout/topbar.component.mjs +3 -3
- package/esm2022/lib/components/layout/version.component.mjs +3 -3
- package/esm2022/lib/components/layoutV2/breadcrumb.component.mjs +3 -3
- package/esm2022/lib/components/layoutV2/footer.component.mjs +15 -5
- package/esm2022/lib/components/layoutV2/main-layout.component.mjs +3 -3
- package/esm2022/lib/components/layoutV2/menu-item.component.mjs +4 -4
- package/esm2022/lib/components/layoutV2/menu.component.mjs +3 -3
- package/esm2022/lib/components/layoutV2/services/main-layout.component.service.mjs +3 -3
- package/esm2022/lib/components/layoutV2/services/menu.service.mjs +3 -3
- package/esm2022/lib/components/layoutV2/sidebar.component.mjs +5 -6
- package/esm2022/lib/components/layoutV2/topbar-user.component.mjs +3 -3
- package/esm2022/lib/components/layoutV2/topbar.component.mjs +3 -3
- package/esm2022/lib/components/layoutV2/version.component.mjs +3 -3
- package/esm2022/lib/components/notification/notification-wrapper.component.mjs +3 -3
- package/esm2022/lib/components/pages/error/error.page.component.mjs +3 -3
- package/esm2022/lib/components/pages/not-found/not-found.page.component.mjs +4 -4
- package/esm2022/lib/components/table/column-filter-full/column-filter-full.component.mjs +8 -6
- package/esm2022/lib/components/table/column-value/column-value.component.mjs +8 -5
- package/esm2022/lib/components/table/table-column-filter-class/table-column-filter-class.pipe.mjs +3 -3
- package/esm2022/lib/components/table/table.component.mjs +3 -3
- package/esm2022/lib/components/tableview/route/tableview-route.abstract.component.mjs +3 -3
- package/esm2022/lib/components/tableview/route/tableview-route.component.mjs +3 -3
- package/esm2022/lib/components/tableview/tableview.component.mjs +4 -8
- package/esm2022/lib/descriptors/action/action-link.descriptor.mjs +1 -2
- package/esm2022/lib/descriptors/editor/field-base.descriptor.mjs +2 -10
- package/esm2022/lib/descriptors/editor/field-lookup.descriptor.mjs +8 -1
- package/esm2022/lib/descriptors/editor/field.descriptor.mjs +9 -1
- package/esm2022/lib/descriptors/filter/filter.descriptor.mjs +8 -1
- package/esm2022/lib/descriptors/table/column.descriptor.mjs +9 -3
- package/esm2022/lib/descriptors/types/index.mjs +2 -1
- package/esm2022/lib/descriptors/types/trim.type.mjs +2 -0
- package/esm2022/lib/directives/component.directive.mjs +3 -3
- package/esm2022/lib/directives/dialog-keydown-handler.directive.mjs +3 -3
- package/esm2022/lib/directives/index.mjs +2 -1
- package/esm2022/lib/directives/input-trim.directive.mjs +55 -0
- package/esm2022/lib/directives/template.directive.mjs +3 -3
- package/esm2022/lib/models/layout-config.model.mjs +1 -1
- package/esm2022/lib/pipes/boolean.pipe.mjs +3 -3
- package/esm2022/lib/pipes/class-map.pipe.mjs +3 -3
- package/esm2022/lib/pipes/enum.pipe.mjs +3 -3
- package/esm2022/lib/pipes/enumerate-async.pipe.mjs +3 -3
- package/esm2022/lib/pipes/enumerate.pipe.mjs +3 -3
- package/esm2022/lib/pipes/getter.pipe.mjs +3 -3
- package/esm2022/lib/pipes/i18n-property.pipe.mjs +3 -3
- package/esm2022/lib/pipes/json-path.pipe.mjs +3 -3
- package/esm2022/lib/pipes/locale-default-row-class.pipe.mjs +3 -3
- package/esm2022/lib/pipes/parametrize.pipe.mjs +3 -3
- package/esm2022/lib/pipes/template.pipe.mjs +3 -3
- package/esm2022/lib/provide-commons.mjs +3 -2
- package/esm2022/lib/security/authorization.service.mjs +3 -3
- package/esm2022/lib/services/action/component-action-executor.service.mjs +3 -3
- package/esm2022/lib/services/action/root-action-executor.service.mjs +3 -3
- package/esm2022/lib/services/commons-init.service.mjs +7 -6
- package/esm2022/lib/services/commons.service.mjs +3 -3
- package/esm2022/lib/services/internal/commons-init.provider.mjs +3 -3
- package/esm2022/lib/services/mng-localstorage-config.service.mjs +3 -3
- package/esm2022/lib/services/navigation.service.mjs +3 -3
- package/esm2022/lib/services/router.service.mjs +3 -3
- package/esm2022/lib/services/version.service.mjs +3 -3
- package/esm2022/lib/services/view/view-container.service.mjs +3 -3
- package/esm2022/lib/utils/editor-formly.util.mjs +40 -10
- package/fesm2022/mediusinc-mng-commons.mjs +7899 -7879
- package/fesm2022/mediusinc-mng-commons.mjs.map +1 -1
- package/lib/components/form/autocomplete/autocomplete.component.d.ts +24 -22
- package/lib/components/form/date-range/date-range.component.d.ts +12 -15
- package/lib/components/form/dropdown/dropdown.component.d.ts +28 -34
- package/lib/components/form/formly/wrappers/formly-field-wrapper/formly-field-wrapper.component.d.ts +0 -1
- package/lib/components/layoutV2/footer.component.d.ts +5 -1
- package/lib/components/tableview/tableview.component.d.ts +4 -5
- package/lib/descriptors/editor/field-base.descriptor.d.ts +1 -5
- package/lib/descriptors/editor/field-lookup.descriptor.d.ts +4 -1
- package/lib/descriptors/editor/field.descriptor.d.ts +4 -1
- package/lib/descriptors/filter/filter.descriptor.d.ts +4 -1
- package/lib/descriptors/table/column.descriptor.d.ts +3 -1
- package/lib/descriptors/types/index.d.ts +1 -0
- package/lib/descriptors/types/trim.type.d.ts +1 -0
- package/lib/directives/index.d.ts +1 -0
- package/lib/directives/input-trim.directive.d.ts +14 -0
- package/lib/models/layout-config.model.d.ts +1 -0
- package/lib/services/commons-init.service.d.ts +3 -2
- package/lib/services/internal/commons-init.provider.d.ts +2 -1
- package/lib/utils/editor-formly.util.d.ts +1 -0
- package/package.json +8 -8
- package/scss/v2/layout/mng/_mng_layout_footer.scss +6 -0
- package/scss/v2/layout/mng/_mng_layout_topbar.scss +1 -1
- package/scss/v2/theme/theme-base/mng/_mng_theme_datatable.scss +0 -8
- package/scss/v2/theme/theme-base/mng/_mng_theme_dropdown.scss +10 -0
|
@@ -1,11 +1,12 @@
|
|
|
1
1
|
import { AsyncPipe } from '@angular/common';
|
|
2
|
-
import { ChangeDetectionStrategy, Component, EventEmitter, Injector,
|
|
2
|
+
import { ChangeDetectionStrategy, Component, DestroyRef, EventEmitter, Injector, Output, computed, forwardRef, inject, input, signal, viewChild } from '@angular/core';
|
|
3
|
+
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
3
4
|
import { FormControl, NG_VALUE_ACCESSOR, ReactiveFormsModule } from '@angular/forms';
|
|
4
5
|
import { TranslateModule, TranslateService } from '@ngx-translate/core';
|
|
5
6
|
import { Dropdown, DropdownModule } from 'primeng/dropdown';
|
|
6
7
|
import { MultiSelectModule } from 'primeng/multiselect';
|
|
7
|
-
import {
|
|
8
|
-
import {
|
|
8
|
+
import { of, switchMap } from 'rxjs';
|
|
9
|
+
import { map } from 'rxjs/operators';
|
|
9
10
|
import { MediusQueryParamBuilder } from '../../../api/models';
|
|
10
11
|
import { toObservable } from '../../../helpers/coercion';
|
|
11
12
|
import { MngInternalError } from '../../../models';
|
|
@@ -13,86 +14,110 @@ import { MngLoggerService } from '../../../services';
|
|
|
13
14
|
import { ErrorUtil } from '../../../utils';
|
|
14
15
|
import { MngFormlyFieldWrapperComponent } from '../formly/wrappers';
|
|
15
16
|
import * as i0 from "@angular/core";
|
|
16
|
-
import * as i1 from "
|
|
17
|
-
import * as i2 from "
|
|
18
|
-
import * as i3 from "
|
|
19
|
-
import * as i4 from "
|
|
20
|
-
import * as i5 from "@angular/forms";
|
|
17
|
+
import * as i1 from "primeng/dropdown";
|
|
18
|
+
import * as i2 from "primeng/multiselect";
|
|
19
|
+
import * as i3 from "@ngx-translate/core";
|
|
20
|
+
import * as i4 from "@angular/forms";
|
|
21
21
|
export const MNG_DROPDOWN_VALUE_ACCESSOR = {
|
|
22
22
|
provide: NG_VALUE_ACCESSOR,
|
|
23
23
|
useExisting: forwardRef(() => MngDropdownComponent),
|
|
24
24
|
multi: true
|
|
25
25
|
};
|
|
26
26
|
export class MngDropdownComponent {
|
|
27
|
-
constructor(
|
|
28
|
-
this.injector = injector;
|
|
29
|
-
this.translate = translate;
|
|
30
|
-
this.formlyWrapper = formlyWrapper;
|
|
27
|
+
constructor() {
|
|
31
28
|
this.logger = inject(MngLoggerService).create('MngDropdownComponent');
|
|
32
|
-
this.
|
|
33
|
-
this.
|
|
34
|
-
this.
|
|
35
|
-
this.
|
|
36
|
-
this.
|
|
37
|
-
this.
|
|
38
|
-
this
|
|
29
|
+
this.injector = inject(Injector);
|
|
30
|
+
this.destroyRef = inject(DestroyRef);
|
|
31
|
+
this.translate = inject(TranslateService);
|
|
32
|
+
this.formlyWrapper = inject(MngFormlyFieldWrapperComponent, { optional: true });
|
|
33
|
+
this.dropdownFormControl = new FormControl();
|
|
34
|
+
this.dataProvider = input();
|
|
35
|
+
this.optionsTrackProperty = input();
|
|
36
|
+
this.optionsLabelPropertyInit = input(undefined, { alias: 'optionsLabelProperty' });
|
|
37
|
+
this.optionsLabelTranslate = input(false);
|
|
38
|
+
this.optionsValuePropertyInit = input(undefined, { alias: 'optionsValueProperty' });
|
|
39
|
+
this.optionsDisabledProperty = input();
|
|
40
|
+
this.multiselect = input(false);
|
|
41
|
+
this.placeholder = input();
|
|
42
|
+
this.showClear = input(false);
|
|
43
|
+
this.selectFirstItem = input(false);
|
|
44
|
+
this.className = input();
|
|
45
|
+
this.dropdownClassName = input();
|
|
46
|
+
this.changeValueOnBlur = input(false);
|
|
47
|
+
this.loading = signal(false);
|
|
39
48
|
this.valueChangeEventEmitter = new EventEmitter();
|
|
40
|
-
this.
|
|
49
|
+
this.primeDropdown = viewChild(Dropdown);
|
|
41
50
|
this.dataProviderService = null;
|
|
42
51
|
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
43
52
|
this.onTouchedFn = () => { };
|
|
44
|
-
this.
|
|
45
|
-
this.
|
|
46
|
-
this.
|
|
47
|
-
|
|
48
|
-
ngOnInit() {
|
|
49
|
-
this.optionsLabelProperty = this.optionsLabelPropertyInit;
|
|
50
|
-
this.optionsValueProperty = this.optionsValuePropertyInit;
|
|
51
|
-
this.dropdownFormControl.valueChanges.subscribe(v => {
|
|
52
|
-
if (!this.changeValueOnBlur) {
|
|
53
|
-
this.propagateValueChange(v);
|
|
54
|
-
}
|
|
55
|
-
});
|
|
56
|
-
if (this.dataProvider) {
|
|
57
|
-
this.loadingSubject.next(true);
|
|
58
|
-
this.dataProviderService = this.dataProvider.serviceType ? this.injector.get(this.dataProvider.serviceType) : null;
|
|
59
|
-
const queryParamBuilder = MediusQueryParamBuilder.create();
|
|
60
|
-
if (this.optionsLabelTranslate) {
|
|
53
|
+
this.items = signal([]);
|
|
54
|
+
this.firstTimeSettingItems = true;
|
|
55
|
+
this.optionsLabelProperty = computed(() => {
|
|
56
|
+
if (this.optionsLabelTranslate()) {
|
|
61
57
|
// setup translation properties
|
|
62
|
-
if (this.optionsLabelPropertyInit) {
|
|
63
|
-
|
|
58
|
+
if (this.optionsLabelPropertyInit()) {
|
|
59
|
+
return `${this.optionsLabelPropertyInit()}_i18n`;
|
|
64
60
|
}
|
|
65
|
-
else if (!this.
|
|
66
|
-
|
|
67
|
-
this.optionsValueProperty = 'value';
|
|
61
|
+
else if (!this.optionsLabelPropertyInit() && !this.optionsValuePropertyInit()) {
|
|
62
|
+
return 'title_i18n';
|
|
68
63
|
}
|
|
69
64
|
else {
|
|
70
|
-
throw new MngInternalError(`Invalid use with value (${this.
|
|
65
|
+
throw new MngInternalError(`Invalid use with value (${this.optionsValuePropertyInit()}) and label (${this.optionsLabelPropertyInit()}) property setup.`, {
|
|
71
66
|
name: 'MngDropdownComponentError'
|
|
72
67
|
});
|
|
73
68
|
}
|
|
74
69
|
}
|
|
75
|
-
|
|
70
|
+
return this.optionsLabelPropertyInit();
|
|
71
|
+
});
|
|
72
|
+
this.optionsValueProperty = computed(() => {
|
|
73
|
+
if (this.optionsLabelTranslate()) {
|
|
74
|
+
// setup translation properties
|
|
75
|
+
if (!this.optionsLabelPropertyInit() && !this.optionsValuePropertyInit()) {
|
|
76
|
+
return 'value';
|
|
77
|
+
}
|
|
78
|
+
else if (!this.optionsLabelPropertyInit()) {
|
|
79
|
+
throw new MngInternalError(`Invalid use with value (${this.optionsValuePropertyInit()}) and label (${this.optionsLabelPropertyInit()}) property setup.`, {
|
|
80
|
+
name: 'MngDropdownComponentError'
|
|
81
|
+
});
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
return this.optionsValuePropertyInit();
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
ngOnInit() {
|
|
88
|
+
this.dropdownFormControl.valueChanges.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(v => {
|
|
89
|
+
if (!this.changeValueOnBlur()) {
|
|
90
|
+
this.propagateValueChange(v);
|
|
91
|
+
}
|
|
92
|
+
});
|
|
93
|
+
const dataProvider = this.dataProvider();
|
|
94
|
+
if (dataProvider) {
|
|
95
|
+
this.loading.set(true);
|
|
96
|
+
this.dataProviderService = dataProvider.serviceType ? this.injector.get(dataProvider.serviceType) : null;
|
|
97
|
+
const queryParamBuilder = MediusQueryParamBuilder.create();
|
|
98
|
+
toObservable(dataProvider.lookup(queryParamBuilder.build(), this.dataProviderService))
|
|
76
99
|
.pipe(switchMap(items => {
|
|
77
|
-
if (this.optionsLabelTranslate) {
|
|
78
|
-
const translationKeys = items.map(item => (typeof item === 'object' && this.optionsLabelPropertyInit
|
|
100
|
+
if (this.optionsLabelTranslate()) {
|
|
101
|
+
const translationKeys = items.map(item => (typeof item === 'object' && this.optionsLabelPropertyInit()
|
|
102
|
+
? item[this.optionsLabelPropertyInit()]
|
|
103
|
+
: item));
|
|
79
104
|
if (translationKeys.length === 0) {
|
|
80
105
|
return of([]);
|
|
81
106
|
}
|
|
82
107
|
return this.translate.stream(translationKeys).pipe(map(translations => items.map(item => {
|
|
83
|
-
if (typeof item === 'object' && this.optionsLabelPropertyInit) {
|
|
84
|
-
const label = item[this.optionsLabelPropertyInit];
|
|
108
|
+
if (typeof item === 'object' && this.optionsLabelPropertyInit()) {
|
|
109
|
+
const label = item[this.optionsLabelPropertyInit()];
|
|
85
110
|
const translation = translations[label];
|
|
86
111
|
if (translation) {
|
|
87
|
-
return { ...item, [this.optionsLabelProperty]: translation };
|
|
112
|
+
return { ...item, [this.optionsLabelProperty()]: translation };
|
|
88
113
|
}
|
|
89
114
|
return { ...item };
|
|
90
115
|
}
|
|
91
116
|
else {
|
|
92
117
|
const translation = translations[item];
|
|
93
118
|
return {
|
|
94
|
-
[this.optionsLabelProperty]: translation ?? item,
|
|
95
|
-
[this.optionsValueProperty]: item
|
|
119
|
+
[this.optionsLabelProperty()]: translation ?? item,
|
|
120
|
+
[this.optionsValueProperty()]: item
|
|
96
121
|
};
|
|
97
122
|
}
|
|
98
123
|
})));
|
|
@@ -100,11 +125,17 @@ export class MngDropdownComponent {
|
|
|
100
125
|
else {
|
|
101
126
|
return of(items);
|
|
102
127
|
}
|
|
103
|
-
}))
|
|
128
|
+
}), takeUntilDestroyed(this.destroyRef))
|
|
104
129
|
.subscribe({
|
|
105
130
|
next: res => {
|
|
106
|
-
this.
|
|
107
|
-
this.
|
|
131
|
+
this.items.set(res);
|
|
132
|
+
this.loading.set(false);
|
|
133
|
+
if (this.firstTimeSettingItems && this.selectFirstItem() && !this.dropdownFormControl?.value) {
|
|
134
|
+
const optionsValueProperty = this.optionsValueProperty();
|
|
135
|
+
const value = optionsValueProperty ? res[0][optionsValueProperty] : res[0];
|
|
136
|
+
this.dropdownFormControl?.setValue(value);
|
|
137
|
+
this.firstTimeSettingItems = false;
|
|
138
|
+
}
|
|
108
139
|
},
|
|
109
140
|
error: err => {
|
|
110
141
|
const mngError = ErrorUtil.fromSubscribeError(err, 'MngDropdownComponentError', {
|
|
@@ -113,20 +144,11 @@ export class MngDropdownComponent {
|
|
|
113
144
|
this.logger.log(mngError, ErrorUtil.getErrorLogLevel(mngError));
|
|
114
145
|
}
|
|
115
146
|
});
|
|
116
|
-
if (this.selectFirstItem && !this.dropdownFormControl?.value) {
|
|
117
|
-
this.items$.pipe(first()).subscribe(res => {
|
|
118
|
-
const value = this.optionsValueProperty ? res[0][this.optionsValueProperty] : res[0];
|
|
119
|
-
this.dropdownFormControl?.setValue(value);
|
|
120
|
-
});
|
|
121
|
-
}
|
|
122
147
|
}
|
|
123
148
|
else {
|
|
124
149
|
this.logger.debug(`WARNING: Data provider should be provided for MngDropdownComponent.`);
|
|
125
150
|
}
|
|
126
151
|
}
|
|
127
|
-
ngOnDestroy() {
|
|
128
|
-
this.itemsSubscription?.unsubscribe();
|
|
129
|
-
}
|
|
130
152
|
registerOnChange(fn) {
|
|
131
153
|
this.onChangeFn = fn;
|
|
132
154
|
}
|
|
@@ -145,20 +167,20 @@ export class MngDropdownComponent {
|
|
|
145
167
|
// this check is required because angular in some cases writes null value
|
|
146
168
|
// before value accessor is initialized
|
|
147
169
|
// if form control value is of primitive type (ex: enums) then write value is not called (we think)
|
|
148
|
-
if (!this.optionsValuePropertyInit && obj === null && !this.isValueAccessorInitialized()) {
|
|
170
|
+
if (!this.optionsValuePropertyInit() && obj === null && !this.isValueAccessorInitialized()) {
|
|
149
171
|
return;
|
|
150
172
|
}
|
|
151
173
|
this.dropdownFormControl.setValue(obj, { emitEvent: false });
|
|
152
174
|
}
|
|
153
175
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
154
176
|
onDropdownBlur(event) {
|
|
155
|
-
if (this.changeValueOnBlur) {
|
|
177
|
+
if (this.changeValueOnBlur()) {
|
|
156
178
|
this.propagateValueChange(this.dropdownFormControl.value);
|
|
157
179
|
}
|
|
158
180
|
}
|
|
159
181
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
|
160
182
|
onPanelHide(event) {
|
|
161
|
-
if (this.changeValueOnBlur) {
|
|
183
|
+
if (this.changeValueOnBlur()) {
|
|
162
184
|
this.propagateValueChange(this.dropdownFormControl.value);
|
|
163
185
|
}
|
|
164
186
|
}
|
|
@@ -179,47 +201,14 @@ export class MngDropdownComponent {
|
|
|
179
201
|
isValueAccessorInitialized() {
|
|
180
202
|
return typeof this.onChangeFn !== 'undefined';
|
|
181
203
|
}
|
|
182
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.
|
|
183
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.
|
|
204
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: MngDropdownComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
205
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.1", type: MngDropdownComponent, isStandalone: true, selector: "mng-dropdown", inputs: { dataProvider: { classPropertyName: "dataProvider", publicName: "dataProvider", 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 }, optionsValuePropertyInit: { classPropertyName: "optionsValuePropertyInit", 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 }, selectFirstItem: { classPropertyName: "selectFirstItem", 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 } }, outputs: { valueChangeEventEmitter: "valueChange" }, providers: [MNG_DROPDOWN_VALUE_ACCESSOR], viewQueries: [{ propertyName: "primeDropdown", first: true, predicate: Dropdown, descendants: true, isSignal: true }], ngImport: i0, template: "@if (!multiselect()) {\n <p-dropdown\n [formControl]=\"dropdownFormControl\"\n [placeholder]=\"placeholder()\"\n [dataKey]=\"optionsTrackProperty()\"\n [optionLabel]=\"optionsLabelProperty()\"\n [optionValue]=\"optionsValueProperty()\"\n [optionDisabled]=\"optionsDisabledProperty()\"\n [options]=\"items()\"\n [showClear]=\"showClear()\"\n [autoDisplayFirst]=\"false\"\n [styleClass]=\"className()\"\n [panelStyleClass]=\"dropdownClassName()\"\n (onBlur)=\"onDropdownBlur($event)\"\n [dropdownIcon]=\"loading() ? 'pi pi-spinner pi-spin' : 'pi pi-chevron-down'\"\n appendTo=\"body\">\n </p-dropdown>\n} @else {\n <p-multiSelect\n [maxSelectedLabels]=\"1\"\n [selectedItemsLabel]=\"'mngDropdown.multiselectOverMaxDisplayLimit' | translate\"\n [formControl]=\"dropdownFormControl\"\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 (onPanelHide)=\"onPanelHide($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", "filterPlaceholder", "filterLocale", "inputId", "dataKey", "filterBy", "filterFields", "autofocus", "resetFilterOnHide", "dropdownIcon", "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", "appendTo", "dataKey", "name", "ariaLabelledBy", "displaySelectedLabel", "maxSelectedLabels", "selectionLimit", "selectedItemsLabel", "showToggleAll", "emptyFilterMessage", "emptyMessage", "resetFilterOnHide", "dropdownIcon", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "showHeader", "filterBy", "scrollHeight", "lazy", "virtualScroll", "virtualScrollItemSize", "virtualScrollOptions", "overlayOptions", "ariaFilterLabel", "filterMatchMode", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "autofocusFilter", "display", "autocomplete", "showClear", "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: ReactiveFormsModule }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
184
206
|
}
|
|
185
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.
|
|
207
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: MngDropdownComponent, decorators: [{
|
|
186
208
|
type: Component,
|
|
187
|
-
args: [{ standalone: true, selector: 'mng-dropdown', providers: [MNG_DROPDOWN_VALUE_ACCESSOR], imports: [DropdownModule, MultiSelectModule, TranslateModule, AsyncPipe, ReactiveFormsModule], changeDetection: ChangeDetectionStrategy.OnPush, template: "@if (!multiselect) {\n <p-dropdown\n [formControl]=\"dropdownFormControl\"\n [placeholder]=\"placeholder\"\n [dataKey]=\"optionsTrackProperty\"\n [optionLabel]=\"optionsLabelProperty\"\n [optionValue]=\"optionsValueProperty\"\n [optionDisabled]=\"optionsDisabledProperty\"\n [options]=\"(
|
|
188
|
-
}],
|
|
189
|
-
type: Optional
|
|
190
|
-
}] }], propDecorators: { dataProvider: [{
|
|
191
|
-
type: Input
|
|
192
|
-
}], optionsTrackProperty: [{
|
|
193
|
-
type: Input
|
|
194
|
-
}], optionsLabelPropertyInit: [{
|
|
195
|
-
type: Input,
|
|
196
|
-
args: ['optionsLabelProperty']
|
|
197
|
-
}], optionsLabelTranslate: [{
|
|
198
|
-
type: Input
|
|
199
|
-
}], optionsValuePropertyInit: [{
|
|
200
|
-
type: Input,
|
|
201
|
-
args: ['optionsValueProperty']
|
|
202
|
-
}], optionsDisabledProperty: [{
|
|
203
|
-
type: Input
|
|
204
|
-
}], multiselect: [{
|
|
205
|
-
type: Input
|
|
206
|
-
}], placeholder: [{
|
|
207
|
-
type: Input
|
|
208
|
-
}], showClear: [{
|
|
209
|
-
type: Input
|
|
210
|
-
}], selectFirstItem: [{
|
|
211
|
-
type: Input
|
|
212
|
-
}], className: [{
|
|
213
|
-
type: Input
|
|
214
|
-
}], dropdownClassName: [{
|
|
215
|
-
type: Input
|
|
216
|
-
}], changeValueOnBlur: [{
|
|
217
|
-
type: Input
|
|
218
|
-
}], valueChangeEventEmitter: [{
|
|
209
|
+
args: [{ standalone: true, selector: 'mng-dropdown', providers: [MNG_DROPDOWN_VALUE_ACCESSOR], imports: [DropdownModule, MultiSelectModule, TranslateModule, AsyncPipe, ReactiveFormsModule], changeDetection: ChangeDetectionStrategy.OnPush, template: "@if (!multiselect()) {\n <p-dropdown\n [formControl]=\"dropdownFormControl\"\n [placeholder]=\"placeholder()\"\n [dataKey]=\"optionsTrackProperty()\"\n [optionLabel]=\"optionsLabelProperty()\"\n [optionValue]=\"optionsValueProperty()\"\n [optionDisabled]=\"optionsDisabledProperty()\"\n [options]=\"items()\"\n [showClear]=\"showClear()\"\n [autoDisplayFirst]=\"false\"\n [styleClass]=\"className()\"\n [panelStyleClass]=\"dropdownClassName()\"\n (onBlur)=\"onDropdownBlur($event)\"\n [dropdownIcon]=\"loading() ? 'pi pi-spinner pi-spin' : 'pi pi-chevron-down'\"\n appendTo=\"body\">\n </p-dropdown>\n} @else {\n <p-multiSelect\n [maxSelectedLabels]=\"1\"\n [selectedItemsLabel]=\"'mngDropdown.multiselectOverMaxDisplayLimit' | translate\"\n [formControl]=\"dropdownFormControl\"\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 (onPanelHide)=\"onPanelHide($event)\"\n appendTo=\"body\">\n </p-multiSelect>\n}\n" }]
|
|
210
|
+
}], propDecorators: { valueChangeEventEmitter: [{
|
|
219
211
|
type: Output,
|
|
220
212
|
args: ['valueChange']
|
|
221
|
-
}], primeDropdown: [{
|
|
222
|
-
type: ViewChild,
|
|
223
|
-
args: [Dropdown]
|
|
224
213
|
}] } });
|
|
225
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/form/dropdown/dropdown.component.ts","../../../../../../src/lib/components/form/dropdown/dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AsyncPipe} from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    EventEmitter,\n    ExistingProvider,\n    Injector,\n    Input,\n    OnDestroy,\n    OnInit,\n    Optional,\n    Output,\n    ViewChild,\n    forwardRef,\n    inject\n} from '@angular/core';\nimport {ControlValueAccessor, FormControl, NG_VALUE_ACCESSOR, ReactiveFormsModule} from '@angular/forms';\n\nimport {TranslateModule, TranslateService} from '@ngx-translate/core';\nimport {Dropdown, DropdownModule} from 'primeng/dropdown';\nimport {MultiSelectModule} from 'primeng/multiselect';\nimport {Observable, ReplaySubject, Subject, Subscription, of, switchMap} from 'rxjs';\nimport {first, map} from 'rxjs/operators';\n\nimport {MediusQueryParamBuilder} from '../../../api/models';\nimport {ILookupDataProvider} from '../../../data-providers';\nimport {toObservable} from '../../../helpers/coercion';\nimport {MngInternalError} from '../../../models';\nimport {MngLoggerService} from '../../../services';\nimport {ErrorUtil} from '../../../utils';\nimport {MngFormlyFieldWrapperComponent} from '../formly/wrappers';\n\nexport const MNG_DROPDOWN_VALUE_ACCESSOR: ExistingProvider = {\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => MngDropdownComponent),\n    multi: true\n};\n\n@Component({\n    standalone: true,\n    selector: 'mng-dropdown',\n    templateUrl: './dropdown.component.html',\n    providers: [MNG_DROPDOWN_VALUE_ACCESSOR],\n    imports: [DropdownModule, MultiSelectModule, TranslateModule, AsyncPipe, ReactiveFormsModule],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class MngDropdownComponent implements OnInit, OnDestroy, ControlValueAccessor {\n    private readonly logger = inject(MngLoggerService).create('MngDropdownComponent');\n\n    @Input() public dataProvider?: ILookupDataProvider<any, any>;\n    @Input() public optionsTrackProperty?: string;\n    @Input('optionsLabelProperty') public optionsLabelPropertyInit?: string;\n    @Input() public optionsLabelTranslate = false;\n    @Input('optionsValueProperty') public optionsValuePropertyInit?: string;\n    @Input() public optionsDisabledProperty?: string;\n    @Input() public multiselect = false;\n    @Input() public placeholder?: string;\n    @Input() public showClear = true;\n    @Input() public selectFirstItem = false;\n    @Input() public className?: string;\n    @Input() public dropdownClassName?: string;\n    @Input() public changeValueOnBlur = false;\n\n    private loadingSubject = new ReplaySubject<boolean>(1);\n    public $loading: Observable<boolean> = this.loadingSubject.asObservable();\n\n    @Output('valueChange') public valueChangeEventEmitter = new EventEmitter();\n\n    @ViewChild(Dropdown) public primeDropdown?: Dropdown;\n\n    public optionsLabelProperty?: string;\n    public optionsValueProperty?: string;\n    private optionsSubject: Subject<Array<any>> = new ReplaySubject<Array<any>>(1);\n    private dataProviderService: any = null;\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 dropdownFormControl: FormControl = new FormControl();\n    public items$: Observable<Array<any>> = this.optionsSubject.asObservable();\n    private itemsSubscription?: Subscription;\n\n    constructor(\n        private injector: Injector,\n        private translate: TranslateService,\n        @Optional() private formlyWrapper: MngFormlyFieldWrapperComponent\n    ) {\n        this.loadingSubject.next(false);\n    }\n\n    ngOnInit(): void {\n        this.optionsLabelProperty = this.optionsLabelPropertyInit;\n        this.optionsValueProperty = this.optionsValuePropertyInit;\n\n        this.dropdownFormControl.valueChanges.subscribe(v => {\n            if (!this.changeValueOnBlur) {\n                this.propagateValueChange(v);\n            }\n        });\n\n        if (this.dataProvider) {\n            this.loadingSubject.next(true);\n            this.dataProviderService = this.dataProvider.serviceType ? this.injector.get<any>(this.dataProvider.serviceType) : null;\n\n            const queryParamBuilder = MediusQueryParamBuilder.create();\n\n            if (this.optionsLabelTranslate) {\n                // setup translation properties\n                if (this.optionsLabelPropertyInit) {\n                    this.optionsLabelProperty = `${this.optionsLabelPropertyInit}_i18n`;\n                } else if (!this.optionsLabelProperty && !this.optionsValuePropertyInit) {\n                    this.optionsLabelProperty = 'title_i18n';\n                    this.optionsValueProperty = 'value';\n                } else {\n                    throw new MngInternalError(`Invalid use with value (${this.optionsLabelPropertyInit}) and label (${this.optionsLabelPropertyInit}) property setup.`, {\n                        name: 'MngDropdownComponentError'\n                    });\n                }\n            }\n\n            this.itemsSubscription = toObservable(this.dataProvider.lookup(queryParamBuilder.build(), 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 ? (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                .subscribe({\n                    next: res => {\n                        this.optionsSubject.next(res);\n                        this.loadingSubject.next(false);\n                    },\n                    error: err => {\n                        const mngError = ErrorUtil.fromSubscribeError(err, 'MngDropdownComponentError', {\n                            queryParam: queryParamBuilder.build()\n                        });\n                        this.logger.log(mngError, ErrorUtil.getErrorLogLevel(mngError));\n                    }\n                });\n\n            if (this.selectFirstItem && !this.dropdownFormControl?.value) {\n                this.items$.pipe(first()).subscribe(res => {\n                    const value = this.optionsValueProperty ? res[0][this.optionsValueProperty] : res[0];\n                    this.dropdownFormControl?.setValue(value);\n                });\n            }\n        } else {\n            this.logger.debug(`WARNING: Data provider should be provided for MngDropdownComponent.`);\n        }\n    }\n\n    ngOnDestroy() {\n        this.itemsSubscription?.unsubscribe();\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) {\n            this.dropdownFormControl.disable();\n        } else {\n            this.dropdownFormControl.enable();\n        }\n    }\n\n    writeValue(obj: 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 (!this.optionsValuePropertyInit && obj === null && !this.isValueAccessorInitialized()) {\n            return;\n        }\n        this.dropdownFormControl.setValue(obj, {emitEvent: false});\n    }\n\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    onDropdownBlur(event: any) {\n        if (this.changeValueOnBlur) {\n            this.propagateValueChange(this.dropdownFormControl.value);\n        }\n    }\n\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    onPanelHide(event: any) {\n        if (this.changeValueOnBlur) {\n            this.propagateValueChange(this.dropdownFormControl.value);\n        }\n    }\n\n    private propagateValueChange(value: any) {\n        if (!this.isValueAccessorInitialized()) {\n            return;\n        }\n\n        this.formlyWrapper?.formControl?.markAsTouched();\n\n        this.onChangeFn(value);\n        this.valueChangeEventEmitter.next(value);\n    }\n\n    /**\n     * Prevents executions for writing and outputting value which is sometimes committed as null in cmp initialization stage.\n     * In dropdown (from ang. 15 and switch to standalone cmp) null value was always committed to dropdown even if default value was set (using ngModel or formControl) which is incorrect.\n     * Github issue: https://github.com/angular/angular/issues/14988\n     * @private\n     */\n    private isValueAccessorInitialized() {\n        return typeof this.onChangeFn !== 'undefined';\n    }\n}\n","@if (!multiselect) {\n    <p-dropdown\n        [formControl]=\"dropdownFormControl\"\n        [placeholder]=\"placeholder\"\n        [dataKey]=\"optionsTrackProperty\"\n        [optionLabel]=\"optionsLabelProperty\"\n        [optionValue]=\"optionsValueProperty\"\n        [optionDisabled]=\"optionsDisabledProperty\"\n        [options]=\"(items$ | async) ?? undefined\"\n        [showClear]=\"showClear\"\n        [autoDisplayFirst]=\"false\"\n        [styleClass]=\"className\"\n        [panelStyleClass]=\"dropdownClassName\"\n        (onBlur)=\"onDropdownBlur($event)\"\n        [dropdownIcon]=\"($loading | async) ?? false ? 'pi pi-spinner pi-spin' : 'pi pi-chevron-down'\"\n        appendTo=\"body\">\n    </p-dropdown>\n} @else {\n    <p-multiSelect\n        [maxSelectedLabels]=\"1\"\n        [selectedItemsLabel]=\"'mngDropdown.multiselectOverMaxDisplayLimit' | translate\"\n        [formControl]=\"dropdownFormControl\"\n        [placeholder]=\"placeholder\"\n        [dataKey]=\"optionsTrackProperty\"\n        [optionLabel]=\"optionsLabelProperty\"\n        [optionValue]=\"optionsValueProperty\"\n        [optionDisabled]=\"optionsDisabledProperty\"\n        [options]=\"(items$ | async) ?? []\"\n        [styleClass]=\"className\"\n        [panelStyleClass]=\"dropdownClassName\"\n        [filter]=\"true\"\n        [showToggleAll]=\"false\"\n        (onPanelHide)=\"onPanelHide($event)\"\n        appendTo=\"body\">\n    </p-multiSelect>\n}\n"]}
|
|
214
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.component.js","sourceRoot":"","sources":["../../../../../../src/lib/components/form/dropdown/dropdown.component.ts","../../../../../../src/lib/components/form/dropdown/dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import {AsyncPipe} from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    DestroyRef,\n    EventEmitter,\n    ExistingProvider,\n    Injector,\n    OnInit,\n    Output,\n    computed,\n    forwardRef,\n    inject,\n    input,\n    signal,\n    viewChild\n} from '@angular/core';\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\nimport {ControlValueAccessor, FormControl, NG_VALUE_ACCESSOR, ReactiveFormsModule} from '@angular/forms';\n\nimport {TranslateModule, TranslateService} from '@ngx-translate/core';\nimport {Dropdown, DropdownModule} from 'primeng/dropdown';\nimport {MultiSelectModule} from 'primeng/multiselect';\nimport {of, switchMap} from 'rxjs';\nimport {map} from 'rxjs/operators';\n\nimport {MediusQueryParamBuilder} from '../../../api/models';\nimport {ILookupDataProvider} from '../../../data-providers';\nimport {toObservable} from '../../../helpers/coercion';\nimport {MngInternalError} from '../../../models';\nimport {MngLoggerService} from '../../../services';\nimport {ErrorUtil} from '../../../utils';\nimport {MngFormlyFieldWrapperComponent} from '../formly/wrappers';\n\nexport const MNG_DROPDOWN_VALUE_ACCESSOR: ExistingProvider = {\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => MngDropdownComponent),\n    multi: true\n};\n\n@Component({\n    standalone: true,\n    selector: 'mng-dropdown',\n    templateUrl: './dropdown.component.html',\n    providers: [MNG_DROPDOWN_VALUE_ACCESSOR],\n    imports: [DropdownModule, MultiSelectModule, TranslateModule, AsyncPipe, ReactiveFormsModule],\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class MngDropdownComponent implements OnInit, ControlValueAccessor {\n    private readonly logger = inject(MngLoggerService).create('MngDropdownComponent');\n\n    private readonly injector = inject(Injector);\n    private readonly destroyRef = inject(DestroyRef);\n    private readonly translate = inject(TranslateService);\n    private readonly formlyWrapper = inject(MngFormlyFieldWrapperComponent, {optional: true});\n\n    public readonly dropdownFormControl: FormControl = new FormControl();\n\n    public dataProvider = input<ILookupDataProvider<any, any>>();\n    public optionsTrackProperty = input<string>();\n    public optionsLabelPropertyInit = input<string | undefined>(undefined, {alias: 'optionsLabelProperty'});\n    public optionsLabelTranslate = input<boolean>(false);\n    public optionsValuePropertyInit = input<string | undefined>(undefined, {alias: 'optionsValueProperty'});\n    public optionsDisabledProperty = input<string>();\n    public multiselect = input<boolean>(false);\n    public placeholder = input<string>();\n    public showClear = input<boolean>(false);\n    public selectFirstItem = input<boolean>(false);\n    public className = input<string>();\n    public dropdownClassName = input<string>();\n    public changeValueOnBlur = input<boolean>(false);\n\n    public loading = signal(false);\n\n    @Output('valueChange') public valueChangeEventEmitter = new EventEmitter();\n\n    public primeDropdown = viewChild(Dropdown);\n\n    private dataProviderService: any = null;\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 items = signal<Array<any>>([]);\n    private firstTimeSettingItems = true;\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.optionsValuePropertyInit()) {\n                return 'title_i18n';\n            } else {\n                throw new MngInternalError(`Invalid use with value (${this.optionsValuePropertyInit()}) and label (${this.optionsLabelPropertyInit()}) property setup.`, {\n                    name: 'MngDropdownComponentError'\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.optionsValuePropertyInit()) {\n                return 'value';\n            } else if (!this.optionsLabelPropertyInit()) {\n                throw new MngInternalError(`Invalid use with value (${this.optionsValuePropertyInit()}) and label (${this.optionsLabelPropertyInit()}) property setup.`, {\n                    name: 'MngDropdownComponentError'\n                });\n            }\n        }\n\n        return this.optionsValuePropertyInit();\n    });\n\n    ngOnInit(): void {\n        this.dropdownFormControl.valueChanges.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(v => {\n            if (!this.changeValueOnBlur()) {\n                this.propagateValueChange(v);\n            }\n        });\n\n        const dataProvider = this.dataProvider();\n        if (dataProvider) {\n            this.loading.set(true);\n            this.dataProviderService = dataProvider.serviceType ? this.injector.get<any>(dataProvider.serviceType) : null;\n\n            const queryParamBuilder = MediusQueryParamBuilder.create();\n\n            toObservable(dataProvider.lookup(queryParamBuilder.build(), 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\n                        if (this.firstTimeSettingItems && this.selectFirstItem() && !this.dropdownFormControl?.value) {\n                            const optionsValueProperty = this.optionsValueProperty();\n                            const value = optionsValueProperty ? res[0][optionsValueProperty] : res[0];\n                            this.dropdownFormControl?.setValue(value);\n                            this.firstTimeSettingItems = false;\n                        }\n                    },\n                    error: err => {\n                        const mngError = ErrorUtil.fromSubscribeError(err, 'MngDropdownComponentError', {\n                            queryParam: queryParamBuilder.build()\n                        });\n                        this.logger.log(mngError, ErrorUtil.getErrorLogLevel(mngError));\n                    }\n                });\n        } else {\n            this.logger.debug(`WARNING: Data provider should be provided for MngDropdownComponent.`);\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        if (isDisabled) {\n            this.dropdownFormControl.disable();\n        } else {\n            this.dropdownFormControl.enable();\n        }\n    }\n\n    writeValue(obj: 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 (!this.optionsValuePropertyInit() && obj === null && !this.isValueAccessorInitialized()) {\n            return;\n        }\n        this.dropdownFormControl.setValue(obj, {emitEvent: false});\n    }\n\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    onDropdownBlur(event: any) {\n        if (this.changeValueOnBlur()) {\n            this.propagateValueChange(this.dropdownFormControl.value);\n        }\n    }\n\n    // eslint-disable-next-line @typescript-eslint/no-unused-vars\n    onPanelHide(event: any) {\n        if (this.changeValueOnBlur()) {\n            this.propagateValueChange(this.dropdownFormControl.value);\n        }\n    }\n\n    private propagateValueChange(value: any) {\n        if (!this.isValueAccessorInitialized()) {\n            return;\n        }\n\n        this.formlyWrapper?.formControl?.markAsTouched();\n\n        this.onChangeFn(value);\n        this.valueChangeEventEmitter.next(value);\n    }\n\n    /**\n     * Prevents executions for writing and outputting value which is sometimes committed as null in cmp initialization stage.\n     * In dropdown (from ang. 15 and switch to standalone cmp) null value was always committed to dropdown even if default value was set (using ngModel or formControl) which is incorrect.\n     * Github issue: https://github.com/angular/angular/issues/14988\n     * @private\n     */\n    private isValueAccessorInitialized() {\n        return typeof this.onChangeFn !== 'undefined';\n    }\n}\n","@if (!multiselect()) {\n    <p-dropdown\n        [formControl]=\"dropdownFormControl\"\n        [placeholder]=\"placeholder()\"\n        [dataKey]=\"optionsTrackProperty()\"\n        [optionLabel]=\"optionsLabelProperty()\"\n        [optionValue]=\"optionsValueProperty()\"\n        [optionDisabled]=\"optionsDisabledProperty()\"\n        [options]=\"items()\"\n        [showClear]=\"showClear()\"\n        [autoDisplayFirst]=\"false\"\n        [styleClass]=\"className()\"\n        [panelStyleClass]=\"dropdownClassName()\"\n        (onBlur)=\"onDropdownBlur($event)\"\n        [dropdownIcon]=\"loading() ? 'pi pi-spinner pi-spin' : 'pi pi-chevron-down'\"\n        appendTo=\"body\">\n    </p-dropdown>\n} @else {\n    <p-multiSelect\n        [maxSelectedLabels]=\"1\"\n        [selectedItemsLabel]=\"'mngDropdown.multiselectOverMaxDisplayLimit' | translate\"\n        [formControl]=\"dropdownFormControl\"\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        (onPanelHide)=\"onPanelHide($event)\"\n        appendTo=\"body\">\n    </p-multiSelect>\n}\n"]}
|
|
@@ -254,10 +254,10 @@ export class MngFormEditorComponent {
|
|
|
254
254
|
}
|
|
255
255
|
this.updateFormState();
|
|
256
256
|
}
|
|
257
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.
|
|
258
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.
|
|
257
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: MngFormEditorComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
258
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.1", type: MngFormEditorComponent, isStandalone: true, selector: "mng-form-editor", inputs: { descriptor: "descriptor", submitLoading: "submitLoading", item: "item", isFormDisabled: "isFormDisabled" }, outputs: { formSubmitEventEmitter: "formSubmit" }, queries: [{ propertyName: "templates", predicate: MngTemplateDirective }], viewQueries: [{ propertyName: "submitButtonElementRef", first: true, predicate: ["submitButton"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<form [formGroup]=\"form\" (ngSubmit)=\"onSubmit($event)\">\n <formly-form [form]=\"form\" [fields]=\"formFields\" [options]=\"formOptions\" [model]=\"formModel\"></formly-form>\n <button\n #submitButton\n pButton\n type=\"submit\"\n class=\"hidden\"\n [disabled]=\"form.disabled\"\n [loading]=\"(submitLoading$ | async) ?? false\"\n loadingIcon=\"pi pi-spin pi-spinner\"></button>\n</form>\n<p-messages [value]=\"formMessages\" [enableService]=\"false\"></p-messages>\n", dependencies: [{ kind: "ngmodule", type: FormlyModule }, { kind: "component", type: i1.FormlyForm, selector: "formly-form", inputs: ["form", "model", "fields", "options"], outputs: ["modelChange"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: MessagesModule }, { kind: "component", type: i3.Messages, selector: "p-messages", inputs: ["value", "closable", "style", "styleClass", "enableService", "key", "escape", "severity", "showTransitionOptions", "hideTransitionOptions"], outputs: ["valueChange"] }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "ngmodule", type: ButtonModule }, { kind: "directive", type: i4.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
259
259
|
}
|
|
260
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.
|
|
260
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: MngFormEditorComponent, decorators: [{
|
|
261
261
|
type: Component,
|
|
262
262
|
args: [{ standalone: true, selector: 'mng-form-editor', imports: [FormlyModule, ReactiveFormsModule, MessagesModule, AsyncPipe, ButtonModule], changeDetection: ChangeDetectionStrategy.OnPush, template: "<form [formGroup]=\"form\" (ngSubmit)=\"onSubmit($event)\">\n <formly-form [form]=\"form\" [fields]=\"formFields\" [options]=\"formOptions\" [model]=\"formModel\"></formly-form>\n <button\n #submitButton\n pButton\n type=\"submit\"\n class=\"hidden\"\n [disabled]=\"form.disabled\"\n [loading]=\"(submitLoading$ | async) ?? false\"\n loadingIcon=\"pi pi-spin pi-spinner\"></button>\n</form>\n<p-messages [value]=\"formMessages\" [enableService]=\"false\"></p-messages>\n" }]
|
|
263
263
|
}], propDecorators: { descriptor: [{
|
|
@@ -51,10 +51,10 @@ export class MngFormlyFieldActionComponent extends FieldType {
|
|
|
51
51
|
this.actionMessage = res.message;
|
|
52
52
|
}
|
|
53
53
|
}
|
|
54
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.
|
|
55
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.
|
|
54
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: MngFormlyFieldActionComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
55
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.1", type: MngFormlyFieldActionComponent, isStandalone: true, selector: "mng-formly-field-action", usesInheritance: true, ngImport: i0, template: "<div class=\"flex\">\n <button\n type=\"button\"\n pButton\n pRipple\n [icon]=\"$any(descriptor.button.icon)\"\n [label]=\"$any(descriptor.button.label === null ? null : descriptor.button.label ?? props!.label) | translate\"\n [pTooltip]=\"$any(descriptor.button.tooltip) | translate\"\n [disabled]=\"formControl.disabled\"\n (click)=\"onClick()\"\n [class]=\"buttonClass + (actionMessage ? ' mr-2' : '')\"></button>\n @if (actionMessage) {\n <p-message [text]=\"actionMessage.content\" [severity]=\"actionMessage.severity ?? 'success'\"></p-message>\n }\n</div>\n", dependencies: [{ kind: "ngmodule", type: ButtonModule }, { kind: "directive", type: i1.ButtonDirective, selector: "[pButton]", inputs: ["iconPos", "loadingIcon", "label", "icon", "loading"] }, { kind: "ngmodule", type: RippleModule }, { kind: "directive", type: i2.Ripple, selector: "[pRipple]" }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i3.TranslatePipe, name: "translate" }, { kind: "ngmodule", type: TooltipModule }, { kind: "directive", type: i4.Tooltip, selector: "[pTooltip]", inputs: ["tooltipPosition", "tooltipEvent", "appendTo", "positionStyle", "tooltipStyleClass", "tooltipZIndex", "escape", "showDelay", "hideDelay", "life", "positionTop", "positionLeft", "autoHide", "fitContent", "hideOnEscape", "pTooltip", "tooltipDisabled", "tooltipOptions"] }, { kind: "ngmodule", type: MessageModule }, { kind: "component", type: i5.UIMessage, selector: "p-message", inputs: ["severity", "text", "escape", "style", "styleClass"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
56
56
|
}
|
|
57
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.
|
|
57
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: MngFormlyFieldActionComponent, decorators: [{
|
|
58
58
|
type: Component,
|
|
59
59
|
args: [{ standalone: true, selector: 'mng-formly-field-action', imports: [ButtonModule, RippleModule, TranslateModule, TooltipModule, JsonPipe, MessageModule], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div class=\"flex\">\n <button\n type=\"button\"\n pButton\n pRipple\n [icon]=\"$any(descriptor.button.icon)\"\n [label]=\"$any(descriptor.button.label === null ? null : descriptor.button.label ?? props!.label) | translate\"\n [pTooltip]=\"$any(descriptor.button.tooltip) | translate\"\n [disabled]=\"formControl.disabled\"\n (click)=\"onClick()\"\n [class]=\"buttonClass + (actionMessage ? ' mr-2' : '')\"></button>\n @if (actionMessage) {\n <p-message [text]=\"actionMessage.content\" [severity]=\"actionMessage.severity ?? 'success'\"></p-message>\n }\n</div>\n" }]
|
|
60
60
|
}] });
|
|
@@ -44,11 +44,11 @@ export class MngFormlyFieldAutocompleteComponent extends FieldType {
|
|
|
44
44
|
eventSubtype: MngFormFieldEventComponentSubtype.ON_DESTROY
|
|
45
45
|
});
|
|
46
46
|
}
|
|
47
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.
|
|
48
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.
|
|
47
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: MngFormlyFieldAutocompleteComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
|
|
48
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.1", type: MngFormlyFieldAutocompleteComponent, isStandalone: true, selector: "mng-formly-field-autocomplete", usesInheritance: true, ngImport: i0, template: "<mng-autocomplete\n [id]=\"$any(key)\"\n [formControl]=\"aFormControl\"\n [formlyAttributes]=\"field\"\n [dataProvider]=\"descriptor.dataProvider\"\n [optionsTrackProperty]=\"descriptor.optionsTrackProperty\"\n [optionsLabelProperty]=\"descriptor.optionsLabelProperty\"\n [optionsValueProperty]=\"descriptor.optionsValueProperty\"\n [className]=\"descriptor.inputClassName\"\n [showClear]=\"!props.required\"\n [selectFirst]=\"descriptor.autocompleteSelectFirst ?? false\"\n [autoClear]=\"descriptor.autocompleteAutoClear ?? false\"\n [openOnFocus]=\"descriptor.autocompleteAutoClear ?? true\"\n [inlineSearch]=\"descriptor.autocompleteInlineSearch ?? false\">\n</mng-autocomplete>\n", dependencies: [{ kind: "component", type: MngAutocompleteComponent, selector: "mng-autocomplete", inputs: ["dataProvider", "optionsTrackProperty", "optionsValueProperty", "optionsLabelProperty", "optionsLabelTranslate", "inlineSearch", "openOnFocus", "multiselect", "placeholder", "className", "dropdownClassName", "showClear", "autoClear", "selectFirst", "searchTrim"], outputs: ["valueChange"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "ngmodule", type: FormlyModule }, { kind: "directive", type: i2.ɵFormlyAttributes, selector: "[formlyAttributes]", inputs: ["formlyAttributes", "id"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
49
49
|
}
|
|
50
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.
|
|
50
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: MngFormlyFieldAutocompleteComponent, decorators: [{
|
|
51
51
|
type: Component,
|
|
52
52
|
args: [{ standalone: true, selector: 'mng-formly-field-autocomplete', imports: [MngAutocompleteComponent, ReactiveFormsModule, FormlyModule], changeDetection: ChangeDetectionStrategy.OnPush, template: "<mng-autocomplete\n [id]=\"$any(key)\"\n [formControl]=\"aFormControl\"\n [formlyAttributes]=\"field\"\n [dataProvider]=\"descriptor.dataProvider\"\n [optionsTrackProperty]=\"descriptor.optionsTrackProperty\"\n [optionsLabelProperty]=\"descriptor.optionsLabelProperty\"\n [optionsValueProperty]=\"descriptor.optionsValueProperty\"\n [className]=\"descriptor.inputClassName\"\n [showClear]=\"!props.required\"\n [selectFirst]=\"descriptor.autocompleteSelectFirst ?? false\"\n [autoClear]=\"descriptor.autocompleteAutoClear ?? false\"\n [openOnFocus]=\"descriptor.autocompleteAutoClear ?? true\"\n [inlineSearch]=\"descriptor.autocompleteInlineSearch ?? false\">\n</mng-autocomplete>\n" }]
|
|
53
53
|
}] });
|
|
54
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
54
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybWx5LWZpZWxkLWF1dG9jb21wbGV0ZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvZm9ybS9mb3JtbHkvZmllbGRzL2Zvcm1seS1maWVsZC1hdXRvY29tcGxldGUvZm9ybWx5LWZpZWxkLWF1dG9jb21wbGV0ZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9zcmMvbGliL2NvbXBvbmVudHMvZm9ybS9mb3JtbHkvZmllbGRzL2Zvcm1seS1maWVsZC1hdXRvY29tcGxldGUvZm9ybWx5LWZpZWxkLWF1dG9jb21wbGV0ZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQWdCLHVCQUF1QixFQUFFLFNBQVMsRUFBb0IsTUFBTSxlQUFlLENBQUM7QUFDbkcsT0FBTyxFQUFjLG1CQUFtQixFQUFDLE1BQU0sZ0JBQWdCLENBQUM7QUFFaEUsT0FBTyxFQUFDLFNBQVMsRUFBRSxZQUFZLEVBQUMsTUFBTSxrQkFBa0IsQ0FBQztBQUN6RCxPQUFPLEVBQWUsb0JBQW9CLEVBQUMsTUFBTSxNQUFNLENBQUM7QUFDeEQsT0FBTyxFQUFDLFNBQVMsRUFBQyxNQUFNLGdCQUFnQixDQUFDO0FBR3pDLE9BQU8sRUFBQyx3QkFBd0IsRUFBQyxNQUFNLDhDQUE4QyxDQUFDO0FBQ3RGLE9BQU8sRUFBQyxpQ0FBaUMsRUFBRSx5QkFBeUIsRUFBQyxNQUFNLGlCQUFpQixDQUFDOzs7O0FBVTdGLE1BQU0sT0FBTyxtQ0FBMkMsU0FBUSxTQUErQjtJQVAvRjs7UUFXWSxrQkFBYSxHQUFtQixFQUFFLENBQUM7S0F3QzlDO0lBdENVLFFBQVE7UUFDWCxJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksQ0FBQyxXQUEwQixDQUFDO1FBQ3BELElBQUksQ0FBQyxVQUFVLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxVQUEwQyxDQUFDO1FBQ3hFLElBQUksQ0FBQyxLQUFLLENBQUMsY0FBYyxHQUFHLElBQUksQ0FBQztRQUVqQyx1QkFBdUI7UUFDdkIsSUFBSSxDQUFDLFVBQVUsQ0FBQyxTQUFTLENBQUMseUJBQXlCLENBQUMsa0JBQWtCLEVBQUUsbUNBQW1DLEVBQUUsSUFBSSxFQUFFO1lBQy9HLFlBQVksRUFBRSxpQ0FBaUMsQ0FBQyxPQUFPO1NBQzFELENBQUMsQ0FBQztRQUVILE1BQU0sWUFBWSxHQUFHLElBQUksQ0FBQyxZQUFZLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxLQUFLLENBQUMsRUFBRSxvQkFBb0IsRUFBRSxDQUFDLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxFQUFFO1lBQy9ILElBQUksQ0FBQyxVQUFVLENBQUMsU0FBUyxDQUFDLHlCQUF5QixDQUFDLFdBQVcsRUFBRSxtQ0FBbUMsRUFBRSxJQUFJLEVBQUU7Z0JBQ3hHLEtBQUssRUFBRSxDQUFDO2FBQ1gsQ0FBQyxDQUFDO1lBRUgsSUFBSSxJQUFJLENBQUMsS0FBSyxDQUFDLGVBQWUsQ0FBQyxFQUFFO2dCQUM3QixJQUFJLENBQUMsS0FBSyxDQUFDLGVBQWUsQ0FBQyxDQUFDLElBQUksQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUFDLENBQUM7YUFDOUM7UUFDTCxDQUFDLENBQUMsQ0FBQztRQUNILElBQUksQ0FBQyxhQUFhLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxDQUFDO0lBQzFDLENBQUM7SUFFTSxlQUFlO1FBQ2xCLElBQUksQ0FBQyxVQUFVLENBQUMsU0FBUyxDQUFDLHlCQUF5QixDQUFDLGtCQUFrQixFQUFFLG1DQUFtQyxFQUFFLElBQUksRUFBRTtZQUMvRyxZQUFZLEVBQUUsaUNBQWlDLENBQUMsWUFBWTtTQUMvRCxDQUFDLENBQUM7SUFDUCxDQUFDO0lBRU0sV0FBVztRQUNkLGtEQUFrRDtRQUVsRCxJQUFJLENBQUMsYUFBYSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsRUFBRSxDQUFDLEtBQUssQ0FBQyxXQUFXLEVBQUUsQ0FBQyxDQUFDO1FBRXpELHVCQUF1QjtRQUN2QixJQUFJLENBQUMsVUFBVSxFQUFFLFNBQVMsQ0FBQyx5QkFBeUIsQ0FBQyxrQkFBa0IsRUFBRSxtQ0FBbUMsRUFBRSxJQUFJLEVBQUU7WUFDaEgsWUFBWSxFQUFFLGlDQUFpQyxDQUFDLFVBQVU7U0FDN0QsQ0FBQyxDQUFDO0lBQ1AsQ0FBQzs4R0EzQ1EsbUNBQW1DO2tHQUFuQyxtQ0FBbUMsZ0hDbkJoRCxvdEJBZUEsNENEQ2Msd0JBQXdCLHVXQUFFLG1CQUFtQix5VEFBRSxZQUFZOzsyRkFHNUQsbUNBQW1DO2tCQVAvQyxTQUFTO2lDQUNNLElBQUksWUFDTiwrQkFBK0IsV0FFaEMsQ0FBQyx3QkFBd0IsRUFBRSxtQkFBbUIsRUFBRSxZQUFZLENBQUMsbUJBQ3JELHVCQUF1QixDQUFDLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0FmdGVyVmlld0luaXQsIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIE9uRGVzdHJveSwgT25Jbml0fSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7Rm9ybUNvbnRyb2wsIFJlYWN0aXZlRm9ybXNNb2R1bGV9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcblxuaW1wb3J0IHtGaWVsZFR5cGUsIEZvcm1seU1vZHVsZX0gZnJvbSAnQG5neC1mb3JtbHkvY29yZSc7XG5pbXBvcnQge1N1YnNjcmlwdGlvbiwgZGlzdGluY3RVbnRpbENoYW5nZWR9IGZyb20gJ3J4anMnO1xuaW1wb3J0IHtzdGFydFdpdGh9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcblxuaW1wb3J0IHtGaWVsZExvb2t1cERlc2NyaXB0b3J9IGZyb20gJy4uLy4uLy4uLy4uLy4uL2Rlc2NyaXB0b3JzL2VkaXRvcic7XG5pbXBvcnQge01uZ0F1dG9jb21wbGV0ZUNvbXBvbmVudH0gZnJvbSAnLi4vLi4vLi4vYXV0b2NvbXBsZXRlL2F1dG9jb21wbGV0ZS5jb21wb25lbnQnO1xuaW1wb3J0IHtNbmdGb3JtRmllbGRFdmVudENvbXBvbmVudFN1YnR5cGUsIE1uZ0Zvcm1GaWVsZEV2ZW50VHlwZUVudW19IGZyb20gJy4uLy4uLy4uL21vZGVscyc7XG5pbXBvcnQge01uZ0Zvcm1seUZpZWxkQ29uZmlnfSBmcm9tICcuLi8uLi9tb2RlbHMnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIHNlbGVjdG9yOiAnbW5nLWZvcm1seS1maWVsZC1hdXRvY29tcGxldGUnLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9mb3JtbHktZmllbGQtYXV0b2NvbXBsZXRlLmNvbXBvbmVudC5odG1sJyxcbiAgICBpbXBvcnRzOiBbTW5nQXV0b2NvbXBsZXRlQ29tcG9uZW50LCBSZWFjdGl2ZUZvcm1zTW9kdWxlLCBGb3JtbHlNb2R1bGVdLFxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXG59KVxuZXhwb3J0IGNsYXNzIE1uZ0Zvcm1seUZpZWxkQXV0b2NvbXBsZXRlQ29tcG9uZW50PFQsIEVUPiBleHRlbmRzIEZpZWxkVHlwZTxNbmdGb3JtbHlGaWVsZENvbmZpZz4gaW1wbGVtZW50cyBPbkluaXQsIEFmdGVyVmlld0luaXQsIE9uRGVzdHJveSB7XG4gICAgcHVibGljIGFGb3JtQ29udHJvbCE6IEZvcm1Db250cm9sO1xuICAgIHB1YmxpYyBkZXNjcmlwdG9yITogRmllbGRMb29rdXBEZXNjcmlwdG9yPFQsIEVUPjtcblxuICAgIHByaXZhdGUgc3Vic2NyaXB0aW9uczogU3Vic2NyaXB0aW9uW10gPSBbXTtcblxuICAgIHB1YmxpYyBuZ09uSW5pdCgpIHtcbiAgICAgICAgdGhpcy5hRm9ybUNvbnRyb2wgPSB0aGlzLmZvcm1Db250cm9sIGFzIEZvcm1Db250cm9sO1xuICAgICAgICB0aGlzLmRlc2NyaXB0b3IgPSB0aGlzLnByb3BzLmRlc2NyaXB0b3IgYXMgRmllbGRMb29rdXBEZXNjcmlwdG9yPFQsIEVUPjtcbiAgICAgICAgdGhpcy5wcm9wcy5maWVsZENvbXBvbmVudCA9IHRoaXM7XG5cbiAgICAgICAgLy8gZW1pdCBsaWZlY3ljbGUgZXZlbnRcbiAgICAgICAgdGhpcy5kZXNjcmlwdG9yLm5leHRFdmVudChNbmdGb3JtRmllbGRFdmVudFR5cGVFbnVtLkNvbXBvbmVudExpZmVjeWNsZSwgTW5nRm9ybWx5RmllbGRBdXRvY29tcGxldGVDb21wb25lbnQsIHRoaXMsIHtcbiAgICAgICAgICAgIGV2ZW50U3VidHlwZTogTW5nRm9ybUZpZWxkRXZlbnRDb21wb25lbnRTdWJ0eXBlLk9OX0lOSVRcbiAgICAgICAgfSk7XG5cbiAgICAgICAgY29uc3Qgc3Vic2NyaXB0aW9uID0gdGhpcy5hRm9ybUNvbnRyb2wudmFsdWVDaGFuZ2VzLnBpcGUoc3RhcnRXaXRoKHRoaXMuYUZvcm1Db250cm9sLnZhbHVlKSwgZGlzdGluY3RVbnRpbENoYW5nZWQoKSkuc3Vic2NyaWJlKHYgPT4ge1xuICAgICAgICAgICAgdGhpcy5kZXNjcmlwdG9yLm5leHRFdmVudChNbmdGb3JtRmllbGRFdmVudFR5cGVFbnVtLlZhbHVlQ2hhbmdlLCBNbmdGb3JtbHlGaWVsZEF1dG9jb21wbGV0ZUNvbXBvbmVudCwgdGhpcywge1xuICAgICAgICAgICAgICAgIHZhbHVlOiB2XG4gICAgICAgICAgICB9KTtcblxuICAgICAgICAgICAgaWYgKHRoaXMucHJvcHNbJ29uVmFsdWVDaGFuZ2UnXSkge1xuICAgICAgICAgICAgICAgIHRoaXMucHJvcHNbJ29uVmFsdWVDaGFuZ2UnXSh0aGlzLmZpZWxkLCB2KTtcbiAgICAgICAgICAgIH1cbiAgICAgICAgfSk7XG4gICAgICAgIHRoaXMuc3Vic2NyaXB0aW9ucy5wdXNoKHN1YnNjcmlwdGlvbik7XG4gICAgfVxuXG4gICAgcHVibGljIG5nQWZ0ZXJWaWV3SW5pdCgpIHtcbiAgICAgICAgdGhpcy5kZXNjcmlwdG9yLm5leHRFdmVudChNbmdGb3JtRmllbGRFdmVudFR5cGVFbnVtLkNvbXBvbmVudExpZmVjeWNsZSwgTW5nRm9ybWx5RmllbGRBdXRvY29tcGxldGVDb21wb25lbnQsIHRoaXMsIHtcbiAgICAgICAgICAgIGV2ZW50U3VidHlwZTogTW5nRm9ybUZpZWxkRXZlbnRDb21wb25lbnRTdWJ0eXBlLk9OX1ZJRVdfSU5JVFxuICAgICAgICB9KTtcbiAgICB9XG5cbiAgICBwdWJsaWMgbmdPbkRlc3Ryb3koKSB7XG4gICAgICAgIC8vIHdhcm5pbmc6IGZvcm1seSBjYWxscyBvbiBkZXN0cm95IGJlZm9yZSBvbiBpbml0XG5cbiAgICAgICAgdGhpcy5zdWJzY3JpcHRpb25zLmZvckVhY2godmFsdWUgPT4gdmFsdWUudW5zdWJzY3JpYmUoKSk7XG5cbiAgICAgICAgLy8gZW1pdCBsaWZlY3ljbGUgZXZlbnRcbiAgICAgICAgdGhpcy5kZXNjcmlwdG9yPy5uZXh0RXZlbnQoTW5nRm9ybUZpZWxkRXZlbnRUeXBlRW51bS5Db21wb25lbnRMaWZlY3ljbGUsIE1uZ0Zvcm1seUZpZWxkQXV0b2NvbXBsZXRlQ29tcG9uZW50LCB0aGlzLCB7XG4gICAgICAgICAgICBldmVudFN1YnR5cGU6IE1uZ0Zvcm1GaWVsZEV2ZW50Q29tcG9uZW50U3VidHlwZS5PTl9ERVNUUk9ZXG4gICAgICAgIH0pO1xuICAgIH1cbn1cbiIsIjxtbmctYXV0b2NvbXBsZXRlXG4gICAgW2lkXT1cIiRhbnkoa2V5KVwiXG4gICAgW2Zvcm1Db250cm9sXT1cImFGb3JtQ29udHJvbFwiXG4gICAgW2Zvcm1seUF0dHJpYnV0ZXNdPVwiZmllbGRcIlxuICAgIFtkYXRhUHJvdmlkZXJdPVwiZGVzY3JpcHRvci5kYXRhUHJvdmlkZXJcIlxuICAgIFtvcHRpb25zVHJhY2tQcm9wZXJ0eV09XCJkZXNjcmlwdG9yLm9wdGlvbnNUcmFja1Byb3BlcnR5XCJcbiAgICBbb3B0aW9uc0xhYmVsUHJvcGVydHldPVwiZGVzY3JpcHRvci5vcHRpb25zTGFiZWxQcm9wZXJ0eVwiXG4gICAgW29wdGlvbnNWYWx1ZVByb3BlcnR5XT1cImRlc2NyaXB0b3Iub3B0aW9uc1ZhbHVlUHJvcGVydHlcIlxuICAgIFtjbGFzc05hbWVdPVwiZGVzY3JpcHRvci5pbnB1dENsYXNzTmFtZVwiXG4gICAgW3Nob3dDbGVhcl09XCIhcHJvcHMucmVxdWlyZWRcIlxuICAgIFtzZWxlY3RGaXJzdF09XCJkZXNjcmlwdG9yLmF1dG9jb21wbGV0ZVNlbGVjdEZpcnN0ID8/IGZhbHNlXCJcbiAgICBbYXV0b0NsZWFyXT1cImRlc2NyaXB0b3IuYXV0b2NvbXBsZXRlQXV0b0NsZWFyID8/IGZhbHNlXCJcbiAgICBbb3Blbk9uRm9jdXNdPVwiZGVzY3JpcHRvci5hdXRvY29tcGxldGVBdXRvQ2xlYXIgPz8gdHJ1ZVwiXG4gICAgW2lubGluZVNlYXJjaF09XCJkZXNjcmlwdG9yLmF1dG9jb21wbGV0ZUlubGluZVNlYXJjaCA/PyBmYWxzZVwiPlxuPC9tbmctYXV0b2NvbXBsZXRlPlxuIl19
|
|
@@ -30,10 +30,10 @@ export class AMngFormlyCustomFieldComponent extends FieldType {
|
|
|
30
30
|
get formState() {
|
|
31
31
|
return this._formState;
|
|
32
32
|
}
|
|
33
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.
|
|
34
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.
|
|
33
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: AMngFormlyCustomFieldComponent, deps: null, target: i0.ɵɵFactoryTarget.Directive }); }
|
|
34
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.2.1", type: AMngFormlyCustomFieldComponent, inputs: { field: "field", _model: ["model", "_model"], _form: ["form", "_form"], _options: ["options", "_options"], _key: ["key", "_key"], _formControl: ["formControl", "_formControl"], _props: ["props", "_props"], _showError: ["showError", "_showError"], _id: ["id", "_id"], _formState: ["formState", "_formState"] }, usesInheritance: true, ngImport: i0 }); }
|
|
35
35
|
}
|
|
36
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.
|
|
36
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.1", ngImport: i0, type: AMngFormlyCustomFieldComponent, decorators: [{
|
|
37
37
|
type: Directive
|
|
38
38
|
}], propDecorators: { field: [{
|
|
39
39
|
type: Input,
|