@a2simcode/ui 0.0.49 → 0.0.51

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 (310) hide show
  1. package/.cursor/skills/ui-component-helper/README.md +43 -43
  2. package/.cursor/skills/ui-component-helper/SKILL.md +81 -81
  3. package/LICENSE +53 -53
  4. package/README.md +156 -156
  5. package/dist/components/index.d.ts +3 -1
  6. package/dist/components/panel/index.d.ts +51 -0
  7. package/dist/components/panel/src/panel.vue.d.ts +71 -0
  8. package/dist/simcode-ui.es.js +1963 -1879
  9. package/dist/simcode-ui.umd.js +2 -2
  10. package/dist/stats.html +1 -1
  11. package/dist/ui.css +1 -1
  12. package/docs/components/autocomplete.md +89 -89
  13. package/docs/components/barcode.md +101 -101
  14. package/docs/components/button-select.md +24 -24
  15. package/docs/components/button.md +117 -117
  16. package/docs/components/buttons.md +119 -119
  17. package/docs/components/cascader-select.md +114 -114
  18. package/docs/components/checkbox.md +114 -114
  19. package/docs/components/code-mirror.md +85 -85
  20. package/docs/components/collapse.md +26 -26
  21. package/docs/components/comp.md +71 -71
  22. package/docs/components/count-up.md +24 -24
  23. package/docs/components/count.md +24 -24
  24. package/docs/components/data-panel.md +24 -24
  25. package/docs/components/dialog-full.md +112 -112
  26. package/docs/components/dialog.md +127 -127
  27. package/docs/components/divider.md +24 -24
  28. package/docs/components/drawer.md +127 -127
  29. package/docs/components/dynamic-layer.md +118 -118
  30. package/docs/components/echarts.md +72 -72
  31. package/docs/components/editor.md +24 -24
  32. package/docs/components/form.md +27 -27
  33. package/docs/components/guid.md +39 -39
  34. package/docs/components/hpanel.md +24 -24
  35. package/docs/components/icon.md +56 -56
  36. package/docs/components/input-button.md +24 -24
  37. package/docs/components/input-code.md +24 -24
  38. package/docs/components/input-color.md +114 -114
  39. package/docs/components/input-layer.md +26 -26
  40. package/docs/components/input-rows.md +370 -370
  41. package/docs/components/input-tag.md +50 -50
  42. package/docs/components/input.md +129 -129
  43. package/docs/components/layer-form.md +61 -61
  44. package/docs/components/layer.md +127 -127
  45. package/docs/components/layout.md +132 -132
  46. package/docs/components/map.md +24 -24
  47. package/docs/components/menu.md +121 -121
  48. package/docs/components/meta/buttons.ts +56 -56
  49. package/docs/components/meta/comp.ts +224 -224
  50. package/docs/components/meta/dynamic-layer.ts +99 -99
  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 +160 -160
  54. package/docs/components/meta/guid.ts +42 -42
  55. package/docs/components/meta/input-color.ts +243 -243
  56. package/docs/components/meta/input-rows.ts +113 -113
  57. package/docs/components/meta/layer-form.ts +56 -56
  58. package/docs/components/meta/map.ts +68 -68
  59. package/docs/components/meta/page.ts +67 -67
  60. package/docs/components/meta/panel.ts +83 -0
  61. package/docs/components/meta/radio.ts +55 -55
  62. package/docs/components/meta/slider.ts +270 -270
  63. package/docs/components/meta/table-panel.ts +154 -154
  64. package/docs/components/meta/table.ts +328 -328
  65. package/docs/components/meta/tabs.ts +136 -136
  66. package/docs/components/meta/workflow-viewer.ts +55 -55
  67. package/docs/components/meta/workflow.ts +113 -113
  68. package/docs/components/number.md +124 -124
  69. package/docs/components/page.md +42 -42
  70. package/docs/components/panel.md +37 -0
  71. package/docs/components/radio.md +87 -87
  72. package/docs/components/rate.md +71 -71
  73. package/docs/components/select.md +133 -133
  74. package/docs/components/slider-captcha.md +41 -41
  75. package/docs/components/slider.md +101 -101
  76. package/docs/components/switch.md +90 -90
  77. package/docs/components/table-panel.md +199 -199
  78. package/docs/components/table.md +202 -202
  79. package/docs/components/tabs.md +26 -26
  80. package/docs/components/title.md +24 -24
  81. package/docs/components/tree.md +207 -207
  82. package/docs/components/upload.md +117 -117
  83. package/docs/components/workflow-viewer.md +21 -21
  84. package/docs/components/workflow.md +21 -21
  85. package/docs/examples/autocomplete/advanced.vue +35 -35
  86. package/docs/examples/autocomplete/basic.vue +32 -32
  87. package/docs/examples/autocomplete/clearable.vue +33 -33
  88. package/docs/examples/autocomplete/custom-template.vue +49 -49
  89. package/docs/examples/autocomplete/disabled.vue +33 -33
  90. package/docs/examples/autocomplete/icon.vue +37 -37
  91. package/docs/examples/barcode/all-types.vue +380 -380
  92. package/docs/examples/barcode/basic.vue +14 -14
  93. package/docs/examples/barcode/props-appearance.vue +243 -243
  94. package/docs/examples/barcode/props-geometry.vue +143 -143
  95. package/docs/examples/barcode/props-logic.vue +216 -216
  96. package/docs/examples/barcode/props-symbology.vue +199 -199
  97. package/docs/examples/barcode/props-text.vue +268 -268
  98. package/docs/examples/button/basic.vue +7 -7
  99. package/docs/examples/button/danger-ghost.vue +17 -17
  100. package/docs/examples/button/disabled.vue +10 -10
  101. package/docs/examples/button/loading.vue +6 -6
  102. package/docs/examples/button/shape.vue +7 -7
  103. package/docs/examples/button/size.vue +14 -14
  104. package/docs/examples/button/type.vue +9 -9
  105. package/docs/examples/button-select/basic.vue +19 -19
  106. package/docs/examples/buttons/basic.vue +45 -45
  107. package/docs/examples/buttons/disabled.vue +36 -36
  108. package/docs/examples/buttons/dropdown.vue +63 -63
  109. package/docs/examples/buttons/group.vue +52 -52
  110. package/docs/examples/buttons/link.vue +47 -47
  111. package/docs/examples/buttons/popup.vue +39 -39
  112. package/docs/examples/buttons/size.vue +45 -45
  113. package/docs/examples/cascader-select/basic.vue +28 -28
  114. package/docs/examples/cascader-select/clearable.vue +34 -34
  115. package/docs/examples/cascader-select/disabled.vue +43 -43
  116. package/docs/examples/cascader-select/filterable.vue +37 -37
  117. package/docs/examples/cascader-select/methods.vue +84 -84
  118. package/docs/examples/cascader-select/multiple.vue +38 -38
  119. package/docs/examples/cascader-select/slot.vue +45 -45
  120. package/docs/examples/checkbox/basic.vue +18 -18
  121. package/docs/examples/checkbox/button.vue +19 -19
  122. package/docs/examples/checkbox/color.vue +25 -25
  123. package/docs/examples/checkbox/disabled.vue +17 -17
  124. package/docs/examples/checkbox/min-max.vue +20 -20
  125. package/docs/examples/checkbox/mixed.vue +56 -56
  126. package/docs/examples/checkbox/size.vue +28 -28
  127. package/docs/examples/code-mirror/basic.vue +11 -11
  128. package/docs/examples/code-mirror/events.vue +42 -42
  129. package/docs/examples/code-mirror/height.vue +25 -25
  130. package/docs/examples/code-mirror/mode.vue +33 -33
  131. package/docs/examples/code-mirror/readonly.vue +14 -14
  132. package/docs/examples/collapse/basic.vue +82 -82
  133. package/docs/examples/comp/basic.vue +7 -7
  134. package/docs/examples/comp/collapse.vue +38 -38
  135. package/docs/examples/comp/tabs.vue +38 -38
  136. package/docs/examples/count/basic.vue +54 -54
  137. package/docs/examples/count-up/basic.vue +89 -89
  138. package/docs/examples/data-panel/basic.vue +110 -110
  139. package/docs/examples/dialog/basic.vue +36 -36
  140. package/docs/examples/dialog/custom-buttons.vue +44 -44
  141. package/docs/examples/dialog/fullscreen.vue +23 -23
  142. package/docs/examples/dialog/no-mask.vue +17 -17
  143. package/docs/examples/dialog/size.vue +44 -44
  144. package/docs/examples/dialog/steps.vue +57 -57
  145. package/docs/examples/dialog-full/basic.vue +29 -29
  146. package/docs/examples/dialog-full/custom-buttons.vue +45 -45
  147. package/docs/examples/dialog-full/no-buttons.vue +18 -18
  148. package/docs/examples/dialog-full/no-header.vue +27 -27
  149. package/docs/examples/dialog-full/steps.vue +71 -71
  150. package/docs/examples/divider/basic.vue +52 -52
  151. package/docs/examples/drawer/basic.vue +35 -35
  152. package/docs/examples/drawer/custom-buttons.vue +34 -34
  153. package/docs/examples/drawer/direction.vue +47 -47
  154. package/docs/examples/drawer/mask.vue +36 -36
  155. package/docs/examples/drawer/no-buttons.vue +20 -20
  156. package/docs/examples/drawer/size.vue +28 -28
  157. package/docs/examples/dynamic-layer/basic.vue +33 -33
  158. package/docs/examples/dynamic-layer/custom-buttons.vue +43 -43
  159. package/docs/examples/dynamic-layer/form.vue +73 -73
  160. package/docs/examples/dynamic-layer/steps.vue +52 -52
  161. package/docs/examples/dynamic-layer/types.vue +40 -40
  162. package/docs/examples/echarts/basic.vue +31 -31
  163. package/docs/examples/echarts/dynamic.vue +43 -43
  164. package/docs/examples/echarts/line.vue +46 -46
  165. package/docs/examples/echarts/pie.vue +44 -44
  166. package/docs/examples/editor/basic.vue +15 -15
  167. package/docs/examples/form/basic.vue +224 -224
  168. package/docs/examples/guid/basic.vue +10 -10
  169. package/docs/examples/guid/size.vue +13 -13
  170. package/docs/examples/hpanel/basic.vue +79 -79
  171. package/docs/examples/icon/basic.vue +9 -9
  172. package/docs/examples/icon/rotate-flip.vue +9 -9
  173. package/docs/examples/icon/size.vue +7 -7
  174. package/docs/examples/input/basic.vue +10 -10
  175. package/docs/examples/input/clearable.vue +12 -12
  176. package/docs/examples/input/disabled.vue +6 -6
  177. package/docs/examples/input/icon.vue +23 -23
  178. package/docs/examples/input/password.vue +18 -18
  179. package/docs/examples/input/size.vue +13 -13
  180. package/docs/examples/input/textarea.vue +25 -25
  181. package/docs/examples/input/word-limit.vue +28 -28
  182. package/docs/examples/input-button/basic.vue +33 -33
  183. package/docs/examples/input-code/basic.vue +29 -29
  184. package/docs/examples/input-color/basic.vue +10 -10
  185. package/docs/examples/input-color/disabled.vue +13 -13
  186. package/docs/examples/input-color/format.vue +17 -17
  187. package/docs/examples/input-color/no-alpha.vue +13 -13
  188. package/docs/examples/input-color/only-button.vue +15 -15
  189. package/docs/examples/input-color/predefine.vue +31 -31
  190. package/docs/examples/input-color/size.vue +15 -15
  191. package/docs/examples/input-layer/basic.vue +69 -69
  192. package/docs/examples/input-rows/basic.vue +73 -73
  193. package/docs/examples/input-rows/drag.vue +48 -48
  194. package/docs/examples/input-rows/layer-form.vue +85 -85
  195. package/docs/examples/input-rows/nested.vue +91 -91
  196. package/docs/examples/input-tag/basic.vue +27 -27
  197. package/docs/examples/input-tag/colors.vue +23 -23
  198. package/docs/examples/input-tag/readonly.vue +17 -17
  199. package/docs/examples/layer/basic.vue +43 -43
  200. package/docs/examples/layer/custom-buttons.vue +61 -61
  201. package/docs/examples/layer/drawer.vue +37 -37
  202. package/docs/examples/layer/full.vue +38 -38
  203. package/docs/examples/layer/modal.vue +34 -34
  204. package/docs/examples/layer/steps.vue +46 -46
  205. package/docs/examples/layer-form/basic.vue +76 -76
  206. package/docs/examples/layer-form/config.vue +82 -82
  207. package/docs/examples/layer-form/size.vue +72 -72
  208. package/docs/examples/layout/basic.vue +36 -36
  209. package/docs/examples/layout/custom-size.vue +50 -50
  210. package/docs/examples/layout/disable-move.vue +37 -37
  211. package/docs/examples/layout/hide-mid-when-narrow.vue +96 -96
  212. package/docs/examples/layout/min-size.vue +73 -73
  213. package/docs/examples/layout/percent-size.vue +80 -80
  214. package/docs/examples/layout/simple.vue +22 -22
  215. package/docs/examples/layout/top-side.vue +34 -34
  216. package/docs/examples/map/basic.vue +22 -22
  217. package/docs/examples/menu/basic.vue +58 -58
  218. package/docs/examples/menu/collapsed.vue +49 -49
  219. package/docs/examples/menu/horizontal.vue +44 -44
  220. package/docs/examples/menu/selection-test.vue +104 -104
  221. package/docs/examples/menu/theme.vue +46 -46
  222. package/docs/examples/menu/vertical.vue +46 -46
  223. package/docs/examples/number/advanced.vue +143 -143
  224. package/docs/examples/number/basic.vue +63 -63
  225. package/docs/examples/number/disabled.vue +49 -49
  226. package/docs/examples/number/size.vue +42 -42
  227. package/docs/examples/number/slots.vue +123 -123
  228. package/docs/examples/number/step-strictly.vue +41 -41
  229. package/docs/examples/number/step.vue +47 -47
  230. package/docs/examples/page/basic.vue +41 -41
  231. package/docs/examples/page/init.vue +87 -87
  232. package/docs/examples/panel/basic.vue +8 -0
  233. package/docs/examples/panel/tool-buttons.vue +18 -0
  234. package/docs/examples/radio/basic.vue +17 -17
  235. package/docs/examples/radio/button.vue +17 -17
  236. package/docs/examples/radio/color.vue +18 -18
  237. package/docs/examples/radio/disabled.vue +17 -17
  238. package/docs/examples/radio/size.vue +29 -29
  239. package/docs/examples/rate/basic.vue +24 -24
  240. package/docs/examples/rate/half.vue +24 -24
  241. package/docs/examples/rate/readonly.vue +11 -11
  242. package/docs/examples/rate/text.vue +32 -32
  243. package/docs/examples/select/basic.vue +16 -16
  244. package/docs/examples/select/clearable.vue +22 -22
  245. package/docs/examples/select/disabled.vue +31 -31
  246. package/docs/examples/select/filterable.vue +24 -24
  247. package/docs/examples/select/group.vue +23 -23
  248. package/docs/examples/select/icon.vue +16 -16
  249. package/docs/examples/select/multiple.vue +18 -18
  250. package/docs/examples/select/size.vue +39 -39
  251. package/docs/examples/slider/basic.vue +42 -42
  252. package/docs/examples/slider/disabled.vue +17 -17
  253. package/docs/examples/slider/marks.vue +30 -30
  254. package/docs/examples/slider/size.vue +37 -37
  255. package/docs/examples/slider/tooltip.vue +36 -36
  256. package/docs/examples/slider/vertical.vue +26 -26
  257. package/docs/examples/slider-captcha/basic.vue +44 -44
  258. package/docs/examples/slider-captcha/custom.vue +48 -48
  259. package/docs/examples/switch/basic.vue +16 -16
  260. package/docs/examples/switch/disabled.vue +13 -13
  261. package/docs/examples/switch/loading.vue +13 -13
  262. package/docs/examples/switch/size.vue +15 -15
  263. package/docs/examples/switch/text.vue +13 -13
  264. package/docs/examples/table/actions.vue +116 -116
  265. package/docs/examples/table/add-row.vue +103 -103
  266. package/docs/examples/table/basic.vue +168 -168
  267. package/docs/examples/table/editable.vue +261 -261
  268. package/docs/examples/table/field-selection.vue +87 -87
  269. package/docs/examples/table/frozen-column.vue +140 -140
  270. package/docs/examples/table/height-mode.vue +99 -99
  271. package/docs/examples/table/multiple.vue +178 -178
  272. package/docs/examples/table/pagination.vue +151 -151
  273. package/docs/examples/table/single-selection.vue +64 -64
  274. package/docs/examples/table/tree-column.vue +119 -119
  275. package/docs/examples/table/tree-data.vue +141 -141
  276. package/docs/examples/table-panel/basic.vue +228 -228
  277. package/docs/examples/table-panel/batch-operations.vue +285 -285
  278. package/docs/examples/table-panel/filter.vue +209 -209
  279. package/docs/examples/table-panel/multiple-selection.vue +243 -243
  280. package/docs/examples/table-panel/pagination.vue +133 -133
  281. package/docs/examples/tabs/basic.vue +98 -98
  282. package/docs/examples/title/basic.vue +80 -80
  283. package/docs/examples/tree/accordion.vue +46 -46
  284. package/docs/examples/tree/basic.vue +50 -50
  285. package/docs/examples/tree/buttons.vue +53 -53
  286. package/docs/examples/tree/checkable.vue +52 -52
  287. package/docs/examples/tree/custom-keys.vue +39 -39
  288. package/docs/examples/tree/default-expanded.vue +52 -52
  289. package/docs/examples/tree/draggable.vue +29 -29
  290. package/docs/examples/tree/expand-on-click.vue +39 -39
  291. package/docs/examples/tree/flat-data.vue +20 -20
  292. package/docs/examples/tree/icon.vue +40 -40
  293. package/docs/examples/tree/load-data.vue +37 -37
  294. package/docs/examples/tree/methods.vue +74 -74
  295. package/docs/examples/tree/theme.vue +33 -33
  296. package/docs/examples/upload/accept.vue +31 -31
  297. package/docs/examples/upload/basic.vue +12 -12
  298. package/docs/examples/upload/drag.vue +11 -11
  299. package/docs/examples/upload/image.vue +17 -17
  300. package/docs/examples/upload/limit.vue +20 -20
  301. package/docs/examples/upload/multiple.vue +17 -17
  302. package/docs/examples/upload/readonly.vue +17 -17
  303. package/docs/examples/utils/cipher.vue +160 -160
  304. package/docs/examples/utils/common.vue +153 -153
  305. package/docs/examples/utils/date.vue +56 -56
  306. package/docs/examples/utils/dom.vue +52 -52
  307. package/docs/examples/utils/is.vue +70 -70
  308. package/docs/examples/workflow/basic.vue +265 -265
  309. package/docs/examples/workflow-viewer/basic.vue +248 -248
  310. package/package.json +23 -23
@@ -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>
@@ -1,33 +1,33 @@
1
- <template>
2
- <div>
3
- <j-button label="打开动态组件" @click="openLayer" />
4
- <j-dynamic-layer ref="layerRef" />
5
- </div>
6
- </template>
7
-
8
- <script setup lang="ts">
9
- import { ref, h } from 'vue'
10
-
11
- const layerRef = ref()
12
-
13
- // 动态组件示例
14
- const DemoComponent = {
15
- setup() {
16
- return () =>
17
- h('div', { style: 'padding: 16px' }, [
18
- h('p', '这是一个动态加载的组件'),
19
- h('p', '可以是任何 Vue 组件'),
20
- ])
21
- },
22
- }
23
-
24
- const openLayer = () => {
25
- layerRef.value.open({
26
- title: '动态组件示例',
27
- name: DemoComponent,
28
- type: 'modal',
29
- width: 600,
30
- height: 400,
31
- })
32
- }
33
- </script>
1
+ <template>
2
+ <div>
3
+ <j-button label="打开动态组件" @click="openLayer" />
4
+ <j-dynamic-layer ref="layerRef" />
5
+ </div>
6
+ </template>
7
+
8
+ <script setup lang="ts">
9
+ import { ref, h } from 'vue'
10
+
11
+ const layerRef = ref()
12
+
13
+ // 动态组件示例
14
+ const DemoComponent = {
15
+ setup() {
16
+ return () =>
17
+ h('div', { style: 'padding: 16px' }, [
18
+ h('p', '这是一个动态加载的组件'),
19
+ h('p', '可以是任何 Vue 组件'),
20
+ ])
21
+ },
22
+ }
23
+
24
+ const openLayer = () => {
25
+ layerRef.value.open({
26
+ title: '动态组件示例',
27
+ name: DemoComponent,
28
+ type: 'modal',
29
+ width: 600,
30
+ height: 400,
31
+ })
32
+ }
33
+ </script>
@@ -1,43 +1,43 @@
1
- <template>
2
- <div>
3
- <j-button label="自定义按钮" @click="openLayer" />
4
- <j-dynamic-layer ref="layerRef" />
5
- </div>
6
- </template>
7
-
8
- <script setup lang="ts">
9
- import { ref, h } from 'vue'
10
-
11
- const layerRef = ref()
12
-
13
- const CustomComponent = {
14
- setup(props: any, { expose }: any) {
15
- const getConfig = () => {
16
- return {
17
- buttons: [
18
- {
19
- label: '自定义操作',
20
- type: 'primary',
21
- onClick: () => {
22
- alert('执行自定义操作')
23
- },
24
- },
25
- ],
26
- }
27
- }
28
-
29
- expose({ getConfig })
30
-
31
- return () => h('div', { style: 'padding: 16px' }, [h('p', '这个弹层有自定义按钮')])
32
- },
33
- }
34
-
35
- const openLayer = () => {
36
- layerRef.value.open({
37
- title: '自定义按钮示例',
38
- name: CustomComponent,
39
- type: 'modal',
40
- hasSaveBtn: false,
41
- })
42
- }
43
- </script>
1
+ <template>
2
+ <div>
3
+ <j-button label="自定义按钮" @click="openLayer" />
4
+ <j-dynamic-layer ref="layerRef" />
5
+ </div>
6
+ </template>
7
+
8
+ <script setup lang="ts">
9
+ import { ref, h } from 'vue'
10
+
11
+ const layerRef = ref()
12
+
13
+ const CustomComponent = {
14
+ setup(props: any, { expose }: any) {
15
+ const getConfig = () => {
16
+ return {
17
+ buttons: [
18
+ {
19
+ label: '自定义操作',
20
+ type: 'primary',
21
+ onClick: () => {
22
+ alert('执行自定义操作')
23
+ },
24
+ },
25
+ ],
26
+ }
27
+ }
28
+
29
+ expose({ getConfig })
30
+
31
+ return () => h('div', { style: 'padding: 16px' }, [h('p', '这个弹层有自定义按钮')])
32
+ },
33
+ }
34
+
35
+ const openLayer = () => {
36
+ layerRef.value.open({
37
+ title: '自定义按钮示例',
38
+ name: CustomComponent,
39
+ type: 'modal',
40
+ hasSaveBtn: false,
41
+ })
42
+ }
43
+ </script>