@a2simcode/ui 0.0.112 → 0.0.114

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (339) hide show
  1. package/.cursor/skills/ui-component-helper/README.md +86 -86
  2. package/.cursor/skills/ui-component-helper/SKILL.md +115 -115
  3. package/LICENSE +53 -53
  4. package/README.md +156 -156
  5. package/dist/components/index.d.ts +2 -1
  6. package/dist/components/inject-provide.d.ts +1 -0
  7. package/dist/components/input-layer/index.d.ts +5 -9
  8. package/dist/components/input-layer/src/input-layer.vue.d.ts +3 -7
  9. package/dist/components/table/index.d.ts +3 -9
  10. package/dist/components/table/src/table.vue.d.ts +1 -4
  11. package/dist/components/table-panel/index.d.ts +3 -9
  12. package/dist/components/table-panel/src/table-panel.vue.d.ts +1 -4
  13. package/dist/components/time/index.d.ts +105 -0
  14. package/dist/components/time/src/time.vue.d.ts +64 -0
  15. package/dist/simcode-ui.es.js +5478 -5290
  16. package/dist/simcode-ui.umd.js +2 -2
  17. package/dist/stats.html +1 -1
  18. package/dist/ui.css +1 -1
  19. package/docs/components/autocomplete.md +89 -89
  20. package/docs/components/barcode.md +101 -101
  21. package/docs/components/button-select.md +24 -24
  22. package/docs/components/button.md +117 -117
  23. package/docs/components/buttons.md +119 -119
  24. package/docs/components/cascader-select.md +114 -114
  25. package/docs/components/checkbox.md +114 -114
  26. package/docs/components/code-mirror.md +85 -85
  27. package/docs/components/collapse.md +26 -26
  28. package/docs/components/comp.md +71 -71
  29. package/docs/components/count-up.md +24 -24
  30. package/docs/components/count.md +24 -24
  31. package/docs/components/data-panel.md +24 -24
  32. package/docs/components/date.md +76 -76
  33. package/docs/components/dialog-full.md +112 -112
  34. package/docs/components/dialog.md +127 -127
  35. package/docs/components/divider.md +24 -24
  36. package/docs/components/drawer.md +127 -127
  37. package/docs/components/dynamic-layer.md +118 -118
  38. package/docs/components/echarts.md +72 -72
  39. package/docs/components/editor.md +24 -24
  40. package/docs/components/form.md +27 -27
  41. package/docs/components/guid.md +39 -39
  42. package/docs/components/hpanel.md +24 -24
  43. package/docs/components/icon.md +56 -56
  44. package/docs/components/input-button.md +24 -24
  45. package/docs/components/input-code.md +24 -24
  46. package/docs/components/input-color.md +114 -114
  47. package/docs/components/input-layer.md +26 -26
  48. package/docs/components/input-rows.md +370 -370
  49. package/docs/components/input-tag.md +50 -50
  50. package/docs/components/input.md +129 -129
  51. package/docs/components/layer-form.md +61 -61
  52. package/docs/components/layer.md +127 -127
  53. package/docs/components/layout.md +132 -132
  54. package/docs/components/map.md +24 -24
  55. package/docs/components/menu.md +121 -121
  56. package/docs/components/meta/buttons.ts +76 -76
  57. package/docs/components/meta/comp.ts +236 -236
  58. package/docs/components/meta/date.ts +256 -256
  59. package/docs/components/meta/echarts.ts +64 -64
  60. package/docs/components/meta/form.ts +165 -165
  61. package/docs/components/meta/input-cards.ts +112 -112
  62. package/docs/components/meta/input-color.ts +243 -243
  63. package/docs/components/meta/input-rows.ts +113 -113
  64. package/docs/components/meta/layer-form.ts +56 -56
  65. package/docs/components/meta/map.ts +68 -68
  66. package/docs/components/meta/panel.ts +152 -152
  67. package/docs/components/meta/slider.ts +270 -270
  68. package/docs/components/meta/table-panel.ts +232 -232
  69. package/docs/components/meta/table.ts +386 -386
  70. package/docs/components/meta/tabs.ts +146 -146
  71. package/docs/components/meta/tree-select.ts +199 -199
  72. package/docs/components/meta/workflow-viewer.ts +55 -55
  73. package/docs/components/number.md +124 -124
  74. package/docs/components/page.md +87 -87
  75. package/docs/components/panel.md +37 -37
  76. package/docs/components/radio.md +87 -87
  77. package/docs/components/rate.md +71 -71
  78. package/docs/components/select.md +133 -133
  79. package/docs/components/slider-captcha.md +41 -41
  80. package/docs/components/slider.md +101 -101
  81. package/docs/components/switch.md +90 -90
  82. package/docs/components/table-panel.md +236 -236
  83. package/docs/components/table.md +391 -378
  84. package/docs/components/tabs.md +26 -26
  85. package/docs/components/title.md +24 -24
  86. package/docs/components/tree.md +207 -207
  87. package/docs/components/upload.md +117 -117
  88. package/docs/components/workflow-viewer.md +21 -21
  89. package/docs/components/workflow.md +21 -21
  90. package/docs/examples/autocomplete/advanced.vue +35 -35
  91. package/docs/examples/autocomplete/basic.vue +32 -32
  92. package/docs/examples/autocomplete/clearable.vue +33 -33
  93. package/docs/examples/autocomplete/custom-template.vue +49 -49
  94. package/docs/examples/autocomplete/disabled.vue +33 -33
  95. package/docs/examples/autocomplete/icon.vue +37 -37
  96. package/docs/examples/barcode/all-types.vue +380 -380
  97. package/docs/examples/barcode/basic.vue +14 -14
  98. package/docs/examples/barcode/props-appearance.vue +243 -243
  99. package/docs/examples/barcode/props-geometry.vue +143 -143
  100. package/docs/examples/barcode/props-logic.vue +216 -216
  101. package/docs/examples/barcode/props-symbology.vue +199 -199
  102. package/docs/examples/barcode/props-text.vue +268 -268
  103. package/docs/examples/button/basic.vue +7 -7
  104. package/docs/examples/button/danger-ghost.vue +17 -17
  105. package/docs/examples/button/disabled.vue +10 -10
  106. package/docs/examples/button/loading.vue +6 -6
  107. package/docs/examples/button/shape.vue +7 -7
  108. package/docs/examples/button/size.vue +14 -14
  109. package/docs/examples/button/type.vue +9 -9
  110. package/docs/examples/button-select/basic.vue +19 -19
  111. package/docs/examples/buttons/basic.vue +45 -45
  112. package/docs/examples/buttons/disabled.vue +36 -36
  113. package/docs/examples/buttons/dropdown.vue +63 -63
  114. package/docs/examples/buttons/group.vue +52 -52
  115. package/docs/examples/buttons/link.vue +47 -47
  116. package/docs/examples/buttons/popup.vue +39 -39
  117. package/docs/examples/buttons/size.vue +45 -45
  118. package/docs/examples/cascader-select/basic.vue +28 -28
  119. package/docs/examples/cascader-select/clearable.vue +34 -34
  120. package/docs/examples/cascader-select/disabled.vue +43 -43
  121. package/docs/examples/cascader-select/filterable.vue +37 -37
  122. package/docs/examples/cascader-select/methods.vue +84 -84
  123. package/docs/examples/cascader-select/multiple.vue +38 -38
  124. package/docs/examples/cascader-select/slot.vue +45 -45
  125. package/docs/examples/checkbox/basic.vue +18 -18
  126. package/docs/examples/checkbox/button.vue +19 -19
  127. package/docs/examples/checkbox/color.vue +25 -25
  128. package/docs/examples/checkbox/disabled.vue +17 -17
  129. package/docs/examples/checkbox/min-max.vue +20 -20
  130. package/docs/examples/checkbox/mixed.vue +56 -56
  131. package/docs/examples/checkbox/size.vue +28 -28
  132. package/docs/examples/code-mirror/basic.vue +11 -11
  133. package/docs/examples/code-mirror/events.vue +42 -42
  134. package/docs/examples/code-mirror/height.vue +25 -25
  135. package/docs/examples/code-mirror/mode.vue +33 -33
  136. package/docs/examples/code-mirror/readonly.vue +14 -14
  137. package/docs/examples/collapse/basic.vue +82 -82
  138. package/docs/examples/comp/basic.vue +7 -7
  139. package/docs/examples/comp/collapse.vue +38 -38
  140. package/docs/examples/comp/tabs.vue +38 -38
  141. package/docs/examples/count/basic.vue +101 -101
  142. package/docs/examples/count-up/basic.vue +89 -89
  143. package/docs/examples/data-panel/basic.vue +110 -110
  144. package/docs/examples/date/basic.vue +73 -73
  145. package/docs/examples/date/default-value.vue +59 -59
  146. package/docs/examples/date/format.vue +75 -75
  147. package/docs/examples/date/range.vue +66 -66
  148. package/docs/examples/date/types.vue +79 -79
  149. package/docs/examples/dialog/basic.vue +36 -36
  150. package/docs/examples/dialog/custom-buttons.vue +44 -44
  151. package/docs/examples/dialog/fullscreen.vue +23 -23
  152. package/docs/examples/dialog/no-mask.vue +17 -17
  153. package/docs/examples/dialog/size.vue +44 -44
  154. package/docs/examples/dialog/steps.vue +57 -57
  155. package/docs/examples/dialog-full/basic.vue +29 -29
  156. package/docs/examples/dialog-full/custom-buttons.vue +45 -45
  157. package/docs/examples/dialog-full/no-buttons.vue +18 -18
  158. package/docs/examples/dialog-full/no-header.vue +27 -27
  159. package/docs/examples/dialog-full/steps.vue +71 -71
  160. package/docs/examples/divider/basic.vue +52 -52
  161. package/docs/examples/drawer/basic.vue +35 -35
  162. package/docs/examples/drawer/custom-buttons.vue +34 -34
  163. package/docs/examples/drawer/direction.vue +47 -47
  164. package/docs/examples/drawer/mask.vue +36 -36
  165. package/docs/examples/drawer/no-buttons.vue +20 -20
  166. package/docs/examples/drawer/size.vue +28 -28
  167. package/docs/examples/dynamic-layer/basic.vue +33 -33
  168. package/docs/examples/dynamic-layer/custom-buttons.vue +43 -43
  169. package/docs/examples/dynamic-layer/form.vue +73 -73
  170. package/docs/examples/dynamic-layer/steps.vue +52 -52
  171. package/docs/examples/dynamic-layer/types.vue +40 -40
  172. package/docs/examples/echarts/basic.vue +31 -31
  173. package/docs/examples/echarts/dynamic.vue +43 -43
  174. package/docs/examples/echarts/line.vue +46 -46
  175. package/docs/examples/echarts/pie.vue +44 -44
  176. package/docs/examples/editor/basic.vue +15 -15
  177. package/docs/examples/form/basic.vue +477 -459
  178. package/docs/examples/guid/basic.vue +10 -10
  179. package/docs/examples/guid/size.vue +13 -13
  180. package/docs/examples/hpanel/basic.vue +79 -79
  181. package/docs/examples/icon/basic.vue +9 -9
  182. package/docs/examples/icon/rotate-flip.vue +9 -9
  183. package/docs/examples/icon/size.vue +7 -7
  184. package/docs/examples/input/basic.vue +10 -10
  185. package/docs/examples/input/clearable.vue +12 -12
  186. package/docs/examples/input/disabled.vue +6 -6
  187. package/docs/examples/input/icon.vue +23 -23
  188. package/docs/examples/input/password.vue +18 -18
  189. package/docs/examples/input/size.vue +13 -13
  190. package/docs/examples/input/textarea.vue +25 -25
  191. package/docs/examples/input/word-limit.vue +28 -28
  192. package/docs/examples/input-button/basic.vue +33 -33
  193. package/docs/examples/input-code/basic.vue +29 -29
  194. package/docs/examples/input-color/basic.vue +10 -10
  195. package/docs/examples/input-color/disabled.vue +13 -13
  196. package/docs/examples/input-color/format.vue +17 -17
  197. package/docs/examples/input-color/no-alpha.vue +13 -13
  198. package/docs/examples/input-color/only-button.vue +15 -15
  199. package/docs/examples/input-color/predefine.vue +31 -31
  200. package/docs/examples/input-color/size.vue +15 -15
  201. package/docs/examples/input-layer/basic.vue +69 -69
  202. package/docs/examples/input-rows/basic.vue +73 -73
  203. package/docs/examples/input-rows/drag.vue +48 -48
  204. package/docs/examples/input-rows/layer-form.vue +85 -85
  205. package/docs/examples/input-rows/nested.vue +91 -91
  206. package/docs/examples/input-tag/basic.vue +27 -27
  207. package/docs/examples/input-tag/colors.vue +23 -23
  208. package/docs/examples/input-tag/readonly.vue +17 -17
  209. package/docs/examples/layer/basic.vue +43 -43
  210. package/docs/examples/layer/custom-buttons.vue +61 -61
  211. package/docs/examples/layer/drawer.vue +37 -37
  212. package/docs/examples/layer/full.vue +38 -38
  213. package/docs/examples/layer/modal.vue +34 -34
  214. package/docs/examples/layer/steps.vue +46 -46
  215. package/docs/examples/layer-form/basic.vue +76 -76
  216. package/docs/examples/layer-form/config.vue +82 -82
  217. package/docs/examples/layer-form/size.vue +72 -72
  218. package/docs/examples/layout/basic.vue +36 -36
  219. package/docs/examples/layout/custom-size.vue +50 -50
  220. package/docs/examples/layout/disable-move.vue +37 -37
  221. package/docs/examples/layout/hide-mid-when-narrow.vue +96 -96
  222. package/docs/examples/layout/min-size.vue +73 -73
  223. package/docs/examples/layout/percent-size.vue +80 -80
  224. package/docs/examples/layout/simple.vue +22 -22
  225. package/docs/examples/layout/top-side.vue +34 -34
  226. package/docs/examples/map/basic.vue +22 -22
  227. package/docs/examples/menu/basic.vue +58 -58
  228. package/docs/examples/menu/collapsed.vue +49 -49
  229. package/docs/examples/menu/horizontal.vue +44 -44
  230. package/docs/examples/menu/selection-test.vue +104 -104
  231. package/docs/examples/menu/theme.vue +46 -46
  232. package/docs/examples/menu/vertical.vue +46 -46
  233. package/docs/examples/number/advanced.vue +143 -143
  234. package/docs/examples/number/basic.vue +63 -63
  235. package/docs/examples/number/disabled.vue +49 -49
  236. package/docs/examples/number/size.vue +42 -42
  237. package/docs/examples/number/slots.vue +123 -123
  238. package/docs/examples/number/step-strictly.vue +41 -41
  239. package/docs/examples/number/step.vue +47 -47
  240. package/docs/examples/page/basic.vue +41 -41
  241. package/docs/examples/page/dept-user-management.vue +211 -211
  242. package/docs/examples/page/init.vue +87 -87
  243. package/docs/examples/page/log.vue +453 -453
  244. package/docs/examples/page/user-management.vue +313 -313
  245. package/docs/examples/panel/tool-buttons.vue +18 -18
  246. package/docs/examples/radio/basic.vue +17 -17
  247. package/docs/examples/radio/button.vue +17 -17
  248. package/docs/examples/radio/color.vue +18 -18
  249. package/docs/examples/radio/disabled.vue +17 -17
  250. package/docs/examples/radio/size.vue +29 -29
  251. package/docs/examples/rate/basic.vue +24 -24
  252. package/docs/examples/rate/half.vue +24 -24
  253. package/docs/examples/rate/readonly.vue +11 -11
  254. package/docs/examples/rate/text.vue +32 -32
  255. package/docs/examples/select/basic.vue +16 -16
  256. package/docs/examples/select/clearable.vue +22 -22
  257. package/docs/examples/select/disabled.vue +31 -31
  258. package/docs/examples/select/filterable.vue +24 -24
  259. package/docs/examples/select/group.vue +23 -23
  260. package/docs/examples/select/icon.vue +16 -16
  261. package/docs/examples/select/multiple.vue +18 -18
  262. package/docs/examples/select/size.vue +39 -39
  263. package/docs/examples/slider/basic.vue +42 -42
  264. package/docs/examples/slider/disabled.vue +17 -17
  265. package/docs/examples/slider/marks.vue +30 -30
  266. package/docs/examples/slider/size.vue +37 -37
  267. package/docs/examples/slider/tooltip.vue +36 -36
  268. package/docs/examples/slider/vertical.vue +26 -26
  269. package/docs/examples/slider-captcha/basic.vue +44 -44
  270. package/docs/examples/slider-captcha/custom.vue +48 -48
  271. package/docs/examples/switch/basic.vue +16 -16
  272. package/docs/examples/switch/disabled.vue +13 -13
  273. package/docs/examples/switch/loading.vue +13 -13
  274. package/docs/examples/switch/size.vue +15 -15
  275. package/docs/examples/switch/text.vue +13 -13
  276. package/docs/examples/table/action-filter.vue +126 -126
  277. package/docs/examples/table/actions.vue +116 -116
  278. package/docs/examples/table/add-row.vue +103 -103
  279. package/docs/examples/table/basic.vue +168 -168
  280. package/docs/examples/table/checkbox-layout.vue +68 -68
  281. package/docs/examples/table/custom-layout.vue +115 -115
  282. package/docs/examples/table/dynamic-type.vue +72 -0
  283. package/docs/examples/table/editable.vue +262 -262
  284. package/docs/examples/table/field-selection.vue +87 -87
  285. package/docs/examples/table/frozen-column.vue +140 -140
  286. package/docs/examples/table/height-mode.vue +99 -99
  287. package/docs/examples/table/icon.vue +85 -85
  288. package/docs/examples/table/link.vue +66 -66
  289. package/docs/examples/table/multiple.vue +178 -178
  290. package/docs/examples/table/pagination.vue +151 -151
  291. package/docs/examples/table/single-selection.vue +64 -64
  292. package/docs/examples/table/sub-table-lazy.vue +97 -97
  293. package/docs/examples/table/sub-table.vue +103 -103
  294. package/docs/examples/table/tag.vue +43 -43
  295. package/docs/examples/table/tree-column.vue +119 -119
  296. package/docs/examples/table/tree-data.vue +141 -141
  297. package/docs/examples/table/tree-default-expand-all.vue +60 -60
  298. package/docs/examples/table/tree-lazy.vue +80 -80
  299. package/docs/examples/table/tree-set-selection.vue +75 -75
  300. package/docs/examples/table-panel/basic.vue +228 -228
  301. package/docs/examples/table-panel/batch-operations.vue +285 -285
  302. package/docs/examples/table-panel/button-visibility.vue +88 -88
  303. package/docs/examples/table-panel/filter.vue +219 -219
  304. package/docs/examples/table-panel/get-selection.vue +111 -111
  305. package/docs/examples/table-panel/multiple-selection.vue +243 -243
  306. package/docs/examples/table-panel/pagination.vue +133 -133
  307. package/docs/examples/table-panel/sub-table-lazy.vue +118 -118
  308. package/docs/examples/table-panel/tree-parent-key.vue +67 -67
  309. package/docs/examples/tabs/basic.vue +98 -98
  310. package/docs/examples/time/base.vue +68 -0
  311. package/docs/examples/title/basic.vue +80 -80
  312. package/docs/examples/tree/accordion.vue +46 -46
  313. package/docs/examples/tree/basic.vue +50 -50
  314. package/docs/examples/tree/buttons.vue +53 -53
  315. package/docs/examples/tree/checkable.vue +52 -52
  316. package/docs/examples/tree/custom-keys.vue +39 -39
  317. package/docs/examples/tree/default-expanded.vue +52 -52
  318. package/docs/examples/tree/draggable.vue +29 -29
  319. package/docs/examples/tree/expand-on-click.vue +39 -39
  320. package/docs/examples/tree/flat-data.vue +20 -20
  321. package/docs/examples/tree/icon.vue +40 -40
  322. package/docs/examples/tree/load-data.vue +37 -37
  323. package/docs/examples/tree/methods.vue +74 -74
  324. package/docs/examples/tree/theme.vue +33 -33
  325. package/docs/examples/upload/accept.vue +31 -31
  326. package/docs/examples/upload/basic.vue +12 -12
  327. package/docs/examples/upload/drag.vue +11 -11
  328. package/docs/examples/upload/image.vue +17 -17
  329. package/docs/examples/upload/limit.vue +20 -20
  330. package/docs/examples/upload/multiple.vue +17 -17
  331. package/docs/examples/upload/readonly.vue +17 -17
  332. package/docs/examples/utils/cipher.vue +160 -160
  333. package/docs/examples/utils/common.vue +153 -153
  334. package/docs/examples/utils/date.vue +56 -56
  335. package/docs/examples/utils/dom.vue +52 -52
  336. package/docs/examples/utils/is.vue +70 -70
  337. package/docs/examples/workflow/basic.vue +265 -265
  338. package/docs/examples/workflow-viewer/basic.vue +248 -248
  339. package/package.json +23 -23
@@ -1,313 +1,313 @@
1
- <template>
2
- <div class="j-block" style="height: 600px">
3
- <j-page ref="pageRef" :noPadding="true" :schema="schema" />
4
- </div>
5
- </template>
6
-
7
- <script setup lang="ts">
8
- import type { ButtonClickScope, TableColumnCompConfig } from '@a2simcode/ui'
9
-
10
- import { ref, defineComponent, h } from 'vue'
11
- import { ElMessage, ElMessageBox } from 'element-plus'
12
-
13
- interface UserRecord {
14
- j_Id: number
15
- j_Account: string
16
- j_Name: string
17
- j_EnabledMark: 0 | 1
18
- j_CreateUserName: string
19
- j_CreateDate: string
20
- j_ModifyDate: string
21
- }
22
-
23
- const randomFrom = <T,>(arr: T[]) => arr[Math.floor(Math.random() * arr.length)]
24
-
25
- const createUsers = (count: number): UserRecord[] => {
26
- const names = ['张三', '李四', '王五', '赵六', '孙七', '周八', '吴九', '郑十']
27
- const creators = ['系统', '管理员', '运维', '审计']
28
- const now = Date.now()
29
-
30
- return Array.from({ length: count }).map((_, i) => {
31
- const id = i + 1
32
- const createTime = new Date(now - Math.floor(Math.random() * 20 * 24 * 60 * 60 * 1000))
33
- const modifyTime = new Date(
34
- createTime.getTime() + Math.floor(Math.random() * 5 * 24 * 60 * 60 * 1000)
35
- )
36
- return {
37
- j_Id: id,
38
- j_Account: `user_${String(id).padStart(3, '0')}`,
39
- j_Name: randomFrom(names),
40
- j_EnabledMark: Math.random() > 0.2 ? 1 : 0,
41
- j_CreateUserName: randomFrom(creators),
42
- j_CreateDate: createTime.toISOString(),
43
- j_ModifyDate: modifyTime.toISOString(),
44
- }
45
- })
46
- }
47
-
48
- const users = ref<UserRecord[]>(createUsers(57))
49
-
50
- const api = {
51
- getPage: async (params: Record<string, any>) => {
52
- const keyword = String(params?.keyword?.value || '').trim()
53
- const { pagination } = params || {}
54
- const { rows = 10, page = 1 } = pagination || {}
55
-
56
- let list = [...users.value]
57
- if (keyword) {
58
- list = list.filter((u) => u.j_Name.includes(keyword) || u.j_Account.includes(keyword))
59
- }
60
-
61
- const start = (page - 1) * rows
62
- const end = start + rows
63
-
64
- return {
65
- rows: list.slice(start, end),
66
- records: list.length,
67
- }
68
- },
69
- updateState: async (id: number, enabled: 0 | 1) => {
70
- const target = users.value.find((u) => u.j_Id === id)
71
- if (!target) return false
72
- target.j_EnabledMark = enabled
73
- target.j_ModifyDate = new Date().toISOString()
74
- return true
75
- },
76
- upsert: async (data: Pick<UserRecord, 'j_Account' | 'j_Name'> & { j_Id?: number }) => {
77
- const now = new Date().toISOString()
78
- if (!data.j_Id) {
79
- const nextId = Math.max(0, ...users.value.map((u) => u.j_Id)) + 1
80
- users.value.unshift({
81
- j_Id: nextId,
82
- j_Account: data.j_Account,
83
- j_Name: data.j_Name,
84
- j_EnabledMark: 1,
85
- j_CreateUserName: '管理员',
86
- j_CreateDate: now,
87
- j_ModifyDate: now,
88
- })
89
- return true
90
- }
91
-
92
- const target = users.value.find((u) => u.j_Id === data.j_Id)
93
- if (!target) return false
94
- target.j_Account = data.j_Account
95
- target.j_Name = data.j_Name
96
- target.j_ModifyDate = now
97
- return true
98
- },
99
- resetPassword: async () => true,
100
- remove: async (id: number) => {
101
- const idx = users.value.findIndex((u) => u.j_Id === id)
102
- if (idx < 0) return false
103
- users.value.splice(idx, 1)
104
- return true
105
- },
106
- }
107
-
108
- const UserFormLayer = defineComponent({
109
- name: 'UserFormLayer',
110
- setup(_, { expose }) {
111
- const isEdit = ref(false)
112
- const currentId = ref<number | undefined>(undefined)
113
- const formData = ref({
114
- j_Account: '',
115
- j_Name: '',
116
- })
117
-
118
- const open = async (param: any) => {
119
- isEdit.value = !!param?.isEdit
120
- const record = param?.record as UserRecord | undefined
121
- currentId.value = record?.j_Id
122
- formData.value = {
123
- j_Account: record?.j_Account || '',
124
- j_Name: record?.j_Name || '',
125
- }
126
- return true
127
- }
128
-
129
- const ok = async () => {
130
- const account = formData.value.j_Account.trim()
131
- const name = formData.value.j_Name.trim()
132
- if (!account) {
133
- ElMessage.warning('请输入账号')
134
- return false
135
- }
136
- if (!name) {
137
- ElMessage.warning('请输入姓名')
138
- return false
139
- }
140
-
141
- const res = await api.upsert({
142
- j_Id: currentId.value,
143
- j_Account: account,
144
- j_Name: name,
145
- })
146
- if (!res) {
147
- ElMessage.warning('保存失败')
148
- }
149
- return res
150
- }
151
-
152
- expose({ open, ok })
153
-
154
- return () =>
155
- h('div', { style: 'padding: 16px' }, [
156
- h('div', { style: 'margin-bottom: 12px' }, [
157
- h('div', { style: 'margin-bottom: 6px; color: var(--j-color-text-2)' }, '账号'),
158
- h('input', {
159
- value: formData.value.j_Account,
160
- onInput: (e: any) => (formData.value.j_Account = e?.target?.value || ''),
161
- placeholder: '请输入账号',
162
- style:
163
- 'width: 100%; padding: 6px 10px; border: 1px solid var(--j-color-border); border-radius: 4px; outline: none;',
164
- }),
165
- ]),
166
- h('div', { style: 'margin-bottom: 12px' }, [
167
- h('div', { style: 'margin-bottom: 6px; color: var(--j-color-text-2)' }, '姓名'),
168
- h('input', {
169
- value: formData.value.j_Name,
170
- onInput: (e: any) => (formData.value.j_Name = e?.target?.value || ''),
171
- placeholder: '请输入姓名',
172
- style:
173
- 'width: 100%; padding: 6px 10px; border: 1px solid var(--j-color-border); border-radius: 4px; outline: none;',
174
- }),
175
- ]),
176
- h(
177
- 'div',
178
- { style: 'color: var(--j-color-text-3); font-size: 12px' },
179
- isEdit.value ? '编辑模式:修改后点击确定保存' : '新增模式:填写后点击确定创建'
180
- ),
181
- ])
182
- },
183
- })
184
-
185
- const pageRef = ref()
186
-
187
- const refreshTable = () => {
188
- pageRef.value?.call('mainTable', 'refreshData')
189
- }
190
-
191
- const columnsConfig: Record<string, TableColumnCompConfig> = {
192
- j_Name: { width: 120, filter: { isSearchKeyword: true } },
193
- j_Account: { width: 140, filter: { isSearchKeyword: true } },
194
- j_EnabledMark: {
195
- type: 'j-switch',
196
- activeValue: 1,
197
- inactiveValue: 0,
198
- width: 72,
199
- align: 'center',
200
- change: async ({ row }: { row: UserRecord }) => {
201
- const res = await api.updateState(row.j_Id, row.j_EnabledMark)
202
- if (res) {
203
- ElMessage.success('更新成功')
204
- refreshTable()
205
- } else {
206
- ElMessage.warning('更新失败')
207
- }
208
- },
209
- },
210
- j_CreateUserName: { filter: { isSearchKeyword: true } },
211
- j_CreateDate: { type: 'dateTime', width: 168 },
212
- j_ModifyDate: { type: 'dateTime', width: 168 },
213
- }
214
-
215
- const columns = [
216
- { id: 'j_Name', label: '姓名' },
217
- { id: 'j_Account', label: '账号' },
218
- { id: 'j_EnabledMark', label: '有效' },
219
- { id: 'j_CreateUserName', label: '创建用户' },
220
- { id: 'j_CreateDate', label: '创建时间' },
221
- { id: 'j_ModifyDate', label: '最后更新时间' },
222
- ].map((item) => {
223
- const cfg = columnsConfig[item.id] || {}
224
- return {
225
- id: item.id,
226
- type: cfg.type || '',
227
- config: { ...cfg, label: item.label },
228
- }
229
- })
230
-
231
- const buttons = [
232
- {
233
- id: 'add',
234
- label: '新增',
235
- config: { icon: 'mdi:add', type: 'primary' },
236
- click: ({ openLayer }: ButtonClickScope) => {
237
- openLayer({
238
- title: '新增用户',
239
- name: UserFormLayer,
240
- width: 520,
241
- height: 240,
242
- param: { isEdit: false },
243
- afterOk: refreshTable,
244
- })
245
- },
246
- },
247
- ]
248
-
249
- const actions = [
250
- {
251
- id: 'edit',
252
- label: '编辑',
253
- click: ({ openLayer, data }: ButtonClickScope) => {
254
- openLayer({
255
- title: '编辑用户',
256
- name: UserFormLayer,
257
- width: 520,
258
- height: 240,
259
- param: { isEdit: true, record: data },
260
- afterOk: refreshTable,
261
- })
262
- },
263
- },
264
- {
265
- id: 'resetPassword',
266
- label: '重置密码',
267
- click: async ({ data }: ButtonClickScope) => {
268
- await ElMessageBox.confirm(`您确定重置【${data?.j_Name}】密码吗?`, '提示', {
269
- type: 'warning',
270
- confirmButtonText: '确定',
271
- cancelButtonText: '取消',
272
- })
273
- const res = await api.resetPassword()
274
- if (res) {
275
- ElMessage.success('重置成功')
276
- }
277
- },
278
- },
279
- {
280
- id: 'delete',
281
- label: '删除',
282
- config: { danger: true },
283
- click: async ({ data }: ButtonClickScope) => {
284
- await ElMessageBox.confirm(`您确定删除【${data?.j_Name}】吗?`, '提示', {
285
- type: 'warning',
286
- confirmButtonText: '确定',
287
- cancelButtonText: '取消',
288
- })
289
- const res = await api.remove(data.j_Id)
290
- if (res) {
291
- ElMessage.success('删除成功')
292
- refreshTable()
293
- }
294
- },
295
- },
296
- ]
297
-
298
- const schema = ref([
299
- {
300
- id: 'mainTable',
301
- type: 'j-table-panel',
302
- config: {
303
- columns,
304
- buttons,
305
- actions,
306
- rowKey: 'j_Id',
307
- isPage: true,
308
- sort: 'j_CreateDate DESC',
309
- loadData: async (params: Record<string, any>) => api.getPage(params),
310
- },
311
- },
312
- ])
313
- </script>
1
+ <template>
2
+ <div class="j-block" style="height: 600px">
3
+ <j-page ref="pageRef" :noPadding="true" :schema="schema" />
4
+ </div>
5
+ </template>
6
+
7
+ <script setup lang="ts">
8
+ import type { ButtonClickScope, TableColumnCompConfig } from '@a2simcode/ui'
9
+
10
+ import { ref, defineComponent, h } from 'vue'
11
+ import { ElMessage, ElMessageBox } from 'element-plus'
12
+
13
+ interface UserRecord {
14
+ j_Id: number
15
+ j_Account: string
16
+ j_Name: string
17
+ j_EnabledMark: 0 | 1
18
+ j_CreateUserName: string
19
+ j_CreateDate: string
20
+ j_ModifyDate: string
21
+ }
22
+
23
+ const randomFrom = <T,>(arr: T[]) => arr[Math.floor(Math.random() * arr.length)]
24
+
25
+ const createUsers = (count: number): UserRecord[] => {
26
+ const names = ['张三', '李四', '王五', '赵六', '孙七', '周八', '吴九', '郑十']
27
+ const creators = ['系统', '管理员', '运维', '审计']
28
+ const now = Date.now()
29
+
30
+ return Array.from({ length: count }).map((_, i) => {
31
+ const id = i + 1
32
+ const createTime = new Date(now - Math.floor(Math.random() * 20 * 24 * 60 * 60 * 1000))
33
+ const modifyTime = new Date(
34
+ createTime.getTime() + Math.floor(Math.random() * 5 * 24 * 60 * 60 * 1000)
35
+ )
36
+ return {
37
+ j_Id: id,
38
+ j_Account: `user_${String(id).padStart(3, '0')}`,
39
+ j_Name: randomFrom(names),
40
+ j_EnabledMark: Math.random() > 0.2 ? 1 : 0,
41
+ j_CreateUserName: randomFrom(creators),
42
+ j_CreateDate: createTime.toISOString(),
43
+ j_ModifyDate: modifyTime.toISOString(),
44
+ }
45
+ })
46
+ }
47
+
48
+ const users = ref<UserRecord[]>(createUsers(57))
49
+
50
+ const api = {
51
+ getPage: async (params: Record<string, any>) => {
52
+ const keyword = String(params?.keyword?.value || '').trim()
53
+ const { pagination } = params || {}
54
+ const { rows = 10, page = 1 } = pagination || {}
55
+
56
+ let list = [...users.value]
57
+ if (keyword) {
58
+ list = list.filter((u) => u.j_Name.includes(keyword) || u.j_Account.includes(keyword))
59
+ }
60
+
61
+ const start = (page - 1) * rows
62
+ const end = start + rows
63
+
64
+ return {
65
+ rows: list.slice(start, end),
66
+ records: list.length,
67
+ }
68
+ },
69
+ updateState: async (id: number, enabled: 0 | 1) => {
70
+ const target = users.value.find((u) => u.j_Id === id)
71
+ if (!target) return false
72
+ target.j_EnabledMark = enabled
73
+ target.j_ModifyDate = new Date().toISOString()
74
+ return true
75
+ },
76
+ upsert: async (data: Pick<UserRecord, 'j_Account' | 'j_Name'> & { j_Id?: number }) => {
77
+ const now = new Date().toISOString()
78
+ if (!data.j_Id) {
79
+ const nextId = Math.max(0, ...users.value.map((u) => u.j_Id)) + 1
80
+ users.value.unshift({
81
+ j_Id: nextId,
82
+ j_Account: data.j_Account,
83
+ j_Name: data.j_Name,
84
+ j_EnabledMark: 1,
85
+ j_CreateUserName: '管理员',
86
+ j_CreateDate: now,
87
+ j_ModifyDate: now,
88
+ })
89
+ return true
90
+ }
91
+
92
+ const target = users.value.find((u) => u.j_Id === data.j_Id)
93
+ if (!target) return false
94
+ target.j_Account = data.j_Account
95
+ target.j_Name = data.j_Name
96
+ target.j_ModifyDate = now
97
+ return true
98
+ },
99
+ resetPassword: async () => true,
100
+ remove: async (id: number) => {
101
+ const idx = users.value.findIndex((u) => u.j_Id === id)
102
+ if (idx < 0) return false
103
+ users.value.splice(idx, 1)
104
+ return true
105
+ },
106
+ }
107
+
108
+ const UserFormLayer = defineComponent({
109
+ name: 'UserFormLayer',
110
+ setup(_, { expose }) {
111
+ const isEdit = ref(false)
112
+ const currentId = ref<number | undefined>(undefined)
113
+ const formData = ref({
114
+ j_Account: '',
115
+ j_Name: '',
116
+ })
117
+
118
+ const open = async (param: any) => {
119
+ isEdit.value = !!param?.isEdit
120
+ const record = param?.record as UserRecord | undefined
121
+ currentId.value = record?.j_Id
122
+ formData.value = {
123
+ j_Account: record?.j_Account || '',
124
+ j_Name: record?.j_Name || '',
125
+ }
126
+ return true
127
+ }
128
+
129
+ const ok = async () => {
130
+ const account = formData.value.j_Account.trim()
131
+ const name = formData.value.j_Name.trim()
132
+ if (!account) {
133
+ ElMessage.warning('请输入账号')
134
+ return false
135
+ }
136
+ if (!name) {
137
+ ElMessage.warning('请输入姓名')
138
+ return false
139
+ }
140
+
141
+ const res = await api.upsert({
142
+ j_Id: currentId.value,
143
+ j_Account: account,
144
+ j_Name: name,
145
+ })
146
+ if (!res) {
147
+ ElMessage.warning('保存失败')
148
+ }
149
+ return res
150
+ }
151
+
152
+ expose({ open, ok })
153
+
154
+ return () =>
155
+ h('div', { style: 'padding: 16px' }, [
156
+ h('div', { style: 'margin-bottom: 12px' }, [
157
+ h('div', { style: 'margin-bottom: 6px; color: var(--j-color-text-2)' }, '账号'),
158
+ h('input', {
159
+ value: formData.value.j_Account,
160
+ onInput: (e: any) => (formData.value.j_Account = e?.target?.value || ''),
161
+ placeholder: '请输入账号',
162
+ style:
163
+ 'width: 100%; padding: 6px 10px; border: 1px solid var(--j-color-border); border-radius: 4px; outline: none;',
164
+ }),
165
+ ]),
166
+ h('div', { style: 'margin-bottom: 12px' }, [
167
+ h('div', { style: 'margin-bottom: 6px; color: var(--j-color-text-2)' }, '姓名'),
168
+ h('input', {
169
+ value: formData.value.j_Name,
170
+ onInput: (e: any) => (formData.value.j_Name = e?.target?.value || ''),
171
+ placeholder: '请输入姓名',
172
+ style:
173
+ 'width: 100%; padding: 6px 10px; border: 1px solid var(--j-color-border); border-radius: 4px; outline: none;',
174
+ }),
175
+ ]),
176
+ h(
177
+ 'div',
178
+ { style: 'color: var(--j-color-text-3); font-size: 12px' },
179
+ isEdit.value ? '编辑模式:修改后点击确定保存' : '新增模式:填写后点击确定创建'
180
+ ),
181
+ ])
182
+ },
183
+ })
184
+
185
+ const pageRef = ref()
186
+
187
+ const refreshTable = () => {
188
+ pageRef.value?.call('mainTable', 'refreshData')
189
+ }
190
+
191
+ const columnsConfig: Record<string, TableColumnCompConfig> = {
192
+ j_Name: { width: 120, filter: { isSearchKeyword: true } },
193
+ j_Account: { width: 140, filter: { isSearchKeyword: true } },
194
+ j_EnabledMark: {
195
+ type: 'j-switch',
196
+ activeValue: 1,
197
+ inactiveValue: 0,
198
+ width: 72,
199
+ align: 'center',
200
+ change: async ({ row }: { row: UserRecord }) => {
201
+ const res = await api.updateState(row.j_Id, row.j_EnabledMark)
202
+ if (res) {
203
+ ElMessage.success('更新成功')
204
+ refreshTable()
205
+ } else {
206
+ ElMessage.warning('更新失败')
207
+ }
208
+ },
209
+ },
210
+ j_CreateUserName: { filter: { isSearchKeyword: true } },
211
+ j_CreateDate: { type: 'dateTime', width: 168 },
212
+ j_ModifyDate: { type: 'dateTime', width: 168 },
213
+ }
214
+
215
+ const columns = [
216
+ { id: 'j_Name', label: '姓名' },
217
+ { id: 'j_Account', label: '账号' },
218
+ { id: 'j_EnabledMark', label: '有效' },
219
+ { id: 'j_CreateUserName', label: '创建用户' },
220
+ { id: 'j_CreateDate', label: '创建时间' },
221
+ { id: 'j_ModifyDate', label: '最后更新时间' },
222
+ ].map((item) => {
223
+ const cfg = columnsConfig[item.id] || {}
224
+ return {
225
+ id: item.id,
226
+ type: cfg.type || '',
227
+ config: { ...cfg, label: item.label },
228
+ }
229
+ })
230
+
231
+ const buttons = [
232
+ {
233
+ id: 'add',
234
+ label: '新增',
235
+ config: { icon: 'mdi:add', type: 'primary' },
236
+ click: ({ openLayer }: ButtonClickScope) => {
237
+ openLayer({
238
+ title: '新增用户',
239
+ name: UserFormLayer,
240
+ width: 520,
241
+ height: 240,
242
+ param: { isEdit: false },
243
+ afterOk: refreshTable,
244
+ })
245
+ },
246
+ },
247
+ ]
248
+
249
+ const actions = [
250
+ {
251
+ id: 'edit',
252
+ label: '编辑',
253
+ click: ({ openLayer, data }: ButtonClickScope) => {
254
+ openLayer({
255
+ title: '编辑用户',
256
+ name: UserFormLayer,
257
+ width: 520,
258
+ height: 240,
259
+ param: { isEdit: true, record: data },
260
+ afterOk: refreshTable,
261
+ })
262
+ },
263
+ },
264
+ {
265
+ id: 'resetPassword',
266
+ label: '重置密码',
267
+ click: async ({ data }: ButtonClickScope) => {
268
+ await ElMessageBox.confirm(`您确定重置【${data?.j_Name}】密码吗?`, '提示', {
269
+ type: 'warning',
270
+ confirmButtonText: '确定',
271
+ cancelButtonText: '取消',
272
+ })
273
+ const res = await api.resetPassword()
274
+ if (res) {
275
+ ElMessage.success('重置成功')
276
+ }
277
+ },
278
+ },
279
+ {
280
+ id: 'delete',
281
+ label: '删除',
282
+ config: { danger: true },
283
+ click: async ({ data }: ButtonClickScope) => {
284
+ await ElMessageBox.confirm(`您确定删除【${data?.j_Name}】吗?`, '提示', {
285
+ type: 'warning',
286
+ confirmButtonText: '确定',
287
+ cancelButtonText: '取消',
288
+ })
289
+ const res = await api.remove(data.j_Id)
290
+ if (res) {
291
+ ElMessage.success('删除成功')
292
+ refreshTable()
293
+ }
294
+ },
295
+ },
296
+ ]
297
+
298
+ const schema = ref([
299
+ {
300
+ id: 'mainTable',
301
+ type: 'j-table-panel',
302
+ config: {
303
+ columns,
304
+ buttons,
305
+ actions,
306
+ rowKey: 'j_Id',
307
+ isPage: true,
308
+ sort: 'j_CreateDate DESC',
309
+ loadData: async (params: Record<string, any>) => api.getPage(params),
310
+ },
311
+ },
312
+ ])
313
+ </script>
@@ -1,18 +1,18 @@
1
- <template>
2
- <j-panel title="Panel with Tool Buttons"
3
- :toolBtns="[
4
- { id: 'edit',label: '编辑', config: { icon: 'mdi:settings-outline' }, click: handleEdit },
5
- ]"
6
- >
7
- <div>This panel has some tool buttons in the header.</div>
8
- </j-panel>
9
- </template>
10
-
11
- <script setup lang="ts">
12
- import JPanel from '../../../packages/components/panel'
13
- import { ElMessage } from 'element-plus'
14
-
15
- const handleEdit = () => {
16
- ElMessage.success('Edit button clicked!')
17
- }
18
- </script>
1
+ <template>
2
+ <j-panel title="Panel with Tool Buttons"
3
+ :toolBtns="[
4
+ { id: 'edit',label: '编辑', config: { icon: 'mdi:settings-outline' }, click: handleEdit },
5
+ ]"
6
+ >
7
+ <div>This panel has some tool buttons in the header.</div>
8
+ </j-panel>
9
+ </template>
10
+
11
+ <script setup lang="ts">
12
+ import JPanel from '../../../packages/components/panel'
13
+ import { ElMessage } from 'element-plus'
14
+
15
+ const handleEdit = () => {
16
+ ElMessage.success('Edit button clicked!')
17
+ }
18
+ </script>