@a2simcode/ui 0.0.112 → 0.0.114

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