@ebiz/designer-components 0.1.78 → 0.1.79

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 (219) hide show
  1. package/README.md +29 -29
  2. package/dist/designer-components.css +1 -1
  3. package/dist/index.mjs +20744 -20701
  4. package/package.json +1 -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/EbizDiv.vue +40 -40
  28. package/src/components/EbizDivider.vue +96 -96
  29. package/src/components/EbizDropdown.vue +135 -135
  30. package/src/components/EbizDropdownItem.vue +85 -85
  31. package/src/components/EbizEmployeeInfo.vue +138 -138
  32. package/src/components/EbizEmployeeSelector.vue +1159 -1159
  33. package/src/components/EbizFileList.vue +466 -466
  34. package/src/components/EbizMap.vue +541 -541
  35. package/src/components/EbizMeetingRoomSelector.vue +664 -664
  36. package/src/components/EbizMobileMeetingRoomSelector.vue +727 -727
  37. package/src/components/EbizOkrTree.vue +99 -99
  38. package/src/components/EbizPageHeader.vue +95 -95
  39. package/src/components/EbizPagination.vue +162 -162
  40. package/src/components/EbizPdfViewer.vue +540 -540
  41. package/src/components/EbizPopconfirm.vue +47 -47
  42. package/src/components/EbizQrCode.vue +73 -73
  43. package/src/components/EbizRadio.vue +86 -86
  44. package/src/components/EbizRadioGroup.vue +83 -83
  45. package/src/components/EbizRemoteSelect.vue +232 -232
  46. package/src/components/EbizRichTextEditor.vue +275 -275
  47. package/src/components/EbizRouteBreadcrumb.vue +46 -46
  48. package/src/components/EbizSApprovalProcess.vue +1429 -1429
  49. package/src/components/EbizSelect.vue +85 -85
  50. package/src/components/EbizSpace.vue +100 -100
  51. package/src/components/EbizStatistic.vue +149 -149
  52. package/src/components/EbizStatsCard.vue +113 -113
  53. package/src/components/EbizSwiper.vue +113 -113
  54. package/src/components/EbizSwiperItem.vue +13 -13
  55. package/src/components/EbizSwitch.vue +85 -85
  56. package/src/components/EbizTabHeader.vue +132 -132
  57. package/src/components/EbizTabPanel.vue +22 -22
  58. package/src/components/EbizTable.vue +469 -469
  59. package/src/components/EbizTableColumn.vue +116 -116
  60. package/src/components/EbizTableSort.vue +179 -179
  61. package/src/components/EbizTabs.vue +142 -142
  62. package/src/components/EbizTdesignButtonDialog.vue +332 -332
  63. package/src/components/EbizTdesignLoading.vue +107 -107
  64. package/src/components/EbizTimePicker.vue +143 -143
  65. package/src/components/EbizTitle.vue +91 -91
  66. package/src/components/EbizTree.vue +141 -141
  67. package/src/components/EbizTreeMergeTable.vue +1494 -1494
  68. package/src/components/EbizTreeSelector.vue +418 -418
  69. package/src/components/EbizVideo.vue +553 -553
  70. package/src/components/EbizVxeTable.vue +290 -290
  71. package/src/components/Form.vue +28 -28
  72. package/src/components/Home.vue +7 -7
  73. package/src/components/MyComponent.vue +39 -39
  74. package/src/components/Table.vue +45 -45
  75. package/src/components/TdesignAlert.vue +115 -115
  76. package/src/components/TdesignButton.vue +135 -135
  77. package/src/components/TdesignCalendar/index.vue +145 -145
  78. package/src/components/TdesignCard.vue +195 -195
  79. package/src/components/TdesignCol.vue +101 -101
  80. package/src/components/TdesignCollapse.vue +142 -142
  81. package/src/components/TdesignCollapsePanel.vue +79 -79
  82. package/src/components/TdesignDatePicker.vue +124 -124
  83. package/src/components/TdesignDescriptions.vue +74 -74
  84. package/src/components/TdesignDescriptionsItem.vue +50 -50
  85. package/src/components/TdesignDialog.vue +225 -225
  86. package/src/components/TdesignForm.vue +138 -138
  87. package/src/components/TdesignFormItem.vue +105 -105
  88. package/src/components/TdesignGrid.vue +55 -55
  89. package/src/components/TdesignIcon.vue +67 -67
  90. package/src/components/TdesignImage.vue +162 -162
  91. package/src/components/TdesignImageViewer.vue +200 -200
  92. package/src/components/TdesignInput.vue +242 -242
  93. package/src/components/TdesignSelect.vue +446 -446
  94. package/src/components/TdesignTag.vue +117 -117
  95. package/src/components/TdesignTextarea.vue +142 -142
  96. package/src/components/TdesignTimeline.vue +58 -58
  97. package/src/components/TdesignTimelineItem.vue +71 -71
  98. package/src/components/TdesignUpload.vue +414 -414
  99. package/src/components/TdesignWatermark.vue +107 -107
  100. package/src/components/ebiz-form/components/cascader.vue +61 -61
  101. package/src/components/ebiz-form/components/checkbox.vue +37 -37
  102. package/src/components/ebiz-form/components/city.vue +137 -137
  103. package/src/components/ebiz-form/components/date-panel.vue +52 -52
  104. package/src/components/ebiz-form/components/date-range-panel.vue +52 -52
  105. package/src/components/ebiz-form/components/date-range.vue +56 -56
  106. package/src/components/ebiz-form/components/date.vue +52 -52
  107. package/src/components/ebiz-form/components/editor-multi-language.vue +47 -47
  108. package/src/components/ebiz-form/components/editor.vue +78 -78
  109. package/src/components/ebiz-form/components/file-multi-language.vue +52 -52
  110. package/src/components/ebiz-form/components/file.vue +149 -149
  111. package/src/components/ebiz-form/components/images-multi-language.vue +52 -52
  112. package/src/components/ebiz-form/components/images.vue +129 -129
  113. package/src/components/ebiz-form/components/img-multi-language.vue +51 -51
  114. package/src/components/ebiz-form/components/img.vue +129 -129
  115. package/src/components/ebiz-form/components/number.vue +50 -50
  116. package/src/components/ebiz-form/components/radio.vue +28 -28
  117. package/src/components/ebiz-form/components/select.vue +119 -119
  118. package/src/components/ebiz-form/components/switch.vue +23 -23
  119. package/src/components/ebiz-form/components/text-multi-language.vue +47 -47
  120. package/src/components/ebiz-form/components/text.vue +52 -52
  121. package/src/components/ebiz-form/components/textarea-multi-language.vue +48 -48
  122. package/src/components/ebiz-form/components/textarea.vue +29 -29
  123. package/src/components/ebiz-form/components/video-multi-language.vue +51 -51
  124. package/src/components/ebiz-form/components/video.vue +97 -97
  125. package/src/components/ebiz-form/index.vue +157 -157
  126. package/src/components/examples/PopconfirmExample.vue +149 -149
  127. package/src/components/icons/IconCommunity.vue +7 -7
  128. package/src/components/icons/IconDocumentation.vue +7 -7
  129. package/src/components/icons/IconEcosystem.vue +7 -7
  130. package/src/components/icons/IconSupport.vue +7 -7
  131. package/src/components/icons/IconTooling.vue +19 -19
  132. package/src/components/mItems/UserInfo.vue +342 -342
  133. package/src/components/senior/EbizSData/index.vue +273 -273
  134. package/src/components/senior/EbizSDialog/index.vue +770 -772
  135. package/src/components/senior/EbizSForm/README.md +157 -157
  136. package/src/components/senior/EbizSForm/index.vue +667 -667
  137. package/src/components/senior/EbizSForm/item.vue +971 -971
  138. package/src/components/senior/EbizSForm/mItems/DateTimePicker.vue +51 -51
  139. package/src/components/senior/EbizSForm/mItems/Picker.vue +63 -63
  140. package/src/index.js +255 -255
  141. package/src/main.js +55 -55
  142. package/src/router/index.js +415 -415
  143. package/src/utils/formatCode.js +24 -24
  144. package/src/utils/generateImportStatement.js +52 -52
  145. package/src/utils/hasJsx.js +25 -25
  146. package/src/utils/index.js +166 -166
  147. package/src/utils/mergeOptions.js +29 -29
  148. package/src/utils/parseRequiredBlocks.js +18 -18
  149. package/src/utils/vue-sfc-validator.js +155 -155
  150. package/src/views/Button.vue +23 -23
  151. package/src/views/CheckboxDemo.vue +104 -104
  152. package/src/views/DataContainer.vue +19 -19
  153. package/src/views/DialogDemo.vue +125 -125
  154. package/src/views/EbizApprovalDemo.vue +87 -87
  155. package/src/views/EbizApprovalFormDemo.vue +207 -207
  156. package/src/views/EbizAutoFormDemo.vue +129 -129
  157. package/src/views/EbizAvatar.vue +223 -223
  158. package/src/views/EbizDepartmentSelectorDemo.vue +169 -169
  159. package/src/views/EbizDetailBlockDemo.vue +30 -30
  160. package/src/views/EbizDetailViewDemo.vue +412 -412
  161. package/src/views/EbizEmployeeInfo.vue +249 -249
  162. package/src/views/EbizEmployeeSelector.vue +85 -85
  163. package/src/views/EbizFileListDemo.vue +339 -339
  164. package/src/views/EbizMap.vue +201 -201
  165. package/src/views/EbizMeetingRoomSelectorDemo.vue +293 -293
  166. package/src/views/EbizMobileMeetingRoomSelectorDemo.vue +566 -566
  167. package/src/views/EbizRadioDemo.vue +151 -151
  168. package/src/views/EbizSDataDemo.vue +136 -136
  169. package/src/views/EbizSDialogDemo.vue +303 -303
  170. package/src/views/EbizSForm/index.vue +351 -351
  171. package/src/views/EbizSFormDemo.vue +420 -420
  172. package/src/views/EbizSpace.vue +185 -185
  173. package/src/views/EbizSwiper.vue +157 -157
  174. package/src/views/EbizTdesignButtonDialogExample.vue +437 -437
  175. package/src/views/Form.vue +19 -19
  176. package/src/views/GridDemo.vue +238 -238
  177. package/src/views/Home.vue +153 -153
  178. package/src/views/Mindmap.vue +17 -17
  179. package/src/views/MyComponent.vue +19 -19
  180. package/src/views/OkrTree.vue +19 -19
  181. package/src/views/PageHeaderDemo.vue +104 -104
  182. package/src/views/PaginationDemo.vue +96 -96
  183. package/src/views/PdfViewerDemo.vue +433 -433
  184. package/src/views/PermissionBoxDemo.vue +85 -85
  185. package/src/views/PopconfirmDemo.vue +80 -80
  186. package/src/views/RemoteSelect.vue +350 -350
  187. package/src/views/StatisticDemo.vue +190 -190
  188. package/src/views/SwitchDemo.vue +79 -79
  189. package/src/views/Table.vue +19 -19
  190. package/src/views/TableDemo.vue +334 -334
  191. package/src/views/TableSortDemo.vue +143 -143
  192. package/src/views/TableView.vue +68 -68
  193. package/src/views/TabsDemo.vue +282 -282
  194. package/src/views/TagDemo.vue +101 -101
  195. package/src/views/TdesignAlert.vue +98 -98
  196. package/src/views/TdesignButton.vue +190 -190
  197. package/src/views/TdesignCalendar.vue +94 -94
  198. package/src/views/TdesignCard.vue +296 -296
  199. package/src/views/TdesignCollapse.vue +293 -293
  200. package/src/views/TdesignDatePicker.vue +187 -187
  201. package/src/views/TdesignDescriptions.vue +101 -101
  202. package/src/views/TdesignForm.vue +248 -248
  203. package/src/views/TdesignIcon.vue +203 -203
  204. package/src/views/TdesignImage.vue +215 -215
  205. package/src/views/TdesignImageViewer.vue +198 -198
  206. package/src/views/TdesignInput.vue +252 -252
  207. package/src/views/TdesignSelect.vue +473 -473
  208. package/src/views/TdesignSwiper.vue +157 -157
  209. package/src/views/TextareaDemo.vue +93 -93
  210. package/src/views/TimePickerDemo.vue +146 -146
  211. package/src/views/TimelineDemo.vue +160 -160
  212. package/src/views/Title.vue +19 -19
  213. package/src/views/TreeDemo.vue +254 -254
  214. package/src/views/TreeMergeTableDemo.vue +239 -239
  215. package/src/views/TreeSelectorDemo.vue +245 -245
  216. package/src/views/UploadDemo.vue +128 -128
  217. package/src/views/VideoDemo.vue +245 -245
  218. package/src/views/VxeTableDemo.vue +279 -279
  219. 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>