@a2simcode/ui 0.0.138 → 0.0.140

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