@a2simcode/ui 0.0.107 → 0.0.108

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