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.
@@ -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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9pbW0tZWxlbWVudC11aS9zcmMvbGliL2dyaWQvY2VsbC1lZGl0L2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLGdDQUFnQyxDQUFBO0FBQzFFLE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLG1DQUFtQyxDQUFBO0FBQy9FLE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLGlDQUFpQyxDQUFBO0FBQzdFLE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLG1DQUFtQyxDQUFBO0FBQ2hGLE9BQU8sRUFBRSw2QkFBNkIsRUFBRSxNQUFNLG9DQUFvQyxDQUFBO0FBQ2xGLE9BQU8sRUFBRSwwQkFBMEIsRUFBRSxNQUFNLGlDQUFpQyxDQUFBO0FBQzVFLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLDhCQUE4QixDQUFBO0FBQ3RFLE9BQU8sRUFDTCx5QkFBeUIsRUFDekIsMkJBQTJCLEVBQzNCLDJCQUEyQixFQUMzQix1QkFBdUIsRUFDdkIsNkJBQTZCLEVBQzdCLDBCQUEwQixFQUMxQiw0QkFBNEIsRUFDN0IsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENlbGxFZGl0SW5wdXRUZXh0Q29tcG9lbnQgfSBmcm9tICcuL2NlbGwtZWRpdC1pbnB1dFRleHQuY29tcG9lbnQnXG5pbXBvcnQgeyBDZWxsRWRpdElucHV0TnVtYmVyQ29tcG9lbnQgfSBmcm9tICcuL2NlbGwtZWRpdC1pbnB1dE51bWJlci5jb21wb25lbnQnXG5pbXBvcnQgeyBDZWxsRWRpdERhdGVQaWNrZXJDb21wb25lbnQgfSBmcm9tICcuL2NlbGwtZWRpdC1kYXRlUGlja2VyLmNvbXBvZW50J1xuaW1wb3J0IHsgQ2VsbEVkaXRTZWxlY3RGaWVsZENvbXBvbmVudCB9IGZyb20gJy4vY2VsbC1lZGl0LXNlbGVjdEZpZWxkLmNvbXBvbmVudCdcbmltcG9ydCB7IENlbGxFZGl0QXV0b0NvbXBsZXRlQ29tcG9uZW50IH0gZnJvbSAnLi9jZWxsLWVkaXQtYXV0b0NvbXBsZXRlLmNvbXBvbmVudCdcbmltcG9ydCB7IENlbGxFZGl0SW5wdXREYXRlQ29tcG9uZW50IH0gZnJvbSAnLi9jZWxsLWVkaXQtaW5wdXREYXRlLmNvbXBvbmVudCdcbmltcG9ydCB7IENlbGxFZGl0U2VsZWN0Q29tcG9uZW50IH0gZnJvbSAnLi9jZWxsLWVkaXQtc2VsZWN0LmNvbXBvbmVudCdcbmV4cG9ydCB7IFxuICBDZWxsRWRpdElucHV0VGV4dENvbXBvZW50LFxuICBDZWxsRWRpdElucHV0TnVtYmVyQ29tcG9lbnQsXG4gIENlbGxFZGl0RGF0ZVBpY2tlckNvbXBvbmVudCxcbiAgQ2VsbEVkaXRTZWxlY3RDb21wb25lbnQsXG4gIENlbGxFZGl0QXV0b0NvbXBsZXRlQ29tcG9uZW50LFxuICBDZWxsRWRpdElucHV0RGF0ZUNvbXBvbmVudCxcbiAgQ2VsbEVkaXRTZWxlY3RGaWVsZENvbXBvbmVudFxufVxuIl19
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=