@a2simcode/ui 0.0.187 → 0.0.188

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 (361) 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/buttons/src/interface.d.ts +4 -0
  6. package/dist/components/input/index.d.ts +3 -3
  7. package/dist/components/input/src/input.vue.d.ts +1 -1
  8. package/dist/components/input-layer/index.d.ts +3 -3
  9. package/dist/components/input-layer/src/input-layer.vue.d.ts +1 -1
  10. package/dist/components/input-map/index.d.ts +3 -3
  11. package/dist/components/input-map/src/input-map.vue.d.ts +1 -1
  12. package/dist/components/input-tag/index.d.ts +3 -3
  13. package/dist/components/input-tag/src/input-tag.vue.d.ts +1 -1
  14. package/dist/components/time/index.d.ts +3 -3
  15. package/dist/components/time/src/time.vue.d.ts +1 -1
  16. package/dist/components/upload/index.d.ts +24 -24
  17. package/dist/components/upload/src/list.vue.d.ts +1 -1
  18. package/dist/components/upload/src/upload.vue.d.ts +8 -8
  19. package/dist/simcode-ui.es.js +458 -441
  20. package/dist/simcode-ui.umd.js +2 -2
  21. package/dist/stats.html +1 -1
  22. package/dist/ui.css +1 -1
  23. package/docs/components/autocomplete.md +89 -89
  24. package/docs/components/barcode.md +101 -101
  25. package/docs/components/button-select.md +24 -24
  26. package/docs/components/button.md +117 -117
  27. package/docs/components/buttons.md +119 -119
  28. package/docs/components/cascader-select.md +114 -114
  29. package/docs/components/checkbox.md +114 -114
  30. package/docs/components/code-mirror.md +85 -85
  31. package/docs/components/collapse.md +26 -26
  32. package/docs/components/comp.md +71 -71
  33. package/docs/components/count-up.md +24 -24
  34. package/docs/components/count.md +24 -24
  35. package/docs/components/data-panel.md +24 -24
  36. package/docs/components/date.md +76 -76
  37. package/docs/components/dialog-full.md +112 -112
  38. package/docs/components/dialog.md +127 -127
  39. package/docs/components/divider.md +24 -24
  40. package/docs/components/drawer.md +127 -127
  41. package/docs/components/dynamic-layer.md +118 -118
  42. package/docs/components/echarts.md +72 -72
  43. package/docs/components/editor.md +24 -24
  44. package/docs/components/form.md +72 -72
  45. package/docs/components/guid.md +39 -39
  46. package/docs/components/hpanel.md +24 -24
  47. package/docs/components/icon.md +56 -56
  48. package/docs/components/input-button.md +24 -24
  49. package/docs/components/input-code.md +24 -24
  50. package/docs/components/input-color.md +114 -114
  51. package/docs/components/input-layer.md +56 -56
  52. package/docs/components/input-rows.md +370 -370
  53. package/docs/components/input-tag.md +50 -50
  54. package/docs/components/input.md +129 -129
  55. package/docs/components/layer-form.md +61 -61
  56. package/docs/components/layer.md +127 -127
  57. package/docs/components/layout.md +132 -132
  58. package/docs/components/map.md +24 -24
  59. package/docs/components/menu.md +121 -121
  60. package/docs/components/meta/button.ts +212 -212
  61. package/docs/components/meta/buttons.ts +76 -76
  62. package/docs/components/meta/code-mirror.ts +108 -108
  63. package/docs/components/meta/comp.ts +236 -236
  64. package/docs/components/meta/date.ts +267 -267
  65. package/docs/components/meta/echarts.ts +64 -64
  66. package/docs/components/meta/form-item.ts +50 -50
  67. package/docs/components/meta/form.ts +181 -181
  68. package/docs/components/meta/input-button.ts +165 -165
  69. package/docs/components/meta/input-cards.ts +112 -112
  70. package/docs/components/meta/input-code.ts +151 -151
  71. package/docs/components/meta/input-color.ts +243 -243
  72. package/docs/components/meta/input-layer.ts +382 -382
  73. package/docs/components/meta/input-rows.ts +119 -119
  74. package/docs/components/meta/layer-form.ts +56 -56
  75. package/docs/components/meta/map.ts +68 -68
  76. package/docs/components/meta/panel.ts +152 -152
  77. package/docs/components/meta/slider.ts +270 -270
  78. package/docs/components/meta/table-panel.ts +237 -237
  79. package/docs/components/meta/table.ts +391 -391
  80. package/docs/components/meta/tabs.ts +146 -146
  81. package/docs/components/meta/title.ts +91 -91
  82. package/docs/components/meta/tree-select.ts +199 -199
  83. package/docs/components/meta/tree.ts +219 -219
  84. package/docs/components/meta/vpanel.ts +19 -19
  85. package/docs/components/meta/workflow-viewer.ts +55 -55
  86. package/docs/components/number.md +124 -124
  87. package/docs/components/page.md +102 -102
  88. package/docs/components/panel.md +37 -37
  89. package/docs/components/radio.md +87 -87
  90. package/docs/components/rate.md +71 -71
  91. package/docs/components/select.md +133 -133
  92. package/docs/components/slider-captcha.md +41 -41
  93. package/docs/components/slider.md +101 -101
  94. package/docs/components/switch.md +90 -90
  95. package/docs/components/table-panel.md +251 -251
  96. package/docs/components/table.md +391 -391
  97. package/docs/components/tabs.md +26 -26
  98. package/docs/components/title.md +24 -24
  99. package/docs/components/tree.md +207 -207
  100. package/docs/components/upload.md +117 -117
  101. package/docs/components/workflow-viewer.md +21 -21
  102. package/docs/components/workflow.md +21 -21
  103. package/docs/examples/autocomplete/advanced.vue +35 -35
  104. package/docs/examples/autocomplete/basic.vue +32 -32
  105. package/docs/examples/autocomplete/clearable.vue +33 -33
  106. package/docs/examples/autocomplete/custom-template.vue +49 -49
  107. package/docs/examples/autocomplete/disabled.vue +33 -33
  108. package/docs/examples/autocomplete/icon.vue +37 -37
  109. package/docs/examples/barcode/all-types.vue +380 -380
  110. package/docs/examples/barcode/basic.vue +14 -14
  111. package/docs/examples/barcode/props-appearance.vue +243 -243
  112. package/docs/examples/barcode/props-geometry.vue +143 -143
  113. package/docs/examples/barcode/props-logic.vue +216 -216
  114. package/docs/examples/barcode/props-symbology.vue +199 -199
  115. package/docs/examples/barcode/props-text.vue +268 -268
  116. package/docs/examples/button/basic.vue +7 -7
  117. package/docs/examples/button/danger-ghost.vue +17 -17
  118. package/docs/examples/button/disabled.vue +10 -10
  119. package/docs/examples/button/loading.vue +6 -6
  120. package/docs/examples/button/shape.vue +7 -7
  121. package/docs/examples/button/size.vue +14 -14
  122. package/docs/examples/button/type.vue +10 -10
  123. package/docs/examples/button-select/basic.vue +19 -19
  124. package/docs/examples/buttons/basic.vue +62 -45
  125. package/docs/examples/buttons/disabled.vue +36 -36
  126. package/docs/examples/buttons/dropdown.vue +63 -63
  127. package/docs/examples/buttons/group.vue +52 -52
  128. package/docs/examples/buttons/link.vue +47 -47
  129. package/docs/examples/buttons/popup.vue +39 -39
  130. package/docs/examples/buttons/size.vue +45 -45
  131. package/docs/examples/cascader-select/basic.vue +28 -28
  132. package/docs/examples/cascader-select/clearable.vue +34 -34
  133. package/docs/examples/cascader-select/disabled.vue +43 -43
  134. package/docs/examples/cascader-select/filterable.vue +37 -37
  135. package/docs/examples/cascader-select/methods.vue +84 -84
  136. package/docs/examples/cascader-select/multiple.vue +38 -38
  137. package/docs/examples/cascader-select/slot.vue +45 -45
  138. package/docs/examples/checkbox/basic.vue +18 -18
  139. package/docs/examples/checkbox/button.vue +19 -19
  140. package/docs/examples/checkbox/color.vue +25 -25
  141. package/docs/examples/checkbox/disabled.vue +17 -17
  142. package/docs/examples/checkbox/min-max.vue +20 -20
  143. package/docs/examples/checkbox/mixed.vue +56 -56
  144. package/docs/examples/checkbox/size.vue +28 -28
  145. package/docs/examples/code-mirror/basic.vue +11 -11
  146. package/docs/examples/code-mirror/events.vue +42 -42
  147. package/docs/examples/code-mirror/height.vue +25 -25
  148. package/docs/examples/code-mirror/mode.vue +33 -33
  149. package/docs/examples/code-mirror/readonly.vue +14 -14
  150. package/docs/examples/collapse/basic.vue +82 -82
  151. package/docs/examples/comp/basic.vue +7 -7
  152. package/docs/examples/comp/collapse.vue +38 -38
  153. package/docs/examples/comp/tabs.vue +38 -38
  154. package/docs/examples/count/basic.vue +101 -101
  155. package/docs/examples/count-up/basic.vue +89 -89
  156. package/docs/examples/data-panel/basic.vue +110 -110
  157. package/docs/examples/date/basic.vue +73 -73
  158. package/docs/examples/date/default-value.vue +59 -59
  159. package/docs/examples/date/format.vue +75 -75
  160. package/docs/examples/date/range.vue +66 -66
  161. package/docs/examples/date/types.vue +79 -79
  162. package/docs/examples/decorated-title/basic.vue +31 -31
  163. package/docs/examples/dialog/basic.vue +36 -36
  164. package/docs/examples/dialog/custom-buttons.vue +44 -44
  165. package/docs/examples/dialog/fullscreen.vue +23 -23
  166. package/docs/examples/dialog/no-mask.vue +17 -17
  167. package/docs/examples/dialog/size.vue +44 -44
  168. package/docs/examples/dialog/steps.vue +57 -57
  169. package/docs/examples/dialog-full/basic.vue +29 -29
  170. package/docs/examples/dialog-full/custom-buttons.vue +45 -45
  171. package/docs/examples/dialog-full/no-buttons.vue +18 -18
  172. package/docs/examples/dialog-full/no-header.vue +27 -27
  173. package/docs/examples/dialog-full/steps.vue +71 -71
  174. package/docs/examples/divider/basic.vue +52 -52
  175. package/docs/examples/drawer/basic.vue +35 -35
  176. package/docs/examples/drawer/custom-buttons.vue +34 -34
  177. package/docs/examples/drawer/direction.vue +47 -47
  178. package/docs/examples/drawer/mask.vue +36 -36
  179. package/docs/examples/drawer/no-buttons.vue +20 -20
  180. package/docs/examples/drawer/size.vue +28 -28
  181. package/docs/examples/dynamic-layer/basic.vue +33 -33
  182. package/docs/examples/dynamic-layer/custom-buttons.vue +43 -43
  183. package/docs/examples/dynamic-layer/form.vue +73 -73
  184. package/docs/examples/dynamic-layer/steps.vue +52 -52
  185. package/docs/examples/dynamic-layer/types.vue +40 -40
  186. package/docs/examples/echarts/basic.vue +31 -31
  187. package/docs/examples/echarts/dynamic.vue +43 -43
  188. package/docs/examples/echarts/line.vue +46 -46
  189. package/docs/examples/echarts/pie.vue +44 -44
  190. package/docs/examples/editor/basic.vue +15 -15
  191. package/docs/examples/form/basic.vue +665 -665
  192. package/docs/examples/form/init.vue +76 -76
  193. package/docs/examples/form/master-detail.vue +203 -203
  194. package/docs/examples/form/rule-format.vue +179 -179
  195. package/docs/examples/guid/basic.vue +10 -10
  196. package/docs/examples/guid/size.vue +13 -13
  197. package/docs/examples/hpanel/basic.vue +79 -79
  198. package/docs/examples/icon/basic.vue +9 -9
  199. package/docs/examples/icon/rotate-flip.vue +9 -9
  200. package/docs/examples/icon/size.vue +7 -7
  201. package/docs/examples/input/basic.vue +10 -10
  202. package/docs/examples/input/clearable.vue +12 -12
  203. package/docs/examples/input/disabled.vue +6 -6
  204. package/docs/examples/input/icon.vue +23 -23
  205. package/docs/examples/input/password.vue +18 -18
  206. package/docs/examples/input/size.vue +13 -13
  207. package/docs/examples/input/textarea.vue +25 -25
  208. package/docs/examples/input/word-limit.vue +28 -28
  209. package/docs/examples/input-button/basic.vue +33 -33
  210. package/docs/examples/input-code/basic.vue +29 -29
  211. package/docs/examples/input-color/basic.vue +10 -10
  212. package/docs/examples/input-color/disabled.vue +13 -13
  213. package/docs/examples/input-color/format.vue +17 -17
  214. package/docs/examples/input-color/no-alpha.vue +13 -13
  215. package/docs/examples/input-color/only-button.vue +15 -15
  216. package/docs/examples/input-color/predefine.vue +31 -31
  217. package/docs/examples/input-color/size.vue +15 -15
  218. package/docs/examples/input-layer/basic.vue +86 -86
  219. package/docs/examples/input-layer/render-vnode-page.vue +160 -160
  220. package/docs/examples/input-layer/render-vnode.vue +127 -127
  221. package/docs/examples/input-rows/basic.vue +73 -73
  222. package/docs/examples/input-rows/drag.vue +48 -48
  223. package/docs/examples/input-rows/layer-form.vue +85 -85
  224. package/docs/examples/input-rows/nested.vue +91 -91
  225. package/docs/examples/input-tag/basic.vue +27 -27
  226. package/docs/examples/input-tag/colors.vue +23 -23
  227. package/docs/examples/input-tag/readonly.vue +17 -17
  228. package/docs/examples/layer/basic.vue +43 -43
  229. package/docs/examples/layer/custom-buttons.vue +61 -61
  230. package/docs/examples/layer/drawer.vue +37 -37
  231. package/docs/examples/layer/full.vue +38 -38
  232. package/docs/examples/layer/modal.vue +34 -34
  233. package/docs/examples/layer/steps.vue +46 -46
  234. package/docs/examples/layer-form/basic.vue +76 -76
  235. package/docs/examples/layer-form/config.vue +82 -82
  236. package/docs/examples/layer-form/size.vue +72 -72
  237. package/docs/examples/layout/basic.vue +36 -36
  238. package/docs/examples/layout/custom-size.vue +50 -50
  239. package/docs/examples/layout/disable-move.vue +37 -37
  240. package/docs/examples/layout/hide-mid-when-narrow.vue +96 -96
  241. package/docs/examples/layout/min-size.vue +73 -73
  242. package/docs/examples/layout/percent-size.vue +80 -80
  243. package/docs/examples/layout/simple.vue +22 -22
  244. package/docs/examples/layout/top-side.vue +34 -34
  245. package/docs/examples/map/basic.vue +22 -22
  246. package/docs/examples/menu/basic.vue +58 -58
  247. package/docs/examples/menu/collapsed.vue +49 -49
  248. package/docs/examples/menu/horizontal.vue +44 -44
  249. package/docs/examples/menu/selection-test.vue +104 -104
  250. package/docs/examples/menu/theme.vue +46 -46
  251. package/docs/examples/menu/vertical.vue +46 -46
  252. package/docs/examples/number/advanced.vue +143 -143
  253. package/docs/examples/number/basic.vue +63 -63
  254. package/docs/examples/number/disabled.vue +49 -49
  255. package/docs/examples/number/size.vue +42 -42
  256. package/docs/examples/number/slots.vue +123 -123
  257. package/docs/examples/number/step-strictly.vue +41 -41
  258. package/docs/examples/number/step.vue +47 -47
  259. package/docs/examples/page/basic.vue +41 -41
  260. package/docs/examples/page/code-table-model.vue +428 -428
  261. package/docs/examples/page/dept-user-management.vue +211 -211
  262. package/docs/examples/page/init.vue +87 -87
  263. package/docs/examples/page/log.vue +453 -453
  264. package/docs/examples/page/user-management.vue +313 -313
  265. package/docs/examples/panel/tool-buttons.vue +18 -18
  266. package/docs/examples/radio/basic.vue +17 -17
  267. package/docs/examples/radio/button.vue +17 -17
  268. package/docs/examples/radio/color.vue +18 -18
  269. package/docs/examples/radio/disabled.vue +17 -17
  270. package/docs/examples/radio/size.vue +29 -29
  271. package/docs/examples/rate/basic.vue +24 -24
  272. package/docs/examples/rate/half.vue +24 -24
  273. package/docs/examples/rate/readonly.vue +11 -11
  274. package/docs/examples/rate/text.vue +37 -37
  275. package/docs/examples/select/basic.vue +16 -16
  276. package/docs/examples/select/clearable.vue +22 -22
  277. package/docs/examples/select/disabled.vue +31 -31
  278. package/docs/examples/select/filterable.vue +24 -24
  279. package/docs/examples/select/group.vue +23 -23
  280. package/docs/examples/select/icon.vue +16 -16
  281. package/docs/examples/select/multiple.vue +18 -18
  282. package/docs/examples/select/size.vue +39 -39
  283. package/docs/examples/slider/basic.vue +42 -42
  284. package/docs/examples/slider/disabled.vue +17 -17
  285. package/docs/examples/slider/marks.vue +30 -30
  286. package/docs/examples/slider/size.vue +37 -37
  287. package/docs/examples/slider/tooltip.vue +36 -36
  288. package/docs/examples/slider/vertical.vue +26 -26
  289. package/docs/examples/slider-captcha/basic.vue +44 -44
  290. package/docs/examples/slider-captcha/custom.vue +48 -48
  291. package/docs/examples/switch/basic.vue +16 -16
  292. package/docs/examples/switch/disabled.vue +13 -13
  293. package/docs/examples/switch/loading.vue +13 -13
  294. package/docs/examples/switch/size.vue +15 -15
  295. package/docs/examples/switch/text.vue +13 -13
  296. package/docs/examples/table/action-filter.vue +126 -126
  297. package/docs/examples/table/actions.vue +116 -116
  298. package/docs/examples/table/add-row.vue +103 -103
  299. package/docs/examples/table/basic.vue +168 -168
  300. package/docs/examples/table/checkbox-layout.vue +68 -68
  301. package/docs/examples/table/custom-layout.vue +115 -115
  302. package/docs/examples/table/dynamic-type.vue +73 -73
  303. package/docs/examples/table/editable.vue +262 -262
  304. package/docs/examples/table/field-selection.vue +87 -87
  305. package/docs/examples/table/frozen-column.vue +140 -140
  306. package/docs/examples/table/height-mode.vue +99 -99
  307. package/docs/examples/table/icon.vue +85 -85
  308. package/docs/examples/table/link.vue +66 -66
  309. package/docs/examples/table/multiple.vue +188 -188
  310. package/docs/examples/table/pagination.vue +151 -151
  311. package/docs/examples/table/single-selection.vue +64 -64
  312. package/docs/examples/table/sub-table-lazy.vue +97 -97
  313. package/docs/examples/table/sub-table.vue +103 -103
  314. package/docs/examples/table/tag.vue +43 -43
  315. package/docs/examples/table/tree-column.vue +119 -119
  316. package/docs/examples/table/tree-data.vue +141 -141
  317. package/docs/examples/table/tree-default-expand-all.vue +60 -60
  318. package/docs/examples/table/tree-lazy.vue +80 -80
  319. package/docs/examples/table/tree-set-selection.vue +75 -75
  320. package/docs/examples/table-panel/basic.vue +229 -229
  321. package/docs/examples/table-panel/batch-operations.vue +285 -285
  322. package/docs/examples/table-panel/button-visibility.vue +88 -88
  323. package/docs/examples/table-panel/filter.vue +219 -219
  324. package/docs/examples/table-panel/get-selection.vue +111 -111
  325. package/docs/examples/table-panel/mask.vue +151 -151
  326. package/docs/examples/table-panel/multiple-selection.vue +243 -243
  327. package/docs/examples/table-panel/pagination.vue +133 -133
  328. package/docs/examples/table-panel/sub-table-lazy.vue +118 -118
  329. package/docs/examples/table-panel/tree-parent-key.vue +67 -67
  330. package/docs/examples/tabs/basic.vue +98 -98
  331. package/docs/examples/time/base.vue +67 -67
  332. package/docs/examples/title/basic.vue +87 -87
  333. package/docs/examples/tree/accordion.vue +46 -46
  334. package/docs/examples/tree/basic.vue +50 -50
  335. package/docs/examples/tree/buttons.vue +53 -53
  336. package/docs/examples/tree/checkable.vue +52 -52
  337. package/docs/examples/tree/custom-keys.vue +39 -39
  338. package/docs/examples/tree/default-expanded.vue +52 -52
  339. package/docs/examples/tree/draggable.vue +29 -29
  340. package/docs/examples/tree/expand-on-click.vue +39 -39
  341. package/docs/examples/tree/flat-data.vue +20 -20
  342. package/docs/examples/tree/icon.vue +40 -40
  343. package/docs/examples/tree/load-data.vue +37 -37
  344. package/docs/examples/tree/methods.vue +74 -74
  345. package/docs/examples/tree/theme.vue +33 -33
  346. package/docs/examples/tree-select/basic.vue +47 -47
  347. package/docs/examples/upload/accept.vue +31 -31
  348. package/docs/examples/upload/basic.vue +12 -12
  349. package/docs/examples/upload/drag.vue +11 -11
  350. package/docs/examples/upload/image.vue +17 -17
  351. package/docs/examples/upload/limit.vue +20 -20
  352. package/docs/examples/upload/multiple.vue +17 -17
  353. package/docs/examples/upload/readonly.vue +17 -17
  354. package/docs/examples/utils/cipher.vue +160 -160
  355. package/docs/examples/utils/common.vue +153 -153
  356. package/docs/examples/utils/date.vue +56 -56
  357. package/docs/examples/utils/dom.vue +52 -52
  358. package/docs/examples/utils/is.vue +70 -70
  359. package/docs/examples/workflow/basic.vue +265 -265
  360. package/docs/examples/workflow-viewer/basic.vue +248 -248
  361. package/package.json +23 -23
package/README.md CHANGED
@@ -1,156 +1,156 @@
1
- # SimCode UI
2
-
3
- <div align="center">
4
- <h1>SimCode UI</h1>
5
- <p>基于 Vue 3 + TypeScript 的现代化 UI 组件库</p>
6
- </div>
7
-
8
- ## ✨ 特性
9
-
10
- - 🚀 **现代化技术栈**: 基于 Vue 3 + TypeScript + Vite
11
- - 📦 **开箱即用**: 提供完善的类型定义和文档
12
- - 🎨 **精美设计**: 现代化的设计风格
13
- - 🔧 **易于定制**: 支持主题定制
14
- - ⚡️ **按需加载**: 支持 Tree Shaking
15
- - 🧪 **完善测试**: 单元测试覆盖
16
-
17
- ## 📦 安装
18
-
19
- 使用 pnpm:
20
-
21
- ```bash
22
- pnpm add @a2simcode/ui
23
- ```
24
-
25
- 使用 npm:
26
-
27
- ```bash
28
- npm install @a2simcode/ui
29
- ```
30
-
31
- 使用 yarn:
32
-
33
- ```bash
34
- yarn add @a2simcode/ui
35
- ```
36
-
37
- ### 安装 Peer Dependencies
38
-
39
- `@a2simcode/ui` 使用 peer dependencies 来避免重复打包依赖。**必须安装**以下依赖:
40
-
41
- ```bash
42
- pnpm add vue element-plus
43
- ```
44
-
45
- 根据你使用的组件,可能还需要安装以下**可选依赖**:
46
-
47
- ```bash
48
- # 如果使用表格组件
49
- pnpm add @visactor/vtable @visactor/vtable-editors
50
-
51
- # 如果使用图表组件
52
- pnpm add echarts
53
-
54
- # 如果使用代码编辑器组件
55
- pnpm add codemirror @codemirror/autocomplete @codemirror/commands @codemirror/lang-javascript @codemirror/lang-json @codemirror/lang-sql @codemirror/lang-python @codemirror/lang-java @codemirror/lang-css @codemirror/lang-html @codemirror/lang-xml @codemirror/lang-markdown @codemirror/language @codemirror/state @codemirror/view
56
-
57
- # 如果使用其他功能组件
58
- pnpm add @iconify/vue @vueuse/core dayjs async-validator crypto-js sortablejs sql-formatter countup.js @bwip-js/browser @wangeditor/editor diagram-js diagram-js-direct-editing min-dom inherits tiny-svg min-dash
59
- ```
60
-
61
- > **注意**: 由于 `@a2simcode/ui` 输出的是预打包的单文件,使用方的打包器可能无法自动识别 peer dependencies。请确保在使用相关组件前,已安装对应的 peer dependencies。
62
-
63
- ## 🔨 快速开始
64
-
65
- ### 完整引入
66
-
67
- ```typescript
68
- import { createApp } from 'vue'
69
- import App from './App.vue'
70
- import SimCodeUI from '@a2simcode/ui'
71
- import '@a2simcode/ui/dist/style.css'
72
-
73
- const app = createApp(App)
74
- app.use(SimCodeUI)
75
- app.mount('#app')
76
- ```
77
-
78
- ### 按需引入
79
-
80
- ```vue
81
- <template>
82
- <j-button type="primary">按钮</j-button>
83
- </template>
84
-
85
- <script setup lang="ts">
86
- import { JButton } from '@a2simcode/ui'
87
- import '@a2simcode/ui/dist/style.css'
88
- </script>
89
- ```
90
-
91
- ## 🎯 组件列表
92
-
93
- - ✅ Button 按钮
94
- - ✅ Input 输入框
95
- - ✅ Radio 单选框
96
- - 🚧 更多组件开发中...
97
-
98
- ## 💻 本地开发
99
-
100
- ```bash
101
- # 进入项目目录
102
- cd simcode-ui
103
-
104
- # 安装依赖
105
- pnpm install
106
-
107
- # 启动开发服务器
108
- pnpm dev
109
-
110
- # 构建组件库
111
- pnpm build
112
-
113
- # 运行测试
114
- pnpm test
115
-
116
- # 启动文档站点
117
- pnpm docs:dev
118
- ```
119
-
120
- ## 📁 项目结构
121
-
122
- ```
123
- simcode-ui/
124
- ├── packages/ # 组件源码
125
- │ ├── components/ # 组件
126
- │ │ ├── button/ # 按钮组件
127
- │ │ ├── input/ # 输入框组件
128
- │ │ └── index.ts # 组件入口
129
- │ └── theme/ # 主题样式
130
- │ └── src/ # 样式源码 (Less)
131
- ├── examples/ # 组件预览
132
- │ ├── App.vue # 预览应用
133
- │ └── main.ts # 入口文件
134
- ├── docs/ # 文档
135
- │ ├── .vitepress/ # VitePress 配置
136
- │ ├── guide/ # 指南
137
- │ └── components/ # 组件文档
138
- ├── __tests__/ # 测试文件
139
- ├── vite.config.ts # Vite 配置
140
- ├── vitest.config.ts # Vitest 配置
141
- └── package.json # 项目配置
142
- ```
143
-
144
- ## 🤝 贡献
145
-
146
- 欢迎提交 Issue 和 Pull Request!
147
-
148
- ## 📄 版权声明
149
-
150
- Copyright © 2024 苏州极简搭信息技术有限公司. All rights reserved.
151
-
152
- 本软件及其相关文档为专有软件,受版权法保护。未经版权所有者明确书面许可,不得以任何形式或方式(电子、机械、复印、录制或其他方式)复制、分发、传播或使用本软件的任何部分。
153
-
154
- ## 🙏 致谢
155
-
156
- 感谢所有为这个项目做出贡献的开发者!
1
+ # SimCode UI
2
+
3
+ <div align="center">
4
+ <h1>SimCode UI</h1>
5
+ <p>基于 Vue 3 + TypeScript 的现代化 UI 组件库</p>
6
+ </div>
7
+
8
+ ## ✨ 特性
9
+
10
+ - 🚀 **现代化技术栈**: 基于 Vue 3 + TypeScript + Vite
11
+ - 📦 **开箱即用**: 提供完善的类型定义和文档
12
+ - 🎨 **精美设计**: 现代化的设计风格
13
+ - 🔧 **易于定制**: 支持主题定制
14
+ - ⚡️ **按需加载**: 支持 Tree Shaking
15
+ - 🧪 **完善测试**: 单元测试覆盖
16
+
17
+ ## 📦 安装
18
+
19
+ 使用 pnpm:
20
+
21
+ ```bash
22
+ pnpm add @a2simcode/ui
23
+ ```
24
+
25
+ 使用 npm:
26
+
27
+ ```bash
28
+ npm install @a2simcode/ui
29
+ ```
30
+
31
+ 使用 yarn:
32
+
33
+ ```bash
34
+ yarn add @a2simcode/ui
35
+ ```
36
+
37
+ ### 安装 Peer Dependencies
38
+
39
+ `@a2simcode/ui` 使用 peer dependencies 来避免重复打包依赖。**必须安装**以下依赖:
40
+
41
+ ```bash
42
+ pnpm add vue element-plus
43
+ ```
44
+
45
+ 根据你使用的组件,可能还需要安装以下**可选依赖**:
46
+
47
+ ```bash
48
+ # 如果使用表格组件
49
+ pnpm add @visactor/vtable @visactor/vtable-editors
50
+
51
+ # 如果使用图表组件
52
+ pnpm add echarts
53
+
54
+ # 如果使用代码编辑器组件
55
+ pnpm add codemirror @codemirror/autocomplete @codemirror/commands @codemirror/lang-javascript @codemirror/lang-json @codemirror/lang-sql @codemirror/lang-python @codemirror/lang-java @codemirror/lang-css @codemirror/lang-html @codemirror/lang-xml @codemirror/lang-markdown @codemirror/language @codemirror/state @codemirror/view
56
+
57
+ # 如果使用其他功能组件
58
+ pnpm add @iconify/vue @vueuse/core dayjs async-validator crypto-js sortablejs sql-formatter countup.js @bwip-js/browser @wangeditor/editor diagram-js diagram-js-direct-editing min-dom inherits tiny-svg min-dash
59
+ ```
60
+
61
+ > **注意**: 由于 `@a2simcode/ui` 输出的是预打包的单文件,使用方的打包器可能无法自动识别 peer dependencies。请确保在使用相关组件前,已安装对应的 peer dependencies。
62
+
63
+ ## 🔨 快速开始
64
+
65
+ ### 完整引入
66
+
67
+ ```typescript
68
+ import { createApp } from 'vue'
69
+ import App from './App.vue'
70
+ import SimCodeUI from '@a2simcode/ui'
71
+ import '@a2simcode/ui/dist/style.css'
72
+
73
+ const app = createApp(App)
74
+ app.use(SimCodeUI)
75
+ app.mount('#app')
76
+ ```
77
+
78
+ ### 按需引入
79
+
80
+ ```vue
81
+ <template>
82
+ <j-button type="primary">按钮</j-button>
83
+ </template>
84
+
85
+ <script setup lang="ts">
86
+ import { JButton } from '@a2simcode/ui'
87
+ import '@a2simcode/ui/dist/style.css'
88
+ </script>
89
+ ```
90
+
91
+ ## 🎯 组件列表
92
+
93
+ - ✅ Button 按钮
94
+ - ✅ Input 输入框
95
+ - ✅ Radio 单选框
96
+ - 🚧 更多组件开发中...
97
+
98
+ ## 💻 本地开发
99
+
100
+ ```bash
101
+ # 进入项目目录
102
+ cd simcode-ui
103
+
104
+ # 安装依赖
105
+ pnpm install
106
+
107
+ # 启动开发服务器
108
+ pnpm dev
109
+
110
+ # 构建组件库
111
+ pnpm build
112
+
113
+ # 运行测试
114
+ pnpm test
115
+
116
+ # 启动文档站点
117
+ pnpm docs:dev
118
+ ```
119
+
120
+ ## 📁 项目结构
121
+
122
+ ```
123
+ simcode-ui/
124
+ ├── packages/ # 组件源码
125
+ │ ├── components/ # 组件
126
+ │ │ ├── button/ # 按钮组件
127
+ │ │ ├── input/ # 输入框组件
128
+ │ │ └── index.ts # 组件入口
129
+ │ └── theme/ # 主题样式
130
+ │ └── src/ # 样式源码 (Less)
131
+ ├── examples/ # 组件预览
132
+ │ ├── App.vue # 预览应用
133
+ │ └── main.ts # 入口文件
134
+ ├── docs/ # 文档
135
+ │ ├── .vitepress/ # VitePress 配置
136
+ │ ├── guide/ # 指南
137
+ │ └── components/ # 组件文档
138
+ ├── __tests__/ # 测试文件
139
+ ├── vite.config.ts # Vite 配置
140
+ ├── vitest.config.ts # Vitest 配置
141
+ └── package.json # 项目配置
142
+ ```
143
+
144
+ ## 🤝 贡献
145
+
146
+ 欢迎提交 Issue 和 Pull Request!
147
+
148
+ ## 📄 版权声明
149
+
150
+ Copyright © 2024 苏州极简搭信息技术有限公司. All rights reserved.
151
+
152
+ 本软件及其相关文档为专有软件,受版权法保护。未经版权所有者明确书面许可,不得以任何形式或方式(电子、机械、复印、录制或其他方式)复制、分发、传播或使用本软件的任何部分。
153
+
154
+ ## 🙏 致谢
155
+
156
+ 感谢所有为这个项目做出贡献的开发者!
@@ -10,6 +10,10 @@ export interface ButtonCompActionType {
10
10
  */
11
11
  config?: ButtonProps & {
12
12
  display?: boolean;
13
+ action?: string;
14
+ uploadAccept?: string;
15
+ uploadCallback?: (param: any) => void;
16
+ uploadSuccess?: (param: any) => void;
13
17
  };
14
18
  /**
15
19
  * @zh 按钮点击方法
@@ -18,10 +18,10 @@ declare const JInput: {
18
18
  type: string;
19
19
  disabled: boolean;
20
20
  rows: number;
21
+ placeholder: string;
21
22
  modelValue: string | number;
22
23
  showWordLimit: boolean;
23
24
  wordLimitPosition: "inside" | "outside";
24
- placeholder: string;
25
25
  clearable: boolean;
26
26
  showPassword: boolean;
27
27
  prependStyle: Record<string, string | number>;
@@ -56,10 +56,10 @@ declare const JInput: {
56
56
  type: string;
57
57
  disabled: boolean;
58
58
  rows: number;
59
+ placeholder: string;
59
60
  modelValue: string | number;
60
61
  showWordLimit: boolean;
61
62
  wordLimitPosition: "inside" | "outside";
62
- placeholder: string;
63
63
  clearable: boolean;
64
64
  showPassword: boolean;
65
65
  prependStyle: Record<string, string | number>;
@@ -96,10 +96,10 @@ declare const JInput: {
96
96
  type: string;
97
97
  disabled: boolean;
98
98
  rows: number;
99
+ placeholder: string;
99
100
  modelValue: string | number;
100
101
  showWordLimit: boolean;
101
102
  wordLimitPosition: "inside" | "outside";
102
- placeholder: string;
103
103
  clearable: boolean;
104
104
  showPassword: boolean;
105
105
  prependStyle: Record<string, string | number>;
@@ -101,10 +101,10 @@ declare const _default: import('vue').DefineComponent<InputProps, {}, {}, {}, {}
101
101
  type: string;
102
102
  disabled: boolean;
103
103
  rows: number;
104
+ placeholder: string;
104
105
  modelValue: string | number;
105
106
  showWordLimit: boolean;
106
107
  wordLimitPosition: "inside" | "outside";
107
- placeholder: string;
108
108
  clearable: boolean;
109
109
  showPassword: boolean;
110
110
  prependStyle: Record<string, string | number>;
@@ -22,8 +22,8 @@ export declare const JInputLayer: {
22
22
  valueKey: string;
23
23
  labelKey: string;
24
24
  buttons: any[];
25
- modelValue: string;
26
25
  placeholder: string;
26
+ modelValue: string;
27
27
  clearable: boolean;
28
28
  readonly: boolean;
29
29
  columns: any[];
@@ -853,8 +853,8 @@ export declare const JInputLayer: {
853
853
  valueKey: string;
854
854
  labelKey: string;
855
855
  buttons: any[];
856
- modelValue: string;
857
856
  placeholder: string;
857
+ modelValue: string;
858
858
  clearable: boolean;
859
859
  readonly: boolean;
860
860
  columns: any[];
@@ -893,8 +893,8 @@ export declare const JInputLayer: {
893
893
  valueKey: string;
894
894
  labelKey: string;
895
895
  buttons: any[];
896
- modelValue: string;
897
896
  placeholder: string;
897
+ modelValue: string;
898
898
  clearable: boolean;
899
899
  readonly: boolean;
900
900
  columns: any[];
@@ -90,8 +90,8 @@ declare const _default: import('vue').DefineComponent<InputLayerProps, {
90
90
  valueKey: string;
91
91
  labelKey: string;
92
92
  buttons: any[];
93
- modelValue: string;
94
93
  placeholder: string;
94
+ modelValue: string;
95
95
  clearable: boolean;
96
96
  readonly: boolean;
97
97
  columns: any[];
@@ -23,8 +23,8 @@ declare const JInputMap: {
23
23
  "update:modelValue": (...args: any[]) => void;
24
24
  change: (...args: any[]) => void;
25
25
  }, import('vue').PublicProps, {
26
- modelValue: string;
27
26
  placeholder: string;
27
+ modelValue: string;
28
28
  clearable: boolean;
29
29
  readonly: boolean;
30
30
  }, true, {}, {}, import('vue').GlobalComponents, import('vue').GlobalDirectives, string, {
@@ -59,8 +59,8 @@ declare const JInputMap: {
59
59
  "onUpdate:modelValue"?: ((...args: any[]) => any) | undefined;
60
60
  onChange?: ((...args: any[]) => any) | undefined;
61
61
  }>, {}, {}, {}, {}, {
62
- modelValue: string;
63
62
  placeholder: string;
63
+ modelValue: string;
64
64
  clearable: boolean;
65
65
  readonly: boolean;
66
66
  }>;
@@ -91,8 +91,8 @@ declare const JInputMap: {
91
91
  "update:modelValue": (...args: any[]) => void;
92
92
  change: (...args: any[]) => void;
93
93
  }, string, {
94
- modelValue: string;
95
94
  placeholder: string;
95
+ modelValue: string;
96
96
  clearable: boolean;
97
97
  readonly: boolean;
98
98
  }, {}, string, {}, import('vue').GlobalComponents, import('vue').GlobalDirectives, string, import('vue').ComponentProvideOptions> & import('vue').VNodeProps & import('vue').AllowedComponentProps & import('vue').ComponentCustomProps & {
@@ -74,8 +74,8 @@ declare const _default: import('vue').DefineComponent<import('vue').ExtractPropT
74
74
  "onUpdate:modelValue"?: ((...args: any[]) => any) | undefined;
75
75
  onChange?: ((...args: any[]) => any) | undefined;
76
76
  }>, {
77
- modelValue: string;
78
77
  placeholder: string;
78
+ modelValue: string;
79
79
  clearable: boolean;
80
80
  readonly: boolean;
81
81
  }, {}, {}, {}, string, import('vue').ComponentProvideOptions, true, {
@@ -16,8 +16,8 @@ export declare const JInputTag: {
16
16
  }, import('vue').PublicProps, {
17
17
  size: "small" | "default" | "large";
18
18
  options: any[];
19
- modelValue: string;
20
19
  placeholder: string;
20
+ modelValue: string;
21
21
  readonly: boolean;
22
22
  colors: any[];
23
23
  isStyleLoop: boolean;
@@ -38,8 +38,8 @@ export declare const JInputTag: {
38
38
  }>, {}, {}, {}, {}, {
39
39
  size: "small" | "default" | "large";
40
40
  options: any[];
41
- modelValue: string;
42
41
  placeholder: string;
42
+ modelValue: string;
43
43
  readonly: boolean;
44
44
  colors: any[];
45
45
  isStyleLoop: boolean;
@@ -64,8 +64,8 @@ export declare const JInputTag: {
64
64
  }, string, {
65
65
  size: "small" | "default" | "large";
66
66
  options: any[];
67
- modelValue: string;
68
67
  placeholder: string;
68
+ modelValue: string;
69
69
  readonly: boolean;
70
70
  colors: any[];
71
71
  isStyleLoop: boolean;
@@ -31,8 +31,8 @@ declare const _default: import('vue').DefineComponent<InputTagProps, {}, {}, {},
31
31
  }>, {
32
32
  size: "small" | "default" | "large";
33
33
  options: any[];
34
- modelValue: string;
35
34
  placeholder: string;
35
+ modelValue: string;
36
36
  readonly: boolean;
37
37
  colors: any[];
38
38
  isStyleLoop: boolean;
@@ -21,8 +21,8 @@ declare const JTime: {
21
21
  size: "large" | "default" | "small";
22
22
  id: string | string[];
23
23
  disabled: boolean;
24
- modelValue: string | number | Date | Array<string | number | Date>;
25
24
  placeholder: string;
25
+ modelValue: string | number | Date | Array<string | number | Date>;
26
26
  clearable: boolean;
27
27
  readonly: boolean;
28
28
  startPlaceholder: string;
@@ -55,8 +55,8 @@ declare const JTime: {
55
55
  size: "large" | "default" | "small";
56
56
  id: string | string[];
57
57
  disabled: boolean;
58
- modelValue: string | number | Date | Array<string | number | Date>;
59
58
  placeholder: string;
59
+ modelValue: string | number | Date | Array<string | number | Date>;
60
60
  clearable: boolean;
61
61
  readonly: boolean;
62
62
  startPlaceholder: string;
@@ -91,8 +91,8 @@ declare const JTime: {
91
91
  size: "large" | "default" | "small";
92
92
  id: string | string[];
93
93
  disabled: boolean;
94
- modelValue: string | number | Date | Array<string | number | Date>;
95
94
  placeholder: string;
95
+ modelValue: string | number | Date | Array<string | number | Date>;
96
96
  clearable: boolean;
97
97
  readonly: boolean;
98
98
  startPlaceholder: string;
@@ -50,8 +50,8 @@ declare const _default: import('vue').DefineComponent<TimeProps, {
50
50
  size: "large" | "default" | "small";
51
51
  id: string | string[];
52
52
  disabled: boolean;
53
- modelValue: string | number | Date | Array<string | number | Date>;
54
53
  placeholder: string;
54
+ modelValue: string | number | Date | Array<string | number | Date>;
55
55
  clearable: boolean;
56
56
  readonly: boolean;
57
57
  startPlaceholder: string;
@@ -109,27 +109,27 @@ declare const JUpload: {
109
109
  notUploadChange: (...args: any[]) => void;
110
110
  }, import('vue').PublicProps, {
111
111
  btnText: string;
112
- modelValue: string;
112
+ uploadCallback: Function;
113
+ upload: Function;
113
114
  placeholder: string;
115
+ btnType: string;
116
+ btnSize: "small" | "default" | "large";
117
+ showFileList: boolean;
118
+ accept: string;
119
+ limit: number;
120
+ modelValue: string;
114
121
  readonly: boolean;
115
122
  multiple: boolean;
116
123
  drag: boolean;
117
124
  isUploadImg: boolean;
118
- showFileList: boolean;
119
125
  isShowSuccessIcon: boolean;
120
- limit: number;
121
126
  maxSize: number;
122
127
  sizeType: string;
123
- accept: string;
124
128
  onlyName: boolean;
125
129
  isTip: boolean;
126
- btnType: string;
127
- btnSize: "small" | "default" | "large";
128
130
  isNotApi: boolean;
129
131
  autoUpload: boolean;
130
132
  isLayer: boolean;
131
- upload: Function;
132
- uploadCallback: Function;
133
133
  isSaveLast: boolean;
134
134
  }, true, {}, {}, import('vue').GlobalComponents, import('vue').GlobalDirectives, string, {
135
135
  iframe: HTMLIFrameElement;
@@ -241,27 +241,27 @@ declare const JUpload: {
241
241
  onNotUploadChange?: ((...args: any[]) => any) | undefined;
242
242
  }>, {}, {}, {}, {}, {
243
243
  btnText: string;
244
- modelValue: string;
244
+ uploadCallback: Function;
245
+ upload: Function;
245
246
  placeholder: string;
247
+ btnType: string;
248
+ btnSize: "small" | "default" | "large";
249
+ showFileList: boolean;
250
+ accept: string;
251
+ limit: number;
252
+ modelValue: string;
246
253
  readonly: boolean;
247
254
  multiple: boolean;
248
255
  drag: boolean;
249
256
  isUploadImg: boolean;
250
- showFileList: boolean;
251
257
  isShowSuccessIcon: boolean;
252
- limit: number;
253
258
  maxSize: number;
254
259
  sizeType: string;
255
- accept: string;
256
260
  onlyName: boolean;
257
261
  isTip: boolean;
258
- btnType: string;
259
- btnSize: "small" | "default" | "large";
260
262
  isNotApi: boolean;
261
263
  autoUpload: boolean;
262
264
  isLayer: boolean;
263
- upload: Function;
264
- uploadCallback: Function;
265
265
  isSaveLast: boolean;
266
266
  }>;
267
267
  __isFragment?: never;
@@ -377,27 +377,27 @@ declare const JUpload: {
377
377
  notUploadChange: (...args: any[]) => void;
378
378
  }, string, {
379
379
  btnText: string;
380
- modelValue: string;
380
+ uploadCallback: Function;
381
+ upload: Function;
381
382
  placeholder: string;
383
+ btnType: string;
384
+ btnSize: "small" | "default" | "large";
385
+ showFileList: boolean;
386
+ accept: string;
387
+ limit: number;
388
+ modelValue: string;
382
389
  readonly: boolean;
383
390
  multiple: boolean;
384
391
  drag: boolean;
385
392
  isUploadImg: boolean;
386
- showFileList: boolean;
387
393
  isShowSuccessIcon: boolean;
388
- limit: number;
389
394
  maxSize: number;
390
395
  sizeType: string;
391
- accept: string;
392
396
  onlyName: boolean;
393
397
  isTip: boolean;
394
- btnType: string;
395
- btnSize: "small" | "default" | "large";
396
398
  isNotApi: boolean;
397
399
  autoUpload: boolean;
398
400
  isLayer: boolean;
399
- upload: Function;
400
- uploadCallback: Function;
401
401
  isSaveLast: boolean;
402
402
  }, {}, string, {}, import('vue').GlobalComponents, import('vue').GlobalDirectives, string, import('vue').ComponentProvideOptions> & import('vue').VNodeProps & import('vue').AllowedComponentProps & import('vue').ComponentCustomProps & {
403
403
  install: (app: import('vue').App) => void;
@@ -88,10 +88,10 @@ declare const __VLS_component: import('vue').DefineComponent<import('vue').Extra
88
88
  };
89
89
  }>> & Readonly<{}>, {
90
90
  list: Record<string, any>[];
91
+ showFileList: boolean;
91
92
  readonly: boolean;
92
93
  drag: boolean;
93
94
  isUploadImg: boolean;
94
- showFileList: boolean;
95
95
  isShowSuccessIcon: boolean;
96
96
  }, {}, {}, {}, string, import('vue').ComponentProvideOptions, true, {}, HTMLDivElement>;
97
97
  declare const _default: __VLS_WithTemplateSlots<typeof __VLS_component, __VLS_TemplateResult["slots"]>;