@a2simcode/ui 0.0.179 → 0.0.180

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 (344) hide show
  1. package/.cursor/skills/ui-component-helper/README.md +86 -86
  2. package/.cursor/skills/ui-component-helper/SKILL.md +115 -115
  3. package/LICENSE +53 -53
  4. package/README.md +156 -156
  5. package/dist/simcode-ui.es.js +1179 -1179
  6. package/dist/simcode-ui.umd.js +2 -2
  7. package/dist/stats.html +1 -1
  8. package/dist/ui.css +1 -1
  9. package/docs/components/autocomplete.md +89 -89
  10. package/docs/components/barcode.md +101 -101
  11. package/docs/components/button-select.md +24 -24
  12. package/docs/components/button.md +117 -117
  13. package/docs/components/buttons.md +119 -119
  14. package/docs/components/cascader-select.md +114 -114
  15. package/docs/components/checkbox.md +114 -114
  16. package/docs/components/code-mirror.md +85 -85
  17. package/docs/components/collapse.md +26 -26
  18. package/docs/components/comp.md +71 -71
  19. package/docs/components/count-up.md +24 -24
  20. package/docs/components/count.md +24 -24
  21. package/docs/components/data-panel.md +24 -24
  22. package/docs/components/date.md +76 -76
  23. package/docs/components/dialog-full.md +112 -112
  24. package/docs/components/dialog.md +127 -127
  25. package/docs/components/divider.md +24 -24
  26. package/docs/components/drawer.md +127 -127
  27. package/docs/components/dynamic-layer.md +118 -118
  28. package/docs/components/echarts.md +72 -72
  29. package/docs/components/editor.md +24 -24
  30. package/docs/components/form.md +72 -72
  31. package/docs/components/guid.md +39 -39
  32. package/docs/components/hpanel.md +24 -24
  33. package/docs/components/icon.md +56 -56
  34. package/docs/components/input-button.md +24 -24
  35. package/docs/components/input-code.md +24 -24
  36. package/docs/components/input-color.md +114 -114
  37. package/docs/components/input-layer.md +26 -26
  38. package/docs/components/input-rows.md +370 -370
  39. package/docs/components/input-tag.md +50 -50
  40. package/docs/components/input.md +129 -129
  41. package/docs/components/layer-form.md +61 -61
  42. package/docs/components/layer.md +127 -127
  43. package/docs/components/layout.md +132 -132
  44. package/docs/components/map.md +24 -24
  45. package/docs/components/menu.md +121 -121
  46. package/docs/components/meta/button.ts +212 -212
  47. package/docs/components/meta/buttons.ts +76 -76
  48. package/docs/components/meta/code-mirror.ts +108 -108
  49. package/docs/components/meta/comp.ts +236 -236
  50. package/docs/components/meta/date.ts +267 -267
  51. package/docs/components/meta/echarts.ts +64 -64
  52. package/docs/components/meta/form-item.ts +50 -50
  53. package/docs/components/meta/form.ts +181 -181
  54. package/docs/components/meta/input-button.ts +165 -165
  55. package/docs/components/meta/input-cards.ts +112 -112
  56. package/docs/components/meta/input-code.ts +151 -151
  57. package/docs/components/meta/input-color.ts +243 -243
  58. package/docs/components/meta/input-layer.ts +366 -366
  59. package/docs/components/meta/input-rows.ts +119 -119
  60. package/docs/components/meta/layer-form.ts +56 -56
  61. package/docs/components/meta/map.ts +68 -68
  62. package/docs/components/meta/panel.ts +152 -152
  63. package/docs/components/meta/slider.ts +270 -270
  64. package/docs/components/meta/table-panel.ts +232 -232
  65. package/docs/components/meta/table.ts +391 -391
  66. package/docs/components/meta/tabs.ts +146 -146
  67. package/docs/components/meta/title.ts +91 -91
  68. package/docs/components/meta/tree-select.ts +199 -199
  69. package/docs/components/meta/tree.ts +219 -219
  70. package/docs/components/meta/vpanel.ts +19 -19
  71. package/docs/components/meta/workflow-viewer.ts +55 -55
  72. package/docs/components/number.md +124 -124
  73. package/docs/components/page.md +102 -102
  74. package/docs/components/panel.md +37 -37
  75. package/docs/components/radio.md +87 -87
  76. package/docs/components/rate.md +71 -71
  77. package/docs/components/select.md +133 -133
  78. package/docs/components/slider-captcha.md +41 -41
  79. package/docs/components/slider.md +101 -101
  80. package/docs/components/switch.md +90 -90
  81. package/docs/components/table-panel.md +236 -236
  82. package/docs/components/table.md +391 -391
  83. package/docs/components/tabs.md +26 -26
  84. package/docs/components/title.md +24 -24
  85. package/docs/components/tree.md +207 -207
  86. package/docs/components/upload.md +117 -117
  87. package/docs/components/workflow-viewer.md +21 -21
  88. package/docs/components/workflow.md +21 -21
  89. package/docs/examples/autocomplete/advanced.vue +35 -35
  90. package/docs/examples/autocomplete/basic.vue +32 -32
  91. package/docs/examples/autocomplete/clearable.vue +33 -33
  92. package/docs/examples/autocomplete/custom-template.vue +49 -49
  93. package/docs/examples/autocomplete/disabled.vue +33 -33
  94. package/docs/examples/autocomplete/icon.vue +37 -37
  95. package/docs/examples/barcode/all-types.vue +380 -380
  96. package/docs/examples/barcode/basic.vue +14 -14
  97. package/docs/examples/barcode/props-appearance.vue +243 -243
  98. package/docs/examples/barcode/props-geometry.vue +143 -143
  99. package/docs/examples/barcode/props-logic.vue +216 -216
  100. package/docs/examples/barcode/props-symbology.vue +199 -199
  101. package/docs/examples/barcode/props-text.vue +268 -268
  102. package/docs/examples/button/basic.vue +7 -7
  103. package/docs/examples/button/danger-ghost.vue +17 -17
  104. package/docs/examples/button/disabled.vue +10 -10
  105. package/docs/examples/button/loading.vue +6 -6
  106. package/docs/examples/button/shape.vue +7 -7
  107. package/docs/examples/button/size.vue +14 -14
  108. package/docs/examples/button/type.vue +10 -10
  109. package/docs/examples/button-select/basic.vue +19 -19
  110. package/docs/examples/buttons/basic.vue +45 -45
  111. package/docs/examples/buttons/disabled.vue +36 -36
  112. package/docs/examples/buttons/dropdown.vue +63 -63
  113. package/docs/examples/buttons/group.vue +52 -52
  114. package/docs/examples/buttons/link.vue +47 -47
  115. package/docs/examples/buttons/popup.vue +39 -39
  116. package/docs/examples/buttons/size.vue +45 -45
  117. package/docs/examples/cascader-select/basic.vue +28 -28
  118. package/docs/examples/cascader-select/clearable.vue +34 -34
  119. package/docs/examples/cascader-select/disabled.vue +43 -43
  120. package/docs/examples/cascader-select/filterable.vue +37 -37
  121. package/docs/examples/cascader-select/methods.vue +84 -84
  122. package/docs/examples/cascader-select/multiple.vue +38 -38
  123. package/docs/examples/cascader-select/slot.vue +45 -45
  124. package/docs/examples/checkbox/basic.vue +18 -18
  125. package/docs/examples/checkbox/button.vue +19 -19
  126. package/docs/examples/checkbox/color.vue +25 -25
  127. package/docs/examples/checkbox/disabled.vue +17 -17
  128. package/docs/examples/checkbox/min-max.vue +20 -20
  129. package/docs/examples/checkbox/mixed.vue +56 -56
  130. package/docs/examples/checkbox/size.vue +28 -28
  131. package/docs/examples/code-mirror/basic.vue +11 -11
  132. package/docs/examples/code-mirror/events.vue +42 -42
  133. package/docs/examples/code-mirror/height.vue +25 -25
  134. package/docs/examples/code-mirror/mode.vue +33 -33
  135. package/docs/examples/code-mirror/readonly.vue +14 -14
  136. package/docs/examples/collapse/basic.vue +82 -82
  137. package/docs/examples/comp/basic.vue +7 -7
  138. package/docs/examples/comp/collapse.vue +38 -38
  139. package/docs/examples/comp/tabs.vue +38 -38
  140. package/docs/examples/count/basic.vue +101 -101
  141. package/docs/examples/count-up/basic.vue +89 -89
  142. package/docs/examples/data-panel/basic.vue +110 -110
  143. package/docs/examples/date/basic.vue +73 -73
  144. package/docs/examples/date/default-value.vue +59 -59
  145. package/docs/examples/date/format.vue +75 -75
  146. package/docs/examples/date/range.vue +66 -66
  147. package/docs/examples/date/types.vue +79 -79
  148. package/docs/examples/decorated-title/basic.vue +31 -31
  149. package/docs/examples/dialog/basic.vue +36 -36
  150. package/docs/examples/dialog/custom-buttons.vue +44 -44
  151. package/docs/examples/dialog/fullscreen.vue +23 -23
  152. package/docs/examples/dialog/no-mask.vue +17 -17
  153. package/docs/examples/dialog/size.vue +44 -44
  154. package/docs/examples/dialog/steps.vue +57 -57
  155. package/docs/examples/dialog-full/basic.vue +29 -29
  156. package/docs/examples/dialog-full/custom-buttons.vue +45 -45
  157. package/docs/examples/dialog-full/no-buttons.vue +18 -18
  158. package/docs/examples/dialog-full/no-header.vue +27 -27
  159. package/docs/examples/dialog-full/steps.vue +71 -71
  160. package/docs/examples/divider/basic.vue +52 -52
  161. package/docs/examples/drawer/basic.vue +35 -35
  162. package/docs/examples/drawer/custom-buttons.vue +34 -34
  163. package/docs/examples/drawer/direction.vue +47 -47
  164. package/docs/examples/drawer/mask.vue +36 -36
  165. package/docs/examples/drawer/no-buttons.vue +20 -20
  166. package/docs/examples/drawer/size.vue +28 -28
  167. package/docs/examples/dynamic-layer/basic.vue +33 -33
  168. package/docs/examples/dynamic-layer/custom-buttons.vue +43 -43
  169. package/docs/examples/dynamic-layer/form.vue +73 -73
  170. package/docs/examples/dynamic-layer/steps.vue +52 -52
  171. package/docs/examples/dynamic-layer/types.vue +40 -40
  172. package/docs/examples/echarts/basic.vue +31 -31
  173. package/docs/examples/echarts/dynamic.vue +43 -43
  174. package/docs/examples/echarts/line.vue +46 -46
  175. package/docs/examples/echarts/pie.vue +44 -44
  176. package/docs/examples/editor/basic.vue +15 -15
  177. package/docs/examples/form/basic.vue +665 -665
  178. package/docs/examples/form/init.vue +76 -76
  179. package/docs/examples/form/master-detail.vue +203 -203
  180. package/docs/examples/form/rule-format.vue +179 -179
  181. package/docs/examples/guid/basic.vue +10 -10
  182. package/docs/examples/guid/size.vue +13 -13
  183. package/docs/examples/hpanel/basic.vue +79 -79
  184. package/docs/examples/icon/basic.vue +9 -9
  185. package/docs/examples/icon/rotate-flip.vue +9 -9
  186. package/docs/examples/icon/size.vue +7 -7
  187. package/docs/examples/input/basic.vue +10 -10
  188. package/docs/examples/input/clearable.vue +12 -12
  189. package/docs/examples/input/disabled.vue +6 -6
  190. package/docs/examples/input/icon.vue +23 -23
  191. package/docs/examples/input/password.vue +18 -18
  192. package/docs/examples/input/size.vue +13 -13
  193. package/docs/examples/input/textarea.vue +25 -25
  194. package/docs/examples/input/word-limit.vue +28 -28
  195. package/docs/examples/input-button/basic.vue +33 -33
  196. package/docs/examples/input-code/basic.vue +29 -29
  197. package/docs/examples/input-color/basic.vue +10 -10
  198. package/docs/examples/input-color/disabled.vue +13 -13
  199. package/docs/examples/input-color/format.vue +17 -17
  200. package/docs/examples/input-color/no-alpha.vue +13 -13
  201. package/docs/examples/input-color/only-button.vue +15 -15
  202. package/docs/examples/input-color/predefine.vue +31 -31
  203. package/docs/examples/input-color/size.vue +15 -15
  204. package/docs/examples/input-layer/basic.vue +86 -86
  205. package/docs/examples/input-rows/basic.vue +73 -73
  206. package/docs/examples/input-rows/drag.vue +48 -48
  207. package/docs/examples/input-rows/layer-form.vue +85 -85
  208. package/docs/examples/input-rows/nested.vue +91 -91
  209. package/docs/examples/input-tag/basic.vue +27 -27
  210. package/docs/examples/input-tag/colors.vue +23 -23
  211. package/docs/examples/input-tag/readonly.vue +17 -17
  212. package/docs/examples/layer/basic.vue +43 -43
  213. package/docs/examples/layer/custom-buttons.vue +61 -61
  214. package/docs/examples/layer/drawer.vue +37 -37
  215. package/docs/examples/layer/full.vue +38 -38
  216. package/docs/examples/layer/modal.vue +34 -34
  217. package/docs/examples/layer/steps.vue +46 -46
  218. package/docs/examples/layer-form/basic.vue +76 -76
  219. package/docs/examples/layer-form/config.vue +82 -82
  220. package/docs/examples/layer-form/size.vue +72 -72
  221. package/docs/examples/layout/basic.vue +36 -36
  222. package/docs/examples/layout/custom-size.vue +50 -50
  223. package/docs/examples/layout/disable-move.vue +37 -37
  224. package/docs/examples/layout/hide-mid-when-narrow.vue +96 -96
  225. package/docs/examples/layout/min-size.vue +73 -73
  226. package/docs/examples/layout/percent-size.vue +80 -80
  227. package/docs/examples/layout/simple.vue +22 -22
  228. package/docs/examples/layout/top-side.vue +34 -34
  229. package/docs/examples/map/basic.vue +22 -22
  230. package/docs/examples/menu/basic.vue +58 -58
  231. package/docs/examples/menu/collapsed.vue +49 -49
  232. package/docs/examples/menu/horizontal.vue +44 -44
  233. package/docs/examples/menu/selection-test.vue +104 -104
  234. package/docs/examples/menu/theme.vue +46 -46
  235. package/docs/examples/menu/vertical.vue +46 -46
  236. package/docs/examples/number/advanced.vue +143 -143
  237. package/docs/examples/number/basic.vue +63 -63
  238. package/docs/examples/number/disabled.vue +49 -49
  239. package/docs/examples/number/size.vue +42 -42
  240. package/docs/examples/number/slots.vue +123 -123
  241. package/docs/examples/number/step-strictly.vue +41 -41
  242. package/docs/examples/number/step.vue +47 -47
  243. package/docs/examples/page/basic.vue +41 -41
  244. package/docs/examples/page/code-table-model.vue +428 -428
  245. package/docs/examples/page/dept-user-management.vue +211 -211
  246. package/docs/examples/page/init.vue +87 -87
  247. package/docs/examples/page/log.vue +453 -453
  248. package/docs/examples/page/user-management.vue +313 -313
  249. package/docs/examples/panel/tool-buttons.vue +18 -18
  250. package/docs/examples/radio/basic.vue +17 -17
  251. package/docs/examples/radio/button.vue +17 -17
  252. package/docs/examples/radio/color.vue +18 -18
  253. package/docs/examples/radio/disabled.vue +17 -17
  254. package/docs/examples/radio/size.vue +29 -29
  255. package/docs/examples/rate/basic.vue +24 -24
  256. package/docs/examples/rate/half.vue +24 -24
  257. package/docs/examples/rate/readonly.vue +11 -11
  258. package/docs/examples/rate/text.vue +37 -37
  259. package/docs/examples/select/basic.vue +16 -16
  260. package/docs/examples/select/clearable.vue +22 -22
  261. package/docs/examples/select/disabled.vue +31 -31
  262. package/docs/examples/select/filterable.vue +24 -24
  263. package/docs/examples/select/group.vue +23 -23
  264. package/docs/examples/select/icon.vue +16 -16
  265. package/docs/examples/select/multiple.vue +18 -18
  266. package/docs/examples/select/size.vue +39 -39
  267. package/docs/examples/slider/basic.vue +42 -42
  268. package/docs/examples/slider/disabled.vue +17 -17
  269. package/docs/examples/slider/marks.vue +30 -30
  270. package/docs/examples/slider/size.vue +37 -37
  271. package/docs/examples/slider/tooltip.vue +36 -36
  272. package/docs/examples/slider/vertical.vue +26 -26
  273. package/docs/examples/slider-captcha/basic.vue +44 -44
  274. package/docs/examples/slider-captcha/custom.vue +48 -48
  275. package/docs/examples/switch/basic.vue +16 -16
  276. package/docs/examples/switch/disabled.vue +13 -13
  277. package/docs/examples/switch/loading.vue +13 -13
  278. package/docs/examples/switch/size.vue +15 -15
  279. package/docs/examples/switch/text.vue +13 -13
  280. package/docs/examples/table/action-filter.vue +126 -126
  281. package/docs/examples/table/actions.vue +116 -116
  282. package/docs/examples/table/add-row.vue +103 -103
  283. package/docs/examples/table/basic.vue +168 -168
  284. package/docs/examples/table/checkbox-layout.vue +68 -68
  285. package/docs/examples/table/custom-layout.vue +115 -115
  286. package/docs/examples/table/dynamic-type.vue +73 -73
  287. package/docs/examples/table/editable.vue +262 -262
  288. package/docs/examples/table/field-selection.vue +87 -87
  289. package/docs/examples/table/frozen-column.vue +140 -140
  290. package/docs/examples/table/height-mode.vue +99 -99
  291. package/docs/examples/table/icon.vue +85 -85
  292. package/docs/examples/table/link.vue +66 -66
  293. package/docs/examples/table/multiple.vue +188 -188
  294. package/docs/examples/table/pagination.vue +151 -151
  295. package/docs/examples/table/single-selection.vue +64 -64
  296. package/docs/examples/table/sub-table-lazy.vue +97 -97
  297. package/docs/examples/table/sub-table.vue +103 -103
  298. package/docs/examples/table/tag.vue +43 -43
  299. package/docs/examples/table/tree-column.vue +119 -119
  300. package/docs/examples/table/tree-data.vue +141 -141
  301. package/docs/examples/table/tree-default-expand-all.vue +60 -60
  302. package/docs/examples/table/tree-lazy.vue +80 -80
  303. package/docs/examples/table/tree-set-selection.vue +75 -75
  304. package/docs/examples/table-panel/basic.vue +229 -229
  305. package/docs/examples/table-panel/batch-operations.vue +285 -285
  306. package/docs/examples/table-panel/button-visibility.vue +88 -88
  307. package/docs/examples/table-panel/filter.vue +219 -219
  308. package/docs/examples/table-panel/get-selection.vue +111 -111
  309. package/docs/examples/table-panel/multiple-selection.vue +243 -243
  310. package/docs/examples/table-panel/pagination.vue +133 -133
  311. package/docs/examples/table-panel/sub-table-lazy.vue +118 -118
  312. package/docs/examples/table-panel/tree-parent-key.vue +67 -67
  313. package/docs/examples/tabs/basic.vue +98 -98
  314. package/docs/examples/time/base.vue +67 -67
  315. package/docs/examples/title/basic.vue +87 -87
  316. package/docs/examples/tree/accordion.vue +46 -46
  317. package/docs/examples/tree/basic.vue +50 -50
  318. package/docs/examples/tree/buttons.vue +53 -53
  319. package/docs/examples/tree/checkable.vue +52 -52
  320. package/docs/examples/tree/custom-keys.vue +39 -39
  321. package/docs/examples/tree/default-expanded.vue +52 -52
  322. package/docs/examples/tree/draggable.vue +29 -29
  323. package/docs/examples/tree/expand-on-click.vue +39 -39
  324. package/docs/examples/tree/flat-data.vue +20 -20
  325. package/docs/examples/tree/icon.vue +40 -40
  326. package/docs/examples/tree/load-data.vue +37 -37
  327. package/docs/examples/tree/methods.vue +74 -74
  328. package/docs/examples/tree/theme.vue +33 -33
  329. package/docs/examples/tree-select/basic.vue +47 -47
  330. package/docs/examples/upload/accept.vue +31 -31
  331. package/docs/examples/upload/basic.vue +12 -12
  332. package/docs/examples/upload/drag.vue +11 -11
  333. package/docs/examples/upload/image.vue +17 -17
  334. package/docs/examples/upload/limit.vue +20 -20
  335. package/docs/examples/upload/multiple.vue +17 -17
  336. package/docs/examples/upload/readonly.vue +17 -17
  337. package/docs/examples/utils/cipher.vue +160 -160
  338. package/docs/examples/utils/common.vue +153 -153
  339. package/docs/examples/utils/date.vue +56 -56
  340. package/docs/examples/utils/dom.vue +52 -52
  341. package/docs/examples/utils/is.vue +70 -70
  342. package/docs/examples/workflow/basic.vue +265 -265
  343. package/docs/examples/workflow-viewer/basic.vue +248 -248
  344. package/package.json +23 -23
@@ -1,71 +1,71 @@
1
- <template>
2
- <div>
3
- <j-button label="打开步骤弹窗" @click="visible = true" />
4
- <j-dialog-full
5
- v-model:visible="visible"
6
- v-model:step-active="stepActive"
7
- title="步骤弹窗"
8
- :is-step="true"
9
- :steps="steps"
10
- :validate-steps="validateSteps"
11
- @ok="handleOk"
12
- >
13
- <div style="padding: 24px">
14
- <div v-if="stepActive === 0">
15
- <h3>第一步:基本信息</h3>
16
- <p>请填写基本信息</p>
17
- <el-input v-model="form.name" placeholder="请输入姓名" style="margin-top: 16px" />
18
- </div>
19
- <div v-if="stepActive === 1">
20
- <h3>第二步:详细信息</h3>
21
- <p>请填写详细信息</p>
22
- <el-input v-model="form.email" placeholder="请输入邮箱" style="margin-top: 16px" />
23
- </div>
24
- <div v-if="stepActive === 2">
25
- <h3>第三步:确认信息</h3>
26
- <p>姓名: {{ form.name }}</p>
27
- <p>邮箱: {{ form.email }}</p>
28
- </div>
29
- </div>
30
- </j-dialog-full>
31
- </div>
32
- </template>
33
-
34
- <script setup lang="ts">
35
- import { ref, reactive } from 'vue'
36
- import { ElMessage } from 'element-plus'
37
-
38
- const visible = ref(false)
39
- const stepActive = ref(0)
40
-
41
- const steps = ['基本信息', '详细信息', '确认信息']
42
-
43
- const form = reactive({
44
- name: '',
45
- email: '',
46
- })
47
-
48
- const validateSteps = async (step: number) => {
49
- if (step === 0 && !form.name) {
50
- ElMessage.warning('请输入姓名')
51
- return false
52
- }
53
- if (step === 1 && !form.email) {
54
- ElMessage.warning('请输入邮箱')
55
- return false
56
- }
57
- return true
58
- }
59
-
60
- const handleOk = (showLoading: any, hideLoading: any) => {
61
- showLoading('保存中...')
62
- setTimeout(() => {
63
- hideLoading()
64
- visible.value = false
65
- stepActive.value = 0
66
- form.name = ''
67
- form.email = ''
68
- ElMessage.success('保存成功')
69
- }, 1000)
70
- }
71
- </script>
1
+ <template>
2
+ <div>
3
+ <j-button label="打开步骤弹窗" @click="visible = true" />
4
+ <j-dialog-full
5
+ v-model:visible="visible"
6
+ v-model:step-active="stepActive"
7
+ title="步骤弹窗"
8
+ :is-step="true"
9
+ :steps="steps"
10
+ :validate-steps="validateSteps"
11
+ @ok="handleOk"
12
+ >
13
+ <div style="padding: 24px">
14
+ <div v-if="stepActive === 0">
15
+ <h3>第一步:基本信息</h3>
16
+ <p>请填写基本信息</p>
17
+ <el-input v-model="form.name" placeholder="请输入姓名" style="margin-top: 16px" />
18
+ </div>
19
+ <div v-if="stepActive === 1">
20
+ <h3>第二步:详细信息</h3>
21
+ <p>请填写详细信息</p>
22
+ <el-input v-model="form.email" placeholder="请输入邮箱" style="margin-top: 16px" />
23
+ </div>
24
+ <div v-if="stepActive === 2">
25
+ <h3>第三步:确认信息</h3>
26
+ <p>姓名: {{ form.name }}</p>
27
+ <p>邮箱: {{ form.email }}</p>
28
+ </div>
29
+ </div>
30
+ </j-dialog-full>
31
+ </div>
32
+ </template>
33
+
34
+ <script setup lang="ts">
35
+ import { ref, reactive } from 'vue'
36
+ import { ElMessage } from 'element-plus'
37
+
38
+ const visible = ref(false)
39
+ const stepActive = ref(0)
40
+
41
+ const steps = ['基本信息', '详细信息', '确认信息']
42
+
43
+ const form = reactive({
44
+ name: '',
45
+ email: '',
46
+ })
47
+
48
+ const validateSteps = async (step: number) => {
49
+ if (step === 0 && !form.name) {
50
+ ElMessage.warning('请输入姓名')
51
+ return false
52
+ }
53
+ if (step === 1 && !form.email) {
54
+ ElMessage.warning('请输入邮箱')
55
+ return false
56
+ }
57
+ return true
58
+ }
59
+
60
+ const handleOk = (showLoading: any, hideLoading: any) => {
61
+ showLoading('保存中...')
62
+ setTimeout(() => {
63
+ hideLoading()
64
+ visible.value = false
65
+ stepActive.value = 0
66
+ form.name = ''
67
+ form.email = ''
68
+ ElMessage.success('保存成功')
69
+ }, 1000)
70
+ }
71
+ </script>
@@ -1,52 +1,52 @@
1
- <template>
2
- <div class="divider-demo">
3
- <div class="demo-item">
4
- <p>默认分隔符</p>
5
- <j-divider />
6
- </div>
7
-
8
- <div class="demo-item">
9
- <p>带文本的分隔符</p>
10
- <j-divider content="or" />
11
- </div>
12
-
13
- <div class="demo-item">
14
- <p>左对齐</p>
15
- <j-divider content="左对齐" content-position="left" />
16
- </div>
17
-
18
- <div class="demo-item">
19
- <p>右对齐</p>
20
- <j-divider content="右对齐" content-position="right" />
21
- </div>
22
-
23
- <div class="demo-item">
24
- <p>自定义颜色和大小</p>
25
- <j-divider content="自定义样式" color="#1890ff" :size="16" />
26
- </div>
27
-
28
- <div class="demo-item">
29
- <p>虚线样式</p>
30
- <j-divider content="虚线" border-style="dashed" />
31
- </div>
32
- </div>
33
- </template>
34
-
35
- <script setup lang="ts">
36
- // 示例代码无需额外逻辑
37
- </script>
38
-
39
- <style scoped>
40
- .divider-demo {
41
- display: flex;
42
- flex-direction: column;
43
- gap: 24px;
44
- }
45
-
46
- .demo-item p {
47
- margin: 0 0 12px;
48
- font-size: 14px;
49
- color: var(--j-color-text-2);
50
- font-weight: 500;
51
- }
52
- </style>
1
+ <template>
2
+ <div class="divider-demo">
3
+ <div class="demo-item">
4
+ <p>默认分隔符</p>
5
+ <j-divider />
6
+ </div>
7
+
8
+ <div class="demo-item">
9
+ <p>带文本的分隔符</p>
10
+ <j-divider content="or" />
11
+ </div>
12
+
13
+ <div class="demo-item">
14
+ <p>左对齐</p>
15
+ <j-divider content="左对齐" content-position="left" />
16
+ </div>
17
+
18
+ <div class="demo-item">
19
+ <p>右对齐</p>
20
+ <j-divider content="右对齐" content-position="right" />
21
+ </div>
22
+
23
+ <div class="demo-item">
24
+ <p>自定义颜色和大小</p>
25
+ <j-divider content="自定义样式" color="#1890ff" :size="16" />
26
+ </div>
27
+
28
+ <div class="demo-item">
29
+ <p>虚线样式</p>
30
+ <j-divider content="虚线" border-style="dashed" />
31
+ </div>
32
+ </div>
33
+ </template>
34
+
35
+ <script setup lang="ts">
36
+ // 示例代码无需额外逻辑
37
+ </script>
38
+
39
+ <style scoped>
40
+ .divider-demo {
41
+ display: flex;
42
+ flex-direction: column;
43
+ gap: 24px;
44
+ }
45
+
46
+ .demo-item p {
47
+ margin: 0 0 12px;
48
+ font-size: 14px;
49
+ color: var(--j-color-text-2);
50
+ font-weight: 500;
51
+ }
52
+ </style>
@@ -1,35 +1,35 @@
1
- <template>
2
- <div>
3
- <j-button label="打开抽屉" @click="visible = true" />
4
- <j-drawer
5
- v-model:visible="visible"
6
- title="基础抽屉"
7
- :width="600"
8
- @ok="handleOk"
9
- @close="handleClose"
10
- >
11
- <div style="padding: 16px">
12
- <p>这是一个基础的抽屉示例。</p>
13
- <p>抽屉从右侧滑出,支持自定义宽度。</p>
14
- </div>
15
- </j-drawer>
16
- </div>
17
- </template>
18
-
19
- <script setup lang="ts">
20
- import { ref } from 'vue'
21
-
22
- const visible = ref(false)
23
-
24
- const handleOk = (showLoading: any, hideLoading: any) => {
25
- showLoading('保存中...')
26
- setTimeout(() => {
27
- hideLoading()
28
- visible.value = false
29
- }, 1000)
30
- }
31
-
32
- const handleClose = () => {
33
- visible.value = false
34
- }
35
- </script>
1
+ <template>
2
+ <div>
3
+ <j-button label="打开抽屉" @click="visible = true" />
4
+ <j-drawer
5
+ v-model:visible="visible"
6
+ title="基础抽屉"
7
+ :width="600"
8
+ @ok="handleOk"
9
+ @close="handleClose"
10
+ >
11
+ <div style="padding: 16px">
12
+ <p>这是一个基础的抽屉示例。</p>
13
+ <p>抽屉从右侧滑出,支持自定义宽度。</p>
14
+ </div>
15
+ </j-drawer>
16
+ </div>
17
+ </template>
18
+
19
+ <script setup lang="ts">
20
+ import { ref } from 'vue'
21
+
22
+ const visible = ref(false)
23
+
24
+ const handleOk = (showLoading: any, hideLoading: any) => {
25
+ showLoading('保存中...')
26
+ setTimeout(() => {
27
+ hideLoading()
28
+ visible.value = false
29
+ }, 1000)
30
+ }
31
+
32
+ const handleClose = () => {
33
+ visible.value = false
34
+ }
35
+ </script>
@@ -1,34 +1,34 @@
1
- <template>
2
- <div>
3
- <j-button label="打开抽屉" @click="visible = true" />
4
- <j-drawer v-model:visible="visible" title="自定义按钮" :width="600">
5
- <template #btns>
6
- <el-space :size="8">
7
- <el-button size="small" @click="visible = false">取消</el-button>
8
- <el-button size="small" type="warning" @click="handleReset">重置</el-button>
9
- <el-button size="small" type="primary" @click="handleSave">保存</el-button>
10
- </el-space>
11
- </template>
12
- <div style="padding: 16px">
13
- <p>通过 btns 插槽可以自定义底部按钮。</p>
14
- <p style="margin-top: 8px">这里展示了三个按钮:取消、重置和保存。</p>
15
- </div>
16
- </j-drawer>
17
- </div>
18
- </template>
19
-
20
- <script setup lang="ts">
21
- import { ref } from 'vue'
22
- import { ElMessage } from 'element-plus'
23
-
24
- const visible = ref(false)
25
-
26
- const handleReset = () => {
27
- ElMessage.info('重置成功')
28
- }
29
-
30
- const handleSave = () => {
31
- ElMessage.success('保存成功')
32
- visible.value = false
33
- }
34
- </script>
1
+ <template>
2
+ <div>
3
+ <j-button label="打开抽屉" @click="visible = true" />
4
+ <j-drawer v-model:visible="visible" title="自定义按钮" :width="600">
5
+ <template #btns>
6
+ <el-space :size="8">
7
+ <el-button size="small" @click="visible = false">取消</el-button>
8
+ <el-button size="small" type="warning" @click="handleReset">重置</el-button>
9
+ <el-button size="small" type="primary" @click="handleSave">保存</el-button>
10
+ </el-space>
11
+ </template>
12
+ <div style="padding: 16px">
13
+ <p>通过 btns 插槽可以自定义底部按钮。</p>
14
+ <p style="margin-top: 8px">这里展示了三个按钮:取消、重置和保存。</p>
15
+ </div>
16
+ </j-drawer>
17
+ </div>
18
+ </template>
19
+
20
+ <script setup lang="ts">
21
+ import { ref } from 'vue'
22
+ import { ElMessage } from 'element-plus'
23
+
24
+ const visible = ref(false)
25
+
26
+ const handleReset = () => {
27
+ ElMessage.info('重置成功')
28
+ }
29
+
30
+ const handleSave = () => {
31
+ ElMessage.success('保存成功')
32
+ visible.value = false
33
+ }
34
+ </script>
@@ -1,47 +1,47 @@
1
- <template>
2
- <div>
3
- <el-space>
4
- <j-button label="从右侧打开(默认)" @click="openDrawer('rtl')" />
5
- <j-button label="从左侧打开" @click="openDrawer('ltr')" />
6
- <j-button label="从顶部打开" @click="openDrawer('ttb')" />
7
- <j-button label="从底部打开" @click="openDrawer('btt')" />
8
- </el-space>
9
- <j-drawer
10
- v-model:visible="visible"
11
- :title="`${directionText}抽屉`"
12
- :direction="direction"
13
- :width="600"
14
- >
15
- <div style="padding: 16px">
16
- <p>抽屉可以从四个方向打开:</p>
17
- <ul style="margin-top: 8px; padding-left: 20px">
18
- <li>rtl: 从右往左(默认)</li>
19
- <li>ltr: 从左往右</li>
20
- <li>ttb: 从上往下</li>
21
- <li>btt: 从下往上</li>
22
- </ul>
23
- </div>
24
- </j-drawer>
25
- </div>
26
- </template>
27
-
28
- <script setup lang="ts">
29
- import { ref } from 'vue'
30
-
31
- const visible = ref(false)
32
- const direction = ref<'rtl' | 'ltr' | 'ttb' | 'btt'>('rtl')
33
- const directionText = ref('从右侧打开的')
34
-
35
- const directionMap = {
36
- rtl: '从右侧打开的',
37
- ltr: '从左侧打开的',
38
- ttb: '从顶部打开的',
39
- btt: '从底部打开的',
40
- }
41
-
42
- const openDrawer = (dir: 'rtl' | 'ltr' | 'ttb' | 'btt') => {
43
- direction.value = dir
44
- directionText.value = directionMap[dir]
45
- visible.value = true
46
- }
47
- </script>
1
+ <template>
2
+ <div>
3
+ <el-space>
4
+ <j-button label="从右侧打开(默认)" @click="openDrawer('rtl')" />
5
+ <j-button label="从左侧打开" @click="openDrawer('ltr')" />
6
+ <j-button label="从顶部打开" @click="openDrawer('ttb')" />
7
+ <j-button label="从底部打开" @click="openDrawer('btt')" />
8
+ </el-space>
9
+ <j-drawer
10
+ v-model:visible="visible"
11
+ :title="`${directionText}抽屉`"
12
+ :direction="direction"
13
+ :width="600"
14
+ >
15
+ <div style="padding: 16px">
16
+ <p>抽屉可以从四个方向打开:</p>
17
+ <ul style="margin-top: 8px; padding-left: 20px">
18
+ <li>rtl: 从右往左(默认)</li>
19
+ <li>ltr: 从左往右</li>
20
+ <li>ttb: 从上往下</li>
21
+ <li>btt: 从下往上</li>
22
+ </ul>
23
+ </div>
24
+ </j-drawer>
25
+ </div>
26
+ </template>
27
+
28
+ <script setup lang="ts">
29
+ import { ref } from 'vue'
30
+
31
+ const visible = ref(false)
32
+ const direction = ref<'rtl' | 'ltr' | 'ttb' | 'btt'>('rtl')
33
+ const directionText = ref('从右侧打开的')
34
+
35
+ const directionMap = {
36
+ rtl: '从右侧打开的',
37
+ ltr: '从左侧打开的',
38
+ ttb: '从顶部打开的',
39
+ btt: '从底部打开的',
40
+ }
41
+
42
+ const openDrawer = (dir: 'rtl' | 'ltr' | 'ttb' | 'btt') => {
43
+ direction.value = dir
44
+ directionText.value = directionMap[dir]
45
+ visible.value = true
46
+ }
47
+ </script>
@@ -1,36 +1,36 @@
1
- <template>
2
- <div>
3
- <el-space>
4
- <j-button label="无遮罩层" @click="openDrawer(false)" />
5
- <j-button label="可点击遮罩关闭" @click="openDrawer(true, true)" />
6
- </el-space>
7
- <j-drawer
8
- v-model:visible="visible"
9
- :title="drawerTitle"
10
- :width="600"
11
- :modal="modal"
12
- :close-on-click-modal="closeOnClickModal"
13
- >
14
- <div style="padding: 16px">
15
- <p v-if="!modal">设置 modal 为 false 可以取消遮罩层。</p>
16
- <p v-else>设置 close-on-click-modal 为 true,点击遮罩层可以关闭抽屉。</p>
17
- </div>
18
- </j-drawer>
19
- </div>
20
- </template>
21
-
22
- <script setup lang="ts">
23
- import { ref } from 'vue'
24
-
25
- const visible = ref(false)
26
- const modal = ref(true)
27
- const closeOnClickModal = ref(false)
28
- const drawerTitle = ref('')
29
-
30
- const openDrawer = (hasModal: boolean, clickModal: boolean = false) => {
31
- modal.value = hasModal
32
- closeOnClickModal.value = clickModal
33
- drawerTitle.value = hasModal ? '可点击遮罩关闭' : '无遮罩层抽屉'
34
- visible.value = true
35
- }
36
- </script>
1
+ <template>
2
+ <div>
3
+ <el-space>
4
+ <j-button label="无遮罩层" @click="openDrawer(false)" />
5
+ <j-button label="可点击遮罩关闭" @click="openDrawer(true, true)" />
6
+ </el-space>
7
+ <j-drawer
8
+ v-model:visible="visible"
9
+ :title="drawerTitle"
10
+ :width="600"
11
+ :modal="modal"
12
+ :close-on-click-modal="closeOnClickModal"
13
+ >
14
+ <div style="padding: 16px">
15
+ <p v-if="!modal">设置 modal 为 false 可以取消遮罩层。</p>
16
+ <p v-else>设置 close-on-click-modal 为 true,点击遮罩层可以关闭抽屉。</p>
17
+ </div>
18
+ </j-drawer>
19
+ </div>
20
+ </template>
21
+
22
+ <script setup lang="ts">
23
+ import { ref } from 'vue'
24
+
25
+ const visible = ref(false)
26
+ const modal = ref(true)
27
+ const closeOnClickModal = ref(false)
28
+ const drawerTitle = ref('')
29
+
30
+ const openDrawer = (hasModal: boolean, clickModal: boolean = false) => {
31
+ modal.value = hasModal
32
+ closeOnClickModal.value = clickModal
33
+ drawerTitle.value = hasModal ? '可点击遮罩关闭' : '无遮罩层抽屉'
34
+ visible.value = true
35
+ }
36
+ </script>
@@ -1,20 +1,20 @@
1
- <template>
2
- <div>
3
- <j-button label="打开抽屉" @click="visible = true" />
4
- <j-drawer v-model:visible="visible" title="无底部按钮" :width="600" :has-btns="false">
5
- <div style="padding: 16px">
6
- <p>设置 has-btns 为 false 可以隐藏底部按钮。</p>
7
- <p style="margin-top: 8px">这种方式适合只展示信息,不需要操作的场景。</p>
8
- <div style="margin-top: 16px">
9
- <el-button @click="visible = false">关闭抽屉</el-button>
10
- </div>
11
- </div>
12
- </j-drawer>
13
- </div>
14
- </template>
15
-
16
- <script setup lang="ts">
17
- import { ref } from 'vue'
18
-
19
- const visible = ref(false)
20
- </script>
1
+ <template>
2
+ <div>
3
+ <j-button label="打开抽屉" @click="visible = true" />
4
+ <j-drawer v-model:visible="visible" title="无底部按钮" :width="600" :has-btns="false">
5
+ <div style="padding: 16px">
6
+ <p>设置 has-btns 为 false 可以隐藏底部按钮。</p>
7
+ <p style="margin-top: 8px">这种方式适合只展示信息,不需要操作的场景。</p>
8
+ <div style="margin-top: 16px">
9
+ <el-button @click="visible = false">关闭抽屉</el-button>
10
+ </div>
11
+ </div>
12
+ </j-drawer>
13
+ </div>
14
+ </template>
15
+
16
+ <script setup lang="ts">
17
+ import { ref } from 'vue'
18
+
19
+ const visible = ref(false)
20
+ </script>
@@ -1,28 +1,28 @@
1
- <template>
2
- <div>
3
- <el-space>
4
- <j-button label="小尺寸(400px)" @click="openDrawer(400)" />
5
- <j-button label="中尺寸(600px)" @click="openDrawer(600)" />
6
- <j-button label="大尺寸(800px)" @click="openDrawer(800)" />
7
- <j-button label="百分比(50%)" @click="openDrawer('50%')" />
8
- </el-space>
9
- <j-drawer v-model:visible="visible" :title="`宽度: ${currentSize}`" :size="currentSize">
10
- <div style="padding: 16px">
11
- <p>抽屉的尺寸可以通过 size 或 width 属性自定义。</p>
12
- <p style="margin-top: 8px">当前尺寸: {{ currentSize }}</p>
13
- </div>
14
- </j-drawer>
15
- </div>
16
- </template>
17
-
18
- <script setup lang="ts">
19
- import { ref } from 'vue'
20
-
21
- const visible = ref(false)
22
- const currentSize = ref<string | number>('600px')
23
-
24
- const openDrawer = (size: string | number) => {
25
- currentSize.value = typeof size === 'number' ? `${size}px` : size
26
- visible.value = true
27
- }
28
- </script>
1
+ <template>
2
+ <div>
3
+ <el-space>
4
+ <j-button label="小尺寸(400px)" @click="openDrawer(400)" />
5
+ <j-button label="中尺寸(600px)" @click="openDrawer(600)" />
6
+ <j-button label="大尺寸(800px)" @click="openDrawer(800)" />
7
+ <j-button label="百分比(50%)" @click="openDrawer('50%')" />
8
+ </el-space>
9
+ <j-drawer v-model:visible="visible" :title="`宽度: ${currentSize}`" :size="currentSize">
10
+ <div style="padding: 16px">
11
+ <p>抽屉的尺寸可以通过 size 或 width 属性自定义。</p>
12
+ <p style="margin-top: 8px">当前尺寸: {{ currentSize }}</p>
13
+ </div>
14
+ </j-drawer>
15
+ </div>
16
+ </template>
17
+
18
+ <script setup lang="ts">
19
+ import { ref } from 'vue'
20
+
21
+ const visible = ref(false)
22
+ const currentSize = ref<string | number>('600px')
23
+
24
+ const openDrawer = (size: string | number) => {
25
+ currentSize.value = typeof size === 'number' ? `${size}px` : size
26
+ visible.value = true
27
+ }
28
+ </script>