@a2simcode/ui 0.0.67 → 0.0.68

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 (320) hide show
  1. package/.cursor/skills/ui-component-helper/README.md +43 -43
  2. package/.cursor/skills/ui-component-helper/SKILL.md +81 -81
  3. package/LICENSE +53 -53
  4. package/README.md +156 -156
  5. package/dist/components/input-layer/index.d.ts +40 -0
  6. package/dist/components/input-layer/src/input-layer.vue.d.ts +40 -0
  7. package/dist/components/table-panel/index.d.ts +60 -0
  8. package/dist/components/table-panel/src/table-panel.vue.d.ts +60 -0
  9. package/dist/simcode-ui.es.js +4350 -4285
  10. package/dist/simcode-ui.umd.js +2 -2
  11. package/dist/stats.html +1 -1
  12. package/dist/ui.css +1 -1
  13. package/docs/components/autocomplete.md +89 -89
  14. package/docs/components/barcode.md +101 -101
  15. package/docs/components/button-select.md +24 -24
  16. package/docs/components/button.md +117 -117
  17. package/docs/components/buttons.md +119 -119
  18. package/docs/components/cascader-select.md +114 -114
  19. package/docs/components/checkbox.md +114 -114
  20. package/docs/components/code-mirror.md +85 -85
  21. package/docs/components/collapse.md +26 -26
  22. package/docs/components/comp.md +71 -71
  23. package/docs/components/count-up.md +24 -24
  24. package/docs/components/count.md +24 -24
  25. package/docs/components/data-panel.md +24 -24
  26. package/docs/components/dialog-full.md +112 -112
  27. package/docs/components/dialog.md +127 -127
  28. package/docs/components/divider.md +24 -24
  29. package/docs/components/drawer.md +127 -127
  30. package/docs/components/dynamic-layer.md +118 -118
  31. package/docs/components/echarts.md +72 -72
  32. package/docs/components/editor.md +24 -24
  33. package/docs/components/form.md +27 -27
  34. package/docs/components/guid.md +39 -39
  35. package/docs/components/hpanel.md +24 -24
  36. package/docs/components/icon.md +56 -56
  37. package/docs/components/input-button.md +24 -24
  38. package/docs/components/input-code.md +24 -24
  39. package/docs/components/input-color.md +114 -114
  40. package/docs/components/input-layer.md +26 -26
  41. package/docs/components/input-rows.md +370 -370
  42. package/docs/components/input-tag.md +50 -50
  43. package/docs/components/input.md +129 -129
  44. package/docs/components/layer-form.md +61 -61
  45. package/docs/components/layer.md +127 -127
  46. package/docs/components/layout.md +132 -132
  47. package/docs/components/map.md +24 -24
  48. package/docs/components/menu.md +121 -121
  49. package/docs/components/meta/buttons.ts +56 -56
  50. package/docs/components/meta/comp.ts +230 -230
  51. package/docs/components/meta/dynamic-layer.ts +99 -99
  52. package/docs/components/meta/echarts.ts +64 -64
  53. package/docs/components/meta/form-item.ts +50 -50
  54. package/docs/components/meta/form.ts +160 -160
  55. package/docs/components/meta/guid.ts +42 -42
  56. package/docs/components/meta/input-cards.ts +112 -112
  57. package/docs/components/meta/input-color.ts +243 -243
  58. package/docs/components/meta/input-rows.ts +113 -113
  59. package/docs/components/meta/input.ts +411 -411
  60. package/docs/components/meta/layer-form.ts +56 -56
  61. package/docs/components/meta/map.ts +68 -68
  62. package/docs/components/meta/number.ts +296 -296
  63. package/docs/components/meta/page.ts +67 -67
  64. package/docs/components/meta/panel.ts +152 -152
  65. package/docs/components/meta/radio.ts +55 -55
  66. package/docs/components/meta/slider.ts +270 -270
  67. package/docs/components/meta/table-panel.ts +154 -154
  68. package/docs/components/meta/table.ts +363 -363
  69. package/docs/components/meta/tabs.ts +136 -136
  70. package/docs/components/meta/tree-select.ts +199 -199
  71. package/docs/components/meta/workflow-viewer.ts +55 -55
  72. package/docs/components/meta/workflow.ts +113 -113
  73. package/docs/components/number.md +124 -124
  74. package/docs/components/page.md +42 -42
  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 +199 -199
  83. package/docs/components/table.md +304 -304
  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 +54 -54
  142. package/docs/examples/count-up/basic.vue +89 -89
  143. package/docs/examples/data-panel/basic.vue +110 -110
  144. package/docs/examples/dialog/basic.vue +36 -36
  145. package/docs/examples/dialog/custom-buttons.vue +44 -44
  146. package/docs/examples/dialog/fullscreen.vue +23 -23
  147. package/docs/examples/dialog/no-mask.vue +17 -17
  148. package/docs/examples/dialog/size.vue +44 -44
  149. package/docs/examples/dialog/steps.vue +57 -57
  150. package/docs/examples/dialog-full/basic.vue +29 -29
  151. package/docs/examples/dialog-full/custom-buttons.vue +45 -45
  152. package/docs/examples/dialog-full/no-buttons.vue +18 -18
  153. package/docs/examples/dialog-full/no-header.vue +27 -27
  154. package/docs/examples/dialog-full/steps.vue +71 -71
  155. package/docs/examples/divider/basic.vue +52 -52
  156. package/docs/examples/drawer/basic.vue +35 -35
  157. package/docs/examples/drawer/custom-buttons.vue +34 -34
  158. package/docs/examples/drawer/direction.vue +47 -47
  159. package/docs/examples/drawer/mask.vue +36 -36
  160. package/docs/examples/drawer/no-buttons.vue +20 -20
  161. package/docs/examples/drawer/size.vue +28 -28
  162. package/docs/examples/dynamic-layer/basic.vue +33 -33
  163. package/docs/examples/dynamic-layer/custom-buttons.vue +43 -43
  164. package/docs/examples/dynamic-layer/form.vue +73 -73
  165. package/docs/examples/dynamic-layer/steps.vue +52 -52
  166. package/docs/examples/dynamic-layer/types.vue +40 -40
  167. package/docs/examples/echarts/basic.vue +31 -31
  168. package/docs/examples/echarts/dynamic.vue +43 -43
  169. package/docs/examples/echarts/line.vue +46 -46
  170. package/docs/examples/echarts/pie.vue +44 -44
  171. package/docs/examples/editor/basic.vue +15 -15
  172. package/docs/examples/form/basic.vue +450 -436
  173. package/docs/examples/guid/basic.vue +10 -10
  174. package/docs/examples/guid/size.vue +13 -13
  175. package/docs/examples/hpanel/basic.vue +79 -79
  176. package/docs/examples/icon/basic.vue +9 -9
  177. package/docs/examples/icon/rotate-flip.vue +9 -9
  178. package/docs/examples/icon/size.vue +7 -7
  179. package/docs/examples/input/basic.vue +10 -10
  180. package/docs/examples/input/clearable.vue +12 -12
  181. package/docs/examples/input/disabled.vue +6 -6
  182. package/docs/examples/input/icon.vue +23 -23
  183. package/docs/examples/input/password.vue +18 -18
  184. package/docs/examples/input/size.vue +13 -13
  185. package/docs/examples/input/textarea.vue +25 -25
  186. package/docs/examples/input/word-limit.vue +28 -28
  187. package/docs/examples/input-button/basic.vue +33 -33
  188. package/docs/examples/input-code/basic.vue +29 -29
  189. package/docs/examples/input-color/basic.vue +10 -10
  190. package/docs/examples/input-color/disabled.vue +13 -13
  191. package/docs/examples/input-color/format.vue +17 -17
  192. package/docs/examples/input-color/no-alpha.vue +13 -13
  193. package/docs/examples/input-color/only-button.vue +15 -15
  194. package/docs/examples/input-color/predefine.vue +31 -31
  195. package/docs/examples/input-color/size.vue +15 -15
  196. package/docs/examples/input-layer/basic.vue +69 -69
  197. package/docs/examples/input-rows/basic.vue +73 -73
  198. package/docs/examples/input-rows/drag.vue +48 -48
  199. package/docs/examples/input-rows/layer-form.vue +85 -85
  200. package/docs/examples/input-rows/nested.vue +91 -91
  201. package/docs/examples/input-tag/basic.vue +27 -27
  202. package/docs/examples/input-tag/colors.vue +23 -23
  203. package/docs/examples/input-tag/readonly.vue +17 -17
  204. package/docs/examples/layer/basic.vue +43 -43
  205. package/docs/examples/layer/custom-buttons.vue +61 -61
  206. package/docs/examples/layer/drawer.vue +37 -37
  207. package/docs/examples/layer/full.vue +38 -38
  208. package/docs/examples/layer/modal.vue +34 -34
  209. package/docs/examples/layer/steps.vue +46 -46
  210. package/docs/examples/layer-form/basic.vue +76 -76
  211. package/docs/examples/layer-form/config.vue +82 -82
  212. package/docs/examples/layer-form/size.vue +72 -72
  213. package/docs/examples/layout/basic.vue +36 -36
  214. package/docs/examples/layout/custom-size.vue +50 -50
  215. package/docs/examples/layout/disable-move.vue +37 -37
  216. package/docs/examples/layout/hide-mid-when-narrow.vue +96 -96
  217. package/docs/examples/layout/min-size.vue +73 -73
  218. package/docs/examples/layout/percent-size.vue +80 -80
  219. package/docs/examples/layout/simple.vue +22 -22
  220. package/docs/examples/layout/top-side.vue +34 -34
  221. package/docs/examples/map/basic.vue +22 -22
  222. package/docs/examples/menu/basic.vue +58 -58
  223. package/docs/examples/menu/collapsed.vue +49 -49
  224. package/docs/examples/menu/horizontal.vue +44 -44
  225. package/docs/examples/menu/selection-test.vue +104 -104
  226. package/docs/examples/menu/theme.vue +46 -46
  227. package/docs/examples/menu/vertical.vue +46 -46
  228. package/docs/examples/number/advanced.vue +143 -143
  229. package/docs/examples/number/basic.vue +63 -63
  230. package/docs/examples/number/disabled.vue +49 -49
  231. package/docs/examples/number/size.vue +42 -42
  232. package/docs/examples/number/slots.vue +123 -123
  233. package/docs/examples/number/step-strictly.vue +41 -41
  234. package/docs/examples/number/step.vue +47 -47
  235. package/docs/examples/page/basic.vue +41 -41
  236. package/docs/examples/page/init.vue +87 -87
  237. package/docs/examples/panel/tool-buttons.vue +18 -18
  238. package/docs/examples/radio/basic.vue +17 -17
  239. package/docs/examples/radio/button.vue +17 -17
  240. package/docs/examples/radio/color.vue +18 -18
  241. package/docs/examples/radio/disabled.vue +17 -17
  242. package/docs/examples/radio/size.vue +29 -29
  243. package/docs/examples/rate/basic.vue +24 -24
  244. package/docs/examples/rate/half.vue +24 -24
  245. package/docs/examples/rate/readonly.vue +11 -11
  246. package/docs/examples/rate/text.vue +32 -32
  247. package/docs/examples/select/basic.vue +16 -16
  248. package/docs/examples/select/clearable.vue +22 -22
  249. package/docs/examples/select/disabled.vue +31 -31
  250. package/docs/examples/select/filterable.vue +24 -24
  251. package/docs/examples/select/group.vue +23 -23
  252. package/docs/examples/select/icon.vue +16 -16
  253. package/docs/examples/select/multiple.vue +18 -18
  254. package/docs/examples/select/size.vue +39 -39
  255. package/docs/examples/slider/basic.vue +42 -42
  256. package/docs/examples/slider/disabled.vue +17 -17
  257. package/docs/examples/slider/marks.vue +30 -30
  258. package/docs/examples/slider/size.vue +37 -37
  259. package/docs/examples/slider/tooltip.vue +36 -36
  260. package/docs/examples/slider/vertical.vue +26 -26
  261. package/docs/examples/slider-captcha/basic.vue +44 -44
  262. package/docs/examples/slider-captcha/custom.vue +48 -48
  263. package/docs/examples/switch/basic.vue +16 -16
  264. package/docs/examples/switch/disabled.vue +13 -13
  265. package/docs/examples/switch/loading.vue +13 -13
  266. package/docs/examples/switch/size.vue +15 -15
  267. package/docs/examples/switch/text.vue +13 -13
  268. package/docs/examples/table/actions.vue +116 -116
  269. package/docs/examples/table/add-row.vue +103 -103
  270. package/docs/examples/table/basic.vue +168 -168
  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-panel/basic.vue +228 -228
  287. package/docs/examples/table-panel/batch-operations.vue +285 -285
  288. package/docs/examples/table-panel/filter.vue +209 -209
  289. package/docs/examples/table-panel/multiple-selection.vue +243 -243
  290. package/docs/examples/table-panel/pagination.vue +133 -133
  291. package/docs/examples/tabs/basic.vue +98 -98
  292. package/docs/examples/title/basic.vue +80 -80
  293. package/docs/examples/tree/accordion.vue +46 -46
  294. package/docs/examples/tree/basic.vue +50 -50
  295. package/docs/examples/tree/buttons.vue +53 -53
  296. package/docs/examples/tree/checkable.vue +52 -52
  297. package/docs/examples/tree/custom-keys.vue +39 -39
  298. package/docs/examples/tree/default-expanded.vue +52 -52
  299. package/docs/examples/tree/draggable.vue +29 -29
  300. package/docs/examples/tree/expand-on-click.vue +39 -39
  301. package/docs/examples/tree/flat-data.vue +20 -20
  302. package/docs/examples/tree/icon.vue +40 -40
  303. package/docs/examples/tree/load-data.vue +37 -37
  304. package/docs/examples/tree/methods.vue +74 -74
  305. package/docs/examples/tree/theme.vue +33 -33
  306. package/docs/examples/upload/accept.vue +31 -31
  307. package/docs/examples/upload/basic.vue +12 -12
  308. package/docs/examples/upload/drag.vue +11 -11
  309. package/docs/examples/upload/image.vue +17 -17
  310. package/docs/examples/upload/limit.vue +20 -20
  311. package/docs/examples/upload/multiple.vue +17 -17
  312. package/docs/examples/upload/readonly.vue +17 -17
  313. package/docs/examples/utils/cipher.vue +160 -160
  314. package/docs/examples/utils/common.vue +153 -153
  315. package/docs/examples/utils/date.vue +56 -56
  316. package/docs/examples/utils/dom.vue +52 -52
  317. package/docs/examples/utils/is.vue +70 -70
  318. package/docs/examples/workflow/basic.vue +265 -265
  319. package/docs/examples/workflow-viewer/basic.vue +248 -248
  320. 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
+ 感谢所有为这个项目做出贡献的开发者!
@@ -309,6 +309,22 @@ export declare const JInputLayer: {
309
309
  type: NumberConstructor;
310
310
  default: number;
311
311
  };
312
+ subColumns: {
313
+ type: import('vue').PropType<any[]>;
314
+ default: () => never[];
315
+ };
316
+ isSubShowNumber: {
317
+ type: BooleanConstructor;
318
+ default: boolean;
319
+ };
320
+ subActions: {
321
+ type: import('vue').PropType<import('..').ButtonCompType[]>;
322
+ default: () => never[];
323
+ };
324
+ loadChildren: {
325
+ type: import('vue').PropType<(record: Record<string, any>) => Promise<any[]>>;
326
+ default: null;
327
+ };
312
328
  rowKey: {
313
329
  type: StringConstructor;
314
330
  default: undefined;
@@ -371,6 +387,10 @@ export declare const JInputLayer: {
371
387
  actionsMaxCount: number;
372
388
  actionsLabel: string;
373
389
  highlightMode: "row" | "cross" | "column" | "cell";
390
+ subColumns: any[];
391
+ isSubShowNumber: boolean;
392
+ subActions: import('..').ButtonCompType[];
393
+ loadChildren: (record: Record<string, any>) => Promise<any[]>;
374
394
  batchButtons: import('..').ButtonCompType[];
375
395
  noPadding: boolean;
376
396
  }, true, {}, {}, import('vue').GlobalComponents, import('vue').GlobalDirectives, string, {
@@ -594,6 +614,22 @@ export declare const JInputLayer: {
594
614
  type: NumberConstructor;
595
615
  default: number;
596
616
  };
617
+ subColumns: {
618
+ type: import('vue').PropType<any[]>;
619
+ default: () => never[];
620
+ };
621
+ isSubShowNumber: {
622
+ type: BooleanConstructor;
623
+ default: boolean;
624
+ };
625
+ subActions: {
626
+ type: import('vue').PropType<import('..').ButtonCompType[]>;
627
+ default: () => never[];
628
+ };
629
+ loadChildren: {
630
+ type: import('vue').PropType<(record: Record<string, any>) => Promise<any[]>>;
631
+ default: null;
632
+ };
597
633
  rowKey: {
598
634
  type: StringConstructor;
599
635
  default: undefined;
@@ -653,6 +689,10 @@ export declare const JInputLayer: {
653
689
  actionsMaxCount: number;
654
690
  actionsLabel: string;
655
691
  highlightMode: "row" | "cross" | "column" | "cell";
692
+ subColumns: any[];
693
+ isSubShowNumber: boolean;
694
+ subActions: import('..').ButtonCompType[];
695
+ loadChildren: (record: Record<string, any>) => Promise<any[]>;
656
696
  batchButtons: import('..').ButtonCompType[];
657
697
  noPadding: boolean;
658
698
  }> | null;
@@ -368,6 +368,22 @@ declare const _default: import('vue').DefineComponent<InputLayerProps, {}, {}, {
368
368
  type: NumberConstructor;
369
369
  default: number;
370
370
  };
371
+ subColumns: {
372
+ type: import('vue').PropType<any[]>;
373
+ default: () => never[];
374
+ };
375
+ isSubShowNumber: {
376
+ type: BooleanConstructor;
377
+ default: boolean;
378
+ };
379
+ subActions: {
380
+ type: import('vue').PropType<import('../..').ButtonCompType[]>;
381
+ default: () => never[];
382
+ };
383
+ loadChildren: {
384
+ type: import('vue').PropType<(record: Record<string, any>) => Promise<any[]>>;
385
+ default: null;
386
+ };
371
387
  rowKey: {
372
388
  type: StringConstructor;
373
389
  default: undefined;
@@ -430,6 +446,10 @@ declare const _default: import('vue').DefineComponent<InputLayerProps, {}, {}, {
430
446
  actionsMaxCount: number;
431
447
  actionsLabel: string;
432
448
  highlightMode: "row" | "cross" | "column" | "cell";
449
+ subColumns: any[];
450
+ isSubShowNumber: boolean;
451
+ subActions: import('../..').ButtonCompType[];
452
+ loadChildren: (record: Record<string, any>) => Promise<any[]>;
433
453
  batchButtons: import('../..').ButtonCompType[];
434
454
  noPadding: boolean;
435
455
  }, true, {}, {}, import('vue').GlobalComponents, import('vue').GlobalDirectives, string, {
@@ -653,6 +673,22 @@ declare const _default: import('vue').DefineComponent<InputLayerProps, {}, {}, {
653
673
  type: NumberConstructor;
654
674
  default: number;
655
675
  };
676
+ subColumns: {
677
+ type: import('vue').PropType<any[]>;
678
+ default: () => never[];
679
+ };
680
+ isSubShowNumber: {
681
+ type: BooleanConstructor;
682
+ default: boolean;
683
+ };
684
+ subActions: {
685
+ type: import('vue').PropType<import('../..').ButtonCompType[]>;
686
+ default: () => never[];
687
+ };
688
+ loadChildren: {
689
+ type: import('vue').PropType<(record: Record<string, any>) => Promise<any[]>>;
690
+ default: null;
691
+ };
656
692
  rowKey: {
657
693
  type: StringConstructor;
658
694
  default: undefined;
@@ -712,6 +748,10 @@ declare const _default: import('vue').DefineComponent<InputLayerProps, {}, {}, {
712
748
  actionsMaxCount: number;
713
749
  actionsLabel: string;
714
750
  highlightMode: "row" | "cross" | "column" | "cell";
751
+ subColumns: any[];
752
+ isSubShowNumber: boolean;
753
+ subActions: import('../..').ButtonCompType[];
754
+ loadChildren: (record: Record<string, any>) => Promise<any[]>;
715
755
  batchButtons: import('../..').ButtonCompType[];
716
756
  noPadding: boolean;
717
757
  }> | null;
@@ -26,6 +26,22 @@ declare const JTablePanel: {
26
26
  type: NumberConstructor;
27
27
  default: number;
28
28
  };
29
+ subColumns: {
30
+ type: import('vue').PropType<any[]>;
31
+ default: () => never[];
32
+ };
33
+ isSubShowNumber: {
34
+ type: BooleanConstructor;
35
+ default: boolean;
36
+ };
37
+ subActions: {
38
+ type: import('vue').PropType<import('..').ButtonCompType[]>;
39
+ default: () => never[];
40
+ };
41
+ loadChildren: {
42
+ type: import('vue').PropType<(record: Record<string, any>) => Promise<any[]>>;
43
+ default: null;
44
+ };
29
45
  rowKey: {
30
46
  type: StringConstructor;
31
47
  default: undefined;
@@ -88,6 +104,10 @@ declare const JTablePanel: {
88
104
  actionsMaxCount: number;
89
105
  actionsLabel: string;
90
106
  highlightMode: "row" | "cross" | "column" | "cell";
107
+ subColumns: any[];
108
+ isSubShowNumber: boolean;
109
+ subActions: import('..').ButtonCompType[];
110
+ loadChildren: (record: Record<string, any>) => Promise<any[]>;
91
111
  batchButtons: import('..').ButtonCompType[];
92
112
  noPadding: boolean;
93
113
  }, true, {}, {}, import('vue').GlobalComponents, import('vue').GlobalDirectives, string, {
@@ -311,6 +331,22 @@ declare const JTablePanel: {
311
331
  type: NumberConstructor;
312
332
  default: number;
313
333
  };
334
+ subColumns: {
335
+ type: import('vue').PropType<any[]>;
336
+ default: () => never[];
337
+ };
338
+ isSubShowNumber: {
339
+ type: BooleanConstructor;
340
+ default: boolean;
341
+ };
342
+ subActions: {
343
+ type: import('vue').PropType<import('..').ButtonCompType[]>;
344
+ default: () => never[];
345
+ };
346
+ loadChildren: {
347
+ type: import('vue').PropType<(record: Record<string, any>) => Promise<any[]>>;
348
+ default: null;
349
+ };
314
350
  rowKey: {
315
351
  type: StringConstructor;
316
352
  default: undefined;
@@ -370,6 +406,10 @@ declare const JTablePanel: {
370
406
  actionsMaxCount: number;
371
407
  actionsLabel: string;
372
408
  highlightMode: "row" | "cross" | "column" | "cell";
409
+ subColumns: any[];
410
+ isSubShowNumber: boolean;
411
+ subActions: import('..').ButtonCompType[];
412
+ loadChildren: (record: Record<string, any>) => Promise<any[]>;
373
413
  batchButtons: import('..').ButtonCompType[];
374
414
  noPadding: boolean;
375
415
  }>;
@@ -403,6 +443,22 @@ declare const JTablePanel: {
403
443
  type: NumberConstructor;
404
444
  default: number;
405
445
  };
446
+ subColumns: {
447
+ type: import('vue').PropType<any[]>;
448
+ default: () => never[];
449
+ };
450
+ isSubShowNumber: {
451
+ type: BooleanConstructor;
452
+ default: boolean;
453
+ };
454
+ subActions: {
455
+ type: import('vue').PropType<import('..').ButtonCompType[]>;
456
+ default: () => never[];
457
+ };
458
+ loadChildren: {
459
+ type: import('vue').PropType<(record: Record<string, any>) => Promise<any[]>>;
460
+ default: null;
461
+ };
406
462
  rowKey: {
407
463
  type: StringConstructor;
408
464
  default: undefined;
@@ -465,6 +521,10 @@ declare const JTablePanel: {
465
521
  actionsMaxCount: number;
466
522
  actionsLabel: string;
467
523
  highlightMode: "row" | "cross" | "column" | "cell";
524
+ subColumns: any[];
525
+ isSubShowNumber: boolean;
526
+ subActions: import('..').ButtonCompType[];
527
+ loadChildren: (record: Record<string, any>) => Promise<any[]>;
468
528
  batchButtons: import('..').ButtonCompType[];
469
529
  noPadding: boolean;
470
530
  }, {}, string, {}, import('vue').GlobalComponents, import('vue').GlobalDirectives, string, import('vue').ComponentProvideOptions> & import('vue').VNodeProps & import('vue').AllowedComponentProps & import('vue').ComponentCustomProps & {
@@ -50,6 +50,34 @@ declare const _default: import('vue').DefineComponent<import('vue').ExtractPropT
50
50
  type: NumberConstructor;
51
51
  default: number;
52
52
  };
53
+ /**
54
+ * @zh 子表列配置
55
+ */
56
+ subColumns: {
57
+ type: PropType<any[]>;
58
+ default: () => never[];
59
+ };
60
+ /**
61
+ * @zh 是否显示子表序号
62
+ */
63
+ isSubShowNumber: {
64
+ type: BooleanConstructor;
65
+ default: boolean;
66
+ };
67
+ /**
68
+ * @zh 子表行内操作按钮配置
69
+ */
70
+ subActions: {
71
+ type: PropType<ButtonCompType[]>;
72
+ default: () => never[];
73
+ };
74
+ /**
75
+ * @zh 懒加载子节点数据
76
+ */
77
+ loadChildren: {
78
+ type: PropType<(record: Record<string, any>) => Promise<any[]>>;
79
+ default: null;
80
+ };
53
81
  /**
54
82
  * @zh 行主键
55
83
  */
@@ -176,6 +204,34 @@ declare const _default: import('vue').DefineComponent<import('vue').ExtractPropT
176
204
  type: NumberConstructor;
177
205
  default: number;
178
206
  };
207
+ /**
208
+ * @zh 子表列配置
209
+ */
210
+ subColumns: {
211
+ type: PropType<any[]>;
212
+ default: () => never[];
213
+ };
214
+ /**
215
+ * @zh 是否显示子表序号
216
+ */
217
+ isSubShowNumber: {
218
+ type: BooleanConstructor;
219
+ default: boolean;
220
+ };
221
+ /**
222
+ * @zh 子表行内操作按钮配置
223
+ */
224
+ subActions: {
225
+ type: PropType<ButtonCompType[]>;
226
+ default: () => never[];
227
+ };
228
+ /**
229
+ * @zh 懒加载子节点数据
230
+ */
231
+ loadChildren: {
232
+ type: PropType<(record: Record<string, any>) => Promise<any[]>>;
233
+ default: null;
234
+ };
179
235
  /**
180
236
  * @zh 行主键
181
237
  */
@@ -261,6 +317,10 @@ declare const _default: import('vue').DefineComponent<import('vue').ExtractPropT
261
317
  actionsMaxCount: number;
262
318
  actionsLabel: string;
263
319
  highlightMode: "row" | "cross" | "column" | "cell";
320
+ subColumns: any[];
321
+ isSubShowNumber: boolean;
322
+ subActions: ButtonCompType[];
323
+ loadChildren: (record: Record<string, any>) => Promise<any[]>;
264
324
  batchButtons: ButtonCompType[];
265
325
  noPadding: boolean;
266
326
  }, {}, {}, {}, string, import('vue').ComponentProvideOptions, true, {