@a2simcode/ui 0.0.188 → 0.0.189

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 (351) 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/input-layer/index.d.ts +2 -0
  6. package/dist/components/input-layer/src/input-layer.vue.d.ts +2 -0
  7. package/dist/components/table-panel/index.d.ts +3 -0
  8. package/dist/components/table-panel/src/table-panel.vue.d.ts +8 -0
  9. package/dist/simcode-ui.es.js +684 -679
  10. package/dist/simcode-ui.umd.js +2 -2
  11. package/dist/stats.html +1 -1
  12. package/dist/ui.css +1 -1
  13. package/docs/components/autocomplete.md +89 -89
  14. package/docs/components/barcode.md +101 -101
  15. package/docs/components/button-select.md +24 -24
  16. package/docs/components/button.md +117 -117
  17. package/docs/components/buttons.md +119 -119
  18. package/docs/components/cascader-select.md +114 -114
  19. package/docs/components/checkbox.md +114 -114
  20. package/docs/components/code-mirror.md +85 -85
  21. package/docs/components/collapse.md +26 -26
  22. package/docs/components/comp.md +71 -71
  23. package/docs/components/count-up.md +24 -24
  24. package/docs/components/count.md +24 -24
  25. package/docs/components/data-panel.md +24 -24
  26. package/docs/components/date.md +76 -76
  27. package/docs/components/dialog-full.md +112 -112
  28. package/docs/components/dialog.md +127 -127
  29. package/docs/components/divider.md +24 -24
  30. package/docs/components/drawer.md +127 -127
  31. package/docs/components/dynamic-layer.md +118 -118
  32. package/docs/components/echarts.md +72 -72
  33. package/docs/components/editor.md +24 -24
  34. package/docs/components/form.md +72 -72
  35. package/docs/components/guid.md +39 -39
  36. package/docs/components/hpanel.md +24 -24
  37. package/docs/components/icon.md +56 -56
  38. package/docs/components/input-button.md +24 -24
  39. package/docs/components/input-code.md +24 -24
  40. package/docs/components/input-color.md +114 -114
  41. package/docs/components/input-layer.md +56 -56
  42. package/docs/components/input-rows.md +370 -370
  43. package/docs/components/input-tag.md +50 -50
  44. package/docs/components/input.md +129 -129
  45. package/docs/components/layer-form.md +61 -61
  46. package/docs/components/layer.md +127 -127
  47. package/docs/components/layout.md +132 -132
  48. package/docs/components/map.md +24 -24
  49. package/docs/components/menu.md +121 -121
  50. package/docs/components/meta/button.ts +212 -212
  51. package/docs/components/meta/buttons.ts +76 -76
  52. package/docs/components/meta/code-mirror.ts +108 -108
  53. package/docs/components/meta/comp.ts +236 -236
  54. package/docs/components/meta/date.ts +267 -267
  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 +382 -382
  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/map.ts +68 -68
  66. package/docs/components/meta/panel.ts +152 -152
  67. package/docs/components/meta/slider.ts +270 -270
  68. package/docs/components/meta/table-panel.ts +237 -237
  69. package/docs/components/meta/table.ts +391 -391
  70. package/docs/components/meta/tabs.ts +146 -146
  71. package/docs/components/meta/title.ts +91 -91
  72. package/docs/components/meta/tree-select.ts +199 -199
  73. package/docs/components/meta/tree.ts +219 -219
  74. package/docs/components/meta/vpanel.ts +19 -19
  75. package/docs/components/meta/workflow-viewer.ts +55 -55
  76. package/docs/components/number.md +124 -124
  77. package/docs/components/page.md +102 -102
  78. package/docs/components/panel.md +37 -37
  79. package/docs/components/radio.md +87 -87
  80. package/docs/components/rate.md +71 -71
  81. package/docs/components/select.md +133 -133
  82. package/docs/components/slider-captcha.md +41 -41
  83. package/docs/components/slider.md +101 -101
  84. package/docs/components/switch.md +90 -90
  85. package/docs/components/table-panel.md +251 -251
  86. package/docs/components/table.md +391 -391
  87. package/docs/components/tabs.md +26 -26
  88. package/docs/components/title.md +24 -24
  89. package/docs/components/tree.md +207 -207
  90. package/docs/components/upload.md +117 -117
  91. package/docs/components/workflow-viewer.md +21 -21
  92. package/docs/components/workflow.md +21 -21
  93. package/docs/examples/autocomplete/advanced.vue +35 -35
  94. package/docs/examples/autocomplete/basic.vue +32 -32
  95. package/docs/examples/autocomplete/clearable.vue +33 -33
  96. package/docs/examples/autocomplete/custom-template.vue +49 -49
  97. package/docs/examples/autocomplete/disabled.vue +33 -33
  98. package/docs/examples/autocomplete/icon.vue +37 -37
  99. package/docs/examples/barcode/all-types.vue +380 -380
  100. package/docs/examples/barcode/basic.vue +14 -14
  101. package/docs/examples/barcode/props-appearance.vue +243 -243
  102. package/docs/examples/barcode/props-geometry.vue +143 -143
  103. package/docs/examples/barcode/props-logic.vue +216 -216
  104. package/docs/examples/barcode/props-symbology.vue +199 -199
  105. package/docs/examples/barcode/props-text.vue +268 -268
  106. package/docs/examples/button/basic.vue +7 -7
  107. package/docs/examples/button/danger-ghost.vue +17 -17
  108. package/docs/examples/button/disabled.vue +10 -10
  109. package/docs/examples/button/loading.vue +6 -6
  110. package/docs/examples/button/shape.vue +7 -7
  111. package/docs/examples/button/size.vue +14 -14
  112. package/docs/examples/button/type.vue +10 -10
  113. package/docs/examples/button-select/basic.vue +19 -19
  114. package/docs/examples/buttons/basic.vue +62 -62
  115. package/docs/examples/buttons/disabled.vue +36 -36
  116. package/docs/examples/buttons/dropdown.vue +63 -63
  117. package/docs/examples/buttons/group.vue +52 -52
  118. package/docs/examples/buttons/link.vue +47 -47
  119. package/docs/examples/buttons/popup.vue +39 -39
  120. package/docs/examples/buttons/size.vue +45 -45
  121. package/docs/examples/cascader-select/basic.vue +28 -28
  122. package/docs/examples/cascader-select/clearable.vue +34 -34
  123. package/docs/examples/cascader-select/disabled.vue +43 -43
  124. package/docs/examples/cascader-select/filterable.vue +37 -37
  125. package/docs/examples/cascader-select/methods.vue +84 -84
  126. package/docs/examples/cascader-select/multiple.vue +38 -38
  127. package/docs/examples/cascader-select/slot.vue +45 -45
  128. package/docs/examples/checkbox/basic.vue +18 -18
  129. package/docs/examples/checkbox/button.vue +19 -19
  130. package/docs/examples/checkbox/color.vue +25 -25
  131. package/docs/examples/checkbox/disabled.vue +17 -17
  132. package/docs/examples/checkbox/min-max.vue +20 -20
  133. package/docs/examples/checkbox/mixed.vue +56 -56
  134. package/docs/examples/checkbox/size.vue +28 -28
  135. package/docs/examples/code-mirror/basic.vue +11 -11
  136. package/docs/examples/code-mirror/events.vue +42 -42
  137. package/docs/examples/code-mirror/height.vue +25 -25
  138. package/docs/examples/code-mirror/mode.vue +33 -33
  139. package/docs/examples/code-mirror/readonly.vue +14 -14
  140. package/docs/examples/collapse/basic.vue +82 -82
  141. package/docs/examples/comp/basic.vue +7 -7
  142. package/docs/examples/comp/collapse.vue +38 -38
  143. package/docs/examples/comp/tabs.vue +38 -38
  144. package/docs/examples/count/basic.vue +101 -101
  145. package/docs/examples/count-up/basic.vue +89 -89
  146. package/docs/examples/data-panel/basic.vue +110 -110
  147. package/docs/examples/date/basic.vue +73 -73
  148. package/docs/examples/date/default-value.vue +59 -59
  149. package/docs/examples/date/format.vue +75 -75
  150. package/docs/examples/date/range.vue +66 -66
  151. package/docs/examples/date/types.vue +79 -79
  152. package/docs/examples/decorated-title/basic.vue +31 -31
  153. package/docs/examples/dialog/basic.vue +36 -36
  154. package/docs/examples/dialog/custom-buttons.vue +44 -44
  155. package/docs/examples/dialog/fullscreen.vue +23 -23
  156. package/docs/examples/dialog/no-mask.vue +17 -17
  157. package/docs/examples/dialog/size.vue +44 -44
  158. package/docs/examples/dialog/steps.vue +57 -57
  159. package/docs/examples/dialog-full/basic.vue +29 -29
  160. package/docs/examples/dialog-full/custom-buttons.vue +45 -45
  161. package/docs/examples/dialog-full/no-buttons.vue +18 -18
  162. package/docs/examples/dialog-full/no-header.vue +27 -27
  163. package/docs/examples/dialog-full/steps.vue +71 -71
  164. package/docs/examples/divider/basic.vue +52 -52
  165. package/docs/examples/drawer/basic.vue +35 -35
  166. package/docs/examples/drawer/custom-buttons.vue +34 -34
  167. package/docs/examples/drawer/direction.vue +47 -47
  168. package/docs/examples/drawer/mask.vue +36 -36
  169. package/docs/examples/drawer/no-buttons.vue +20 -20
  170. package/docs/examples/drawer/size.vue +28 -28
  171. package/docs/examples/dynamic-layer/basic.vue +33 -33
  172. package/docs/examples/dynamic-layer/custom-buttons.vue +43 -43
  173. package/docs/examples/dynamic-layer/form.vue +73 -73
  174. package/docs/examples/dynamic-layer/steps.vue +52 -52
  175. package/docs/examples/dynamic-layer/types.vue +40 -40
  176. package/docs/examples/echarts/basic.vue +31 -31
  177. package/docs/examples/echarts/dynamic.vue +43 -43
  178. package/docs/examples/echarts/line.vue +46 -46
  179. package/docs/examples/echarts/pie.vue +44 -44
  180. package/docs/examples/editor/basic.vue +15 -15
  181. package/docs/examples/form/basic.vue +665 -665
  182. package/docs/examples/form/init.vue +76 -76
  183. package/docs/examples/form/master-detail.vue +203 -203
  184. package/docs/examples/form/rule-format.vue +179 -179
  185. package/docs/examples/guid/basic.vue +10 -10
  186. package/docs/examples/guid/size.vue +13 -13
  187. package/docs/examples/hpanel/basic.vue +79 -79
  188. package/docs/examples/icon/basic.vue +9 -9
  189. package/docs/examples/icon/rotate-flip.vue +9 -9
  190. package/docs/examples/icon/size.vue +7 -7
  191. package/docs/examples/input/basic.vue +10 -10
  192. package/docs/examples/input/clearable.vue +12 -12
  193. package/docs/examples/input/disabled.vue +6 -6
  194. package/docs/examples/input/icon.vue +23 -23
  195. package/docs/examples/input/password.vue +18 -18
  196. package/docs/examples/input/size.vue +13 -13
  197. package/docs/examples/input/textarea.vue +25 -25
  198. package/docs/examples/input/word-limit.vue +28 -28
  199. package/docs/examples/input-button/basic.vue +33 -33
  200. package/docs/examples/input-code/basic.vue +29 -29
  201. package/docs/examples/input-color/basic.vue +10 -10
  202. package/docs/examples/input-color/disabled.vue +13 -13
  203. package/docs/examples/input-color/format.vue +17 -17
  204. package/docs/examples/input-color/no-alpha.vue +13 -13
  205. package/docs/examples/input-color/only-button.vue +15 -15
  206. package/docs/examples/input-color/predefine.vue +31 -31
  207. package/docs/examples/input-color/size.vue +15 -15
  208. package/docs/examples/input-layer/basic.vue +86 -86
  209. package/docs/examples/input-layer/render-vnode-page.vue +160 -160
  210. package/docs/examples/input-layer/render-vnode.vue +127 -127
  211. package/docs/examples/input-rows/basic.vue +73 -73
  212. package/docs/examples/input-rows/drag.vue +48 -48
  213. package/docs/examples/input-rows/layer-form.vue +85 -85
  214. package/docs/examples/input-rows/nested.vue +91 -91
  215. package/docs/examples/input-tag/basic.vue +27 -27
  216. package/docs/examples/input-tag/colors.vue +23 -23
  217. package/docs/examples/input-tag/readonly.vue +17 -17
  218. package/docs/examples/layer/basic.vue +43 -43
  219. package/docs/examples/layer/custom-buttons.vue +61 -61
  220. package/docs/examples/layer/drawer.vue +37 -37
  221. package/docs/examples/layer/full.vue +38 -38
  222. package/docs/examples/layer/modal.vue +34 -34
  223. package/docs/examples/layer/steps.vue +46 -46
  224. package/docs/examples/layer-form/basic.vue +76 -76
  225. package/docs/examples/layer-form/config.vue +82 -82
  226. package/docs/examples/layer-form/size.vue +72 -72
  227. package/docs/examples/layout/basic.vue +36 -36
  228. package/docs/examples/layout/custom-size.vue +50 -50
  229. package/docs/examples/layout/disable-move.vue +37 -37
  230. package/docs/examples/layout/hide-mid-when-narrow.vue +96 -96
  231. package/docs/examples/layout/min-size.vue +73 -73
  232. package/docs/examples/layout/percent-size.vue +80 -80
  233. package/docs/examples/layout/simple.vue +22 -22
  234. package/docs/examples/layout/top-side.vue +34 -34
  235. package/docs/examples/map/basic.vue +22 -22
  236. package/docs/examples/menu/basic.vue +58 -58
  237. package/docs/examples/menu/collapsed.vue +49 -49
  238. package/docs/examples/menu/horizontal.vue +44 -44
  239. package/docs/examples/menu/selection-test.vue +104 -104
  240. package/docs/examples/menu/theme.vue +46 -46
  241. package/docs/examples/menu/vertical.vue +46 -46
  242. package/docs/examples/number/advanced.vue +143 -143
  243. package/docs/examples/number/basic.vue +63 -63
  244. package/docs/examples/number/disabled.vue +49 -49
  245. package/docs/examples/number/size.vue +42 -42
  246. package/docs/examples/number/slots.vue +123 -123
  247. package/docs/examples/number/step-strictly.vue +41 -41
  248. package/docs/examples/number/step.vue +47 -47
  249. package/docs/examples/page/basic.vue +41 -41
  250. package/docs/examples/page/code-table-model.vue +428 -428
  251. package/docs/examples/page/dept-user-management.vue +211 -211
  252. package/docs/examples/page/init.vue +87 -87
  253. package/docs/examples/page/log.vue +453 -453
  254. package/docs/examples/page/user-management.vue +313 -313
  255. package/docs/examples/panel/tool-buttons.vue +18 -18
  256. package/docs/examples/radio/basic.vue +17 -17
  257. package/docs/examples/radio/button.vue +17 -17
  258. package/docs/examples/radio/color.vue +18 -18
  259. package/docs/examples/radio/disabled.vue +17 -17
  260. package/docs/examples/radio/size.vue +29 -29
  261. package/docs/examples/rate/basic.vue +24 -24
  262. package/docs/examples/rate/half.vue +24 -24
  263. package/docs/examples/rate/readonly.vue +11 -11
  264. package/docs/examples/rate/text.vue +37 -37
  265. package/docs/examples/select/basic.vue +16 -16
  266. package/docs/examples/select/clearable.vue +22 -22
  267. package/docs/examples/select/disabled.vue +31 -31
  268. package/docs/examples/select/filterable.vue +24 -24
  269. package/docs/examples/select/group.vue +23 -23
  270. package/docs/examples/select/icon.vue +16 -16
  271. package/docs/examples/select/multiple.vue +18 -18
  272. package/docs/examples/select/size.vue +39 -39
  273. package/docs/examples/slider/basic.vue +42 -42
  274. package/docs/examples/slider/disabled.vue +17 -17
  275. package/docs/examples/slider/marks.vue +30 -30
  276. package/docs/examples/slider/size.vue +37 -37
  277. package/docs/examples/slider/tooltip.vue +36 -36
  278. package/docs/examples/slider/vertical.vue +26 -26
  279. package/docs/examples/slider-captcha/basic.vue +44 -44
  280. package/docs/examples/slider-captcha/custom.vue +48 -48
  281. package/docs/examples/switch/basic.vue +16 -16
  282. package/docs/examples/switch/disabled.vue +13 -13
  283. package/docs/examples/switch/loading.vue +13 -13
  284. package/docs/examples/switch/size.vue +15 -15
  285. package/docs/examples/switch/text.vue +13 -13
  286. package/docs/examples/table/action-filter.vue +126 -126
  287. package/docs/examples/table/actions.vue +116 -116
  288. package/docs/examples/table/add-row.vue +103 -103
  289. package/docs/examples/table/basic.vue +168 -168
  290. package/docs/examples/table/checkbox-layout.vue +68 -68
  291. package/docs/examples/table/custom-layout.vue +115 -115
  292. package/docs/examples/table/dynamic-type.vue +73 -73
  293. package/docs/examples/table/editable.vue +262 -262
  294. package/docs/examples/table/field-selection.vue +87 -87
  295. package/docs/examples/table/frozen-column.vue +140 -140
  296. package/docs/examples/table/height-mode.vue +99 -99
  297. package/docs/examples/table/icon.vue +85 -85
  298. package/docs/examples/table/link.vue +66 -66
  299. package/docs/examples/table/multiple.vue +188 -188
  300. package/docs/examples/table/pagination.vue +151 -151
  301. package/docs/examples/table/single-selection.vue +64 -64
  302. package/docs/examples/table/sub-table-lazy.vue +97 -97
  303. package/docs/examples/table/sub-table.vue +103 -103
  304. package/docs/examples/table/tag.vue +43 -43
  305. package/docs/examples/table/tree-column.vue +119 -119
  306. package/docs/examples/table/tree-data.vue +141 -141
  307. package/docs/examples/table/tree-default-expand-all.vue +60 -60
  308. package/docs/examples/table/tree-lazy.vue +80 -80
  309. package/docs/examples/table/tree-set-selection.vue +75 -75
  310. package/docs/examples/table-panel/basic.vue +229 -229
  311. package/docs/examples/table-panel/batch-operations.vue +285 -285
  312. package/docs/examples/table-panel/button-visibility.vue +88 -88
  313. package/docs/examples/table-panel/filter.vue +219 -219
  314. package/docs/examples/table-panel/get-selection.vue +111 -111
  315. package/docs/examples/table-panel/mask.vue +151 -151
  316. package/docs/examples/table-panel/multiple-selection.vue +243 -243
  317. package/docs/examples/table-panel/pagination.vue +133 -133
  318. package/docs/examples/table-panel/sub-table-lazy.vue +118 -118
  319. package/docs/examples/table-panel/tree-parent-key.vue +67 -67
  320. package/docs/examples/tabs/basic.vue +98 -98
  321. package/docs/examples/time/base.vue +67 -67
  322. package/docs/examples/title/basic.vue +87 -87
  323. package/docs/examples/tree/accordion.vue +46 -46
  324. package/docs/examples/tree/basic.vue +50 -50
  325. package/docs/examples/tree/buttons.vue +53 -53
  326. package/docs/examples/tree/checkable.vue +52 -52
  327. package/docs/examples/tree/custom-keys.vue +39 -39
  328. package/docs/examples/tree/default-expanded.vue +52 -52
  329. package/docs/examples/tree/draggable.vue +29 -29
  330. package/docs/examples/tree/expand-on-click.vue +39 -39
  331. package/docs/examples/tree/flat-data.vue +20 -20
  332. package/docs/examples/tree/icon.vue +40 -40
  333. package/docs/examples/tree/load-data.vue +37 -37
  334. package/docs/examples/tree/methods.vue +74 -74
  335. package/docs/examples/tree/theme.vue +33 -33
  336. package/docs/examples/tree-select/basic.vue +47 -47
  337. package/docs/examples/upload/accept.vue +31 -31
  338. package/docs/examples/upload/basic.vue +12 -12
  339. package/docs/examples/upload/drag.vue +11 -11
  340. package/docs/examples/upload/image.vue +17 -17
  341. package/docs/examples/upload/limit.vue +20 -20
  342. package/docs/examples/upload/multiple.vue +17 -17
  343. package/docs/examples/upload/readonly.vue +17 -17
  344. package/docs/examples/utils/cipher.vue +160 -160
  345. package/docs/examples/utils/common.vue +153 -153
  346. package/docs/examples/utils/date.vue +56 -56
  347. package/docs/examples/utils/dom.vue +52 -52
  348. package/docs/examples/utils/is.vue +70 -70
  349. package/docs/examples/workflow/basic.vue +265 -265
  350. package/docs/examples/workflow-viewer/basic.vue +248 -248
  351. package/package.json +23 -23
@@ -1,25 +1,25 @@
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-slider v-model="height" :min="150" :max="500" style="width: 300px" />
7
- <span style="margin-left: 10px">{{ height }}px</span>
8
- </div>
9
- <j-code-mirror v-model="code" :height="height" mode="application/javascript" />
10
- </el-space>
11
- </div>
12
- </template>
13
-
14
- <script setup lang="ts">
15
- import { ref } from 'vue'
16
-
17
- const height = ref(300)
18
- const code = ref(`// 可以通过 height 属性调整编辑器高度
19
- function fibonacci(n) {
20
- if (n <= 1) return n;
21
- return fibonacci(n - 1) + fibonacci(n - 2);
22
- }
23
-
24
- console.log(fibonacci(10));`)
25
- </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-slider v-model="height" :min="150" :max="500" style="width: 300px" />
7
+ <span style="margin-left: 10px">{{ height }}px</span>
8
+ </div>
9
+ <j-code-mirror v-model="code" :height="height" mode="application/javascript" />
10
+ </el-space>
11
+ </div>
12
+ </template>
13
+
14
+ <script setup lang="ts">
15
+ import { ref } from 'vue'
16
+
17
+ const height = ref(300)
18
+ const code = ref(`// 可以通过 height 属性调整编辑器高度
19
+ function fibonacci(n) {
20
+ if (n <= 1) return n;
21
+ return fibonacci(n - 1) + fibonacci(n - 2);
22
+ }
23
+
24
+ console.log(fibonacci(10));`)
25
+ </script>
@@ -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>