imm-element-ui 2.6.3 → 2.6.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/grid/cell-edit/cell-edit-async-selectField.component.mjs +381 -0
- package/esm2022/lib/grid/cell-edit/index.mjs +3 -2
- package/esm2022/lib/grid/cell-render/async-select-label-renderer.mjs +102 -0
- package/esm2022/lib/grid/cell-utils/async-select-options-cache.service.mjs +20 -0
- package/esm2022/lib/grid/cell-utils/async-select-options.mjs +79 -0
- package/esm2022/lib/grid/grid/grid.component.mjs +6 -3
- package/esm2022/lib/grid/mock-data.mjs +6 -3
- package/esm2022/lib/page-form/page-form.component.mjs +41 -4
- package/esm2022/lib/page-form/page-form.interface.mjs +1 -1
- package/esm2022/lib/page-grid-list/page-grid-list.component.mjs +2 -2
- package/esm2022/lib/row-selector/row-selector.component.mjs +2 -2
- package/esm2022/lib/share/utils.mjs +3 -3
- package/esm2022/public-api.mjs +3 -1
- package/fesm2022/imm-element-ui.mjs +616 -12
- package/fesm2022/imm-element-ui.mjs.map +1 -1
- package/lib/grid/cell-edit/cell-edit-async-selectField.component.d.ts +22 -0
- package/lib/grid/cell-edit/index.d.ts +2 -1
- package/lib/grid/cell-render/async-select-label-renderer.d.ts +19 -0
- package/lib/grid/cell-utils/async-select-options-cache.service.d.ts +7 -0
- package/lib/grid/cell-utils/async-select-options.d.ts +10 -0
- package/lib/grid/grid/grid.component.d.ts +6 -1
- package/lib/grid/mock-data.d.ts +4 -1
- package/lib/page-form/page-form.component.d.ts +5 -0
- package/lib/page-form/page-form.interface.d.ts +3 -0
- package/package.json +1 -1
- package/public-api.d.ts +2 -0
|
@@ -0,0 +1,381 @@
|
|
|
1
|
+
import { Component, ViewChild, ViewContainerRef, inject } from '@angular/core';
|
|
2
|
+
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
3
|
+
import { SelectModule } from 'primeng/select';
|
|
4
|
+
import { MultiSelect } from 'primeng/multiselect';
|
|
5
|
+
import { resolveAsyncSelectOptions } from '../cell-utils/async-select-options';
|
|
6
|
+
import { AsyncSelectOptionsCacheService } from '../cell-utils/async-select-options-cache.service';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
import * as i1 from "@angular/forms";
|
|
9
|
+
import * as i2 from "primeng/select";
|
|
10
|
+
export class CellEditAsyncSelectFieldComponent {
|
|
11
|
+
constructor() {
|
|
12
|
+
this.cacheService = inject(AsyncSelectOptionsCacheService);
|
|
13
|
+
}
|
|
14
|
+
async agInit(params) {
|
|
15
|
+
this.params = params;
|
|
16
|
+
this.params.optionLabel = this.params.optionLabel || 'label';
|
|
17
|
+
this.params.optionValue = this.params.optionValue || 'value';
|
|
18
|
+
const rowValue = this.params.data?.[this.params.colDef.field];
|
|
19
|
+
this.value = this.params.multiple ? this.toValueArray(params.value ?? rowValue) : (params.value ?? rowValue);
|
|
20
|
+
this.setEditorSize(params);
|
|
21
|
+
await this.loadOptions();
|
|
22
|
+
}
|
|
23
|
+
getValue() {
|
|
24
|
+
if (this.params.multiple) {
|
|
25
|
+
return this.toValueString(this.value);
|
|
26
|
+
}
|
|
27
|
+
const value = this.value;
|
|
28
|
+
return value === '' || value == null ? null : value;
|
|
29
|
+
}
|
|
30
|
+
onChange(event) {
|
|
31
|
+
const nameFields = this.params.nameFields || [];
|
|
32
|
+
nameFields.forEach((nameField) => {
|
|
33
|
+
this.updateNameField(nameField, event);
|
|
34
|
+
});
|
|
35
|
+
}
|
|
36
|
+
async loadOptions() {
|
|
37
|
+
const context = this.createContext();
|
|
38
|
+
try {
|
|
39
|
+
this.params.loading = true;
|
|
40
|
+
this.params.options = await resolveAsyncSelectOptions(this.params, context);
|
|
41
|
+
}
|
|
42
|
+
finally {
|
|
43
|
+
this.params.loading = false;
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
createContext() {
|
|
47
|
+
return {
|
|
48
|
+
data: this.params.data,
|
|
49
|
+
value: this.params.multiple ? this.toValueString(this.value) : this.value,
|
|
50
|
+
params: this.params,
|
|
51
|
+
field: this.params.colDef.field,
|
|
52
|
+
colDef: this.params.colDef,
|
|
53
|
+
rowIndex: this.params.node?.rowIndex,
|
|
54
|
+
};
|
|
55
|
+
}
|
|
56
|
+
setEditorSize(params) {
|
|
57
|
+
const cellWidth = params.column.getActualWidth();
|
|
58
|
+
this.params.style = {
|
|
59
|
+
border: 'none',
|
|
60
|
+
boxShadow: 'none',
|
|
61
|
+
width: `${cellWidth}px`,
|
|
62
|
+
background: 'var(--ag-background-color)',
|
|
63
|
+
height: '40px',
|
|
64
|
+
alignItems: 'center',
|
|
65
|
+
...(this.params.style || {}),
|
|
66
|
+
};
|
|
67
|
+
this.params.panelStyle = {
|
|
68
|
+
width: `${cellWidth}px`,
|
|
69
|
+
...(this.params.panelStyle || {}),
|
|
70
|
+
};
|
|
71
|
+
}
|
|
72
|
+
updateNameField(nameField, event) {
|
|
73
|
+
const oldValue = this.params.data[nameField.field];
|
|
74
|
+
const newValue = this.resolveNameFieldValue(nameField, event.value);
|
|
75
|
+
const grid = this.params.grid();
|
|
76
|
+
const e = {
|
|
77
|
+
colDef: nameField,
|
|
78
|
+
oldValue,
|
|
79
|
+
newValue,
|
|
80
|
+
rowIndex: this.params.node.rowIndex,
|
|
81
|
+
data: { id: this.params.data.id },
|
|
82
|
+
};
|
|
83
|
+
grid.cellValueChanged(e);
|
|
84
|
+
this.params.data[nameField.field] = newValue;
|
|
85
|
+
}
|
|
86
|
+
resolveNameFieldValue(nameField, value) {
|
|
87
|
+
const valueField = this.params.optionValue || 'value';
|
|
88
|
+
if (this.params.multiple) {
|
|
89
|
+
const values = this.toValueArray(value);
|
|
90
|
+
return (this.params.options || [])
|
|
91
|
+
.filter((op) => values.some((selectedValue) => selectedValue == op?.[valueField]))
|
|
92
|
+
.map((op) => op?.[nameField.key])
|
|
93
|
+
.filter((item) => item !== undefined && item !== null && item !== '')
|
|
94
|
+
.join(',');
|
|
95
|
+
}
|
|
96
|
+
const item = (this.params.options || []).find((op) => op?.[valueField] === value);
|
|
97
|
+
return item ? item[nameField.key] : null;
|
|
98
|
+
}
|
|
99
|
+
toValueArray(value) {
|
|
100
|
+
if (Array.isArray(value)) {
|
|
101
|
+
return value;
|
|
102
|
+
}
|
|
103
|
+
if (value === '' || value == null) {
|
|
104
|
+
return [];
|
|
105
|
+
}
|
|
106
|
+
return String(value).split(',').filter((item) => item !== '');
|
|
107
|
+
}
|
|
108
|
+
toValueString(value) {
|
|
109
|
+
if (Array.isArray(value)) {
|
|
110
|
+
return value.filter((item) => item !== '' && item != null).join(',');
|
|
111
|
+
}
|
|
112
|
+
if (value === '' || value == null) {
|
|
113
|
+
return '';
|
|
114
|
+
}
|
|
115
|
+
return String(value);
|
|
116
|
+
}
|
|
117
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CellEditAsyncSelectFieldComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
118
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: CellEditAsyncSelectFieldComponent, isStandalone: true, selector: "ng-component", viewQueries: [{ propertyName: "input", first: true, predicate: ["input"], descendants: true, read: ViewContainerRef }], ngImport: i0, template: `
|
|
119
|
+
@if (params.multiple) {
|
|
120
|
+
<p-multiselect
|
|
121
|
+
[(ngModel)]="value"
|
|
122
|
+
[scrollHeight]="params.scrollHeight || '200px'"
|
|
123
|
+
[filter]="params.filter"
|
|
124
|
+
[name]="params.name"
|
|
125
|
+
[options]="params.options"
|
|
126
|
+
[placeholder]="params.placeholder"
|
|
127
|
+
[class]="params.class"
|
|
128
|
+
[style]="params.style"
|
|
129
|
+
[panelStyle]="params.panelStyle"
|
|
130
|
+
[panelStyleClass]="params.panelStyleClass"
|
|
131
|
+
[readonly]="params.readonly"
|
|
132
|
+
[appendTo]="params.appendTo || 'body'"
|
|
133
|
+
[tabindex]="params.tabindex"
|
|
134
|
+
[loadingIcon]="params.loadingIcon"
|
|
135
|
+
[filterPlaceHolder]="params.filterPlaceHolder || params.filterPlaceholder"
|
|
136
|
+
[filterLocale]="params.filterLocale"
|
|
137
|
+
[variant]="params.variant"
|
|
138
|
+
[inputId]="params.inputId"
|
|
139
|
+
[dataKey]="params.dataKey"
|
|
140
|
+
[filterBy]="params.filterBy"
|
|
141
|
+
[filterFields]="params.filterFields"
|
|
142
|
+
[autofocus]="params.autofocus ?? true"
|
|
143
|
+
[resetFilterOnHide]="params.resetFilterOnHide"
|
|
144
|
+
[dropdownIcon]="params.dropdownIcon"
|
|
145
|
+
[loading]="params.loading"
|
|
146
|
+
[optionLabel]="params.optionLabel"
|
|
147
|
+
[optionValue]="params.optionValue"
|
|
148
|
+
[optionDisabled]="params.optionDisabled"
|
|
149
|
+
[optionGroupLabel]="params.optionGroupLabel"
|
|
150
|
+
[optionGroupChildren]="params.optionGroupChildren || 'items'"
|
|
151
|
+
[group]="params.group"
|
|
152
|
+
[showClear]="params.showClear"
|
|
153
|
+
[emptyFilterMessage]="params.emptyFilterMessage"
|
|
154
|
+
[emptyMessage]="params.emptyMessage"
|
|
155
|
+
[lazy]="params.lazy"
|
|
156
|
+
[virtualScroll]="params.virtualScroll"
|
|
157
|
+
[virtualScrollItemSize]="params.virtualScrollItemSize"
|
|
158
|
+
[virtualScrollOptions]="params.virtualScrollOptions"
|
|
159
|
+
[overlayOptions]="params.overlayOptions"
|
|
160
|
+
[size]="params.size"
|
|
161
|
+
[ariaFilterLabel]="params.ariaFilterLabel"
|
|
162
|
+
[ariaLabel]="params.ariaLabel"
|
|
163
|
+
[ariaLabelledBy]="params.ariaLabelledBy"
|
|
164
|
+
[filterMatchMode]="params.filterMatchMode"
|
|
165
|
+
[maxlength]="params.maxlength"
|
|
166
|
+
[tooltip]="params.tooltip"
|
|
167
|
+
[tooltipPosition]="params.tooltipPosition || 'right'"
|
|
168
|
+
[tooltipPositionStyle]="params.tooltipPositionStyle || 'absolute'"
|
|
169
|
+
[tooltipStyleClass]="params.tooltipStyleClass"
|
|
170
|
+
[focusOnHover]="params.focusOnHover == undefined ? true : params.focusOnHover"
|
|
171
|
+
[fluid]="params.fluid == undefined ? true : params.fluid"
|
|
172
|
+
[filterValue]="params.filterValue"
|
|
173
|
+
[display]="params.display ?? 'comma'"
|
|
174
|
+
[displaySelectedLabel]="params.displaySelectedLabel ?? true"
|
|
175
|
+
[maxSelectedLabels]="params.maxSelectedLabels"
|
|
176
|
+
[selectionLimit]="params.selectionLimit"
|
|
177
|
+
[selectedItemsLabel]="params.selectedItemsLabel"
|
|
178
|
+
[showToggleAll]="params.showToggleAll ?? true"
|
|
179
|
+
[showHeader]="params.showHeader ?? true"
|
|
180
|
+
[autofocusFilter]="params.autofocusFilter"
|
|
181
|
+
[selectAll]="params.selectAll ?? null"
|
|
182
|
+
[selectOnFocus]="params.selectOnFocus"
|
|
183
|
+
[autoOptionFocus]="params.autoOptionFocus"
|
|
184
|
+
(onChange)="onChange($event)" />
|
|
185
|
+
} @else {
|
|
186
|
+
<p-select
|
|
187
|
+
[(ngModel)]="value"
|
|
188
|
+
[scrollHeight]="params.scrollHeight || '200px'"
|
|
189
|
+
[filter]="params.filter"
|
|
190
|
+
[name]="params.name"
|
|
191
|
+
[options]="params.options"
|
|
192
|
+
[placeholder]="params.placeholder"
|
|
193
|
+
[class]="params.class"
|
|
194
|
+
[style]="params.style"
|
|
195
|
+
[panelStyle]="params.panelStyle"
|
|
196
|
+
[panelStyleClass]="params.panelStyleClass"
|
|
197
|
+
[readonly]="params.readonly"
|
|
198
|
+
[editable]="params.editable"
|
|
199
|
+
[appendTo]="params.appendTo || 'body'"
|
|
200
|
+
[tabindex]="params.tabindex"
|
|
201
|
+
[loadingIcon]="params.loadingIcon"
|
|
202
|
+
[filterPlaceholder]="params.filterPlaceholder"
|
|
203
|
+
[filterLocale]="params.filterLocale"
|
|
204
|
+
[variant]="params.variant"
|
|
205
|
+
[inputId]="params.inputId"
|
|
206
|
+
[dataKey]="params.dataKey"
|
|
207
|
+
[filterBy]="params.filterBy"
|
|
208
|
+
[filterFields]="params.filterFields"
|
|
209
|
+
[autofocus]="params.autofocus ?? true"
|
|
210
|
+
[resetFilterOnHide]="params.resetFilterOnHide"
|
|
211
|
+
[checkmark]="params.checkmark"
|
|
212
|
+
[dropdownIcon]="params.dropdownIcon"
|
|
213
|
+
[loading]="params.loading"
|
|
214
|
+
[optionLabel]="params.optionLabel"
|
|
215
|
+
[optionValue]="params.optionValue"
|
|
216
|
+
[optionDisabled]="params.optionDisabled"
|
|
217
|
+
[optionGroupLabel]="params.optionGroupLabel"
|
|
218
|
+
[optionGroupChildren]="params.optionGroupChildren || 'items'"
|
|
219
|
+
[group]="params.group"
|
|
220
|
+
[showClear]="params.showClear"
|
|
221
|
+
[emptyFilterMessage]="params.emptyFilterMessage"
|
|
222
|
+
[emptyMessage]="params.emptyMessage"
|
|
223
|
+
[lazy]="params.lazy"
|
|
224
|
+
[virtualScroll]="params.virtualScroll"
|
|
225
|
+
[virtualScrollItemSize]="params.virtualScrollItemSize"
|
|
226
|
+
[virtualScrollOptions]="params.virtualScrollOptions"
|
|
227
|
+
[overlayOptions]="params.overlayOptions"
|
|
228
|
+
[size]="params.size"
|
|
229
|
+
[ariaFilterLabel]="params.ariaFilterLabel"
|
|
230
|
+
[ariaLabel]="params.ariaLabel"
|
|
231
|
+
[ariaLabelledBy]="params.ariaLabelledBy"
|
|
232
|
+
[filterMatchMode]="params.filterMatchMode"
|
|
233
|
+
[maxlength]="params.maxlength"
|
|
234
|
+
[tooltip]="params.tooltip"
|
|
235
|
+
[tooltipPosition]="params.tooltipPosition || 'right'"
|
|
236
|
+
[tooltipPositionStyle]="params.tooltipPositionStyle || 'absolute'"
|
|
237
|
+
[tooltipStyleClass]="params.tooltipStyleClass"
|
|
238
|
+
[focusOnHover]="params.focusOnHover == undefined ? true : params.focusOnHover"
|
|
239
|
+
[fluid]="params.fluid == undefined ? true : params.fluid"
|
|
240
|
+
[filterValue]="params.filterValue"
|
|
241
|
+
(onChange)="onChange($event)" />
|
|
242
|
+
}
|
|
243
|
+
`, isInline: true, dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: ReactiveFormsModule }, { kind: "ngmodule", type: SelectModule }, { kind: "component", type: i2.Select, selector: "p-select", 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", "size", "overlayOptions", "ariaFilterLabel", "ariaLabel", "ariaLabelledBy", "filterMatchMode", "maxlength", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "focusOnHover", "selectOnFocus", "autoOptionFocus", "autofocusFilter", "fluid", "disabled", "itemSize", "autoZIndex", "baseZIndex", "showTransitionOptions", "hideTransitionOptions", "filterValue", "options"], outputs: ["onChange", "onFilter", "onFocus", "onBlur", "onClick", "onShow", "onHide", "onClear", "onLazyLoad"] }, { kind: "component", type: MultiSelect, selector: "p-multiSelect, p-multiselect, p-multi-select", inputs: ["id", "ariaLabel", "style", "styleClass", "panelStyle", "panelStyleClass", "inputId", "disabled", "fluid", "readonly", "group", "filter", "filterPlaceHolder", "filterLocale", "overlayVisible", "tabindex", "variant", "appendTo", "dataKey", "name", "ariaLabelledBy", "displaySelectedLabel", "maxSelectedLabels", "selectionLimit", "selectedItemsLabel", "showToggleAll", "emptyFilterMessage", "emptyMessage", "resetFilterOnHide", "dropdownIcon", "chipIcon", "optionLabel", "optionValue", "optionDisabled", "optionGroupLabel", "optionGroupChildren", "showHeader", "filterBy", "scrollHeight", "lazy", "virtualScroll", "loading", "virtualScrollItemSize", "loadingIcon", "virtualScrollOptions", "overlayOptions", "ariaFilterLabel", "filterMatchMode", "tooltip", "tooltipPosition", "tooltipPositionStyle", "tooltipStyleClass", "autofocusFilter", "display", "autocomplete", "size", "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"] }] }); }
|
|
244
|
+
}
|
|
245
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CellEditAsyncSelectFieldComponent, decorators: [{
|
|
246
|
+
type: Component,
|
|
247
|
+
args: [{
|
|
248
|
+
standalone: true,
|
|
249
|
+
template: `
|
|
250
|
+
@if (params.multiple) {
|
|
251
|
+
<p-multiselect
|
|
252
|
+
[(ngModel)]="value"
|
|
253
|
+
[scrollHeight]="params.scrollHeight || '200px'"
|
|
254
|
+
[filter]="params.filter"
|
|
255
|
+
[name]="params.name"
|
|
256
|
+
[options]="params.options"
|
|
257
|
+
[placeholder]="params.placeholder"
|
|
258
|
+
[class]="params.class"
|
|
259
|
+
[style]="params.style"
|
|
260
|
+
[panelStyle]="params.panelStyle"
|
|
261
|
+
[panelStyleClass]="params.panelStyleClass"
|
|
262
|
+
[readonly]="params.readonly"
|
|
263
|
+
[appendTo]="params.appendTo || 'body'"
|
|
264
|
+
[tabindex]="params.tabindex"
|
|
265
|
+
[loadingIcon]="params.loadingIcon"
|
|
266
|
+
[filterPlaceHolder]="params.filterPlaceHolder || params.filterPlaceholder"
|
|
267
|
+
[filterLocale]="params.filterLocale"
|
|
268
|
+
[variant]="params.variant"
|
|
269
|
+
[inputId]="params.inputId"
|
|
270
|
+
[dataKey]="params.dataKey"
|
|
271
|
+
[filterBy]="params.filterBy"
|
|
272
|
+
[filterFields]="params.filterFields"
|
|
273
|
+
[autofocus]="params.autofocus ?? true"
|
|
274
|
+
[resetFilterOnHide]="params.resetFilterOnHide"
|
|
275
|
+
[dropdownIcon]="params.dropdownIcon"
|
|
276
|
+
[loading]="params.loading"
|
|
277
|
+
[optionLabel]="params.optionLabel"
|
|
278
|
+
[optionValue]="params.optionValue"
|
|
279
|
+
[optionDisabled]="params.optionDisabled"
|
|
280
|
+
[optionGroupLabel]="params.optionGroupLabel"
|
|
281
|
+
[optionGroupChildren]="params.optionGroupChildren || 'items'"
|
|
282
|
+
[group]="params.group"
|
|
283
|
+
[showClear]="params.showClear"
|
|
284
|
+
[emptyFilterMessage]="params.emptyFilterMessage"
|
|
285
|
+
[emptyMessage]="params.emptyMessage"
|
|
286
|
+
[lazy]="params.lazy"
|
|
287
|
+
[virtualScroll]="params.virtualScroll"
|
|
288
|
+
[virtualScrollItemSize]="params.virtualScrollItemSize"
|
|
289
|
+
[virtualScrollOptions]="params.virtualScrollOptions"
|
|
290
|
+
[overlayOptions]="params.overlayOptions"
|
|
291
|
+
[size]="params.size"
|
|
292
|
+
[ariaFilterLabel]="params.ariaFilterLabel"
|
|
293
|
+
[ariaLabel]="params.ariaLabel"
|
|
294
|
+
[ariaLabelledBy]="params.ariaLabelledBy"
|
|
295
|
+
[filterMatchMode]="params.filterMatchMode"
|
|
296
|
+
[maxlength]="params.maxlength"
|
|
297
|
+
[tooltip]="params.tooltip"
|
|
298
|
+
[tooltipPosition]="params.tooltipPosition || 'right'"
|
|
299
|
+
[tooltipPositionStyle]="params.tooltipPositionStyle || 'absolute'"
|
|
300
|
+
[tooltipStyleClass]="params.tooltipStyleClass"
|
|
301
|
+
[focusOnHover]="params.focusOnHover == undefined ? true : params.focusOnHover"
|
|
302
|
+
[fluid]="params.fluid == undefined ? true : params.fluid"
|
|
303
|
+
[filterValue]="params.filterValue"
|
|
304
|
+
[display]="params.display ?? 'comma'"
|
|
305
|
+
[displaySelectedLabel]="params.displaySelectedLabel ?? true"
|
|
306
|
+
[maxSelectedLabels]="params.maxSelectedLabels"
|
|
307
|
+
[selectionLimit]="params.selectionLimit"
|
|
308
|
+
[selectedItemsLabel]="params.selectedItemsLabel"
|
|
309
|
+
[showToggleAll]="params.showToggleAll ?? true"
|
|
310
|
+
[showHeader]="params.showHeader ?? true"
|
|
311
|
+
[autofocusFilter]="params.autofocusFilter"
|
|
312
|
+
[selectAll]="params.selectAll ?? null"
|
|
313
|
+
[selectOnFocus]="params.selectOnFocus"
|
|
314
|
+
[autoOptionFocus]="params.autoOptionFocus"
|
|
315
|
+
(onChange)="onChange($event)" />
|
|
316
|
+
} @else {
|
|
317
|
+
<p-select
|
|
318
|
+
[(ngModel)]="value"
|
|
319
|
+
[scrollHeight]="params.scrollHeight || '200px'"
|
|
320
|
+
[filter]="params.filter"
|
|
321
|
+
[name]="params.name"
|
|
322
|
+
[options]="params.options"
|
|
323
|
+
[placeholder]="params.placeholder"
|
|
324
|
+
[class]="params.class"
|
|
325
|
+
[style]="params.style"
|
|
326
|
+
[panelStyle]="params.panelStyle"
|
|
327
|
+
[panelStyleClass]="params.panelStyleClass"
|
|
328
|
+
[readonly]="params.readonly"
|
|
329
|
+
[editable]="params.editable"
|
|
330
|
+
[appendTo]="params.appendTo || 'body'"
|
|
331
|
+
[tabindex]="params.tabindex"
|
|
332
|
+
[loadingIcon]="params.loadingIcon"
|
|
333
|
+
[filterPlaceholder]="params.filterPlaceholder"
|
|
334
|
+
[filterLocale]="params.filterLocale"
|
|
335
|
+
[variant]="params.variant"
|
|
336
|
+
[inputId]="params.inputId"
|
|
337
|
+
[dataKey]="params.dataKey"
|
|
338
|
+
[filterBy]="params.filterBy"
|
|
339
|
+
[filterFields]="params.filterFields"
|
|
340
|
+
[autofocus]="params.autofocus ?? true"
|
|
341
|
+
[resetFilterOnHide]="params.resetFilterOnHide"
|
|
342
|
+
[checkmark]="params.checkmark"
|
|
343
|
+
[dropdownIcon]="params.dropdownIcon"
|
|
344
|
+
[loading]="params.loading"
|
|
345
|
+
[optionLabel]="params.optionLabel"
|
|
346
|
+
[optionValue]="params.optionValue"
|
|
347
|
+
[optionDisabled]="params.optionDisabled"
|
|
348
|
+
[optionGroupLabel]="params.optionGroupLabel"
|
|
349
|
+
[optionGroupChildren]="params.optionGroupChildren || 'items'"
|
|
350
|
+
[group]="params.group"
|
|
351
|
+
[showClear]="params.showClear"
|
|
352
|
+
[emptyFilterMessage]="params.emptyFilterMessage"
|
|
353
|
+
[emptyMessage]="params.emptyMessage"
|
|
354
|
+
[lazy]="params.lazy"
|
|
355
|
+
[virtualScroll]="params.virtualScroll"
|
|
356
|
+
[virtualScrollItemSize]="params.virtualScrollItemSize"
|
|
357
|
+
[virtualScrollOptions]="params.virtualScrollOptions"
|
|
358
|
+
[overlayOptions]="params.overlayOptions"
|
|
359
|
+
[size]="params.size"
|
|
360
|
+
[ariaFilterLabel]="params.ariaFilterLabel"
|
|
361
|
+
[ariaLabel]="params.ariaLabel"
|
|
362
|
+
[ariaLabelledBy]="params.ariaLabelledBy"
|
|
363
|
+
[filterMatchMode]="params.filterMatchMode"
|
|
364
|
+
[maxlength]="params.maxlength"
|
|
365
|
+
[tooltip]="params.tooltip"
|
|
366
|
+
[tooltipPosition]="params.tooltipPosition || 'right'"
|
|
367
|
+
[tooltipPositionStyle]="params.tooltipPositionStyle || 'absolute'"
|
|
368
|
+
[tooltipStyleClass]="params.tooltipStyleClass"
|
|
369
|
+
[focusOnHover]="params.focusOnHover == undefined ? true : params.focusOnHover"
|
|
370
|
+
[fluid]="params.fluid == undefined ? true : params.fluid"
|
|
371
|
+
[filterValue]="params.filterValue"
|
|
372
|
+
(onChange)="onChange($event)" />
|
|
373
|
+
}
|
|
374
|
+
`,
|
|
375
|
+
imports: [FormsModule, ReactiveFormsModule, SelectModule, MultiSelect],
|
|
376
|
+
}]
|
|
377
|
+
}], propDecorators: { input: [{
|
|
378
|
+
type: ViewChild,
|
|
379
|
+
args: ['input', { read: ViewContainerRef }]
|
|
380
|
+
}] } });
|
|
381
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cell-edit-async-selectField.component.js","sourceRoot":"","sources":["../../../../../../projects/imm-element-ui/src/lib/grid/cell-edit/cell-edit-async-selectField.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, ViewChild, ViewContainerRef, inject } from '@angular/core';\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport type { ICellEditorAngularComp } from 'ag-grid-angular';\nimport type { ICellEditorParams } from 'ag-grid-community';\nimport { SelectModule } from 'primeng/select';\nimport { MultiSelect } from 'primeng/multiselect';\nimport { GridComponent } from '../grid/grid.component';\nimport { AsyncSelectContext, resolveAsyncSelectOptions } from '../cell-utils/async-select-options';\nimport { AsyncSelectOptionsCacheService } from '../cell-utils/async-select-options-cache.service';\n\n@Component({\n\tstandalone: true,\n\ttemplate: `\n\t\t@if (params.multiple) {\n\t\t\t<p-multiselect\n\t\t\t\t[(ngModel)]=\"value\"\n\t\t\t\t[scrollHeight]=\"params.scrollHeight || '200px'\"\n\t\t\t\t[filter]=\"params.filter\"\n\t\t\t\t[name]=\"params.name\"\n\t\t\t\t[options]=\"params.options\"\n\t\t\t\t[placeholder]=\"params.placeholder\"\n\t\t\t\t[class]=\"params.class\"\n\t\t\t\t[style]=\"params.style\"\n\t\t\t\t[panelStyle]=\"params.panelStyle\"\n\t\t\t\t[panelStyleClass]=\"params.panelStyleClass\"\n\t\t\t\t[readonly]=\"params.readonly\"\n\t\t\t\t[appendTo]=\"params.appendTo || 'body'\"\n\t\t\t\t[tabindex]=\"params.tabindex\"\n\t\t\t\t[loadingIcon]=\"params.loadingIcon\"\n\t\t\t\t[filterPlaceHolder]=\"params.filterPlaceHolder || params.filterPlaceholder\"\n\t\t\t\t[filterLocale]=\"params.filterLocale\"\n\t\t\t\t[variant]=\"params.variant\"\n\t\t\t\t[inputId]=\"params.inputId\"\n\t\t\t\t[dataKey]=\"params.dataKey\"\n\t\t\t\t[filterBy]=\"params.filterBy\"\n\t\t\t\t[filterFields]=\"params.filterFields\"\n\t\t\t\t[autofocus]=\"params.autofocus ?? true\"\n\t\t\t\t[resetFilterOnHide]=\"params.resetFilterOnHide\"\n\t\t\t\t[dropdownIcon]=\"params.dropdownIcon\"\n\t\t\t\t[loading]=\"params.loading\"\n\t\t\t\t[optionLabel]=\"params.optionLabel\"\n\t\t\t\t[optionValue]=\"params.optionValue\"\n\t\t\t\t[optionDisabled]=\"params.optionDisabled\"\n\t\t\t\t[optionGroupLabel]=\"params.optionGroupLabel\"\n\t\t\t\t[optionGroupChildren]=\"params.optionGroupChildren || 'items'\"\n\t\t\t\t[group]=\"params.group\"\n\t\t\t\t[showClear]=\"params.showClear\"\n\t\t\t\t[emptyFilterMessage]=\"params.emptyFilterMessage\"\n\t\t\t\t[emptyMessage]=\"params.emptyMessage\"\n\t\t\t\t[lazy]=\"params.lazy\"\n\t\t\t\t[virtualScroll]=\"params.virtualScroll\"\n\t\t\t\t[virtualScrollItemSize]=\"params.virtualScrollItemSize\"\n\t\t\t\t[virtualScrollOptions]=\"params.virtualScrollOptions\"\n\t\t\t\t[overlayOptions]=\"params.overlayOptions\"\n\t\t\t\t[size]=\"params.size\"\n\t\t\t\t[ariaFilterLabel]=\"params.ariaFilterLabel\"\n\t\t\t\t[ariaLabel]=\"params.ariaLabel\"\n\t\t\t\t[ariaLabelledBy]=\"params.ariaLabelledBy\"\n\t\t\t\t[filterMatchMode]=\"params.filterMatchMode\"\n\t\t\t\t[maxlength]=\"params.maxlength\"\n\t\t\t\t[tooltip]=\"params.tooltip\"\n\t\t\t\t[tooltipPosition]=\"params.tooltipPosition || 'right'\"\n\t\t\t\t[tooltipPositionStyle]=\"params.tooltipPositionStyle || 'absolute'\"\n\t\t\t\t[tooltipStyleClass]=\"params.tooltipStyleClass\"\n\t\t\t\t[focusOnHover]=\"params.focusOnHover == undefined ? true : params.focusOnHover\"\n\t\t\t\t[fluid]=\"params.fluid == undefined ? true : params.fluid\"\n\t\t\t\t[filterValue]=\"params.filterValue\"\n\t\t\t\t[display]=\"params.display ?? 'comma'\"\n\t\t\t\t[displaySelectedLabel]=\"params.displaySelectedLabel ?? true\"\n\t\t\t\t[maxSelectedLabels]=\"params.maxSelectedLabels\"\n\t\t\t\t[selectionLimit]=\"params.selectionLimit\"\n\t\t\t\t[selectedItemsLabel]=\"params.selectedItemsLabel\"\n\t\t\t\t[showToggleAll]=\"params.showToggleAll ?? true\"\n\t\t\t\t[showHeader]=\"params.showHeader ?? true\"\n\t\t\t\t[autofocusFilter]=\"params.autofocusFilter\"\n\t\t\t\t[selectAll]=\"params.selectAll ?? null\"\n\t\t\t\t[selectOnFocus]=\"params.selectOnFocus\"\n\t\t\t\t[autoOptionFocus]=\"params.autoOptionFocus\"\n\t\t\t\t(onChange)=\"onChange($event)\" />\n\t\t} @else {\n\t\t\t<p-select\n\t\t\t\t[(ngModel)]=\"value\"\n\t\t\t\t[scrollHeight]=\"params.scrollHeight || '200px'\"\n\t\t\t\t[filter]=\"params.filter\"\n\t\t\t\t[name]=\"params.name\"\n\t\t\t\t[options]=\"params.options\"\n\t\t\t\t[placeholder]=\"params.placeholder\"\n\t\t\t\t[class]=\"params.class\"\n\t\t\t\t[style]=\"params.style\"\n\t\t\t\t[panelStyle]=\"params.panelStyle\"\n\t\t\t\t[panelStyleClass]=\"params.panelStyleClass\"\n\t\t\t\t[readonly]=\"params.readonly\"\n\t\t\t\t[editable]=\"params.editable\"\n\t\t\t\t[appendTo]=\"params.appendTo || 'body'\"\n\t\t\t\t[tabindex]=\"params.tabindex\"\n\t\t\t\t[loadingIcon]=\"params.loadingIcon\"\n\t\t\t\t[filterPlaceholder]=\"params.filterPlaceholder\"\n\t\t\t\t[filterLocale]=\"params.filterLocale\"\n\t\t\t\t[variant]=\"params.variant\"\n\t\t\t\t[inputId]=\"params.inputId\"\n\t\t\t\t[dataKey]=\"params.dataKey\"\n\t\t\t\t[filterBy]=\"params.filterBy\"\n\t\t\t\t[filterFields]=\"params.filterFields\"\n\t\t\t\t[autofocus]=\"params.autofocus ?? true\"\n\t\t\t\t[resetFilterOnHide]=\"params.resetFilterOnHide\"\n\t\t\t\t[checkmark]=\"params.checkmark\"\n\t\t\t\t[dropdownIcon]=\"params.dropdownIcon\"\n\t\t\t\t[loading]=\"params.loading\"\n\t\t\t\t[optionLabel]=\"params.optionLabel\"\n\t\t\t\t[optionValue]=\"params.optionValue\"\n\t\t\t\t[optionDisabled]=\"params.optionDisabled\"\n\t\t\t\t[optionGroupLabel]=\"params.optionGroupLabel\"\n\t\t\t\t[optionGroupChildren]=\"params.optionGroupChildren || 'items'\"\n\t\t\t\t[group]=\"params.group\"\n\t\t\t\t[showClear]=\"params.showClear\"\n\t\t\t\t[emptyFilterMessage]=\"params.emptyFilterMessage\"\n\t\t\t\t[emptyMessage]=\"params.emptyMessage\"\n\t\t\t\t[lazy]=\"params.lazy\"\n\t\t\t\t[virtualScroll]=\"params.virtualScroll\"\n\t\t\t\t[virtualScrollItemSize]=\"params.virtualScrollItemSize\"\n\t\t\t\t[virtualScrollOptions]=\"params.virtualScrollOptions\"\n\t\t\t\t[overlayOptions]=\"params.overlayOptions\"\n\t\t\t\t[size]=\"params.size\"\n\t\t\t\t[ariaFilterLabel]=\"params.ariaFilterLabel\"\n\t\t\t\t[ariaLabel]=\"params.ariaLabel\"\n\t\t\t\t[ariaLabelledBy]=\"params.ariaLabelledBy\"\n\t\t\t\t[filterMatchMode]=\"params.filterMatchMode\"\n\t\t\t\t[maxlength]=\"params.maxlength\"\n\t\t\t\t[tooltip]=\"params.tooltip\"\n\t\t\t\t[tooltipPosition]=\"params.tooltipPosition || 'right'\"\n\t\t\t\t[tooltipPositionStyle]=\"params.tooltipPositionStyle || 'absolute'\"\n\t\t\t\t[tooltipStyleClass]=\"params.tooltipStyleClass\"\n\t\t\t\t[focusOnHover]=\"params.focusOnHover == undefined ? true : params.focusOnHover\"\n\t\t\t\t[fluid]=\"params.fluid == undefined ? true : params.fluid\"\n\t\t\t\t[filterValue]=\"params.filterValue\"\n\t\t\t\t(onChange)=\"onChange($event)\" />\n\t\t}\n\t`,\n\timports: [FormsModule, ReactiveFormsModule, SelectModule, MultiSelect],\n})\nexport class CellEditAsyncSelectFieldComponent implements ICellEditorAngularComp {\n\tparams!: any;\n\tvalue: any;\n\tprivate readonly cacheService = inject(AsyncSelectOptionsCacheService);\n\n\t@ViewChild('input', { read: ViewContainerRef }) public input!: ViewContainerRef;\n\n\tasync agInit(params: ICellEditorParams): Promise<void> {\n\t\tthis.params = params;\n\t\tthis.params.optionLabel = this.params.optionLabel || 'label';\n\t\tthis.params.optionValue = this.params.optionValue || 'value';\n\t\tconst rowValue = this.params.data?.[this.params.colDef.field!];\n\t\tthis.value = this.params.multiple ? this.toValueArray(params.value ?? rowValue) : (params.value ?? rowValue);\n\n\t\tthis.setEditorSize(params);\n\t\tawait this.loadOptions();\n\t}\n\n\tgetValue(): any {\n\t\tif (this.params.multiple) {\n\t\t\treturn this.toValueString(this.value);\n\t\t}\n\t\tconst value = this.value;\n\t\treturn value === '' || value == null ? null : value;\n\t}\n\n\tonChange(event: any) {\n\t\tconst nameFields = this.params.nameFields || [];\n\t\tnameFields.forEach((nameField: any) => {\n\t\t\tthis.updateNameField(nameField, event);\n\t\t});\n\t}\n\n\tprivate async loadOptions() {\n\t\tconst context = this.createContext();\n\n\t\ttry {\n\t\t\tthis.params.loading = true;\n\t\t\tthis.params.options = await resolveAsyncSelectOptions(this.params, context);\n\t\t} finally {\n\t\t\tthis.params.loading = false;\n\t\t}\n\t}\n\n\tprivate createContext(): AsyncSelectContext {\n\t\treturn {\n\t\t\tdata: this.params.data,\n\t\t\tvalue: this.params.multiple ? this.toValueString(this.value) : this.value,\n\t\t\tparams: this.params,\n\t\t\tfield: this.params.colDef.field,\n\t\t\tcolDef: this.params.colDef,\n\t\t\trowIndex: this.params.node?.rowIndex,\n\t\t};\n\t}\n\n\tprivate setEditorSize(params: ICellEditorParams) {\n\t\tconst cellWidth = params.column.getActualWidth();\n\t\tthis.params.style = {\n\t\t\tborder: 'none',\n\t\t\tboxShadow: 'none',\n\t\t\twidth: `${cellWidth}px`,\n\t\t\tbackground: 'var(--ag-background-color)',\n\t\t\theight: '40px',\n\t\t\talignItems: 'center',\n\t\t\t...(this.params.style || {}),\n\t\t};\n\t\tthis.params.panelStyle = {\n\t\t\twidth: `${cellWidth}px`,\n\t\t\t...(this.params.panelStyle || {}),\n\t\t};\n\t}\n\n\tprivate updateNameField(nameField: any, event: any) {\n\t\tconst oldValue = this.params.data[nameField.field];\n\t\tconst newValue = this.resolveNameFieldValue(nameField, event.value);\n\t\tconst grid: GridComponent = this.params.grid();\n\t\tconst e: any = {\n\t\t\tcolDef: nameField,\n\t\t\toldValue,\n\t\t\tnewValue,\n\t\t\trowIndex: this.params.node.rowIndex,\n\t\t\tdata: { id: this.params.data.id },\n\t\t};\n\t\tgrid.cellValueChanged(e);\n\t\tthis.params.data[nameField.field] = newValue;\n\t}\n\n\tprivate resolveNameFieldValue(nameField: any, value: any) {\n\t\tconst valueField = this.params.optionValue || 'value';\n\t\tif (this.params.multiple) {\n\t\t\tconst values = this.toValueArray(value);\n\t\t\treturn (this.params.options || [])\n\t\t\t\t.filter((op: any) => values.some((selectedValue: any) => selectedValue == op?.[valueField]))\n\t\t\t\t.map((op: any) => op?.[nameField.key])\n\t\t\t\t.filter((item: any) => item !== undefined && item !== null && item !== '')\n\t\t\t\t.join(',');\n\t\t}\n\t\tconst item = (this.params.options || []).find((op: any) => op?.[valueField] === value);\n\t\treturn item ? item[nameField.key] : null;\n\t}\n\n\tprivate toValueArray(value: any): any[] {\n\t\tif (Array.isArray(value)) {\n\t\t\treturn value;\n\t\t}\n\t\tif (value === '' || value == null) {\n\t\t\treturn [];\n\t\t}\n\t\treturn String(value).split(',').filter((item) => item !== '');\n\t}\n\n\tprivate toValueString(value: any): string {\n\t\tif (Array.isArray(value)) {\n\t\t\treturn value.filter((item) => item !== '' && item != null).join(',');\n\t\t}\n\t\tif (value === '' || value == null) {\n\t\t\treturn '';\n\t\t}\n\t\treturn String(value);\n\t}\n}\n\n/**\n * Async select editor for ag-grid cells.\n *\n * Column usage:\n * {\n *   field: 'procCode',\n *   editable: true,\n *   cellEditor: 'cellEditAsyncSelectFieldComponent',\n *   cellRenderer: 'asyncSelectLabelRenderer',\n *   cellEditorParams: asyncSelectParams,\n *   cellRendererParams: asyncSelectParams\n * }\n *\n * const asyncSelectParams = {\n *   // Value mapping\n *   optionLabel: 'label',       // default: 'label'\n *   optionValue: 'value',       // default: 'value'\n *   options: [],                // static options\n *   rawOptions: [],             // static options alias\n *\n *   // Async options. Context shape: { data, value, params, field, colDef, rowIndex }.\n *   getOptions: ({ data, value, params, field, colDef, rowIndex }) => [],\n *   optionsHook: ({ data, value, params, field, colDef, rowIndex }) => [],\n *   filterOptions: (options, context) => options,\n *\n *   // Cache. Cache is shared by this editor and asyncSelectLabelRenderer.\n *   cache: true,                // default: true\n *   cacheKey: ({ data }) => ['procCode', data?.deptId].join('|'),\n *   clearCache: false,\n *\n *   // Multiple mode. Row values are stored as comma strings like \"1,2\".\n *   multiple: true,\n *   display: 'comma',\n *   maxSelectedLabels: 3,\n *   selectionLimit: 10,\n *   showToggleAll: true,\n *   showHeader: true,\n *\n *   // PrimeNG Select/MultiSelect common props\n *   filter: true,\n *   placeholder: '请选择',\n *   showClear: true,\n *   appendTo: 'body',\n *   scrollHeight: '200px',\n *   optionDisabled: 'disabled',\n *   group: false,\n *   optionGroupLabel: 'label',\n *   optionGroupChildren: 'items',\n *   virtualScroll: false,\n *   virtualScrollItemSize: 32,\n *   panelStyle: {},\n *   panelStyleClass: '',\n *\n *   // AG Grid related write-back. Copies selected option fields to row fields.\n *   nameFields: [\n *     { field: 'procName', key: 'label' }\n *   ]\n * };\n *\n * getOptions/optionsHook may return Option[], { data: Option[] }, Promise, or Observable.\n * For multiple=true, the editor converts comma strings to arrays for p-multiselect\n * and converts selected arrays back to comma strings on save.\n * Use arrow functions when reading FormComponent model from the outer component.\n */\n"]}
|
|
@@ -2,8 +2,9 @@ import { CellEditInputTextCompoent } from './cell-edit-inputText.compoent';
|
|
|
2
2
|
import { CellEditInputNumberCompoent } from './cell-edit-inputNumber.component';
|
|
3
3
|
import { CellEditDatePickerComponent } from './cell-edit-datePicker.compoent';
|
|
4
4
|
import { CellEditSelectFieldComponent } from './cell-edit-selectField.component';
|
|
5
|
+
import { CellEditAsyncSelectFieldComponent } from './cell-edit-async-selectField.component';
|
|
5
6
|
import { CellEditAutoCompleteComponent } from './cell-edit-autoComplete.component';
|
|
6
7
|
import { CellEditInputDateComponent } from './cell-edit-inputDate.component';
|
|
7
8
|
import { CellEditSelectComponent } from './cell-edit-select.component';
|
|
8
|
-
export { CellEditInputTextCompoent, CellEditInputNumberCompoent, CellEditDatePickerComponent, CellEditSelectComponent, CellEditAutoCompleteComponent, CellEditInputDateComponent, CellEditSelectFieldComponent };
|
|
9
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
9
|
+
export { CellEditInputTextCompoent, CellEditInputNumberCompoent, CellEditDatePickerComponent, CellEditSelectComponent, CellEditAutoCompleteComponent, CellEditInputDateComponent, CellEditSelectFieldComponent, CellEditAsyncSelectFieldComponent };
|
|
10
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9pbW0tZWxlbWVudC11aS9zcmMvbGliL2dyaWQvY2VsbC1lZGl0L2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLGdDQUFnQyxDQUFBO0FBQzFFLE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLG1DQUFtQyxDQUFBO0FBQy9FLE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLGlDQUFpQyxDQUFBO0FBQzdFLE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLG1DQUFtQyxDQUFBO0FBQ2hGLE9BQU8sRUFBRSxpQ0FBaUMsRUFBRSxNQUFNLHlDQUF5QyxDQUFBO0FBQzNGLE9BQU8sRUFBRSw2QkFBNkIsRUFBRSxNQUFNLG9DQUFvQyxDQUFBO0FBQ2xGLE9BQU8sRUFBRSwwQkFBMEIsRUFBRSxNQUFNLGlDQUFpQyxDQUFBO0FBQzVFLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLDhCQUE4QixDQUFBO0FBQ3RFLE9BQU8sRUFDTCx5QkFBeUIsRUFDekIsMkJBQTJCLEVBQzNCLDJCQUEyQixFQUMzQix1QkFBdUIsRUFDdkIsNkJBQTZCLEVBQzdCLDBCQUEwQixFQUMxQiw0QkFBNEIsRUFDNUIsaUNBQWlDLEVBQ2xDLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDZWxsRWRpdElucHV0VGV4dENvbXBvZW50IH0gZnJvbSAnLi9jZWxsLWVkaXQtaW5wdXRUZXh0LmNvbXBvZW50J1xuaW1wb3J0IHsgQ2VsbEVkaXRJbnB1dE51bWJlckNvbXBvZW50IH0gZnJvbSAnLi9jZWxsLWVkaXQtaW5wdXROdW1iZXIuY29tcG9uZW50J1xuaW1wb3J0IHsgQ2VsbEVkaXREYXRlUGlja2VyQ29tcG9uZW50IH0gZnJvbSAnLi9jZWxsLWVkaXQtZGF0ZVBpY2tlci5jb21wb2VudCdcbmltcG9ydCB7IENlbGxFZGl0U2VsZWN0RmllbGRDb21wb25lbnQgfSBmcm9tICcuL2NlbGwtZWRpdC1zZWxlY3RGaWVsZC5jb21wb25lbnQnXG5pbXBvcnQgeyBDZWxsRWRpdEFzeW5jU2VsZWN0RmllbGRDb21wb25lbnQgfSBmcm9tICcuL2NlbGwtZWRpdC1hc3luYy1zZWxlY3RGaWVsZC5jb21wb25lbnQnXG5pbXBvcnQgeyBDZWxsRWRpdEF1dG9Db21wbGV0ZUNvbXBvbmVudCB9IGZyb20gJy4vY2VsbC1lZGl0LWF1dG9Db21wbGV0ZS5jb21wb25lbnQnXG5pbXBvcnQgeyBDZWxsRWRpdElucHV0RGF0ZUNvbXBvbmVudCB9IGZyb20gJy4vY2VsbC1lZGl0LWlucHV0RGF0ZS5jb21wb25lbnQnXG5pbXBvcnQgeyBDZWxsRWRpdFNlbGVjdENvbXBvbmVudCB9IGZyb20gJy4vY2VsbC1lZGl0LXNlbGVjdC5jb21wb25lbnQnXG5leHBvcnQgeyBcbiAgQ2VsbEVkaXRJbnB1dFRleHRDb21wb2VudCxcbiAgQ2VsbEVkaXRJbnB1dE51bWJlckNvbXBvZW50LFxuICBDZWxsRWRpdERhdGVQaWNrZXJDb21wb25lbnQsXG4gIENlbGxFZGl0U2VsZWN0Q29tcG9uZW50LFxuICBDZWxsRWRpdEF1dG9Db21wbGV0ZUNvbXBvbmVudCxcbiAgQ2VsbEVkaXRJbnB1dERhdGVDb21wb25lbnQsXG4gIENlbGxFZGl0U2VsZWN0RmllbGRDb21wb25lbnQsXG4gIENlbGxFZGl0QXN5bmNTZWxlY3RGaWVsZENvbXBvbmVudFxufVxuIl19
|
|
@@ -0,0 +1,102 @@
|
|
|
1
|
+
import { Component, inject } from '@angular/core';
|
|
2
|
+
import { resolveAsyncSelectOptions } from '../cell-utils/async-select-options';
|
|
3
|
+
import { AsyncSelectOptionsCacheService } from '../cell-utils/async-select-options-cache.service';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
export class AsyncSelectLabelRenderer {
|
|
6
|
+
constructor() {
|
|
7
|
+
this.label = '';
|
|
8
|
+
this.loadId = 0;
|
|
9
|
+
this.cacheService = inject(AsyncSelectOptionsCacheService);
|
|
10
|
+
}
|
|
11
|
+
agInit(params) {
|
|
12
|
+
this.refresh(params);
|
|
13
|
+
}
|
|
14
|
+
refresh(params) {
|
|
15
|
+
this.params = this.mergeParams(params);
|
|
16
|
+
void this.loadLabel();
|
|
17
|
+
return true;
|
|
18
|
+
}
|
|
19
|
+
async loadLabel() {
|
|
20
|
+
const loadId = ++this.loadId;
|
|
21
|
+
const value = this.params.value ?? this.params.data?.[this.params.colDef.field];
|
|
22
|
+
if (value === '' || value == null) {
|
|
23
|
+
this.label = '';
|
|
24
|
+
return;
|
|
25
|
+
}
|
|
26
|
+
const context = this.createContext(value);
|
|
27
|
+
try {
|
|
28
|
+
const options = await resolveAsyncSelectOptions(this.params, context);
|
|
29
|
+
if (loadId !== this.loadId) {
|
|
30
|
+
return;
|
|
31
|
+
}
|
|
32
|
+
this.label = this.formatLabel(value, options);
|
|
33
|
+
}
|
|
34
|
+
catch {
|
|
35
|
+
if (loadId === this.loadId) {
|
|
36
|
+
this.label = String(value);
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
mergeParams(params) {
|
|
41
|
+
const cellEditorParams = params.colDef?.cellEditorParams || {};
|
|
42
|
+
return {
|
|
43
|
+
...cellEditorParams,
|
|
44
|
+
...params,
|
|
45
|
+
optionLabel: params.optionLabel || cellEditorParams.optionLabel || 'label',
|
|
46
|
+
optionValue: params.optionValue || cellEditorParams.optionValue || 'value',
|
|
47
|
+
multiple: params.multiple ?? cellEditorParams.multiple,
|
|
48
|
+
};
|
|
49
|
+
}
|
|
50
|
+
createContext(value) {
|
|
51
|
+
return {
|
|
52
|
+
data: this.params.data,
|
|
53
|
+
value: this.params.multiple ? this.toValueString(value) : value,
|
|
54
|
+
params: this.params,
|
|
55
|
+
field: this.params.colDef.field,
|
|
56
|
+
colDef: this.params.colDef,
|
|
57
|
+
rowIndex: this.params.node?.rowIndex,
|
|
58
|
+
};
|
|
59
|
+
}
|
|
60
|
+
formatLabel(value, options) {
|
|
61
|
+
const valueField = this.params.optionValue || 'value';
|
|
62
|
+
const labelField = this.params.optionLabel || 'label';
|
|
63
|
+
if (this.params.multiple) {
|
|
64
|
+
const values = this.toValueArray(value);
|
|
65
|
+
const labels = values.map((item) => {
|
|
66
|
+
const option = options.find((opt) => opt?.[valueField] == item);
|
|
67
|
+
return option ? option?.[labelField] : item;
|
|
68
|
+
});
|
|
69
|
+
return labels.filter((item) => item !== undefined && item !== null && item !== '').join(',');
|
|
70
|
+
}
|
|
71
|
+
const option = options.find((opt) => opt?.[valueField] == value);
|
|
72
|
+
return option ? option?.[labelField] : String(value);
|
|
73
|
+
}
|
|
74
|
+
toValueArray(value) {
|
|
75
|
+
if (Array.isArray(value)) {
|
|
76
|
+
return value;
|
|
77
|
+
}
|
|
78
|
+
if (value === '' || value == null) {
|
|
79
|
+
return [];
|
|
80
|
+
}
|
|
81
|
+
return String(value).split(',').filter((item) => item !== '');
|
|
82
|
+
}
|
|
83
|
+
toValueString(value) {
|
|
84
|
+
if (Array.isArray(value)) {
|
|
85
|
+
return value.filter((item) => item !== '' && item != null).join(',');
|
|
86
|
+
}
|
|
87
|
+
if (value === '' || value == null) {
|
|
88
|
+
return '';
|
|
89
|
+
}
|
|
90
|
+
return String(value);
|
|
91
|
+
}
|
|
92
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AsyncSelectLabelRenderer, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
93
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: AsyncSelectLabelRenderer, isStandalone: true, selector: "ng-component", ngImport: i0, template: `{{ label }}`, isInline: true }); }
|
|
94
|
+
}
|
|
95
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AsyncSelectLabelRenderer, decorators: [{
|
|
96
|
+
type: Component,
|
|
97
|
+
args: [{
|
|
98
|
+
standalone: true,
|
|
99
|
+
template: `{{ label }}`,
|
|
100
|
+
}]
|
|
101
|
+
}] });
|
|
102
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"async-select-label-renderer.js","sourceRoot":"","sources":["../../../../../../projects/imm-element-ui/src/lib/grid/cell-render/async-select-label-renderer.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, inject } from '@angular/core';\nimport type { ICellRendererAngularComp } from 'ag-grid-angular';\nimport type { ICellRendererParams } from 'ag-grid-community';\nimport { AsyncSelectContext, resolveAsyncSelectOptions } from '../cell-utils/async-select-options';\nimport { AsyncSelectOptionsCacheService } from '../cell-utils/async-select-options-cache.service';\n\n@Component({\n\tstandalone: true,\n\ttemplate: `{{ label }}`,\n})\nexport class AsyncSelectLabelRenderer implements ICellRendererAngularComp {\n\tlabel = '';\n\tparams!: any;\n\tprivate loadId = 0;\n\tprivate readonly cacheService = inject(AsyncSelectOptionsCacheService);\n\n\tagInit(params: ICellRendererParams): void {\n\t\tthis.refresh(params);\n\t}\n\n\trefresh(params: ICellRendererParams): boolean {\n\t\tthis.params = this.mergeParams(params);\n\t\tvoid this.loadLabel();\n\t\treturn true;\n\t}\n\n\tprivate async loadLabel() {\n\t\tconst loadId = ++this.loadId;\n\t\tconst value = this.params.value ?? this.params.data?.[this.params.colDef.field];\n\t\tif (value === '' || value == null) {\n\t\t\tthis.label = '';\n\t\t\treturn;\n\t\t}\n\n\t\tconst context = this.createContext(value);\n\t\ttry {\n\t\t\tconst options = await resolveAsyncSelectOptions(this.params, context);\n\t\t\tif (loadId !== this.loadId) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tthis.label = this.formatLabel(value, options);\n\t\t} catch {\n\t\t\tif (loadId === this.loadId) {\n\t\t\t\tthis.label = String(value);\n\t\t\t}\n\t\t}\n\t}\n\n\tprivate mergeParams(params: ICellRendererParams) {\n\t\tconst cellEditorParams = (params.colDef as any)?.cellEditorParams || {};\n\t\treturn {\n\t\t\t...cellEditorParams,\n\t\t\t...params,\n\t\t\toptionLabel: (params as any).optionLabel || cellEditorParams.optionLabel || 'label',\n\t\t\toptionValue: (params as any).optionValue || cellEditorParams.optionValue || 'value',\n\t\t\tmultiple: (params as any).multiple ?? cellEditorParams.multiple,\n\t\t};\n\t}\n\n\tprivate createContext(value: any): AsyncSelectContext {\n\t\treturn {\n\t\t\tdata: this.params.data,\n\t\t\tvalue: this.params.multiple ? this.toValueString(value) : value,\n\t\t\tparams: this.params,\n\t\t\tfield: this.params.colDef.field,\n\t\t\tcolDef: this.params.colDef,\n\t\t\trowIndex: this.params.node?.rowIndex,\n\t\t};\n\t}\n\n\tprivate formatLabel(value: any, options: any[]) {\n\t\tconst valueField = this.params.optionValue || 'value';\n\t\tconst labelField = this.params.optionLabel || 'label';\n\t\tif (this.params.multiple) {\n\t\t\tconst values = this.toValueArray(value);\n\t\t\tconst labels = values.map((item) => {\n\t\t\t\tconst option = options.find((opt: any) => opt?.[valueField] == item);\n\t\t\t\treturn option ? option?.[labelField] : item;\n\t\t\t});\n\t\t\treturn labels.filter((item) => item !== undefined && item !== null && item !== '').join(',');\n\t\t}\n\t\tconst option = options.find((opt: any) => opt?.[valueField] == value);\n\t\treturn option ? option?.[labelField] : String(value);\n\t}\n\n\tprivate toValueArray(value: any): any[] {\n\t\tif (Array.isArray(value)) {\n\t\t\treturn value;\n\t\t}\n\t\tif (value === '' || value == null) {\n\t\t\treturn [];\n\t\t}\n\t\treturn String(value).split(',').filter((item) => item !== '');\n\t}\n\n\tprivate toValueString(value: any): string {\n\t\tif (Array.isArray(value)) {\n\t\t\treturn value.filter((item) => item !== '' && item != null).join(',');\n\t\t}\n\t\tif (value === '' || value == null) {\n\t\t\treturn '';\n\t\t}\n\t\treturn String(value);\n\t}\n}\n"]}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { NavigationStart } from '@angular/router';
|
|
3
|
+
import { filter } from 'rxjs';
|
|
4
|
+
import { clearAsyncSelectOptionsCache } from './async-select-options';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@angular/router";
|
|
7
|
+
export class AsyncSelectOptionsCacheService {
|
|
8
|
+
constructor(router) {
|
|
9
|
+
router.events
|
|
10
|
+
.pipe(filter((event) => event instanceof NavigationStart))
|
|
11
|
+
.subscribe(() => clearAsyncSelectOptionsCache());
|
|
12
|
+
}
|
|
13
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AsyncSelectOptionsCacheService, deps: [{ token: i1.Router }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
14
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AsyncSelectOptionsCacheService, providedIn: 'root' }); }
|
|
15
|
+
}
|
|
16
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AsyncSelectOptionsCacheService, decorators: [{
|
|
17
|
+
type: Injectable,
|
|
18
|
+
args: [{ providedIn: 'root' }]
|
|
19
|
+
}], ctorParameters: () => [{ type: i1.Router }] });
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXN5bmMtc2VsZWN0LW9wdGlvbnMtY2FjaGUuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2ltbS1lbGVtZW50LXVpL3NyYy9saWIvZ3JpZC9jZWxsLXV0aWxzL2FzeW5jLXNlbGVjdC1vcHRpb25zLWNhY2hlLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLEVBQUUsZUFBZSxFQUFVLE1BQU0saUJBQWlCLENBQUM7QUFDMUQsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUM5QixPQUFPLEVBQUUsNEJBQTRCLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQzs7O0FBR3RFLE1BQU0sT0FBTyw4QkFBOEI7SUFDMUMsWUFBWSxNQUFjO1FBQ3pCLE1BQU0sQ0FBQyxNQUFNO2FBQ1gsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDLEtBQUssRUFBNEIsRUFBRSxDQUFDLEtBQUssWUFBWSxlQUFlLENBQUMsQ0FBQzthQUNuRixTQUFTLENBQUMsR0FBRyxFQUFFLENBQUMsNEJBQTRCLEVBQUUsQ0FBQyxDQUFDO0lBQ25ELENBQUM7K0dBTFcsOEJBQThCO21IQUE5Qiw4QkFBOEIsY0FEakIsTUFBTTs7NEZBQ25CLDhCQUE4QjtrQkFEMUMsVUFBVTttQkFBQyxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBOYXZpZ2F0aW9uU3RhcnQsIFJvdXRlciB9IGZyb20gJ0Bhbmd1bGFyL3JvdXRlcic7XG5pbXBvcnQgeyBmaWx0ZXIgfSBmcm9tICdyeGpzJztcbmltcG9ydCB7IGNsZWFyQXN5bmNTZWxlY3RPcHRpb25zQ2FjaGUgfSBmcm9tICcuL2FzeW5jLXNlbGVjdC1vcHRpb25zJztcblxuQEluamVjdGFibGUoeyBwcm92aWRlZEluOiAncm9vdCcgfSlcbmV4cG9ydCBjbGFzcyBBc3luY1NlbGVjdE9wdGlvbnNDYWNoZVNlcnZpY2Uge1xuXHRjb25zdHJ1Y3Rvcihyb3V0ZXI6IFJvdXRlcikge1xuXHRcdHJvdXRlci5ldmVudHNcblx0XHRcdC5waXBlKGZpbHRlcigoZXZlbnQpOiBldmVudCBpcyBOYXZpZ2F0aW9uU3RhcnQgPT4gZXZlbnQgaW5zdGFuY2VvZiBOYXZpZ2F0aW9uU3RhcnQpKVxuXHRcdFx0LnN1YnNjcmliZSgoKSA9PiBjbGVhckFzeW5jU2VsZWN0T3B0aW9uc0NhY2hlKCkpO1xuXHR9XG59XG4iXX0=
|