@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.
- package/assets/images/overview-banner.svg +1 -0
- package/components/deleting-tag/component.d.ts +7 -0
- package/components/index.d.ts +6 -1
- package/components/list-display/component.d.ts +15 -0
- package/components/multi-search/action-input/component.d.ts +122 -0
- package/components/multi-search/form/component.d.ts +66 -0
- package/components/multi-search/index.d.ts +4 -0
- package/components/multi-search/multi-search-tags/component.d.ts +27 -0
- package/components/multi-search/types.d.ts +33 -0
- package/components/multi-search/utils.d.ts +24 -0
- package/components/mutable/directive.d.ts +83 -0
- package/components/mutable/element.d.ts +10 -0
- package/components/mutable/index.d.ts +8 -0
- package/components/mutable/mosaic/component.d.ts +32 -0
- package/components/mutable/mosaic/directive.d.ts +9 -0
- package/components/mutable/util.d.ts +18 -0
- package/components/overview-banner/component.d.ts +11 -0
- package/components/table/component.d.ts +88 -0
- package/components/table/constants.d.ts +3 -0
- package/components/table/helper.d.ts +2 -0
- package/components/table/helpers.directive.d.ts +21 -0
- package/components/table/index.d.ts +5 -0
- package/components/table/types.d.ts +71 -0
- package/components/table/util.service.d.ts +13 -0
- package/esm2022/components/deleting-tag/component.mjs +16 -0
- package/esm2022/components/index.mjs +7 -2
- package/esm2022/components/list-display/component.mjs +46 -0
- package/esm2022/components/multi-search/action-input/component.mjs +675 -0
- package/esm2022/components/multi-search/form/component.mjs +322 -0
- package/esm2022/components/multi-search/index.mjs +5 -0
- package/esm2022/components/multi-search/multi-search-tags/component.mjs +67 -0
- package/esm2022/components/multi-search/types.mjs +2 -0
- package/esm2022/components/multi-search/utils.mjs +46 -0
- package/esm2022/components/mutable/directive.mjs +351 -0
- package/esm2022/components/mutable/element.mjs +23 -0
- package/esm2022/components/mutable/index.mjs +15 -0
- package/esm2022/components/mutable/mosaic/component.mjs +76 -0
- package/esm2022/components/mutable/mosaic/directive.mjs +24 -0
- package/esm2022/components/mutable/util.mjs +16 -0
- package/esm2022/components/overview-banner/component.mjs +17 -0
- package/esm2022/components/table/component.mjs +321 -0
- package/esm2022/components/table/constants.mjs +4 -0
- package/esm2022/components/table/helper.mjs +16 -0
- package/esm2022/components/table/helpers.directive.mjs +19 -0
- package/esm2022/components/table/index.mjs +6 -0
- package/esm2022/components/table/types.mjs +2 -0
- package/esm2022/components/table/util.service.mjs +81 -0
- package/esm2022/form/base-form-container.mjs +2 -2
- package/esm2022/k8s-resource-list/footer/component.mjs +3 -3
- package/esm2022/page-deactivate/deactivate.directive.mjs +2 -2
- package/esm2022/page-deactivate/deactivate.guard.mjs +2 -3
- package/esm2022/page-deactivate/deactivate.service.mjs +4 -14
- package/fesm2022/alauda-fe-dynamic-plugin-shared.mjs +2228 -222
- package/fesm2022/alauda-fe-dynamic-plugin-shared.mjs.map +1 -1
- package/package.json +1 -1
- package/page-deactivate/deactivate.guard.d.ts +0 -2
- package/page-deactivate/deactivate.service.d.ts +1 -1
- package/styles/lib.scss +1 -1
- package/components/terminating-tag/component.d.ts +0 -7
- 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"]}
|