@ebiz/designer-components 0.1.1 → 0.1.4

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 (205) hide show
  1. package/README.md +29 -29
  2. package/dist/designer-components.css +1 -1
  3. package/dist/index.mjs +4781 -4773
  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 +297 -297
  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 +332 -332
  14. package/src/components/EbizAutoForm.vue +596 -596
  15. package/src/components/EbizAvatar.vue +115 -115
  16. package/src/components/EbizCheckbox.vue +93 -93
  17. package/src/components/EbizCheckboxGroup.vue +69 -69
  18. package/src/components/EbizDepartmentSelector.vue +144 -144
  19. package/src/components/EbizDescriptions.vue +340 -340
  20. package/src/components/EbizDescriptionsItem.vue +47 -47
  21. package/src/components/EbizDetailBlock.vue +81 -81
  22. package/src/components/EbizDialog.vue +260 -260
  23. package/src/components/EbizDiv.vue +32 -32
  24. package/src/components/EbizDivider.vue +96 -96
  25. package/src/components/EbizEmployeeInfo.vue +138 -138
  26. package/src/components/EbizEmployeeSelector.vue +1095 -1095
  27. package/src/components/EbizFileUpload.vue +238 -238
  28. package/src/components/EbizMap.vue +541 -541
  29. package/src/components/EbizMeetingRoomSelector.vue +664 -664
  30. package/src/components/EbizMobileMeetingRoomSelector.vue +727 -727
  31. package/src/components/EbizOkrTree.vue +99 -99
  32. package/src/components/EbizPageHeader.vue +95 -95
  33. package/src/components/EbizPagination.vue +162 -162
  34. package/src/components/EbizPopconfirm.vue +47 -47
  35. package/src/components/EbizRadio.vue +86 -86
  36. package/src/components/EbizRadioGroup.vue +83 -83
  37. package/src/components/EbizRemoteSelect.vue +232 -232
  38. package/src/components/EbizRouteBreadcrumb.vue +46 -46
  39. package/src/components/EbizSelect.vue +85 -85
  40. package/src/components/EbizSpace.vue +100 -100
  41. package/src/components/EbizStatistic.vue +149 -149
  42. package/src/components/EbizStatsCard.vue +113 -113
  43. package/src/components/EbizSwiper.vue +113 -113
  44. package/src/components/EbizSwiperItem.vue +13 -13
  45. package/src/components/EbizSwitch.vue +85 -85
  46. package/src/components/EbizTabHeader.vue +132 -132
  47. package/src/components/EbizTabPanel.vue +22 -22
  48. package/src/components/EbizTable.vue +469 -469
  49. package/src/components/EbizTableColumn.vue +116 -116
  50. package/src/components/EbizTableSort.vue +179 -179
  51. package/src/components/EbizTabs.vue +142 -142
  52. package/src/components/EbizTdesignButtonDialog.vue +332 -332
  53. package/src/components/EbizTdesignLoading.vue +107 -107
  54. package/src/components/EbizTimePicker.vue +143 -143
  55. package/src/components/EbizTitle.vue +91 -91
  56. package/src/components/EbizTree.vue +152 -152
  57. package/src/components/EbizTreeMergeTable.vue +1414 -1414
  58. package/src/components/EbizTreeSelector.vue +418 -418
  59. package/src/components/EbizVxeTable.vue +290 -290
  60. package/src/components/Form.vue +28 -28
  61. package/src/components/Home.vue +7 -7
  62. package/src/components/MyComponent.vue +39 -39
  63. package/src/components/Table.vue +45 -45
  64. package/src/components/TdesignAlert.vue +115 -115
  65. package/src/components/TdesignButton.vue +135 -135
  66. package/src/components/TdesignCalendar/index.vue +145 -145
  67. package/src/components/TdesignCard.vue +195 -195
  68. package/src/components/TdesignCol.vue +101 -101
  69. package/src/components/TdesignCollapse.vue +142 -142
  70. package/src/components/TdesignCollapsePanel.vue +79 -79
  71. package/src/components/TdesignDatePicker.vue +124 -124
  72. package/src/components/TdesignDescriptions.vue +74 -74
  73. package/src/components/TdesignDescriptionsItem.vue +50 -50
  74. package/src/components/TdesignDialog.vue +225 -225
  75. package/src/components/TdesignForm.vue +138 -138
  76. package/src/components/TdesignFormItem.vue +105 -105
  77. package/src/components/TdesignGrid.vue +55 -55
  78. package/src/components/TdesignIcon.vue +67 -67
  79. package/src/components/TdesignImage.vue +162 -162
  80. package/src/components/TdesignImageViewer.vue +200 -200
  81. package/src/components/TdesignInput.vue +242 -242
  82. package/src/components/TdesignSelect.vue +444 -444
  83. package/src/components/TdesignTag.vue +117 -117
  84. package/src/components/TdesignTextarea.vue +142 -142
  85. package/src/components/TdesignTimeline.vue +58 -58
  86. package/src/components/TdesignTimelineItem.vue +71 -71
  87. package/src/components/TdesignUpload.vue +405 -392
  88. package/src/components/TdesignWatermark.vue +107 -107
  89. package/src/components/ebiz-form/components/cascader.vue +61 -61
  90. package/src/components/ebiz-form/components/checkbox.vue +37 -37
  91. package/src/components/ebiz-form/components/city.vue +137 -137
  92. package/src/components/ebiz-form/components/date-panel.vue +52 -52
  93. package/src/components/ebiz-form/components/date-range-panel.vue +52 -52
  94. package/src/components/ebiz-form/components/date-range.vue +56 -56
  95. package/src/components/ebiz-form/components/date.vue +52 -52
  96. package/src/components/ebiz-form/components/editor-multi-language.vue +47 -47
  97. package/src/components/ebiz-form/components/editor.vue +78 -78
  98. package/src/components/ebiz-form/components/file-multi-language.vue +52 -52
  99. package/src/components/ebiz-form/components/file.vue +149 -149
  100. package/src/components/ebiz-form/components/images-multi-language.vue +52 -52
  101. package/src/components/ebiz-form/components/images.vue +129 -129
  102. package/src/components/ebiz-form/components/img-multi-language.vue +51 -51
  103. package/src/components/ebiz-form/components/img.vue +129 -129
  104. package/src/components/ebiz-form/components/number.vue +50 -50
  105. package/src/components/ebiz-form/components/radio.vue +28 -28
  106. package/src/components/ebiz-form/components/select.vue +119 -119
  107. package/src/components/ebiz-form/components/switch.vue +23 -23
  108. package/src/components/ebiz-form/components/text-multi-language.vue +47 -47
  109. package/src/components/ebiz-form/components/text.vue +52 -52
  110. package/src/components/ebiz-form/components/textarea-multi-language.vue +48 -48
  111. package/src/components/ebiz-form/components/textarea.vue +29 -29
  112. package/src/components/ebiz-form/components/video-multi-language.vue +51 -51
  113. package/src/components/ebiz-form/components/video.vue +97 -97
  114. package/src/components/ebiz-form/index.vue +157 -157
  115. package/src/components/examples/PopconfirmExample.vue +149 -149
  116. package/src/components/icons/IconCommunity.vue +7 -7
  117. package/src/components/icons/IconDocumentation.vue +7 -7
  118. package/src/components/icons/IconEcosystem.vue +7 -7
  119. package/src/components/icons/IconSupport.vue +7 -7
  120. package/src/components/icons/IconTooling.vue +19 -19
  121. package/src/components/senior/EbizSData/index.vue +262 -262
  122. package/src/components/senior/EbizSDialog/index.vue +715 -715
  123. package/src/components/senior/EbizSForm/README.md +157 -157
  124. package/src/components/senior/EbizSForm/index.vue +668 -668
  125. package/src/components/senior/EbizSForm/item.vue +512 -512
  126. package/src/components/senior/EbizSForm/mItems/DateTimePicker.vue +51 -51
  127. package/src/components/senior/EbizSForm/mItems/Picker.vue +63 -63
  128. package/src/index.js +224 -224
  129. package/src/main.js +55 -55
  130. package/src/router/index.js +386 -386
  131. package/src/utils/formatCode.js +24 -24
  132. package/src/utils/generateImportStatement.js +52 -52
  133. package/src/utils/hasJsx.js +25 -25
  134. package/src/utils/index.js +166 -166
  135. package/src/utils/mergeOptions.js +29 -29
  136. package/src/utils/parseRequiredBlocks.js +18 -18
  137. package/src/utils/upload.ts +126 -126
  138. package/src/utils/vue-sfc-validator.js +155 -155
  139. package/src/views/Button.vue +23 -23
  140. package/src/views/CheckboxDemo.vue +104 -104
  141. package/src/views/DataContainer.vue +19 -19
  142. package/src/views/DialogDemo.vue +125 -125
  143. package/src/views/EbizApprovalDemo.vue +76 -76
  144. package/src/views/EbizAutoFormDemo.vue +129 -129
  145. package/src/views/EbizAvatar.vue +223 -223
  146. package/src/views/EbizDepartmentSelectorDemo.vue +169 -169
  147. package/src/views/EbizDetailBlockDemo.vue +30 -30
  148. package/src/views/EbizEmployeeInfo.vue +249 -249
  149. package/src/views/EbizEmployeeSelector.vue +83 -83
  150. package/src/views/EbizMap.vue +201 -201
  151. package/src/views/EbizMeetingRoomSelectorDemo.vue +293 -293
  152. package/src/views/EbizMobileMeetingRoomSelectorDemo.vue +566 -566
  153. package/src/views/EbizRadioDemo.vue +151 -151
  154. package/src/views/EbizSDataDemo.vue +136 -136
  155. package/src/views/EbizSDialogDemo.vue +301 -301
  156. package/src/views/EbizSForm/index.vue +359 -359
  157. package/src/views/EbizSFormDemo.vue +420 -420
  158. package/src/views/EbizSpace.vue +185 -185
  159. package/src/views/EbizSwiper.vue +157 -157
  160. package/src/views/EbizTdesignButtonDialogExample.vue +437 -437
  161. package/src/views/Form.vue +19 -19
  162. package/src/views/GridDemo.vue +238 -238
  163. package/src/views/Home.vue +148 -148
  164. package/src/views/Mindmap.vue +17 -17
  165. package/src/views/MyComponent.vue +19 -19
  166. package/src/views/OkrTree.vue +19 -19
  167. package/src/views/PageHeaderDemo.vue +104 -104
  168. package/src/views/PaginationDemo.vue +96 -96
  169. package/src/views/PermissionBoxDemo.vue +85 -85
  170. package/src/views/PopconfirmDemo.vue +80 -80
  171. package/src/views/RemoteSelect.vue +350 -350
  172. package/src/views/StatisticDemo.vue +190 -190
  173. package/src/views/SwitchDemo.vue +79 -79
  174. package/src/views/Table.vue +19 -19
  175. package/src/views/TableDemo.vue +334 -334
  176. package/src/views/TableSortDemo.vue +143 -143
  177. package/src/views/TableView.vue +68 -68
  178. package/src/views/TabsDemo.vue +282 -282
  179. package/src/views/TagDemo.vue +101 -101
  180. package/src/views/TdesignAlert.vue +98 -98
  181. package/src/views/TdesignButton.vue +190 -190
  182. package/src/views/TdesignCalendar.vue +94 -94
  183. package/src/views/TdesignCard.vue +296 -296
  184. package/src/views/TdesignCollapse.vue +293 -293
  185. package/src/views/TdesignDatePicker.vue +187 -187
  186. package/src/views/TdesignDescriptions.vue +101 -101
  187. package/src/views/TdesignForm.vue +248 -248
  188. package/src/views/TdesignIcon.vue +203 -203
  189. package/src/views/TdesignImage.vue +215 -215
  190. package/src/views/TdesignImageViewer.vue +198 -198
  191. package/src/views/TdesignInput.vue +252 -252
  192. package/src/views/TdesignSelect.vue +473 -473
  193. package/src/views/TdesignSwiper.vue +157 -157
  194. package/src/views/TextareaDemo.vue +93 -93
  195. package/src/views/TimePickerDemo.vue +146 -146
  196. package/src/views/TimelineDemo.vue +160 -160
  197. package/src/views/Title.vue +19 -19
  198. package/src/views/TreeDemo.vue +254 -254
  199. package/src/views/TreeMergeTableDemo.vue +239 -239
  200. package/src/views/TreeSelectorDemo.vue +245 -245
  201. package/src/views/UploadDemo.vue +121 -121
  202. package/src/views/VxeTableDemo.vue +279 -279
  203. package/src/views/WatermarkDemo.vue +85 -85
  204. package/src/components/EbizDropdown.vue +0 -117
  205. package/src/components/EbizDropdownItem.vue +0 -81
@@ -1,163 +1,163 @@
1
- <template>
2
- <t-pagination
3
- :current="current"
4
- :defaultCurrent="defaultCurrent"
5
- :defaultPageSize="defaultPageSize"
6
- :disabled="disabled"
7
- :foldedMaxPageBtn="foldedMaxPageBtn"
8
- :hideOnSinglePage="hideOnSinglePage"
9
- :maxPageBtn="maxPageBtn"
10
- :pageEllipsisMode="pageEllipsisMode"
11
- :pageSize="pageSize"
12
- :pageSizeOptions="pageSizeOptions"
13
- :selectProps="selectProps"
14
- :showFirstAndLastPageBtn="showFirstAndLastPageBtn"
15
- :showJumper="showJumper"
16
- :showPageNumber="showPageNumber"
17
- :showPageSize="showPageSize"
18
- :showPreviousAndNextBtn="showPreviousAndNextBtn"
19
- :size="size"
20
- :theme="theme"
21
- :total="total"
22
- :totalContent="totalContent"
23
- @change="handleChange"
24
- >
25
- <!-- 如果有totalContent插槽,使用插槽内容 -->
26
- <template v-if="$slots.totalContent" #totalContent>
27
- <slot name="totalContent"></slot>
28
- </template>
29
-
30
- <!-- 如果有pageNumber插槽,使用插槽内容 -->
31
- <template v-if="$slots.pageNumber" #pageNumber>
32
- <slot name="pageNumber"></slot>
33
- </template>
34
- </t-pagination>
35
- </template>
36
-
37
- <script>
38
- export default {
39
- name: "EbizPagination"
40
- }
41
- </script>
42
-
43
- <script setup>
44
- import { defineProps, defineEmits } from 'vue';
45
- import { Pagination as TPagination } from 'tdesign-vue-next';
46
-
47
- defineProps({
48
- // 当前页
49
- current: {
50
- type: Number,
51
- default: undefined
52
- },
53
- // 默认当前页
54
- defaultCurrent: {
55
- type: Number,
56
- default: 1
57
- },
58
- // 默认每页显示条数
59
- defaultPageSize: {
60
- type: Number,
61
- default: 10
62
- },
63
- // 是否禁用分页
64
- disabled: {
65
- type: Boolean,
66
- default: false
67
- },
68
- // 折叠时最多显示的页码按钮数
69
- foldedMaxPageBtn: {
70
- type: Number,
71
- default: 5
72
- },
73
- // 当只有一页时是否隐藏分页
74
- hideOnSinglePage: {
75
- type: Boolean,
76
- default: false
77
- },
78
- // 最多显示的页码按钮数
79
- maxPageBtn: {
80
- type: Number,
81
- default: 10
82
- },
83
- // 页码数量超出时的省略模式
84
- pageEllipsisMode: {
85
- type: String,
86
- default: 'mid',
87
- validator: (val) => ['mid', 'both-ends'].includes(val)
88
- },
89
- // 每页显示条数
90
- pageSize: {
91
- type: Number,
92
- default: 10
93
- },
94
- // 分页大小控制器选项
95
- pageSizeOptions: {
96
- type: Array,
97
- default: () => [5, 10, 20, 50]
98
- },
99
- // 透传Select组件属性
100
- selectProps: {
101
- type: Object,
102
- default: () => ({})
103
- },
104
- // 是否显示跳转首页尾页页码控制器
105
- showFirstAndLastPageBtn: {
106
- type: Boolean,
107
- default: false
108
- },
109
- // 是否显示跳转页码控制器
110
- showJumper: {
111
- type: Boolean,
112
- default: false
113
- },
114
- // 是否显示页码控制器
115
- showPageNumber: {
116
- type: Boolean,
117
- default: true
118
- },
119
- // 是否显示分页数量控制器
120
- showPageSize: {
121
- type: Boolean,
122
- default: true
123
- },
124
- // 是否显示跳转前后页页码控制器
125
- showPreviousAndNextBtn: {
126
- type: Boolean,
127
- default: true
128
- },
129
- // 分页组件尺寸
130
- size: {
131
- type: String,
132
- default: 'medium',
133
- validator: (val) => ['small', 'medium'].includes(val)
134
- },
135
- // 分页组件风格
136
- theme: {
137
- type: String,
138
- default: 'default',
139
- validator: (val) => ['default', 'simple'].includes(val)
140
- },
141
- // 数据总条数
142
- total: {
143
- type: Number,
144
- default: 0
145
- },
146
- // 用于自定义总条数呈现内容
147
- totalContent: {
148
- type: [Boolean, Function],
149
- default: true
150
- }
151
- });
152
-
153
- const emit = defineEmits(['change']);
154
-
155
- // 分页变化事件
156
- const handleChange = (pageInfo) => {
157
- emit('change', pageInfo);
158
- };
159
- </script>
160
-
161
- <style lang="less" scoped>
162
- /* 自定义样式 */
1
+ <template>
2
+ <t-pagination
3
+ :current="current"
4
+ :defaultCurrent="defaultCurrent"
5
+ :defaultPageSize="defaultPageSize"
6
+ :disabled="disabled"
7
+ :foldedMaxPageBtn="foldedMaxPageBtn"
8
+ :hideOnSinglePage="hideOnSinglePage"
9
+ :maxPageBtn="maxPageBtn"
10
+ :pageEllipsisMode="pageEllipsisMode"
11
+ :pageSize="pageSize"
12
+ :pageSizeOptions="pageSizeOptions"
13
+ :selectProps="selectProps"
14
+ :showFirstAndLastPageBtn="showFirstAndLastPageBtn"
15
+ :showJumper="showJumper"
16
+ :showPageNumber="showPageNumber"
17
+ :showPageSize="showPageSize"
18
+ :showPreviousAndNextBtn="showPreviousAndNextBtn"
19
+ :size="size"
20
+ :theme="theme"
21
+ :total="total"
22
+ :totalContent="totalContent"
23
+ @change="handleChange"
24
+ >
25
+ <!-- 如果有totalContent插槽,使用插槽内容 -->
26
+ <template v-if="$slots.totalContent" #totalContent>
27
+ <slot name="totalContent"></slot>
28
+ </template>
29
+
30
+ <!-- 如果有pageNumber插槽,使用插槽内容 -->
31
+ <template v-if="$slots.pageNumber" #pageNumber>
32
+ <slot name="pageNumber"></slot>
33
+ </template>
34
+ </t-pagination>
35
+ </template>
36
+
37
+ <script>
38
+ export default {
39
+ name: "EbizPagination"
40
+ }
41
+ </script>
42
+
43
+ <script setup>
44
+ import { defineProps, defineEmits } from 'vue';
45
+ import { Pagination as TPagination } from 'tdesign-vue-next';
46
+
47
+ defineProps({
48
+ // 当前页
49
+ current: {
50
+ type: Number,
51
+ default: undefined
52
+ },
53
+ // 默认当前页
54
+ defaultCurrent: {
55
+ type: Number,
56
+ default: 1
57
+ },
58
+ // 默认每页显示条数
59
+ defaultPageSize: {
60
+ type: Number,
61
+ default: 10
62
+ },
63
+ // 是否禁用分页
64
+ disabled: {
65
+ type: Boolean,
66
+ default: false
67
+ },
68
+ // 折叠时最多显示的页码按钮数
69
+ foldedMaxPageBtn: {
70
+ type: Number,
71
+ default: 5
72
+ },
73
+ // 当只有一页时是否隐藏分页
74
+ hideOnSinglePage: {
75
+ type: Boolean,
76
+ default: false
77
+ },
78
+ // 最多显示的页码按钮数
79
+ maxPageBtn: {
80
+ type: Number,
81
+ default: 10
82
+ },
83
+ // 页码数量超出时的省略模式
84
+ pageEllipsisMode: {
85
+ type: String,
86
+ default: 'mid',
87
+ validator: (val) => ['mid', 'both-ends'].includes(val)
88
+ },
89
+ // 每页显示条数
90
+ pageSize: {
91
+ type: Number,
92
+ default: 10
93
+ },
94
+ // 分页大小控制器选项
95
+ pageSizeOptions: {
96
+ type: Array,
97
+ default: () => [5, 10, 20, 50]
98
+ },
99
+ // 透传Select组件属性
100
+ selectProps: {
101
+ type: Object,
102
+ default: () => ({})
103
+ },
104
+ // 是否显示跳转首页尾页页码控制器
105
+ showFirstAndLastPageBtn: {
106
+ type: Boolean,
107
+ default: false
108
+ },
109
+ // 是否显示跳转页码控制器
110
+ showJumper: {
111
+ type: Boolean,
112
+ default: false
113
+ },
114
+ // 是否显示页码控制器
115
+ showPageNumber: {
116
+ type: Boolean,
117
+ default: true
118
+ },
119
+ // 是否显示分页数量控制器
120
+ showPageSize: {
121
+ type: Boolean,
122
+ default: true
123
+ },
124
+ // 是否显示跳转前后页页码控制器
125
+ showPreviousAndNextBtn: {
126
+ type: Boolean,
127
+ default: true
128
+ },
129
+ // 分页组件尺寸
130
+ size: {
131
+ type: String,
132
+ default: 'medium',
133
+ validator: (val) => ['small', 'medium'].includes(val)
134
+ },
135
+ // 分页组件风格
136
+ theme: {
137
+ type: String,
138
+ default: 'default',
139
+ validator: (val) => ['default', 'simple'].includes(val)
140
+ },
141
+ // 数据总条数
142
+ total: {
143
+ type: Number,
144
+ default: 0
145
+ },
146
+ // 用于自定义总条数呈现内容
147
+ totalContent: {
148
+ type: [Boolean, Function],
149
+ default: true
150
+ }
151
+ });
152
+
153
+ const emit = defineEmits(['change']);
154
+
155
+ // 分页变化事件
156
+ const handleChange = (pageInfo) => {
157
+ emit('change', pageInfo);
158
+ };
159
+ </script>
160
+
161
+ <style lang="less" scoped>
162
+ /* 自定义样式 */
163
163
  </style>
@@ -1,48 +1,48 @@
1
- <template>
2
- <t-popconfirm
3
- :content="content"
4
- @cancel="handleCancel"
5
- @confirm="handleConfirm"
6
- >
7
- <slot></slot>
8
- </t-popconfirm>
9
- </template>
10
-
11
- <script>
12
- export default {
13
- name: "EbizPopconfirm"
14
- }
15
- </script>
16
-
17
- <script setup>
18
- import { Popconfirm as TPopconfirm } from 'tdesign-vue-next';
19
-
20
- // 定义属性
21
- const props = defineProps({
22
- // 确认框内容
23
- content: {
24
- type: [String, Function],
25
- default: ''
26
- }
27
- });
28
-
29
- // 定义事件
30
- const emit = defineEmits([
31
- 'cancel',
32
- 'confirm'
33
- ]);
34
-
35
- // 取消按钮点击事件
36
- const handleCancel = ({ e }) => {
37
- emit('cancel', { e });
38
- };
39
-
40
- // 确认按钮点击事件
41
- const handleConfirm = ({ e }) => {
42
- emit('confirm', { e });
43
- };
44
- </script>
45
-
46
- <style lang="less" scoped>
47
- /* 自定义样式可在此处添加 */
1
+ <template>
2
+ <t-popconfirm
3
+ :content="content"
4
+ @cancel="handleCancel"
5
+ @confirm="handleConfirm"
6
+ >
7
+ <slot></slot>
8
+ </t-popconfirm>
9
+ </template>
10
+
11
+ <script>
12
+ export default {
13
+ name: "EbizPopconfirm"
14
+ }
15
+ </script>
16
+
17
+ <script setup>
18
+ import { Popconfirm as TPopconfirm } from 'tdesign-vue-next';
19
+
20
+ // 定义属性
21
+ const props = defineProps({
22
+ // 确认框内容
23
+ content: {
24
+ type: [String, Function],
25
+ default: ''
26
+ }
27
+ });
28
+
29
+ // 定义事件
30
+ const emit = defineEmits([
31
+ 'cancel',
32
+ 'confirm'
33
+ ]);
34
+
35
+ // 取消按钮点击事件
36
+ const handleCancel = ({ e }) => {
37
+ emit('cancel', { e });
38
+ };
39
+
40
+ // 确认按钮点击事件
41
+ const handleConfirm = ({ e }) => {
42
+ emit('confirm', { e });
43
+ };
44
+ </script>
45
+
46
+ <style lang="less" scoped>
47
+ /* 自定义样式可在此处添加 */
48
48
  </style>
@@ -1,87 +1,87 @@
1
- <template>
2
- <t-radio
3
- :allowUncheck="allowUncheck"
4
- :checked="modelValue"
5
- :defaultChecked="defaultChecked"
6
- :disabled="disabled"
7
- :label="label"
8
- :name="name"
9
- :readonly="readonly"
10
- :value="value"
11
- @change="handleChange"
12
- @click="handleClick"
13
- >
14
- <slot>{{ label }}</slot>
15
- </t-radio>
16
- </template>
17
-
18
- <script>
19
- export default {
20
- name: "EbizRadio"
21
- }
22
- </script>
23
-
24
- <script setup>
25
- import { defineProps, defineEmits } from 'vue';
26
- import { Radio as TRadio } from 'tdesign-vue-next';
27
-
28
- const props = defineProps({
29
- // 是否允许取消选中
30
- allowUncheck: {
31
- type: Boolean,
32
- default: false
33
- },
34
- // 是否选中 (v-model)
35
- modelValue: {
36
- type: Boolean,
37
- default: false
38
- },
39
- // 默认是否选中
40
- defaultChecked: {
41
- type: Boolean,
42
- default: false
43
- },
44
- // 是否禁用组件
45
- disabled: {
46
- type: Boolean,
47
- default: undefined
48
- },
49
- // 主文案
50
- label: {
51
- type: String,
52
- default: ''
53
- },
54
- // HTML 元素原生属性
55
- name: {
56
- type: String,
57
- default: ''
58
- },
59
- // 只读状态
60
- readonly: {
61
- type: Boolean,
62
- default: false
63
- },
64
- // 单选按钮的值
65
- value: {
66
- type: [String, Number, Boolean],
67
- default: undefined
68
- }
69
- });
70
-
71
- const emit = defineEmits(['change', 'click', 'update:modelValue']);
72
-
73
- // 选中状态变化事件
74
- const handleChange = (checked, context) => {
75
- emit('update:modelValue', checked);
76
- emit('change', checked, context);
77
- };
78
-
79
- // 点击事件
80
- const handleClick = (context) => {
81
- emit('click', context);
82
- };
83
- </script>
84
-
85
- <style lang="less" scoped>
86
- /* 自定义样式 */
1
+ <template>
2
+ <t-radio
3
+ :allowUncheck="allowUncheck"
4
+ :checked="modelValue"
5
+ :defaultChecked="defaultChecked"
6
+ :disabled="disabled"
7
+ :label="label"
8
+ :name="name"
9
+ :readonly="readonly"
10
+ :value="value"
11
+ @change="handleChange"
12
+ @click="handleClick"
13
+ >
14
+ <slot>{{ label }}</slot>
15
+ </t-radio>
16
+ </template>
17
+
18
+ <script>
19
+ export default {
20
+ name: "EbizRadio"
21
+ }
22
+ </script>
23
+
24
+ <script setup>
25
+ import { defineProps, defineEmits } from 'vue';
26
+ import { Radio as TRadio } from 'tdesign-vue-next';
27
+
28
+ const props = defineProps({
29
+ // 是否允许取消选中
30
+ allowUncheck: {
31
+ type: Boolean,
32
+ default: false
33
+ },
34
+ // 是否选中 (v-model)
35
+ modelValue: {
36
+ type: Boolean,
37
+ default: false
38
+ },
39
+ // 默认是否选中
40
+ defaultChecked: {
41
+ type: Boolean,
42
+ default: false
43
+ },
44
+ // 是否禁用组件
45
+ disabled: {
46
+ type: Boolean,
47
+ default: undefined
48
+ },
49
+ // 主文案
50
+ label: {
51
+ type: String,
52
+ default: ''
53
+ },
54
+ // HTML 元素原生属性
55
+ name: {
56
+ type: String,
57
+ default: ''
58
+ },
59
+ // 只读状态
60
+ readonly: {
61
+ type: Boolean,
62
+ default: false
63
+ },
64
+ // 单选按钮的值
65
+ value: {
66
+ type: [String, Number, Boolean],
67
+ default: undefined
68
+ }
69
+ });
70
+
71
+ const emit = defineEmits(['change', 'click', 'update:modelValue']);
72
+
73
+ // 选中状态变化事件
74
+ const handleChange = (checked, context) => {
75
+ emit('update:modelValue', checked);
76
+ emit('change', checked, context);
77
+ };
78
+
79
+ // 点击事件
80
+ const handleClick = (context) => {
81
+ emit('click', context);
82
+ };
83
+ </script>
84
+
85
+ <style lang="less" scoped>
86
+ /* 自定义样式 */
87
87
  </style>