@a2simcode/ui 0.0.142 → 0.0.145

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 (343) 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/count/index.d.ts +3 -3
  6. package/dist/components/count/src/count.vue.d.ts +1 -1
  7. package/dist/components/form/index.d.ts +27 -3
  8. package/dist/components/form/src/form.vue.d.ts +12 -1
  9. package/dist/components/inject-provide.d.ts +0 -1
  10. package/dist/simcode-ui.es.js +2905 -2913
  11. package/dist/simcode-ui.umd.js +2 -2
  12. package/dist/stats.html +1 -1
  13. package/dist/ui.css +1 -1
  14. package/docs/components/autocomplete.md +89 -89
  15. package/docs/components/barcode.md +101 -101
  16. package/docs/components/button-select.md +24 -24
  17. package/docs/components/button.md +117 -117
  18. package/docs/components/buttons.md +119 -119
  19. package/docs/components/cascader-select.md +114 -114
  20. package/docs/components/checkbox.md +114 -114
  21. package/docs/components/code-mirror.md +85 -85
  22. package/docs/components/collapse.md +26 -26
  23. package/docs/components/comp.md +71 -71
  24. package/docs/components/count-up.md +24 -24
  25. package/docs/components/count.md +24 -24
  26. package/docs/components/data-panel.md +24 -24
  27. package/docs/components/date.md +76 -76
  28. package/docs/components/dialog-full.md +112 -112
  29. package/docs/components/dialog.md +127 -127
  30. package/docs/components/divider.md +24 -24
  31. package/docs/components/drawer.md +127 -127
  32. package/docs/components/dynamic-layer.md +118 -118
  33. package/docs/components/echarts.md +72 -72
  34. package/docs/components/editor.md +24 -24
  35. package/docs/components/form.md +57 -57
  36. package/docs/components/guid.md +39 -39
  37. package/docs/components/hpanel.md +24 -24
  38. package/docs/components/icon.md +56 -56
  39. package/docs/components/input-button.md +24 -24
  40. package/docs/components/input-code.md +24 -24
  41. package/docs/components/input-color.md +114 -114
  42. package/docs/components/input-layer.md +26 -26
  43. package/docs/components/input-rows.md +370 -370
  44. package/docs/components/input-tag.md +50 -50
  45. package/docs/components/input.md +129 -129
  46. package/docs/components/layer-form.md +61 -61
  47. package/docs/components/layer.md +127 -127
  48. package/docs/components/layout.md +132 -132
  49. package/docs/components/map.md +24 -24
  50. package/docs/components/menu.md +121 -121
  51. package/docs/components/meta/buttons.ts +76 -76
  52. package/docs/components/meta/comp.ts +236 -236
  53. package/docs/components/meta/date.ts +267 -267
  54. package/docs/components/meta/echarts.ts +64 -64
  55. package/docs/components/meta/form-item.ts +50 -50
  56. package/docs/components/meta/form.ts +171 -171
  57. package/docs/components/meta/input-cards.ts +112 -112
  58. package/docs/components/meta/input-color.ts +243 -243
  59. package/docs/components/meta/input-layer.ts +366 -366
  60. package/docs/components/meta/input-rows.ts +113 -113
  61. package/docs/components/meta/layer-form.ts +56 -56
  62. package/docs/components/meta/map.ts +68 -68
  63. package/docs/components/meta/panel.ts +152 -152
  64. package/docs/components/meta/slider.ts +270 -270
  65. package/docs/components/meta/table-panel.ts +232 -232
  66. package/docs/components/meta/table.ts +391 -391
  67. package/docs/components/meta/tabs.ts +146 -146
  68. package/docs/components/meta/title.ts +91 -91
  69. package/docs/components/meta/tree-select.ts +199 -199
  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 +9 -9
  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 +539 -539
  178. package/docs/examples/form/init.vue +76 -76
  179. package/docs/examples/form/master-detail.vue +203 -203
  180. package/docs/examples/guid/basic.vue +10 -10
  181. package/docs/examples/guid/size.vue +13 -13
  182. package/docs/examples/hpanel/basic.vue +79 -79
  183. package/docs/examples/icon/basic.vue +9 -9
  184. package/docs/examples/icon/rotate-flip.vue +9 -9
  185. package/docs/examples/icon/size.vue +7 -7
  186. package/docs/examples/input/basic.vue +10 -10
  187. package/docs/examples/input/clearable.vue +12 -12
  188. package/docs/examples/input/disabled.vue +6 -6
  189. package/docs/examples/input/icon.vue +23 -23
  190. package/docs/examples/input/password.vue +18 -18
  191. package/docs/examples/input/size.vue +13 -13
  192. package/docs/examples/input/textarea.vue +25 -25
  193. package/docs/examples/input/word-limit.vue +28 -28
  194. package/docs/examples/input-button/basic.vue +33 -33
  195. package/docs/examples/input-code/basic.vue +29 -29
  196. package/docs/examples/input-color/basic.vue +10 -10
  197. package/docs/examples/input-color/disabled.vue +13 -13
  198. package/docs/examples/input-color/format.vue +17 -17
  199. package/docs/examples/input-color/no-alpha.vue +13 -13
  200. package/docs/examples/input-color/only-button.vue +15 -15
  201. package/docs/examples/input-color/predefine.vue +31 -31
  202. package/docs/examples/input-color/size.vue +15 -15
  203. package/docs/examples/input-layer/basic.vue +86 -86
  204. package/docs/examples/input-rows/basic.vue +73 -73
  205. package/docs/examples/input-rows/drag.vue +48 -48
  206. package/docs/examples/input-rows/layer-form.vue +85 -85
  207. package/docs/examples/input-rows/nested.vue +91 -91
  208. package/docs/examples/input-tag/basic.vue +27 -27
  209. package/docs/examples/input-tag/colors.vue +23 -23
  210. package/docs/examples/input-tag/readonly.vue +17 -17
  211. package/docs/examples/layer/basic.vue +43 -43
  212. package/docs/examples/layer/custom-buttons.vue +61 -61
  213. package/docs/examples/layer/drawer.vue +37 -37
  214. package/docs/examples/layer/full.vue +38 -38
  215. package/docs/examples/layer/modal.vue +34 -34
  216. package/docs/examples/layer/steps.vue +46 -46
  217. package/docs/examples/layer-form/basic.vue +76 -76
  218. package/docs/examples/layer-form/config.vue +82 -82
  219. package/docs/examples/layer-form/size.vue +72 -72
  220. package/docs/examples/layout/basic.vue +36 -36
  221. package/docs/examples/layout/custom-size.vue +50 -50
  222. package/docs/examples/layout/disable-move.vue +37 -37
  223. package/docs/examples/layout/hide-mid-when-narrow.vue +96 -96
  224. package/docs/examples/layout/min-size.vue +73 -73
  225. package/docs/examples/layout/percent-size.vue +80 -80
  226. package/docs/examples/layout/simple.vue +22 -22
  227. package/docs/examples/layout/top-side.vue +34 -34
  228. package/docs/examples/map/basic.vue +22 -22
  229. package/docs/examples/menu/basic.vue +58 -58
  230. package/docs/examples/menu/collapsed.vue +49 -49
  231. package/docs/examples/menu/horizontal.vue +44 -44
  232. package/docs/examples/menu/selection-test.vue +104 -104
  233. package/docs/examples/menu/theme.vue +46 -46
  234. package/docs/examples/menu/vertical.vue +46 -46
  235. package/docs/examples/number/advanced.vue +143 -143
  236. package/docs/examples/number/basic.vue +63 -63
  237. package/docs/examples/number/disabled.vue +49 -49
  238. package/docs/examples/number/size.vue +42 -42
  239. package/docs/examples/number/slots.vue +123 -123
  240. package/docs/examples/number/step-strictly.vue +41 -41
  241. package/docs/examples/number/step.vue +47 -47
  242. package/docs/examples/page/basic.vue +41 -41
  243. package/docs/examples/page/code-table-model.vue +428 -428
  244. package/docs/examples/page/dept-user-management.vue +211 -211
  245. package/docs/examples/page/init.vue +87 -87
  246. package/docs/examples/page/log.vue +453 -453
  247. package/docs/examples/page/user-management.vue +313 -313
  248. package/docs/examples/panel/tool-buttons.vue +18 -18
  249. package/docs/examples/radio/basic.vue +17 -17
  250. package/docs/examples/radio/button.vue +17 -17
  251. package/docs/examples/radio/color.vue +18 -18
  252. package/docs/examples/radio/disabled.vue +17 -17
  253. package/docs/examples/radio/size.vue +29 -29
  254. package/docs/examples/rate/basic.vue +24 -24
  255. package/docs/examples/rate/half.vue +24 -24
  256. package/docs/examples/rate/readonly.vue +11 -11
  257. package/docs/examples/rate/text.vue +37 -37
  258. package/docs/examples/select/basic.vue +16 -16
  259. package/docs/examples/select/clearable.vue +22 -22
  260. package/docs/examples/select/disabled.vue +31 -31
  261. package/docs/examples/select/filterable.vue +24 -24
  262. package/docs/examples/select/group.vue +23 -23
  263. package/docs/examples/select/icon.vue +16 -16
  264. package/docs/examples/select/multiple.vue +18 -18
  265. package/docs/examples/select/size.vue +39 -39
  266. package/docs/examples/slider/basic.vue +42 -42
  267. package/docs/examples/slider/disabled.vue +17 -17
  268. package/docs/examples/slider/marks.vue +30 -30
  269. package/docs/examples/slider/size.vue +37 -37
  270. package/docs/examples/slider/tooltip.vue +36 -36
  271. package/docs/examples/slider/vertical.vue +26 -26
  272. package/docs/examples/slider-captcha/basic.vue +44 -44
  273. package/docs/examples/slider-captcha/custom.vue +48 -48
  274. package/docs/examples/switch/basic.vue +16 -16
  275. package/docs/examples/switch/disabled.vue +13 -13
  276. package/docs/examples/switch/loading.vue +13 -13
  277. package/docs/examples/switch/size.vue +15 -15
  278. package/docs/examples/switch/text.vue +13 -13
  279. package/docs/examples/table/action-filter.vue +126 -126
  280. package/docs/examples/table/actions.vue +116 -116
  281. package/docs/examples/table/add-row.vue +103 -103
  282. package/docs/examples/table/basic.vue +168 -168
  283. package/docs/examples/table/checkbox-layout.vue +68 -68
  284. package/docs/examples/table/custom-layout.vue +115 -115
  285. package/docs/examples/table/dynamic-type.vue +73 -73
  286. package/docs/examples/table/editable.vue +262 -262
  287. package/docs/examples/table/field-selection.vue +87 -87
  288. package/docs/examples/table/frozen-column.vue +140 -140
  289. package/docs/examples/table/height-mode.vue +99 -99
  290. package/docs/examples/table/icon.vue +85 -85
  291. package/docs/examples/table/link.vue +66 -66
  292. package/docs/examples/table/multiple.vue +188 -188
  293. package/docs/examples/table/pagination.vue +151 -151
  294. package/docs/examples/table/single-selection.vue +64 -64
  295. package/docs/examples/table/sub-table-lazy.vue +97 -97
  296. package/docs/examples/table/sub-table.vue +103 -103
  297. package/docs/examples/table/tag.vue +43 -43
  298. package/docs/examples/table/tree-column.vue +119 -119
  299. package/docs/examples/table/tree-data.vue +141 -141
  300. package/docs/examples/table/tree-default-expand-all.vue +60 -60
  301. package/docs/examples/table/tree-lazy.vue +80 -80
  302. package/docs/examples/table/tree-set-selection.vue +75 -75
  303. package/docs/examples/table-panel/basic.vue +229 -229
  304. package/docs/examples/table-panel/batch-operations.vue +285 -285
  305. package/docs/examples/table-panel/button-visibility.vue +88 -88
  306. package/docs/examples/table-panel/filter.vue +219 -219
  307. package/docs/examples/table-panel/get-selection.vue +111 -111
  308. package/docs/examples/table-panel/multiple-selection.vue +243 -243
  309. package/docs/examples/table-panel/pagination.vue +133 -133
  310. package/docs/examples/table-panel/sub-table-lazy.vue +118 -118
  311. package/docs/examples/table-panel/tree-parent-key.vue +67 -67
  312. package/docs/examples/tabs/basic.vue +98 -98
  313. package/docs/examples/time/base.vue +67 -67
  314. package/docs/examples/title/basic.vue +87 -87
  315. package/docs/examples/tree/accordion.vue +46 -46
  316. package/docs/examples/tree/basic.vue +50 -50
  317. package/docs/examples/tree/buttons.vue +53 -53
  318. package/docs/examples/tree/checkable.vue +52 -52
  319. package/docs/examples/tree/custom-keys.vue +39 -39
  320. package/docs/examples/tree/default-expanded.vue +52 -52
  321. package/docs/examples/tree/draggable.vue +29 -29
  322. package/docs/examples/tree/expand-on-click.vue +39 -39
  323. package/docs/examples/tree/flat-data.vue +20 -20
  324. package/docs/examples/tree/icon.vue +40 -40
  325. package/docs/examples/tree/load-data.vue +37 -37
  326. package/docs/examples/tree/methods.vue +74 -74
  327. package/docs/examples/tree/theme.vue +33 -33
  328. package/docs/examples/tree-select/basic.vue +47 -47
  329. package/docs/examples/upload/accept.vue +31 -31
  330. package/docs/examples/upload/basic.vue +12 -12
  331. package/docs/examples/upload/drag.vue +11 -11
  332. package/docs/examples/upload/image.vue +17 -17
  333. package/docs/examples/upload/limit.vue +20 -20
  334. package/docs/examples/upload/multiple.vue +17 -17
  335. package/docs/examples/upload/readonly.vue +17 -17
  336. package/docs/examples/utils/cipher.vue +160 -160
  337. package/docs/examples/utils/common.vue +153 -153
  338. package/docs/examples/utils/date.vue +56 -56
  339. package/docs/examples/utils/dom.vue +52 -52
  340. package/docs/examples/utils/is.vue +70 -70
  341. package/docs/examples/workflow/basic.vue +265 -265
  342. package/docs/examples/workflow-viewer/basic.vue +248 -248
  343. package/package.json +23 -23
@@ -1,79 +1,79 @@
1
- <template>
2
- <div class="hpanel-demo">
3
- <div class="demo-item">
4
- <p>基础用法</p>
5
- <j-hpanel class="custom-panel">
6
- <template #left>
7
- <div class="side-content">Left Slot</div>
8
- </template>
9
- <div class="main-content">Default Slot (Main Content)</div>
10
- <template #right>
11
- <div class="side-content">Right Slot</div>
12
- </template>
13
- </j-hpanel>
14
- </div>
15
-
16
- <div class="demo-item">
17
- <p>仅左侧和内容</p>
18
- <j-hpanel class="custom-panel">
19
- <template #left>
20
- <div class="side-content">Left</div>
21
- </template>
22
- <div class="main-content">Main Content</div>
23
- </j-hpanel>
24
- </div>
25
-
26
- <div class="demo-item">
27
- <p>仅内容和右侧</p>
28
- <j-hpanel class="custom-panel">
29
- <div class="main-content">Main Content</div>
30
- <template #right>
31
- <div class="side-content">Right</div>
32
- </template>
33
- </j-hpanel>
34
- </div>
35
- </div>
36
- </template>
37
-
38
- <script setup lang="ts">
39
- // 示例代码无需额外逻辑
40
- </script>
41
-
42
- <style scoped>
43
- .hpanel-demo {
44
- display: flex;
45
- flex-direction: column;
46
- gap: 24px;
47
- }
48
-
49
- .demo-item p {
50
- margin: 0 0 12px;
51
- font-size: 14px;
52
- color: var(--j-color-text-2);
53
- font-weight: 500;
54
- }
55
-
56
- .custom-panel {
57
- border: 1px solid var(--j-color-border);
58
- border-radius: 4px;
59
- overflow: hidden;
60
- }
61
-
62
- .side-content {
63
- background-color: var(--j-color-fill-2);
64
- padding: 12px 20px;
65
- display: flex;
66
- align-items: center;
67
- justify-content: center;
68
- min-width: 100px;
69
- }
70
-
71
- .main-content {
72
- background-color: var(--j-color-bg-2);
73
- padding: 12px 20px;
74
- height: 60px;
75
- display: flex;
76
- align-items: center;
77
- justify-content: center;
78
- }
79
- </style>
1
+ <template>
2
+ <div class="hpanel-demo">
3
+ <div class="demo-item">
4
+ <p>基础用法</p>
5
+ <j-hpanel class="custom-panel">
6
+ <template #left>
7
+ <div class="side-content">Left Slot</div>
8
+ </template>
9
+ <div class="main-content">Default Slot (Main Content)</div>
10
+ <template #right>
11
+ <div class="side-content">Right Slot</div>
12
+ </template>
13
+ </j-hpanel>
14
+ </div>
15
+
16
+ <div class="demo-item">
17
+ <p>仅左侧和内容</p>
18
+ <j-hpanel class="custom-panel">
19
+ <template #left>
20
+ <div class="side-content">Left</div>
21
+ </template>
22
+ <div class="main-content">Main Content</div>
23
+ </j-hpanel>
24
+ </div>
25
+
26
+ <div class="demo-item">
27
+ <p>仅内容和右侧</p>
28
+ <j-hpanel class="custom-panel">
29
+ <div class="main-content">Main Content</div>
30
+ <template #right>
31
+ <div class="side-content">Right</div>
32
+ </template>
33
+ </j-hpanel>
34
+ </div>
35
+ </div>
36
+ </template>
37
+
38
+ <script setup lang="ts">
39
+ // 示例代码无需额外逻辑
40
+ </script>
41
+
42
+ <style scoped>
43
+ .hpanel-demo {
44
+ display: flex;
45
+ flex-direction: column;
46
+ gap: 24px;
47
+ }
48
+
49
+ .demo-item p {
50
+ margin: 0 0 12px;
51
+ font-size: 14px;
52
+ color: var(--j-color-text-2);
53
+ font-weight: 500;
54
+ }
55
+
56
+ .custom-panel {
57
+ border: 1px solid var(--j-color-border);
58
+ border-radius: 4px;
59
+ overflow: hidden;
60
+ }
61
+
62
+ .side-content {
63
+ background-color: var(--j-color-fill-2);
64
+ padding: 12px 20px;
65
+ display: flex;
66
+ align-items: center;
67
+ justify-content: center;
68
+ min-width: 100px;
69
+ }
70
+
71
+ .main-content {
72
+ background-color: var(--j-color-bg-2);
73
+ padding: 12px 20px;
74
+ height: 60px;
75
+ display: flex;
76
+ align-items: center;
77
+ justify-content: center;
78
+ }
79
+ </style>
@@ -1,9 +1,9 @@
1
- <template>
2
- <div style="display: flex; gap: 20px; align-items: center">
3
- <j-icon icon="mdi:home" />
4
- <j-icon icon="mdi:account" color="#409eff" />
5
- <j-icon icon="mdi:check-circle" color="#67c23a" />
6
- <j-icon icon="mdi:alert-circle" color="#f56c6c" />
7
- <j-icon icon="mdi:information" color="#909399" />
8
- </div>
9
- </template>
1
+ <template>
2
+ <div style="display: flex; gap: 20px; align-items: center">
3
+ <j-icon icon="mdi:home" />
4
+ <j-icon icon="mdi:account" color="#409eff" />
5
+ <j-icon icon="mdi:check-circle" color="#67c23a" />
6
+ <j-icon icon="mdi:alert-circle" color="#f56c6c" />
7
+ <j-icon icon="mdi:information" color="#909399" />
8
+ </div>
9
+ </template>
@@ -1,9 +1,9 @@
1
- <template>
2
- <div style="display: flex; gap: 20px; align-items: center; font-size: 24px">
3
- <j-icon icon="mdi:send" :rotate="45" />
4
- <j-icon icon="mdi:send" :rotate="90" />
5
- <j-icon icon="mdi:send" :rotate="180" />
6
- <j-icon icon="mdi:send" flip="horizontal" />
7
- <j-icon icon="mdi:send" flip="vertical" />
8
- </div>
9
- </template>
1
+ <template>
2
+ <div style="display: flex; gap: 20px; align-items: center; font-size: 24px">
3
+ <j-icon icon="mdi:send" :rotate="45" />
4
+ <j-icon icon="mdi:send" :rotate="90" />
5
+ <j-icon icon="mdi:send" :rotate="180" />
6
+ <j-icon icon="mdi:send" flip="horizontal" />
7
+ <j-icon icon="mdi:send" flip="vertical" />
8
+ </div>
9
+ </template>
@@ -1,7 +1,7 @@
1
- <template>
2
- <div style="display: flex; gap: 20px; align-items: center">
3
- <j-icon icon="mdi:home" :size="16" />
4
- <j-icon icon="mdi:home" :size="24" />
5
- <j-icon icon="mdi:home" :size="32" />
6
- </div>
7
- </template>
1
+ <template>
2
+ <div style="display: flex; gap: 20px; align-items: center">
3
+ <j-icon icon="mdi:home" :size="16" />
4
+ <j-icon icon="mdi:home" :size="24" />
5
+ <j-icon icon="mdi:home" :size="32" />
6
+ </div>
7
+ </template>
@@ -1,10 +1,10 @@
1
- <template>
2
- <j-input v-model="value" placeholder="请输入内容" style="width: 300px" />
3
- <p v-if="value" style="margin-top: 12px; color: #606266">输入的内容: {{ value }}</p>
4
- </template>
5
-
6
- <script setup lang="ts">
7
- import { ref } from 'vue'
8
-
9
- const value = ref('')
10
- </script>
1
+ <template>
2
+ <j-input v-model="value" placeholder="请输入内容" style="width: 300px" />
3
+ <p v-if="value" style="margin-top: 12px; color: #606266">输入的内容: {{ value }}</p>
4
+ </template>
5
+
6
+ <script setup lang="ts">
7
+ import { ref } from 'vue'
8
+
9
+ const value = ref('')
10
+ </script>
@@ -1,12 +1,12 @@
1
- <template>
2
- <div style="display: flex; flex-direction: column; gap: 12px">
3
- <j-input v-model="value1" clearable placeholder="可清除的输入框" style="width: 300px" />
4
- <p v-if="value1" style="color: #606266">输入的内容: {{ value1 }}</p>
5
- </div>
6
- </template>
7
-
8
- <script setup lang="ts">
9
- import { ref } from 'vue'
10
-
11
- const value1 = ref('')
12
- </script>
1
+ <template>
2
+ <div style="display: flex; flex-direction: column; gap: 12px">
3
+ <j-input v-model="value1" clearable placeholder="可清除的输入框" style="width: 300px" />
4
+ <p v-if="value1" style="color: #606266">输入的内容: {{ value1 }}</p>
5
+ </div>
6
+ </template>
7
+
8
+ <script setup lang="ts">
9
+ import { ref } from 'vue'
10
+
11
+ const value1 = ref('')
12
+ </script>
@@ -1,6 +1,6 @@
1
- <template>
2
- <div style="display: flex; flex-direction: column; gap: 12px">
3
- <j-input disabled placeholder="禁用状态" style="width: 300px" />
4
- <j-input readonly model-value="只读内容" style="width: 300px" />
5
- </div>
6
- </template>
1
+ <template>
2
+ <div style="display: flex; flex-direction: column; gap: 12px">
3
+ <j-input disabled placeholder="禁用状态" style="width: 300px" />
4
+ <j-input readonly model-value="只读内容" style="width: 300px" />
5
+ </div>
6
+ </template>
@@ -1,23 +1,23 @@
1
- <template>
2
- <div style="display: flex; flex-direction: column; gap: 12px">
3
- <j-input
4
- v-model="value1"
5
- prefix-icon="mdi:search"
6
- placeholder="带前缀图标的输入框"
7
- style="width: 300px"
8
- />
9
- <j-input
10
- v-model="value2"
11
- suffix-icon="mdi:calendar"
12
- placeholder="带后缀图标的输入框"
13
- style="width: 300px"
14
- />
15
- </div>
16
- </template>
17
-
18
- <script setup lang="ts">
19
- import { ref } from 'vue'
20
-
21
- const value1 = ref('')
22
- const value2 = ref('')
23
- </script>
1
+ <template>
2
+ <div style="display: flex; flex-direction: column; gap: 12px">
3
+ <j-input
4
+ v-model="value1"
5
+ prefix-icon="mdi:search"
6
+ placeholder="带前缀图标的输入框"
7
+ style="width: 300px"
8
+ />
9
+ <j-input
10
+ v-model="value2"
11
+ suffix-icon="mdi:calendar"
12
+ placeholder="带后缀图标的输入框"
13
+ style="width: 300px"
14
+ />
15
+ </div>
16
+ </template>
17
+
18
+ <script setup lang="ts">
19
+ import { ref } from 'vue'
20
+
21
+ const value1 = ref('')
22
+ const value2 = ref('')
23
+ </script>
@@ -1,18 +1,18 @@
1
- <template>
2
- <div style="display: flex; flex-direction: column; gap: 12px">
3
- <j-input
4
- v-model="password"
5
- type="password"
6
- show-password
7
- placeholder="请输入密码"
8
- style="width: 300px"
9
- />
10
- <p v-if="password" style="color: #606266">密码: {{ password }}</p>
11
- </div>
12
- </template>
13
-
14
- <script setup lang="ts">
15
- import { ref } from 'vue'
16
-
17
- const password = ref('')
18
- </script>
1
+ <template>
2
+ <div style="display: flex; flex-direction: column; gap: 12px">
3
+ <j-input
4
+ v-model="password"
5
+ type="password"
6
+ show-password
7
+ placeholder="请输入密码"
8
+ style="width: 300px"
9
+ />
10
+ <p v-if="password" style="color: #606266">密码: {{ password }}</p>
11
+ </div>
12
+ </template>
13
+
14
+ <script setup lang="ts">
15
+ import { ref } from 'vue'
16
+
17
+ const password = ref('')
18
+ </script>
@@ -1,13 +1,13 @@
1
- <template>
2
- <div style="display: flex; flex-direction: column; gap: 12px">
3
- <j-input v-model="value" size="large" placeholder="大型输入框" style="width: 300px" />
4
- <j-input v-model="value" placeholder="默认输入框" style="width: 300px" />
5
- <j-input v-model="value" size="small" placeholder="小型输入框" style="width: 300px" />
6
- </div>
7
- </template>
8
-
9
- <script setup lang="ts">
10
- import { ref } from 'vue'
11
-
12
- const value = ref('')
13
- </script>
1
+ <template>
2
+ <div style="display: flex; flex-direction: column; gap: 12px">
3
+ <j-input v-model="value" size="large" placeholder="大型输入框" style="width: 300px" />
4
+ <j-input v-model="value" placeholder="默认输入框" style="width: 300px" />
5
+ <j-input v-model="value" size="small" placeholder="小型输入框" style="width: 300px" />
6
+ </div>
7
+ </template>
8
+
9
+ <script setup lang="ts">
10
+ import { ref } from 'vue'
11
+
12
+ const value = ref('')
13
+ </script>
@@ -1,25 +1,25 @@
1
- <template>
2
- <div style="display: flex; flex-direction: column; gap: 12px">
3
- <j-input
4
- v-model="value1"
5
- type="textarea"
6
- :rows="4"
7
- placeholder="固定行数的文本域"
8
- style="width: 300px"
9
- />
10
- <j-input
11
- v-model="value2"
12
- type="textarea"
13
- :autosize="{ minRows: 2, maxRows: 6 }"
14
- placeholder="自适应高度的文本域"
15
- style="width: 300px"
16
- />
17
- </div>
18
- </template>
19
-
20
- <script setup lang="ts">
21
- import { ref } from 'vue'
22
-
23
- const value1 = ref('')
24
- const value2 = ref('')
25
- </script>
1
+ <template>
2
+ <div style="display: flex; flex-direction: column; gap: 12px">
3
+ <j-input
4
+ v-model="value1"
5
+ type="textarea"
6
+ :rows="4"
7
+ placeholder="固定行数的文本域"
8
+ style="width: 300px"
9
+ />
10
+ <j-input
11
+ v-model="value2"
12
+ type="textarea"
13
+ :autosize="{ minRows: 2, maxRows: 6 }"
14
+ placeholder="自适应高度的文本域"
15
+ style="width: 300px"
16
+ />
17
+ </div>
18
+ </template>
19
+
20
+ <script setup lang="ts">
21
+ import { ref } from 'vue'
22
+
23
+ const value1 = ref('')
24
+ const value2 = ref('')
25
+ </script>
@@ -1,28 +1,28 @@
1
- <template>
2
- <div style="display: flex; flex-direction: column; gap: 12px">
3
- <j-input
4
- v-model="value1"
5
- type="text"
6
- :maxlength="10"
7
- show-word-limit
8
- placeholder="最多输入10个字符"
9
- style="width: 300px"
10
- />
11
- <j-input
12
- v-model="value2"
13
- type="textarea"
14
- :maxlength="20"
15
- show-word-limit
16
- word-limit-position="outside"
17
- placeholder="字数统计在外部"
18
- style="width: 300px"
19
- />
20
- </div>
21
- </template>
22
-
23
- <script setup lang="ts">
24
- import { ref } from 'vue'
25
-
26
- const value1 = ref('')
27
- const value2 = ref('')
28
- </script>
1
+ <template>
2
+ <div style="display: flex; flex-direction: column; gap: 12px">
3
+ <j-input
4
+ v-model="value1"
5
+ type="text"
6
+ :maxlength="10"
7
+ show-word-limit
8
+ placeholder="最多输入10个字符"
9
+ style="width: 300px"
10
+ />
11
+ <j-input
12
+ v-model="value2"
13
+ type="textarea"
14
+ :maxlength="20"
15
+ show-word-limit
16
+ word-limit-position="outside"
17
+ placeholder="字数统计在外部"
18
+ style="width: 300px"
19
+ />
20
+ </div>
21
+ </template>
22
+
23
+ <script setup lang="ts">
24
+ import { ref } from 'vue'
25
+
26
+ const value1 = ref('')
27
+ const value2 = ref('')
28
+ </script>
@@ -1,33 +1,33 @@
1
- <template>
2
- <j-input-button v-model="value" title="选择数据" btn-text="打开弹窗" :ok="handleOk">
3
- <div style="padding: 20px">
4
- <j-input
5
- v-model="form.name"
6
- label="名称"
7
- placeholder="请输入名称"
8
- style="margin-bottom: 16px"
9
- />
10
- <j-input v-model="form.age" label="年龄" placeholder="请输入年龄" />
11
- </div>
12
- </j-input-button>
13
- <p v-if="value" style="margin-top: 12px; color: #606266">选择的结果: {{ value }}</p>
14
- </template>
15
-
16
- <script setup lang="ts">
17
- import { ref, reactive } from 'vue'
18
-
19
- const value = ref('')
20
- const form = reactive({
21
- name: '',
22
- age: '',
23
- })
24
-
25
- const handleOk = async () => {
26
- // 模拟异步操作
27
- return new Promise((resolve) => {
28
- setTimeout(() => {
29
- resolve(JSON.stringify(form))
30
- }, 500)
31
- })
32
- }
33
- </script>
1
+ <template>
2
+ <j-input-button v-model="value" title="选择数据" btn-text="打开弹窗" :ok="handleOk">
3
+ <div style="padding: 20px">
4
+ <j-input
5
+ v-model="form.name"
6
+ label="名称"
7
+ placeholder="请输入名称"
8
+ style="margin-bottom: 16px"
9
+ />
10
+ <j-input v-model="form.age" label="年龄" placeholder="请输入年龄" />
11
+ </div>
12
+ </j-input-button>
13
+ <p v-if="value" style="margin-top: 12px; color: #606266">选择的结果: {{ value }}</p>
14
+ </template>
15
+
16
+ <script setup lang="ts">
17
+ import { ref, reactive } from 'vue'
18
+
19
+ const value = ref('')
20
+ const form = reactive({
21
+ name: '',
22
+ age: '',
23
+ })
24
+
25
+ const handleOk = async () => {
26
+ // 模拟异步操作
27
+ return new Promise((resolve) => {
28
+ setTimeout(() => {
29
+ resolve(JSON.stringify(form))
30
+ }, 500)
31
+ })
32
+ }
33
+ </script>
@@ -1,29 +1,29 @@
1
- <template>
2
- <j-input-code
3
- v-model="code"
4
- title="脚本编辑器"
5
- btn-text="编写脚本"
6
- mode="javascript"
7
- :example="exampleCode"
8
- @change="handleChange"
9
- />
10
- <div style="margin-top: 12px">
11
- <div style="font-weight: bold">当前脚本内容:</div>
12
- <p style="background: #f4f4f5; padding: 12px; border-radius: 4px">{{ code || '未设置' }}</p>
13
- </div>
14
- </template>
15
-
16
- <script setup lang="ts">
17
- import { ref } from 'vue'
18
-
19
- const code = ref('console.log("Hello, World!");')
20
- const exampleCode = `
21
- // 示例代码,只支持ES5语法
22
- // 获取表单是新增还是编辑
23
- var isUpdate = jianda.isUpdate
24
- `
25
-
26
- const handleChange = (value: string) => {
27
- console.log('代码改变:', value)
28
- }
29
- </script>
1
+ <template>
2
+ <j-input-code
3
+ v-model="code"
4
+ title="脚本编辑器"
5
+ btn-text="编写脚本"
6
+ mode="javascript"
7
+ :example="exampleCode"
8
+ @change="handleChange"
9
+ />
10
+ <div style="margin-top: 12px">
11
+ <div style="font-weight: bold">当前脚本内容:</div>
12
+ <p style="background: #f4f4f5; padding: 12px; border-radius: 4px">{{ code || '未设置' }}</p>
13
+ </div>
14
+ </template>
15
+
16
+ <script setup lang="ts">
17
+ import { ref } from 'vue'
18
+
19
+ const code = ref('console.log("Hello, World!");')
20
+ const exampleCode = `
21
+ // 示例代码,只支持ES5语法
22
+ // 获取表单是新增还是编辑
23
+ var isUpdate = jianda.isUpdate
24
+ `
25
+
26
+ const handleChange = (value: string) => {
27
+ console.log('代码改变:', value)
28
+ }
29
+ </script>
@@ -1,10 +1,10 @@
1
- <template>
2
- <j-input-color v-model="value" placeholder="请选择颜色" style="width: 300px" />
3
- <p v-if="value" style="margin-top: 12px; color: #606266">选择的颜色: {{ value }}</p>
4
- </template>
5
-
6
- <script setup lang="ts">
7
- import { ref } from 'vue'
8
-
9
- const value = ref('')
10
- </script>
1
+ <template>
2
+ <j-input-color v-model="value" placeholder="请选择颜色" style="width: 300px" />
3
+ <p v-if="value" style="margin-top: 12px; color: #606266">选择的颜色: {{ value }}</p>
4
+ </template>
5
+
6
+ <script setup lang="ts">
7
+ import { ref } from 'vue'
8
+
9
+ const value = ref('')
10
+ </script>