@a2simcode/ui 0.0.107 → 0.0.108

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (327) hide show
  1. package/.cursor/skills/ui-component-helper/README.md +86 -86
  2. package/.cursor/skills/ui-component-helper/SKILL.md +115 -115
  3. package/LICENSE +53 -53
  4. package/README.md +156 -156
  5. package/dist/simcode-ui.es.js +2655 -2645
  6. package/dist/simcode-ui.umd.js +2 -2
  7. package/dist/stats.html +1 -1
  8. package/dist/ui.css +1 -1
  9. package/docs/components/autocomplete.md +89 -89
  10. package/docs/components/barcode.md +101 -101
  11. package/docs/components/button-select.md +24 -24
  12. package/docs/components/button.md +117 -117
  13. package/docs/components/buttons.md +119 -119
  14. package/docs/components/cascader-select.md +114 -114
  15. package/docs/components/checkbox.md +114 -114
  16. package/docs/components/code-mirror.md +85 -85
  17. package/docs/components/collapse.md +26 -26
  18. package/docs/components/comp.md +71 -71
  19. package/docs/components/count-up.md +24 -24
  20. package/docs/components/count.md +24 -24
  21. package/docs/components/data-panel.md +24 -24
  22. package/docs/components/date.md +76 -76
  23. package/docs/components/dialog-full.md +112 -112
  24. package/docs/components/dialog.md +127 -127
  25. package/docs/components/divider.md +24 -24
  26. package/docs/components/drawer.md +127 -127
  27. package/docs/components/dynamic-layer.md +118 -118
  28. package/docs/components/echarts.md +72 -72
  29. package/docs/components/editor.md +24 -24
  30. package/docs/components/form.md +27 -27
  31. package/docs/components/guid.md +39 -39
  32. package/docs/components/hpanel.md +24 -24
  33. package/docs/components/icon.md +56 -56
  34. package/docs/components/input-button.md +24 -24
  35. package/docs/components/input-code.md +24 -24
  36. package/docs/components/input-color.md +114 -114
  37. package/docs/components/input-layer.md +26 -26
  38. package/docs/components/input-rows.md +370 -370
  39. package/docs/components/input-tag.md +50 -50
  40. package/docs/components/input.md +129 -129
  41. package/docs/components/layer-form.md +61 -61
  42. package/docs/components/layer.md +127 -127
  43. package/docs/components/layout.md +132 -132
  44. package/docs/components/map.md +24 -24
  45. package/docs/components/menu.md +121 -121
  46. package/docs/components/meta/buttons.ts +76 -76
  47. package/docs/components/meta/comp.ts +236 -236
  48. package/docs/components/meta/date.ts +256 -256
  49. package/docs/components/meta/echarts.ts +64 -64
  50. package/docs/components/meta/form.ts +165 -165
  51. package/docs/components/meta/input-cards.ts +112 -112
  52. package/docs/components/meta/input-color.ts +243 -243
  53. package/docs/components/meta/input-rows.ts +113 -113
  54. package/docs/components/meta/layer-form.ts +56 -56
  55. package/docs/components/meta/map.ts +68 -68
  56. package/docs/components/meta/panel.ts +152 -152
  57. package/docs/components/meta/slider.ts +270 -270
  58. package/docs/components/meta/table-panel.ts +220 -220
  59. package/docs/components/meta/table.ts +380 -380
  60. package/docs/components/meta/tabs.ts +146 -146
  61. package/docs/components/meta/tree-select.ts +199 -199
  62. package/docs/components/meta/workflow-viewer.ts +55 -55
  63. package/docs/components/number.md +124 -124
  64. package/docs/components/page.md +87 -87
  65. package/docs/components/panel.md +37 -37
  66. package/docs/components/radio.md +87 -87
  67. package/docs/components/rate.md +71 -71
  68. package/docs/components/select.md +133 -133
  69. package/docs/components/slider-captcha.md +41 -41
  70. package/docs/components/slider.md +101 -101
  71. package/docs/components/switch.md +90 -90
  72. package/docs/components/table-panel.md +236 -236
  73. package/docs/components/table.md +378 -378
  74. package/docs/components/tabs.md +26 -26
  75. package/docs/components/title.md +24 -24
  76. package/docs/components/tree.md +207 -207
  77. package/docs/components/upload.md +117 -117
  78. package/docs/components/workflow-viewer.md +21 -21
  79. package/docs/components/workflow.md +21 -21
  80. package/docs/examples/autocomplete/advanced.vue +35 -35
  81. package/docs/examples/autocomplete/basic.vue +32 -32
  82. package/docs/examples/autocomplete/clearable.vue +33 -33
  83. package/docs/examples/autocomplete/custom-template.vue +49 -49
  84. package/docs/examples/autocomplete/disabled.vue +33 -33
  85. package/docs/examples/autocomplete/icon.vue +37 -37
  86. package/docs/examples/barcode/all-types.vue +380 -380
  87. package/docs/examples/barcode/basic.vue +14 -14
  88. package/docs/examples/barcode/props-appearance.vue +243 -243
  89. package/docs/examples/barcode/props-geometry.vue +143 -143
  90. package/docs/examples/barcode/props-logic.vue +216 -216
  91. package/docs/examples/barcode/props-symbology.vue +199 -199
  92. package/docs/examples/barcode/props-text.vue +268 -268
  93. package/docs/examples/button/basic.vue +7 -7
  94. package/docs/examples/button/danger-ghost.vue +17 -17
  95. package/docs/examples/button/disabled.vue +10 -10
  96. package/docs/examples/button/loading.vue +6 -6
  97. package/docs/examples/button/shape.vue +7 -7
  98. package/docs/examples/button/size.vue +14 -14
  99. package/docs/examples/button/type.vue +9 -9
  100. package/docs/examples/button-select/basic.vue +19 -19
  101. package/docs/examples/buttons/basic.vue +45 -45
  102. package/docs/examples/buttons/disabled.vue +36 -36
  103. package/docs/examples/buttons/dropdown.vue +63 -63
  104. package/docs/examples/buttons/group.vue +52 -52
  105. package/docs/examples/buttons/link.vue +47 -47
  106. package/docs/examples/buttons/popup.vue +39 -39
  107. package/docs/examples/buttons/size.vue +45 -45
  108. package/docs/examples/cascader-select/basic.vue +28 -28
  109. package/docs/examples/cascader-select/clearable.vue +34 -34
  110. package/docs/examples/cascader-select/disabled.vue +43 -43
  111. package/docs/examples/cascader-select/filterable.vue +37 -37
  112. package/docs/examples/cascader-select/methods.vue +84 -84
  113. package/docs/examples/cascader-select/multiple.vue +38 -38
  114. package/docs/examples/cascader-select/slot.vue +45 -45
  115. package/docs/examples/checkbox/basic.vue +18 -18
  116. package/docs/examples/checkbox/button.vue +19 -19
  117. package/docs/examples/checkbox/color.vue +25 -25
  118. package/docs/examples/checkbox/disabled.vue +17 -17
  119. package/docs/examples/checkbox/min-max.vue +20 -20
  120. package/docs/examples/checkbox/mixed.vue +56 -56
  121. package/docs/examples/checkbox/size.vue +28 -28
  122. package/docs/examples/code-mirror/basic.vue +11 -11
  123. package/docs/examples/code-mirror/events.vue +42 -42
  124. package/docs/examples/code-mirror/height.vue +25 -25
  125. package/docs/examples/code-mirror/mode.vue +33 -33
  126. package/docs/examples/code-mirror/readonly.vue +14 -14
  127. package/docs/examples/collapse/basic.vue +82 -82
  128. package/docs/examples/comp/basic.vue +7 -7
  129. package/docs/examples/comp/collapse.vue +38 -38
  130. package/docs/examples/comp/tabs.vue +38 -38
  131. package/docs/examples/count/basic.vue +101 -101
  132. package/docs/examples/count-up/basic.vue +89 -89
  133. package/docs/examples/data-panel/basic.vue +110 -110
  134. package/docs/examples/date/basic.vue +73 -73
  135. package/docs/examples/date/default-value.vue +59 -59
  136. package/docs/examples/date/format.vue +75 -75
  137. package/docs/examples/date/range.vue +66 -66
  138. package/docs/examples/date/types.vue +79 -79
  139. package/docs/examples/dialog/basic.vue +36 -36
  140. package/docs/examples/dialog/custom-buttons.vue +44 -44
  141. package/docs/examples/dialog/fullscreen.vue +23 -23
  142. package/docs/examples/dialog/no-mask.vue +17 -17
  143. package/docs/examples/dialog/size.vue +44 -44
  144. package/docs/examples/dialog/steps.vue +57 -57
  145. package/docs/examples/dialog-full/basic.vue +29 -29
  146. package/docs/examples/dialog-full/custom-buttons.vue +45 -45
  147. package/docs/examples/dialog-full/no-buttons.vue +18 -18
  148. package/docs/examples/dialog-full/no-header.vue +27 -27
  149. package/docs/examples/dialog-full/steps.vue +71 -71
  150. package/docs/examples/divider/basic.vue +52 -52
  151. package/docs/examples/drawer/basic.vue +35 -35
  152. package/docs/examples/drawer/custom-buttons.vue +34 -34
  153. package/docs/examples/drawer/direction.vue +47 -47
  154. package/docs/examples/drawer/mask.vue +36 -36
  155. package/docs/examples/drawer/no-buttons.vue +20 -20
  156. package/docs/examples/drawer/size.vue +28 -28
  157. package/docs/examples/dynamic-layer/basic.vue +33 -33
  158. package/docs/examples/dynamic-layer/custom-buttons.vue +43 -43
  159. package/docs/examples/dynamic-layer/form.vue +73 -73
  160. package/docs/examples/dynamic-layer/steps.vue +52 -52
  161. package/docs/examples/dynamic-layer/types.vue +40 -40
  162. package/docs/examples/echarts/basic.vue +31 -31
  163. package/docs/examples/echarts/dynamic.vue +43 -43
  164. package/docs/examples/echarts/line.vue +46 -46
  165. package/docs/examples/echarts/pie.vue +44 -44
  166. package/docs/examples/editor/basic.vue +15 -15
  167. package/docs/examples/form/basic.vue +459 -456
  168. package/docs/examples/guid/basic.vue +10 -10
  169. package/docs/examples/guid/size.vue +13 -13
  170. package/docs/examples/hpanel/basic.vue +79 -79
  171. package/docs/examples/icon/basic.vue +9 -9
  172. package/docs/examples/icon/rotate-flip.vue +9 -9
  173. package/docs/examples/icon/size.vue +7 -7
  174. package/docs/examples/input/basic.vue +10 -10
  175. package/docs/examples/input/clearable.vue +12 -12
  176. package/docs/examples/input/disabled.vue +6 -6
  177. package/docs/examples/input/icon.vue +23 -23
  178. package/docs/examples/input/password.vue +18 -18
  179. package/docs/examples/input/size.vue +13 -13
  180. package/docs/examples/input/textarea.vue +25 -25
  181. package/docs/examples/input/word-limit.vue +28 -28
  182. package/docs/examples/input-button/basic.vue +33 -33
  183. package/docs/examples/input-code/basic.vue +29 -29
  184. package/docs/examples/input-color/basic.vue +10 -10
  185. package/docs/examples/input-color/disabled.vue +13 -13
  186. package/docs/examples/input-color/format.vue +17 -17
  187. package/docs/examples/input-color/no-alpha.vue +13 -13
  188. package/docs/examples/input-color/only-button.vue +15 -15
  189. package/docs/examples/input-color/predefine.vue +31 -31
  190. package/docs/examples/input-color/size.vue +15 -15
  191. package/docs/examples/input-layer/basic.vue +69 -69
  192. package/docs/examples/input-rows/basic.vue +73 -73
  193. package/docs/examples/input-rows/drag.vue +48 -48
  194. package/docs/examples/input-rows/layer-form.vue +85 -85
  195. package/docs/examples/input-rows/nested.vue +91 -91
  196. package/docs/examples/input-tag/basic.vue +27 -27
  197. package/docs/examples/input-tag/colors.vue +23 -23
  198. package/docs/examples/input-tag/readonly.vue +17 -17
  199. package/docs/examples/layer/basic.vue +43 -43
  200. package/docs/examples/layer/custom-buttons.vue +61 -61
  201. package/docs/examples/layer/drawer.vue +37 -37
  202. package/docs/examples/layer/full.vue +38 -38
  203. package/docs/examples/layer/modal.vue +34 -34
  204. package/docs/examples/layer/steps.vue +46 -46
  205. package/docs/examples/layer-form/basic.vue +76 -76
  206. package/docs/examples/layer-form/config.vue +82 -82
  207. package/docs/examples/layer-form/size.vue +72 -72
  208. package/docs/examples/layout/basic.vue +36 -36
  209. package/docs/examples/layout/custom-size.vue +50 -50
  210. package/docs/examples/layout/disable-move.vue +37 -37
  211. package/docs/examples/layout/hide-mid-when-narrow.vue +96 -96
  212. package/docs/examples/layout/min-size.vue +73 -73
  213. package/docs/examples/layout/percent-size.vue +80 -80
  214. package/docs/examples/layout/simple.vue +22 -22
  215. package/docs/examples/layout/top-side.vue +34 -34
  216. package/docs/examples/map/basic.vue +22 -22
  217. package/docs/examples/menu/basic.vue +58 -58
  218. package/docs/examples/menu/collapsed.vue +49 -49
  219. package/docs/examples/menu/horizontal.vue +44 -44
  220. package/docs/examples/menu/selection-test.vue +104 -104
  221. package/docs/examples/menu/theme.vue +46 -46
  222. package/docs/examples/menu/vertical.vue +46 -46
  223. package/docs/examples/number/advanced.vue +143 -143
  224. package/docs/examples/number/basic.vue +63 -63
  225. package/docs/examples/number/disabled.vue +49 -49
  226. package/docs/examples/number/size.vue +42 -42
  227. package/docs/examples/number/slots.vue +123 -123
  228. package/docs/examples/number/step-strictly.vue +41 -41
  229. package/docs/examples/number/step.vue +47 -47
  230. package/docs/examples/page/basic.vue +41 -41
  231. package/docs/examples/page/dept-user-management.vue +211 -211
  232. package/docs/examples/page/init.vue +87 -87
  233. package/docs/examples/page/log.vue +453 -453
  234. package/docs/examples/page/user-management.vue +313 -313
  235. package/docs/examples/panel/tool-buttons.vue +18 -18
  236. package/docs/examples/radio/basic.vue +17 -17
  237. package/docs/examples/radio/button.vue +17 -17
  238. package/docs/examples/radio/color.vue +18 -18
  239. package/docs/examples/radio/disabled.vue +17 -17
  240. package/docs/examples/radio/size.vue +29 -29
  241. package/docs/examples/rate/basic.vue +24 -24
  242. package/docs/examples/rate/half.vue +24 -24
  243. package/docs/examples/rate/readonly.vue +11 -11
  244. package/docs/examples/rate/text.vue +32 -32
  245. package/docs/examples/select/basic.vue +16 -16
  246. package/docs/examples/select/clearable.vue +22 -22
  247. package/docs/examples/select/disabled.vue +31 -31
  248. package/docs/examples/select/filterable.vue +24 -24
  249. package/docs/examples/select/group.vue +23 -23
  250. package/docs/examples/select/icon.vue +16 -16
  251. package/docs/examples/select/multiple.vue +18 -18
  252. package/docs/examples/select/size.vue +39 -39
  253. package/docs/examples/slider/basic.vue +42 -42
  254. package/docs/examples/slider/disabled.vue +17 -17
  255. package/docs/examples/slider/marks.vue +30 -30
  256. package/docs/examples/slider/size.vue +37 -37
  257. package/docs/examples/slider/tooltip.vue +36 -36
  258. package/docs/examples/slider/vertical.vue +26 -26
  259. package/docs/examples/slider-captcha/basic.vue +44 -44
  260. package/docs/examples/slider-captcha/custom.vue +48 -48
  261. package/docs/examples/switch/basic.vue +16 -16
  262. package/docs/examples/switch/disabled.vue +13 -13
  263. package/docs/examples/switch/loading.vue +13 -13
  264. package/docs/examples/switch/size.vue +15 -15
  265. package/docs/examples/switch/text.vue +13 -13
  266. package/docs/examples/table/action-filter.vue +126 -126
  267. package/docs/examples/table/actions.vue +116 -116
  268. package/docs/examples/table/add-row.vue +103 -103
  269. package/docs/examples/table/basic.vue +168 -168
  270. package/docs/examples/table/checkbox-layout.vue +68 -68
  271. package/docs/examples/table/custom-layout.vue +115 -115
  272. package/docs/examples/table/editable.vue +262 -262
  273. package/docs/examples/table/field-selection.vue +87 -87
  274. package/docs/examples/table/frozen-column.vue +140 -140
  275. package/docs/examples/table/height-mode.vue +99 -99
  276. package/docs/examples/table/icon.vue +85 -85
  277. package/docs/examples/table/link.vue +66 -66
  278. package/docs/examples/table/multiple.vue +178 -178
  279. package/docs/examples/table/pagination.vue +151 -151
  280. package/docs/examples/table/single-selection.vue +64 -64
  281. package/docs/examples/table/sub-table-lazy.vue +97 -97
  282. package/docs/examples/table/sub-table.vue +103 -103
  283. package/docs/examples/table/tag.vue +43 -43
  284. package/docs/examples/table/tree-column.vue +119 -119
  285. package/docs/examples/table/tree-data.vue +141 -141
  286. package/docs/examples/table/tree-default-expand-all.vue +60 -60
  287. package/docs/examples/table/tree-lazy.vue +80 -80
  288. package/docs/examples/table/tree-set-selection.vue +75 -75
  289. package/docs/examples/table-panel/basic.vue +228 -228
  290. package/docs/examples/table-panel/batch-operations.vue +285 -285
  291. package/docs/examples/table-panel/button-visibility.vue +88 -88
  292. package/docs/examples/table-panel/filter.vue +219 -219
  293. package/docs/examples/table-panel/get-selection.vue +111 -111
  294. package/docs/examples/table-panel/multiple-selection.vue +243 -243
  295. package/docs/examples/table-panel/pagination.vue +133 -133
  296. package/docs/examples/table-panel/sub-table-lazy.vue +118 -118
  297. package/docs/examples/table-panel/tree-parent-key.vue +67 -67
  298. package/docs/examples/tabs/basic.vue +98 -98
  299. package/docs/examples/title/basic.vue +80 -80
  300. package/docs/examples/tree/accordion.vue +46 -46
  301. package/docs/examples/tree/basic.vue +50 -50
  302. package/docs/examples/tree/buttons.vue +53 -53
  303. package/docs/examples/tree/checkable.vue +52 -52
  304. package/docs/examples/tree/custom-keys.vue +39 -39
  305. package/docs/examples/tree/default-expanded.vue +52 -52
  306. package/docs/examples/tree/draggable.vue +29 -29
  307. package/docs/examples/tree/expand-on-click.vue +39 -39
  308. package/docs/examples/tree/flat-data.vue +20 -20
  309. package/docs/examples/tree/icon.vue +40 -40
  310. package/docs/examples/tree/load-data.vue +37 -37
  311. package/docs/examples/tree/methods.vue +74 -74
  312. package/docs/examples/tree/theme.vue +33 -33
  313. package/docs/examples/upload/accept.vue +31 -31
  314. package/docs/examples/upload/basic.vue +12 -12
  315. package/docs/examples/upload/drag.vue +11 -11
  316. package/docs/examples/upload/image.vue +17 -17
  317. package/docs/examples/upload/limit.vue +20 -20
  318. package/docs/examples/upload/multiple.vue +17 -17
  319. package/docs/examples/upload/readonly.vue +17 -17
  320. package/docs/examples/utils/cipher.vue +160 -160
  321. package/docs/examples/utils/common.vue +153 -153
  322. package/docs/examples/utils/date.vue +56 -56
  323. package/docs/examples/utils/dom.vue +52 -52
  324. package/docs/examples/utils/is.vue +70 -70
  325. package/docs/examples/workflow/basic.vue +265 -265
  326. package/docs/examples/workflow-viewer/basic.vue +248 -248
  327. package/package.json +23 -23
@@ -1,75 +1,75 @@
1
- <template>
2
- <div class="demo-date-format">
3
- <div class="block">
4
- <span class="demonstration">Format</span>
5
- <div class="demonstration-value">Value: {{ value1 }}</div>
6
- <j-date
7
- v-model="value1"
8
- select-type="date"
9
- placeholder="Pick a day"
10
- format="YYYY/MM/DD"
11
- value-format="YYYY-MM-DD"
12
- />
13
- </div>
14
- <div class="block">
15
- <span class="demonstration">Timestamp</span>
16
- <div class="demonstration-value">Value: {{ value2 }}</div>
17
- <j-date
18
- v-model="value2"
19
- select-type="date"
20
- placeholder="Pick a day"
21
- format="YYYY/MM/DD"
22
- value-format="x"
23
- />
24
- </div>
25
- <div class="block">
26
- <span class="demonstration">Month Format</span>
27
- <div class="demonstration-value">Value: {{ value3 }}</div>
28
- <j-date
29
- v-model="value3"
30
- select-type="month"
31
- placeholder="Pick a month"
32
- format="MMM"
33
- value-format="M"
34
- />
35
- </div>
36
- </div>
37
- </template>
38
-
39
- <script setup lang="ts">
40
- import { ref } from 'vue'
41
-
42
- const value1 = ref('')
43
- const value2 = ref('')
44
- const value3 = ref('')
45
- </script>
46
-
47
- <style scoped>
48
- .demo-date-format {
49
- display: flex;
50
- flex-wrap: wrap;
51
- gap: 20px;
52
- }
53
- .demo-date-format .block {
54
- padding: 30px 0;
55
- text-align: center;
56
- border-right: solid 1px var(--el-border-color);
57
- flex: 1;
58
- min-width: 300px;
59
- }
60
- .demo-date-format .block:last-child {
61
- border-right: none;
62
- }
63
- .demo-date-format .demonstration {
64
- display: block;
65
- color: var(--el-text-color-secondary);
66
- font-size: 14px;
67
- margin-bottom: 20px;
68
- }
69
- .demo-date-format .demonstration-value {
70
- display: block;
71
- color: var(--el-text-color-primary);
72
- font-size: 12px;
73
- margin-bottom: 10px;
74
- }
75
- </style>
1
+ <template>
2
+ <div class="demo-date-format">
3
+ <div class="block">
4
+ <span class="demonstration">Format</span>
5
+ <div class="demonstration-value">Value: {{ value1 }}</div>
6
+ <j-date
7
+ v-model="value1"
8
+ select-type="date"
9
+ placeholder="Pick a day"
10
+ format="YYYY/MM/DD"
11
+ value-format="YYYY-MM-DD"
12
+ />
13
+ </div>
14
+ <div class="block">
15
+ <span class="demonstration">Timestamp</span>
16
+ <div class="demonstration-value">Value: {{ value2 }}</div>
17
+ <j-date
18
+ v-model="value2"
19
+ select-type="date"
20
+ placeholder="Pick a day"
21
+ format="YYYY/MM/DD"
22
+ value-format="x"
23
+ />
24
+ </div>
25
+ <div class="block">
26
+ <span class="demonstration">Month Format</span>
27
+ <div class="demonstration-value">Value: {{ value3 }}</div>
28
+ <j-date
29
+ v-model="value3"
30
+ select-type="month"
31
+ placeholder="Pick a month"
32
+ format="MMM"
33
+ value-format="M"
34
+ />
35
+ </div>
36
+ </div>
37
+ </template>
38
+
39
+ <script setup lang="ts">
40
+ import { ref } from 'vue'
41
+
42
+ const value1 = ref('')
43
+ const value2 = ref('')
44
+ const value3 = ref('')
45
+ </script>
46
+
47
+ <style scoped>
48
+ .demo-date-format {
49
+ display: flex;
50
+ flex-wrap: wrap;
51
+ gap: 20px;
52
+ }
53
+ .demo-date-format .block {
54
+ padding: 30px 0;
55
+ text-align: center;
56
+ border-right: solid 1px var(--el-border-color);
57
+ flex: 1;
58
+ min-width: 300px;
59
+ }
60
+ .demo-date-format .block:last-child {
61
+ border-right: none;
62
+ }
63
+ .demo-date-format .demonstration {
64
+ display: block;
65
+ color: var(--el-text-color-secondary);
66
+ font-size: 14px;
67
+ margin-bottom: 20px;
68
+ }
69
+ .demo-date-format .demonstration-value {
70
+ display: block;
71
+ color: var(--el-text-color-primary);
72
+ font-size: 12px;
73
+ margin-bottom: 10px;
74
+ }
75
+ </style>
@@ -1,66 +1,66 @@
1
- <template>
2
- <div class="demo-date-range">
3
- <div class="block">
4
- <span class="demonstration">Date Range</span>
5
- <j-date
6
- v-model="value1"
7
- select-type="daterange"
8
- range-separator="To"
9
- start-placeholder="Start date"
10
- end-placeholder="End date"
11
- />
12
- </div>
13
- <div class="block">
14
- <span class="demonstration">Datetime Range</span>
15
- <j-date
16
- v-model="value2"
17
- select-type="datetimerange"
18
- range-separator="To"
19
- start-placeholder="Start date"
20
- end-placeholder="End date"
21
- />
22
- </div>
23
- <div class="block">
24
- <span class="demonstration">Month Range</span>
25
- <j-date
26
- v-model="value3"
27
- select-type="monthrange"
28
- range-separator="To"
29
- start-placeholder="Start month"
30
- end-placeholder="End month"
31
- />
32
- </div>
33
- </div>
34
- </template>
35
-
36
- <script setup lang="ts">
37
- import { ref } from 'vue'
38
-
39
- const value1 = ref('')
40
- const value2 = ref('')
41
- const value3 = ref('')
42
- </script>
43
-
44
- <style scoped>
45
- .demo-date-range {
46
- display: flex;
47
- flex-wrap: wrap;
48
- gap: 20px;
49
- }
50
- .demo-date-range .block {
51
- padding: 30px 0;
52
- text-align: center;
53
- border-right: solid 1px var(--el-border-color);
54
- flex: 1;
55
- min-width: 300px;
56
- }
57
- .demo-date-range .block:last-child {
58
- border-right: none;
59
- }
60
- .demo-date-range .demonstration {
61
- display: block;
62
- color: var(--el-text-color-secondary);
63
- font-size: 14px;
64
- margin-bottom: 20px;
65
- }
66
- </style>
1
+ <template>
2
+ <div class="demo-date-range">
3
+ <div class="block">
4
+ <span class="demonstration">Date Range</span>
5
+ <j-date
6
+ v-model="value1"
7
+ select-type="daterange"
8
+ range-separator="To"
9
+ start-placeholder="Start date"
10
+ end-placeholder="End date"
11
+ />
12
+ </div>
13
+ <div class="block">
14
+ <span class="demonstration">Datetime Range</span>
15
+ <j-date
16
+ v-model="value2"
17
+ select-type="datetimerange"
18
+ range-separator="To"
19
+ start-placeholder="Start date"
20
+ end-placeholder="End date"
21
+ />
22
+ </div>
23
+ <div class="block">
24
+ <span class="demonstration">Month Range</span>
25
+ <j-date
26
+ v-model="value3"
27
+ select-type="monthrange"
28
+ range-separator="To"
29
+ start-placeholder="Start month"
30
+ end-placeholder="End month"
31
+ />
32
+ </div>
33
+ </div>
34
+ </template>
35
+
36
+ <script setup lang="ts">
37
+ import { ref } from 'vue'
38
+
39
+ const value1 = ref('')
40
+ const value2 = ref('')
41
+ const value3 = ref('')
42
+ </script>
43
+
44
+ <style scoped>
45
+ .demo-date-range {
46
+ display: flex;
47
+ flex-wrap: wrap;
48
+ gap: 20px;
49
+ }
50
+ .demo-date-range .block {
51
+ padding: 30px 0;
52
+ text-align: center;
53
+ border-right: solid 1px var(--el-border-color);
54
+ flex: 1;
55
+ min-width: 300px;
56
+ }
57
+ .demo-date-range .block:last-child {
58
+ border-right: none;
59
+ }
60
+ .demo-date-range .demonstration {
61
+ display: block;
62
+ color: var(--el-text-color-secondary);
63
+ font-size: 14px;
64
+ margin-bottom: 20px;
65
+ }
66
+ </style>
@@ -1,79 +1,79 @@
1
- <template>
2
- <div class="demo-date-types">
3
- <div class="block">
4
- <span class="demonstration">Week</span>
5
- <j-date
6
- v-model="value1"
7
- select-type="week"
8
- format="[Week] ww"
9
- placeholder="Pick a week"
10
- />
11
- </div>
12
- <div class="block">
13
- <span class="demonstration">Month</span>
14
- <j-date
15
- v-model="value2"
16
- select-type="month"
17
- placeholder="Pick a month"
18
- />
19
- </div>
20
- <div class="block">
21
- <span class="demonstration">Year</span>
22
- <j-date
23
- v-model="value3"
24
- select-type="year"
25
- placeholder="Pick a year"
26
- />
27
- </div>
28
- <div class="block">
29
- <span class="demonstration">Dates</span>
30
- <j-date
31
- v-model="value4"
32
- select-type="dates"
33
- placeholder="Pick one or more dates"
34
- />
35
- </div>
36
- <div class="block">
37
- <span class="demonstration">Datetime</span>
38
- <j-date
39
- v-model="value5"
40
- select-type="datetime"
41
- placeholder="Select date and time"
42
- />
43
- </div>
44
- </div>
45
- </template>
46
-
47
- <script setup lang="ts">
48
- import { ref } from 'vue'
49
-
50
- const value1 = ref('')
51
- const value2 = ref('')
52
- const value3 = ref('')
53
- const value4 = ref('')
54
- const value5 = ref('')
55
- </script>
56
-
57
- <style scoped>
58
- .demo-date-types {
59
- display: flex;
60
- flex-wrap: wrap;
61
- gap: 20px;
62
- }
63
- .demo-date-types .block {
64
- padding: 30px 0;
65
- text-align: center;
66
- border-right: solid 1px var(--el-border-color);
67
- flex: 1;
68
- min-width: 300px;
69
- }
70
- .demo-date-types .block:last-child {
71
- border-right: none;
72
- }
73
- .demo-date-types .demonstration {
74
- display: block;
75
- color: var(--el-text-color-secondary);
76
- font-size: 14px;
77
- margin-bottom: 20px;
78
- }
79
- </style>
1
+ <template>
2
+ <div class="demo-date-types">
3
+ <div class="block">
4
+ <span class="demonstration">Week</span>
5
+ <j-date
6
+ v-model="value1"
7
+ select-type="week"
8
+ format="[Week] ww"
9
+ placeholder="Pick a week"
10
+ />
11
+ </div>
12
+ <div class="block">
13
+ <span class="demonstration">Month</span>
14
+ <j-date
15
+ v-model="value2"
16
+ select-type="month"
17
+ placeholder="Pick a month"
18
+ />
19
+ </div>
20
+ <div class="block">
21
+ <span class="demonstration">Year</span>
22
+ <j-date
23
+ v-model="value3"
24
+ select-type="year"
25
+ placeholder="Pick a year"
26
+ />
27
+ </div>
28
+ <div class="block">
29
+ <span class="demonstration">Dates</span>
30
+ <j-date
31
+ v-model="value4"
32
+ select-type="dates"
33
+ placeholder="Pick one or more dates"
34
+ />
35
+ </div>
36
+ <div class="block">
37
+ <span class="demonstration">Datetime</span>
38
+ <j-date
39
+ v-model="value5"
40
+ select-type="datetime"
41
+ placeholder="Select date and time"
42
+ />
43
+ </div>
44
+ </div>
45
+ </template>
46
+
47
+ <script setup lang="ts">
48
+ import { ref } from 'vue'
49
+
50
+ const value1 = ref('')
51
+ const value2 = ref('')
52
+ const value3 = ref('')
53
+ const value4 = ref('')
54
+ const value5 = ref('')
55
+ </script>
56
+
57
+ <style scoped>
58
+ .demo-date-types {
59
+ display: flex;
60
+ flex-wrap: wrap;
61
+ gap: 20px;
62
+ }
63
+ .demo-date-types .block {
64
+ padding: 30px 0;
65
+ text-align: center;
66
+ border-right: solid 1px var(--el-border-color);
67
+ flex: 1;
68
+ min-width: 300px;
69
+ }
70
+ .demo-date-types .block:last-child {
71
+ border-right: none;
72
+ }
73
+ .demo-date-types .demonstration {
74
+ display: block;
75
+ color: var(--el-text-color-secondary);
76
+ font-size: 14px;
77
+ margin-bottom: 20px;
78
+ }
79
+ </style>
@@ -1,36 +1,36 @@
1
- <template>
2
- <div>
3
- <j-button label="打开弹窗" @click="visible = true" />
4
- <j-dialog
5
- v-model:visible="visible"
6
- title="基础弹窗"
7
- :width="600"
8
- :height="400"
9
- @ok="handleOk"
10
- @cancel="handleCancel"
11
- >
12
- <div style="padding: 16px">
13
- <p>这是一个基础的弹窗示例。</p>
14
- <p>弹窗支持拖拽、缩放等功能。</p>
15
- </div>
16
- </j-dialog>
17
- </div>
18
- </template>
19
-
20
- <script setup lang="ts">
21
- import { ref } from 'vue'
22
-
23
- const visible = ref(false)
24
-
25
- const handleOk = (showLoading: any, hideLoading: any) => {
26
- showLoading('保存中...')
27
- setTimeout(() => {
28
- hideLoading()
29
- visible.value = false
30
- }, 1000)
31
- }
32
-
33
- const handleCancel = () => {
34
- visible.value = false
35
- }
36
- </script>
1
+ <template>
2
+ <div>
3
+ <j-button label="打开弹窗" @click="visible = true" />
4
+ <j-dialog
5
+ v-model:visible="visible"
6
+ title="基础弹窗"
7
+ :width="600"
8
+ :height="400"
9
+ @ok="handleOk"
10
+ @cancel="handleCancel"
11
+ >
12
+ <div style="padding: 16px">
13
+ <p>这是一个基础的弹窗示例。</p>
14
+ <p>弹窗支持拖拽、缩放等功能。</p>
15
+ </div>
16
+ </j-dialog>
17
+ </div>
18
+ </template>
19
+
20
+ <script setup lang="ts">
21
+ import { ref } from 'vue'
22
+
23
+ const visible = ref(false)
24
+
25
+ const handleOk = (showLoading: any, hideLoading: any) => {
26
+ showLoading('保存中...')
27
+ setTimeout(() => {
28
+ hideLoading()
29
+ visible.value = false
30
+ }, 1000)
31
+ }
32
+
33
+ const handleCancel = () => {
34
+ visible.value = false
35
+ }
36
+ </script>
@@ -1,44 +1,44 @@
1
- <template>
2
- <div>
3
- <j-button label="自定义按钮" @click="visible = true" />
4
- <j-dialog
5
- v-model:visible="visible"
6
- title="自定义按钮弹窗"
7
- :width="600"
8
- :height="400"
9
- :has-save-btn="false"
10
- :buttons="buttons"
11
- >
12
- <div style="padding: 16px">
13
- <p>这个弹窗使用了自定义按钮配置。</p>
14
- </div>
15
- </j-dialog>
16
- </div>
17
- </template>
18
-
19
- <script setup lang="ts">
20
- import { ref } from 'vue'
21
- import { ElMessage } from 'element-plus'
22
-
23
- const visible = ref(false)
24
-
25
- const buttons = [
26
- {
27
- prop: 'confirm',
28
- label: '确认',
29
- type: 'primary',
30
- click: () => {
31
- ElMessage.success('点击了确认按钮')
32
- visible.value = false
33
- },
34
- },
35
- {
36
- prop: 'delete',
37
- label: '删除',
38
- danger: true,
39
- click: () => {
40
- ElMessage.warning('点击了删除按钮')
41
- },
42
- },
43
- ]
44
- </script>
1
+ <template>
2
+ <div>
3
+ <j-button label="自定义按钮" @click="visible = true" />
4
+ <j-dialog
5
+ v-model:visible="visible"
6
+ title="自定义按钮弹窗"
7
+ :width="600"
8
+ :height="400"
9
+ :has-save-btn="false"
10
+ :buttons="buttons"
11
+ >
12
+ <div style="padding: 16px">
13
+ <p>这个弹窗使用了自定义按钮配置。</p>
14
+ </div>
15
+ </j-dialog>
16
+ </div>
17
+ </template>
18
+
19
+ <script setup lang="ts">
20
+ import { ref } from 'vue'
21
+ import { ElMessage } from 'element-plus'
22
+
23
+ const visible = ref(false)
24
+
25
+ const buttons = [
26
+ {
27
+ prop: 'confirm',
28
+ label: '确认',
29
+ type: 'primary',
30
+ click: () => {
31
+ ElMessage.success('点击了确认按钮')
32
+ visible.value = false
33
+ },
34
+ },
35
+ {
36
+ prop: 'delete',
37
+ label: '删除',
38
+ danger: true,
39
+ click: () => {
40
+ ElMessage.warning('点击了删除按钮')
41
+ },
42
+ },
43
+ ]
44
+ </script>
@@ -1,23 +1,23 @@
1
- <template>
2
- <div>
3
- <j-button label="可全屏弹窗" @click="visible = true" />
4
- <j-dialog
5
- v-model:visible="visible"
6
- title="全屏弹窗"
7
- :show-full-screen-btn="true"
8
- :width="600"
9
- :height="400"
10
- >
11
- <div style="padding: 16px">
12
- <p>点击右上角的全屏按钮可以切换全屏显示。</p>
13
- <p>全屏状态下可以再次点击退出全屏。</p>
14
- </div>
15
- </j-dialog>
16
- </div>
17
- </template>
18
-
19
- <script setup lang="ts">
20
- import { ref } from 'vue'
21
-
22
- const visible = ref(false)
23
- </script>
1
+ <template>
2
+ <div>
3
+ <j-button label="可全屏弹窗" @click="visible = true" />
4
+ <j-dialog
5
+ v-model:visible="visible"
6
+ title="全屏弹窗"
7
+ :show-full-screen-btn="true"
8
+ :width="600"
9
+ :height="400"
10
+ >
11
+ <div style="padding: 16px">
12
+ <p>点击右上角的全屏按钮可以切换全屏显示。</p>
13
+ <p>全屏状态下可以再次点击退出全屏。</p>
14
+ </div>
15
+ </j-dialog>
16
+ </div>
17
+ </template>
18
+
19
+ <script setup lang="ts">
20
+ import { ref } from 'vue'
21
+
22
+ const visible = ref(false)
23
+ </script>