@a2simcode/ui 0.0.125 → 0.0.127

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 (347) 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/decorated-title/index.d.ts +46 -0
  6. package/dist/components/decorated-title/src/decorated-title.vue.d.ts +62 -0
  7. package/dist/components/form/index.d.ts +3 -3
  8. package/dist/components/form/src/form.vue.d.ts +1 -1
  9. package/dist/components/form-item/index.d.ts +3 -3
  10. package/dist/components/form-item/src/form-item.vue.d.ts +2 -2
  11. package/dist/components/index.d.ts +2 -1
  12. package/dist/components/page/index.d.ts +3 -3
  13. package/dist/components/page/src/page.vue.d.ts +1 -1
  14. package/dist/components/slider-captcha/index.d.ts +5 -5
  15. package/dist/components/slider-captcha/src/slider-captcha-content.vue.d.ts +1 -1
  16. package/dist/components/slider-captcha/src/slider-captcha.vue.d.ts +3 -3
  17. package/dist/components/tree/index.d.ts +3 -3
  18. package/dist/components/tree/src/tree.vue.d.ts +1 -1
  19. package/dist/simcode-ui.es.js +4364 -4204
  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/decorated-title.md +24 -0
  38. package/docs/components/dialog-full.md +112 -112
  39. package/docs/components/dialog.md +127 -127
  40. package/docs/components/divider.md +24 -24
  41. package/docs/components/drawer.md +127 -127
  42. package/docs/components/dynamic-layer.md +118 -118
  43. package/docs/components/echarts.md +72 -72
  44. package/docs/components/editor.md +24 -24
  45. package/docs/components/form.md +27 -27
  46. package/docs/components/guid.md +39 -39
  47. package/docs/components/hpanel.md +24 -24
  48. package/docs/components/icon.md +56 -56
  49. package/docs/components/input-button.md +24 -24
  50. package/docs/components/input-code.md +24 -24
  51. package/docs/components/input-color.md +114 -114
  52. package/docs/components/input-layer.md +26 -26
  53. package/docs/components/input-rows.md +370 -370
  54. package/docs/components/input-tag.md +50 -50
  55. package/docs/components/input.md +129 -129
  56. package/docs/components/layer-form.md +61 -61
  57. package/docs/components/layer.md +127 -127
  58. package/docs/components/layout.md +132 -132
  59. package/docs/components/map.md +24 -24
  60. package/docs/components/menu.md +121 -121
  61. package/docs/components/meta/buttons.ts +76 -76
  62. package/docs/components/meta/comp.ts +236 -236
  63. package/docs/components/meta/date.ts +267 -267
  64. package/docs/components/meta/decorated-title.ts +74 -0
  65. package/docs/components/meta/echarts.ts +64 -64
  66. package/docs/components/meta/form.ts +165 -165
  67. package/docs/components/meta/input-cards.ts +112 -112
  68. package/docs/components/meta/input-color.ts +243 -243
  69. package/docs/components/meta/input-rows.ts +113 -113
  70. package/docs/components/meta/layer-form.ts +56 -56
  71. package/docs/components/meta/map.ts +68 -68
  72. package/docs/components/meta/panel.ts +152 -152
  73. package/docs/components/meta/slider.ts +270 -270
  74. package/docs/components/meta/table-panel.ts +232 -232
  75. package/docs/components/meta/table.ts +391 -391
  76. package/docs/components/meta/tabs.ts +146 -146
  77. package/docs/components/meta/tree-select.ts +199 -199
  78. package/docs/components/meta/workflow-viewer.ts +55 -55
  79. package/docs/components/number.md +124 -124
  80. package/docs/components/page.md +87 -87
  81. package/docs/components/panel.md +37 -37
  82. package/docs/components/radio.md +87 -87
  83. package/docs/components/rate.md +71 -71
  84. package/docs/components/select.md +133 -133
  85. package/docs/components/slider-captcha.md +41 -41
  86. package/docs/components/slider.md +101 -101
  87. package/docs/components/switch.md +90 -90
  88. package/docs/components/table-panel.md +236 -236
  89. package/docs/components/table.md +391 -391
  90. package/docs/components/tabs.md +26 -26
  91. package/docs/components/title.md +24 -24
  92. package/docs/components/tree.md +207 -207
  93. package/docs/components/upload.md +117 -117
  94. package/docs/components/workflow-viewer.md +21 -21
  95. package/docs/components/workflow.md +21 -21
  96. package/docs/examples/autocomplete/advanced.vue +35 -35
  97. package/docs/examples/autocomplete/basic.vue +32 -32
  98. package/docs/examples/autocomplete/clearable.vue +33 -33
  99. package/docs/examples/autocomplete/custom-template.vue +49 -49
  100. package/docs/examples/autocomplete/disabled.vue +33 -33
  101. package/docs/examples/autocomplete/icon.vue +37 -37
  102. package/docs/examples/barcode/all-types.vue +380 -380
  103. package/docs/examples/barcode/basic.vue +14 -14
  104. package/docs/examples/barcode/props-appearance.vue +243 -243
  105. package/docs/examples/barcode/props-geometry.vue +143 -143
  106. package/docs/examples/barcode/props-logic.vue +216 -216
  107. package/docs/examples/barcode/props-symbology.vue +199 -199
  108. package/docs/examples/barcode/props-text.vue +268 -268
  109. package/docs/examples/button/basic.vue +7 -7
  110. package/docs/examples/button/danger-ghost.vue +17 -17
  111. package/docs/examples/button/disabled.vue +10 -10
  112. package/docs/examples/button/loading.vue +6 -6
  113. package/docs/examples/button/shape.vue +7 -7
  114. package/docs/examples/button/size.vue +14 -14
  115. package/docs/examples/button/type.vue +9 -9
  116. package/docs/examples/button-select/basic.vue +19 -19
  117. package/docs/examples/buttons/basic.vue +45 -45
  118. package/docs/examples/buttons/disabled.vue +36 -36
  119. package/docs/examples/buttons/dropdown.vue +63 -63
  120. package/docs/examples/buttons/group.vue +52 -52
  121. package/docs/examples/buttons/link.vue +47 -47
  122. package/docs/examples/buttons/popup.vue +39 -39
  123. package/docs/examples/buttons/size.vue +45 -45
  124. package/docs/examples/cascader-select/basic.vue +28 -28
  125. package/docs/examples/cascader-select/clearable.vue +34 -34
  126. package/docs/examples/cascader-select/disabled.vue +43 -43
  127. package/docs/examples/cascader-select/filterable.vue +37 -37
  128. package/docs/examples/cascader-select/methods.vue +84 -84
  129. package/docs/examples/cascader-select/multiple.vue +38 -38
  130. package/docs/examples/cascader-select/slot.vue +45 -45
  131. package/docs/examples/checkbox/basic.vue +18 -18
  132. package/docs/examples/checkbox/button.vue +19 -19
  133. package/docs/examples/checkbox/color.vue +25 -25
  134. package/docs/examples/checkbox/disabled.vue +17 -17
  135. package/docs/examples/checkbox/min-max.vue +20 -20
  136. package/docs/examples/checkbox/mixed.vue +56 -56
  137. package/docs/examples/checkbox/size.vue +28 -28
  138. package/docs/examples/code-mirror/basic.vue +11 -11
  139. package/docs/examples/code-mirror/events.vue +42 -42
  140. package/docs/examples/code-mirror/height.vue +25 -25
  141. package/docs/examples/code-mirror/mode.vue +33 -33
  142. package/docs/examples/code-mirror/readonly.vue +14 -14
  143. package/docs/examples/collapse/basic.vue +82 -82
  144. package/docs/examples/comp/basic.vue +7 -7
  145. package/docs/examples/comp/collapse.vue +38 -38
  146. package/docs/examples/comp/tabs.vue +38 -38
  147. package/docs/examples/count/basic.vue +101 -101
  148. package/docs/examples/count-up/basic.vue +89 -89
  149. package/docs/examples/data-panel/basic.vue +110 -110
  150. package/docs/examples/date/basic.vue +73 -73
  151. package/docs/examples/date/default-value.vue +59 -59
  152. package/docs/examples/date/format.vue +75 -75
  153. package/docs/examples/date/range.vue +66 -66
  154. package/docs/examples/date/types.vue +79 -79
  155. package/docs/examples/decorated-title/basic.vue +31 -0
  156. package/docs/examples/dialog/basic.vue +36 -36
  157. package/docs/examples/dialog/custom-buttons.vue +44 -44
  158. package/docs/examples/dialog/fullscreen.vue +23 -23
  159. package/docs/examples/dialog/no-mask.vue +17 -17
  160. package/docs/examples/dialog/size.vue +44 -44
  161. package/docs/examples/dialog/steps.vue +57 -57
  162. package/docs/examples/dialog-full/basic.vue +29 -29
  163. package/docs/examples/dialog-full/custom-buttons.vue +45 -45
  164. package/docs/examples/dialog-full/no-buttons.vue +18 -18
  165. package/docs/examples/dialog-full/no-header.vue +27 -27
  166. package/docs/examples/dialog-full/steps.vue +71 -71
  167. package/docs/examples/divider/basic.vue +52 -52
  168. package/docs/examples/drawer/basic.vue +35 -35
  169. package/docs/examples/drawer/custom-buttons.vue +34 -34
  170. package/docs/examples/drawer/direction.vue +47 -47
  171. package/docs/examples/drawer/mask.vue +36 -36
  172. package/docs/examples/drawer/no-buttons.vue +20 -20
  173. package/docs/examples/drawer/size.vue +28 -28
  174. package/docs/examples/dynamic-layer/basic.vue +33 -33
  175. package/docs/examples/dynamic-layer/custom-buttons.vue +43 -43
  176. package/docs/examples/dynamic-layer/form.vue +73 -73
  177. package/docs/examples/dynamic-layer/steps.vue +52 -52
  178. package/docs/examples/dynamic-layer/types.vue +40 -40
  179. package/docs/examples/echarts/basic.vue +31 -31
  180. package/docs/examples/echarts/dynamic.vue +43 -43
  181. package/docs/examples/echarts/line.vue +46 -46
  182. package/docs/examples/echarts/pie.vue +44 -44
  183. package/docs/examples/editor/basic.vue +15 -15
  184. package/docs/examples/form/basic.vue +502 -498
  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 +69 -69
  209. package/docs/examples/input-rows/basic.vue +73 -73
  210. package/docs/examples/input-rows/drag.vue +48 -48
  211. package/docs/examples/input-rows/layer-form.vue +85 -85
  212. package/docs/examples/input-rows/nested.vue +91 -91
  213. package/docs/examples/input-tag/basic.vue +27 -27
  214. package/docs/examples/input-tag/colors.vue +23 -23
  215. package/docs/examples/input-tag/readonly.vue +17 -17
  216. package/docs/examples/layer/basic.vue +43 -43
  217. package/docs/examples/layer/custom-buttons.vue +61 -61
  218. package/docs/examples/layer/drawer.vue +37 -37
  219. package/docs/examples/layer/full.vue +38 -38
  220. package/docs/examples/layer/modal.vue +34 -34
  221. package/docs/examples/layer/steps.vue +46 -46
  222. package/docs/examples/layer-form/basic.vue +76 -76
  223. package/docs/examples/layer-form/config.vue +82 -82
  224. package/docs/examples/layer-form/size.vue +72 -72
  225. package/docs/examples/layout/basic.vue +36 -36
  226. package/docs/examples/layout/custom-size.vue +50 -50
  227. package/docs/examples/layout/disable-move.vue +37 -37
  228. package/docs/examples/layout/hide-mid-when-narrow.vue +96 -96
  229. package/docs/examples/layout/min-size.vue +73 -73
  230. package/docs/examples/layout/percent-size.vue +80 -80
  231. package/docs/examples/layout/simple.vue +22 -22
  232. package/docs/examples/layout/top-side.vue +34 -34
  233. package/docs/examples/map/basic.vue +22 -22
  234. package/docs/examples/menu/basic.vue +58 -58
  235. package/docs/examples/menu/collapsed.vue +49 -49
  236. package/docs/examples/menu/horizontal.vue +44 -44
  237. package/docs/examples/menu/selection-test.vue +104 -104
  238. package/docs/examples/menu/theme.vue +46 -46
  239. package/docs/examples/menu/vertical.vue +46 -46
  240. package/docs/examples/number/advanced.vue +143 -143
  241. package/docs/examples/number/basic.vue +63 -63
  242. package/docs/examples/number/disabled.vue +49 -49
  243. package/docs/examples/number/size.vue +42 -42
  244. package/docs/examples/number/slots.vue +123 -123
  245. package/docs/examples/number/step-strictly.vue +41 -41
  246. package/docs/examples/number/step.vue +47 -47
  247. package/docs/examples/page/basic.vue +41 -41
  248. package/docs/examples/page/dept-user-management.vue +211 -211
  249. package/docs/examples/page/init.vue +87 -87
  250. package/docs/examples/page/log.vue +453 -453
  251. package/docs/examples/page/user-management.vue +313 -313
  252. package/docs/examples/panel/tool-buttons.vue +18 -18
  253. package/docs/examples/radio/basic.vue +17 -17
  254. package/docs/examples/radio/button.vue +17 -17
  255. package/docs/examples/radio/color.vue +18 -18
  256. package/docs/examples/radio/disabled.vue +17 -17
  257. package/docs/examples/radio/size.vue +29 -29
  258. package/docs/examples/rate/basic.vue +24 -24
  259. package/docs/examples/rate/half.vue +24 -24
  260. package/docs/examples/rate/readonly.vue +11 -11
  261. package/docs/examples/rate/text.vue +32 -32
  262. package/docs/examples/select/basic.vue +16 -16
  263. package/docs/examples/select/clearable.vue +22 -22
  264. package/docs/examples/select/disabled.vue +31 -31
  265. package/docs/examples/select/filterable.vue +24 -24
  266. package/docs/examples/select/group.vue +23 -23
  267. package/docs/examples/select/icon.vue +16 -16
  268. package/docs/examples/select/multiple.vue +18 -18
  269. package/docs/examples/select/size.vue +39 -39
  270. package/docs/examples/slider/basic.vue +42 -42
  271. package/docs/examples/slider/disabled.vue +17 -17
  272. package/docs/examples/slider/marks.vue +30 -30
  273. package/docs/examples/slider/size.vue +37 -37
  274. package/docs/examples/slider/tooltip.vue +36 -36
  275. package/docs/examples/slider/vertical.vue +26 -26
  276. package/docs/examples/slider-captcha/basic.vue +44 -44
  277. package/docs/examples/slider-captcha/custom.vue +48 -48
  278. package/docs/examples/switch/basic.vue +16 -16
  279. package/docs/examples/switch/disabled.vue +13 -13
  280. package/docs/examples/switch/loading.vue +13 -13
  281. package/docs/examples/switch/size.vue +15 -15
  282. package/docs/examples/switch/text.vue +13 -13
  283. package/docs/examples/table/action-filter.vue +126 -126
  284. package/docs/examples/table/actions.vue +116 -116
  285. package/docs/examples/table/add-row.vue +103 -103
  286. package/docs/examples/table/basic.vue +168 -168
  287. package/docs/examples/table/checkbox-layout.vue +68 -68
  288. package/docs/examples/table/custom-layout.vue +115 -115
  289. package/docs/examples/table/dynamic-type.vue +73 -73
  290. package/docs/examples/table/editable.vue +262 -262
  291. package/docs/examples/table/field-selection.vue +87 -87
  292. package/docs/examples/table/frozen-column.vue +140 -140
  293. package/docs/examples/table/height-mode.vue +99 -99
  294. package/docs/examples/table/icon.vue +85 -85
  295. package/docs/examples/table/link.vue +66 -66
  296. package/docs/examples/table/multiple.vue +188 -188
  297. package/docs/examples/table/pagination.vue +151 -151
  298. package/docs/examples/table/single-selection.vue +64 -64
  299. package/docs/examples/table/sub-table-lazy.vue +97 -97
  300. package/docs/examples/table/sub-table.vue +103 -103
  301. package/docs/examples/table/tag.vue +43 -43
  302. package/docs/examples/table/tree-column.vue +119 -119
  303. package/docs/examples/table/tree-data.vue +141 -141
  304. package/docs/examples/table/tree-default-expand-all.vue +60 -60
  305. package/docs/examples/table/tree-lazy.vue +80 -80
  306. package/docs/examples/table/tree-set-selection.vue +75 -75
  307. package/docs/examples/table-panel/basic.vue +228 -228
  308. package/docs/examples/table-panel/batch-operations.vue +285 -285
  309. package/docs/examples/table-panel/button-visibility.vue +88 -88
  310. package/docs/examples/table-panel/filter.vue +219 -219
  311. package/docs/examples/table-panel/get-selection.vue +111 -111
  312. package/docs/examples/table-panel/multiple-selection.vue +243 -243
  313. package/docs/examples/table-panel/pagination.vue +133 -133
  314. package/docs/examples/table-panel/sub-table-lazy.vue +118 -118
  315. package/docs/examples/table-panel/tree-parent-key.vue +67 -67
  316. package/docs/examples/tabs/basic.vue +98 -98
  317. package/docs/examples/time/base.vue +67 -67
  318. package/docs/examples/title/basic.vue +80 -80
  319. package/docs/examples/tree/accordion.vue +46 -46
  320. package/docs/examples/tree/basic.vue +50 -50
  321. package/docs/examples/tree/buttons.vue +53 -53
  322. package/docs/examples/tree/checkable.vue +52 -52
  323. package/docs/examples/tree/custom-keys.vue +39 -39
  324. package/docs/examples/tree/default-expanded.vue +52 -52
  325. package/docs/examples/tree/draggable.vue +29 -29
  326. package/docs/examples/tree/expand-on-click.vue +39 -39
  327. package/docs/examples/tree/flat-data.vue +20 -20
  328. package/docs/examples/tree/icon.vue +40 -40
  329. package/docs/examples/tree/load-data.vue +37 -37
  330. package/docs/examples/tree/methods.vue +74 -74
  331. package/docs/examples/tree/theme.vue +33 -33
  332. package/docs/examples/tree-select/basic.vue +47 -47
  333. package/docs/examples/upload/accept.vue +31 -31
  334. package/docs/examples/upload/basic.vue +12 -12
  335. package/docs/examples/upload/drag.vue +11 -11
  336. package/docs/examples/upload/image.vue +17 -17
  337. package/docs/examples/upload/limit.vue +20 -20
  338. package/docs/examples/upload/multiple.vue +17 -17
  339. package/docs/examples/upload/readonly.vue +17 -17
  340. package/docs/examples/utils/cipher.vue +160 -160
  341. package/docs/examples/utils/common.vue +153 -153
  342. package/docs/examples/utils/date.vue +56 -56
  343. package/docs/examples/utils/dom.vue +52 -52
  344. package/docs/examples/utils/is.vue +70 -70
  345. package/docs/examples/workflow/basic.vue +265 -265
  346. package/docs/examples/workflow-viewer/basic.vue +248 -248
  347. package/package.json +23 -23
@@ -1,248 +1,248 @@
1
- <template>
2
- <div>
3
- <div style="margin-bottom: 16px; display: flex; gap: 8px; flex-wrap: wrap; align-items: center">
4
- <h3 style="margin: 0; width: 100%">属性演示</h3>
5
-
6
- <div style="display: flex; gap: 8px; align-items: center">
7
- <label>线条颜色:</label>
8
- <j-input-color v-model="lineStroke" style="width: 100px" />
9
- </div>
10
-
11
- <div style="display: flex; gap: 8px; align-items: center">
12
- <label>自定义调色板:</label>
13
- <j-switch v-model="useCustomPalette" />
14
- </div>
15
- </div>
16
-
17
- <div style="margin-bottom: 16px; display: flex; gap: 8px; flex-wrap: wrap; align-items: center">
18
- <h3 style="margin: 0; width: 100%">方法演示</h3>
19
-
20
- <j-button size="small" label="重置画布" @click="handleReset" />
21
- <j-button size="small" label="放大 (+0.2)" @click="handleZoomIn" />
22
- <j-button size="small" label="缩小 (-0.2)" @click="handleZoomOut" />
23
- <j-button size="small" label="获取数据" @click="handleGetData" />
24
- <j-button size="small" label="设置示例数据" @click="handleSetData" />
25
- <j-button size="small" label="更新节点" @click="handleUpdateElement" />
26
- </div>
27
-
28
- <div style="margin-bottom: 16px">
29
- <h3 style="margin: 0 0 8px 0">事件演示</h3>
30
- <div
31
- style="
32
- background: #f5f5f5;
33
- padding: 12px;
34
- border-radius: 4px;
35
- max-height: 150px;
36
- overflow-y: auto;
37
- "
38
- >
39
- <div v-if="eventLogs.length === 0" style="color: #999">
40
- 点击或双击画布中的元素查看事件触发...
41
- </div>
42
- <div
43
- v-for="(log, index) in eventLogs"
44
- :key="index"
45
- style="margin-bottom: 8px; font-size: 12px"
46
- >
47
- <strong style="color: #1890ff">[{{ log.time }}]</strong>
48
- <span style="color: #52c41a">{{ log.type }}</span
49
- >:
50
- <code style="background: #fff; padding: 2px 6px; border-radius: 2px; margin-left: 4px">{{
51
- log.data
52
- }}</code>
53
- </div>
54
- </div>
55
- </div>
56
-
57
- <div
58
- style="
59
- height: 600px;
60
- width: 100%;
61
- border: 1px solid #ddd;
62
- border-radius: 4px;
63
- overflow: hidden;
64
- "
65
- >
66
- <j-workflow-viewer
67
- ref="workflowViewerRef"
68
- :line-stroke="lineStroke"
69
- :palette-options="useCustomPalette ? customPaletteOptions : undefined"
70
- @element-click="handleElementClick"
71
- @element-dblclick="handleElementDblclick"
72
- />
73
- </div>
74
- </div>
75
- </template>
76
-
77
- <script setup lang="ts">
78
- import { ref, watch } from 'vue'
79
-
80
- const workflowViewerRef = ref()
81
-
82
- // 属性演示
83
- const lineStroke = ref('#1890ff')
84
- const useCustomPalette = ref(false)
85
-
86
- const customPaletteOptions = {
87
- 'create.start-event': {
88
- className: 'icon-start-event',
89
- type: 'startEvent',
90
- group: 'event',
91
- title: '创建开始事件',
92
- },
93
- 'create.end-event': {
94
- className: 'icon-end-event',
95
- type: 'endEvent',
96
- group: 'event',
97
- title: '创建结束事件',
98
- },
99
- 'create.task': {
100
- className: 'icon-gateway4',
101
- type: 'userTask',
102
- group: 'activity',
103
- title: '创建任务',
104
- },
105
- }
106
-
107
- // 事件演示
108
- const eventLogs = ref<Array<{ time: string; type: string; data: string }>>([])
109
-
110
- const addEventLog = (type: string, data: any) => {
111
- const time = new Date().toLocaleTimeString()
112
- eventLogs.value.unshift({
113
- time,
114
- type,
115
- data: JSON.stringify(data, null, 2),
116
- })
117
- // 只保留最近10条
118
- if (eventLogs.value.length > 10) {
119
- eventLogs.value = eventLogs.value.slice(0, 10)
120
- }
121
- }
122
-
123
- // 监听属性变化
124
- watch(lineStroke, (newValue) => {
125
- addEventLog('属性变更', {
126
- property: 'lineStroke',
127
- value: newValue,
128
- })
129
- })
130
-
131
- watch(useCustomPalette, (newValue) => {
132
- addEventLog('属性变更', {
133
- property: 'paletteOptions',
134
- value: newValue ? '自定义调色板' : '默认调色板',
135
- })
136
- })
137
-
138
- const handleElementClick = (ev: Record<string, any>) => {
139
- addEventLog('elementClick (单击)', ev)
140
- }
141
-
142
- const handleElementDblclick = (ev: Record<string, any>) => {
143
- addEventLog('elementDblclick (双击)', ev)
144
- }
145
-
146
- // 方法演示
147
- const handleReset = () => {
148
- workflowViewerRef.value?.reset()
149
- addEventLog('方法调用', { method: 'reset()', description: '重置画布视图' })
150
- }
151
-
152
- const handleZoomIn = () => {
153
- workflowViewerRef.value?.zoom(0.2)
154
- addEventLog('方法调用', { method: 'zoom(0.2)', description: '放大画布' })
155
- }
156
-
157
- const handleZoomOut = () => {
158
- workflowViewerRef.value?.zoom(-0.2)
159
- addEventLog('方法调用', { method: 'zoom(-0.2)', description: '缩小画布' })
160
- }
161
-
162
- const handleGetData = () => {
163
- const data = workflowViewerRef.value?.getData()
164
- addEventLog('方法调用', {
165
- method: 'getData()',
166
- description: '获取工作流数据',
167
- result: data,
168
- })
169
- console.log('工作流数据:', data)
170
- }
171
-
172
- const handleSetData = () => {
173
- const exampleData = [
174
- {
175
- id: '0a210b2c-a3de-44d1-8f37-174ab5a9e167',
176
- type: 'startEvent',
177
- name: 'woshi',
178
- x: 190,
179
- y: 110,
180
- },
181
- {
182
- id: '2c0c0406-864e-4de3-8ffe-6da303cf5c7a',
183
- type: 'userTask',
184
- name: '我是',
185
- x: 251,
186
- y: 130,
187
- },
188
- {
189
- id: '4e947a78-91cb-4e23-82f7-238a34c127a8',
190
- from: '0a210b2c-a3de-44d1-8f37-174ab5a9e167',
191
- to: '2c0c0406-864e-4de3-8ffe-6da303cf5c7a',
192
- waypoint: [
193
- { x: 226, y: 128 },
194
- { x: 239, y: 128 },
195
- { x: 239, y: 179 },
196
- { x: 251, y: 179 },
197
- ],
198
- type: 'myline',
199
- label: {
200
- height: 14,
201
- width: 19,
202
- x: 226,
203
- y: 174,
204
- },
205
- name: 'hao',
206
- },
207
- ]
208
-
209
- workflowViewerRef.value?.setData(exampleData)
210
- addEventLog('方法调用', {
211
- method: 'setData(data)',
212
- description: '设置工作流数据',
213
- dataCount: exampleData.length,
214
- })
215
- }
216
-
217
- const handleUpdateElement = () => {
218
- // 先获取当前数据,然后更新第一个节点
219
- const data = workflowViewerRef.value?.getData()
220
- if (data && data.length > 0) {
221
- const firstNode = data.find((item: any) => item.type !== 'myline')
222
- if (firstNode) {
223
- const updatedNode = {
224
- ...firstNode,
225
- name: `已更新 - ${new Date().toLocaleTimeString()}`,
226
- }
227
- workflowViewerRef.value?.updateElemet(updatedNode)
228
- addEventLog('方法调用', {
229
- method: 'updateElemet(data)',
230
- description: '更新节点',
231
- nodeId: updatedNode.id,
232
- })
233
- } else {
234
- addEventLog('方法调用', {
235
- method: 'updateElemet(data)',
236
- description: '更新节点失败:没有可更新的节点',
237
- tip: '请先使用"设置示例数据"创建节点',
238
- })
239
- }
240
- } else {
241
- addEventLog('方法调用', {
242
- method: 'updateElemet(data)',
243
- description: '更新节点失败:没有数据',
244
- tip: '请先使用"设置示例数据"创建节点',
245
- })
246
- }
247
- }
248
- </script>
1
+ <template>
2
+ <div>
3
+ <div style="margin-bottom: 16px; display: flex; gap: 8px; flex-wrap: wrap; align-items: center">
4
+ <h3 style="margin: 0; width: 100%">属性演示</h3>
5
+
6
+ <div style="display: flex; gap: 8px; align-items: center">
7
+ <label>线条颜色:</label>
8
+ <j-input-color v-model="lineStroke" style="width: 100px" />
9
+ </div>
10
+
11
+ <div style="display: flex; gap: 8px; align-items: center">
12
+ <label>自定义调色板:</label>
13
+ <j-switch v-model="useCustomPalette" />
14
+ </div>
15
+ </div>
16
+
17
+ <div style="margin-bottom: 16px; display: flex; gap: 8px; flex-wrap: wrap; align-items: center">
18
+ <h3 style="margin: 0; width: 100%">方法演示</h3>
19
+
20
+ <j-button size="small" label="重置画布" @click="handleReset" />
21
+ <j-button size="small" label="放大 (+0.2)" @click="handleZoomIn" />
22
+ <j-button size="small" label="缩小 (-0.2)" @click="handleZoomOut" />
23
+ <j-button size="small" label="获取数据" @click="handleGetData" />
24
+ <j-button size="small" label="设置示例数据" @click="handleSetData" />
25
+ <j-button size="small" label="更新节点" @click="handleUpdateElement" />
26
+ </div>
27
+
28
+ <div style="margin-bottom: 16px">
29
+ <h3 style="margin: 0 0 8px 0">事件演示</h3>
30
+ <div
31
+ style="
32
+ background: #f5f5f5;
33
+ padding: 12px;
34
+ border-radius: 4px;
35
+ max-height: 150px;
36
+ overflow-y: auto;
37
+ "
38
+ >
39
+ <div v-if="eventLogs.length === 0" style="color: #999">
40
+ 点击或双击画布中的元素查看事件触发...
41
+ </div>
42
+ <div
43
+ v-for="(log, index) in eventLogs"
44
+ :key="index"
45
+ style="margin-bottom: 8px; font-size: 12px"
46
+ >
47
+ <strong style="color: #1890ff">[{{ log.time }}]</strong>
48
+ <span style="color: #52c41a">{{ log.type }}</span
49
+ >:
50
+ <code style="background: #fff; padding: 2px 6px; border-radius: 2px; margin-left: 4px">{{
51
+ log.data
52
+ }}</code>
53
+ </div>
54
+ </div>
55
+ </div>
56
+
57
+ <div
58
+ style="
59
+ height: 600px;
60
+ width: 100%;
61
+ border: 1px solid #ddd;
62
+ border-radius: 4px;
63
+ overflow: hidden;
64
+ "
65
+ >
66
+ <j-workflow-viewer
67
+ ref="workflowViewerRef"
68
+ :line-stroke="lineStroke"
69
+ :palette-options="useCustomPalette ? customPaletteOptions : undefined"
70
+ @element-click="handleElementClick"
71
+ @element-dblclick="handleElementDblclick"
72
+ />
73
+ </div>
74
+ </div>
75
+ </template>
76
+
77
+ <script setup lang="ts">
78
+ import { ref, watch } from 'vue'
79
+
80
+ const workflowViewerRef = ref()
81
+
82
+ // 属性演示
83
+ const lineStroke = ref('#1890ff')
84
+ const useCustomPalette = ref(false)
85
+
86
+ const customPaletteOptions = {
87
+ 'create.start-event': {
88
+ className: 'icon-start-event',
89
+ type: 'startEvent',
90
+ group: 'event',
91
+ title: '创建开始事件',
92
+ },
93
+ 'create.end-event': {
94
+ className: 'icon-end-event',
95
+ type: 'endEvent',
96
+ group: 'event',
97
+ title: '创建结束事件',
98
+ },
99
+ 'create.task': {
100
+ className: 'icon-gateway4',
101
+ type: 'userTask',
102
+ group: 'activity',
103
+ title: '创建任务',
104
+ },
105
+ }
106
+
107
+ // 事件演示
108
+ const eventLogs = ref<Array<{ time: string; type: string; data: string }>>([])
109
+
110
+ const addEventLog = (type: string, data: any) => {
111
+ const time = new Date().toLocaleTimeString()
112
+ eventLogs.value.unshift({
113
+ time,
114
+ type,
115
+ data: JSON.stringify(data, null, 2),
116
+ })
117
+ // 只保留最近10条
118
+ if (eventLogs.value.length > 10) {
119
+ eventLogs.value = eventLogs.value.slice(0, 10)
120
+ }
121
+ }
122
+
123
+ // 监听属性变化
124
+ watch(lineStroke, (newValue) => {
125
+ addEventLog('属性变更', {
126
+ property: 'lineStroke',
127
+ value: newValue,
128
+ })
129
+ })
130
+
131
+ watch(useCustomPalette, (newValue) => {
132
+ addEventLog('属性变更', {
133
+ property: 'paletteOptions',
134
+ value: newValue ? '自定义调色板' : '默认调色板',
135
+ })
136
+ })
137
+
138
+ const handleElementClick = (ev: Record<string, any>) => {
139
+ addEventLog('elementClick (单击)', ev)
140
+ }
141
+
142
+ const handleElementDblclick = (ev: Record<string, any>) => {
143
+ addEventLog('elementDblclick (双击)', ev)
144
+ }
145
+
146
+ // 方法演示
147
+ const handleReset = () => {
148
+ workflowViewerRef.value?.reset()
149
+ addEventLog('方法调用', { method: 'reset()', description: '重置画布视图' })
150
+ }
151
+
152
+ const handleZoomIn = () => {
153
+ workflowViewerRef.value?.zoom(0.2)
154
+ addEventLog('方法调用', { method: 'zoom(0.2)', description: '放大画布' })
155
+ }
156
+
157
+ const handleZoomOut = () => {
158
+ workflowViewerRef.value?.zoom(-0.2)
159
+ addEventLog('方法调用', { method: 'zoom(-0.2)', description: '缩小画布' })
160
+ }
161
+
162
+ const handleGetData = () => {
163
+ const data = workflowViewerRef.value?.getData()
164
+ addEventLog('方法调用', {
165
+ method: 'getData()',
166
+ description: '获取工作流数据',
167
+ result: data,
168
+ })
169
+ console.log('工作流数据:', data)
170
+ }
171
+
172
+ const handleSetData = () => {
173
+ const exampleData = [
174
+ {
175
+ id: '0a210b2c-a3de-44d1-8f37-174ab5a9e167',
176
+ type: 'startEvent',
177
+ name: 'woshi',
178
+ x: 190,
179
+ y: 110,
180
+ },
181
+ {
182
+ id: '2c0c0406-864e-4de3-8ffe-6da303cf5c7a',
183
+ type: 'userTask',
184
+ name: '我是',
185
+ x: 251,
186
+ y: 130,
187
+ },
188
+ {
189
+ id: '4e947a78-91cb-4e23-82f7-238a34c127a8',
190
+ from: '0a210b2c-a3de-44d1-8f37-174ab5a9e167',
191
+ to: '2c0c0406-864e-4de3-8ffe-6da303cf5c7a',
192
+ waypoint: [
193
+ { x: 226, y: 128 },
194
+ { x: 239, y: 128 },
195
+ { x: 239, y: 179 },
196
+ { x: 251, y: 179 },
197
+ ],
198
+ type: 'myline',
199
+ label: {
200
+ height: 14,
201
+ width: 19,
202
+ x: 226,
203
+ y: 174,
204
+ },
205
+ name: 'hao',
206
+ },
207
+ ]
208
+
209
+ workflowViewerRef.value?.setData(exampleData)
210
+ addEventLog('方法调用', {
211
+ method: 'setData(data)',
212
+ description: '设置工作流数据',
213
+ dataCount: exampleData.length,
214
+ })
215
+ }
216
+
217
+ const handleUpdateElement = () => {
218
+ // 先获取当前数据,然后更新第一个节点
219
+ const data = workflowViewerRef.value?.getData()
220
+ if (data && data.length > 0) {
221
+ const firstNode = data.find((item: any) => item.type !== 'myline')
222
+ if (firstNode) {
223
+ const updatedNode = {
224
+ ...firstNode,
225
+ name: `已更新 - ${new Date().toLocaleTimeString()}`,
226
+ }
227
+ workflowViewerRef.value?.updateElemet(updatedNode)
228
+ addEventLog('方法调用', {
229
+ method: 'updateElemet(data)',
230
+ description: '更新节点',
231
+ nodeId: updatedNode.id,
232
+ })
233
+ } else {
234
+ addEventLog('方法调用', {
235
+ method: 'updateElemet(data)',
236
+ description: '更新节点失败:没有可更新的节点',
237
+ tip: '请先使用"设置示例数据"创建节点',
238
+ })
239
+ }
240
+ } else {
241
+ addEventLog('方法调用', {
242
+ method: 'updateElemet(data)',
243
+ description: '更新节点失败:没有数据',
244
+ tip: '请先使用"设置示例数据"创建节点',
245
+ })
246
+ }
247
+ }
248
+ </script>
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@a2simcode/ui",
3
- "version": "0.0.125",
3
+ "version": "0.0.127",
4
4
  "description": "A Vue 3 UI Component Library",
5
5
  "type": "module",
6
6
  "main": "./dist/simcode-ui.umd.js",
@@ -21,27 +21,6 @@
21
21
  "docs/examples",
22
22
  ".cursor/skills/ui-component-helper"
23
23
  ],
24
- "scripts": {
25
- "dev": "pnpm docs:dev",
26
- "build": "vite build && tsx scripts/fix-index-dts.ts",
27
- "ui:publish": "pnpm build && npm publish --access public",
28
- "test": "vitest",
29
- "test:ui": "vitest --ui",
30
- "lint": "eslint . --fix",
31
- "format": "prettier --write .",
32
- "gen:docs": "tsx scripts/gen-api-docs.ts",
33
- "gen:dui:docs": "tsx scripts/gen-dui-api-docs.ts",
34
- "docs:dev": "pnpm gen:docs && vitepress dev docs",
35
- "docs:build": "pnpm gen:docs && vitepress build docs",
36
- "docs:preview": "vitepress preview docs",
37
- "dui:install": "cd packages/components-dui && pnpm install",
38
- "dui:build": "cd packages/components-dui && pnpm build",
39
- "dui:publish": "pnpm dui:build && cd packages/components-dui && npm publish --access public",
40
- "dui:dev": "pnpm dui:docs:dev",
41
- "dui:docs:dev": "pnpm gen:dui:docs && vitepress dev docs-dui",
42
- "dui:docs:build": "pnpm gen:dui:docs && vitepress build docs-dui",
43
- "dui:docs:preview": "vitepress preview docs-dui"
44
- },
45
24
  "keywords": [
46
25
  "vue",
47
26
  "vue3",
@@ -230,5 +209,26 @@
230
209
  "vue": "3.5.30",
231
210
  "vue-docgen-api": "4.79.2",
232
211
  "vue-tsc": "3.2.6"
212
+ },
213
+ "scripts": {
214
+ "dev": "pnpm docs:dev",
215
+ "build": "vite build && tsx scripts/fix-index-dts.ts",
216
+ "ui:publish": "pnpm build && npm publish --access public",
217
+ "test": "vitest",
218
+ "test:ui": "vitest --ui",
219
+ "lint": "eslint . --fix",
220
+ "format": "prettier --write .",
221
+ "gen:docs": "tsx scripts/gen-api-docs.ts",
222
+ "gen:dui:docs": "tsx scripts/gen-dui-api-docs.ts",
223
+ "docs:dev": "pnpm gen:docs && vitepress dev docs",
224
+ "docs:build": "pnpm gen:docs && vitepress build docs",
225
+ "docs:preview": "vitepress preview docs",
226
+ "dui:install": "cd packages/components-dui && pnpm install",
227
+ "dui:build": "cd packages/components-dui && pnpm build",
228
+ "dui:publish": "pnpm dui:build && cd packages/components-dui && npm publish --access public",
229
+ "dui:dev": "pnpm dui:docs:dev",
230
+ "dui:docs:dev": "pnpm gen:dui:docs && vitepress dev docs-dui",
231
+ "dui:docs:build": "pnpm gen:dui:docs && vitepress build docs-dui",
232
+ "dui:docs:preview": "vitepress preview docs-dui"
233
233
  }
234
- }
234
+ }