@a2simcode/ui 0.0.187 → 0.0.188

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 (361) 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/buttons/src/interface.d.ts +4 -0
  6. package/dist/components/input/index.d.ts +3 -3
  7. package/dist/components/input/src/input.vue.d.ts +1 -1
  8. package/dist/components/input-layer/index.d.ts +3 -3
  9. package/dist/components/input-layer/src/input-layer.vue.d.ts +1 -1
  10. package/dist/components/input-map/index.d.ts +3 -3
  11. package/dist/components/input-map/src/input-map.vue.d.ts +1 -1
  12. package/dist/components/input-tag/index.d.ts +3 -3
  13. package/dist/components/input-tag/src/input-tag.vue.d.ts +1 -1
  14. package/dist/components/time/index.d.ts +3 -3
  15. package/dist/components/time/src/time.vue.d.ts +1 -1
  16. package/dist/components/upload/index.d.ts +24 -24
  17. package/dist/components/upload/src/list.vue.d.ts +1 -1
  18. package/dist/components/upload/src/upload.vue.d.ts +8 -8
  19. package/dist/simcode-ui.es.js +458 -441
  20. package/dist/simcode-ui.umd.js +2 -2
  21. package/dist/stats.html +1 -1
  22. package/dist/ui.css +1 -1
  23. package/docs/components/autocomplete.md +89 -89
  24. package/docs/components/barcode.md +101 -101
  25. package/docs/components/button-select.md +24 -24
  26. package/docs/components/button.md +117 -117
  27. package/docs/components/buttons.md +119 -119
  28. package/docs/components/cascader-select.md +114 -114
  29. package/docs/components/checkbox.md +114 -114
  30. package/docs/components/code-mirror.md +85 -85
  31. package/docs/components/collapse.md +26 -26
  32. package/docs/components/comp.md +71 -71
  33. package/docs/components/count-up.md +24 -24
  34. package/docs/components/count.md +24 -24
  35. package/docs/components/data-panel.md +24 -24
  36. package/docs/components/date.md +76 -76
  37. package/docs/components/dialog-full.md +112 -112
  38. package/docs/components/dialog.md +127 -127
  39. package/docs/components/divider.md +24 -24
  40. package/docs/components/drawer.md +127 -127
  41. package/docs/components/dynamic-layer.md +118 -118
  42. package/docs/components/echarts.md +72 -72
  43. package/docs/components/editor.md +24 -24
  44. package/docs/components/form.md +72 -72
  45. package/docs/components/guid.md +39 -39
  46. package/docs/components/hpanel.md +24 -24
  47. package/docs/components/icon.md +56 -56
  48. package/docs/components/input-button.md +24 -24
  49. package/docs/components/input-code.md +24 -24
  50. package/docs/components/input-color.md +114 -114
  51. package/docs/components/input-layer.md +56 -56
  52. package/docs/components/input-rows.md +370 -370
  53. package/docs/components/input-tag.md +50 -50
  54. package/docs/components/input.md +129 -129
  55. package/docs/components/layer-form.md +61 -61
  56. package/docs/components/layer.md +127 -127
  57. package/docs/components/layout.md +132 -132
  58. package/docs/components/map.md +24 -24
  59. package/docs/components/menu.md +121 -121
  60. package/docs/components/meta/button.ts +212 -212
  61. package/docs/components/meta/buttons.ts +76 -76
  62. package/docs/components/meta/code-mirror.ts +108 -108
  63. package/docs/components/meta/comp.ts +236 -236
  64. package/docs/components/meta/date.ts +267 -267
  65. package/docs/components/meta/echarts.ts +64 -64
  66. package/docs/components/meta/form-item.ts +50 -50
  67. package/docs/components/meta/form.ts +181 -181
  68. package/docs/components/meta/input-button.ts +165 -165
  69. package/docs/components/meta/input-cards.ts +112 -112
  70. package/docs/components/meta/input-code.ts +151 -151
  71. package/docs/components/meta/input-color.ts +243 -243
  72. package/docs/components/meta/input-layer.ts +382 -382
  73. package/docs/components/meta/input-rows.ts +119 -119
  74. package/docs/components/meta/layer-form.ts +56 -56
  75. package/docs/components/meta/map.ts +68 -68
  76. package/docs/components/meta/panel.ts +152 -152
  77. package/docs/components/meta/slider.ts +270 -270
  78. package/docs/components/meta/table-panel.ts +237 -237
  79. package/docs/components/meta/table.ts +391 -391
  80. package/docs/components/meta/tabs.ts +146 -146
  81. package/docs/components/meta/title.ts +91 -91
  82. package/docs/components/meta/tree-select.ts +199 -199
  83. package/docs/components/meta/tree.ts +219 -219
  84. package/docs/components/meta/vpanel.ts +19 -19
  85. package/docs/components/meta/workflow-viewer.ts +55 -55
  86. package/docs/components/number.md +124 -124
  87. package/docs/components/page.md +102 -102
  88. package/docs/components/panel.md +37 -37
  89. package/docs/components/radio.md +87 -87
  90. package/docs/components/rate.md +71 -71
  91. package/docs/components/select.md +133 -133
  92. package/docs/components/slider-captcha.md +41 -41
  93. package/docs/components/slider.md +101 -101
  94. package/docs/components/switch.md +90 -90
  95. package/docs/components/table-panel.md +251 -251
  96. package/docs/components/table.md +391 -391
  97. package/docs/components/tabs.md +26 -26
  98. package/docs/components/title.md +24 -24
  99. package/docs/components/tree.md +207 -207
  100. package/docs/components/upload.md +117 -117
  101. package/docs/components/workflow-viewer.md +21 -21
  102. package/docs/components/workflow.md +21 -21
  103. package/docs/examples/autocomplete/advanced.vue +35 -35
  104. package/docs/examples/autocomplete/basic.vue +32 -32
  105. package/docs/examples/autocomplete/clearable.vue +33 -33
  106. package/docs/examples/autocomplete/custom-template.vue +49 -49
  107. package/docs/examples/autocomplete/disabled.vue +33 -33
  108. package/docs/examples/autocomplete/icon.vue +37 -37
  109. package/docs/examples/barcode/all-types.vue +380 -380
  110. package/docs/examples/barcode/basic.vue +14 -14
  111. package/docs/examples/barcode/props-appearance.vue +243 -243
  112. package/docs/examples/barcode/props-geometry.vue +143 -143
  113. package/docs/examples/barcode/props-logic.vue +216 -216
  114. package/docs/examples/barcode/props-symbology.vue +199 -199
  115. package/docs/examples/barcode/props-text.vue +268 -268
  116. package/docs/examples/button/basic.vue +7 -7
  117. package/docs/examples/button/danger-ghost.vue +17 -17
  118. package/docs/examples/button/disabled.vue +10 -10
  119. package/docs/examples/button/loading.vue +6 -6
  120. package/docs/examples/button/shape.vue +7 -7
  121. package/docs/examples/button/size.vue +14 -14
  122. package/docs/examples/button/type.vue +10 -10
  123. package/docs/examples/button-select/basic.vue +19 -19
  124. package/docs/examples/buttons/basic.vue +62 -45
  125. package/docs/examples/buttons/disabled.vue +36 -36
  126. package/docs/examples/buttons/dropdown.vue +63 -63
  127. package/docs/examples/buttons/group.vue +52 -52
  128. package/docs/examples/buttons/link.vue +47 -47
  129. package/docs/examples/buttons/popup.vue +39 -39
  130. package/docs/examples/buttons/size.vue +45 -45
  131. package/docs/examples/cascader-select/basic.vue +28 -28
  132. package/docs/examples/cascader-select/clearable.vue +34 -34
  133. package/docs/examples/cascader-select/disabled.vue +43 -43
  134. package/docs/examples/cascader-select/filterable.vue +37 -37
  135. package/docs/examples/cascader-select/methods.vue +84 -84
  136. package/docs/examples/cascader-select/multiple.vue +38 -38
  137. package/docs/examples/cascader-select/slot.vue +45 -45
  138. package/docs/examples/checkbox/basic.vue +18 -18
  139. package/docs/examples/checkbox/button.vue +19 -19
  140. package/docs/examples/checkbox/color.vue +25 -25
  141. package/docs/examples/checkbox/disabled.vue +17 -17
  142. package/docs/examples/checkbox/min-max.vue +20 -20
  143. package/docs/examples/checkbox/mixed.vue +56 -56
  144. package/docs/examples/checkbox/size.vue +28 -28
  145. package/docs/examples/code-mirror/basic.vue +11 -11
  146. package/docs/examples/code-mirror/events.vue +42 -42
  147. package/docs/examples/code-mirror/height.vue +25 -25
  148. package/docs/examples/code-mirror/mode.vue +33 -33
  149. package/docs/examples/code-mirror/readonly.vue +14 -14
  150. package/docs/examples/collapse/basic.vue +82 -82
  151. package/docs/examples/comp/basic.vue +7 -7
  152. package/docs/examples/comp/collapse.vue +38 -38
  153. package/docs/examples/comp/tabs.vue +38 -38
  154. package/docs/examples/count/basic.vue +101 -101
  155. package/docs/examples/count-up/basic.vue +89 -89
  156. package/docs/examples/data-panel/basic.vue +110 -110
  157. package/docs/examples/date/basic.vue +73 -73
  158. package/docs/examples/date/default-value.vue +59 -59
  159. package/docs/examples/date/format.vue +75 -75
  160. package/docs/examples/date/range.vue +66 -66
  161. package/docs/examples/date/types.vue +79 -79
  162. package/docs/examples/decorated-title/basic.vue +31 -31
  163. package/docs/examples/dialog/basic.vue +36 -36
  164. package/docs/examples/dialog/custom-buttons.vue +44 -44
  165. package/docs/examples/dialog/fullscreen.vue +23 -23
  166. package/docs/examples/dialog/no-mask.vue +17 -17
  167. package/docs/examples/dialog/size.vue +44 -44
  168. package/docs/examples/dialog/steps.vue +57 -57
  169. package/docs/examples/dialog-full/basic.vue +29 -29
  170. package/docs/examples/dialog-full/custom-buttons.vue +45 -45
  171. package/docs/examples/dialog-full/no-buttons.vue +18 -18
  172. package/docs/examples/dialog-full/no-header.vue +27 -27
  173. package/docs/examples/dialog-full/steps.vue +71 -71
  174. package/docs/examples/divider/basic.vue +52 -52
  175. package/docs/examples/drawer/basic.vue +35 -35
  176. package/docs/examples/drawer/custom-buttons.vue +34 -34
  177. package/docs/examples/drawer/direction.vue +47 -47
  178. package/docs/examples/drawer/mask.vue +36 -36
  179. package/docs/examples/drawer/no-buttons.vue +20 -20
  180. package/docs/examples/drawer/size.vue +28 -28
  181. package/docs/examples/dynamic-layer/basic.vue +33 -33
  182. package/docs/examples/dynamic-layer/custom-buttons.vue +43 -43
  183. package/docs/examples/dynamic-layer/form.vue +73 -73
  184. package/docs/examples/dynamic-layer/steps.vue +52 -52
  185. package/docs/examples/dynamic-layer/types.vue +40 -40
  186. package/docs/examples/echarts/basic.vue +31 -31
  187. package/docs/examples/echarts/dynamic.vue +43 -43
  188. package/docs/examples/echarts/line.vue +46 -46
  189. package/docs/examples/echarts/pie.vue +44 -44
  190. package/docs/examples/editor/basic.vue +15 -15
  191. package/docs/examples/form/basic.vue +665 -665
  192. package/docs/examples/form/init.vue +76 -76
  193. package/docs/examples/form/master-detail.vue +203 -203
  194. package/docs/examples/form/rule-format.vue +179 -179
  195. package/docs/examples/guid/basic.vue +10 -10
  196. package/docs/examples/guid/size.vue +13 -13
  197. package/docs/examples/hpanel/basic.vue +79 -79
  198. package/docs/examples/icon/basic.vue +9 -9
  199. package/docs/examples/icon/rotate-flip.vue +9 -9
  200. package/docs/examples/icon/size.vue +7 -7
  201. package/docs/examples/input/basic.vue +10 -10
  202. package/docs/examples/input/clearable.vue +12 -12
  203. package/docs/examples/input/disabled.vue +6 -6
  204. package/docs/examples/input/icon.vue +23 -23
  205. package/docs/examples/input/password.vue +18 -18
  206. package/docs/examples/input/size.vue +13 -13
  207. package/docs/examples/input/textarea.vue +25 -25
  208. package/docs/examples/input/word-limit.vue +28 -28
  209. package/docs/examples/input-button/basic.vue +33 -33
  210. package/docs/examples/input-code/basic.vue +29 -29
  211. package/docs/examples/input-color/basic.vue +10 -10
  212. package/docs/examples/input-color/disabled.vue +13 -13
  213. package/docs/examples/input-color/format.vue +17 -17
  214. package/docs/examples/input-color/no-alpha.vue +13 -13
  215. package/docs/examples/input-color/only-button.vue +15 -15
  216. package/docs/examples/input-color/predefine.vue +31 -31
  217. package/docs/examples/input-color/size.vue +15 -15
  218. package/docs/examples/input-layer/basic.vue +86 -86
  219. package/docs/examples/input-layer/render-vnode-page.vue +160 -160
  220. package/docs/examples/input-layer/render-vnode.vue +127 -127
  221. package/docs/examples/input-rows/basic.vue +73 -73
  222. package/docs/examples/input-rows/drag.vue +48 -48
  223. package/docs/examples/input-rows/layer-form.vue +85 -85
  224. package/docs/examples/input-rows/nested.vue +91 -91
  225. package/docs/examples/input-tag/basic.vue +27 -27
  226. package/docs/examples/input-tag/colors.vue +23 -23
  227. package/docs/examples/input-tag/readonly.vue +17 -17
  228. package/docs/examples/layer/basic.vue +43 -43
  229. package/docs/examples/layer/custom-buttons.vue +61 -61
  230. package/docs/examples/layer/drawer.vue +37 -37
  231. package/docs/examples/layer/full.vue +38 -38
  232. package/docs/examples/layer/modal.vue +34 -34
  233. package/docs/examples/layer/steps.vue +46 -46
  234. package/docs/examples/layer-form/basic.vue +76 -76
  235. package/docs/examples/layer-form/config.vue +82 -82
  236. package/docs/examples/layer-form/size.vue +72 -72
  237. package/docs/examples/layout/basic.vue +36 -36
  238. package/docs/examples/layout/custom-size.vue +50 -50
  239. package/docs/examples/layout/disable-move.vue +37 -37
  240. package/docs/examples/layout/hide-mid-when-narrow.vue +96 -96
  241. package/docs/examples/layout/min-size.vue +73 -73
  242. package/docs/examples/layout/percent-size.vue +80 -80
  243. package/docs/examples/layout/simple.vue +22 -22
  244. package/docs/examples/layout/top-side.vue +34 -34
  245. package/docs/examples/map/basic.vue +22 -22
  246. package/docs/examples/menu/basic.vue +58 -58
  247. package/docs/examples/menu/collapsed.vue +49 -49
  248. package/docs/examples/menu/horizontal.vue +44 -44
  249. package/docs/examples/menu/selection-test.vue +104 -104
  250. package/docs/examples/menu/theme.vue +46 -46
  251. package/docs/examples/menu/vertical.vue +46 -46
  252. package/docs/examples/number/advanced.vue +143 -143
  253. package/docs/examples/number/basic.vue +63 -63
  254. package/docs/examples/number/disabled.vue +49 -49
  255. package/docs/examples/number/size.vue +42 -42
  256. package/docs/examples/number/slots.vue +123 -123
  257. package/docs/examples/number/step-strictly.vue +41 -41
  258. package/docs/examples/number/step.vue +47 -47
  259. package/docs/examples/page/basic.vue +41 -41
  260. package/docs/examples/page/code-table-model.vue +428 -428
  261. package/docs/examples/page/dept-user-management.vue +211 -211
  262. package/docs/examples/page/init.vue +87 -87
  263. package/docs/examples/page/log.vue +453 -453
  264. package/docs/examples/page/user-management.vue +313 -313
  265. package/docs/examples/panel/tool-buttons.vue +18 -18
  266. package/docs/examples/radio/basic.vue +17 -17
  267. package/docs/examples/radio/button.vue +17 -17
  268. package/docs/examples/radio/color.vue +18 -18
  269. package/docs/examples/radio/disabled.vue +17 -17
  270. package/docs/examples/radio/size.vue +29 -29
  271. package/docs/examples/rate/basic.vue +24 -24
  272. package/docs/examples/rate/half.vue +24 -24
  273. package/docs/examples/rate/readonly.vue +11 -11
  274. package/docs/examples/rate/text.vue +37 -37
  275. package/docs/examples/select/basic.vue +16 -16
  276. package/docs/examples/select/clearable.vue +22 -22
  277. package/docs/examples/select/disabled.vue +31 -31
  278. package/docs/examples/select/filterable.vue +24 -24
  279. package/docs/examples/select/group.vue +23 -23
  280. package/docs/examples/select/icon.vue +16 -16
  281. package/docs/examples/select/multiple.vue +18 -18
  282. package/docs/examples/select/size.vue +39 -39
  283. package/docs/examples/slider/basic.vue +42 -42
  284. package/docs/examples/slider/disabled.vue +17 -17
  285. package/docs/examples/slider/marks.vue +30 -30
  286. package/docs/examples/slider/size.vue +37 -37
  287. package/docs/examples/slider/tooltip.vue +36 -36
  288. package/docs/examples/slider/vertical.vue +26 -26
  289. package/docs/examples/slider-captcha/basic.vue +44 -44
  290. package/docs/examples/slider-captcha/custom.vue +48 -48
  291. package/docs/examples/switch/basic.vue +16 -16
  292. package/docs/examples/switch/disabled.vue +13 -13
  293. package/docs/examples/switch/loading.vue +13 -13
  294. package/docs/examples/switch/size.vue +15 -15
  295. package/docs/examples/switch/text.vue +13 -13
  296. package/docs/examples/table/action-filter.vue +126 -126
  297. package/docs/examples/table/actions.vue +116 -116
  298. package/docs/examples/table/add-row.vue +103 -103
  299. package/docs/examples/table/basic.vue +168 -168
  300. package/docs/examples/table/checkbox-layout.vue +68 -68
  301. package/docs/examples/table/custom-layout.vue +115 -115
  302. package/docs/examples/table/dynamic-type.vue +73 -73
  303. package/docs/examples/table/editable.vue +262 -262
  304. package/docs/examples/table/field-selection.vue +87 -87
  305. package/docs/examples/table/frozen-column.vue +140 -140
  306. package/docs/examples/table/height-mode.vue +99 -99
  307. package/docs/examples/table/icon.vue +85 -85
  308. package/docs/examples/table/link.vue +66 -66
  309. package/docs/examples/table/multiple.vue +188 -188
  310. package/docs/examples/table/pagination.vue +151 -151
  311. package/docs/examples/table/single-selection.vue +64 -64
  312. package/docs/examples/table/sub-table-lazy.vue +97 -97
  313. package/docs/examples/table/sub-table.vue +103 -103
  314. package/docs/examples/table/tag.vue +43 -43
  315. package/docs/examples/table/tree-column.vue +119 -119
  316. package/docs/examples/table/tree-data.vue +141 -141
  317. package/docs/examples/table/tree-default-expand-all.vue +60 -60
  318. package/docs/examples/table/tree-lazy.vue +80 -80
  319. package/docs/examples/table/tree-set-selection.vue +75 -75
  320. package/docs/examples/table-panel/basic.vue +229 -229
  321. package/docs/examples/table-panel/batch-operations.vue +285 -285
  322. package/docs/examples/table-panel/button-visibility.vue +88 -88
  323. package/docs/examples/table-panel/filter.vue +219 -219
  324. package/docs/examples/table-panel/get-selection.vue +111 -111
  325. package/docs/examples/table-panel/mask.vue +151 -151
  326. package/docs/examples/table-panel/multiple-selection.vue +243 -243
  327. package/docs/examples/table-panel/pagination.vue +133 -133
  328. package/docs/examples/table-panel/sub-table-lazy.vue +118 -118
  329. package/docs/examples/table-panel/tree-parent-key.vue +67 -67
  330. package/docs/examples/tabs/basic.vue +98 -98
  331. package/docs/examples/time/base.vue +67 -67
  332. package/docs/examples/title/basic.vue +87 -87
  333. package/docs/examples/tree/accordion.vue +46 -46
  334. package/docs/examples/tree/basic.vue +50 -50
  335. package/docs/examples/tree/buttons.vue +53 -53
  336. package/docs/examples/tree/checkable.vue +52 -52
  337. package/docs/examples/tree/custom-keys.vue +39 -39
  338. package/docs/examples/tree/default-expanded.vue +52 -52
  339. package/docs/examples/tree/draggable.vue +29 -29
  340. package/docs/examples/tree/expand-on-click.vue +39 -39
  341. package/docs/examples/tree/flat-data.vue +20 -20
  342. package/docs/examples/tree/icon.vue +40 -40
  343. package/docs/examples/tree/load-data.vue +37 -37
  344. package/docs/examples/tree/methods.vue +74 -74
  345. package/docs/examples/tree/theme.vue +33 -33
  346. package/docs/examples/tree-select/basic.vue +47 -47
  347. package/docs/examples/upload/accept.vue +31 -31
  348. package/docs/examples/upload/basic.vue +12 -12
  349. package/docs/examples/upload/drag.vue +11 -11
  350. package/docs/examples/upload/image.vue +17 -17
  351. package/docs/examples/upload/limit.vue +20 -20
  352. package/docs/examples/upload/multiple.vue +17 -17
  353. package/docs/examples/upload/readonly.vue +17 -17
  354. package/docs/examples/utils/cipher.vue +160 -160
  355. package/docs/examples/utils/common.vue +153 -153
  356. package/docs/examples/utils/date.vue +56 -56
  357. package/docs/examples/utils/dom.vue +52 -52
  358. package/docs/examples/utils/is.vue +70 -70
  359. package/docs/examples/workflow/basic.vue +265 -265
  360. package/docs/examples/workflow-viewer/basic.vue +248 -248
  361. package/package.json +23 -23
@@ -1,33 +1,33 @@
1
- <template>
2
- <div class="demo-container">
3
- <el-space direction="vertical" :fill="true" style="width: 100%">
4
- <div>
5
- <span style="margin-right: 10px">选择语言模式:</span>
6
- <el-radio-group v-model="mode">
7
- <el-radio value="application/javascript">JavaScript</el-radio>
8
- <el-radio value="text/x-sql">SQL</el-radio>
9
- </el-radio-group>
10
- </div>
11
- <j-code-mirror v-model="code" :height="250" :mode="mode" />
12
- </el-space>
13
- </div>
14
- </template>
15
-
16
- <script setup lang="ts">
17
- import { ref, watch } from 'vue'
18
-
19
- const mode = ref('application/javascript')
20
- const code = ref(`function greet(name) {
21
- return 'Hello, ' + name + '!';
22
- }`)
23
-
24
- watch(mode, (newMode) => {
25
- if (newMode === 'text/x-sql') {
26
- code.value = 'SELECT * FROM users WHERE status = "active";'
27
- } else {
28
- code.value = `function greet(name) {
29
- return 'Hello, ' + name + '!';
30
- }`
31
- }
32
- })
33
- </script>
1
+ <template>
2
+ <div class="demo-container">
3
+ <el-space direction="vertical" :fill="true" style="width: 100%">
4
+ <div>
5
+ <span style="margin-right: 10px">选择语言模式:</span>
6
+ <el-radio-group v-model="mode">
7
+ <el-radio value="application/javascript">JavaScript</el-radio>
8
+ <el-radio value="text/x-sql">SQL</el-radio>
9
+ </el-radio-group>
10
+ </div>
11
+ <j-code-mirror v-model="code" :height="250" :mode="mode" />
12
+ </el-space>
13
+ </div>
14
+ </template>
15
+
16
+ <script setup lang="ts">
17
+ import { ref, watch } from 'vue'
18
+
19
+ const mode = ref('application/javascript')
20
+ const code = ref(`function greet(name) {
21
+ return 'Hello, ' + name + '!';
22
+ }`)
23
+
24
+ watch(mode, (newMode) => {
25
+ if (newMode === 'text/x-sql') {
26
+ code.value = 'SELECT * FROM users WHERE status = "active";'
27
+ } else {
28
+ code.value = `function greet(name) {
29
+ return 'Hello, ' + name + '!';
30
+ }`
31
+ }
32
+ })
33
+ </script>
@@ -1,14 +1,14 @@
1
- <template>
2
- <div>
3
- <j-code-mirror :model-value="code" :height="200" mode="application/javascript" :readonly="true" />
4
- </div>
5
- </template>
6
-
7
- <script setup lang="ts">
8
- import { ref } from 'vue'
9
-
10
- const code = ref(`function hello() {
11
- console.log('Hello, World!');
12
- return 'This is readonly mode';
13
- }`)
14
- </script>
1
+ <template>
2
+ <div>
3
+ <j-code-mirror :model-value="code" :height="200" mode="application/javascript" :readonly="true" />
4
+ </div>
5
+ </template>
6
+
7
+ <script setup lang="ts">
8
+ import { ref } from 'vue'
9
+
10
+ const code = ref(`function hello() {
11
+ console.log('Hello, World!');
12
+ return 'This is readonly mode';
13
+ }`)
14
+ </script>
@@ -1,82 +1,82 @@
1
- <template>
2
- <div class="collapse-demo">
3
- <div class="demo-item">
4
- <p>基础用法</p>
5
- <j-collapse v-model="activeNames1">
6
- <el-collapse-item title="一致性 Consistency" name="1">
7
- <div>与现实生活一致:与现实生活的流程、逻辑保持一致,遵循用户习惯的语言和概念;</div>
8
- <div>
9
- 在界面中一致:所有的元素和结构需保持一致,比如:设计样式、图标和文本、元素的位置等。
10
- </div>
11
- </el-collapse-item>
12
- <el-collapse-item title="反馈 Feedback" name="2">
13
- <div>控制反馈:通过界面样式和交互动效让用户可以清晰的感知自己的操作;</div>
14
- <div>页面反馈:操作后,通过页面元素的变化清晰地展现当前状态。</div>
15
- </el-collapse-item>
16
- <el-collapse-item title="效率 Efficiency" name="3">
17
- <div>简化流程:设计简洁直观的操作流程;</div>
18
- <div>清晰明确:语言表达清晰且表意明确,让用户快速理解进而作出决策;</div>
19
- <div>帮助用户识别:界面简单直白,让用户快速识别而非回忆,减少用户记忆负担。</div>
20
- </el-collapse-item>
21
- <el-collapse-item title="可控 Controllability" name="4">
22
- <div>用户决策:根据场景可给予用户操作建议或安全提示,但不能代替用户进行决策;</div>
23
- <div>结果可控:用户可以自由的进行操作,包括撤销、回退和终止当前操作等。</div>
24
- </el-collapse-item>
25
- </j-collapse>
26
- </div>
27
-
28
- <div class="demo-item">
29
- <p>手风琴效果</p>
30
- <j-collapse v-model="activeName2" accordion>
31
- <el-collapse-item title="一致性 Consistency" name="1">
32
- <div>与现实生活一致:与现实生活的流程、逻辑保持一致,遵循用户习惯的语言和概念;</div>
33
- <div>
34
- 在界面中一致:所有的元素和结构需保持一致,比如:设计样式、图标和文本、元素的位置等。
35
- </div>
36
- </el-collapse-item>
37
- <el-collapse-item title="反馈 Feedback" name="2">
38
- <div>控制反馈:通过界面样式和交互动效让用户可以清晰的感知自己的操作;</div>
39
- <div>页面反馈:操作后,通过页面元素的变化清晰地展现当前状态。</div>
40
- </el-collapse-item>
41
- <el-collapse-item title="效率 Efficiency" name="3">
42
- <div>简化流程:设计简洁直观的操作流程;</div>
43
- <div>清晰明确:语言表达清晰且表意明确,让用户快速理解进而作出决策;</div>
44
- <div>帮助用户识别:界面简单直白,让用户快速识别而非回忆,减少用户记忆负担。</div>
45
- </el-collapse-item>
46
- <el-collapse-item title="可控 Controllability" name="4">
47
- <div>用户决策:根据场景可给予用户操作建议或安全提示,但不能代替用户进行决策;</div>
48
- <div>结果可控:用户可以自由的进行操作,包括撤销、回退和终止当前操作等。</div>
49
- </el-collapse-item>
50
- </j-collapse>
51
- </div>
52
- </div>
53
- </template>
54
-
55
- <script setup lang="ts">
56
- import { ref } from 'vue'
57
-
58
- const activeNames1 = ref(['1'])
59
- const activeName2 = ref('1')
60
- </script>
61
-
62
- <style scoped>
63
- .collapse-demo {
64
- display: flex;
65
- flex-direction: column;
66
- gap: 24px;
67
- }
68
-
69
- .demo-item p {
70
- margin: 0 0 12px;
71
- font-size: 14px;
72
- color: var(--j-color-text-2);
73
- font-weight: 500;
74
- }
75
-
76
- .demo-item {
77
- position: relative;
78
- width: 100%;
79
- display: flex;
80
- flex-direction: column;
81
- }
82
- </style>
1
+ <template>
2
+ <div class="collapse-demo">
3
+ <div class="demo-item">
4
+ <p>基础用法</p>
5
+ <j-collapse v-model="activeNames1">
6
+ <el-collapse-item title="一致性 Consistency" name="1">
7
+ <div>与现实生活一致:与现实生活的流程、逻辑保持一致,遵循用户习惯的语言和概念;</div>
8
+ <div>
9
+ 在界面中一致:所有的元素和结构需保持一致,比如:设计样式、图标和文本、元素的位置等。
10
+ </div>
11
+ </el-collapse-item>
12
+ <el-collapse-item title="反馈 Feedback" name="2">
13
+ <div>控制反馈:通过界面样式和交互动效让用户可以清晰的感知自己的操作;</div>
14
+ <div>页面反馈:操作后,通过页面元素的变化清晰地展现当前状态。</div>
15
+ </el-collapse-item>
16
+ <el-collapse-item title="效率 Efficiency" name="3">
17
+ <div>简化流程:设计简洁直观的操作流程;</div>
18
+ <div>清晰明确:语言表达清晰且表意明确,让用户快速理解进而作出决策;</div>
19
+ <div>帮助用户识别:界面简单直白,让用户快速识别而非回忆,减少用户记忆负担。</div>
20
+ </el-collapse-item>
21
+ <el-collapse-item title="可控 Controllability" name="4">
22
+ <div>用户决策:根据场景可给予用户操作建议或安全提示,但不能代替用户进行决策;</div>
23
+ <div>结果可控:用户可以自由的进行操作,包括撤销、回退和终止当前操作等。</div>
24
+ </el-collapse-item>
25
+ </j-collapse>
26
+ </div>
27
+
28
+ <div class="demo-item">
29
+ <p>手风琴效果</p>
30
+ <j-collapse v-model="activeName2" accordion>
31
+ <el-collapse-item title="一致性 Consistency" name="1">
32
+ <div>与现实生活一致:与现实生活的流程、逻辑保持一致,遵循用户习惯的语言和概念;</div>
33
+ <div>
34
+ 在界面中一致:所有的元素和结构需保持一致,比如:设计样式、图标和文本、元素的位置等。
35
+ </div>
36
+ </el-collapse-item>
37
+ <el-collapse-item title="反馈 Feedback" name="2">
38
+ <div>控制反馈:通过界面样式和交互动效让用户可以清晰的感知自己的操作;</div>
39
+ <div>页面反馈:操作后,通过页面元素的变化清晰地展现当前状态。</div>
40
+ </el-collapse-item>
41
+ <el-collapse-item title="效率 Efficiency" name="3">
42
+ <div>简化流程:设计简洁直观的操作流程;</div>
43
+ <div>清晰明确:语言表达清晰且表意明确,让用户快速理解进而作出决策;</div>
44
+ <div>帮助用户识别:界面简单直白,让用户快速识别而非回忆,减少用户记忆负担。</div>
45
+ </el-collapse-item>
46
+ <el-collapse-item title="可控 Controllability" name="4">
47
+ <div>用户决策:根据场景可给予用户操作建议或安全提示,但不能代替用户进行决策;</div>
48
+ <div>结果可控:用户可以自由的进行操作,包括撤销、回退和终止当前操作等。</div>
49
+ </el-collapse-item>
50
+ </j-collapse>
51
+ </div>
52
+ </div>
53
+ </template>
54
+
55
+ <script setup lang="ts">
56
+ import { ref } from 'vue'
57
+
58
+ const activeNames1 = ref(['1'])
59
+ const activeName2 = ref('1')
60
+ </script>
61
+
62
+ <style scoped>
63
+ .collapse-demo {
64
+ display: flex;
65
+ flex-direction: column;
66
+ gap: 24px;
67
+ }
68
+
69
+ .demo-item p {
70
+ margin: 0 0 12px;
71
+ font-size: 14px;
72
+ color: var(--j-color-text-2);
73
+ font-weight: 500;
74
+ }
75
+
76
+ .demo-item {
77
+ position: relative;
78
+ width: 100%;
79
+ display: flex;
80
+ flex-direction: column;
81
+ }
82
+ </style>
@@ -1,7 +1,7 @@
1
- <template>
2
- <div>
3
- <j-comp type="j-button" :config="{ type: 'primary', label: '我是通过 JComp 渲染的按钮' }" />
4
- </div>
5
- </template>
6
-
7
- <script setup lang="ts"></script>
1
+ <template>
2
+ <div>
3
+ <j-comp type="j-button" :config="{ type: 'primary', label: '我是通过 JComp 渲染的按钮' }" />
4
+ </div>
5
+ </template>
6
+
7
+ <script setup lang="ts"></script>
@@ -1,38 +1,38 @@
1
- <template>
2
- <j-comp
3
- type="j-collapse"
4
- :children="[
5
- {
6
- type: 'el-collapse-item',
7
- config: {
8
- label: 'Panel 1',
9
- },
10
- children: [
11
- {
12
- type: 'j-button',
13
- config: {
14
- label: 'Button in Panel 1',
15
- },
16
- },
17
- ],
18
- },
19
- {
20
- type: 'el-collapse-item',
21
- config: {
22
- label: 'Panel 2',
23
- active: true,
24
- },
25
- children: [
26
- {
27
- type: 'j-button',
28
- config: {
29
- label: 'Button in Panel 2 (Active by default)',
30
- },
31
- },
32
- ],
33
- },
34
- ]"
35
- />
36
- </template>
37
-
38
- <script setup lang="ts"></script>
1
+ <template>
2
+ <j-comp
3
+ type="j-collapse"
4
+ :children="[
5
+ {
6
+ type: 'el-collapse-item',
7
+ config: {
8
+ label: 'Panel 1',
9
+ },
10
+ children: [
11
+ {
12
+ type: 'j-button',
13
+ config: {
14
+ label: 'Button in Panel 1',
15
+ },
16
+ },
17
+ ],
18
+ },
19
+ {
20
+ type: 'el-collapse-item',
21
+ config: {
22
+ label: 'Panel 2',
23
+ active: true,
24
+ },
25
+ children: [
26
+ {
27
+ type: 'j-button',
28
+ config: {
29
+ label: 'Button in Panel 2 (Active by default)',
30
+ },
31
+ },
32
+ ],
33
+ },
34
+ ]"
35
+ />
36
+ </template>
37
+
38
+ <script setup lang="ts"></script>
@@ -1,38 +1,38 @@
1
- <template>
2
- <j-comp
3
- type="j-tabs"
4
- :children="[
5
- {
6
- type: 'el-tab-pane',
7
- config: {
8
- label: 'Tab 1',
9
- },
10
- children: [
11
- {
12
- type: 'j-button',
13
- config: {
14
- label: 'Button in Tab 1',
15
- },
16
- },
17
- ],
18
- },
19
- {
20
- type: 'el-tab-pane',
21
- config: {
22
- label: 'Tab 2',
23
- active: true,
24
- },
25
- children: [
26
- {
27
- type: 'j-button',
28
- config: {
29
- label: 'Button in Tab 2 (Active by default)',
30
- },
31
- },
32
- ],
33
- },
34
- ]"
35
- />
36
- </template>
37
-
38
- <script setup lang="ts"></script>
1
+ <template>
2
+ <j-comp
3
+ type="j-tabs"
4
+ :children="[
5
+ {
6
+ type: 'el-tab-pane',
7
+ config: {
8
+ label: 'Tab 1',
9
+ },
10
+ children: [
11
+ {
12
+ type: 'j-button',
13
+ config: {
14
+ label: 'Button in Tab 1',
15
+ },
16
+ },
17
+ ],
18
+ },
19
+ {
20
+ type: 'el-tab-pane',
21
+ config: {
22
+ label: 'Tab 2',
23
+ active: true,
24
+ },
25
+ children: [
26
+ {
27
+ type: 'j-button',
28
+ config: {
29
+ label: 'Button in Tab 2 (Active by default)',
30
+ },
31
+ },
32
+ ],
33
+ },
34
+ ]"
35
+ />
36
+ </template>
37
+
38
+ <script setup lang="ts"></script>
@@ -1,101 +1,101 @@
1
- <template>
2
- <div class="count-demo">
3
- <div class="demo-item">
4
- <p>基础计算 (1000 + 200):</p>
5
- <j-count :format-json="formJSON" />
6
- </div>
7
-
8
- <div class="demo-item">
9
- <p>千分位展示:</p>
10
- <j-count :format-json="formJSON" thousand-separator />
11
- </div>
12
-
13
- <div class="demo-item">
14
- <p>人民币大写:</p>
15
- <j-count :format-json="formJSON" is-chinese />
16
- </div>
17
-
18
- <div class="demo-item">
19
- <p>保留两位小数:</p>
20
- <j-count :format-json="formJSON" :decimal="2" />
21
- </div>
22
-
23
- <!-- 计算公式 -->
24
- <div class="demo-item">
25
- <p>配置计算公式来计算结果:</p>
26
- <j-input-count v-model="value" :list="list" @change="handleChange" />
27
- <j-count :format-json="value" />
28
- </div>
29
- </div>
30
- </template>
31
-
32
- <script setup lang="ts">
33
- import { useFormProvide } from '@a2simcode/ui'
34
- import { ref } from 'vue'
35
-
36
-
37
- // 模拟表单提供者,因为 Count 组件内部依赖注入
38
- const getValue = ({ id, i }: { id: string; i?: number }) => {
39
- const mockData: Record<string, number> = {
40
- price: 100,
41
- quantity: 3,
42
- 'table1.price1': [100, 200],
43
- 'table1.quantity1': [1, 2]
44
- }
45
- return mockData[id] || 0
46
- }
47
- //@ts-ignore
48
- useFormProvide({ getValue: getValue })
49
-
50
- const formJSON =
51
- '[{"value":1,"type":"num"},{"value":0,"type":"num"},{"value":0,"type":"num"},{"value":0,"type":"num"},{"value":"+","type":"num"},{"value":2,"type":"num"},{"value":0,"type":"num"},{"value":0,"type":"num"}]'
52
-
53
-
54
- const value = ref('')
55
- const list = [
56
- {
57
- label: '主表组件',
58
- children: [
59
- {
60
- label: '价格',
61
- value: 'price',
62
- },
63
- {
64
- label: '数量',
65
- value: 'quantity',
66
- },
67
- ],
68
- },
69
- {
70
- label: '子表组件',
71
- children: [
72
- {
73
- label: '价格',
74
- value: 'table1.price1',
75
- },
76
- {
77
- label: '数量',
78
- value: 'table1.quantity1',
79
- },
80
- ],
81
- },
82
- ]
83
-
84
- const countRes = ref('')
85
- const handleChange = (list: any[]) => {
86
- console.log(list, 'change', value)
87
- }
88
- </script>
89
-
90
- <style scoped>
91
- .count-demo {
92
- display: flex;
93
- flex-direction: column;
94
- gap: 20px;
95
- }
96
- .demo-item p {
97
- margin-bottom: 8px;
98
- font-size: 14px;
99
- color: var(--j-color-text-2);
100
- }
101
- </style>
1
+ <template>
2
+ <div class="count-demo">
3
+ <div class="demo-item">
4
+ <p>基础计算 (1000 + 200):</p>
5
+ <j-count :format-json="formJSON" />
6
+ </div>
7
+
8
+ <div class="demo-item">
9
+ <p>千分位展示:</p>
10
+ <j-count :format-json="formJSON" thousand-separator />
11
+ </div>
12
+
13
+ <div class="demo-item">
14
+ <p>人民币大写:</p>
15
+ <j-count :format-json="formJSON" is-chinese />
16
+ </div>
17
+
18
+ <div class="demo-item">
19
+ <p>保留两位小数:</p>
20
+ <j-count :format-json="formJSON" :decimal="2" />
21
+ </div>
22
+
23
+ <!-- 计算公式 -->
24
+ <div class="demo-item">
25
+ <p>配置计算公式来计算结果:</p>
26
+ <j-input-count v-model="value" :list="list" @change="handleChange" />
27
+ <j-count :format-json="value" />
28
+ </div>
29
+ </div>
30
+ </template>
31
+
32
+ <script setup lang="ts">
33
+ import { useFormProvide } from '@a2simcode/ui'
34
+ import { ref } from 'vue'
35
+
36
+
37
+ // 模拟表单提供者,因为 Count 组件内部依赖注入
38
+ const getValue = ({ id, i }: { id: string; i?: number }) => {
39
+ const mockData: Record<string, number> = {
40
+ price: 100,
41
+ quantity: 3,
42
+ 'table1.price1': [100, 200],
43
+ 'table1.quantity1': [1, 2]
44
+ }
45
+ return mockData[id] || 0
46
+ }
47
+ //@ts-ignore
48
+ useFormProvide({ getValue: getValue })
49
+
50
+ const formJSON =
51
+ '[{"value":1,"type":"num"},{"value":0,"type":"num"},{"value":0,"type":"num"},{"value":0,"type":"num"},{"value":"+","type":"num"},{"value":2,"type":"num"},{"value":0,"type":"num"},{"value":0,"type":"num"}]'
52
+
53
+
54
+ const value = ref('')
55
+ const list = [
56
+ {
57
+ label: '主表组件',
58
+ children: [
59
+ {
60
+ label: '价格',
61
+ value: 'price',
62
+ },
63
+ {
64
+ label: '数量',
65
+ value: 'quantity',
66
+ },
67
+ ],
68
+ },
69
+ {
70
+ label: '子表组件',
71
+ children: [
72
+ {
73
+ label: '价格',
74
+ value: 'table1.price1',
75
+ },
76
+ {
77
+ label: '数量',
78
+ value: 'table1.quantity1',
79
+ },
80
+ ],
81
+ },
82
+ ]
83
+
84
+ const countRes = ref('')
85
+ const handleChange = (list: any[]) => {
86
+ console.log(list, 'change', value)
87
+ }
88
+ </script>
89
+
90
+ <style scoped>
91
+ .count-demo {
92
+ display: flex;
93
+ flex-direction: column;
94
+ gap: 20px;
95
+ }
96
+ .demo-item p {
97
+ margin-bottom: 8px;
98
+ font-size: 14px;
99
+ color: var(--j-color-text-2);
100
+ }
101
+ </style>