@ebiz/designer-components 0.1.80 → 0.1.82

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 (220) hide show
  1. package/README.md +29 -29
  2. package/dist/designer-components.css +1 -1
  3. package/dist/index.mjs +26609 -24286
  4. package/package.json +2 -1
  5. package/src/App.vue +26 -26
  6. package/src/apiService/SIMPLE_DATA_SERVICE.md +284 -284
  7. package/src/apiService/mockDataService.js +115 -115
  8. package/src/apiService/simpleDataService.js +299 -299
  9. package/src/assets/base.css +86 -86
  10. package/src/assets/logo.svg +1 -1
  11. package/src/components/Button.vue +149 -149
  12. package/src/components/DataContainer.vue +40 -40
  13. package/src/components/EbizApproval.vue +335 -335
  14. package/src/components/EbizApprovalForm.vue +507 -507
  15. package/src/components/EbizAutoForm.vue +596 -596
  16. package/src/components/EbizAvatar.vue +115 -115
  17. package/src/components/EbizCheckbox.vue +93 -93
  18. package/src/components/EbizCheckboxGroup.vue +69 -69
  19. package/src/components/EbizDepartmentSelector.vue +149 -149
  20. package/src/components/EbizDescriptions.vue +340 -340
  21. package/src/components/EbizDescriptionsItem.vue +47 -47
  22. package/src/components/EbizDetailBlock.vue +81 -81
  23. package/src/components/EbizDetailItem.vue +559 -559
  24. package/src/components/EbizDetailView.md +438 -438
  25. package/src/components/EbizDetailView.vue +355 -355
  26. package/src/components/EbizDialog.vue +260 -260
  27. package/src/components/EbizDictionarySelect.vue +229 -0
  28. package/src/components/EbizDiv.vue +40 -40
  29. package/src/components/EbizDivider.vue +96 -96
  30. package/src/components/EbizDropdown.vue +135 -135
  31. package/src/components/EbizDropdownItem.vue +85 -85
  32. package/src/components/EbizEmployeeInfo.vue +145 -139
  33. package/src/components/EbizEmployeeSelector.vue +1159 -1159
  34. package/src/components/EbizFileList.vue +466 -466
  35. package/src/components/EbizMap.vue +541 -541
  36. package/src/components/EbizMeetingRoomSelector.vue +664 -664
  37. package/src/components/EbizMobileMeetingRoomSelector.vue +727 -727
  38. package/src/components/EbizOkrTree.vue +99 -99
  39. package/src/components/EbizPageHeader.vue +99 -96
  40. package/src/components/EbizPagination.vue +162 -162
  41. package/src/components/EbizPdfViewer.vue +540 -540
  42. package/src/components/EbizPopconfirm.vue +47 -47
  43. package/src/components/EbizQrCode.vue +73 -73
  44. package/src/components/EbizRadio.vue +86 -86
  45. package/src/components/EbizRadioGroup.vue +83 -83
  46. package/src/components/EbizRemoteSelect.vue +232 -232
  47. package/src/components/EbizRichTextEditor.vue +275 -275
  48. package/src/components/EbizRouteBreadcrumb.vue +46 -46
  49. package/src/components/EbizSApprovalProcess.vue +1429 -1429
  50. package/src/components/EbizSelect.vue +85 -85
  51. package/src/components/EbizSpace.vue +100 -100
  52. package/src/components/EbizStatistic.vue +149 -149
  53. package/src/components/EbizStatsCard.vue +113 -113
  54. package/src/components/EbizSwiper.vue +113 -113
  55. package/src/components/EbizSwiperItem.vue +13 -13
  56. package/src/components/EbizSwitch.vue +85 -85
  57. package/src/components/EbizTabHeader.vue +132 -132
  58. package/src/components/EbizTabPanel.vue +22 -22
  59. package/src/components/EbizTable.vue +469 -469
  60. package/src/components/EbizTableColumn.vue +116 -116
  61. package/src/components/EbizTableSort.vue +179 -179
  62. package/src/components/EbizTabs.vue +142 -142
  63. package/src/components/EbizTdesignButtonDialog.vue +332 -332
  64. package/src/components/EbizTdesignLoading.vue +107 -107
  65. package/src/components/EbizTimePicker.vue +143 -143
  66. package/src/components/EbizTitle.vue +91 -91
  67. package/src/components/EbizTree.vue +141 -141
  68. package/src/components/EbizTreeMergeTable.vue +1494 -1494
  69. package/src/components/EbizTreeSelector.vue +418 -418
  70. package/src/components/EbizVideo.vue +553 -553
  71. package/src/components/EbizVxeTable.vue +290 -290
  72. package/src/components/Form.vue +28 -28
  73. package/src/components/Home.vue +7 -7
  74. package/src/components/MyComponent.vue +39 -39
  75. package/src/components/Table.vue +45 -45
  76. package/src/components/TdesignAlert.vue +115 -115
  77. package/src/components/TdesignButton.vue +135 -135
  78. package/src/components/TdesignCalendar/index.vue +145 -145
  79. package/src/components/TdesignCard.vue +195 -195
  80. package/src/components/TdesignCol.vue +101 -101
  81. package/src/components/TdesignCollapse.vue +142 -142
  82. package/src/components/TdesignCollapsePanel.vue +79 -79
  83. package/src/components/TdesignDatePicker.vue +124 -124
  84. package/src/components/TdesignDescriptions.vue +74 -74
  85. package/src/components/TdesignDescriptionsItem.vue +50 -50
  86. package/src/components/TdesignDialog.vue +225 -225
  87. package/src/components/TdesignForm.vue +138 -138
  88. package/src/components/TdesignFormItem.vue +105 -105
  89. package/src/components/TdesignGrid.vue +55 -55
  90. package/src/components/TdesignIcon.vue +67 -67
  91. package/src/components/TdesignImage.vue +162 -162
  92. package/src/components/TdesignImageViewer.vue +200 -200
  93. package/src/components/TdesignInput.vue +242 -242
  94. package/src/components/TdesignSelect.vue +446 -446
  95. package/src/components/TdesignTag.vue +117 -117
  96. package/src/components/TdesignTextarea.vue +142 -142
  97. package/src/components/TdesignTimeline.vue +58 -58
  98. package/src/components/TdesignTimelineItem.vue +71 -71
  99. package/src/components/TdesignUpload.vue +414 -414
  100. package/src/components/TdesignWatermark.vue +107 -107
  101. package/src/components/ebiz-form/components/cascader.vue +61 -61
  102. package/src/components/ebiz-form/components/checkbox.vue +37 -37
  103. package/src/components/ebiz-form/components/city.vue +137 -137
  104. package/src/components/ebiz-form/components/date-panel.vue +52 -52
  105. package/src/components/ebiz-form/components/date-range-panel.vue +52 -52
  106. package/src/components/ebiz-form/components/date-range.vue +56 -56
  107. package/src/components/ebiz-form/components/date.vue +52 -52
  108. package/src/components/ebiz-form/components/editor-multi-language.vue +47 -47
  109. package/src/components/ebiz-form/components/editor.vue +78 -78
  110. package/src/components/ebiz-form/components/file-multi-language.vue +52 -52
  111. package/src/components/ebiz-form/components/file.vue +149 -149
  112. package/src/components/ebiz-form/components/images-multi-language.vue +52 -52
  113. package/src/components/ebiz-form/components/images.vue +129 -129
  114. package/src/components/ebiz-form/components/img-multi-language.vue +51 -51
  115. package/src/components/ebiz-form/components/img.vue +129 -129
  116. package/src/components/ebiz-form/components/number.vue +50 -50
  117. package/src/components/ebiz-form/components/radio.vue +28 -28
  118. package/src/components/ebiz-form/components/select.vue +119 -119
  119. package/src/components/ebiz-form/components/switch.vue +23 -23
  120. package/src/components/ebiz-form/components/text-multi-language.vue +47 -47
  121. package/src/components/ebiz-form/components/text.vue +52 -52
  122. package/src/components/ebiz-form/components/textarea-multi-language.vue +48 -48
  123. package/src/components/ebiz-form/components/textarea.vue +29 -29
  124. package/src/components/ebiz-form/components/video-multi-language.vue +51 -51
  125. package/src/components/ebiz-form/components/video.vue +97 -97
  126. package/src/components/ebiz-form/index.vue +157 -157
  127. package/src/components/examples/PopconfirmExample.vue +149 -149
  128. package/src/components/icons/IconCommunity.vue +7 -7
  129. package/src/components/icons/IconDocumentation.vue +7 -7
  130. package/src/components/icons/IconEcosystem.vue +7 -7
  131. package/src/components/icons/IconSupport.vue +7 -7
  132. package/src/components/icons/IconTooling.vue +19 -19
  133. package/src/components/mItems/UserInfo.vue +342 -342
  134. package/src/components/senior/EbizSData/index.vue +273 -273
  135. package/src/components/senior/EbizSDialog/index.vue +770 -770
  136. package/src/components/senior/EbizSForm/README.md +157 -157
  137. package/src/components/senior/EbizSForm/index.vue +667 -667
  138. package/src/components/senior/EbizSForm/item.vue +986 -971
  139. package/src/components/senior/EbizSForm/mItems/DateTimePicker.vue +51 -51
  140. package/src/components/senior/EbizSForm/mItems/Picker.vue +63 -63
  141. package/src/index.js +313 -255
  142. package/src/main.js +55 -55
  143. package/src/router/index.js +415 -415
  144. package/src/utils/formatCode.js +24 -24
  145. package/src/utils/generateImportStatement.js +52 -52
  146. package/src/utils/hasJsx.js +25 -25
  147. package/src/utils/index.js +166 -166
  148. package/src/utils/mergeOptions.js +29 -29
  149. package/src/utils/parseRequiredBlocks.js +18 -18
  150. package/src/utils/vue-sfc-validator.js +155 -155
  151. package/src/views/Button.vue +23 -23
  152. package/src/views/CheckboxDemo.vue +104 -104
  153. package/src/views/DataContainer.vue +19 -19
  154. package/src/views/DialogDemo.vue +125 -125
  155. package/src/views/EbizApprovalDemo.vue +87 -87
  156. package/src/views/EbizApprovalFormDemo.vue +207 -207
  157. package/src/views/EbizAutoFormDemo.vue +129 -129
  158. package/src/views/EbizAvatar.vue +223 -223
  159. package/src/views/EbizDepartmentSelectorDemo.vue +169 -169
  160. package/src/views/EbizDetailBlockDemo.vue +30 -30
  161. package/src/views/EbizDetailViewDemo.vue +412 -412
  162. package/src/views/EbizEmployeeInfo.vue +249 -249
  163. package/src/views/EbizEmployeeSelector.vue +85 -85
  164. package/src/views/EbizFileListDemo.vue +339 -339
  165. package/src/views/EbizMap.vue +201 -201
  166. package/src/views/EbizMeetingRoomSelectorDemo.vue +293 -293
  167. package/src/views/EbizMobileMeetingRoomSelectorDemo.vue +566 -566
  168. package/src/views/EbizRadioDemo.vue +151 -151
  169. package/src/views/EbizSDataDemo.vue +136 -136
  170. package/src/views/EbizSDialogDemo.vue +303 -303
  171. package/src/views/EbizSForm/index.vue +352 -351
  172. package/src/views/EbizSFormDemo.vue +420 -420
  173. package/src/views/EbizSpace.vue +185 -185
  174. package/src/views/EbizSwiper.vue +157 -157
  175. package/src/views/EbizTdesignButtonDialogExample.vue +437 -437
  176. package/src/views/Form.vue +19 -19
  177. package/src/views/GridDemo.vue +238 -238
  178. package/src/views/Home.vue +153 -153
  179. package/src/views/Mindmap.vue +17 -17
  180. package/src/views/MyComponent.vue +19 -19
  181. package/src/views/OkrTree.vue +19 -19
  182. package/src/views/PageHeaderDemo.vue +104 -104
  183. package/src/views/PaginationDemo.vue +96 -96
  184. package/src/views/PdfViewerDemo.vue +433 -433
  185. package/src/views/PermissionBoxDemo.vue +85 -85
  186. package/src/views/PopconfirmDemo.vue +80 -80
  187. package/src/views/RemoteSelect.vue +350 -350
  188. package/src/views/StatisticDemo.vue +190 -190
  189. package/src/views/SwitchDemo.vue +79 -79
  190. package/src/views/Table.vue +19 -19
  191. package/src/views/TableDemo.vue +334 -334
  192. package/src/views/TableSortDemo.vue +143 -143
  193. package/src/views/TableView.vue +68 -68
  194. package/src/views/TabsDemo.vue +282 -282
  195. package/src/views/TagDemo.vue +101 -101
  196. package/src/views/TdesignAlert.vue +98 -98
  197. package/src/views/TdesignButton.vue +190 -190
  198. package/src/views/TdesignCalendar.vue +94 -94
  199. package/src/views/TdesignCard.vue +296 -296
  200. package/src/views/TdesignCollapse.vue +293 -293
  201. package/src/views/TdesignDatePicker.vue +187 -187
  202. package/src/views/TdesignDescriptions.vue +101 -101
  203. package/src/views/TdesignForm.vue +248 -248
  204. package/src/views/TdesignIcon.vue +203 -203
  205. package/src/views/TdesignImage.vue +215 -215
  206. package/src/views/TdesignImageViewer.vue +198 -198
  207. package/src/views/TdesignInput.vue +252 -252
  208. package/src/views/TdesignSelect.vue +473 -473
  209. package/src/views/TdesignSwiper.vue +157 -157
  210. package/src/views/TextareaDemo.vue +93 -93
  211. package/src/views/TimePickerDemo.vue +146 -146
  212. package/src/views/TimelineDemo.vue +160 -160
  213. package/src/views/Title.vue +19 -19
  214. package/src/views/TreeDemo.vue +254 -254
  215. package/src/views/TreeMergeTableDemo.vue +239 -239
  216. package/src/views/TreeSelectorDemo.vue +245 -245
  217. package/src/views/UploadDemo.vue +128 -128
  218. package/src/views/VideoDemo.vue +245 -245
  219. package/src/views/VxeTableDemo.vue +279 -279
  220. package/src/views/WatermarkDemo.vue +85 -85
@@ -1,447 +1,447 @@
1
- <template>
2
- <t-select
3
- :autoWidth="autoWidth"
4
- :borderless="borderless"
5
- :clearable="clearable"
6
- :collapsedItems="collapsedItems"
7
- :creatable="creatable"
8
- :disabled="disabled"
9
- :empty="empty"
10
- :filterable="filterable"
11
- :keys="keys"
12
- :label="label"
13
- :loading="loading"
14
- :loadingText="loadingText"
15
- :max="max"
16
- :minCollapsedNum="minCollapsedNum"
17
- :multiple="multiple"
18
- :options="options"
19
- :placeholder="placeholder"
20
- :popupProps="popupProps"
21
- :prefixIcon="prefixIcon"
22
- :readonly="readonly"
23
- :reserveKeyword="reserveKeyword"
24
- :scroll="scroll"
25
- :selectInputProps="selectInputProps"
26
- :showArrow="showArrow"
27
- :size="size"
28
- :status="status"
29
- :tagInputProps="tagInputProps"
30
- :tagProps="tagProps"
31
- :tips="tips"
32
- :valueDisplay="valueDisplay"
33
- :valueType="valueType"
34
- :onPaste="onPaste"
35
- v-model="selectedValue"
36
- @blur="handleBlur"
37
- @change="handleChange"
38
- @clear="handleClear"
39
- @create="handleCreate"
40
- @dropdown-visible-change="handleDropdownVisibleChange"
41
- @enter="handleEnter"
42
- @focus="handleFocus"
43
- @keydown="handleKeydown"
44
- @mouseenter="handleMouseenter"
45
- @mouseleave="handleMouseleave"
46
- @paste="handlePaste"
47
- @popup-visible-change="handlePopupVisibleChange"
48
- @remove="handleRemove"
49
- @scroll="handleScroll"
50
- @search="handleSearch"
51
- >
52
- <!-- 选项插槽 -->
53
- <template v-if="$slots.options" #options>
54
- <slot name="options"></slot>
55
- </template>
56
-
57
- <!-- 前缀图标插槽 -->
58
- <template v-if="$slots.prefixIcon" #prefixIcon>
59
- <slot name="prefixIcon"></slot>
60
- </template>
61
-
62
- <!-- 后缀图标插槽 -->
63
- <template v-if="$slots.suffixIcon" #suffixIcon>
64
- <slot name="suffixIcon"></slot>
65
- </template>
66
-
67
- <!-- 后缀内容插槽 -->
68
- <template v-if="$slots.suffix" #suffix>
69
- <slot name="suffix"></slot>
70
- </template>
71
-
72
- <!-- 空数据插槽 -->
73
- <template v-if="$slots.empty" #empty>
74
- <slot name="empty"></slot>
75
- </template>
76
-
77
- <!-- 选项显示插槽 -->
78
- <template v-if="$slots.valueDisplay" #valueDisplay>
79
- <slot name="valueDisplay"></slot>
80
- </template>
81
-
82
- <!-- 面板底部内容插槽 -->
83
- <template v-if="$slots.panelBottomContent" #panelBottomContent>
84
- <slot name="panelBottomContent"></slot>
85
- </template>
86
-
87
- <!-- 面板顶部内容插槽 -->
88
- <template v-if="$slots.panelTopContent" #panelTopContent>
89
- <slot name="panelTopContent"></slot>
90
- </template>
91
-
92
- <!-- 选项标签插槽 -->
93
- <template v-if="$slots.tag" #tag>
94
- <slot name="tag"></slot>
95
- </template>
96
-
97
- <!-- 加载中插槽 -->
98
- <template v-if="$slots.loadingText" #loadingText>
99
- <slot name="loadingText"></slot>
100
- </template>
101
-
102
- <!-- 折叠项插槽 -->
103
- <template v-if="$slots.collapsedItems" #collapsedItems>
104
- <slot name="collapsedItems"></slot>
105
- </template>
106
-
107
- <!-- 选择框自定义首部内容插槽 -->
108
- <template v-if="$slots.header" #header>
109
- <slot name="header"></slot>
110
- </template>
111
-
112
- <!-- 选择框自定义底部内容插槽 -->
113
- <template v-if="$slots.footer" #footer>
114
- <slot name="footer"></slot>
115
- </template>
116
-
117
- <!-- 输入框前置内容插槽 -->
118
- <template v-if="$slots.prepend" #prepend>
119
- <slot name="prepend"></slot>
120
- </template>
121
-
122
- <!-- 输入框后置内容插槽 -->
123
- <template v-if="$slots.append" #append>
124
- <slot name="append"></slot>
125
- </template>
126
-
127
- <!-- 选项内容插槽 -->
128
- <template v-if="$slots.default" #default>
129
- <slot></slot>
130
- </template>
131
-
132
- <!-- 选项分组标题插槽 -->
133
- <template v-if="$slots.optionGroup" #optionGroup>
134
- <slot name="optionGroup"></slot>
135
- </template>
136
- </t-select>
137
- </template>
138
-
139
- <script>
140
- export default {
141
- name: "EbizTdesignSelect"
142
- }
143
- </script>
144
-
145
- <script setup>
146
- import { defineProps, defineEmits, computed } from 'vue';
147
- import { Select as TSelect } from 'tdesign-vue-next';
148
-
149
- const props = defineProps({
150
- // 选择器的值
151
- modelValue: {
152
- type: [String, Number, Object, Array],
153
- default: undefined
154
- },
155
- // 宽度随内容自适应
156
- autoWidth: {
157
- type: Boolean,
158
- default: false
159
- },
160
- // 无边框模式
161
- borderless: {
162
- type: Boolean,
163
- default: false
164
- },
165
- // 是否可以清空选项
166
- clearable: {
167
- type: Boolean,
168
- default: false
169
- },
170
- // 用于控制多选数量超出时,折叠选项的内容
171
- collapsedItems: {
172
- type: [Function, Boolean],
173
- default: undefined
174
- },
175
- // 是否允许用户创建新条目
176
- creatable: {
177
- type: Boolean,
178
- default: false
179
- },
180
- // 是否禁用选择器
181
- disabled: {
182
- type: Boolean,
183
- default: false
184
- },
185
- // 当下拉列表为空时显示的内容
186
- empty: {
187
- type: String,
188
- default: undefined
189
- },
190
- // 自定义过滤方法
191
- filter: {
192
- type: Function,
193
- default: undefined
194
- },
195
- // 是否可搜索
196
- filterable: {
197
- type: Boolean,
198
- default: false
199
- },
200
- // 默认搜索处理,开启后不需监听 search 事件
201
- ifDefaultHandleSearch: {
202
- type: Boolean,
203
- default: false
204
- },
205
- // 用来定义选项中的字段别名
206
- keys: {
207
- type: Object,
208
- default: () => ({})
209
- },
210
- // 左侧文本
211
- label: {
212
- type: [String, Function],
213
- default: undefined
214
- },
215
- // 是否为加载状态
216
- loading: {
217
- type: Boolean,
218
- default: false
219
- },
220
- // 远程加载时显示的文字
221
- loadingText: {
222
- type: String,
223
- default: undefined
224
- },
225
- // 用于控制多选数量,值为 0 则不限制
226
- max: {
227
- type: Number,
228
- default: 0
229
- },
230
- // 最小折叠数量,用于多选情况下折叠选中项
231
- minCollapsedNum: {
232
- type: Number,
233
- default: 0
234
- },
235
- // 是否允许多选
236
- multiple: {
237
- type: Boolean,
238
- default: false
239
- },
240
- // 数据化配置选项内容
241
- options: {
242
- type: Array,
243
- default: () => []
244
- },
245
- // 占位符
246
- placeholder: {
247
- type: String,
248
- default: undefined
249
- },
250
- // 弹出层的定位方式,同 Popup 组件
251
- popupProps: {
252
- type: Object,
253
- default: () => ({})
254
- },
255
- // 是否显示下拉框 //这个属性会导致search的值不显示
256
- // popupVisible: {
257
- // type: Boolean,
258
- // default: undefined
259
- // },
260
- // 前缀图标
261
- prefixIcon: {
262
- type: [Function, String],
263
- default: undefined
264
- },
265
- // 只读状态
266
- readonly: {
267
- type: Boolean,
268
- default: false
269
- },
270
- // 多选且可搜索时,是否在选中一个选项后保留当前的搜索关键词
271
- reserveKeyword: {
272
- type: Boolean,
273
- default: false
274
- },
275
- // 懒加载和虚拟滚动配置
276
- scroll: {
277
- type: Object,
278
- default: () => ({})
279
- },
280
- // 透传 SelectInput 筛选器输入框组件的全部属性
281
- selectInputProps: {
282
- type: Object,
283
- default: () => ({})
284
- },
285
- // 是否显示右侧箭头
286
- showArrow: {
287
- type: Boolean,
288
- default: true
289
- },
290
- // 组件尺寸
291
- size: {
292
- type: String,
293
- default: 'medium',
294
- validator: (val) => ['small', 'medium', 'large'].includes(val)
295
- },
296
- // 输入框状态
297
- status: {
298
- type: String,
299
- default: undefined,
300
- validator: (val) => ['default', 'success', 'warning', 'error'].includes(val)
301
- },
302
- // 后置图标前的后置内容
303
- suffix: {
304
- type: String,
305
- default: undefined
306
- },
307
- // 后置图标
308
- suffixIcon: {
309
- type: [Function, String],
310
- default: undefined
311
- },
312
- // 透传 TagInput 标签输入框组件的全部属性
313
- tagInputProps: {
314
- type: Object,
315
- default: () => ({})
316
- },
317
- // 透传 Tag 标签组件的全部属性
318
- tagProps: {
319
- type: Object,
320
- default: () => ({})
321
- },
322
- // 输入框下方提示文本,会根据不同的 status 呈现不同的样式
323
- tips: {
324
- type: String,
325
- default: ''
326
- },
327
- // 自定义选中项呈现方式
328
- valueDisplay: {
329
- type: Function,
330
- default: undefined
331
- },
332
- // 用于控制选中值的类型
333
- valueType: {
334
- type: String,
335
- default: undefined,
336
- validator: (val) => ['value', 'object'].includes(val)
337
- },
338
- // 粘贴事件回调函数,参数为粘贴板内容
339
- onPaste: {
340
- type: Function,
341
- default: undefined
342
- }
343
- });
344
-
345
- // 选择器的值
346
- const selectedValue = computed({
347
- get: () => props.modelValue,
348
- set: (value) => emit('update:modelValue', value)
349
- });
350
-
351
- const emit = defineEmits([
352
- 'update:modelValue',
353
- 'blur',
354
- 'change',
355
- 'clear',
356
- 'create',
357
- 'dropdown-visible-change',
358
- 'enter',
359
- 'focus',
360
- 'keydown',
361
- 'mouseenter',
362
- 'mouseleave',
363
- 'paste',
364
- 'popup-visible-change',
365
- 'remove',
366
- 'scroll',
367
- 'search'
368
- ]);
369
-
370
- // 失去焦点时触发
371
- const handleBlur = (value, context) => {
372
- emit('blur', value, context);
373
- };
374
-
375
- // 选中值变化时触发
376
- const handleChange = (value, context) => {
377
- emit('change', value, context);
378
- };
379
-
380
- // 点击清除按钮时触发
381
- const handleClear = (context) => {
382
- emit('clear', context);
383
- };
384
-
385
- // 当新增选项时触发
386
- const handleCreate = (value, context) => {
387
- emit('create', value, context);
388
- };
389
-
390
- // 下拉框显示状态变化时触发
391
- const handleDropdownVisibleChange = (visible) => {
392
- emit('dropdown-visible-change', visible);
393
- };
394
-
395
- // 按下回车键时触发
396
- const handleEnter = (context) => {
397
- emit('enter', context);
398
- };
399
-
400
- // 获得焦点时触发
401
- const handleFocus = (context) => {
402
- emit('focus', context);
403
- };
404
-
405
- // 键盘按下时触发
406
- const handleKeydown = (value, context) => {
407
- emit('keydown', value, context);
408
- };
409
-
410
- // 鼠标进入时触发
411
- const handleMouseenter = (context) => {
412
- emit('mouseenter', context);
413
- };
414
-
415
- // 鼠标离开时触发
416
- const handleMouseleave = (context) => {
417
- emit('mouseleave', context);
418
- };
419
-
420
- // 粘贴事件触发
421
- const handlePaste = (context) => {
422
- emit('paste', context);
423
- };
424
-
425
- // 下拉框显示或隐藏时触发
426
- const handlePopupVisibleChange = (visible, context) => {
427
- emit('popup-visible-change', visible, context);
428
- };
429
-
430
- // 多选模式下移除tag时触发
431
- const handleRemove = (options) => {
432
- emit('remove', options);
433
- };
434
-
435
- // 滚动事件触发
436
- const handleScroll = ({ scrollTop, scrollBottom }) => {
437
- emit('scroll', { scrollTop, scrollBottom });
438
- };
439
- // 搜索时触发
440
- const handleSearch = props.ifDefaultHandleSearch ? undefined : (filterWords) => {
441
- emit('search', filterWords);
442
- }
443
- </script>
444
-
445
- <style lang="less" scoped>
446
- /* 自定义样式 */
1
+ <template>
2
+ <t-select
3
+ :autoWidth="autoWidth"
4
+ :borderless="borderless"
5
+ :clearable="clearable"
6
+ :collapsedItems="collapsedItems"
7
+ :creatable="creatable"
8
+ :disabled="disabled"
9
+ :empty="empty"
10
+ :filterable="filterable"
11
+ :keys="keys"
12
+ :label="label"
13
+ :loading="loading"
14
+ :loadingText="loadingText"
15
+ :max="max"
16
+ :minCollapsedNum="minCollapsedNum"
17
+ :multiple="multiple"
18
+ :options="options"
19
+ :placeholder="placeholder"
20
+ :popupProps="popupProps"
21
+ :prefixIcon="prefixIcon"
22
+ :readonly="readonly"
23
+ :reserveKeyword="reserveKeyword"
24
+ :scroll="scroll"
25
+ :selectInputProps="selectInputProps"
26
+ :showArrow="showArrow"
27
+ :size="size"
28
+ :status="status"
29
+ :tagInputProps="tagInputProps"
30
+ :tagProps="tagProps"
31
+ :tips="tips"
32
+ :valueDisplay="valueDisplay"
33
+ :valueType="valueType"
34
+ :onPaste="onPaste"
35
+ v-model="selectedValue"
36
+ @blur="handleBlur"
37
+ @change="handleChange"
38
+ @clear="handleClear"
39
+ @create="handleCreate"
40
+ @dropdown-visible-change="handleDropdownVisibleChange"
41
+ @enter="handleEnter"
42
+ @focus="handleFocus"
43
+ @keydown="handleKeydown"
44
+ @mouseenter="handleMouseenter"
45
+ @mouseleave="handleMouseleave"
46
+ @paste="handlePaste"
47
+ @popup-visible-change="handlePopupVisibleChange"
48
+ @remove="handleRemove"
49
+ @scroll="handleScroll"
50
+ @search="handleSearch"
51
+ >
52
+ <!-- 选项插槽 -->
53
+ <template v-if="$slots.options" #options>
54
+ <slot name="options"></slot>
55
+ </template>
56
+
57
+ <!-- 前缀图标插槽 -->
58
+ <template v-if="$slots.prefixIcon" #prefixIcon>
59
+ <slot name="prefixIcon"></slot>
60
+ </template>
61
+
62
+ <!-- 后缀图标插槽 -->
63
+ <template v-if="$slots.suffixIcon" #suffixIcon>
64
+ <slot name="suffixIcon"></slot>
65
+ </template>
66
+
67
+ <!-- 后缀内容插槽 -->
68
+ <template v-if="$slots.suffix" #suffix>
69
+ <slot name="suffix"></slot>
70
+ </template>
71
+
72
+ <!-- 空数据插槽 -->
73
+ <template v-if="$slots.empty" #empty>
74
+ <slot name="empty"></slot>
75
+ </template>
76
+
77
+ <!-- 选项显示插槽 -->
78
+ <template v-if="$slots.valueDisplay" #valueDisplay>
79
+ <slot name="valueDisplay"></slot>
80
+ </template>
81
+
82
+ <!-- 面板底部内容插槽 -->
83
+ <template v-if="$slots.panelBottomContent" #panelBottomContent>
84
+ <slot name="panelBottomContent"></slot>
85
+ </template>
86
+
87
+ <!-- 面板顶部内容插槽 -->
88
+ <template v-if="$slots.panelTopContent" #panelTopContent>
89
+ <slot name="panelTopContent"></slot>
90
+ </template>
91
+
92
+ <!-- 选项标签插槽 -->
93
+ <template v-if="$slots.tag" #tag>
94
+ <slot name="tag"></slot>
95
+ </template>
96
+
97
+ <!-- 加载中插槽 -->
98
+ <template v-if="$slots.loadingText" #loadingText>
99
+ <slot name="loadingText"></slot>
100
+ </template>
101
+
102
+ <!-- 折叠项插槽 -->
103
+ <template v-if="$slots.collapsedItems" #collapsedItems>
104
+ <slot name="collapsedItems"></slot>
105
+ </template>
106
+
107
+ <!-- 选择框自定义首部内容插槽 -->
108
+ <template v-if="$slots.header" #header>
109
+ <slot name="header"></slot>
110
+ </template>
111
+
112
+ <!-- 选择框自定义底部内容插槽 -->
113
+ <template v-if="$slots.footer" #footer>
114
+ <slot name="footer"></slot>
115
+ </template>
116
+
117
+ <!-- 输入框前置内容插槽 -->
118
+ <template v-if="$slots.prepend" #prepend>
119
+ <slot name="prepend"></slot>
120
+ </template>
121
+
122
+ <!-- 输入框后置内容插槽 -->
123
+ <template v-if="$slots.append" #append>
124
+ <slot name="append"></slot>
125
+ </template>
126
+
127
+ <!-- 选项内容插槽 -->
128
+ <template v-if="$slots.default" #default>
129
+ <slot></slot>
130
+ </template>
131
+
132
+ <!-- 选项分组标题插槽 -->
133
+ <template v-if="$slots.optionGroup" #optionGroup>
134
+ <slot name="optionGroup"></slot>
135
+ </template>
136
+ </t-select>
137
+ </template>
138
+
139
+ <script>
140
+ export default {
141
+ name: "EbizTdesignSelect"
142
+ }
143
+ </script>
144
+
145
+ <script setup>
146
+ import { defineProps, defineEmits, computed } from 'vue';
147
+ import { Select as TSelect } from 'tdesign-vue-next';
148
+
149
+ const props = defineProps({
150
+ // 选择器的值
151
+ modelValue: {
152
+ type: [String, Number, Object, Array],
153
+ default: undefined
154
+ },
155
+ // 宽度随内容自适应
156
+ autoWidth: {
157
+ type: Boolean,
158
+ default: false
159
+ },
160
+ // 无边框模式
161
+ borderless: {
162
+ type: Boolean,
163
+ default: false
164
+ },
165
+ // 是否可以清空选项
166
+ clearable: {
167
+ type: Boolean,
168
+ default: false
169
+ },
170
+ // 用于控制多选数量超出时,折叠选项的内容
171
+ collapsedItems: {
172
+ type: [Function, Boolean],
173
+ default: undefined
174
+ },
175
+ // 是否允许用户创建新条目
176
+ creatable: {
177
+ type: Boolean,
178
+ default: false
179
+ },
180
+ // 是否禁用选择器
181
+ disabled: {
182
+ type: Boolean,
183
+ default: false
184
+ },
185
+ // 当下拉列表为空时显示的内容
186
+ empty: {
187
+ type: String,
188
+ default: undefined
189
+ },
190
+ // 自定义过滤方法
191
+ filter: {
192
+ type: Function,
193
+ default: undefined
194
+ },
195
+ // 是否可搜索
196
+ filterable: {
197
+ type: Boolean,
198
+ default: false
199
+ },
200
+ // 默认搜索处理,开启后不需监听 search 事件
201
+ ifDefaultHandleSearch: {
202
+ type: Boolean,
203
+ default: false
204
+ },
205
+ // 用来定义选项中的字段别名
206
+ keys: {
207
+ type: Object,
208
+ default: () => ({})
209
+ },
210
+ // 左侧文本
211
+ label: {
212
+ type: [String, Function],
213
+ default: undefined
214
+ },
215
+ // 是否为加载状态
216
+ loading: {
217
+ type: Boolean,
218
+ default: false
219
+ },
220
+ // 远程加载时显示的文字
221
+ loadingText: {
222
+ type: String,
223
+ default: undefined
224
+ },
225
+ // 用于控制多选数量,值为 0 则不限制
226
+ max: {
227
+ type: Number,
228
+ default: 0
229
+ },
230
+ // 最小折叠数量,用于多选情况下折叠选中项
231
+ minCollapsedNum: {
232
+ type: Number,
233
+ default: 0
234
+ },
235
+ // 是否允许多选
236
+ multiple: {
237
+ type: Boolean,
238
+ default: false
239
+ },
240
+ // 数据化配置选项内容
241
+ options: {
242
+ type: Array,
243
+ default: () => []
244
+ },
245
+ // 占位符
246
+ placeholder: {
247
+ type: String,
248
+ default: undefined
249
+ },
250
+ // 弹出层的定位方式,同 Popup 组件
251
+ popupProps: {
252
+ type: Object,
253
+ default: () => ({})
254
+ },
255
+ // 是否显示下拉框 //这个属性会导致search的值不显示
256
+ // popupVisible: {
257
+ // type: Boolean,
258
+ // default: undefined
259
+ // },
260
+ // 前缀图标
261
+ prefixIcon: {
262
+ type: [Function, String],
263
+ default: undefined
264
+ },
265
+ // 只读状态
266
+ readonly: {
267
+ type: Boolean,
268
+ default: false
269
+ },
270
+ // 多选且可搜索时,是否在选中一个选项后保留当前的搜索关键词
271
+ reserveKeyword: {
272
+ type: Boolean,
273
+ default: false
274
+ },
275
+ // 懒加载和虚拟滚动配置
276
+ scroll: {
277
+ type: Object,
278
+ default: () => ({})
279
+ },
280
+ // 透传 SelectInput 筛选器输入框组件的全部属性
281
+ selectInputProps: {
282
+ type: Object,
283
+ default: () => ({})
284
+ },
285
+ // 是否显示右侧箭头
286
+ showArrow: {
287
+ type: Boolean,
288
+ default: true
289
+ },
290
+ // 组件尺寸
291
+ size: {
292
+ type: String,
293
+ default: 'medium',
294
+ validator: (val) => ['small', 'medium', 'large'].includes(val)
295
+ },
296
+ // 输入框状态
297
+ status: {
298
+ type: String,
299
+ default: undefined,
300
+ validator: (val) => ['default', 'success', 'warning', 'error'].includes(val)
301
+ },
302
+ // 后置图标前的后置内容
303
+ suffix: {
304
+ type: String,
305
+ default: undefined
306
+ },
307
+ // 后置图标
308
+ suffixIcon: {
309
+ type: [Function, String],
310
+ default: undefined
311
+ },
312
+ // 透传 TagInput 标签输入框组件的全部属性
313
+ tagInputProps: {
314
+ type: Object,
315
+ default: () => ({})
316
+ },
317
+ // 透传 Tag 标签组件的全部属性
318
+ tagProps: {
319
+ type: Object,
320
+ default: () => ({})
321
+ },
322
+ // 输入框下方提示文本,会根据不同的 status 呈现不同的样式
323
+ tips: {
324
+ type: String,
325
+ default: ''
326
+ },
327
+ // 自定义选中项呈现方式
328
+ valueDisplay: {
329
+ type: Function,
330
+ default: undefined
331
+ },
332
+ // 用于控制选中值的类型
333
+ valueType: {
334
+ type: String,
335
+ default: undefined,
336
+ validator: (val) => ['value', 'object'].includes(val)
337
+ },
338
+ // 粘贴事件回调函数,参数为粘贴板内容
339
+ onPaste: {
340
+ type: Function,
341
+ default: undefined
342
+ }
343
+ });
344
+
345
+ // 选择器的值
346
+ const selectedValue = computed({
347
+ get: () => props.modelValue,
348
+ set: (value) => emit('update:modelValue', value)
349
+ });
350
+
351
+ const emit = defineEmits([
352
+ 'update:modelValue',
353
+ 'blur',
354
+ 'change',
355
+ 'clear',
356
+ 'create',
357
+ 'dropdown-visible-change',
358
+ 'enter',
359
+ 'focus',
360
+ 'keydown',
361
+ 'mouseenter',
362
+ 'mouseleave',
363
+ 'paste',
364
+ 'popup-visible-change',
365
+ 'remove',
366
+ 'scroll',
367
+ 'search'
368
+ ]);
369
+
370
+ // 失去焦点时触发
371
+ const handleBlur = (value, context) => {
372
+ emit('blur', value, context);
373
+ };
374
+
375
+ // 选中值变化时触发
376
+ const handleChange = (value, context) => {
377
+ emit('change', value, context);
378
+ };
379
+
380
+ // 点击清除按钮时触发
381
+ const handleClear = (context) => {
382
+ emit('clear', context);
383
+ };
384
+
385
+ // 当新增选项时触发
386
+ const handleCreate = (value, context) => {
387
+ emit('create', value, context);
388
+ };
389
+
390
+ // 下拉框显示状态变化时触发
391
+ const handleDropdownVisibleChange = (visible) => {
392
+ emit('dropdown-visible-change', visible);
393
+ };
394
+
395
+ // 按下回车键时触发
396
+ const handleEnter = (context) => {
397
+ emit('enter', context);
398
+ };
399
+
400
+ // 获得焦点时触发
401
+ const handleFocus = (context) => {
402
+ emit('focus', context);
403
+ };
404
+
405
+ // 键盘按下时触发
406
+ const handleKeydown = (value, context) => {
407
+ emit('keydown', value, context);
408
+ };
409
+
410
+ // 鼠标进入时触发
411
+ const handleMouseenter = (context) => {
412
+ emit('mouseenter', context);
413
+ };
414
+
415
+ // 鼠标离开时触发
416
+ const handleMouseleave = (context) => {
417
+ emit('mouseleave', context);
418
+ };
419
+
420
+ // 粘贴事件触发
421
+ const handlePaste = (context) => {
422
+ emit('paste', context);
423
+ };
424
+
425
+ // 下拉框显示或隐藏时触发
426
+ const handlePopupVisibleChange = (visible, context) => {
427
+ emit('popup-visible-change', visible, context);
428
+ };
429
+
430
+ // 多选模式下移除tag时触发
431
+ const handleRemove = (options) => {
432
+ emit('remove', options);
433
+ };
434
+
435
+ // 滚动事件触发
436
+ const handleScroll = ({ scrollTop, scrollBottom }) => {
437
+ emit('scroll', { scrollTop, scrollBottom });
438
+ };
439
+ // 搜索时触发
440
+ const handleSearch = props.ifDefaultHandleSearch ? undefined : (filterWords) => {
441
+ emit('search', filterWords);
442
+ }
443
+ </script>
444
+
445
+ <style lang="less" scoped>
446
+ /* 自定义样式 */
447
447
  </style>