@ebiz/designer-components 0.1.88 → 0.1.90

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 (222) hide show
  1. package/README.md +29 -29
  2. package/dist/designer-components.css +1 -1
  3. package/dist/index.mjs +23400 -22651
  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 +338 -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 -229
  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 +144 -144
  33. package/src/components/EbizEmployeeSelector.vue +1160 -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 +98 -98
  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 +451 -451
  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/LaunchInterview.vue +403 -0
  75. package/src/components/MyComponent.vue +39 -39
  76. package/src/components/Table.vue +45 -45
  77. package/src/components/TdesignAlert.vue +115 -115
  78. package/src/components/TdesignButton.vue +135 -135
  79. package/src/components/TdesignCalendar/index.vue +145 -145
  80. package/src/components/TdesignCard.vue +195 -195
  81. package/src/components/TdesignCol.vue +101 -101
  82. package/src/components/TdesignCollapse.vue +142 -142
  83. package/src/components/TdesignCollapsePanel.vue +79 -79
  84. package/src/components/TdesignDatePicker.vue +124 -124
  85. package/src/components/TdesignDescriptions.vue +74 -74
  86. package/src/components/TdesignDescriptionsItem.vue +50 -50
  87. package/src/components/TdesignDialog.vue +225 -225
  88. package/src/components/TdesignForm.vue +138 -138
  89. package/src/components/TdesignFormItem.vue +105 -105
  90. package/src/components/TdesignGrid.vue +55 -55
  91. package/src/components/TdesignIcon.vue +67 -67
  92. package/src/components/TdesignImage.vue +162 -162
  93. package/src/components/TdesignImageViewer.vue +200 -200
  94. package/src/components/TdesignInput.vue +242 -242
  95. package/src/components/TdesignSelect.vue +446 -446
  96. package/src/components/TdesignTag.vue +117 -117
  97. package/src/components/TdesignTextarea.vue +142 -142
  98. package/src/components/TdesignTimeline.vue +58 -58
  99. package/src/components/TdesignTimelineItem.vue +71 -71
  100. package/src/components/TdesignUpload.vue +414 -414
  101. package/src/components/TdesignWatermark.vue +107 -107
  102. package/src/components/ebiz-form/components/cascader.vue +61 -61
  103. package/src/components/ebiz-form/components/checkbox.vue +37 -37
  104. package/src/components/ebiz-form/components/city.vue +137 -137
  105. package/src/components/ebiz-form/components/date-panel.vue +52 -52
  106. package/src/components/ebiz-form/components/date-range-panel.vue +52 -52
  107. package/src/components/ebiz-form/components/date-range.vue +56 -56
  108. package/src/components/ebiz-form/components/date.vue +52 -52
  109. package/src/components/ebiz-form/components/editor-multi-language.vue +47 -47
  110. package/src/components/ebiz-form/components/editor.vue +78 -78
  111. package/src/components/ebiz-form/components/file-multi-language.vue +52 -52
  112. package/src/components/ebiz-form/components/file.vue +149 -149
  113. package/src/components/ebiz-form/components/images-multi-language.vue +52 -52
  114. package/src/components/ebiz-form/components/images.vue +129 -129
  115. package/src/components/ebiz-form/components/img-multi-language.vue +51 -51
  116. package/src/components/ebiz-form/components/img.vue +129 -129
  117. package/src/components/ebiz-form/components/number.vue +50 -50
  118. package/src/components/ebiz-form/components/radio.vue +28 -28
  119. package/src/components/ebiz-form/components/select.vue +119 -119
  120. package/src/components/ebiz-form/components/switch.vue +23 -23
  121. package/src/components/ebiz-form/components/text-multi-language.vue +47 -47
  122. package/src/components/ebiz-form/components/text.vue +52 -52
  123. package/src/components/ebiz-form/components/textarea-multi-language.vue +48 -48
  124. package/src/components/ebiz-form/components/textarea.vue +29 -29
  125. package/src/components/ebiz-form/components/video-multi-language.vue +51 -51
  126. package/src/components/ebiz-form/components/video.vue +97 -97
  127. package/src/components/ebiz-form/index.vue +157 -157
  128. package/src/components/examples/PopconfirmExample.vue +149 -149
  129. package/src/components/icons/IconCommunity.vue +7 -7
  130. package/src/components/icons/IconDocumentation.vue +7 -7
  131. package/src/components/icons/IconEcosystem.vue +7 -7
  132. package/src/components/icons/IconSupport.vue +7 -7
  133. package/src/components/icons/IconTooling.vue +19 -19
  134. package/src/components/mItems/UserInfo.vue +349 -349
  135. package/src/components/senior/EbizSData/index.vue +273 -273
  136. package/src/components/senior/EbizSDialog/index.vue +770 -770
  137. package/src/components/senior/EbizSForm/README.md +157 -157
  138. package/src/components/senior/EbizSForm/index.vue +667 -667
  139. package/src/components/senior/EbizSForm/item.vue +998 -998
  140. package/src/components/senior/EbizSForm/mItems/DateTimePicker.vue +51 -51
  141. package/src/components/senior/EbizSForm/mItems/Picker.vue +63 -63
  142. package/src/index.js +317 -313
  143. package/src/main.js +55 -55
  144. package/src/router/index.js +422 -415
  145. package/src/utils/formatCode.js +24 -24
  146. package/src/utils/generateImportStatement.js +52 -52
  147. package/src/utils/hasJsx.js +25 -25
  148. package/src/utils/index.js +166 -166
  149. package/src/utils/mergeOptions.js +29 -29
  150. package/src/utils/parseRequiredBlocks.js +18 -18
  151. package/src/utils/vue-sfc-validator.js +155 -155
  152. package/src/views/Button.vue +23 -23
  153. package/src/views/CheckboxDemo.vue +104 -104
  154. package/src/views/DataContainer.vue +19 -19
  155. package/src/views/DialogDemo.vue +125 -125
  156. package/src/views/EbizApprovalDemo.vue +87 -87
  157. package/src/views/EbizApprovalFormDemo.vue +207 -207
  158. package/src/views/EbizAutoFormDemo.vue +129 -129
  159. package/src/views/EbizAvatar.vue +223 -223
  160. package/src/views/EbizDepartmentSelectorDemo.vue +169 -169
  161. package/src/views/EbizDetailBlockDemo.vue +30 -30
  162. package/src/views/EbizDetailViewDemo.vue +412 -412
  163. package/src/views/EbizEmployeeInfo.vue +249 -249
  164. package/src/views/EbizEmployeeSelector.vue +85 -85
  165. package/src/views/EbizFileListDemo.vue +339 -339
  166. package/src/views/EbizMap.vue +201 -201
  167. package/src/views/EbizMeetingRoomSelectorDemo.vue +293 -293
  168. package/src/views/EbizMobileMeetingRoomSelectorDemo.vue +566 -566
  169. package/src/views/EbizRadioDemo.vue +151 -151
  170. package/src/views/EbizSDataDemo.vue +136 -136
  171. package/src/views/EbizSDialogDemo.vue +303 -303
  172. package/src/views/EbizSForm/index.vue +352 -352
  173. package/src/views/EbizSFormDemo.vue +420 -420
  174. package/src/views/EbizSpace.vue +185 -185
  175. package/src/views/EbizSwiper.vue +157 -157
  176. package/src/views/EbizTdesignButtonDialogExample.vue +437 -437
  177. package/src/views/Form.vue +19 -19
  178. package/src/views/GridDemo.vue +238 -238
  179. package/src/views/Home.vue +154 -153
  180. package/src/views/LaunchInterviewDemo.vue +112 -0
  181. package/src/views/Mindmap.vue +17 -17
  182. package/src/views/MyComponent.vue +19 -19
  183. package/src/views/OkrTree.vue +19 -19
  184. package/src/views/PageHeaderDemo.vue +104 -104
  185. package/src/views/PaginationDemo.vue +96 -96
  186. package/src/views/PdfViewerDemo.vue +433 -433
  187. package/src/views/PermissionBoxDemo.vue +85 -85
  188. package/src/views/PopconfirmDemo.vue +80 -80
  189. package/src/views/RemoteSelect.vue +350 -350
  190. package/src/views/StatisticDemo.vue +190 -190
  191. package/src/views/SwitchDemo.vue +79 -79
  192. package/src/views/Table.vue +19 -19
  193. package/src/views/TableDemo.vue +334 -334
  194. package/src/views/TableSortDemo.vue +143 -143
  195. package/src/views/TableView.vue +68 -68
  196. package/src/views/TabsDemo.vue +282 -282
  197. package/src/views/TagDemo.vue +101 -101
  198. package/src/views/TdesignAlert.vue +98 -98
  199. package/src/views/TdesignButton.vue +190 -190
  200. package/src/views/TdesignCalendar.vue +94 -94
  201. package/src/views/TdesignCard.vue +296 -296
  202. package/src/views/TdesignCollapse.vue +293 -293
  203. package/src/views/TdesignDatePicker.vue +187 -187
  204. package/src/views/TdesignDescriptions.vue +101 -101
  205. package/src/views/TdesignForm.vue +248 -248
  206. package/src/views/TdesignIcon.vue +203 -203
  207. package/src/views/TdesignImage.vue +215 -215
  208. package/src/views/TdesignImageViewer.vue +198 -198
  209. package/src/views/TdesignInput.vue +252 -252
  210. package/src/views/TdesignSelect.vue +473 -473
  211. package/src/views/TdesignSwiper.vue +157 -157
  212. package/src/views/TextareaDemo.vue +93 -93
  213. package/src/views/TimePickerDemo.vue +146 -146
  214. package/src/views/TimelineDemo.vue +160 -160
  215. package/src/views/Title.vue +19 -19
  216. package/src/views/TreeDemo.vue +254 -254
  217. package/src/views/TreeMergeTableDemo.vue +239 -239
  218. package/src/views/TreeSelectorDemo.vue +245 -245
  219. package/src/views/UploadDemo.vue +128 -128
  220. package/src/views/VideoDemo.vue +245 -245
  221. package/src/views/VxeTableDemo.vue +279 -279
  222. 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>