@a2simcode/ui 0.0.178 → 0.0.179

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 (349) 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/components/dialog-full/index.d.ts +15 -0
  6. package/dist/components/dialog-full/src/index.vue.d.ts +17 -0
  7. package/dist/components/layer/src/layer.vue.d.ts +2 -2
  8. package/dist/simcode-ui.es.js +19 -5
  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/date.md +76 -76
  26. package/docs/components/dialog-full.md +112 -112
  27. package/docs/components/dialog.md +127 -127
  28. package/docs/components/divider.md +24 -24
  29. package/docs/components/drawer.md +127 -127
  30. package/docs/components/dynamic-layer.md +118 -118
  31. package/docs/components/echarts.md +72 -72
  32. package/docs/components/editor.md +24 -24
  33. package/docs/components/form.md +72 -72
  34. package/docs/components/guid.md +39 -39
  35. package/docs/components/hpanel.md +24 -24
  36. package/docs/components/icon.md +56 -56
  37. package/docs/components/input-button.md +24 -24
  38. package/docs/components/input-code.md +24 -24
  39. package/docs/components/input-color.md +114 -114
  40. package/docs/components/input-layer.md +26 -26
  41. package/docs/components/input-rows.md +370 -370
  42. package/docs/components/input-tag.md +50 -50
  43. package/docs/components/input.md +129 -129
  44. package/docs/components/layer-form.md +61 -61
  45. package/docs/components/layer.md +127 -127
  46. package/docs/components/layout.md +132 -132
  47. package/docs/components/map.md +24 -24
  48. package/docs/components/menu.md +121 -121
  49. package/docs/components/meta/button.ts +212 -212
  50. package/docs/components/meta/buttons.ts +76 -76
  51. package/docs/components/meta/code-mirror.ts +108 -108
  52. package/docs/components/meta/comp.ts +236 -236
  53. package/docs/components/meta/date.ts +267 -267
  54. package/docs/components/meta/dialog-full.ts +6 -0
  55. package/docs/components/meta/echarts.ts +64 -64
  56. package/docs/components/meta/form-item.ts +50 -50
  57. package/docs/components/meta/form.ts +181 -181
  58. package/docs/components/meta/input-button.ts +165 -165
  59. package/docs/components/meta/input-cards.ts +112 -112
  60. package/docs/components/meta/input-code.ts +151 -151
  61. package/docs/components/meta/input-color.ts +243 -243
  62. package/docs/components/meta/input-layer.ts +366 -366
  63. package/docs/components/meta/input-rows.ts +119 -119
  64. package/docs/components/meta/layer-form.ts +56 -56
  65. package/docs/components/meta/layer.ts +1 -1
  66. package/docs/components/meta/map.ts +68 -68
  67. package/docs/components/meta/panel.ts +152 -152
  68. package/docs/components/meta/slider.ts +270 -270
  69. package/docs/components/meta/table-panel.ts +232 -232
  70. package/docs/components/meta/table.ts +391 -391
  71. package/docs/components/meta/tabs.ts +146 -146
  72. package/docs/components/meta/title.ts +91 -91
  73. package/docs/components/meta/tree-select.ts +199 -199
  74. package/docs/components/meta/tree.ts +219 -219
  75. package/docs/components/meta/vpanel.ts +19 -19
  76. package/docs/components/meta/workflow-viewer.ts +55 -55
  77. package/docs/components/number.md +124 -124
  78. package/docs/components/page.md +102 -102
  79. package/docs/components/panel.md +37 -37
  80. package/docs/components/radio.md +87 -87
  81. package/docs/components/rate.md +71 -71
  82. package/docs/components/select.md +133 -133
  83. package/docs/components/slider-captcha.md +41 -41
  84. package/docs/components/slider.md +101 -101
  85. package/docs/components/switch.md +90 -90
  86. package/docs/components/table-panel.md +236 -236
  87. package/docs/components/table.md +391 -391
  88. package/docs/components/tabs.md +26 -26
  89. package/docs/components/title.md +24 -24
  90. package/docs/components/tree.md +207 -207
  91. package/docs/components/upload.md +117 -117
  92. package/docs/components/workflow-viewer.md +21 -21
  93. package/docs/components/workflow.md +21 -21
  94. package/docs/examples/autocomplete/advanced.vue +35 -35
  95. package/docs/examples/autocomplete/basic.vue +32 -32
  96. package/docs/examples/autocomplete/clearable.vue +33 -33
  97. package/docs/examples/autocomplete/custom-template.vue +49 -49
  98. package/docs/examples/autocomplete/disabled.vue +33 -33
  99. package/docs/examples/autocomplete/icon.vue +37 -37
  100. package/docs/examples/barcode/all-types.vue +380 -380
  101. package/docs/examples/barcode/basic.vue +14 -14
  102. package/docs/examples/barcode/props-appearance.vue +243 -243
  103. package/docs/examples/barcode/props-geometry.vue +143 -143
  104. package/docs/examples/barcode/props-logic.vue +216 -216
  105. package/docs/examples/barcode/props-symbology.vue +199 -199
  106. package/docs/examples/barcode/props-text.vue +268 -268
  107. package/docs/examples/button/basic.vue +7 -7
  108. package/docs/examples/button/danger-ghost.vue +17 -17
  109. package/docs/examples/button/disabled.vue +10 -10
  110. package/docs/examples/button/loading.vue +6 -6
  111. package/docs/examples/button/shape.vue +7 -7
  112. package/docs/examples/button/size.vue +14 -14
  113. package/docs/examples/button/type.vue +10 -10
  114. package/docs/examples/button-select/basic.vue +19 -19
  115. package/docs/examples/buttons/basic.vue +45 -45
  116. package/docs/examples/buttons/disabled.vue +36 -36
  117. package/docs/examples/buttons/dropdown.vue +63 -63
  118. package/docs/examples/buttons/group.vue +52 -52
  119. package/docs/examples/buttons/link.vue +47 -47
  120. package/docs/examples/buttons/popup.vue +39 -39
  121. package/docs/examples/buttons/size.vue +45 -45
  122. package/docs/examples/cascader-select/basic.vue +28 -28
  123. package/docs/examples/cascader-select/clearable.vue +34 -34
  124. package/docs/examples/cascader-select/disabled.vue +43 -43
  125. package/docs/examples/cascader-select/filterable.vue +37 -37
  126. package/docs/examples/cascader-select/methods.vue +84 -84
  127. package/docs/examples/cascader-select/multiple.vue +38 -38
  128. package/docs/examples/cascader-select/slot.vue +45 -45
  129. package/docs/examples/checkbox/basic.vue +18 -18
  130. package/docs/examples/checkbox/button.vue +19 -19
  131. package/docs/examples/checkbox/color.vue +25 -25
  132. package/docs/examples/checkbox/disabled.vue +17 -17
  133. package/docs/examples/checkbox/min-max.vue +20 -20
  134. package/docs/examples/checkbox/mixed.vue +56 -56
  135. package/docs/examples/checkbox/size.vue +28 -28
  136. package/docs/examples/code-mirror/basic.vue +11 -11
  137. package/docs/examples/code-mirror/events.vue +42 -42
  138. package/docs/examples/code-mirror/height.vue +25 -25
  139. package/docs/examples/code-mirror/mode.vue +33 -33
  140. package/docs/examples/code-mirror/readonly.vue +14 -14
  141. package/docs/examples/collapse/basic.vue +82 -82
  142. package/docs/examples/comp/basic.vue +7 -7
  143. package/docs/examples/comp/collapse.vue +38 -38
  144. package/docs/examples/comp/tabs.vue +38 -38
  145. package/docs/examples/count/basic.vue +101 -101
  146. package/docs/examples/count-up/basic.vue +89 -89
  147. package/docs/examples/data-panel/basic.vue +110 -110
  148. package/docs/examples/date/basic.vue +73 -73
  149. package/docs/examples/date/default-value.vue +59 -59
  150. package/docs/examples/date/format.vue +75 -75
  151. package/docs/examples/date/range.vue +66 -66
  152. package/docs/examples/date/types.vue +79 -79
  153. package/docs/examples/decorated-title/basic.vue +31 -31
  154. package/docs/examples/dialog/basic.vue +36 -36
  155. package/docs/examples/dialog/custom-buttons.vue +44 -44
  156. package/docs/examples/dialog/fullscreen.vue +23 -23
  157. package/docs/examples/dialog/no-mask.vue +17 -17
  158. package/docs/examples/dialog/size.vue +44 -44
  159. package/docs/examples/dialog/steps.vue +57 -57
  160. package/docs/examples/dialog-full/basic.vue +29 -29
  161. package/docs/examples/dialog-full/custom-buttons.vue +45 -45
  162. package/docs/examples/dialog-full/no-buttons.vue +18 -18
  163. package/docs/examples/dialog-full/no-header.vue +27 -27
  164. package/docs/examples/dialog-full/steps.vue +71 -71
  165. package/docs/examples/divider/basic.vue +52 -52
  166. package/docs/examples/drawer/basic.vue +35 -35
  167. package/docs/examples/drawer/custom-buttons.vue +34 -34
  168. package/docs/examples/drawer/direction.vue +47 -47
  169. package/docs/examples/drawer/mask.vue +36 -36
  170. package/docs/examples/drawer/no-buttons.vue +20 -20
  171. package/docs/examples/drawer/size.vue +28 -28
  172. package/docs/examples/dynamic-layer/basic.vue +33 -33
  173. package/docs/examples/dynamic-layer/custom-buttons.vue +43 -43
  174. package/docs/examples/dynamic-layer/form.vue +73 -73
  175. package/docs/examples/dynamic-layer/steps.vue +52 -52
  176. package/docs/examples/dynamic-layer/types.vue +40 -40
  177. package/docs/examples/echarts/basic.vue +31 -31
  178. package/docs/examples/echarts/dynamic.vue +43 -43
  179. package/docs/examples/echarts/line.vue +46 -46
  180. package/docs/examples/echarts/pie.vue +44 -44
  181. package/docs/examples/editor/basic.vue +15 -15
  182. package/docs/examples/form/basic.vue +665 -665
  183. package/docs/examples/form/init.vue +76 -76
  184. package/docs/examples/form/master-detail.vue +203 -203
  185. package/docs/examples/form/rule-format.vue +179 -179
  186. package/docs/examples/guid/basic.vue +10 -10
  187. package/docs/examples/guid/size.vue +13 -13
  188. package/docs/examples/hpanel/basic.vue +79 -79
  189. package/docs/examples/icon/basic.vue +9 -9
  190. package/docs/examples/icon/rotate-flip.vue +9 -9
  191. package/docs/examples/icon/size.vue +7 -7
  192. package/docs/examples/input/basic.vue +10 -10
  193. package/docs/examples/input/clearable.vue +12 -12
  194. package/docs/examples/input/disabled.vue +6 -6
  195. package/docs/examples/input/icon.vue +23 -23
  196. package/docs/examples/input/password.vue +18 -18
  197. package/docs/examples/input/size.vue +13 -13
  198. package/docs/examples/input/textarea.vue +25 -25
  199. package/docs/examples/input/word-limit.vue +28 -28
  200. package/docs/examples/input-button/basic.vue +33 -33
  201. package/docs/examples/input-code/basic.vue +29 -29
  202. package/docs/examples/input-color/basic.vue +10 -10
  203. package/docs/examples/input-color/disabled.vue +13 -13
  204. package/docs/examples/input-color/format.vue +17 -17
  205. package/docs/examples/input-color/no-alpha.vue +13 -13
  206. package/docs/examples/input-color/only-button.vue +15 -15
  207. package/docs/examples/input-color/predefine.vue +31 -31
  208. package/docs/examples/input-color/size.vue +15 -15
  209. package/docs/examples/input-layer/basic.vue +86 -86
  210. package/docs/examples/input-rows/basic.vue +73 -73
  211. package/docs/examples/input-rows/drag.vue +48 -48
  212. package/docs/examples/input-rows/layer-form.vue +85 -85
  213. package/docs/examples/input-rows/nested.vue +91 -91
  214. package/docs/examples/input-tag/basic.vue +27 -27
  215. package/docs/examples/input-tag/colors.vue +23 -23
  216. package/docs/examples/input-tag/readonly.vue +17 -17
  217. package/docs/examples/layer/basic.vue +43 -43
  218. package/docs/examples/layer/custom-buttons.vue +61 -61
  219. package/docs/examples/layer/drawer.vue +37 -37
  220. package/docs/examples/layer/full.vue +38 -38
  221. package/docs/examples/layer/modal.vue +34 -34
  222. package/docs/examples/layer/steps.vue +46 -46
  223. package/docs/examples/layer-form/basic.vue +76 -76
  224. package/docs/examples/layer-form/config.vue +82 -82
  225. package/docs/examples/layer-form/size.vue +72 -72
  226. package/docs/examples/layout/basic.vue +36 -36
  227. package/docs/examples/layout/custom-size.vue +50 -50
  228. package/docs/examples/layout/disable-move.vue +37 -37
  229. package/docs/examples/layout/hide-mid-when-narrow.vue +96 -96
  230. package/docs/examples/layout/min-size.vue +73 -73
  231. package/docs/examples/layout/percent-size.vue +80 -80
  232. package/docs/examples/layout/simple.vue +22 -22
  233. package/docs/examples/layout/top-side.vue +34 -34
  234. package/docs/examples/map/basic.vue +22 -22
  235. package/docs/examples/menu/basic.vue +58 -58
  236. package/docs/examples/menu/collapsed.vue +49 -49
  237. package/docs/examples/menu/horizontal.vue +44 -44
  238. package/docs/examples/menu/selection-test.vue +104 -104
  239. package/docs/examples/menu/theme.vue +46 -46
  240. package/docs/examples/menu/vertical.vue +46 -46
  241. package/docs/examples/number/advanced.vue +143 -143
  242. package/docs/examples/number/basic.vue +63 -63
  243. package/docs/examples/number/disabled.vue +49 -49
  244. package/docs/examples/number/size.vue +42 -42
  245. package/docs/examples/number/slots.vue +123 -123
  246. package/docs/examples/number/step-strictly.vue +41 -41
  247. package/docs/examples/number/step.vue +47 -47
  248. package/docs/examples/page/basic.vue +41 -41
  249. package/docs/examples/page/code-table-model.vue +428 -428
  250. package/docs/examples/page/dept-user-management.vue +211 -211
  251. package/docs/examples/page/init.vue +87 -87
  252. package/docs/examples/page/log.vue +453 -453
  253. package/docs/examples/page/user-management.vue +313 -313
  254. package/docs/examples/panel/tool-buttons.vue +18 -18
  255. package/docs/examples/radio/basic.vue +17 -17
  256. package/docs/examples/radio/button.vue +17 -17
  257. package/docs/examples/radio/color.vue +18 -18
  258. package/docs/examples/radio/disabled.vue +17 -17
  259. package/docs/examples/radio/size.vue +29 -29
  260. package/docs/examples/rate/basic.vue +24 -24
  261. package/docs/examples/rate/half.vue +24 -24
  262. package/docs/examples/rate/readonly.vue +11 -11
  263. package/docs/examples/rate/text.vue +37 -37
  264. package/docs/examples/select/basic.vue +16 -16
  265. package/docs/examples/select/clearable.vue +22 -22
  266. package/docs/examples/select/disabled.vue +31 -31
  267. package/docs/examples/select/filterable.vue +24 -24
  268. package/docs/examples/select/group.vue +23 -23
  269. package/docs/examples/select/icon.vue +16 -16
  270. package/docs/examples/select/multiple.vue +18 -18
  271. package/docs/examples/select/size.vue +39 -39
  272. package/docs/examples/slider/basic.vue +42 -42
  273. package/docs/examples/slider/disabled.vue +17 -17
  274. package/docs/examples/slider/marks.vue +30 -30
  275. package/docs/examples/slider/size.vue +37 -37
  276. package/docs/examples/slider/tooltip.vue +36 -36
  277. package/docs/examples/slider/vertical.vue +26 -26
  278. package/docs/examples/slider-captcha/basic.vue +44 -44
  279. package/docs/examples/slider-captcha/custom.vue +48 -48
  280. package/docs/examples/switch/basic.vue +16 -16
  281. package/docs/examples/switch/disabled.vue +13 -13
  282. package/docs/examples/switch/loading.vue +13 -13
  283. package/docs/examples/switch/size.vue +15 -15
  284. package/docs/examples/switch/text.vue +13 -13
  285. package/docs/examples/table/action-filter.vue +126 -126
  286. package/docs/examples/table/actions.vue +116 -116
  287. package/docs/examples/table/add-row.vue +103 -103
  288. package/docs/examples/table/basic.vue +168 -168
  289. package/docs/examples/table/checkbox-layout.vue +68 -68
  290. package/docs/examples/table/custom-layout.vue +115 -115
  291. package/docs/examples/table/dynamic-type.vue +73 -73
  292. package/docs/examples/table/editable.vue +262 -262
  293. package/docs/examples/table/field-selection.vue +87 -87
  294. package/docs/examples/table/frozen-column.vue +140 -140
  295. package/docs/examples/table/height-mode.vue +99 -99
  296. package/docs/examples/table/icon.vue +85 -85
  297. package/docs/examples/table/link.vue +66 -66
  298. package/docs/examples/table/multiple.vue +188 -188
  299. package/docs/examples/table/pagination.vue +151 -151
  300. package/docs/examples/table/single-selection.vue +64 -64
  301. package/docs/examples/table/sub-table-lazy.vue +97 -97
  302. package/docs/examples/table/sub-table.vue +103 -103
  303. package/docs/examples/table/tag.vue +43 -43
  304. package/docs/examples/table/tree-column.vue +119 -119
  305. package/docs/examples/table/tree-data.vue +141 -141
  306. package/docs/examples/table/tree-default-expand-all.vue +60 -60
  307. package/docs/examples/table/tree-lazy.vue +80 -80
  308. package/docs/examples/table/tree-set-selection.vue +75 -75
  309. package/docs/examples/table-panel/basic.vue +229 -229
  310. package/docs/examples/table-panel/batch-operations.vue +285 -285
  311. package/docs/examples/table-panel/button-visibility.vue +88 -88
  312. package/docs/examples/table-panel/filter.vue +219 -219
  313. package/docs/examples/table-panel/get-selection.vue +111 -111
  314. package/docs/examples/table-panel/multiple-selection.vue +243 -243
  315. package/docs/examples/table-panel/pagination.vue +133 -133
  316. package/docs/examples/table-panel/sub-table-lazy.vue +118 -118
  317. package/docs/examples/table-panel/tree-parent-key.vue +67 -67
  318. package/docs/examples/tabs/basic.vue +98 -98
  319. package/docs/examples/time/base.vue +67 -67
  320. package/docs/examples/title/basic.vue +87 -87
  321. package/docs/examples/tree/accordion.vue +46 -46
  322. package/docs/examples/tree/basic.vue +50 -50
  323. package/docs/examples/tree/buttons.vue +53 -53
  324. package/docs/examples/tree/checkable.vue +52 -52
  325. package/docs/examples/tree/custom-keys.vue +39 -39
  326. package/docs/examples/tree/default-expanded.vue +52 -52
  327. package/docs/examples/tree/draggable.vue +29 -29
  328. package/docs/examples/tree/expand-on-click.vue +39 -39
  329. package/docs/examples/tree/flat-data.vue +20 -20
  330. package/docs/examples/tree/icon.vue +40 -40
  331. package/docs/examples/tree/load-data.vue +37 -37
  332. package/docs/examples/tree/methods.vue +74 -74
  333. package/docs/examples/tree/theme.vue +33 -33
  334. package/docs/examples/tree-select/basic.vue +47 -47
  335. package/docs/examples/upload/accept.vue +31 -31
  336. package/docs/examples/upload/basic.vue +12 -12
  337. package/docs/examples/upload/drag.vue +11 -11
  338. package/docs/examples/upload/image.vue +17 -17
  339. package/docs/examples/upload/limit.vue +20 -20
  340. package/docs/examples/upload/multiple.vue +17 -17
  341. package/docs/examples/upload/readonly.vue +17 -17
  342. package/docs/examples/utils/cipher.vue +160 -160
  343. package/docs/examples/utils/common.vue +153 -153
  344. package/docs/examples/utils/date.vue +56 -56
  345. package/docs/examples/utils/dom.vue +52 -52
  346. package/docs/examples/utils/is.vue +70 -70
  347. package/docs/examples/workflow/basic.vue +265 -265
  348. package/docs/examples/workflow-viewer/basic.vue +248 -248
  349. package/package.json +23 -23
@@ -1,38 +1,38 @@
1
- <template>
2
- <div>
3
- <j-button label="打开全屏" @click="openLayer" />
4
- <j-layer ref="layerRef" @ok="handleOk" @cancel="handleCancel">
5
- <div style="padding: 16px">
6
- <h3>全屏模式示例</h3>
7
- <p>全屏模式会占据整个浏览器窗口。</p>
8
- <p>适用于需要大量展示内容的场景。</p>
9
- <div style="margin-top: 20px">
10
- <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit.</p>
11
- <p>Sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.</p>
12
- </div>
13
- </div>
14
- </j-layer>
15
- </div>
16
- </template>
17
-
18
- <script setup lang="ts">
19
- import { ref } from 'vue'
20
-
21
- const layerRef = ref()
22
-
23
- const openLayer = () => {
24
- layerRef.value.open('全屏示例', 'full')
25
- }
26
-
27
- const handleOk = (showLoading: any, hideLoading: any) => {
28
- showLoading('保存中...')
29
- setTimeout(() => {
30
- hideLoading()
31
- layerRef.value.close()
32
- }, 1500)
33
- }
34
-
35
- const handleCancel = () => {
36
- layerRef.value.close()
37
- }
38
- </script>
1
+ <template>
2
+ <div>
3
+ <j-button label="打开全屏" @click="openLayer" />
4
+ <j-layer ref="layerRef" @ok="handleOk" @cancel="handleCancel">
5
+ <div style="padding: 16px">
6
+ <h3>全屏模式示例</h3>
7
+ <p>全屏模式会占据整个浏览器窗口。</p>
8
+ <p>适用于需要大量展示内容的场景。</p>
9
+ <div style="margin-top: 20px">
10
+ <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit.</p>
11
+ <p>Sed do eiusmod tempor incididunt ut labore et dolore magna aliqua.</p>
12
+ </div>
13
+ </div>
14
+ </j-layer>
15
+ </div>
16
+ </template>
17
+
18
+ <script setup lang="ts">
19
+ import { ref } from 'vue'
20
+
21
+ const layerRef = ref()
22
+
23
+ const openLayer = () => {
24
+ layerRef.value.open('全屏示例', 'full')
25
+ }
26
+
27
+ const handleOk = (showLoading: any, hideLoading: any) => {
28
+ showLoading('保存中...')
29
+ setTimeout(() => {
30
+ hideLoading()
31
+ layerRef.value.close()
32
+ }, 1500)
33
+ }
34
+
35
+ const handleCancel = () => {
36
+ layerRef.value.close()
37
+ }
38
+ </script>
@@ -1,34 +1,34 @@
1
- <template>
2
- <div>
3
- <j-button label="打开弹窗" @click="openLayer" />
4
- <j-layer ref="layerRef" :width="800" :height="500" @ok="handleOk" @cancel="handleCancel">
5
- <div style="padding: 16px">
6
- <p>这是弹窗模式的示例。</p>
7
- <p>可以通过 width 和 height 属性设置弹窗大小。</p>
8
- <p>弹窗支持拖拽和缩放功能。</p>
9
- </div>
10
- </j-layer>
11
- </div>
12
- </template>
13
-
14
- <script setup lang="ts">
15
- import { ref } from 'vue'
16
-
17
- const layerRef = ref()
18
-
19
- const openLayer = () => {
20
- layerRef.value.open('弹窗示例', 'modal')
21
- }
22
-
23
- const handleOk = (showLoading: any, hideLoading: any) => {
24
- showLoading('处理中...')
25
- setTimeout(() => {
26
- hideLoading()
27
- layerRef.value.close()
28
- }, 1000)
29
- }
30
-
31
- const handleCancel = () => {
32
- layerRef.value.close()
33
- }
34
- </script>
1
+ <template>
2
+ <div>
3
+ <j-button label="打开弹窗" @click="openLayer" />
4
+ <j-layer ref="layerRef" :width="800" :height="500" @ok="handleOk" @cancel="handleCancel">
5
+ <div style="padding: 16px">
6
+ <p>这是弹窗模式的示例。</p>
7
+ <p>可以通过 width 和 height 属性设置弹窗大小。</p>
8
+ <p>弹窗支持拖拽和缩放功能。</p>
9
+ </div>
10
+ </j-layer>
11
+ </div>
12
+ </template>
13
+
14
+ <script setup lang="ts">
15
+ import { ref } from 'vue'
16
+
17
+ const layerRef = ref()
18
+
19
+ const openLayer = () => {
20
+ layerRef.value.open('弹窗示例', 'modal')
21
+ }
22
+
23
+ const handleOk = (showLoading: any, hideLoading: any) => {
24
+ showLoading('处理中...')
25
+ setTimeout(() => {
26
+ hideLoading()
27
+ layerRef.value.close()
28
+ }, 1000)
29
+ }
30
+
31
+ const handleCancel = () => {
32
+ layerRef.value.close()
33
+ }
34
+ </script>
@@ -1,46 +1,46 @@
1
- <template>
2
- <div>
3
- <j-button label="打开步骤弹窗" @click="openLayer" />
4
- <j-layer
5
- ref="layerRef"
6
- :is-step="true"
7
- :steps="['基本信息', '详细配置', '确认提交']"
8
- :validate-steps="validateSteps"
9
- @ok="handleOk"
10
- @cancel="handleCancel"
11
- >
12
- <div style="padding: 16px">
13
- <p>这是带步骤条的 Layer 组件示例。</p>
14
- <p>适用于多步骤表单或向导式流程。</p>
15
- <p>可以配置步骤校验函数。</p>
16
- </div>
17
- </j-layer>
18
- </div>
19
- </template>
20
-
21
- <script setup lang="ts">
22
- import { ref } from 'vue'
23
-
24
- const layerRef = ref()
25
-
26
- const openLayer = () => {
27
- layerRef.value.open('步骤弹窗示例', 'modal')
28
- }
29
-
30
- const validateSteps = (step: number) => {
31
- console.log('校验步骤:', step)
32
- return true
33
- }
34
-
35
- const handleOk = (showLoading: any, hideLoading: any) => {
36
- showLoading('提交中...')
37
- setTimeout(() => {
38
- hideLoading()
39
- layerRef.value.close()
40
- }, 1000)
41
- }
42
-
43
- const handleCancel = () => {
44
- layerRef.value.close()
45
- }
46
- </script>
1
+ <template>
2
+ <div>
3
+ <j-button label="打开步骤弹窗" @click="openLayer" />
4
+ <j-layer
5
+ ref="layerRef"
6
+ :is-step="true"
7
+ :steps="['基本信息', '详细配置', '确认提交']"
8
+ :validate-steps="validateSteps"
9
+ @ok="handleOk"
10
+ @cancel="handleCancel"
11
+ >
12
+ <div style="padding: 16px">
13
+ <p>这是带步骤条的 Layer 组件示例。</p>
14
+ <p>适用于多步骤表单或向导式流程。</p>
15
+ <p>可以配置步骤校验函数。</p>
16
+ </div>
17
+ </j-layer>
18
+ </div>
19
+ </template>
20
+
21
+ <script setup lang="ts">
22
+ import { ref } from 'vue'
23
+
24
+ const layerRef = ref()
25
+
26
+ const openLayer = () => {
27
+ layerRef.value.open('步骤弹窗示例', 'modal')
28
+ }
29
+
30
+ const validateSteps = (step: number) => {
31
+ console.log('校验步骤:', step)
32
+ return true
33
+ }
34
+
35
+ const handleOk = (showLoading: any, hideLoading: any) => {
36
+ showLoading('提交中...')
37
+ setTimeout(() => {
38
+ hideLoading()
39
+ layerRef.value.close()
40
+ }, 1000)
41
+ }
42
+
43
+ const handleCancel = () => {
44
+ layerRef.value.close()
45
+ }
46
+ </script>
@@ -1,76 +1,76 @@
1
- <template>
2
- <div>
3
- <!-- j-form 通过 schema 渲染表单字段,j-layer-form 作为 schema 中的一项 -->
4
- <j-form ref="formRef" :schema="schema" :config="formConfig" />
5
-
6
- <div v-if="formData" style="margin-top: 16px">
7
- <h4>表单数据:</h4>
8
- <pre>{{ JSON.stringify(formData, null, 2) }}</pre>
9
- </div>
10
- </div>
11
- </template>
12
-
13
- <script setup lang="ts">
14
- import { ref } from 'vue'
15
- import type { SchemaConfig } from '@simcode/ui'
16
-
17
- const formRef = ref()
18
- const formData = ref<any>(null)
19
-
20
- // j-form 的表单配置
21
- const formConfig = {
22
- labelWidth: 100,
23
- labelPosition: 'right',
24
- size: 'default',
25
- gutter: 16,
26
- span: 24,
27
- }
28
-
29
- // j-form 的 schema,j-layer-form 作为其中的一项
30
- const schema = ref<SchemaConfig[]>([
31
- {
32
- type: 'j-layer-form',
33
- config: {
34
- label: '用户信息',
35
- layerLabel: '用户信息',
36
- layerWidth: 600,
37
- layerHeight: 400,
38
- },
39
- // j-layer-form 弹窗内的表单字段通过 children 配置
40
- children: [
41
- {
42
- id: 'name',
43
- type: 'j-input',
44
- config: {
45
- label: '姓名',
46
- field: 'name',
47
- placeholder: '请输入姓名',
48
- defaultValue: '',
49
- },
50
- },
51
- {
52
- id: 'age',
53
- type: 'j-number',
54
- config: {
55
- label: '年龄',
56
- field: 'age',
57
- placeholder: '请输入年龄',
58
- defaultValue: 0,
59
- min: 0,
60
- max: 150,
61
- },
62
- },
63
- {
64
- id: 'email',
65
- type: 'j-input',
66
- config: {
67
- label: '邮箱',
68
- field: 'email',
69
- placeholder: '请输入邮箱',
70
- defaultValue: '',
71
- },
72
- },
73
- ],
74
- },
75
- ])
76
- </script>
1
+ <template>
2
+ <div>
3
+ <!-- j-form 通过 schema 渲染表单字段,j-layer-form 作为 schema 中的一项 -->
4
+ <j-form ref="formRef" :schema="schema" :config="formConfig" />
5
+
6
+ <div v-if="formData" style="margin-top: 16px">
7
+ <h4>表单数据:</h4>
8
+ <pre>{{ JSON.stringify(formData, null, 2) }}</pre>
9
+ </div>
10
+ </div>
11
+ </template>
12
+
13
+ <script setup lang="ts">
14
+ import { ref } from 'vue'
15
+ import type { SchemaConfig } from '@simcode/ui'
16
+
17
+ const formRef = ref()
18
+ const formData = ref<any>(null)
19
+
20
+ // j-form 的表单配置
21
+ const formConfig = {
22
+ labelWidth: 100,
23
+ labelPosition: 'right',
24
+ size: 'default',
25
+ gutter: 16,
26
+ span: 24,
27
+ }
28
+
29
+ // j-form 的 schema,j-layer-form 作为其中的一项
30
+ const schema = ref<SchemaConfig[]>([
31
+ {
32
+ type: 'j-layer-form',
33
+ config: {
34
+ label: '用户信息',
35
+ layerLabel: '用户信息',
36
+ layerWidth: 600,
37
+ layerHeight: 400,
38
+ },
39
+ // j-layer-form 弹窗内的表单字段通过 children 配置
40
+ children: [
41
+ {
42
+ id: 'name',
43
+ type: 'j-input',
44
+ config: {
45
+ label: '姓名',
46
+ field: 'name',
47
+ placeholder: '请输入姓名',
48
+ defaultValue: '',
49
+ },
50
+ },
51
+ {
52
+ id: 'age',
53
+ type: 'j-number',
54
+ config: {
55
+ label: '年龄',
56
+ field: 'age',
57
+ placeholder: '请输入年龄',
58
+ defaultValue: 0,
59
+ min: 0,
60
+ max: 150,
61
+ },
62
+ },
63
+ {
64
+ id: 'email',
65
+ type: 'j-input',
66
+ config: {
67
+ label: '邮箱',
68
+ field: 'email',
69
+ placeholder: '请输入邮箱',
70
+ defaultValue: '',
71
+ },
72
+ },
73
+ ],
74
+ },
75
+ ])
76
+ </script>
@@ -1,82 +1,82 @@
1
- <template>
2
- <div>
3
- <!-- j-form 通过 schema 渲染表单字段,j-layer-form 作为 schema 中的一项 -->
4
- <j-form :schema="schema" :config="formConfig" />
5
- </div>
6
- </template>
7
-
8
- <script setup lang="ts">
9
- import { ref } from 'vue'
10
- import type { SchemaConfig } from '@simcode/ui'
11
-
12
- // j-form 的表单配置
13
- const formConfig = {
14
- labelWidth: 100,
15
- labelPosition: 'right',
16
- size: 'default',
17
- gutter: 16,
18
- span: 24,
19
- }
20
-
21
- // j-form 的 schema,j-layer-form 作为其中的一项
22
- const schema = ref<SchemaConfig[]>([
23
- {
24
- type: 'j-layer-form',
25
- config: {
26
- label: '表单配置示例',
27
- layerLabel: '表单配置示例',
28
- // j-layer-form 的表单配置(会覆盖 j-form 的配置)
29
- formConfig: {
30
- labelWidth: 120,
31
- labelPosition: 'left',
32
- size: 'default',
33
- gutter: 20,
34
- span: 12,
35
- },
36
- },
37
- // j-layer-form 弹窗内的表单字段通过 children 配置
38
- children: [
39
- {
40
- id: 'name',
41
- type: 'j-input',
42
- config: {
43
- label: '姓名',
44
- field: 'name',
45
- placeholder: '请输入姓名',
46
- defaultValue: '',
47
- },
48
- },
49
- {
50
- id: 'age',
51
- type: 'j-number',
52
- config: {
53
- label: '年龄',
54
- field: 'age',
55
- placeholder: '请输入年龄',
56
- defaultValue: 0,
57
- },
58
- },
59
- {
60
- id: 'email',
61
- type: 'j-input',
62
- config: {
63
- label: '邮箱',
64
- field: 'email',
65
- placeholder: '请输入邮箱',
66
- defaultValue: '',
67
- },
68
- },
69
- {
70
- id: 'phone',
71
- type: 'j-input',
72
- config: {
73
- label: '电话',
74
- field: 'phone',
75
- placeholder: '请输入电话',
76
- defaultValue: '',
77
- },
78
- },
79
- ],
80
- },
81
- ])
82
- </script>
1
+ <template>
2
+ <div>
3
+ <!-- j-form 通过 schema 渲染表单字段,j-layer-form 作为 schema 中的一项 -->
4
+ <j-form :schema="schema" :config="formConfig" />
5
+ </div>
6
+ </template>
7
+
8
+ <script setup lang="ts">
9
+ import { ref } from 'vue'
10
+ import type { SchemaConfig } from '@simcode/ui'
11
+
12
+ // j-form 的表单配置
13
+ const formConfig = {
14
+ labelWidth: 100,
15
+ labelPosition: 'right',
16
+ size: 'default',
17
+ gutter: 16,
18
+ span: 24,
19
+ }
20
+
21
+ // j-form 的 schema,j-layer-form 作为其中的一项
22
+ const schema = ref<SchemaConfig[]>([
23
+ {
24
+ type: 'j-layer-form',
25
+ config: {
26
+ label: '表单配置示例',
27
+ layerLabel: '表单配置示例',
28
+ // j-layer-form 的表单配置(会覆盖 j-form 的配置)
29
+ formConfig: {
30
+ labelWidth: 120,
31
+ labelPosition: 'left',
32
+ size: 'default',
33
+ gutter: 20,
34
+ span: 12,
35
+ },
36
+ },
37
+ // j-layer-form 弹窗内的表单字段通过 children 配置
38
+ children: [
39
+ {
40
+ id: 'name',
41
+ type: 'j-input',
42
+ config: {
43
+ label: '姓名',
44
+ field: 'name',
45
+ placeholder: '请输入姓名',
46
+ defaultValue: '',
47
+ },
48
+ },
49
+ {
50
+ id: 'age',
51
+ type: 'j-number',
52
+ config: {
53
+ label: '年龄',
54
+ field: 'age',
55
+ placeholder: '请输入年龄',
56
+ defaultValue: 0,
57
+ },
58
+ },
59
+ {
60
+ id: 'email',
61
+ type: 'j-input',
62
+ config: {
63
+ label: '邮箱',
64
+ field: 'email',
65
+ placeholder: '请输入邮箱',
66
+ defaultValue: '',
67
+ },
68
+ },
69
+ {
70
+ id: 'phone',
71
+ type: 'j-input',
72
+ config: {
73
+ label: '电话',
74
+ field: 'phone',
75
+ placeholder: '请输入电话',
76
+ defaultValue: '',
77
+ },
78
+ },
79
+ ],
80
+ },
81
+ ])
82
+ </script>