imm-element-ui 2.6.3 → 2.6.4

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,377 @@
1
+ import { Component, ViewChild, ViewContainerRef } 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 * as i0 from "@angular/core";
7
+ import * as i1 from "@angular/forms";
8
+ import * as i2 from "primeng/select";
9
+ export class CellEditAsyncSelectFieldComponent {
10
+ async agInit(params) {
11
+ this.params = params;
12
+ this.params.optionLabel = this.params.optionLabel || 'label';
13
+ this.params.optionValue = this.params.optionValue || 'value';
14
+ const rowValue = this.params.data?.[this.params.colDef.field];
15
+ this.value = this.params.multiple ? this.toValueArray(params.value ?? rowValue) : (params.value ?? rowValue);
16
+ this.setEditorSize(params);
17
+ await this.loadOptions();
18
+ }
19
+ getValue() {
20
+ if (this.params.multiple) {
21
+ return this.toValueString(this.value);
22
+ }
23
+ const value = this.value;
24
+ return value === '' || value == null ? null : value;
25
+ }
26
+ onChange(event) {
27
+ const nameFields = this.params.nameFields || [];
28
+ nameFields.forEach((nameField) => {
29
+ this.updateNameField(nameField, event);
30
+ });
31
+ }
32
+ async loadOptions() {
33
+ const context = this.createContext();
34
+ try {
35
+ this.params.loading = true;
36
+ this.params.options = await resolveAsyncSelectOptions(this.params, context);
37
+ }
38
+ finally {
39
+ this.params.loading = false;
40
+ }
41
+ }
42
+ createContext() {
43
+ return {
44
+ data: this.params.data,
45
+ value: this.params.multiple ? this.toValueString(this.value) : this.value,
46
+ params: this.params,
47
+ field: this.params.colDef.field,
48
+ colDef: this.params.colDef,
49
+ rowIndex: this.params.node?.rowIndex,
50
+ };
51
+ }
52
+ setEditorSize(params) {
53
+ const cellWidth = params.column.getActualWidth();
54
+ this.params.style = {
55
+ border: 'none',
56
+ boxShadow: 'none',
57
+ width: `${cellWidth}px`,
58
+ background: 'var(--ag-background-color)',
59
+ height: '40px',
60
+ alignItems: 'center',
61
+ ...(this.params.style || {}),
62
+ };
63
+ this.params.panelStyle = {
64
+ width: `${cellWidth}px`,
65
+ ...(this.params.panelStyle || {}),
66
+ };
67
+ }
68
+ updateNameField(nameField, event) {
69
+ const oldValue = this.params.data[nameField.field];
70
+ const newValue = this.resolveNameFieldValue(nameField, event.value);
71
+ const grid = this.params.grid();
72
+ const e = {
73
+ colDef: nameField,
74
+ oldValue,
75
+ newValue,
76
+ rowIndex: this.params.node.rowIndex,
77
+ data: { id: this.params.data.id },
78
+ };
79
+ grid.cellValueChanged(e);
80
+ this.params.data[nameField.field] = newValue;
81
+ }
82
+ resolveNameFieldValue(nameField, value) {
83
+ const valueField = this.params.optionValue || 'value';
84
+ if (this.params.multiple) {
85
+ const values = this.toValueArray(value);
86
+ return (this.params.options || [])
87
+ .filter((op) => values.some((selectedValue) => selectedValue == op?.[valueField]))
88
+ .map((op) => op?.[nameField.key])
89
+ .filter((item) => item !== undefined && item !== null && item !== '')
90
+ .join(',');
91
+ }
92
+ const item = (this.params.options || []).find((op) => op?.[valueField] === value);
93
+ return item ? item[nameField.key] : null;
94
+ }
95
+ toValueArray(value) {
96
+ if (Array.isArray(value)) {
97
+ return value;
98
+ }
99
+ if (value === '' || value == null) {
100
+ return [];
101
+ }
102
+ return String(value).split(',').filter((item) => item !== '');
103
+ }
104
+ toValueString(value) {
105
+ if (Array.isArray(value)) {
106
+ return value.filter((item) => item !== '' && item != null).join(',');
107
+ }
108
+ if (value === '' || value == null) {
109
+ return '';
110
+ }
111
+ return String(value);
112
+ }
113
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CellEditAsyncSelectFieldComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
114
+ 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: `
115
+ @if (params.multiple) {
116
+ <p-multiselect
117
+ [(ngModel)]="value"
118
+ [scrollHeight]="params.scrollHeight || '200px'"
119
+ [filter]="params.filter"
120
+ [name]="params.name"
121
+ [options]="params.options"
122
+ [placeholder]="params.placeholder"
123
+ [class]="params.class"
124
+ [style]="params.style"
125
+ [panelStyle]="params.panelStyle"
126
+ [panelStyleClass]="params.panelStyleClass"
127
+ [readonly]="params.readonly"
128
+ [appendTo]="params.appendTo || 'body'"
129
+ [tabindex]="params.tabindex"
130
+ [loadingIcon]="params.loadingIcon"
131
+ [filterPlaceHolder]="params.filterPlaceHolder || params.filterPlaceholder"
132
+ [filterLocale]="params.filterLocale"
133
+ [variant]="params.variant"
134
+ [inputId]="params.inputId"
135
+ [dataKey]="params.dataKey"
136
+ [filterBy]="params.filterBy"
137
+ [filterFields]="params.filterFields"
138
+ [autofocus]="params.autofocus ?? true"
139
+ [resetFilterOnHide]="params.resetFilterOnHide"
140
+ [dropdownIcon]="params.dropdownIcon"
141
+ [loading]="params.loading"
142
+ [optionLabel]="params.optionLabel"
143
+ [optionValue]="params.optionValue"
144
+ [optionDisabled]="params.optionDisabled"
145
+ [optionGroupLabel]="params.optionGroupLabel"
146
+ [optionGroupChildren]="params.optionGroupChildren || 'items'"
147
+ [group]="params.group"
148
+ [showClear]="params.showClear"
149
+ [emptyFilterMessage]="params.emptyFilterMessage"
150
+ [emptyMessage]="params.emptyMessage"
151
+ [lazy]="params.lazy"
152
+ [virtualScroll]="params.virtualScroll"
153
+ [virtualScrollItemSize]="params.virtualScrollItemSize"
154
+ [virtualScrollOptions]="params.virtualScrollOptions"
155
+ [overlayOptions]="params.overlayOptions"
156
+ [size]="params.size"
157
+ [ariaFilterLabel]="params.ariaFilterLabel"
158
+ [ariaLabel]="params.ariaLabel"
159
+ [ariaLabelledBy]="params.ariaLabelledBy"
160
+ [filterMatchMode]="params.filterMatchMode"
161
+ [maxlength]="params.maxlength"
162
+ [tooltip]="params.tooltip"
163
+ [tooltipPosition]="params.tooltipPosition || 'right'"
164
+ [tooltipPositionStyle]="params.tooltipPositionStyle || 'absolute'"
165
+ [tooltipStyleClass]="params.tooltipStyleClass"
166
+ [focusOnHover]="params.focusOnHover == undefined ? true : params.focusOnHover"
167
+ [fluid]="params.fluid == undefined ? true : params.fluid"
168
+ [filterValue]="params.filterValue"
169
+ [display]="params.display ?? 'comma'"
170
+ [displaySelectedLabel]="params.displaySelectedLabel ?? true"
171
+ [maxSelectedLabels]="params.maxSelectedLabels"
172
+ [selectionLimit]="params.selectionLimit"
173
+ [selectedItemsLabel]="params.selectedItemsLabel"
174
+ [showToggleAll]="params.showToggleAll ?? true"
175
+ [showHeader]="params.showHeader ?? true"
176
+ [autofocusFilter]="params.autofocusFilter"
177
+ [selectAll]="params.selectAll ?? null"
178
+ [selectOnFocus]="params.selectOnFocus"
179
+ [autoOptionFocus]="params.autoOptionFocus"
180
+ (onChange)="onChange($event)" />
181
+ } @else {
182
+ <p-select
183
+ [(ngModel)]="value"
184
+ [scrollHeight]="params.scrollHeight || '200px'"
185
+ [filter]="params.filter"
186
+ [name]="params.name"
187
+ [options]="params.options"
188
+ [placeholder]="params.placeholder"
189
+ [class]="params.class"
190
+ [style]="params.style"
191
+ [panelStyle]="params.panelStyle"
192
+ [panelStyleClass]="params.panelStyleClass"
193
+ [readonly]="params.readonly"
194
+ [editable]="params.editable"
195
+ [appendTo]="params.appendTo || 'body'"
196
+ [tabindex]="params.tabindex"
197
+ [loadingIcon]="params.loadingIcon"
198
+ [filterPlaceholder]="params.filterPlaceholder"
199
+ [filterLocale]="params.filterLocale"
200
+ [variant]="params.variant"
201
+ [inputId]="params.inputId"
202
+ [dataKey]="params.dataKey"
203
+ [filterBy]="params.filterBy"
204
+ [filterFields]="params.filterFields"
205
+ [autofocus]="params.autofocus ?? true"
206
+ [resetFilterOnHide]="params.resetFilterOnHide"
207
+ [checkmark]="params.checkmark"
208
+ [dropdownIcon]="params.dropdownIcon"
209
+ [loading]="params.loading"
210
+ [optionLabel]="params.optionLabel"
211
+ [optionValue]="params.optionValue"
212
+ [optionDisabled]="params.optionDisabled"
213
+ [optionGroupLabel]="params.optionGroupLabel"
214
+ [optionGroupChildren]="params.optionGroupChildren || 'items'"
215
+ [group]="params.group"
216
+ [showClear]="params.showClear"
217
+ [emptyFilterMessage]="params.emptyFilterMessage"
218
+ [emptyMessage]="params.emptyMessage"
219
+ [lazy]="params.lazy"
220
+ [virtualScroll]="params.virtualScroll"
221
+ [virtualScrollItemSize]="params.virtualScrollItemSize"
222
+ [virtualScrollOptions]="params.virtualScrollOptions"
223
+ [overlayOptions]="params.overlayOptions"
224
+ [size]="params.size"
225
+ [ariaFilterLabel]="params.ariaFilterLabel"
226
+ [ariaLabel]="params.ariaLabel"
227
+ [ariaLabelledBy]="params.ariaLabelledBy"
228
+ [filterMatchMode]="params.filterMatchMode"
229
+ [maxlength]="params.maxlength"
230
+ [tooltip]="params.tooltip"
231
+ [tooltipPosition]="params.tooltipPosition || 'right'"
232
+ [tooltipPositionStyle]="params.tooltipPositionStyle || 'absolute'"
233
+ [tooltipStyleClass]="params.tooltipStyleClass"
234
+ [focusOnHover]="params.focusOnHover == undefined ? true : params.focusOnHover"
235
+ [fluid]="params.fluid == undefined ? true : params.fluid"
236
+ [filterValue]="params.filterValue"
237
+ (onChange)="onChange($event)" />
238
+ }
239
+ `, 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"] }] }); }
240
+ }
241
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CellEditAsyncSelectFieldComponent, decorators: [{
242
+ type: Component,
243
+ args: [{
244
+ standalone: true,
245
+ template: `
246
+ @if (params.multiple) {
247
+ <p-multiselect
248
+ [(ngModel)]="value"
249
+ [scrollHeight]="params.scrollHeight || '200px'"
250
+ [filter]="params.filter"
251
+ [name]="params.name"
252
+ [options]="params.options"
253
+ [placeholder]="params.placeholder"
254
+ [class]="params.class"
255
+ [style]="params.style"
256
+ [panelStyle]="params.panelStyle"
257
+ [panelStyleClass]="params.panelStyleClass"
258
+ [readonly]="params.readonly"
259
+ [appendTo]="params.appendTo || 'body'"
260
+ [tabindex]="params.tabindex"
261
+ [loadingIcon]="params.loadingIcon"
262
+ [filterPlaceHolder]="params.filterPlaceHolder || params.filterPlaceholder"
263
+ [filterLocale]="params.filterLocale"
264
+ [variant]="params.variant"
265
+ [inputId]="params.inputId"
266
+ [dataKey]="params.dataKey"
267
+ [filterBy]="params.filterBy"
268
+ [filterFields]="params.filterFields"
269
+ [autofocus]="params.autofocus ?? true"
270
+ [resetFilterOnHide]="params.resetFilterOnHide"
271
+ [dropdownIcon]="params.dropdownIcon"
272
+ [loading]="params.loading"
273
+ [optionLabel]="params.optionLabel"
274
+ [optionValue]="params.optionValue"
275
+ [optionDisabled]="params.optionDisabled"
276
+ [optionGroupLabel]="params.optionGroupLabel"
277
+ [optionGroupChildren]="params.optionGroupChildren || 'items'"
278
+ [group]="params.group"
279
+ [showClear]="params.showClear"
280
+ [emptyFilterMessage]="params.emptyFilterMessage"
281
+ [emptyMessage]="params.emptyMessage"
282
+ [lazy]="params.lazy"
283
+ [virtualScroll]="params.virtualScroll"
284
+ [virtualScrollItemSize]="params.virtualScrollItemSize"
285
+ [virtualScrollOptions]="params.virtualScrollOptions"
286
+ [overlayOptions]="params.overlayOptions"
287
+ [size]="params.size"
288
+ [ariaFilterLabel]="params.ariaFilterLabel"
289
+ [ariaLabel]="params.ariaLabel"
290
+ [ariaLabelledBy]="params.ariaLabelledBy"
291
+ [filterMatchMode]="params.filterMatchMode"
292
+ [maxlength]="params.maxlength"
293
+ [tooltip]="params.tooltip"
294
+ [tooltipPosition]="params.tooltipPosition || 'right'"
295
+ [tooltipPositionStyle]="params.tooltipPositionStyle || 'absolute'"
296
+ [tooltipStyleClass]="params.tooltipStyleClass"
297
+ [focusOnHover]="params.focusOnHover == undefined ? true : params.focusOnHover"
298
+ [fluid]="params.fluid == undefined ? true : params.fluid"
299
+ [filterValue]="params.filterValue"
300
+ [display]="params.display ?? 'comma'"
301
+ [displaySelectedLabel]="params.displaySelectedLabel ?? true"
302
+ [maxSelectedLabels]="params.maxSelectedLabels"
303
+ [selectionLimit]="params.selectionLimit"
304
+ [selectedItemsLabel]="params.selectedItemsLabel"
305
+ [showToggleAll]="params.showToggleAll ?? true"
306
+ [showHeader]="params.showHeader ?? true"
307
+ [autofocusFilter]="params.autofocusFilter"
308
+ [selectAll]="params.selectAll ?? null"
309
+ [selectOnFocus]="params.selectOnFocus"
310
+ [autoOptionFocus]="params.autoOptionFocus"
311
+ (onChange)="onChange($event)" />
312
+ } @else {
313
+ <p-select
314
+ [(ngModel)]="value"
315
+ [scrollHeight]="params.scrollHeight || '200px'"
316
+ [filter]="params.filter"
317
+ [name]="params.name"
318
+ [options]="params.options"
319
+ [placeholder]="params.placeholder"
320
+ [class]="params.class"
321
+ [style]="params.style"
322
+ [panelStyle]="params.panelStyle"
323
+ [panelStyleClass]="params.panelStyleClass"
324
+ [readonly]="params.readonly"
325
+ [editable]="params.editable"
326
+ [appendTo]="params.appendTo || 'body'"
327
+ [tabindex]="params.tabindex"
328
+ [loadingIcon]="params.loadingIcon"
329
+ [filterPlaceholder]="params.filterPlaceholder"
330
+ [filterLocale]="params.filterLocale"
331
+ [variant]="params.variant"
332
+ [inputId]="params.inputId"
333
+ [dataKey]="params.dataKey"
334
+ [filterBy]="params.filterBy"
335
+ [filterFields]="params.filterFields"
336
+ [autofocus]="params.autofocus ?? true"
337
+ [resetFilterOnHide]="params.resetFilterOnHide"
338
+ [checkmark]="params.checkmark"
339
+ [dropdownIcon]="params.dropdownIcon"
340
+ [loading]="params.loading"
341
+ [optionLabel]="params.optionLabel"
342
+ [optionValue]="params.optionValue"
343
+ [optionDisabled]="params.optionDisabled"
344
+ [optionGroupLabel]="params.optionGroupLabel"
345
+ [optionGroupChildren]="params.optionGroupChildren || 'items'"
346
+ [group]="params.group"
347
+ [showClear]="params.showClear"
348
+ [emptyFilterMessage]="params.emptyFilterMessage"
349
+ [emptyMessage]="params.emptyMessage"
350
+ [lazy]="params.lazy"
351
+ [virtualScroll]="params.virtualScroll"
352
+ [virtualScrollItemSize]="params.virtualScrollItemSize"
353
+ [virtualScrollOptions]="params.virtualScrollOptions"
354
+ [overlayOptions]="params.overlayOptions"
355
+ [size]="params.size"
356
+ [ariaFilterLabel]="params.ariaFilterLabel"
357
+ [ariaLabel]="params.ariaLabel"
358
+ [ariaLabelledBy]="params.ariaLabelledBy"
359
+ [filterMatchMode]="params.filterMatchMode"
360
+ [maxlength]="params.maxlength"
361
+ [tooltip]="params.tooltip"
362
+ [tooltipPosition]="params.tooltipPosition || 'right'"
363
+ [tooltipPositionStyle]="params.tooltipPositionStyle || 'absolute'"
364
+ [tooltipStyleClass]="params.tooltipStyleClass"
365
+ [focusOnHover]="params.focusOnHover == undefined ? true : params.focusOnHover"
366
+ [fluid]="params.fluid == undefined ? true : params.fluid"
367
+ [filterValue]="params.filterValue"
368
+ (onChange)="onChange($event)" />
369
+ }
370
+ `,
371
+ imports: [FormsModule, ReactiveFormsModule, SelectModule, MultiSelect],
372
+ }]
373
+ }], propDecorators: { input: [{
374
+ type: ViewChild,
375
+ args: ['input', { read: ViewContainerRef }]
376
+ }] } });
377
+ //# 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":"AAAA,OAAO,EAAE,SAAS,EAAE,SAAS,EAAE,gBAAgB,EAAE,MAAM,eAAe,CAAC;AACvE,OAAO,EAAE,WAAW,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAGlE,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAC9C,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAElD,OAAO,EAAsB,yBAAyB,EAAE,MAAM,oCAAoC,CAAC;;;;AAoInG,MAAM,OAAO,iCAAiC;IAM7C,KAAK,CAAC,MAAM,CAAC,MAAyB;QACrC,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,MAAM,CAAC,WAAW,GAAG,IAAI,CAAC,MAAM,CAAC,WAAW,IAAI,OAAO,CAAC;QAC7D,IAAI,CAAC,MAAM,CAAC,WAAW,GAAG,IAAI,CAAC,MAAM,CAAC,WAAW,IAAI,OAAO,CAAC;QAC7D,MAAM,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,KAAM,CAAC,CAAC;QAC/D,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,CAAC,MAAM,CAAC,KAAK,IAAI,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,IAAI,QAAQ,CAAC,CAAC;QAE7G,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;QAC3B,MAAM,IAAI,CAAC,WAAW,EAAE,CAAC;IAC1B,CAAC;IAED,QAAQ;QACP,IAAI,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;YAC1B,OAAO,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACvC,CAAC;QACD,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC;QACzB,OAAO,KAAK,KAAK,EAAE,IAAI,KAAK,IAAI,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC;IACrD,CAAC;IAED,QAAQ,CAAC,KAAU;QAClB,MAAM,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,UAAU,IAAI,EAAE,CAAC;QAChD,UAAU,CAAC,OAAO,CAAC,CAAC,SAAc,EAAE,EAAE;YACrC,IAAI,CAAC,eAAe,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC;QACxC,CAAC,CAAC,CAAC;IACJ,CAAC;IAEO,KAAK,CAAC,WAAW;QACxB,MAAM,OAAO,GAAG,IAAI,CAAC,aAAa,EAAE,CAAC;QAErC,IAAI,CAAC;YACJ,IAAI,CAAC,MAAM,CAAC,OAAO,GAAG,IAAI,CAAC;YAC3B,IAAI,CAAC,MAAM,CAAC,OAAO,GAAG,MAAM,yBAAyB,CAAC,IAAI,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;QAC7E,CAAC;gBAAS,CAAC;YACV,IAAI,CAAC,MAAM,CAAC,OAAO,GAAG,KAAK,CAAC;QAC7B,CAAC;IACF,CAAC;IAEO,aAAa;QACpB,OAAO;YACN,IAAI,EAAE,IAAI,CAAC,MAAM,CAAC,IAAI;YACtB,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK;YACzE,MAAM,EAAE,IAAI,CAAC,MAAM;YACnB,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK;YAC/B,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,MAAM;YAC1B,QAAQ,EAAE,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,QAAQ;SACpC,CAAC;IACH,CAAC;IAEO,aAAa,CAAC,MAAyB;QAC9C,MAAM,SAAS,GAAG,MAAM,CAAC,MAAM,CAAC,cAAc,EAAE,CAAC;QACjD,IAAI,CAAC,MAAM,CAAC,KAAK,GAAG;YACnB,MAAM,EAAE,MAAM;YACd,SAAS,EAAE,MAAM;YACjB,KAAK,EAAE,GAAG,SAAS,IAAI;YACvB,UAAU,EAAE,4BAA4B;YACxC,MAAM,EAAE,MAAM;YACd,UAAU,EAAE,QAAQ;YACpB,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,IAAI,EAAE,CAAC;SAC5B,CAAC;QACF,IAAI,CAAC,MAAM,CAAC,UAAU,GAAG;YACxB,KAAK,EAAE,GAAG,SAAS,IAAI;YACvB,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,IAAI,EAAE,CAAC;SACjC,CAAC;IACH,CAAC;IAEO,eAAe,CAAC,SAAc,EAAE,KAAU;QACjD,MAAM,QAAQ,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QACnD,MAAM,QAAQ,GAAG,IAAI,CAAC,qBAAqB,CAAC,SAAS,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC;QACpE,MAAM,IAAI,GAAkB,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;QAC/C,MAAM,CAAC,GAAQ;YACd,MAAM,EAAE,SAAS;YACjB,QAAQ;YACR,QAAQ;YACR,QAAQ,EAAE,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ;YACnC,IAAI,EAAE,EAAE,EAAE,EAAE,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,EAAE;SACjC,CAAC;QACF,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC;QACzB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,GAAG,QAAQ,CAAC;IAC9C,CAAC;IAEO,qBAAqB,CAAC,SAAc,EAAE,KAAU;QACvD,MAAM,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,WAAW,IAAI,OAAO,CAAC;QACtD,IAAI,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;YAC1B,MAAM,MAAM,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;YACxC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,EAAE,CAAC;iBAChC,MAAM,CAAC,CAAC,EAAO,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,aAAkB,EAAE,EAAE,CAAC,aAAa,IAAI,EAAE,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC;iBAC3F,GAAG,CAAC,CAAC,EAAO,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;iBACrC,MAAM,CAAC,CAAC,IAAS,EAAE,EAAE,CAAC,IAAI,KAAK,SAAS,IAAI,IAAI,KAAK,IAAI,IAAI,IAAI,KAAK,EAAE,CAAC;iBACzE,IAAI,CAAC,GAAG,CAAC,CAAC;QACb,CAAC;QACD,MAAM,IAAI,GAAG,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,EAAO,EAAE,EAAE,CAAC,EAAE,EAAE,CAAC,UAAU,CAAC,KAAK,KAAK,CAAC,CAAC;QACvF,OAAO,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IAC1C,CAAC;IAEO,YAAY,CAAC,KAAU;QAC9B,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;YAC1B,OAAO,KAAK,CAAC;QACd,CAAC;QACD,IAAI,KAAK,KAAK,EAAE,IAAI,KAAK,IAAI,IAAI,EAAE,CAAC;YACnC,OAAO,EAAE,CAAC;QACX,CAAC;QACD,OAAO,MAAM,CAAC,KAAK,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,KAAK,EAAE,CAAC,CAAC;IAC/D,CAAC;IAEO,aAAa,CAAC,KAAU;QAC/B,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,CAAC;YAC1B,OAAO,KAAK,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,KAAK,EAAE,IAAI,IAAI,IAAI,IAAI,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACtE,CAAC;QACD,IAAI,KAAK,KAAK,EAAE,IAAI,KAAK,IAAI,IAAI,EAAE,CAAC;YACnC,OAAO,EAAE,CAAC;QACX,CAAC;QACD,OAAO,MAAM,CAAC,KAAK,CAAC,CAAC;IACtB,CAAC;+GAtHW,iCAAiC;mGAAjC,iCAAiC,mJAIjB,gBAAgB,6BApIlC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EA6HT,2DACS,WAAW,igBAAE,mBAAmB,8BAAE,YAAY,yrCAAE,WAAW;;4FAEzD,iCAAiC;kBAlI7C,SAAS;mBAAC;oBACV,UAAU,EAAE,IAAI;oBAChB,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EA6HT;oBACD,OAAO,EAAE,CAAC,WAAW,EAAE,mBAAmB,EAAE,YAAY,EAAE,WAAW,CAAC;iBACtE;8BAKuD,KAAK;sBAA3D,SAAS;uBAAC,OAAO,EAAE,EAAE,IAAI,EAAE,gBAAgB,EAAE","sourcesContent":["import { Component, ViewChild, ViewContainerRef } 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';\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\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"]}
@@ -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,100 @@
1
+ import { Component } from '@angular/core';
2
+ import { resolveAsyncSelectOptions } from '../cell-utils/async-select-options';
3
+ import * as i0 from "@angular/core";
4
+ export class AsyncSelectLabelRenderer {
5
+ constructor() {
6
+ this.label = '';
7
+ this.loadId = 0;
8
+ }
9
+ agInit(params) {
10
+ this.refresh(params);
11
+ }
12
+ refresh(params) {
13
+ this.params = this.mergeParams(params);
14
+ void this.loadLabel();
15
+ return true;
16
+ }
17
+ async loadLabel() {
18
+ const loadId = ++this.loadId;
19
+ const value = this.params.value ?? this.params.data?.[this.params.colDef.field];
20
+ if (value === '' || value == null) {
21
+ this.label = '';
22
+ return;
23
+ }
24
+ const context = this.createContext(value);
25
+ try {
26
+ const options = await resolveAsyncSelectOptions(this.params, context);
27
+ if (loadId !== this.loadId) {
28
+ return;
29
+ }
30
+ this.label = this.formatLabel(value, options);
31
+ }
32
+ catch {
33
+ if (loadId === this.loadId) {
34
+ this.label = String(value);
35
+ }
36
+ }
37
+ }
38
+ mergeParams(params) {
39
+ const cellEditorParams = params.colDef?.cellEditorParams || {};
40
+ return {
41
+ ...cellEditorParams,
42
+ ...params,
43
+ optionLabel: params.optionLabel || cellEditorParams.optionLabel || 'label',
44
+ optionValue: params.optionValue || cellEditorParams.optionValue || 'value',
45
+ multiple: params.multiple ?? cellEditorParams.multiple,
46
+ };
47
+ }
48
+ createContext(value) {
49
+ return {
50
+ data: this.params.data,
51
+ value: this.params.multiple ? this.toValueString(value) : value,
52
+ params: this.params,
53
+ field: this.params.colDef.field,
54
+ colDef: this.params.colDef,
55
+ rowIndex: this.params.node?.rowIndex,
56
+ };
57
+ }
58
+ formatLabel(value, options) {
59
+ const valueField = this.params.optionValue || 'value';
60
+ const labelField = this.params.optionLabel || 'label';
61
+ if (this.params.multiple) {
62
+ const values = this.toValueArray(value);
63
+ const labels = values.map((item) => {
64
+ const option = options.find((opt) => opt?.[valueField] == item);
65
+ return option ? option?.[labelField] : item;
66
+ });
67
+ return labels.filter((item) => item !== undefined && item !== null && item !== '').join(',');
68
+ }
69
+ const option = options.find((opt) => opt?.[valueField] == value);
70
+ return option ? option?.[labelField] : String(value);
71
+ }
72
+ toValueArray(value) {
73
+ if (Array.isArray(value)) {
74
+ return value;
75
+ }
76
+ if (value === '' || value == null) {
77
+ return [];
78
+ }
79
+ return String(value).split(',').filter((item) => item !== '');
80
+ }
81
+ toValueString(value) {
82
+ if (Array.isArray(value)) {
83
+ return value.filter((item) => item !== '' && item != null).join(',');
84
+ }
85
+ if (value === '' || value == null) {
86
+ return '';
87
+ }
88
+ return String(value);
89
+ }
90
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AsyncSelectLabelRenderer, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
91
+ 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 }); }
92
+ }
93
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: AsyncSelectLabelRenderer, decorators: [{
94
+ type: Component,
95
+ args: [{
96
+ standalone: true,
97
+ template: `{{ label }}`,
98
+ }]
99
+ }] });
100
+ //# 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 } 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';\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\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"]}