cnhis-design-vue 2.1.17 → 2.1.18

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 (122) hide show
  1. package/CHANGELOG.md +2219 -2219
  2. package/es/affix/index.js +8 -8
  3. package/es/age/index.js +10 -10
  4. package/es/alert/index.js +8 -8
  5. package/es/anchor/index.js +8 -8
  6. package/es/auto-complete/index.js +8 -8
  7. package/es/avatar/index.js +8 -8
  8. package/es/back-top/index.js +8 -8
  9. package/es/badge/index.js +8 -8
  10. package/es/base/index.js +8 -8
  11. package/es/big-table/index.js +164 -164
  12. package/es/breadcrumb/index.js +8 -8
  13. package/es/button/index.js +32 -32
  14. package/es/calendar/index.js +8 -8
  15. package/es/captcha/index.js +3 -3
  16. package/es/card/index.js +8 -8
  17. package/es/carousel/index.js +8 -8
  18. package/es/cascader/index.js +8 -8
  19. package/es/checkbox/index.js +9 -9
  20. package/es/col/index.js +8 -8
  21. package/es/collapse/index.js +8 -8
  22. package/es/color-picker/index.js +1 -1
  23. package/es/comment/index.js +8 -8
  24. package/es/config-provider/index.js +8 -8
  25. package/es/date-picker/index.js +8 -8
  26. package/es/descriptions/index.js +8 -8
  27. package/es/divider/index.js +8 -8
  28. package/es/drag-layout/index.js +3 -3
  29. package/es/drawer/index.js +8 -8
  30. package/es/dropdown/index.js +8 -8
  31. package/es/editor/index.js +1 -1
  32. package/es/empty/index.js +8 -8
  33. package/es/fabric-chart/index.js +34 -34
  34. package/es/form/index.js +8 -8
  35. package/es/form-model/index.js +8 -8
  36. package/es/form-table/index.js +62 -62
  37. package/es/index/index.js +672 -657
  38. package/es/index/style.css +1 -1
  39. package/es/input/index.js +9 -9
  40. package/es/input-number/index.js +8 -8
  41. package/es/layout/index.js +8 -8
  42. package/es/list/index.js +8 -8
  43. package/es/locale-provider/index.js +8 -8
  44. package/es/map/index.js +9 -9
  45. package/es/mentions/index.js +8 -8
  46. package/es/menu/index.js +8 -8
  47. package/es/message/index.js +8 -8
  48. package/es/multi-chat/index.js +92 -92
  49. package/es/multi-chat-client/index.js +86 -86
  50. package/es/multi-chat-history/index.js +4 -4
  51. package/es/multi-chat-record/index.js +14 -14
  52. package/es/multi-chat-setting/index.js +81 -66
  53. package/es/multi-chat-setting/style.css +1 -1
  54. package/es/multi-chat-sip/index.js +1 -1
  55. package/es/notification/index.js +8 -8
  56. package/es/page-header/index.js +8 -8
  57. package/es/pagination/index.js +8 -8
  58. package/es/popconfirm/index.js +8 -8
  59. package/es/popover/index.js +8 -8
  60. package/es/progress/index.js +8 -8
  61. package/es/radio/index.js +9 -9
  62. package/es/rate/index.js +8 -8
  63. package/es/result/index.js +8 -8
  64. package/es/row/index.js +8 -8
  65. package/es/scale-view/index.js +33 -33
  66. package/es/select/index.js +11 -11
  67. package/es/select-label/index.js +11 -11
  68. package/es/select-person/index.js +20 -20
  69. package/es/skeleton/index.js +8 -8
  70. package/es/slider/index.js +8 -8
  71. package/es/space/index.js +8 -8
  72. package/es/spin/index.js +8 -8
  73. package/es/statistic/index.js +8 -8
  74. package/es/steps/index.js +8 -8
  75. package/es/switch/index.js +8 -8
  76. package/es/table-filter/index.js +118 -118
  77. package/es/tabs/index.js +8 -8
  78. package/es/tag/index.js +9 -9
  79. package/es/time-picker/index.js +8 -8
  80. package/es/timeline/index.js +8 -8
  81. package/es/tooltip/index.js +8 -8
  82. package/es/transfer/index.js +8 -8
  83. package/es/tree/index.js +8 -8
  84. package/es/tree-select/index.js +8 -8
  85. package/es/upload/index.js +8 -8
  86. package/es/verification-code/index.js +2 -2
  87. package/lib/cui.common.js +620 -605
  88. package/lib/cui.umd.js +620 -605
  89. package/lib/cui.umd.min.js +71 -71
  90. package/package.json +106 -106
  91. package/packages/big-table/src/BigTable.vue +3038 -3038
  92. package/packages/big-table/src/assets/style/table-base.less +370 -370
  93. package/packages/big-table/src/components/AutoLayoutButton.vue +270 -270
  94. package/packages/big-table/src/utils/batchEditing.js +610 -610
  95. package/packages/big-table/src/utils/bigTableProps.js +95 -95
  96. package/packages/button/src/ButtonPrint/components/IdentityVerification.vue +181 -181
  97. package/packages/button/src/ButtonPrint/index.vue +728 -728
  98. package/packages/button/src/ButtonPrint/js/print.es.min.js +1 -1
  99. package/packages/fabric-chart/src/components/TimeScaleValue.vue +117 -117
  100. package/packages/fabric-chart/src/const/defaultVaule.js +59 -59
  101. package/packages/fabric-chart/src/fabric-chart/FabricPolylines.vue +960 -960
  102. package/packages/fabric-chart/src/fabric-chart/FabricScaleValue.vue +135 -135
  103. package/packages/fabric-chart/src/fabric-chart/FabricTextGroup.vue +558 -558
  104. package/packages/fabric-chart/src/fabric-chart2/FabricTop.vue +172 -172
  105. package/packages/multi-chat/chat/chatFooter.vue +1598 -1598
  106. package/packages/multi-chat/chat/chatMain.vue +1442 -1442
  107. package/packages/multi-chat/chat/quickReply.vue +439 -439
  108. package/packages/multi-chat/chat/scrollList.vue +1232 -1232
  109. package/packages/multi-chat/setting/baseInfo/index.vue +1316 -1302
  110. package/packages/multi-chat/store/actions.js +448 -448
  111. package/packages/multi-chat/store/state.js +112 -112
  112. package/packages/scale-view/formitem/r-choice.vue +714 -714
  113. package/packages/scale-view/scaleView.vue +2010 -2010
  114. package/packages/select-person/select-person.vue +1658 -1658
  115. package/packages/table-filter/src/base-search-com/BaseSearch.vue +2462 -2462
  116. package/packages/table-filter/src/components/c-tree-select/tree-select.vue +336 -336
  117. package/packages/table-filter/src/components/multi-select/multi-select.vue +219 -219
  118. package/packages/table-filter/src/components/out-quick-search/out-quick-search.vue +340 -340
  119. package/packages/table-filter/src/const/dataOptions.js +43 -43
  120. package/packages/table-filter/src/mixins/mixins.js +695 -695
  121. package/packages/table-filter/src/quick-search/QuickSearch.vue +2083 -2083
  122. package/src/directive/preventReClick.js +12 -12
@@ -1,336 +1,336 @@
1
- <template>
2
- <a-tree-select
3
- v-model="item.value"
4
- dropdownClassName="c-a-tree-select-container"
5
- @select="treeSelect"
6
- @change="change"
7
- :maxTagCount="handleMaxTagCount(item)"
8
- :maxTagPlaceholder="handleMaxTag"
9
- showSearch
10
- multiple
11
- :style="`width: ${item.advanceColWidth||160}px`"
12
- :class="[!showRemoveIcon && 'c-a-tree-select-show-hide-icon','c-a-quick-input-tree-mul']"
13
- :dropdown-style="{ maxHeight: '292px', overflow: 'auto' }"
14
- :tree-data="treeData"
15
- :allowClear="item.explicitRequired != 1"
16
- treeNodeFilterProp="title"
17
- ref="quickInputSelect"
18
- :placeholder="`请选择${item.alias || item.title}`"
19
- >
20
- <a-icon slot="suffixIcon" type="smile" />
21
- <span class="init-key-loading" v-if="key === '_init_key_'" slot="title" slot-scope="{ key, value }" style="color: #08c">
22
- <span v-show="false">{{ value }}</span>
23
- <a-spin :tip="`加载中...`" />
24
- </span>
25
- </a-tree-select>
26
- </template>
27
-
28
- <script>
29
- import { TreeSelect, Spin, Icon } from 'ant-design-vue';
30
- import vexutils from '@/utils/vexutils';
31
- export default {
32
- name: 'cTreeSelect',
33
- data() {
34
- return {
35
- treeData: [
36
- {
37
- // title: "_init_key_",
38
- value: '_init_key_',
39
- key: '_init_key_',
40
- selectable: false,
41
- scopedSlots: {
42
- title: 'title'
43
- }
44
- }
45
- ]
46
- };
47
- },
48
- props: {
49
- item: {
50
- type: Object,
51
- default: () => ({ value: [] })
52
- },
53
- handleGetConfigApi: {
54
- type: Function,
55
- default: () => {}
56
- },
57
- outFilterChange: {
58
- type: Function,
59
- default: () => {}
60
- }
61
- },
62
- computed: {
63
- handleMaxTagCount() {
64
- return function(item) {
65
- let len = this.maxTagPlaceholder(item);
66
- if (len <= 1) return 1;
67
- return 0;
68
- };
69
- },
70
- // handleMaxTag() {
71
- // return function(item) {
72
- // let len = this.maxTagPlaceholder(item);
73
- // if (len <= 1) return '';
74
- // return `已选${this.maxTagPlaceholder(item)}个${item.alias || item.title}`;
75
- // };
76
- // },
77
-
78
- showRemoveIcon() {
79
- let v = this.item.value;
80
- let f = 1 == this?.item?.filterExplicit
81
- if (Array.isArray(v) && f) {
82
- let l = v.length;
83
- if (this.item.explicitRequired == 1) {
84
- return l > 1;
85
- }
86
- }
87
- return true;
88
- }
89
- },
90
- watch: {
91
- 'item.value': {
92
- immediate: true,
93
- deep: true,
94
- handler() {
95
- // if (this.showRemoveIcon) return;
96
- this.handleDisabledTreeData(this.treeData,{showRemoveIcon: this.showRemoveIcon});
97
- this.$forceUpdate();
98
- }
99
- }
100
- },
101
- beforeCreate() {},
102
- created() {},
103
- beforeMount() {},
104
- mounted() {
105
- this.init();
106
- this.createSuffixIcon();
107
- },
108
- beforeUpdate() {},
109
- updated() {},
110
- beforeDestroy() {},
111
- destroyed() {},
112
- activated() {},
113
- methods: {
114
- async init() {
115
- try {
116
- let res = await this.handleRequestedOptions(this.item);
117
- let { result, map } = res.data;
118
- if (result !== 'SUCCESS') {
119
- this.treeData = [];
120
- return;
121
- }
122
- let rows = map.rows || [];
123
- if (rows) {
124
- this.handleInitTreeData(rows, this.item);
125
- this.treeData = rows;
126
- }
127
- } catch (error) {
128
- console.log(error);
129
- this.treeData = [];
130
- } finally {
131
- this.hanldeSetTreeDef();
132
- }
133
- },
134
- handleMaxTag() {
135
- let item = this.item;
136
- let len = this.maxTagPlaceholder(item);
137
- if (len <= 1) return '';
138
- return `已选${this.maxTagPlaceholder(item)}个${item.alias || item.title}`;
139
- },
140
- async handleRequestedOptions(item = {}) {
141
- let params = this.getSearchDefParams(item);
142
- let res = await this.handleGetConfigApi(params, 'requestGetWordbookData', { fields: item });
143
- return res;
144
- },
145
-
146
- getSearchDefParams(item = {}) {
147
- let obj = {};
148
- let { params = [], autograph, filterKeys, id, wordbookType } = item?.settingObj?.wordbook || {};
149
- if (params) {
150
- params.forEach(item => {
151
- obj[item.p_name] = item.p_value;
152
- });
153
- }
154
- if (autograph) {
155
- obj.autograph = autograph;
156
- }
157
- let resFieldKeys = Array.isArray(filterKeys) ? JSON.stringify(filterKeys) : filterKeys;
158
- let res = {
159
- wordbookId: id,
160
- fieldKeys: resFieldKeys,
161
- wordbookType: wordbookType || 'WORDBOOK',
162
- isLevelLazyLoad: false,
163
- ...obj
164
- };
165
-
166
- return res;
167
- },
168
-
169
- /* 解析下拉选择接口返回字段 */
170
- formatField(value, key) {
171
- let res = value;
172
- try {
173
- if (res && typeof res == 'string' && res.startsWith('###')) {
174
- res = res.slice(3);
175
- res = JSON.parse(res);
176
- res = res.change_text;
177
- }
178
-
179
- return res || '';
180
- } catch (error) {
181
- return '';
182
- }
183
- },
184
-
185
- hanldeGetCascadelabel(v = [], k = {}) {
186
- if (Array.isArray(v) && v.length) {
187
- const l = [];
188
- v.forEach(i => {
189
- let res = this.formatField(k[i]);
190
- l.push(res);
191
- });
192
- if (l.length == 0) {
193
- return '';
194
- }
195
- return l.join(' ');
196
- }
197
- return '';
198
- },
199
-
200
- handleInitTreeData(list = [], config = {}) {
201
- let { showKeys = [], field_key } = config?.setting?.wordbook || {};
202
- list.forEach((item, i) => {
203
- let val = vexutils.stringToValue(item[field_key], 'value');
204
- item.myLabel = this.hanldeGetCascadelabel(showKeys, item) || val;
205
- item.key = item.theUniqueKey;
206
- item.title = item.myLabel;
207
- // 避免接口配置的value 不知唯一值,导致前端页面卡死
208
- item.value = `${val}<&=&>${i}<&=&>${item.key}`;
209
- // item.scopedSlots = {
210
- // title: "title"
211
- // };
212
-
213
- if (item.children && item.children.length) {
214
- this.handleInitTreeData(item.children, config);
215
- }
216
- });
217
- },
218
-
219
- hanldeSetTreeDef() {
220
- let f = 1 == this?.item?.filterExplicit
221
- let df = this?.item?.explicitDefaultVal || '';
222
- if (df === 'firstOption' && f) {
223
- let [v] = this.treeData;
224
- this.item.value = v?.value ? [v.value] : [];
225
- if (typeof this.outFilterChange === 'function') {
226
- this.outFilterChange({type: 'outSearchInit'});
227
- }
228
- }
229
- },
230
-
231
- maxTagPlaceholder(item) {
232
- if (Array.isArray(item.value)) {
233
- return item.value.length;
234
- } else {
235
- return 1;
236
- }
237
- },
238
-
239
- treeSelect(key, vnode) {
240
- },
241
-
242
- change(){
243
- },
244
-
245
- handleDisabledTreeData(list = [], config = {}) {
246
- list.forEach((item, i) => {
247
- let k = config.showRemoveIcon? false: this.item.value.includes(item.value);
248
- this.$set(item, 'disabled', k);
249
- if (item.children && item.children.length) {
250
- this.handleDisabledTreeData(item.children, config);
251
- }
252
- });
253
- },
254
-
255
- createSuffixIcon() {
256
- let refDom = this.$refs.quickInputSelect;
257
- if (!refDom) return;
258
- let selectDom = refDom.$el;
259
- if(!selectDom) return;
260
-
261
- let pDom = selectDom.querySelector('.ant-select-selection--multiple');
262
- let hasTag = pDom.querySelector('.quick-input-select-span');
263
- if (!hasTag) {
264
- let tag = document.createElement('span');
265
- tag.className = 'quick-input-select-span';
266
- let icon = `<i aria-label="图标: down" class="anticon anticon-down ant-select-arrow-icon"><svg viewBox="64 64 896 896" data-icon="down" width="1em" height="1em" fill="currentColor" aria-hidden="true" focusable="false" class=""><path d="M884 256h-75c-5.1 0-9.9 2.5-12.9 6.6L512 654.2 227.9 262.6c-3-4.1-7.8-6.6-12.9-6.6h-75c-6.5 0-10.3 7.4-6.5 12.7l352.6 486.1c12.8 17.6 39 17.6 51.7 0l352.6-486.1c3.9-5.3.1-12.7-6.4-12.7z"></path></svg></i>`;
267
- tag.innerHTML = icon;
268
- pDom.appendChild(tag);
269
- }
270
- },
271
- },
272
- components: {
273
- [TreeSelect.name]: TreeSelect,
274
- [Spin.name]: Spin,
275
- [Icon.name]: Icon
276
- }
277
- };
278
- </script>
279
-
280
- <style lang="less">
281
- .c-a-tree-select-container {
282
- .ant-select-tree-title {
283
- display: inline-block;
284
- width: 100%;
285
- }
286
-
287
- .init-key-loading {
288
- display: flex;
289
- justify-content: center;
290
- width: 100%;
291
- }
292
-
293
- .ant-select-tree {
294
- li.filter-node {
295
- > span {
296
- font-weight: 600;
297
- }
298
- }
299
- }
300
- }
301
-
302
- .c-a-quick-input-tree-mul {
303
- .ant-select-selection--multiple {
304
- max-height: unset !important;
305
- }
306
- .ant-select-selection__rendered {
307
- height: 32px !important;
308
- overflow: hidden;
309
- }
310
- .ant-select-selection--multiple {
311
- position: relative;
312
- max-height: 32px !important;
313
- .quick-input-select-span {
314
- position: absolute;
315
- right: 2px;
316
- top: 4px;
317
- top: 50%;
318
- right: 11px;
319
- transform-origin: 50% 50%;
320
- margin-top: -7px;
321
- line-height: 1;
322
- .quick-input-select-icon {
323
- font-size: 12px;
324
- }
325
- }
326
- }
327
- }
328
-
329
-
330
-
331
- .c-a-tree-select-show-hide-icon {
332
- .ant-select-selection__choice__remove {
333
- display: none!important;
334
- }
335
- }
336
- </style>
1
+ <template>
2
+ <a-tree-select
3
+ v-model="item.value"
4
+ dropdownClassName="c-a-tree-select-container"
5
+ @select="treeSelect"
6
+ @change="change"
7
+ :maxTagCount="handleMaxTagCount(item)"
8
+ :maxTagPlaceholder="handleMaxTag"
9
+ showSearch
10
+ multiple
11
+ :style="`width: ${item.advanceColWidth||160}px`"
12
+ :class="[!showRemoveIcon && 'c-a-tree-select-show-hide-icon','c-a-quick-input-tree-mul']"
13
+ :dropdown-style="{ maxHeight: '292px', overflow: 'auto' }"
14
+ :tree-data="treeData"
15
+ :allowClear="item.explicitRequired != 1"
16
+ treeNodeFilterProp="title"
17
+ ref="quickInputSelect"
18
+ :placeholder="`请选择${item.alias || item.title}`"
19
+ >
20
+ <a-icon slot="suffixIcon" type="smile" />
21
+ <span class="init-key-loading" v-if="key === '_init_key_'" slot="title" slot-scope="{ key, value }" style="color: #08c">
22
+ <span v-show="false">{{ value }}</span>
23
+ <a-spin :tip="`加载中...`" />
24
+ </span>
25
+ </a-tree-select>
26
+ </template>
27
+
28
+ <script>
29
+ import { TreeSelect, Spin, Icon } from 'ant-design-vue';
30
+ import vexutils from '@/utils/vexutils';
31
+ export default {
32
+ name: 'cTreeSelect',
33
+ data() {
34
+ return {
35
+ treeData: [
36
+ {
37
+ // title: "_init_key_",
38
+ value: '_init_key_',
39
+ key: '_init_key_',
40
+ selectable: false,
41
+ scopedSlots: {
42
+ title: 'title'
43
+ }
44
+ }
45
+ ]
46
+ };
47
+ },
48
+ props: {
49
+ item: {
50
+ type: Object,
51
+ default: () => ({ value: [] })
52
+ },
53
+ handleGetConfigApi: {
54
+ type: Function,
55
+ default: () => {}
56
+ },
57
+ outFilterChange: {
58
+ type: Function,
59
+ default: () => {}
60
+ }
61
+ },
62
+ computed: {
63
+ handleMaxTagCount() {
64
+ return function(item) {
65
+ let len = this.maxTagPlaceholder(item);
66
+ if (len <= 1) return 1;
67
+ return 0;
68
+ };
69
+ },
70
+ // handleMaxTag() {
71
+ // return function(item) {
72
+ // let len = this.maxTagPlaceholder(item);
73
+ // if (len <= 1) return '';
74
+ // return `已选${this.maxTagPlaceholder(item)}个${item.alias || item.title}`;
75
+ // };
76
+ // },
77
+
78
+ showRemoveIcon() {
79
+ let v = this.item.value;
80
+ let f = 1 == this?.item?.filterExplicit
81
+ if (Array.isArray(v) && f) {
82
+ let l = v.length;
83
+ if (this.item.explicitRequired == 1) {
84
+ return l > 1;
85
+ }
86
+ }
87
+ return true;
88
+ }
89
+ },
90
+ watch: {
91
+ 'item.value': {
92
+ immediate: true,
93
+ deep: true,
94
+ handler() {
95
+ // if (this.showRemoveIcon) return;
96
+ this.handleDisabledTreeData(this.treeData,{showRemoveIcon: this.showRemoveIcon});
97
+ this.$forceUpdate();
98
+ }
99
+ }
100
+ },
101
+ beforeCreate() {},
102
+ created() {},
103
+ beforeMount() {},
104
+ mounted() {
105
+ this.init();
106
+ this.createSuffixIcon();
107
+ },
108
+ beforeUpdate() {},
109
+ updated() {},
110
+ beforeDestroy() {},
111
+ destroyed() {},
112
+ activated() {},
113
+ methods: {
114
+ async init() {
115
+ try {
116
+ let res = await this.handleRequestedOptions(this.item);
117
+ let { result, map } = res.data;
118
+ if (result !== 'SUCCESS') {
119
+ this.treeData = [];
120
+ return;
121
+ }
122
+ let rows = map.rows || [];
123
+ if (rows) {
124
+ this.handleInitTreeData(rows, this.item);
125
+ this.treeData = rows;
126
+ }
127
+ } catch (error) {
128
+ console.log(error);
129
+ this.treeData = [];
130
+ } finally {
131
+ this.hanldeSetTreeDef();
132
+ }
133
+ },
134
+ handleMaxTag() {
135
+ let item = this.item;
136
+ let len = this.maxTagPlaceholder(item);
137
+ if (len <= 1) return '';
138
+ return `已选${this.maxTagPlaceholder(item)}个${item.alias || item.title}`;
139
+ },
140
+ async handleRequestedOptions(item = {}) {
141
+ let params = this.getSearchDefParams(item);
142
+ let res = await this.handleGetConfigApi(params, 'requestGetWordbookData', { fields: item });
143
+ return res;
144
+ },
145
+
146
+ getSearchDefParams(item = {}) {
147
+ let obj = {};
148
+ let { params = [], autograph, filterKeys, id, wordbookType } = item?.settingObj?.wordbook || {};
149
+ if (params) {
150
+ params.forEach(item => {
151
+ obj[item.p_name] = item.p_value;
152
+ });
153
+ }
154
+ if (autograph) {
155
+ obj.autograph = autograph;
156
+ }
157
+ let resFieldKeys = Array.isArray(filterKeys) ? JSON.stringify(filterKeys) : filterKeys;
158
+ let res = {
159
+ wordbookId: id,
160
+ fieldKeys: resFieldKeys,
161
+ wordbookType: wordbookType || 'WORDBOOK',
162
+ isLevelLazyLoad: false,
163
+ ...obj
164
+ };
165
+
166
+ return res;
167
+ },
168
+
169
+ /* 解析下拉选择接口返回字段 */
170
+ formatField(value, key) {
171
+ let res = value;
172
+ try {
173
+ if (res && typeof res == 'string' && res.startsWith('###')) {
174
+ res = res.slice(3);
175
+ res = JSON.parse(res);
176
+ res = res.change_text;
177
+ }
178
+
179
+ return res || '';
180
+ } catch (error) {
181
+ return '';
182
+ }
183
+ },
184
+
185
+ hanldeGetCascadelabel(v = [], k = {}) {
186
+ if (Array.isArray(v) && v.length) {
187
+ const l = [];
188
+ v.forEach(i => {
189
+ let res = this.formatField(k[i]);
190
+ l.push(res);
191
+ });
192
+ if (l.length == 0) {
193
+ return '';
194
+ }
195
+ return l.join(' ');
196
+ }
197
+ return '';
198
+ },
199
+
200
+ handleInitTreeData(list = [], config = {}) {
201
+ let { showKeys = [], field_key } = config?.setting?.wordbook || {};
202
+ list.forEach((item, i) => {
203
+ let val = vexutils.stringToValue(item[field_key], 'value');
204
+ item.myLabel = this.hanldeGetCascadelabel(showKeys, item) || val;
205
+ item.key = item.theUniqueKey;
206
+ item.title = item.myLabel;
207
+ // 避免接口配置的value 不知唯一值,导致前端页面卡死
208
+ item.value = `${val}<&=&>${i}<&=&>${item.key}`;
209
+ // item.scopedSlots = {
210
+ // title: "title"
211
+ // };
212
+
213
+ if (item.children && item.children.length) {
214
+ this.handleInitTreeData(item.children, config);
215
+ }
216
+ });
217
+ },
218
+
219
+ hanldeSetTreeDef() {
220
+ let f = 1 == this?.item?.filterExplicit
221
+ let df = this?.item?.explicitDefaultVal || '';
222
+ if (df === 'firstOption' && f) {
223
+ let [v] = this.treeData;
224
+ this.item.value = v?.value ? [v.value] : [];
225
+ if (typeof this.outFilterChange === 'function') {
226
+ this.outFilterChange({type: 'outSearchInit'});
227
+ }
228
+ }
229
+ },
230
+
231
+ maxTagPlaceholder(item) {
232
+ if (Array.isArray(item.value)) {
233
+ return item.value.length;
234
+ } else {
235
+ return 1;
236
+ }
237
+ },
238
+
239
+ treeSelect(key, vnode) {
240
+ },
241
+
242
+ change(){
243
+ },
244
+
245
+ handleDisabledTreeData(list = [], config = {}) {
246
+ list.forEach((item, i) => {
247
+ let k = config.showRemoveIcon? false: this.item.value.includes(item.value);
248
+ this.$set(item, 'disabled', k);
249
+ if (item.children && item.children.length) {
250
+ this.handleDisabledTreeData(item.children, config);
251
+ }
252
+ });
253
+ },
254
+
255
+ createSuffixIcon() {
256
+ let refDom = this.$refs.quickInputSelect;
257
+ if (!refDom) return;
258
+ let selectDom = refDom.$el;
259
+ if(!selectDom) return;
260
+
261
+ let pDom = selectDom.querySelector('.ant-select-selection--multiple');
262
+ let hasTag = pDom.querySelector('.quick-input-select-span');
263
+ if (!hasTag) {
264
+ let tag = document.createElement('span');
265
+ tag.className = 'quick-input-select-span';
266
+ let icon = `<i aria-label="图标: down" class="anticon anticon-down ant-select-arrow-icon"><svg viewBox="64 64 896 896" data-icon="down" width="1em" height="1em" fill="currentColor" aria-hidden="true" focusable="false" class=""><path d="M884 256h-75c-5.1 0-9.9 2.5-12.9 6.6L512 654.2 227.9 262.6c-3-4.1-7.8-6.6-12.9-6.6h-75c-6.5 0-10.3 7.4-6.5 12.7l352.6 486.1c12.8 17.6 39 17.6 51.7 0l352.6-486.1c3.9-5.3.1-12.7-6.4-12.7z"></path></svg></i>`;
267
+ tag.innerHTML = icon;
268
+ pDom.appendChild(tag);
269
+ }
270
+ },
271
+ },
272
+ components: {
273
+ [TreeSelect.name]: TreeSelect,
274
+ [Spin.name]: Spin,
275
+ [Icon.name]: Icon
276
+ }
277
+ };
278
+ </script>
279
+
280
+ <style lang="less">
281
+ .c-a-tree-select-container {
282
+ .ant-select-tree-title {
283
+ display: inline-block;
284
+ width: 100%;
285
+ }
286
+
287
+ .init-key-loading {
288
+ display: flex;
289
+ justify-content: center;
290
+ width: 100%;
291
+ }
292
+
293
+ .ant-select-tree {
294
+ li.filter-node {
295
+ > span {
296
+ font-weight: 600;
297
+ }
298
+ }
299
+ }
300
+ }
301
+
302
+ .c-a-quick-input-tree-mul {
303
+ .ant-select-selection--multiple {
304
+ max-height: unset !important;
305
+ }
306
+ .ant-select-selection__rendered {
307
+ height: 32px !important;
308
+ overflow: hidden;
309
+ }
310
+ .ant-select-selection--multiple {
311
+ position: relative;
312
+ max-height: 32px !important;
313
+ .quick-input-select-span {
314
+ position: absolute;
315
+ right: 2px;
316
+ top: 4px;
317
+ top: 50%;
318
+ right: 11px;
319
+ transform-origin: 50% 50%;
320
+ margin-top: -7px;
321
+ line-height: 1;
322
+ .quick-input-select-icon {
323
+ font-size: 12px;
324
+ }
325
+ }
326
+ }
327
+ }
328
+
329
+
330
+
331
+ .c-a-tree-select-show-hide-icon {
332
+ .ant-select-selection__choice__remove {
333
+ display: none!important;
334
+ }
335
+ }
336
+ </style>