@alauda-fe/dynamic-plugin-shared 0.0.1-alpha.12 → 0.0.1-alpha.13

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.
Files changed (60) hide show
  1. package/assets/images/overview-banner.svg +1 -0
  2. package/components/deleting-tag/component.d.ts +7 -0
  3. package/components/index.d.ts +6 -1
  4. package/components/list-display/component.d.ts +15 -0
  5. package/components/multi-search/action-input/component.d.ts +122 -0
  6. package/components/multi-search/form/component.d.ts +66 -0
  7. package/components/multi-search/index.d.ts +4 -0
  8. package/components/multi-search/multi-search-tags/component.d.ts +27 -0
  9. package/components/multi-search/types.d.ts +33 -0
  10. package/components/multi-search/utils.d.ts +24 -0
  11. package/components/mutable/directive.d.ts +83 -0
  12. package/components/mutable/element.d.ts +10 -0
  13. package/components/mutable/index.d.ts +8 -0
  14. package/components/mutable/mosaic/component.d.ts +32 -0
  15. package/components/mutable/mosaic/directive.d.ts +9 -0
  16. package/components/mutable/util.d.ts +18 -0
  17. package/components/overview-banner/component.d.ts +11 -0
  18. package/components/table/component.d.ts +88 -0
  19. package/components/table/constants.d.ts +3 -0
  20. package/components/table/helper.d.ts +2 -0
  21. package/components/table/helpers.directive.d.ts +21 -0
  22. package/components/table/index.d.ts +5 -0
  23. package/components/table/types.d.ts +71 -0
  24. package/components/table/util.service.d.ts +13 -0
  25. package/esm2022/components/deleting-tag/component.mjs +16 -0
  26. package/esm2022/components/index.mjs +7 -2
  27. package/esm2022/components/list-display/component.mjs +46 -0
  28. package/esm2022/components/multi-search/action-input/component.mjs +675 -0
  29. package/esm2022/components/multi-search/form/component.mjs +322 -0
  30. package/esm2022/components/multi-search/index.mjs +5 -0
  31. package/esm2022/components/multi-search/multi-search-tags/component.mjs +67 -0
  32. package/esm2022/components/multi-search/types.mjs +2 -0
  33. package/esm2022/components/multi-search/utils.mjs +46 -0
  34. package/esm2022/components/mutable/directive.mjs +351 -0
  35. package/esm2022/components/mutable/element.mjs +23 -0
  36. package/esm2022/components/mutable/index.mjs +15 -0
  37. package/esm2022/components/mutable/mosaic/component.mjs +76 -0
  38. package/esm2022/components/mutable/mosaic/directive.mjs +24 -0
  39. package/esm2022/components/mutable/util.mjs +16 -0
  40. package/esm2022/components/overview-banner/component.mjs +17 -0
  41. package/esm2022/components/table/component.mjs +321 -0
  42. package/esm2022/components/table/constants.mjs +4 -0
  43. package/esm2022/components/table/helper.mjs +16 -0
  44. package/esm2022/components/table/helpers.directive.mjs +19 -0
  45. package/esm2022/components/table/index.mjs +6 -0
  46. package/esm2022/components/table/types.mjs +2 -0
  47. package/esm2022/components/table/util.service.mjs +81 -0
  48. package/esm2022/form/base-form-container.mjs +2 -2
  49. package/esm2022/k8s-resource-list/footer/component.mjs +3 -3
  50. package/esm2022/page-deactivate/deactivate.directive.mjs +2 -2
  51. package/esm2022/page-deactivate/deactivate.guard.mjs +2 -3
  52. package/esm2022/page-deactivate/deactivate.service.mjs +4 -14
  53. package/fesm2022/alauda-fe-dynamic-plugin-shared.mjs +2228 -222
  54. package/fesm2022/alauda-fe-dynamic-plugin-shared.mjs.map +1 -1
  55. package/package.json +1 -1
  56. package/page-deactivate/deactivate.guard.d.ts +0 -2
  57. package/page-deactivate/deactivate.service.d.ts +1 -1
  58. package/styles/lib.scss +1 -1
  59. package/components/terminating-tag/component.d.ts +0 -7
  60. package/esm2022/components/terminating-tag/component.mjs +0 -16
@@ -0,0 +1,675 @@
1
+ import { __decorate, __metadata } from "tslib";
2
+ import { CheckboxComponent, TooltipDirective, InputComponent, ButtonComponent, } from '@alauda/ui';
3
+ import { AsyncPipe, NgClass, NgFor, NgIf, NgTemplateOutlet, } from '@angular/common';
4
+ import { ChangeDetectionStrategy, Component, EventEmitter, HostBinding, Inject, Injector, Input, Output, ViewChild, forwardRef, } from '@angular/core';
5
+ import { FormsModule } from '@angular/forms';
6
+ import { cloneDeep, debounce } from 'lodash-es';
7
+ import { BaseResourceFormComponent } from 'ng-resource-form-util';
8
+ import { BehaviorSubject, combineLatest, map, Observable, takeUntil, } from 'rxjs';
9
+ import { DEFAULT_OPERATOR, MultiSearchComponent } from '../form/component';
10
+ import { PurePipe } from '../../../pipes';
11
+ import { TranslatePipe } from '@alauda-fe/dynamic-plugin-sdk';
12
+ import { ObservableInput, publishRef } from '../../../utils';
13
+ import * as i0 from "@angular/core";
14
+ import * as i1 from "@angular/forms";
15
+ import * as i2 from "../form/component";
16
+ var KeyCode;
17
+ (function (KeyCode) {
18
+ KeyCode["DELETE"] = "Backspace";
19
+ KeyCode["ENTER"] = "Enter";
20
+ KeyCode["TAB"] = "Tab";
21
+ KeyCode["ArrowDown"] = "ArrowDown";
22
+ KeyCode["ArrowUp"] = "ArrowUp";
23
+ })(KeyCode || (KeyCode = {}));
24
+ const ARROW_EVENTS = new Set([KeyCode.ArrowDown, KeyCode.ArrowUp]);
25
+ const DROPDOWN_ITEM_CLASS = 'search-dropdown-item';
26
+ export class MultiSearchActionInputComponent extends BaseResourceFormComponent {
27
+ get hiddenState() {
28
+ return this.hidden;
29
+ }
30
+ get conditionsModel() {
31
+ return this.conditionsModel$$.value;
32
+ }
33
+ set conditionsModel(v) {
34
+ this.conditionsModel$$.next(v);
35
+ }
36
+ valuesFilter(conditions, condition, separator, isMulti = false) {
37
+ const searchVal = this.getMultiSearchVal(separator);
38
+ const already = conditions.some(condition => this.getValueLabel(condition) === searchVal);
39
+ return ((isMulti && already) || this.getValueLabel(condition).includes(searchVal));
40
+ }
41
+ get isConditionSelecting() {
42
+ return !this.form?.value;
43
+ }
44
+ get isOperatorSelecting() {
45
+ return this.form?.value && !this.form.value.operator;
46
+ }
47
+ get isValueSelecting() {
48
+ return this.form?.value && this.form.value.operator;
49
+ }
50
+ get isInitialized() {
51
+ return this.isConditionSelecting && !this.conditionsModel;
52
+ }
53
+ get isOperationComplete() {
54
+ const activeCondition = this.form.value;
55
+ return (activeCondition?.selectedValues?.length &&
56
+ activeCondition?.operator &&
57
+ activeCondition.condition);
58
+ }
59
+ get isSelectAll() {
60
+ if (!this.isValueSelecting)
61
+ return false;
62
+ const conditionsModel = this.conditionsModel;
63
+ const activeCondition = this.form.value;
64
+ const valueLabels = conditionsModel
65
+ ? conditionsModel.split(this.getSeparator(activeCondition))
66
+ : [];
67
+ return activeCondition.values?.every(value => valueLabels?.some(label => this.getValueLabel(value) === label));
68
+ }
69
+ get isIndeterminate() {
70
+ if (!this.isValueSelecting || this.isSelectAll)
71
+ return false;
72
+ const conditionsModel = this.conditionsModel;
73
+ const activeCondition = this.form.value;
74
+ const valueLabels = conditionsModel
75
+ ? conditionsModel.split(this.getSeparator(activeCondition))
76
+ : [];
77
+ return activeCondition.values?.some(value => valueLabels?.some(label => this.getValueLabel(value) === label));
78
+ }
79
+ get inputElement() {
80
+ return this.inputRef?.elementRef?.nativeElement;
81
+ }
82
+ get optionElements() {
83
+ return document.querySelectorAll(`.${DROPDOWN_ITEM_CLASS}`);
84
+ }
85
+ constructor(injector, multiSearch) {
86
+ super(injector);
87
+ this.injector = injector;
88
+ this.multiSearch = multiSearch;
89
+ // 是否为编辑态
90
+ this.isEditing = false;
91
+ // 完成事件
92
+ this.completed = new EventEmitter();
93
+ // 转换为编辑态
94
+ this.editing = new EventEmitter();
95
+ // 键盘delete事件。
96
+ this.delete = new EventEmitter();
97
+ // 键盘enter事件
98
+ this.search = new EventEmitter();
99
+ this._conditionsModel = '';
100
+ this.conditionsModel$$ = new BehaviorSubject('');
101
+ this.hasFilteredConditions$ = combineLatest([
102
+ this.conditionConfig$,
103
+ this.conditionsModel$$,
104
+ this.existingConditions$,
105
+ ]).pipe(map(([conditionConfig, model, existingConditions]) => {
106
+ return (!model ||
107
+ conditionConfig?.filter(config => this.getConditionLabel(config)?.includes(model) &&
108
+ this.conditionFilterByExists(config, existingConditions))?.length > 0);
109
+ }), publishRef());
110
+ this.conditionsShouldShow$ = combineLatest([
111
+ this.conditionConfig$,
112
+ this.conditionsModel$$,
113
+ this.existingConditions$,
114
+ ]).pipe(map(([conditionConfig, model, existingConditions]) => {
115
+ return (model ||
116
+ conditionConfig?.filter(config => this.conditionFilterByExists(config, existingConditions))?.length > 0);
117
+ }), publishRef());
118
+ this.normalConditionsResource$ = combineLatest([
119
+ this.conditionConfig$,
120
+ this.existingConditions$,
121
+ ]).pipe(map(([conditionConfig, existingConditions]) => conditionConfig?.filter(config => !config.condition.group &&
122
+ this.conditionFilterByExists(config, existingConditions))), publishRef());
123
+ this.normalConditions$ = combineLatest([
124
+ this.normalConditionsResource$,
125
+ this.conditionsModel$$,
126
+ ]).pipe(map(([normalConditions, model]) => {
127
+ return normalConditions.filter(condition => !model || this.getConditionLabel(condition)?.includes(model));
128
+ }));
129
+ this.groupConditionsResource$ = combineLatest([
130
+ this.conditionConfig$,
131
+ this.existingConditions$,
132
+ ]).pipe(map(([conditionConfig, existingConditions]) => conditionConfig?.filter(config => config.condition.group &&
133
+ this.conditionFilterByExists(config, existingConditions))), map(conditionConfig => {
134
+ return this.resolveGroup(conditionConfig, config => config.condition.group);
135
+ }), publishRef());
136
+ this.groupConditions$ = combineLatest([
137
+ this.groupConditionsResource$,
138
+ this.conditionsModel$$,
139
+ ]).pipe(map(([groupConditions, model]) => {
140
+ return groupConditions.map(group => ({
141
+ group: group.group,
142
+ member: group.member.filter(condition => !model || this.getConditionLabel(condition).includes(model)),
143
+ }));
144
+ }));
145
+ this.hasFilteredValues = (activeCondition, model, isMulti = false) => {
146
+ const values = activeCondition?.values;
147
+ if (!model)
148
+ return values?.length > 0;
149
+ return (values?.filter(value => this.valuesFilter(values, value, this.getSeparator(activeCondition), isMulti))?.length > 0);
150
+ };
151
+ this.getNormalValues = (activeCondition, model, isMulti = false) => {
152
+ const normalConditions = activeCondition.values?.filter(value => !value.group);
153
+ if (!model)
154
+ return normalConditions;
155
+ return normalConditions?.filter(condition => this.valuesFilter(activeCondition.values, condition, this.getSeparator(activeCondition), isMulti));
156
+ };
157
+ this.getValuesGroup = (activeCondition, model, isMulti) => {
158
+ const groupCondition = activeCondition.values?.filter(value => value.group);
159
+ const groups = this.resolveGroup(groupCondition, value => value.group);
160
+ if (!model)
161
+ return groups;
162
+ return groups?.map(group => ({
163
+ group: group.group,
164
+ member: group.member.filter(condition => this.valuesFilter(activeCondition.values, condition, this.getSeparator(activeCondition), isMulti)),
165
+ }));
166
+ };
167
+ // 键盘操作指针
168
+ this.arrowCursor = -1;
169
+ this.MAX_SAFE_INTEGER = Number.MAX_SAFE_INTEGER;
170
+ this.DEFAULT_OPERATOR = DEFAULT_OPERATOR;
171
+ this.DROPDOWN_ITEM_CLASS = DROPDOWN_ITEM_CLASS;
172
+ this.selectAllClick = debounce(() => {
173
+ if (this.isSelectAll) {
174
+ this.deselectAllValues();
175
+ }
176
+ else {
177
+ this.selectAllValues();
178
+ }
179
+ this.refreshCursor();
180
+ }, 50);
181
+ this.getValueContent = (condition) => {
182
+ return condition?.selectedValues
183
+ ?.map(value => value.label || value.value)
184
+ ?.join(this.getSeparator(condition));
185
+ };
186
+ this.isValueSelected = (current, conditionsModel, condition) => {
187
+ return conditionsModel
188
+ ?.split(this.getSeparator(condition))
189
+ ?.includes(current);
190
+ };
191
+ this.resolveHideSync();
192
+ this.resolveFormModelChangeSync();
193
+ }
194
+ resolveHideSync() {
195
+ this.hidden$.pipe(takeUntil(this.destroy$)).subscribe(hidden => {
196
+ // 控件被隐藏时,确保tooltip也一并隐藏
197
+ if (hidden) {
198
+ this.toolTipHide();
199
+ }
200
+ });
201
+ }
202
+ // input内容发生变化时,确保formModel也同步更新
203
+ resolveFormModelChangeSync() {
204
+ this.conditionsModel$$
205
+ .pipe(takeUntil(this.destroy$))
206
+ .subscribe(conditionsModel => {
207
+ if (this.isValueSelecting) {
208
+ this.valuesSync(conditionsModel);
209
+ }
210
+ });
211
+ }
212
+ conditionSync(conditionsModel) {
213
+ const config = this.conditionConfig?.find(config => this.getConditionLabel(config) === conditionsModel);
214
+ let activeCondition = {
215
+ condition: { value: conditionsModel },
216
+ };
217
+ if (config) {
218
+ activeCondition = { ...config };
219
+ // 当operators只有一个选项时,会默认选中
220
+ if (config.operators?.length === 1) {
221
+ activeCondition.operator = config.operators[0];
222
+ }
223
+ else if (!config.operators?.length) {
224
+ activeCondition.operator = DEFAULT_OPERATOR;
225
+ }
226
+ }
227
+ else {
228
+ activeCondition.operator = DEFAULT_OPERATOR;
229
+ }
230
+ activeCondition.isEditing = true;
231
+ this.form.reset(activeCondition);
232
+ }
233
+ valuesSync(conditionsModel) {
234
+ const activeCondition = this.form.value;
235
+ const valueLabels = conditionsModel
236
+ ? conditionsModel.split(this.getSeparator(activeCondition))
237
+ : [];
238
+ const conditions = valueLabels.map(label => {
239
+ const find = activeCondition.values?.find(value => this.getValueLabel(value) === label);
240
+ return find || { label, value: label };
241
+ });
242
+ this.setValues(conditions);
243
+ }
244
+ createForm() {
245
+ return this.fb.control(null);
246
+ }
247
+ adaptResourceModel(resource) {
248
+ if (this.isEditing) {
249
+ this.initModel(resource);
250
+ }
251
+ else {
252
+ this.manualFocus();
253
+ }
254
+ return resource;
255
+ }
256
+ initModel(condition) {
257
+ if ((this.conditionsModel = this.getValueContent(condition))) {
258
+ this.manualFocus();
259
+ }
260
+ }
261
+ // 设置当前操作的condition
262
+ selectActiveCondition(conditionConfig) {
263
+ this.resetArrowCursor();
264
+ this.changeToEditing();
265
+ // 只在点击事件中设置form.value
266
+ this.conditionsModel = this.getConditionLabel(conditionConfig);
267
+ this.setConditionByModel();
268
+ }
269
+ setConditionByModel() {
270
+ this.conditionSync(this.conditionsModel);
271
+ this.conditionsModel = null;
272
+ this.manualFocus();
273
+ this.refreshCursor();
274
+ }
275
+ // 选择当前condition的operator
276
+ selectActiveOperator(operator) {
277
+ this.resetArrowCursor();
278
+ this.changeToEditing();
279
+ // operator选择不依赖resolveFormModelChangeSync,只依赖选择
280
+ this.setActiveOperator(operator);
281
+ this.conditionsModel = null;
282
+ this.manualFocus();
283
+ }
284
+ // 选择条件
285
+ // 多选不会重置arrowCursor,当激活arrowCursor时,需要tab完成多选事件
286
+ selectValue(condition, isMulti) {
287
+ this.changeToEditing();
288
+ // 利用resolveFormModelChangeSync设置form.value.selectedValues
289
+ if (isMulti) {
290
+ this.selectMultiValue(condition);
291
+ this.refreshCursor();
292
+ }
293
+ else {
294
+ this.resetArrowCursor();
295
+ const currentLabel = this.getValueLabel(condition);
296
+ this.conditionsModel = currentLabel;
297
+ // 如果是单选,则需要在选中时抛出complete事件,并抛出search事件
298
+ this.ifComplete(false, true);
299
+ this.search.emit();
300
+ }
301
+ }
302
+ // 多选
303
+ selectMultiValue(condition) {
304
+ const activeCondition = this.form.value;
305
+ const currentLabel = this.getValueLabel(condition);
306
+ const separator = this.getSeparator(activeCondition);
307
+ const selected = activeCondition.selectedValues?.map(value => this.getValueLabel(value)) ||
308
+ [];
309
+ const find = selected.includes(currentLabel);
310
+ if (find) {
311
+ const idx = selected.indexOf(currentLabel);
312
+ selected.splice(idx, 1);
313
+ }
314
+ else {
315
+ const lastVal = selected?.at(-1);
316
+ // 只有当输入的内容不存在于选项中时,才能算是searchVal
317
+ const searchVal = activeCondition.values?.some(v => this.getValueLabel(v) === lastVal)
318
+ ? ''
319
+ : selected?.at(-1);
320
+ // 如果当前选中的值包含末尾用户的输入值,则代表应该补全而非末尾处新增
321
+ /**
322
+ * 如:
323
+ * 输入框中为 value1|value2|val
324
+ * 若此时选择下拉选项中的 value3,应补全为value1|value2|value3
325
+ * 若此时选择了 xxxx,则结果应为value1|value2|val|xxxx
326
+ */
327
+ if (searchVal && currentLabel.includes(searchVal)) {
328
+ selected.pop();
329
+ }
330
+ selected.push(currentLabel);
331
+ }
332
+ this.conditionsModel = selected.join(separator);
333
+ }
334
+ selectAllValues() {
335
+ const conditionsModel = this.conditionsModel;
336
+ const activeCondition = this.form.value;
337
+ const valueLabels = conditionsModel
338
+ ? conditionsModel.split(this.getSeparator(activeCondition))
339
+ : [];
340
+ const shouldPush = activeCondition.values
341
+ ?.filter(value => valueLabels?.every(label => this.getValueLabel(value) !== label))
342
+ ?.map(condition => this.getValueLabel(condition));
343
+ const final = [...valueLabels, ...shouldPush];
344
+ this.conditionsModel = final.join(this.getSeparator(activeCondition));
345
+ }
346
+ deselectAllValues() {
347
+ const conditionsModel = this.conditionsModel;
348
+ const activeCondition = this.form.value;
349
+ const valueLabels = conditionsModel
350
+ ? conditionsModel.split(this.getSeparator(activeCondition))
351
+ : [];
352
+ const final = valueLabels.filter(label => activeCondition.values.every(value => this.getValueLabel(value) !== label));
353
+ this.conditionsModel = final.join(this.getSeparator(activeCondition));
354
+ }
355
+ // 点击操作中已选择的类目
356
+ activeConditionClick() {
357
+ this.changeToEditing();
358
+ this.conditionsModel = this.getConditionLabel(this.form.value);
359
+ this.clearActiveCondition();
360
+ this.manualFocus();
361
+ }
362
+ // 点击操作中已选择的operator
363
+ activeOperatorClick() {
364
+ this.changeToEditing();
365
+ this.conditionsModel = null;
366
+ this.setActiveOperator(null);
367
+ this.setValues([]);
368
+ this.manualFocus();
369
+ }
370
+ // 点击操作中已选择的条件
371
+ activeValueClick() {
372
+ this.changeToEditing();
373
+ const activeCondition = this.form.value;
374
+ this.conditionsModel = this.getValueContent(activeCondition);
375
+ this.manualFocus();
376
+ }
377
+ setActiveOperator(operator) {
378
+ this.form.patchValue({ ...this.form.value, operator });
379
+ }
380
+ setValues(conditions) {
381
+ this.form.patchValue({
382
+ ...this.form.value,
383
+ selectedValues: conditions,
384
+ });
385
+ }
386
+ clearActiveCondition() {
387
+ this.form.patchValue(null);
388
+ }
389
+ changeToEditing() {
390
+ if (!this.isEditing) {
391
+ this.editing.emit();
392
+ }
393
+ }
394
+ inputFocus() {
395
+ this.multiSearch.setFocus(true);
396
+ this.toolTipShow();
397
+ }
398
+ inputKeydown(e) {
399
+ switch (e.code) {
400
+ case KeyCode.DELETE: {
401
+ this.resolveDeleteEvent();
402
+ break;
403
+ }
404
+ case KeyCode.ENTER: {
405
+ this.resolveEnterEvent();
406
+ break;
407
+ }
408
+ case KeyCode.TAB: {
409
+ this.resolveTabEvent();
410
+ break;
411
+ }
412
+ default: {
413
+ if (ARROW_EVENTS.has(e.code)) {
414
+ this.resolveArrowEvent(e);
415
+ }
416
+ else {
417
+ // 删除状态时,若输入内容,则会转变为编辑状态
418
+ this.changeToEditingIfNeed();
419
+ // 输入内容时,会自动打开tooltip
420
+ this.toolTipShow();
421
+ }
422
+ }
423
+ }
424
+ }
425
+ confirmSelection() {
426
+ this.resolveEnterEvent();
427
+ }
428
+ changeToEditingIfNeed() {
429
+ if (!this.isEditing) {
430
+ if (this.isConditionSelecting) {
431
+ this.activeConditionClick();
432
+ }
433
+ else if (this.isValueSelecting) {
434
+ this.activeValueClick();
435
+ }
436
+ }
437
+ }
438
+ resolveTabEvent() {
439
+ // 当激活arrowCursor时,tab事件会切换为enter事件交互
440
+ if (this.arrowCursor > -1) {
441
+ this.resetArrowCursor();
442
+ this.resolveEnterEvent();
443
+ }
444
+ else {
445
+ requestAnimationFrame(() => {
446
+ this.ifComplete();
447
+ this.multiSearch.manualBlur();
448
+ });
449
+ }
450
+ }
451
+ resolveArrowEvent(e) {
452
+ const options = this.optionElements;
453
+ const length = options.length;
454
+ if (e.code === KeyCode.ArrowDown) {
455
+ this.arrowCursor =
456
+ this.arrowCursor === length - 1 ? 0 : this.arrowCursor + 1;
457
+ }
458
+ else if (e.code === KeyCode.ArrowUp) {
459
+ this.arrowCursor =
460
+ this.arrowCursor === 0 ? length - 1 : this.arrowCursor - 1;
461
+ }
462
+ options.forEach(option => option.classList.remove('cursor-light'));
463
+ options.item(this.arrowCursor)?.classList?.add('cursor-light');
464
+ e.preventDefault();
465
+ }
466
+ resolveDeleteEvent() {
467
+ if (!this.conditionsModel) {
468
+ const activeCondition = cloneDeep(this.form.value);
469
+ // 若当前存在activeCondition内容,则需要先删除当前内容,删除完成后再触发删除联动
470
+ if (activeCondition) {
471
+ this.deleteSelf(activeCondition);
472
+ // 自动展示选项
473
+ this.manualFocus();
474
+ }
475
+ else {
476
+ if (this.resourceModel) {
477
+ this._complete(null);
478
+ }
479
+ this.delete.emit();
480
+ }
481
+ }
482
+ }
483
+ resolveEnterEvent() {
484
+ if (this.arrowCursor > -1) {
485
+ this.optionElements.item(this.arrowCursor)?.click();
486
+ }
487
+ else {
488
+ // 当前操作内容已完成,,则会抛出enter事件
489
+ if (this.ifComplete(false, true)) {
490
+ this.search.emit();
491
+ }
492
+ else if (this.conditionCreatable && this.isConditionSelecting) {
493
+ this.setConditionByModel();
494
+ }
495
+ }
496
+ }
497
+ deleteSelf(activeCondition) {
498
+ // 此时,先删除operator,再删除当前activeCondition,并抛出complete事件
499
+ if (activeCondition.selectedValues?.length) {
500
+ activeCondition.selectedValues.pop();
501
+ this.setValues(activeCondition.selectedValues);
502
+ }
503
+ else if (activeCondition.operator) {
504
+ this.setActiveOperator(null);
505
+ }
506
+ else {
507
+ // 清空后,需要在下一次delete时才会从数据源中删除,在此期间,依旧可以重新进行编辑操作
508
+ this.clearActiveCondition();
509
+ }
510
+ }
511
+ resetArrowCursor() {
512
+ this.arrowCursor = -1;
513
+ }
514
+ manualFocus(silence) {
515
+ requestAnimationFrame(() => {
516
+ if (this.autoScroll) {
517
+ this.inputElement?.scrollIntoView({
518
+ behavior: 'smooth',
519
+ });
520
+ }
521
+ this.inputElement?.focus();
522
+ if (silence) {
523
+ this.toolTipHide();
524
+ }
525
+ else {
526
+ this.refreshDropdown();
527
+ }
528
+ });
529
+ }
530
+ manualBlur() {
531
+ this.toolTipHide();
532
+ requestAnimationFrame(() => {
533
+ this.inputElement?.blur();
534
+ });
535
+ }
536
+ refreshDropdown() {
537
+ if (this.hidden)
538
+ return;
539
+ this.toolTipHide();
540
+ this.toolTipShow();
541
+ }
542
+ refreshCursor() {
543
+ requestAnimationFrame(() => {
544
+ this.inputElement?.blur();
545
+ this.inputElement?.focus();
546
+ });
547
+ }
548
+ toolTipHide() {
549
+ this.toolTipRef?.hide();
550
+ }
551
+ toolTipShow() {
552
+ this.toolTipRef?.show();
553
+ }
554
+ ifComplete(toContinue = false, manualFocus = false) {
555
+ const activeCondition = this.form.value;
556
+ // 完成所有选项,或者内容为空,则代表complete
557
+ if (this.isOperationComplete || this.isInitialized) {
558
+ this._complete(activeCondition, toContinue, manualFocus);
559
+ return true;
560
+ }
561
+ }
562
+ _complete(activeCondition, toContinue = false, manualFocus = true) {
563
+ this.toolTipHide();
564
+ this.completed.emit({ activeCondition, toContinue, manualFocus });
565
+ this.clearActiveCondition();
566
+ this.initModel(null);
567
+ }
568
+ conditionFilterByExists(condition, existingConditions) {
569
+ return existingConditions.every(exist => condition.condition.value !== exist.condition.value ||
570
+ exist.condition.value === this.resourceModel?.condition?.value);
571
+ }
572
+ resolveGroup(items, getGroupKey) {
573
+ const groups = [];
574
+ items?.forEach(config => {
575
+ const groupKey = getGroupKey(config);
576
+ const find = groups.find(group => group.group === groupKey);
577
+ if (find) {
578
+ find.member.push(config);
579
+ }
580
+ else {
581
+ groups.push({
582
+ group: groupKey,
583
+ member: [config],
584
+ });
585
+ }
586
+ });
587
+ return groups;
588
+ }
589
+ getConditionLabel(condition) {
590
+ return condition?.condition?.label ?? condition?.condition?.value;
591
+ }
592
+ getSeparator(condition) {
593
+ return condition.separator ?? ' | ';
594
+ }
595
+ getValueLabel(value) {
596
+ return value.label ?? value.value;
597
+ }
598
+ getMultiSearchVal(separator) {
599
+ const latestSeparatorIdx = this.conditionsModel?.lastIndexOf(separator);
600
+ return latestSeparatorIdx >= 0
601
+ ? this.conditionsModel.slice(latestSeparatorIdx + separator.length)
602
+ : this.conditionsModel;
603
+ }
604
+ isConditionSelected(current, conditionsModel) {
605
+ return conditionsModel === current;
606
+ }
607
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.1", ngImport: i0, type: MultiSearchActionInputComponent, deps: [{ token: i0.Injector }, { token: forwardRef(() => MultiSearchComponent) }], target: i0.ɵɵFactoryTarget.Component }); }
608
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.1.1", type: MultiSearchActionInputComponent, isStandalone: true, selector: "acl-multi-search-action-input", inputs: { placeholder: "placeholder", conditionCreatable: "conditionCreatable", isEditing: "isEditing", hidden: "hidden", autoScroll: "autoScroll", conditionConfig: "conditionConfig", showFootAction: "showFootAction", existingConditions: "existingConditions" }, outputs: { completed: "completed", editing: "editing", delete: "delete", search: "search" }, host: { properties: { "hidden": "this.hiddenState" } }, viewQueries: [{ propertyName: "inputRef", first: true, predicate: ["inputRef"], descendants: true }, { propertyName: "toolTipRef", first: true, predicate: ["toolTipRef"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"tw-flex tw-items-center tw-text-m\">\n <ng-container *ngIf=\"form.value as activeCondition\">\n <span\n class=\"tw-ml-6 tw-max-w-[45%] tw-flex-shrink-0 tw-text-ellipsis tw-overflow-hidden\"\n (click)=\"activeConditionClick(); $event.stopPropagation()\"\n >\n {{ activeCondition | pure: getConditionLabel }}\n </span>\n <span\n *ngIf=\"activeCondition.operator\"\n class=\"tw-ml-6\"\n (click)=\"activeOperatorClick(); $event.stopPropagation()\"\n >\n {{ activeCondition.operator }}\n </span>\n <span\n *ngIf=\"!isEditing\"\n class=\"tw-ml-6 tw-max-w-[45%] tw-flex-shrink-0 tw-text-ellipsis tw-overflow-hidden\"\n (click)=\"activeValueClick(); $event.stopPropagation()\"\n >\n {{ getValueContent(activeCondition) }}\n </span>\n </ng-container>\n <input\n class=\"search-input\"\n [ngClass]=\"{\n 'mock-input':\n (!isEditing && !isConditionSelecting) || isOperatorSelecting,\n }\"\n [maxlength]=\"isOperatorSelecting ? 0 : MAX_SAFE_INTEGER\"\n aui-input\n #inputRef\n #toolTipRef=\"auiTooltip\"\n [placeholder]=\"isConditionSelecting ? placeholder : ''\"\n [(ngModel)]=\"conditionsModel\"\n (ngModelChange)=\"conditionsModel$$.next($event)\"\n (keydown)=\"inputKeydown($event)\"\n (focus)=\"inputFocus()\"\n [auiTooltip]=\"templateRef\"\n auiTooltipAnimType=\"none\"\n auiTooltipTrigger=\"manual\"\n auiTooltipType=\"info\"\n auiTooltipClass=\"multi-search-dropdown\"\n auiTooltipPosition=\"bottom start\"\n />\n</div>\n\n<ng-template #templateRef>\n <div\n (mousedown)=\"$event.preventDefault()\"\n (click)=\"$event.stopPropagation()\"\n >\n <!-- \u7C7B\u76EE\u9009\u62E9 -->\n <ng-container\n *ngIf=\"isConditionSelecting && (conditionsShouldShow$ | async)\"\n >\n <ul\n *ngIf=\"hasFilteredConditions$ | async; else nonFilteredCategories\"\n class=\"tw-min-w-[260px] tw-max-w-[400px]\"\n >\n <ng-container\n [ngTemplateOutlet]=\"categoriesTemp\"\n [ngTemplateOutletContext]=\"{\n normal: (normalConditions$ | async),\n groups: groupConditions$ | async,\n }\"\n ></ng-container>\n </ul>\n\n <ng-template #nonFilteredCategories>\n <ul class=\"tw-min-w-[260px] tw-max-w-[400px]\">\n <div class=\"no-match-categories-tip\">\n {{ 'no_match_categories_tip' | translate }}\n </div>\n <ng-container\n [ngTemplateOutlet]=\"categoriesTemp\"\n [ngTemplateOutletContext]=\"{\n normal: normalConditionsResource$ | async,\n groups: groupConditionsResource$ | async,\n }\"\n ></ng-container>\n </ul>\n </ng-template>\n\n <ng-template\n #categoriesTemp\n let-normal=\"normal\"\n let-groups=\"groups\"\n >\n <ng-container\n [ngTemplateOutlet]=\"liConditionTemp\"\n [ngTemplateOutletContext]=\"{ conditions: normal }\"\n ></ng-container>\n\n <ng-container *ngFor=\"let group of groups\">\n <ng-container *ngIf=\"group.member?.length\">\n <div\n [title]=\"group.group\"\n class=\"dropdown-group-label dropdown-content\"\n >\n {{ group.group }}\n </div>\n\n <ng-container\n [ngTemplateOutlet]=\"liConditionTemp\"\n [ngTemplateOutletContext]=\"{ conditions: group.member }\"\n ></ng-container>\n </ng-container>\n </ng-container>\n </ng-template>\n </ng-container>\n\n <ng-container *ngIf=\"form.value as activeCondition\">\n <!-- operator\u9009\u62E9 -->\n <ng-container *ngIf=\"isOperatorSelecting\">\n <ul class=\"tw-min-w-[160px]\">\n <li\n (click)=\"selectActiveOperator($any(operator))\"\n *ngFor=\"\n let operator of activeCondition.operators || [DEFAULT_OPERATOR]\n \"\n >\n <ng-container\n [ngTemplateOutlet]=\"basicLiContentTemp\"\n [ngTemplateOutletContext]=\"{\n isSelect: operator === conditionsModel,\n label: operator,\n }\"\n >\n </ng-container>\n </li>\n </ul>\n </ng-container>\n\n <!-- \u5177\u4F53\u6761\u4EF6\u9009\u62E9 -->\n <ng-container *ngIf=\"isValueSelecting\">\n <ul\n *ngIf=\"\n activeCondition\n | pure\n : hasFilteredValues\n : conditionsModel\n : activeCondition.isMulti\n \"\n class=\"tw-min-w-[260px] tw-max-w-[400px]\"\n >\n <li\n *ngIf=\"activeCondition.allowSelectAll && activeCondition.isMulti\"\n class=\"dropdown-content select-all\"\n >\n <div\n class=\"search-dropdown-item\"\n [ngClass]=\"{\n 'tw-text-p-2': isSelectAll,\n 'tw-bg-p-6': isSelectAll,\n }\"\n (click)=\"selectAllClick()\"\n >\n <div class=\"multi-item\">\n <aui-checkbox\n [value]=\"isSelectAll\"\n [indeterminate]=\"isIndeterminate\"\n ></aui-checkbox>\n <div class=\"search-dropdown-item-label\">\n {{ 'all' | translate }}\n </div>\n </div>\n </div>\n </li>\n <ng-container\n [ngTemplateOutlet]=\"liValueTemp\"\n [ngTemplateOutletContext]=\"{\n values:\n activeCondition\n | pure\n : getNormalValues\n : conditionsModel\n : activeCondition.isMulti,\n activeCondition: activeCondition,\n }\"\n >\n </ng-container>\n\n <ng-container\n *ngFor=\"\n let group of activeCondition\n | pure\n : getValuesGroup\n : conditionsModel\n : activeCondition.isMulti\n \"\n >\n <ng-container *ngIf=\"group.member?.length\">\n <div\n [title]=\"group.group\"\n class=\"dropdown-group-label dropdown-content\"\n >\n {{ group.group }}\n </div>\n\n <ng-container\n [ngTemplateOutlet]=\"liValueTemp\"\n [ngTemplateOutletContext]=\"{\n values: group.member,\n activeCondition: activeCondition,\n }\"\n ></ng-container>\n </ng-container>\n </ng-container>\n </ul>\n </ng-container>\n </ng-container>\n <ng-container *ngIf=\"showFootAction && form?.value?.isMulti\">\n <div class=\"footer\">\n <button\n aui-button=\"text\"\n size=\"mini\"\n (click)=\"confirmSelection()\"\n >\n {{ 'confirm' | translate }}\n </button>\n <button\n aui-button=\"text\"\n size=\"mini\"\n class=\"cancel\"\n (click)=\"toolTipHide()\"\n >\n {{ 'cancel' | translate }}\n </button>\n </div>\n </ng-container>\n </div>\n</ng-template>\n\n<ng-template\n #liConditionTemp\n let-conditions=\"conditions\"\n>\n <li\n class=\"dropdown-content\"\n *ngFor=\"let condition of conditions\"\n (click)=\"selectActiveCondition(condition)\"\n >\n <ng-container\n [ngTemplateOutlet]=\"basicLiContentTemp\"\n [ngTemplateOutletContext]=\"{\n isSelect:\n condition\n | pure: getConditionLabel\n | pure: isConditionSelected : conditionsModel,\n label: condition | pure: getConditionLabel,\n }\"\n >\n </ng-container>\n </li>\n</ng-template>\n\n<ng-template\n #liValueTemp\n let-values=\"values\"\n let-activeCondition=\"activeCondition\"\n>\n <li\n class=\"dropdown-content\"\n *ngFor=\"let value of values\"\n (click)=\"\n selectValue(value, activeCondition.isMulti);\n $event.stopPropagation();\n $event.preventDefault()\n \"\n >\n <ng-container\n [ngTemplateOutlet]=\"basicLiContentTemp\"\n [ngTemplateOutletContext]=\"{\n isSelect:\n value\n | pure: getValueLabel\n | pure\n : isValueSelected\n : conditionsModel || (form.value | pure: getValueContent)\n : activeCondition,\n label: value | pure: getValueLabel,\n isMulti: activeCondition.isMulti,\n }\"\n >\n </ng-container>\n </li>\n</ng-template>\n\n<ng-template\n #basicLiContentTemp\n let-isSelect=\"isSelect\"\n let-label=\"label\"\n let-isMulti=\"isMulti\"\n>\n <div\n [class]=\"DROPDOWN_ITEM_CLASS\"\n [ngClass]=\"{\n 'is-multi-value-select': isSelect,\n }\"\n >\n <div\n class=\"multi-item\"\n *ngIf=\"isMulti\"\n >\n <aui-checkbox [value]=\"isSelect\"></aui-checkbox>\n <div\n [title]=\"label\"\n class=\"search-dropdown-item-label\"\n >\n {{ label }}\n </div>\n </div>\n <div\n [title]=\"label\"\n class=\"search-dropdown-item-label\"\n *ngIf=\"!isMulti\"\n >\n {{ label }}\n </div>\n </div>\n</ng-template>\n", styles: [":host{display:block;padding-top:5px}.search-input{border:none;box-shadow:none!important;height:22px}.mock-input{width:1px!important;flex-shrink:0;padding:0;margin-left:7px}::ng-deep .multi-search-dropdown{padding:0!important;margin-top:8px!important;cursor:pointer;max-height:284px;overflow-y:auto}::ng-deep .multi-search-dropdown ul .dropdown-content:first-child{border:none;padding-top:0;margin-top:0}::ng-deep .multi-search-dropdown .cursor-light{background-color:rgb(var(--aui-color-p-6))}::ng-deep .multi-search-dropdown .is-multi-value-select{background-color:rgb(var(--aui-color-p-6));color:rgb(var(--aui-color-p-2))}::ng-deep .multi-search-dropdown .search-dropdown-item{padding:0 8px}::ng-deep .multi-search-dropdown .search-dropdown-item:hover{background-color:rgb(var(--aui-color-p-6))}::ng-deep .multi-search-dropdown .search-dropdown-item .multi-item{display:flex;height:28px;align-items:center}::ng-deep .multi-search-dropdown .search-dropdown-item .multi-item aui-checkbox{width:24px}::ng-deep .multi-search-dropdown .search-dropdown-item-label{height:28px;line-height:28px;white-space:nowrap;word-break:break-all;overflow:hidden;text-overflow:ellipsis;font-size:var(--aui-font-size-m)}::ng-deep .multi-search-dropdown .dropdown-group-label{font-size:12px;color:rgb(var(--aui-color-n-4));padding-bottom:8px;padding-top:12px;margin-top:12px;margin-left:8px;margin-right:8px;border-top:1px solid rgb(var(--aui-color-n-8));white-space:nowrap;word-break:break-all;overflow:hidden;text-overflow:ellipsis}::ng-deep .multi-search-dropdown .no-match-categories-tip{text-align:center;font-size:12px;color:rgb(var(--aui-color-n-4));border-bottom:1px solid rgb(var(--aui-color-n-8));margin-left:8px;margin-right:8px;margin-bottom:8px;padding-top:4px;padding-bottom:12px}::ng-deep .multi-search-dropdown .select-all{border-bottom:1px solid rgb(var(--aui-color-n-8))!important;margin-bottom:8px}::ng-deep .multi-search-dropdown .footer{display:flex;background:rgb(var(--aui-color-n-10));justify-content:flex-end;border-top:1px solid rgb(var(--aui-color-n-8));position:sticky;bottom:0;height:30px;padding:0 8px;align-items:center}::ng-deep .multi-search-dropdown .footer .cancel{color:rgb(var(--aui-color-n-1))!important}\n"], dependencies: [{ kind: "component", type: InputComponent, selector: "input[aui-input],textarea[aui-input]", inputs: ["size", "disabled"] }, { kind: "pipe", type: PurePipe, name: "pure" }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: TooltipDirective, selector: "[auiTooltip]", inputs: ["auiTooltip", "auiTooltipContext", "auiTooltipClass", "auiTooltipType", "auiTooltipPosition", "auiTooltipTrigger", "auiTooltipDisabled", "auiTooltipHideOnClick", "auiTooltipAnimType"], outputs: ["auiTooltipVisibleChange"], exportAs: ["auiTooltip"] }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "pipe", type: TranslatePipe, name: "translate" }, { kind: "component", type: CheckboxComponent, selector: "aui-checkbox", inputs: ["name", "type", "label", "indeterminate"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { 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: "component", type: ButtonComponent, selector: "button[aui-button]", inputs: ["aui-button", "size", "plain", "loading", "round", "square"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
609
+ }
610
+ __decorate([
611
+ ObservableInput(),
612
+ __metadata("design:type", Observable)
613
+ ], MultiSearchActionInputComponent.prototype, "hidden$", void 0);
614
+ __decorate([
615
+ ObservableInput(),
616
+ __metadata("design:type", Observable)
617
+ ], MultiSearchActionInputComponent.prototype, "conditionConfig$", void 0);
618
+ __decorate([
619
+ ObservableInput(),
620
+ __metadata("design:type", Observable)
621
+ ], MultiSearchActionInputComponent.prototype, "existingConditions$", void 0);
622
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.1", ngImport: i0, type: MultiSearchActionInputComponent, decorators: [{
623
+ type: Component,
624
+ args: [{ selector: 'acl-multi-search-action-input', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [
625
+ InputComponent,
626
+ PurePipe,
627
+ NgIf,
628
+ NgFor,
629
+ NgClass,
630
+ TooltipDirective,
631
+ AsyncPipe,
632
+ TranslatePipe,
633
+ CheckboxComponent,
634
+ NgTemplateOutlet,
635
+ FormsModule,
636
+ ButtonComponent,
637
+ ], template: "<div class=\"tw-flex tw-items-center tw-text-m\">\n <ng-container *ngIf=\"form.value as activeCondition\">\n <span\n class=\"tw-ml-6 tw-max-w-[45%] tw-flex-shrink-0 tw-text-ellipsis tw-overflow-hidden\"\n (click)=\"activeConditionClick(); $event.stopPropagation()\"\n >\n {{ activeCondition | pure: getConditionLabel }}\n </span>\n <span\n *ngIf=\"activeCondition.operator\"\n class=\"tw-ml-6\"\n (click)=\"activeOperatorClick(); $event.stopPropagation()\"\n >\n {{ activeCondition.operator }}\n </span>\n <span\n *ngIf=\"!isEditing\"\n class=\"tw-ml-6 tw-max-w-[45%] tw-flex-shrink-0 tw-text-ellipsis tw-overflow-hidden\"\n (click)=\"activeValueClick(); $event.stopPropagation()\"\n >\n {{ getValueContent(activeCondition) }}\n </span>\n </ng-container>\n <input\n class=\"search-input\"\n [ngClass]=\"{\n 'mock-input':\n (!isEditing && !isConditionSelecting) || isOperatorSelecting,\n }\"\n [maxlength]=\"isOperatorSelecting ? 0 : MAX_SAFE_INTEGER\"\n aui-input\n #inputRef\n #toolTipRef=\"auiTooltip\"\n [placeholder]=\"isConditionSelecting ? placeholder : ''\"\n [(ngModel)]=\"conditionsModel\"\n (ngModelChange)=\"conditionsModel$$.next($event)\"\n (keydown)=\"inputKeydown($event)\"\n (focus)=\"inputFocus()\"\n [auiTooltip]=\"templateRef\"\n auiTooltipAnimType=\"none\"\n auiTooltipTrigger=\"manual\"\n auiTooltipType=\"info\"\n auiTooltipClass=\"multi-search-dropdown\"\n auiTooltipPosition=\"bottom start\"\n />\n</div>\n\n<ng-template #templateRef>\n <div\n (mousedown)=\"$event.preventDefault()\"\n (click)=\"$event.stopPropagation()\"\n >\n <!-- \u7C7B\u76EE\u9009\u62E9 -->\n <ng-container\n *ngIf=\"isConditionSelecting && (conditionsShouldShow$ | async)\"\n >\n <ul\n *ngIf=\"hasFilteredConditions$ | async; else nonFilteredCategories\"\n class=\"tw-min-w-[260px] tw-max-w-[400px]\"\n >\n <ng-container\n [ngTemplateOutlet]=\"categoriesTemp\"\n [ngTemplateOutletContext]=\"{\n normal: (normalConditions$ | async),\n groups: groupConditions$ | async,\n }\"\n ></ng-container>\n </ul>\n\n <ng-template #nonFilteredCategories>\n <ul class=\"tw-min-w-[260px] tw-max-w-[400px]\">\n <div class=\"no-match-categories-tip\">\n {{ 'no_match_categories_tip' | translate }}\n </div>\n <ng-container\n [ngTemplateOutlet]=\"categoriesTemp\"\n [ngTemplateOutletContext]=\"{\n normal: normalConditionsResource$ | async,\n groups: groupConditionsResource$ | async,\n }\"\n ></ng-container>\n </ul>\n </ng-template>\n\n <ng-template\n #categoriesTemp\n let-normal=\"normal\"\n let-groups=\"groups\"\n >\n <ng-container\n [ngTemplateOutlet]=\"liConditionTemp\"\n [ngTemplateOutletContext]=\"{ conditions: normal }\"\n ></ng-container>\n\n <ng-container *ngFor=\"let group of groups\">\n <ng-container *ngIf=\"group.member?.length\">\n <div\n [title]=\"group.group\"\n class=\"dropdown-group-label dropdown-content\"\n >\n {{ group.group }}\n </div>\n\n <ng-container\n [ngTemplateOutlet]=\"liConditionTemp\"\n [ngTemplateOutletContext]=\"{ conditions: group.member }\"\n ></ng-container>\n </ng-container>\n </ng-container>\n </ng-template>\n </ng-container>\n\n <ng-container *ngIf=\"form.value as activeCondition\">\n <!-- operator\u9009\u62E9 -->\n <ng-container *ngIf=\"isOperatorSelecting\">\n <ul class=\"tw-min-w-[160px]\">\n <li\n (click)=\"selectActiveOperator($any(operator))\"\n *ngFor=\"\n let operator of activeCondition.operators || [DEFAULT_OPERATOR]\n \"\n >\n <ng-container\n [ngTemplateOutlet]=\"basicLiContentTemp\"\n [ngTemplateOutletContext]=\"{\n isSelect: operator === conditionsModel,\n label: operator,\n }\"\n >\n </ng-container>\n </li>\n </ul>\n </ng-container>\n\n <!-- \u5177\u4F53\u6761\u4EF6\u9009\u62E9 -->\n <ng-container *ngIf=\"isValueSelecting\">\n <ul\n *ngIf=\"\n activeCondition\n | pure\n : hasFilteredValues\n : conditionsModel\n : activeCondition.isMulti\n \"\n class=\"tw-min-w-[260px] tw-max-w-[400px]\"\n >\n <li\n *ngIf=\"activeCondition.allowSelectAll && activeCondition.isMulti\"\n class=\"dropdown-content select-all\"\n >\n <div\n class=\"search-dropdown-item\"\n [ngClass]=\"{\n 'tw-text-p-2': isSelectAll,\n 'tw-bg-p-6': isSelectAll,\n }\"\n (click)=\"selectAllClick()\"\n >\n <div class=\"multi-item\">\n <aui-checkbox\n [value]=\"isSelectAll\"\n [indeterminate]=\"isIndeterminate\"\n ></aui-checkbox>\n <div class=\"search-dropdown-item-label\">\n {{ 'all' | translate }}\n </div>\n </div>\n </div>\n </li>\n <ng-container\n [ngTemplateOutlet]=\"liValueTemp\"\n [ngTemplateOutletContext]=\"{\n values:\n activeCondition\n | pure\n : getNormalValues\n : conditionsModel\n : activeCondition.isMulti,\n activeCondition: activeCondition,\n }\"\n >\n </ng-container>\n\n <ng-container\n *ngFor=\"\n let group of activeCondition\n | pure\n : getValuesGroup\n : conditionsModel\n : activeCondition.isMulti\n \"\n >\n <ng-container *ngIf=\"group.member?.length\">\n <div\n [title]=\"group.group\"\n class=\"dropdown-group-label dropdown-content\"\n >\n {{ group.group }}\n </div>\n\n <ng-container\n [ngTemplateOutlet]=\"liValueTemp\"\n [ngTemplateOutletContext]=\"{\n values: group.member,\n activeCondition: activeCondition,\n }\"\n ></ng-container>\n </ng-container>\n </ng-container>\n </ul>\n </ng-container>\n </ng-container>\n <ng-container *ngIf=\"showFootAction && form?.value?.isMulti\">\n <div class=\"footer\">\n <button\n aui-button=\"text\"\n size=\"mini\"\n (click)=\"confirmSelection()\"\n >\n {{ 'confirm' | translate }}\n </button>\n <button\n aui-button=\"text\"\n size=\"mini\"\n class=\"cancel\"\n (click)=\"toolTipHide()\"\n >\n {{ 'cancel' | translate }}\n </button>\n </div>\n </ng-container>\n </div>\n</ng-template>\n\n<ng-template\n #liConditionTemp\n let-conditions=\"conditions\"\n>\n <li\n class=\"dropdown-content\"\n *ngFor=\"let condition of conditions\"\n (click)=\"selectActiveCondition(condition)\"\n >\n <ng-container\n [ngTemplateOutlet]=\"basicLiContentTemp\"\n [ngTemplateOutletContext]=\"{\n isSelect:\n condition\n | pure: getConditionLabel\n | pure: isConditionSelected : conditionsModel,\n label: condition | pure: getConditionLabel,\n }\"\n >\n </ng-container>\n </li>\n</ng-template>\n\n<ng-template\n #liValueTemp\n let-values=\"values\"\n let-activeCondition=\"activeCondition\"\n>\n <li\n class=\"dropdown-content\"\n *ngFor=\"let value of values\"\n (click)=\"\n selectValue(value, activeCondition.isMulti);\n $event.stopPropagation();\n $event.preventDefault()\n \"\n >\n <ng-container\n [ngTemplateOutlet]=\"basicLiContentTemp\"\n [ngTemplateOutletContext]=\"{\n isSelect:\n value\n | pure: getValueLabel\n | pure\n : isValueSelected\n : conditionsModel || (form.value | pure: getValueContent)\n : activeCondition,\n label: value | pure: getValueLabel,\n isMulti: activeCondition.isMulti,\n }\"\n >\n </ng-container>\n </li>\n</ng-template>\n\n<ng-template\n #basicLiContentTemp\n let-isSelect=\"isSelect\"\n let-label=\"label\"\n let-isMulti=\"isMulti\"\n>\n <div\n [class]=\"DROPDOWN_ITEM_CLASS\"\n [ngClass]=\"{\n 'is-multi-value-select': isSelect,\n }\"\n >\n <div\n class=\"multi-item\"\n *ngIf=\"isMulti\"\n >\n <aui-checkbox [value]=\"isSelect\"></aui-checkbox>\n <div\n [title]=\"label\"\n class=\"search-dropdown-item-label\"\n >\n {{ label }}\n </div>\n </div>\n <div\n [title]=\"label\"\n class=\"search-dropdown-item-label\"\n *ngIf=\"!isMulti\"\n >\n {{ label }}\n </div>\n </div>\n</ng-template>\n", styles: [":host{display:block;padding-top:5px}.search-input{border:none;box-shadow:none!important;height:22px}.mock-input{width:1px!important;flex-shrink:0;padding:0;margin-left:7px}::ng-deep .multi-search-dropdown{padding:0!important;margin-top:8px!important;cursor:pointer;max-height:284px;overflow-y:auto}::ng-deep .multi-search-dropdown ul .dropdown-content:first-child{border:none;padding-top:0;margin-top:0}::ng-deep .multi-search-dropdown .cursor-light{background-color:rgb(var(--aui-color-p-6))}::ng-deep .multi-search-dropdown .is-multi-value-select{background-color:rgb(var(--aui-color-p-6));color:rgb(var(--aui-color-p-2))}::ng-deep .multi-search-dropdown .search-dropdown-item{padding:0 8px}::ng-deep .multi-search-dropdown .search-dropdown-item:hover{background-color:rgb(var(--aui-color-p-6))}::ng-deep .multi-search-dropdown .search-dropdown-item .multi-item{display:flex;height:28px;align-items:center}::ng-deep .multi-search-dropdown .search-dropdown-item .multi-item aui-checkbox{width:24px}::ng-deep .multi-search-dropdown .search-dropdown-item-label{height:28px;line-height:28px;white-space:nowrap;word-break:break-all;overflow:hidden;text-overflow:ellipsis;font-size:var(--aui-font-size-m)}::ng-deep .multi-search-dropdown .dropdown-group-label{font-size:12px;color:rgb(var(--aui-color-n-4));padding-bottom:8px;padding-top:12px;margin-top:12px;margin-left:8px;margin-right:8px;border-top:1px solid rgb(var(--aui-color-n-8));white-space:nowrap;word-break:break-all;overflow:hidden;text-overflow:ellipsis}::ng-deep .multi-search-dropdown .no-match-categories-tip{text-align:center;font-size:12px;color:rgb(var(--aui-color-n-4));border-bottom:1px solid rgb(var(--aui-color-n-8));margin-left:8px;margin-right:8px;margin-bottom:8px;padding-top:4px;padding-bottom:12px}::ng-deep .multi-search-dropdown .select-all{border-bottom:1px solid rgb(var(--aui-color-n-8))!important;margin-bottom:8px}::ng-deep .multi-search-dropdown .footer{display:flex;background:rgb(var(--aui-color-n-10));justify-content:flex-end;border-top:1px solid rgb(var(--aui-color-n-8));position:sticky;bottom:0;height:30px;padding:0 8px;align-items:center}::ng-deep .multi-search-dropdown .footer .cancel{color:rgb(var(--aui-color-n-1))!important}\n"] }]
638
+ }], ctorParameters: () => [{ type: i0.Injector }, { type: i2.MultiSearchComponent, decorators: [{
639
+ type: Inject,
640
+ args: [forwardRef(() => MultiSearchComponent)]
641
+ }] }], propDecorators: { placeholder: [{
642
+ type: Input
643
+ }], conditionCreatable: [{
644
+ type: Input
645
+ }], isEditing: [{
646
+ type: Input
647
+ }], hidden: [{
648
+ type: Input
649
+ }], hidden$: [], autoScroll: [{
650
+ type: Input
651
+ }], conditionConfig: [{
652
+ type: Input
653
+ }], showFootAction: [{
654
+ type: Input
655
+ }], conditionConfig$: [], existingConditions: [{
656
+ type: Input
657
+ }], existingConditions$: [], completed: [{
658
+ type: Output
659
+ }], editing: [{
660
+ type: Output
661
+ }], delete: [{
662
+ type: Output
663
+ }], search: [{
664
+ type: Output
665
+ }], inputRef: [{
666
+ type: ViewChild,
667
+ args: ['inputRef']
668
+ }], toolTipRef: [{
669
+ type: ViewChild,
670
+ args: ['toolTipRef']
671
+ }], hiddenState: [{
672
+ type: HostBinding,
673
+ args: ['hidden']
674
+ }] } });
675
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"component.js","sourceRoot":"","sources":["../../../../../../../libs/dynamic-plugin-shared/src/components/multi-search/action-input/component.ts","../../../../../../../libs/dynamic-plugin-shared/src/components/multi-search/action-input/template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  CheckboxComponent,\n  TooltipDirective,\n  InputComponent,\n  ButtonComponent,\n} from '@alauda/ui';\nimport {\n  AsyncPipe,\n  NgClass,\n  NgFor,\n  NgIf,\n  NgTemplateOutlet,\n} from '@angular/common';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  EventEmitter,\n  HostBinding,\n  Inject,\n  Injector,\n  Input,\n  OnDestroy,\n  Output,\n  ViewChild,\n  forwardRef,\n} from '@angular/core';\nimport { FormControl, FormsModule } from '@angular/forms';\nimport { cloneDeep, debounce } from 'lodash-es';\nimport { BaseResourceFormComponent } from 'ng-resource-form-util';\nimport {\n  BehaviorSubject,\n  combineLatest,\n  map,\n  Observable,\n  takeUntil,\n} from 'rxjs';\n\nimport { DEFAULT_OPERATOR, MultiSearchComponent } from '../form/component';\nimport {\n  SearchConditionConfig,\n  SearchConditionModel,\n  MultiSearchOption,\n} from '../types';\nimport { PurePipe } from '../../../pipes';\nimport { TranslatePipe } from '@alauda-fe/dynamic-plugin-sdk';\nimport { ObservableInput, publishRef } from '../../../utils';\n\nenum KeyCode {\n  DELETE = 'Backspace',\n  ENTER = 'Enter',\n  TAB = 'Tab',\n  ArrowDown = 'ArrowDown',\n  ArrowUp = 'ArrowUp',\n}\n\nconst ARROW_EVENTS = new Set([KeyCode.ArrowDown, KeyCode.ArrowUp]);\n\nconst DROPDOWN_ITEM_CLASS = 'search-dropdown-item';\n\n@Component({\n  selector: 'acl-multi-search-action-input',\n  templateUrl: './template.html',\n  styleUrls: ['./styles.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    InputComponent,\n    PurePipe,\n    NgIf,\n    NgFor,\n    NgClass,\n    TooltipDirective,\n    AsyncPipe,\n    TranslatePipe,\n    CheckboxComponent,\n    NgTemplateOutlet,\n    FormsModule,\n    ButtonComponent,\n  ],\n})\nexport class MultiSearchActionInputComponent\n  extends BaseResourceFormComponent<SearchConditionModel>\n  implements OnDestroy\n{\n  @Input()\n  placeholder: string;\n\n  @Input()\n  conditionCreatable: boolean;\n\n  // 是否为编辑态\n  @Input()\n  isEditing: boolean = false;\n\n  @Input()\n  hidden: boolean;\n\n  @ObservableInput()\n  hidden$!: Observable<boolean>;\n\n  @Input()\n  autoScroll: boolean;\n\n  // 类目配置\n  @Input()\n  conditionConfig: SearchConditionConfig[];\n\n  @Input()\n  showFootAction: boolean;\n\n  @ObservableInput()\n  conditionConfig$!: Observable<SearchConditionConfig[]>;\n\n  // 类目配置\n  @Input()\n  existingConditions: SearchConditionModel[];\n\n  @ObservableInput()\n  existingConditions$!: Observable<SearchConditionModel[]>;\n\n  // 完成事件\n  @Output()\n  completed = new EventEmitter<{\n    activeCondition: SearchConditionModel;\n    toContinue?: boolean;\n    manualFocus?: boolean;\n  }>();\n\n  // 转换为编辑态\n  @Output()\n  editing = new EventEmitter<void>();\n\n  // 键盘delete事件。\n  @Output()\n  delete = new EventEmitter<void>();\n\n  // 键盘enter事件\n  @Output()\n  search = new EventEmitter<void>();\n\n  @ViewChild('inputRef')\n  inputRef: InputComponent;\n\n  @ViewChild('toolTipRef')\n  toolTipRef: TooltipDirective;\n\n  @HostBinding('hidden')\n  get hiddenState(): boolean {\n    return this.hidden;\n  }\n\n  _conditionsModel: string = '';\n\n  get conditionsModel() {\n    return this.conditionsModel$$.value;\n  }\n\n  set conditionsModel(v: string) {\n    this.conditionsModel$$.next(v);\n  }\n\n  conditionsModel$$ = new BehaviorSubject<string>('');\n\n  hasFilteredConditions$ = combineLatest([\n    this.conditionConfig$,\n    this.conditionsModel$$,\n    this.existingConditions$,\n  ]).pipe(\n    map(([conditionConfig, model, existingConditions]) => {\n      return (\n        !model ||\n        conditionConfig?.filter(\n          config =>\n            this.getConditionLabel(config)?.includes(model) &&\n            this.conditionFilterByExists(config, existingConditions),\n        )?.length > 0\n      );\n    }),\n    publishRef(),\n  );\n\n  conditionsShouldShow$ = combineLatest([\n    this.conditionConfig$,\n    this.conditionsModel$$,\n    this.existingConditions$,\n  ]).pipe(\n    map(([conditionConfig, model, existingConditions]) => {\n      return (\n        model ||\n        conditionConfig?.filter(config =>\n          this.conditionFilterByExists(config, existingConditions),\n        )?.length > 0\n      );\n    }),\n    publishRef(),\n  );\n\n  normalConditionsResource$ = combineLatest([\n    this.conditionConfig$,\n    this.existingConditions$,\n  ]).pipe(\n    map(([conditionConfig, existingConditions]) =>\n      conditionConfig?.filter(\n        config =>\n          !config.condition.group &&\n          this.conditionFilterByExists(config, existingConditions),\n      ),\n    ),\n    publishRef(),\n  );\n\n  normalConditions$ = combineLatest([\n    this.normalConditionsResource$,\n    this.conditionsModel$$,\n  ]).pipe(\n    map(([normalConditions, model]) => {\n      return normalConditions.filter(\n        condition =>\n          !model || this.getConditionLabel(condition)?.includes(model),\n      );\n    }),\n  );\n\n  groupConditionsResource$ = combineLatest([\n    this.conditionConfig$,\n    this.existingConditions$,\n  ]).pipe(\n    map(([conditionConfig, existingConditions]) =>\n      conditionConfig?.filter(\n        config =>\n          config.condition.group &&\n          this.conditionFilterByExists(config, existingConditions),\n      ),\n    ),\n    map(conditionConfig => {\n      return this.resolveGroup<SearchConditionConfig>(\n        conditionConfig,\n        config => config.condition.group,\n      );\n    }),\n    publishRef(),\n  );\n\n  groupConditions$ = combineLatest([\n    this.groupConditionsResource$,\n    this.conditionsModel$$,\n  ]).pipe(\n    map(([groupConditions, model]) => {\n      return groupConditions.map(group => ({\n        group: group.group,\n        member: group.member.filter(\n          condition =>\n            !model || this.getConditionLabel(condition).includes(model),\n        ),\n      }));\n    }),\n  );\n\n  hasFilteredValues = (\n    activeCondition: SearchConditionModel,\n    model: string,\n    isMulti: boolean = false,\n  ) => {\n    const values = activeCondition?.values;\n    if (!model) return values?.length > 0;\n    return (\n      values?.filter(value =>\n        this.valuesFilter(\n          values,\n          value,\n          this.getSeparator(activeCondition),\n          isMulti,\n        ),\n      )?.length > 0\n    );\n  };\n\n  getNormalValues = (\n    activeCondition: SearchConditionModel,\n    model: string,\n    isMulti: boolean = false,\n  ) => {\n    const normalConditions = activeCondition.values?.filter(\n      value => !value.group,\n    );\n\n    if (!model) return normalConditions;\n    return normalConditions?.filter(condition =>\n      this.valuesFilter(\n        activeCondition.values,\n        condition,\n        this.getSeparator(activeCondition),\n        isMulti,\n      ),\n    );\n  };\n\n  getValuesGroup = (\n    activeCondition: SearchConditionModel,\n    model: string,\n    isMulti: boolean,\n  ) => {\n    const groupCondition = activeCondition.values?.filter(value => value.group);\n    const groups = this.resolveGroup<MultiSearchOption>(\n      groupCondition,\n      value => value.group,\n    );\n\n    if (!model) return groups;\n    return groups?.map(group => ({\n      group: group.group,\n      member: group.member.filter(condition =>\n        this.valuesFilter(\n          activeCondition.values,\n          condition,\n          this.getSeparator(activeCondition),\n          isMulti,\n        ),\n      ),\n    }));\n  };\n\n  valuesFilter(\n    conditions: MultiSearchOption[],\n    condition: MultiSearchOption,\n    separator: string,\n    isMulti: boolean = false,\n  ) {\n    const searchVal = this.getMultiSearchVal(separator);\n\n    const already = conditions.some(\n      condition => this.getValueLabel(condition) === searchVal,\n    );\n\n    return (\n      (isMulti && already) || this.getValueLabel(condition).includes(searchVal)\n    );\n  }\n\n  get isConditionSelecting() {\n    return !this.form?.value;\n  }\n\n  get isOperatorSelecting() {\n    return this.form?.value && !this.form.value.operator;\n  }\n\n  get isValueSelecting() {\n    return this.form?.value && this.form.value.operator;\n  }\n\n  get isInitialized() {\n    return this.isConditionSelecting && !this.conditionsModel;\n  }\n\n  get isOperationComplete() {\n    const activeCondition: SearchConditionModel = this.form.value;\n    return (\n      activeCondition?.selectedValues?.length &&\n      activeCondition?.operator &&\n      activeCondition.condition\n    );\n  }\n\n  get isSelectAll() {\n    if (!this.isValueSelecting) return false;\n    const conditionsModel = this.conditionsModel;\n    const activeCondition = this.form.value;\n\n    const valueLabels = conditionsModel\n      ? conditionsModel.split(this.getSeparator(activeCondition))\n      : [];\n\n    return activeCondition.values?.every(value =>\n      valueLabels?.some(label => this.getValueLabel(value) === label),\n    );\n  }\n\n  get isIndeterminate() {\n    if (!this.isValueSelecting || this.isSelectAll) return false;\n    const conditionsModel = this.conditionsModel;\n    const activeCondition = this.form.value;\n\n    const valueLabels = conditionsModel\n      ? conditionsModel.split(this.getSeparator(activeCondition))\n      : [];\n\n    return activeCondition.values?.some(value =>\n      valueLabels?.some(label => this.getValueLabel(value) === label),\n    );\n  }\n\n  get inputElement() {\n    return this.inputRef?.elementRef?.nativeElement;\n  }\n\n  get optionElements(): NodeListOf<HTMLDivElement> {\n    return document.querySelectorAll(`.${DROPDOWN_ITEM_CLASS}`);\n  }\n\n  // 键盘操作指针\n  arrowCursor = -1;\n\n  MAX_SAFE_INTEGER = Number.MAX_SAFE_INTEGER;\n  DEFAULT_OPERATOR = DEFAULT_OPERATOR;\n  DROPDOWN_ITEM_CLASS = DROPDOWN_ITEM_CLASS;\n\n  constructor(\n    public override injector: Injector,\n    @Inject(forwardRef(() => MultiSearchComponent))\n    private readonly multiSearch: MultiSearchComponent,\n  ) {\n    super(injector);\n\n    this.resolveHideSync();\n    this.resolveFormModelChangeSync();\n  }\n\n  private resolveHideSync() {\n    this.hidden$.pipe(takeUntil(this.destroy$)).subscribe(hidden => {\n      // 控件被隐藏时，确保tooltip也一并隐藏\n      if (hidden) {\n        this.toolTipHide();\n      }\n    });\n  }\n\n  // input内容发生变化时，确保formModel也同步更新\n  private resolveFormModelChangeSync() {\n    this.conditionsModel$$\n      .pipe(takeUntil(this.destroy$))\n      .subscribe(conditionsModel => {\n        if (this.isValueSelecting) {\n          this.valuesSync(conditionsModel);\n        }\n      });\n  }\n\n  private conditionSync(conditionsModel: string) {\n    const config = this.conditionConfig?.find(\n      config => this.getConditionLabel(config) === conditionsModel,\n    );\n    let activeCondition: SearchConditionModel = {\n      condition: { value: conditionsModel },\n    };\n    if (config) {\n      activeCondition = { ...config };\n      // 当operators只有一个选项时，会默认选中\n      if (config.operators?.length === 1) {\n        activeCondition.operator = config.operators[0];\n      } else if (!config.operators?.length) {\n        activeCondition.operator = DEFAULT_OPERATOR;\n      }\n    } else {\n      activeCondition.operator = DEFAULT_OPERATOR;\n    }\n    activeCondition.isEditing = true;\n    this.form.reset(activeCondition);\n  }\n\n  private valuesSync(conditionsModel: string) {\n    const activeCondition = this.form.value;\n    const valueLabels = conditionsModel\n      ? conditionsModel.split(this.getSeparator(activeCondition))\n      : [];\n\n    const conditions = valueLabels.map(label => {\n      const find = activeCondition.values?.find(\n        value => this.getValueLabel(value) === label,\n      );\n      return find || { label, value: label };\n    });\n\n    this.setValues(conditions);\n  }\n\n  createForm(): FormControl<SearchConditionModel> {\n    return this.fb.control(null);\n  }\n\n  override adaptResourceModel(\n    resource: SearchConditionModel,\n  ): SearchConditionModel {\n    if (this.isEditing) {\n      this.initModel(resource);\n    } else {\n      this.manualFocus();\n    }\n\n    return resource;\n  }\n\n  private initModel(condition: SearchConditionModel) {\n    if ((this.conditionsModel = this.getValueContent(condition))) {\n      this.manualFocus();\n    }\n  }\n\n  // 设置当前操作的condition\n  selectActiveCondition(conditionConfig: SearchConditionConfig) {\n    this.resetArrowCursor();\n    this.changeToEditing();\n    // 只在点击事件中设置form.value\n    this.conditionsModel = this.getConditionLabel(conditionConfig);\n\n    this.setConditionByModel();\n  }\n\n  setConditionByModel() {\n    this.conditionSync(this.conditionsModel);\n\n    this.conditionsModel = null;\n    this.manualFocus();\n\n    this.refreshCursor();\n  }\n\n  // 选择当前condition的operator\n  selectActiveOperator(operator: string) {\n    this.resetArrowCursor();\n    this.changeToEditing();\n    // operator选择不依赖resolveFormModelChangeSync，只依赖选择\n    this.setActiveOperator(operator);\n\n    this.conditionsModel = null;\n    this.manualFocus();\n  }\n\n  // 选择条件\n  // 多选不会重置arrowCursor，当激活arrowCursor时，需要tab完成多选事件\n  selectValue(condition: MultiSearchOption, isMulti?: boolean) {\n    this.changeToEditing();\n\n    // 利用resolveFormModelChangeSync设置form.value.selectedValues\n    if (isMulti) {\n      this.selectMultiValue(condition);\n\n      this.refreshCursor();\n    } else {\n      this.resetArrowCursor();\n\n      const currentLabel = this.getValueLabel(condition);\n\n      this.conditionsModel = currentLabel;\n\n      // 如果是单选，则需要在选中时抛出complete事件，并抛出search事件\n      this.ifComplete(false, true);\n      this.search.emit();\n    }\n  }\n\n  // 多选\n  private selectMultiValue(condition: MultiSearchOption) {\n    const activeCondition = this.form.value;\n\n    const currentLabel = this.getValueLabel(condition);\n\n    const separator = this.getSeparator(activeCondition);\n\n    const selected =\n      activeCondition.selectedValues?.map(value => this.getValueLabel(value)) ||\n      [];\n    const find = selected.includes(currentLabel);\n\n    if (find) {\n      const idx = selected.indexOf(currentLabel);\n      selected.splice(idx, 1);\n    } else {\n      const lastVal = selected?.at(-1);\n\n      // 只有当输入的内容不存在于选项中时，才能算是searchVal\n      const searchVal = activeCondition.values?.some(\n        v => this.getValueLabel(v) === lastVal,\n      )\n        ? ''\n        : selected?.at(-1);\n\n      // 如果当前选中的值包含末尾用户的输入值，则代表应该补全而非末尾处新增\n      /**\n       * 如：\n       * 输入框中为 value1|value2|val\n       * 若此时选择下拉选项中的 value3,应补全为value1|value2|value3\n       * 若此时选择了 xxxx，则结果应为value1|value2|val|xxxx\n       */\n      if (searchVal && currentLabel.includes(searchVal)) {\n        selected.pop();\n      }\n      selected.push(currentLabel);\n    }\n    this.conditionsModel = selected.join(separator);\n  }\n\n  selectAllClick = debounce(() => {\n    if (this.isSelectAll) {\n      this.deselectAllValues();\n    } else {\n      this.selectAllValues();\n    }\n    this.refreshCursor();\n  }, 50);\n\n  private selectAllValues() {\n    const conditionsModel = this.conditionsModel;\n    const activeCondition = this.form.value;\n\n    const valueLabels = conditionsModel\n      ? conditionsModel.split(this.getSeparator(activeCondition))\n      : [];\n\n    const shouldPush = activeCondition.values\n      ?.filter(value =>\n        valueLabels?.every(label => this.getValueLabel(value) !== label),\n      )\n      ?.map(condition => this.getValueLabel(condition));\n\n    const final = [...valueLabels, ...shouldPush];\n    this.conditionsModel = final.join(this.getSeparator(activeCondition));\n  }\n\n  private deselectAllValues() {\n    const conditionsModel = this.conditionsModel;\n    const activeCondition = this.form.value;\n\n    const valueLabels = conditionsModel\n      ? conditionsModel.split(this.getSeparator(activeCondition))\n      : [];\n\n    const final = valueLabels.filter(label =>\n      activeCondition.values.every(\n        value => this.getValueLabel(value) !== label,\n      ),\n    );\n    this.conditionsModel = final.join(this.getSeparator(activeCondition));\n  }\n\n  // 点击操作中已选择的类目\n  activeConditionClick() {\n    this.changeToEditing();\n    this.conditionsModel = this.getConditionLabel(this.form.value);\n    this.clearActiveCondition();\n    this.manualFocus();\n  }\n\n  // 点击操作中已选择的operator\n  activeOperatorClick() {\n    this.changeToEditing();\n    this.conditionsModel = null;\n    this.setActiveOperator(null);\n    this.setValues([]);\n    this.manualFocus();\n  }\n\n  // 点击操作中已选择的条件\n  activeValueClick() {\n    this.changeToEditing();\n    const activeCondition = this.form.value;\n    this.conditionsModel = this.getValueContent(activeCondition);\n    this.manualFocus();\n  }\n\n  private setActiveOperator(operator: string) {\n    this.form.patchValue({ ...this.form.value, operator });\n  }\n\n  private setValues(conditions: MultiSearchOption[]) {\n    this.form.patchValue({\n      ...this.form.value,\n      selectedValues: conditions,\n    });\n  }\n\n  private clearActiveCondition() {\n    this.form.patchValue(null);\n  }\n\n  private changeToEditing() {\n    if (!this.isEditing) {\n      this.editing.emit();\n    }\n  }\n\n  inputFocus() {\n    this.multiSearch.setFocus(true);\n    this.toolTipShow();\n  }\n\n  inputKeydown(e: KeyboardEvent) {\n    switch (e.code) {\n      case KeyCode.DELETE: {\n        this.resolveDeleteEvent();\n        break;\n      }\n      case KeyCode.ENTER: {\n        this.resolveEnterEvent();\n        break;\n      }\n      case KeyCode.TAB: {\n        this.resolveTabEvent();\n        break;\n      }\n      default: {\n        if (ARROW_EVENTS.has(e.code as KeyCode)) {\n          this.resolveArrowEvent(e);\n        } else {\n          // 删除状态时，若输入内容，则会转变为编辑状态\n          this.changeToEditingIfNeed();\n          // 输入内容时，会自动打开tooltip\n          this.toolTipShow();\n        }\n      }\n    }\n  }\n\n  confirmSelection() {\n    this.resolveEnterEvent();\n  }\n\n  private changeToEditingIfNeed() {\n    if (!this.isEditing) {\n      if (this.isConditionSelecting) {\n        this.activeConditionClick();\n      } else if (this.isValueSelecting) {\n        this.activeValueClick();\n      }\n    }\n  }\n\n  private resolveTabEvent() {\n    // 当激活arrowCursor时，tab事件会切换为enter事件交互\n    if (this.arrowCursor > -1) {\n      this.resetArrowCursor();\n      this.resolveEnterEvent();\n    } else {\n      requestAnimationFrame(() => {\n        this.ifComplete();\n        this.multiSearch.manualBlur();\n      });\n    }\n  }\n\n  private resolveArrowEvent(e: KeyboardEvent) {\n    const options = this.optionElements;\n    const length = options.length;\n\n    if (e.code === KeyCode.ArrowDown) {\n      this.arrowCursor =\n        this.arrowCursor === length - 1 ? 0 : this.arrowCursor + 1;\n    } else if (e.code === KeyCode.ArrowUp) {\n      this.arrowCursor =\n        this.arrowCursor === 0 ? length - 1 : this.arrowCursor - 1;\n    }\n\n    options.forEach(option => option.classList.remove('cursor-light'));\n    options.item(this.arrowCursor)?.classList?.add('cursor-light');\n\n    e.preventDefault();\n  }\n\n  private resolveDeleteEvent() {\n    if (!this.conditionsModel) {\n      const activeCondition: SearchConditionModel = cloneDeep(this.form.value);\n      // 若当前存在activeCondition内容，则需要先删除当前内容，删除完成后再触发删除联动\n      if (activeCondition) {\n        this.deleteSelf(activeCondition);\n        // 自动展示选项\n        this.manualFocus();\n      } else {\n        if (this.resourceModel) {\n          this._complete(null);\n        }\n        this.delete.emit();\n      }\n    }\n  }\n\n  private resolveEnterEvent() {\n    if (this.arrowCursor > -1) {\n      this.optionElements.item(this.arrowCursor)?.click();\n    } else {\n      // 当前操作内容已完成，，则会抛出enter事件\n      if (this.ifComplete(false, true)) {\n        this.search.emit();\n      } else if (this.conditionCreatable && this.isConditionSelecting) {\n        this.setConditionByModel();\n      }\n    }\n  }\n\n  private deleteSelf(activeCondition: SearchConditionModel) {\n    // 此时，先删除operator，再删除当前activeCondition，并抛出complete事件\n    if (activeCondition.selectedValues?.length) {\n      activeCondition.selectedValues.pop();\n\n      this.setValues(activeCondition.selectedValues);\n    } else if (activeCondition.operator) {\n      this.setActiveOperator(null);\n    } else {\n      // 清空后，需要在下一次delete时才会从数据源中删除，在此期间，依旧可以重新进行编辑操作\n      this.clearActiveCondition();\n    }\n  }\n\n  private resetArrowCursor() {\n    this.arrowCursor = -1;\n  }\n\n  manualFocus(silence?: boolean) {\n    requestAnimationFrame(() => {\n      if (this.autoScroll) {\n        this.inputElement?.scrollIntoView({\n          behavior: 'smooth',\n        });\n      }\n      this.inputElement?.focus();\n      if (silence) {\n        this.toolTipHide();\n      } else {\n        this.refreshDropdown();\n      }\n    });\n  }\n\n  manualBlur() {\n    this.toolTipHide();\n\n    requestAnimationFrame(() => {\n      this.inputElement?.blur();\n    });\n  }\n\n  private refreshDropdown() {\n    if (this.hidden) return;\n    this.toolTipHide();\n    this.toolTipShow();\n  }\n\n  private refreshCursor() {\n    requestAnimationFrame(() => {\n      this.inputElement?.blur();\n      this.inputElement?.focus();\n    });\n  }\n\n  toolTipHide() {\n    this.toolTipRef?.hide();\n  }\n\n  toolTipShow() {\n    this.toolTipRef?.show();\n  }\n\n  ifComplete(toContinue: boolean = false, manualFocus: boolean = false) {\n    const activeCondition: SearchConditionModel = this.form.value;\n    // 完成所有选项，或者内容为空，则代表complete\n    if (this.isOperationComplete || this.isInitialized) {\n      this._complete(activeCondition, toContinue, manualFocus);\n      return true;\n    }\n  }\n\n  _complete(\n    activeCondition: SearchConditionModel,\n    toContinue: boolean = false,\n    manualFocus: boolean = true,\n  ) {\n    this.toolTipHide();\n    this.completed.emit({ activeCondition, toContinue, manualFocus });\n    this.clearActiveCondition();\n    this.initModel(null);\n  }\n\n  private conditionFilterByExists(\n    condition: SearchConditionModel,\n    existingConditions: SearchConditionModel[],\n  ) {\n    return existingConditions.every(\n      exist =>\n        condition.condition.value !== exist.condition.value ||\n        exist.condition.value === this.resourceModel?.condition?.value,\n    );\n  }\n\n  private resolveGroup<T>(items: T[], getGroupKey: (item: T) => string) {\n    const groups: Array<{\n      group: string;\n      member: T[];\n    }> = [];\n    items?.forEach(config => {\n      const groupKey = getGroupKey(config);\n      const find = groups.find(group => group.group === groupKey);\n      if (find) {\n        find.member.push(config);\n      } else {\n        groups.push({\n          group: groupKey,\n          member: [config],\n        });\n      }\n    });\n    return groups;\n  }\n\n  getConditionLabel(condition: SearchConditionModel) {\n    return condition?.condition?.label ?? condition?.condition?.value;\n  }\n\n  private getSeparator(condition: SearchConditionModel) {\n    return condition.separator ?? ' | ';\n  }\n\n  getValueContent = (condition: SearchConditionModel) => {\n    return condition?.selectedValues\n      ?.map(value => value.label || value.value)\n      ?.join(this.getSeparator(condition));\n  };\n\n  getValueLabel(value: MultiSearchOption) {\n    return value.label ?? value.value;\n  }\n\n  private getMultiSearchVal(separator: string) {\n    const latestSeparatorIdx = this.conditionsModel?.lastIndexOf(separator);\n\n    return latestSeparatorIdx >= 0\n      ? this.conditionsModel.slice(latestSeparatorIdx + separator.length)\n      : this.conditionsModel;\n  }\n\n  isConditionSelected(current: string, conditionsModel: string) {\n    return conditionsModel === current;\n  }\n\n  isValueSelected = (\n    current: string,\n    conditionsModel: string,\n    condition: SearchConditionModel,\n  ) => {\n    return conditionsModel\n      ?.split(this.getSeparator(condition))\n      ?.includes(current);\n  };\n}\n","<div class=\"tw-flex tw-items-center tw-text-m\">\n  <ng-container *ngIf=\"form.value as activeCondition\">\n    <span\n      class=\"tw-ml-6 tw-max-w-[45%] tw-flex-shrink-0 tw-text-ellipsis tw-overflow-hidden\"\n      (click)=\"activeConditionClick(); $event.stopPropagation()\"\n    >\n      {{ activeCondition | pure: getConditionLabel }}\n    </span>\n    <span\n      *ngIf=\"activeCondition.operator\"\n      class=\"tw-ml-6\"\n      (click)=\"activeOperatorClick(); $event.stopPropagation()\"\n    >\n      {{ activeCondition.operator }}\n    </span>\n    <span\n      *ngIf=\"!isEditing\"\n      class=\"tw-ml-6 tw-max-w-[45%] tw-flex-shrink-0 tw-text-ellipsis tw-overflow-hidden\"\n      (click)=\"activeValueClick(); $event.stopPropagation()\"\n    >\n      {{ getValueContent(activeCondition) }}\n    </span>\n  </ng-container>\n  <input\n    class=\"search-input\"\n    [ngClass]=\"{\n      'mock-input':\n        (!isEditing && !isConditionSelecting) || isOperatorSelecting,\n    }\"\n    [maxlength]=\"isOperatorSelecting ? 0 : MAX_SAFE_INTEGER\"\n    aui-input\n    #inputRef\n    #toolTipRef=\"auiTooltip\"\n    [placeholder]=\"isConditionSelecting ? placeholder : ''\"\n    [(ngModel)]=\"conditionsModel\"\n    (ngModelChange)=\"conditionsModel$$.next($event)\"\n    (keydown)=\"inputKeydown($event)\"\n    (focus)=\"inputFocus()\"\n    [auiTooltip]=\"templateRef\"\n    auiTooltipAnimType=\"none\"\n    auiTooltipTrigger=\"manual\"\n    auiTooltipType=\"info\"\n    auiTooltipClass=\"multi-search-dropdown\"\n    auiTooltipPosition=\"bottom start\"\n  />\n</div>\n\n<ng-template #templateRef>\n  <div\n    (mousedown)=\"$event.preventDefault()\"\n    (click)=\"$event.stopPropagation()\"\n  >\n    <!-- 类目选择 -->\n    <ng-container\n      *ngIf=\"isConditionSelecting && (conditionsShouldShow$ | async)\"\n    >\n      <ul\n        *ngIf=\"hasFilteredConditions$ | async; else nonFilteredCategories\"\n        class=\"tw-min-w-[260px] tw-max-w-[400px]\"\n      >\n        <ng-container\n          [ngTemplateOutlet]=\"categoriesTemp\"\n          [ngTemplateOutletContext]=\"{\n            normal: (normalConditions$ | async),\n            groups: groupConditions$ | async,\n          }\"\n        ></ng-container>\n      </ul>\n\n      <ng-template #nonFilteredCategories>\n        <ul class=\"tw-min-w-[260px] tw-max-w-[400px]\">\n          <div class=\"no-match-categories-tip\">\n            {{ 'no_match_categories_tip' | translate }}\n          </div>\n          <ng-container\n            [ngTemplateOutlet]=\"categoriesTemp\"\n            [ngTemplateOutletContext]=\"{\n              normal: normalConditionsResource$ | async,\n              groups: groupConditionsResource$ | async,\n            }\"\n          ></ng-container>\n        </ul>\n      </ng-template>\n\n      <ng-template\n        #categoriesTemp\n        let-normal=\"normal\"\n        let-groups=\"groups\"\n      >\n        <ng-container\n          [ngTemplateOutlet]=\"liConditionTemp\"\n          [ngTemplateOutletContext]=\"{ conditions: normal }\"\n        ></ng-container>\n\n        <ng-container *ngFor=\"let group of groups\">\n          <ng-container *ngIf=\"group.member?.length\">\n            <div\n              [title]=\"group.group\"\n              class=\"dropdown-group-label dropdown-content\"\n            >\n              {{ group.group }}\n            </div>\n\n            <ng-container\n              [ngTemplateOutlet]=\"liConditionTemp\"\n              [ngTemplateOutletContext]=\"{ conditions: group.member }\"\n            ></ng-container>\n          </ng-container>\n        </ng-container>\n      </ng-template>\n    </ng-container>\n\n    <ng-container *ngIf=\"form.value as activeCondition\">\n      <!-- operator选择 -->\n      <ng-container *ngIf=\"isOperatorSelecting\">\n        <ul class=\"tw-min-w-[160px]\">\n          <li\n            (click)=\"selectActiveOperator($any(operator))\"\n            *ngFor=\"\n              let operator of activeCondition.operators || [DEFAULT_OPERATOR]\n            \"\n          >\n            <ng-container\n              [ngTemplateOutlet]=\"basicLiContentTemp\"\n              [ngTemplateOutletContext]=\"{\n                isSelect: operator === conditionsModel,\n                label: operator,\n              }\"\n            >\n            </ng-container>\n          </li>\n        </ul>\n      </ng-container>\n\n      <!-- 具体条件选择 -->\n      <ng-container *ngIf=\"isValueSelecting\">\n        <ul\n          *ngIf=\"\n            activeCondition\n              | pure\n                : hasFilteredValues\n                : conditionsModel\n                : activeCondition.isMulti\n          \"\n          class=\"tw-min-w-[260px] tw-max-w-[400px]\"\n        >\n          <li\n            *ngIf=\"activeCondition.allowSelectAll && activeCondition.isMulti\"\n            class=\"dropdown-content select-all\"\n          >\n            <div\n              class=\"search-dropdown-item\"\n              [ngClass]=\"{\n                'tw-text-p-2': isSelectAll,\n                'tw-bg-p-6': isSelectAll,\n              }\"\n              (click)=\"selectAllClick()\"\n            >\n              <div class=\"multi-item\">\n                <aui-checkbox\n                  [value]=\"isSelectAll\"\n                  [indeterminate]=\"isIndeterminate\"\n                ></aui-checkbox>\n                <div class=\"search-dropdown-item-label\">\n                  {{ 'all' | translate }}\n                </div>\n              </div>\n            </div>\n          </li>\n          <ng-container\n            [ngTemplateOutlet]=\"liValueTemp\"\n            [ngTemplateOutletContext]=\"{\n              values:\n                activeCondition\n                | pure\n                  : getNormalValues\n                  : conditionsModel\n                  : activeCondition.isMulti,\n              activeCondition: activeCondition,\n            }\"\n          >\n          </ng-container>\n\n          <ng-container\n            *ngFor=\"\n              let group of activeCondition\n                | pure\n                  : getValuesGroup\n                  : conditionsModel\n                  : activeCondition.isMulti\n            \"\n          >\n            <ng-container *ngIf=\"group.member?.length\">\n              <div\n                [title]=\"group.group\"\n                class=\"dropdown-group-label dropdown-content\"\n              >\n                {{ group.group }}\n              </div>\n\n              <ng-container\n                [ngTemplateOutlet]=\"liValueTemp\"\n                [ngTemplateOutletContext]=\"{\n                  values: group.member,\n                  activeCondition: activeCondition,\n                }\"\n              ></ng-container>\n            </ng-container>\n          </ng-container>\n        </ul>\n      </ng-container>\n    </ng-container>\n    <ng-container *ngIf=\"showFootAction && form?.value?.isMulti\">\n      <div class=\"footer\">\n        <button\n          aui-button=\"text\"\n          size=\"mini\"\n          (click)=\"confirmSelection()\"\n        >\n          {{ 'confirm' | translate }}\n        </button>\n        <button\n          aui-button=\"text\"\n          size=\"mini\"\n          class=\"cancel\"\n          (click)=\"toolTipHide()\"\n        >\n          {{ 'cancel' | translate }}\n        </button>\n      </div>\n    </ng-container>\n  </div>\n</ng-template>\n\n<ng-template\n  #liConditionTemp\n  let-conditions=\"conditions\"\n>\n  <li\n    class=\"dropdown-content\"\n    *ngFor=\"let condition of conditions\"\n    (click)=\"selectActiveCondition(condition)\"\n  >\n    <ng-container\n      [ngTemplateOutlet]=\"basicLiContentTemp\"\n      [ngTemplateOutletContext]=\"{\n        isSelect:\n          condition\n          | pure: getConditionLabel\n          | pure: isConditionSelected : conditionsModel,\n        label: condition | pure: getConditionLabel,\n      }\"\n    >\n    </ng-container>\n  </li>\n</ng-template>\n\n<ng-template\n  #liValueTemp\n  let-values=\"values\"\n  let-activeCondition=\"activeCondition\"\n>\n  <li\n    class=\"dropdown-content\"\n    *ngFor=\"let value of values\"\n    (click)=\"\n      selectValue(value, activeCondition.isMulti);\n      $event.stopPropagation();\n      $event.preventDefault()\n    \"\n  >\n    <ng-container\n      [ngTemplateOutlet]=\"basicLiContentTemp\"\n      [ngTemplateOutletContext]=\"{\n        isSelect:\n          value\n          | pure: getValueLabel\n          | pure\n            : isValueSelected\n            : conditionsModel || (form.value | pure: getValueContent)\n            : activeCondition,\n        label: value | pure: getValueLabel,\n        isMulti: activeCondition.isMulti,\n      }\"\n    >\n    </ng-container>\n  </li>\n</ng-template>\n\n<ng-template\n  #basicLiContentTemp\n  let-isSelect=\"isSelect\"\n  let-label=\"label\"\n  let-isMulti=\"isMulti\"\n>\n  <div\n    [class]=\"DROPDOWN_ITEM_CLASS\"\n    [ngClass]=\"{\n      'is-multi-value-select': isSelect,\n    }\"\n  >\n    <div\n      class=\"multi-item\"\n      *ngIf=\"isMulti\"\n    >\n      <aui-checkbox [value]=\"isSelect\"></aui-checkbox>\n      <div\n        [title]=\"label\"\n        class=\"search-dropdown-item-label\"\n      >\n        {{ label }}\n      </div>\n    </div>\n    <div\n      [title]=\"label\"\n      class=\"search-dropdown-item-label\"\n      *ngIf=\"!isMulti\"\n    >\n      {{ label }}\n    </div>\n  </div>\n</ng-template>\n"]}