element-ps 2.0.37 → 2.0.39

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 (566) hide show
  1. package/dist/index.full.js +448 -327
  2. package/dist/index.full.min.js +8 -8
  3. package/dist/index.full.min.js.map +1 -1
  4. package/dist/index.full.min.mjs +8 -8
  5. package/dist/index.full.min.mjs.map +1 -1
  6. package/dist/index.full.mjs +448 -327
  7. package/dist/locale/en.js +1 -1
  8. package/dist/locale/en.min.js +1 -1
  9. package/dist/locale/en.min.mjs +1 -1
  10. package/dist/locale/en.mjs +1 -1
  11. package/dist/locale/zh-cn.js +1 -1
  12. package/dist/locale/zh-cn.min.js +1 -1
  13. package/dist/locale/zh-cn.min.mjs +1 -1
  14. package/dist/locale/zh-cn.mjs +1 -1
  15. package/es/components/affix/index.mjs +2 -2
  16. package/es/components/affix/src/affix.mjs +19 -82
  17. package/es/components/affix/src/affix.mjs.map +1 -1
  18. package/es/components/affix/src/affix2.mjs +82 -19
  19. package/es/components/affix/src/affix2.mjs.map +1 -1
  20. package/es/components/alert/index.mjs +2 -2
  21. package/es/components/alert/src/alert.mjs +33 -83
  22. package/es/components/alert/src/alert.mjs.map +1 -1
  23. package/es/components/alert/src/alert2.mjs +83 -33
  24. package/es/components/alert/src/alert2.mjs.map +1 -1
  25. package/es/components/autocomplete/index.d.ts +5 -5
  26. package/es/components/autocomplete/index.mjs +2 -2
  27. package/es/components/autocomplete/src/autocomplete.mjs +94 -58
  28. package/es/components/autocomplete/src/autocomplete.mjs.map +1 -1
  29. package/es/components/autocomplete/src/autocomplete.vue.d.ts +5 -5
  30. package/es/components/autocomplete/src/autocomplete2.mjs +58 -94
  31. package/es/components/autocomplete/src/autocomplete2.mjs.map +1 -1
  32. package/es/components/avatar/index.mjs +2 -2
  33. package/es/components/avatar/src/avatar.mjs +61 -29
  34. package/es/components/avatar/src/avatar.mjs.map +1 -1
  35. package/es/components/avatar/src/avatar2.mjs +29 -61
  36. package/es/components/avatar/src/avatar2.mjs.map +1 -1
  37. package/es/components/breadcrumb/index.mjs +4 -4
  38. package/es/components/breadcrumb/src/breadcrumb-item.mjs +46 -11
  39. package/es/components/breadcrumb/src/breadcrumb-item.mjs.map +1 -1
  40. package/es/components/breadcrumb/src/breadcrumb-item2.mjs +11 -46
  41. package/es/components/breadcrumb/src/breadcrumb-item2.mjs.map +1 -1
  42. package/es/components/breadcrumb/src/breadcrumb.mjs +12 -37
  43. package/es/components/breadcrumb/src/breadcrumb.mjs.map +1 -1
  44. package/es/components/breadcrumb/src/breadcrumb2.mjs +37 -12
  45. package/es/components/breadcrumb/src/breadcrumb2.mjs.map +1 -1
  46. package/es/components/button/index.mjs +2 -2
  47. package/es/components/button/src/button-group.mjs +1 -1
  48. package/es/components/button/src/button.mjs +48 -96
  49. package/es/components/button/src/button.mjs.map +1 -1
  50. package/es/components/button/src/button2.mjs +96 -48
  51. package/es/components/button/src/button2.mjs.map +1 -1
  52. package/es/components/calendar/index.mjs +2 -2
  53. package/es/components/calendar/src/calendar.mjs +9 -188
  54. package/es/components/calendar/src/calendar.mjs.map +1 -1
  55. package/es/components/calendar/src/calendar2.mjs +188 -9
  56. package/es/components/calendar/src/calendar2.mjs.map +1 -1
  57. package/es/components/calendar/src/date-table.mjs +146 -27
  58. package/es/components/calendar/src/date-table.mjs.map +1 -1
  59. package/es/components/calendar/src/date-table2.mjs +27 -146
  60. package/es/components/calendar/src/date-table2.mjs.map +1 -1
  61. package/es/components/card/index.mjs +2 -2
  62. package/es/components/card/src/card.mjs +15 -35
  63. package/es/components/card/src/card.mjs.map +1 -1
  64. package/es/components/card/src/card2.mjs +35 -15
  65. package/es/components/card/src/card2.mjs.map +1 -1
  66. package/es/components/carousel/index.mjs +4 -4
  67. package/es/components/carousel/src/carousel-item.mjs +148 -7
  68. package/es/components/carousel/src/carousel-item.mjs.map +1 -1
  69. package/es/components/carousel/src/carousel-item2.mjs +7 -148
  70. package/es/components/carousel/src/carousel-item2.mjs.map +1 -1
  71. package/es/components/carousel/src/carousel.mjs +201 -43
  72. package/es/components/carousel/src/carousel.mjs.map +1 -1
  73. package/es/components/carousel/src/carousel2.mjs +43 -201
  74. package/es/components/carousel/src/carousel2.mjs.map +1 -1
  75. package/es/components/check-tag/index.mjs +2 -2
  76. package/es/components/check-tag/src/check-tag.mjs +7 -20
  77. package/es/components/check-tag/src/check-tag.mjs.map +1 -1
  78. package/es/components/check-tag/src/check-tag2.mjs +20 -7
  79. package/es/components/check-tag/src/check-tag2.mjs.map +1 -1
  80. package/es/components/collection/index.mjs +1 -1
  81. package/es/components/collection/src/collection.mjs +10 -30
  82. package/es/components/collection/src/collection.mjs.map +1 -1
  83. package/es/components/collection/src/collection2.mjs +30 -10
  84. package/es/components/collection/src/collection2.mjs.map +1 -1
  85. package/es/components/dialog/index.mjs +2 -2
  86. package/es/components/dialog/src/dialog.mjs +87 -61
  87. package/es/components/dialog/src/dialog.mjs.map +1 -1
  88. package/es/components/dialog/src/dialog2.mjs +61 -87
  89. package/es/components/dialog/src/dialog2.mjs.map +1 -1
  90. package/es/components/drawer/index.mjs +2 -2
  91. package/es/components/drawer/src/drawer.mjs +23 -117
  92. package/es/components/drawer/src/drawer.mjs.map +1 -1
  93. package/es/components/drawer/src/drawer2.mjs +117 -23
  94. package/es/components/drawer/src/drawer2.mjs.map +1 -1
  95. package/es/components/dropdown/index.d.ts +3 -3
  96. package/es/components/dropdown/src/dropdown.d.ts +1 -1
  97. package/es/components/dropdown/src/dropdown.mjs +1 -1
  98. package/es/components/dropdown/src/dropdown.vue.d.ts +3 -3
  99. package/es/components/form/index.mjs +4 -4
  100. package/es/components/form/src/form-item.mjs +46 -171
  101. package/es/components/form/src/form-item.mjs.map +1 -1
  102. package/es/components/form/src/form-item2.mjs +171 -46
  103. package/es/components/form/src/form-item2.mjs.map +1 -1
  104. package/es/components/form/src/form.mjs +40 -45
  105. package/es/components/form/src/form.mjs.map +1 -1
  106. package/es/components/form/src/form2.mjs +45 -40
  107. package/es/components/form/src/form2.mjs.map +1 -1
  108. package/es/components/icon/index.mjs +2 -2
  109. package/es/components/icon/src/icon.mjs +8 -35
  110. package/es/components/icon/src/icon.mjs.map +1 -1
  111. package/es/components/icon/src/icon2.mjs +35 -8
  112. package/es/components/icon/src/icon2.mjs.map +1 -1
  113. package/es/components/image/index.mjs +2 -2
  114. package/es/components/image/src/image.mjs +127 -50
  115. package/es/components/image/src/image.mjs.map +1 -1
  116. package/es/components/image/src/image2.mjs +50 -127
  117. package/es/components/image/src/image2.mjs.map +1 -1
  118. package/es/components/image-viewer/index.mjs +2 -2
  119. package/es/components/image-viewer/src/image-viewer.mjs +210 -31
  120. package/es/components/image-viewer/src/image-viewer.mjs.map +1 -1
  121. package/es/components/image-viewer/src/image-viewer2.mjs +31 -210
  122. package/es/components/image-viewer/src/image-viewer2.mjs.map +1 -1
  123. package/es/components/index.mjs +34 -34
  124. package/es/components/link/index.mjs +2 -2
  125. package/es/components/link/src/link.mjs +43 -19
  126. package/es/components/link/src/link.mjs.map +1 -1
  127. package/es/components/link/src/link2.mjs +19 -43
  128. package/es/components/link/src/link2.mjs.map +1 -1
  129. package/es/components/menu/index.d.ts +3 -3
  130. package/es/components/menu/index.mjs +4 -4
  131. package/es/components/menu/src/menu-item-group.mjs +4 -35
  132. package/es/components/menu/src/menu-item-group.mjs.map +1 -1
  133. package/es/components/menu/src/menu-item-group2.mjs +35 -4
  134. package/es/components/menu/src/menu-item-group2.mjs.map +1 -1
  135. package/es/components/menu/src/menu-item.mjs +74 -15
  136. package/es/components/menu/src/menu-item.mjs.map +1 -1
  137. package/es/components/menu/src/menu-item2.mjs +15 -74
  138. package/es/components/menu/src/menu-item2.mjs.map +1 -1
  139. package/es/components/menu/src/menu.d.ts +4 -4
  140. package/es/components/page-header/index.mjs +2 -2
  141. package/es/components/page-header/src/page-header.mjs +55 -14
  142. package/es/components/page-header/src/page-header.mjs.map +1 -1
  143. package/es/components/page-header/src/page-header2.mjs +14 -55
  144. package/es/components/page-header/src/page-header2.mjs.map +1 -1
  145. package/es/components/popconfirm/src/popconfirm.mjs +1 -1
  146. package/es/components/popover/index.d.ts +6 -6
  147. package/es/components/popover/src/index.vue.d.ts +3 -3
  148. package/es/components/popover/src/popover.d.ts +1 -1
  149. package/es/components/popper/index.mjs +2 -2
  150. package/es/components/popper/src/content.mjs +52 -64
  151. package/es/components/popper/src/content.mjs.map +1 -1
  152. package/es/components/popper/src/content2.mjs +64 -52
  153. package/es/components/popper/src/content2.mjs.map +1 -1
  154. package/es/components/progress/index.mjs +2 -2
  155. package/es/components/progress/src/progress.mjs +230 -57
  156. package/es/components/progress/src/progress.mjs.map +1 -1
  157. package/es/components/progress/src/progress2.mjs +57 -230
  158. package/es/components/progress/src/progress2.mjs.map +1 -1
  159. package/es/components/radio/index.mjs +2 -2
  160. package/es/components/radio/src/radio-button.mjs +80 -9
  161. package/es/components/radio/src/radio-button.mjs.map +1 -1
  162. package/es/components/radio/src/radio-button2.mjs +9 -80
  163. package/es/components/radio/src/radio-button2.mjs.map +1 -1
  164. package/es/components/result/index.mjs +2 -2
  165. package/es/components/result/src/result.mjs +73 -28
  166. package/es/components/result/src/result.mjs.map +1 -1
  167. package/es/components/result/src/result2.mjs +28 -73
  168. package/es/components/result/src/result2.mjs.map +1 -1
  169. package/es/components/roving-focus-group/index.mjs +3 -3
  170. package/es/components/roving-focus-group/src/roving-focus-group-impl.mjs +1 -1
  171. package/es/components/roving-focus-group/src/roving-focus-group.mjs +27 -29
  172. package/es/components/roving-focus-group/src/roving-focus-group.mjs.map +1 -1
  173. package/es/components/roving-focus-group/src/roving-focus-group2.mjs +29 -27
  174. package/es/components/roving-focus-group/src/roving-focus-group2.mjs.map +1 -1
  175. package/es/components/roving-focus-group/src/roving-focus-item.mjs +1 -1
  176. package/es/components/scrollbar/src/bar.mjs +35 -22
  177. package/es/components/scrollbar/src/bar.mjs.map +1 -1
  178. package/es/components/scrollbar/src/bar2.mjs +22 -35
  179. package/es/components/scrollbar/src/bar2.mjs.map +1 -1
  180. package/es/components/scrollbar/src/scrollbar2.mjs +1 -1
  181. package/es/components/select/index.d.ts +5 -5
  182. package/es/components/select/src/select.vue.d.ts +5 -5
  183. package/es/components/select/src/useSelect.d.ts +5 -5
  184. package/es/components/select-v2/index.d.ts +10 -10
  185. package/es/components/select-v2/src/option-item.vue.d.ts +1 -1
  186. package/es/components/select-v2/src/select.vue.d.ts +5 -5
  187. package/es/components/select-v2/src/useSelect.d.ts +5 -5
  188. package/es/components/skeleton/index.mjs +2 -2
  189. package/es/components/skeleton/src/skeleton.mjs +49 -22
  190. package/es/components/skeleton/src/skeleton.mjs.map +1 -1
  191. package/es/components/skeleton/src/skeleton2.mjs +22 -49
  192. package/es/components/skeleton/src/skeleton2.mjs.map +1 -1
  193. package/es/components/switch/index.mjs +2 -2
  194. package/es/components/switch/src/switch.mjs +81 -176
  195. package/es/components/switch/src/switch.mjs.map +1 -1
  196. package/es/components/switch/src/switch2.mjs +176 -81
  197. package/es/components/switch/src/switch2.mjs.map +1 -1
  198. package/es/components/table/index.d.ts +39 -86
  199. package/es/components/table/src/config.mjs +3 -0
  200. package/es/components/table/src/config.mjs.map +1 -1
  201. package/es/components/table/src/filter-panel.mjs +8 -1
  202. package/es/components/table/src/filter-panel.mjs.map +1 -1
  203. package/es/components/table/src/filter-panel.vue.d.ts +5 -5
  204. package/es/components/table/src/store/current.mjs +14 -12
  205. package/es/components/table/src/store/current.mjs.map +1 -1
  206. package/es/components/table/src/store/helper.mjs +5 -1
  207. package/es/components/table/src/store/helper.mjs.map +1 -1
  208. package/es/components/table/src/store/index.mjs +9 -9
  209. package/es/components/table/src/store/index.mjs.map +1 -1
  210. package/es/components/table/src/store/watcher.mjs +11 -1
  211. package/es/components/table/src/store/watcher.mjs.map +1 -1
  212. package/es/components/table/src/table/defaults.d.ts +8 -4
  213. package/es/components/table/src/table/defaults.mjs +3 -4
  214. package/es/components/table/src/table/defaults.mjs.map +1 -1
  215. package/es/components/table/src/table/style-helper.d.ts +24 -34
  216. package/es/components/table/src/table/style-helper.mjs +107 -120
  217. package/es/components/table/src/table/style-helper.mjs.map +1 -1
  218. package/es/components/table/src/table/utils-helper.d.ts +1 -1
  219. package/es/components/table/src/table/utils-helper.mjs.map +1 -1
  220. package/es/components/table/src/table-body/events-helper.d.ts +1 -3
  221. package/es/components/table/src/table-body/events-helper.mjs +3 -3
  222. package/es/components/table/src/table-body/events-helper.mjs.map +1 -1
  223. package/es/components/table/src/table-body/index.mjs +1 -5
  224. package/es/components/table/src/table-body/index.mjs.map +1 -1
  225. package/es/components/table/src/table-body/render-helper.mjs +6 -3
  226. package/es/components/table/src/table-body/render-helper.mjs.map +1 -1
  227. package/es/components/table/src/table-body/styles-helper.d.ts +1 -1
  228. package/es/components/table/src/table-body/styles-helper.mjs +3 -3
  229. package/es/components/table/src/table-body/styles-helper.mjs.map +1 -1
  230. package/es/components/table/src/table-column/render-helper.mjs +4 -2
  231. package/es/components/table/src/table-column/render-helper.mjs.map +1 -1
  232. package/es/components/table/src/table-header/event-helper.mjs +5 -9
  233. package/es/components/table/src/table-header/event-helper.mjs.map +1 -1
  234. package/es/components/table/src/table-header/index.mjs +1 -2
  235. package/es/components/table/src/table-header/index.mjs.map +1 -1
  236. package/es/components/table/src/table-header/style.helper.mjs +2 -2
  237. package/es/components/table/src/table-header/style.helper.mjs.map +1 -1
  238. package/es/components/table/src/table-layout.d.ts +1 -6
  239. package/es/components/table/src/table-layout.mjs +0 -64
  240. package/es/components/table/src/table-layout.mjs.map +1 -1
  241. package/es/components/table/src/table.mjs +31 -35
  242. package/es/components/table/src/table.mjs.map +1 -1
  243. package/es/components/table/src/table.vue.d.ts +39 -86
  244. package/es/components/table/src/util.d.ts +7 -7
  245. package/es/components/table/src/util.mjs +68 -52
  246. package/es/components/table/src/util.mjs.map +1 -1
  247. package/es/components/table-v2/src/components/header.d.ts +1 -1
  248. package/es/components/table-v2/src/table-grid.d.ts +1 -1
  249. package/es/components/table-v2/src/table-v2.d.ts +1 -1
  250. package/es/components/tabs/index.mjs +2 -2
  251. package/es/components/tabs/src/tab-pane.mjs +61 -15
  252. package/es/components/tabs/src/tab-pane.mjs.map +1 -1
  253. package/es/components/tabs/src/tab-pane2.mjs +15 -61
  254. package/es/components/tabs/src/tab-pane2.mjs.map +1 -1
  255. package/es/components/teleport/index.mjs +2 -2
  256. package/es/components/teleport/src/teleport.mjs +18 -43
  257. package/es/components/teleport/src/teleport.mjs.map +1 -1
  258. package/es/components/teleport/src/teleport2.mjs +43 -18
  259. package/es/components/teleport/src/teleport2.mjs.map +1 -1
  260. package/es/components/time-picker/src/common/picker.vue.d.ts +5 -5
  261. package/es/components/tooltip/index.d.ts +3 -3
  262. package/es/components/tooltip/src/tooltip.d.ts +1 -1
  263. package/es/components/tooltip/src/tooltip.mjs +1 -1
  264. package/es/components/tooltip/src/tooltip.vue.d.ts +3 -3
  265. package/es/components/tooltip/src/trigger.vue.d.ts +3 -3
  266. package/es/components/tooltip-v2/index.mjs +1 -1
  267. package/es/components/tooltip-v2/src/tooltip.mjs +1 -1
  268. package/es/components/tooltip-v2/src/tooltip2.mjs +2 -2
  269. package/es/components/tooltip-v2/src/trigger.mjs +89 -11
  270. package/es/components/tooltip-v2/src/trigger.mjs.map +1 -1
  271. package/es/components/tooltip-v2/src/trigger2.mjs +11 -89
  272. package/es/components/tooltip-v2/src/trigger2.mjs.map +1 -1
  273. package/es/components/upload/index.mjs +4 -4
  274. package/es/components/upload/src/upload-content.mjs +15 -46
  275. package/es/components/upload/src/upload-content.mjs.map +1 -1
  276. package/es/components/upload/src/upload-content2.mjs +46 -15
  277. package/es/components/upload/src/upload-content2.mjs.map +1 -1
  278. package/es/components/upload/src/upload-list.mjs +155 -26
  279. package/es/components/upload/src/upload-list.mjs.map +1 -1
  280. package/es/components/upload/src/upload-list2.mjs +26 -155
  281. package/es/components/upload/src/upload-list2.mjs.map +1 -1
  282. package/es/components/upload/src/upload.mjs +99 -106
  283. package/es/components/upload/src/upload.mjs.map +1 -1
  284. package/es/components/upload/src/upload2.mjs +106 -99
  285. package/es/components/upload/src/upload2.mjs.map +1 -1
  286. package/es/index.mjs +34 -34
  287. package/es/version.d.ts +1 -1
  288. package/es/version.mjs +1 -1
  289. package/es/version.mjs.map +1 -1
  290. package/lib/components/affix/index.js +2 -2
  291. package/lib/components/affix/src/affix.js +19 -82
  292. package/lib/components/affix/src/affix.js.map +1 -1
  293. package/lib/components/affix/src/affix2.js +82 -19
  294. package/lib/components/affix/src/affix2.js.map +1 -1
  295. package/lib/components/alert/index.js +2 -2
  296. package/lib/components/alert/src/alert.js +33 -82
  297. package/lib/components/alert/src/alert.js.map +1 -1
  298. package/lib/components/alert/src/alert2.js +82 -33
  299. package/lib/components/alert/src/alert2.js.map +1 -1
  300. package/lib/components/autocomplete/index.d.ts +5 -5
  301. package/lib/components/autocomplete/index.js +2 -2
  302. package/lib/components/autocomplete/src/autocomplete.js +94 -58
  303. package/lib/components/autocomplete/src/autocomplete.js.map +1 -1
  304. package/lib/components/autocomplete/src/autocomplete.vue.d.ts +5 -5
  305. package/lib/components/autocomplete/src/autocomplete2.js +58 -94
  306. package/lib/components/autocomplete/src/autocomplete2.js.map +1 -1
  307. package/lib/components/avatar/index.js +2 -2
  308. package/lib/components/avatar/src/avatar.js +61 -29
  309. package/lib/components/avatar/src/avatar.js.map +1 -1
  310. package/lib/components/avatar/src/avatar2.js +29 -61
  311. package/lib/components/avatar/src/avatar2.js.map +1 -1
  312. package/lib/components/breadcrumb/index.js +4 -4
  313. package/lib/components/breadcrumb/src/breadcrumb-item.js +46 -11
  314. package/lib/components/breadcrumb/src/breadcrumb-item.js.map +1 -1
  315. package/lib/components/breadcrumb/src/breadcrumb-item2.js +11 -46
  316. package/lib/components/breadcrumb/src/breadcrumb-item2.js.map +1 -1
  317. package/lib/components/breadcrumb/src/breadcrumb.js +12 -37
  318. package/lib/components/breadcrumb/src/breadcrumb.js.map +1 -1
  319. package/lib/components/breadcrumb/src/breadcrumb2.js +37 -12
  320. package/lib/components/breadcrumb/src/breadcrumb2.js.map +1 -1
  321. package/lib/components/button/index.js +2 -2
  322. package/lib/components/button/src/button-group.js +1 -1
  323. package/lib/components/button/src/button.js +50 -96
  324. package/lib/components/button/src/button.js.map +1 -1
  325. package/lib/components/button/src/button2.js +96 -50
  326. package/lib/components/button/src/button2.js.map +1 -1
  327. package/lib/components/calendar/index.js +2 -2
  328. package/lib/components/calendar/src/calendar.js +9 -192
  329. package/lib/components/calendar/src/calendar.js.map +1 -1
  330. package/lib/components/calendar/src/calendar2.js +192 -9
  331. package/lib/components/calendar/src/calendar2.js.map +1 -1
  332. package/lib/components/calendar/src/date-table.js +151 -30
  333. package/lib/components/calendar/src/date-table.js.map +1 -1
  334. package/lib/components/calendar/src/date-table2.js +30 -151
  335. package/lib/components/calendar/src/date-table2.js.map +1 -1
  336. package/lib/components/card/index.js +2 -2
  337. package/lib/components/card/src/card.js +15 -35
  338. package/lib/components/card/src/card.js.map +1 -1
  339. package/lib/components/card/src/card2.js +35 -15
  340. package/lib/components/card/src/card2.js.map +1 -1
  341. package/lib/components/carousel/index.js +4 -4
  342. package/lib/components/carousel/src/carousel-item.js +148 -7
  343. package/lib/components/carousel/src/carousel-item.js.map +1 -1
  344. package/lib/components/carousel/src/carousel-item2.js +7 -148
  345. package/lib/components/carousel/src/carousel-item2.js.map +1 -1
  346. package/lib/components/carousel/src/carousel.js +201 -43
  347. package/lib/components/carousel/src/carousel.js.map +1 -1
  348. package/lib/components/carousel/src/carousel2.js +43 -201
  349. package/lib/components/carousel/src/carousel2.js.map +1 -1
  350. package/lib/components/check-tag/index.js +2 -2
  351. package/lib/components/check-tag/src/check-tag.js +7 -20
  352. package/lib/components/check-tag/src/check-tag.js.map +1 -1
  353. package/lib/components/check-tag/src/check-tag2.js +20 -7
  354. package/lib/components/check-tag/src/check-tag2.js.map +1 -1
  355. package/lib/components/collection/index.js +1 -1
  356. package/lib/components/collection/src/collection.js +9 -30
  357. package/lib/components/collection/src/collection.js.map +1 -1
  358. package/lib/components/collection/src/collection2.js +30 -9
  359. package/lib/components/collection/src/collection2.js.map +1 -1
  360. package/lib/components/dialog/index.js +2 -2
  361. package/lib/components/dialog/src/dialog.js +87 -61
  362. package/lib/components/dialog/src/dialog.js.map +1 -1
  363. package/lib/components/dialog/src/dialog2.js +61 -87
  364. package/lib/components/dialog/src/dialog2.js.map +1 -1
  365. package/lib/components/drawer/index.js +2 -2
  366. package/lib/components/drawer/src/drawer.js +23 -117
  367. package/lib/components/drawer/src/drawer.js.map +1 -1
  368. package/lib/components/drawer/src/drawer2.js +117 -23
  369. package/lib/components/drawer/src/drawer2.js.map +1 -1
  370. package/lib/components/dropdown/index.d.ts +3 -3
  371. package/lib/components/dropdown/src/dropdown.d.ts +1 -1
  372. package/lib/components/dropdown/src/dropdown.js +1 -1
  373. package/lib/components/dropdown/src/dropdown.vue.d.ts +3 -3
  374. package/lib/components/form/index.js +4 -4
  375. package/lib/components/form/src/form-item.js +47 -171
  376. package/lib/components/form/src/form-item.js.map +1 -1
  377. package/lib/components/form/src/form-item2.js +171 -47
  378. package/lib/components/form/src/form-item2.js.map +1 -1
  379. package/lib/components/form/src/form.js +40 -45
  380. package/lib/components/form/src/form.js.map +1 -1
  381. package/lib/components/form/src/form2.js +45 -40
  382. package/lib/components/form/src/form2.js.map +1 -1
  383. package/lib/components/icon/index.js +2 -2
  384. package/lib/components/icon/src/icon.js +8 -35
  385. package/lib/components/icon/src/icon.js.map +1 -1
  386. package/lib/components/icon/src/icon2.js +35 -8
  387. package/lib/components/icon/src/icon2.js.map +1 -1
  388. package/lib/components/image/index.js +2 -2
  389. package/lib/components/image/src/image.js +127 -50
  390. package/lib/components/image/src/image.js.map +1 -1
  391. package/lib/components/image/src/image2.js +50 -127
  392. package/lib/components/image/src/image2.js.map +1 -1
  393. package/lib/components/image-viewer/index.js +2 -2
  394. package/lib/components/image-viewer/src/image-viewer.js +210 -31
  395. package/lib/components/image-viewer/src/image-viewer.js.map +1 -1
  396. package/lib/components/image-viewer/src/image-viewer2.js +31 -210
  397. package/lib/components/image-viewer/src/image-viewer2.js.map +1 -1
  398. package/lib/components/index.js +34 -34
  399. package/lib/components/link/index.js +2 -2
  400. package/lib/components/link/src/link.js +43 -19
  401. package/lib/components/link/src/link.js.map +1 -1
  402. package/lib/components/link/src/link2.js +19 -43
  403. package/lib/components/link/src/link2.js.map +1 -1
  404. package/lib/components/menu/index.d.ts +3 -3
  405. package/lib/components/menu/index.js +4 -4
  406. package/lib/components/menu/src/menu-item-group.js +4 -35
  407. package/lib/components/menu/src/menu-item-group.js.map +1 -1
  408. package/lib/components/menu/src/menu-item-group2.js +35 -4
  409. package/lib/components/menu/src/menu-item-group2.js.map +1 -1
  410. package/lib/components/menu/src/menu-item.js +74 -16
  411. package/lib/components/menu/src/menu-item.js.map +1 -1
  412. package/lib/components/menu/src/menu-item2.js +16 -74
  413. package/lib/components/menu/src/menu-item2.js.map +1 -1
  414. package/lib/components/menu/src/menu.d.ts +4 -4
  415. package/lib/components/page-header/index.js +2 -2
  416. package/lib/components/page-header/src/page-header.js +55 -14
  417. package/lib/components/page-header/src/page-header.js.map +1 -1
  418. package/lib/components/page-header/src/page-header2.js +14 -55
  419. package/lib/components/page-header/src/page-header2.js.map +1 -1
  420. package/lib/components/popconfirm/src/popconfirm.js +1 -1
  421. package/lib/components/popover/index.d.ts +6 -6
  422. package/lib/components/popover/src/index.vue.d.ts +3 -3
  423. package/lib/components/popover/src/popover.d.ts +1 -1
  424. package/lib/components/popper/index.js +2 -2
  425. package/lib/components/popper/src/content.js +52 -65
  426. package/lib/components/popper/src/content.js.map +1 -1
  427. package/lib/components/popper/src/content2.js +65 -52
  428. package/lib/components/popper/src/content2.js.map +1 -1
  429. package/lib/components/progress/index.js +2 -2
  430. package/lib/components/progress/src/progress.js +230 -57
  431. package/lib/components/progress/src/progress.js.map +1 -1
  432. package/lib/components/progress/src/progress2.js +57 -230
  433. package/lib/components/progress/src/progress2.js.map +1 -1
  434. package/lib/components/radio/index.js +2 -2
  435. package/lib/components/radio/src/radio-button.js +79 -8
  436. package/lib/components/radio/src/radio-button.js.map +1 -1
  437. package/lib/components/radio/src/radio-button2.js +8 -79
  438. package/lib/components/radio/src/radio-button2.js.map +1 -1
  439. package/lib/components/result/index.js +2 -2
  440. package/lib/components/result/src/result.js +73 -30
  441. package/lib/components/result/src/result.js.map +1 -1
  442. package/lib/components/result/src/result2.js +30 -73
  443. package/lib/components/result/src/result2.js.map +1 -1
  444. package/lib/components/roving-focus-group/index.js +2 -2
  445. package/lib/components/roving-focus-group/src/roving-focus-group-impl.js +1 -1
  446. package/lib/components/roving-focus-group/src/roving-focus-group.js +27 -33
  447. package/lib/components/roving-focus-group/src/roving-focus-group.js.map +1 -1
  448. package/lib/components/roving-focus-group/src/roving-focus-group2.js +33 -27
  449. package/lib/components/roving-focus-group/src/roving-focus-group2.js.map +1 -1
  450. package/lib/components/roving-focus-group/src/roving-focus-item.js +1 -1
  451. package/lib/components/scrollbar/src/bar.js +35 -22
  452. package/lib/components/scrollbar/src/bar.js.map +1 -1
  453. package/lib/components/scrollbar/src/bar2.js +22 -35
  454. package/lib/components/scrollbar/src/bar2.js.map +1 -1
  455. package/lib/components/scrollbar/src/scrollbar2.js +1 -1
  456. package/lib/components/select/index.d.ts +5 -5
  457. package/lib/components/select/src/select.vue.d.ts +5 -5
  458. package/lib/components/select/src/useSelect.d.ts +5 -5
  459. package/lib/components/select-v2/index.d.ts +10 -10
  460. package/lib/components/select-v2/src/option-item.vue.d.ts +1 -1
  461. package/lib/components/select-v2/src/select.vue.d.ts +5 -5
  462. package/lib/components/select-v2/src/useSelect.d.ts +5 -5
  463. package/lib/components/skeleton/index.js +2 -2
  464. package/lib/components/skeleton/src/skeleton.js +49 -22
  465. package/lib/components/skeleton/src/skeleton.js.map +1 -1
  466. package/lib/components/skeleton/src/skeleton2.js +22 -49
  467. package/lib/components/skeleton/src/skeleton2.js.map +1 -1
  468. package/lib/components/switch/index.js +2 -2
  469. package/lib/components/switch/src/switch.js +81 -176
  470. package/lib/components/switch/src/switch.js.map +1 -1
  471. package/lib/components/switch/src/switch2.js +176 -81
  472. package/lib/components/switch/src/switch2.js.map +1 -1
  473. package/lib/components/table/index.d.ts +39 -86
  474. package/lib/components/table/src/config.js +3 -0
  475. package/lib/components/table/src/config.js.map +1 -1
  476. package/lib/components/table/src/filter-panel.js +7 -0
  477. package/lib/components/table/src/filter-panel.js.map +1 -1
  478. package/lib/components/table/src/filter-panel.vue.d.ts +5 -5
  479. package/lib/components/table/src/store/current.js +14 -12
  480. package/lib/components/table/src/store/current.js.map +1 -1
  481. package/lib/components/table/src/store/helper.js +5 -1
  482. package/lib/components/table/src/store/helper.js.map +1 -1
  483. package/lib/components/table/src/store/index.js +8 -8
  484. package/lib/components/table/src/store/index.js.map +1 -1
  485. package/lib/components/table/src/store/watcher.js +11 -1
  486. package/lib/components/table/src/store/watcher.js.map +1 -1
  487. package/lib/components/table/src/table/defaults.d.ts +8 -4
  488. package/lib/components/table/src/table/defaults.js +3 -4
  489. package/lib/components/table/src/table/defaults.js.map +1 -1
  490. package/lib/components/table/src/table/style-helper.d.ts +24 -34
  491. package/lib/components/table/src/table/style-helper.js +106 -119
  492. package/lib/components/table/src/table/style-helper.js.map +1 -1
  493. package/lib/components/table/src/table/utils-helper.d.ts +1 -1
  494. package/lib/components/table/src/table/utils-helper.js.map +1 -1
  495. package/lib/components/table/src/table-body/events-helper.d.ts +1 -3
  496. package/lib/components/table/src/table-body/events-helper.js +3 -3
  497. package/lib/components/table/src/table-body/events-helper.js.map +1 -1
  498. package/lib/components/table/src/table-body/index.js +0 -4
  499. package/lib/components/table/src/table-body/index.js.map +1 -1
  500. package/lib/components/table/src/table-body/render-helper.js +6 -3
  501. package/lib/components/table/src/table-body/render-helper.js.map +1 -1
  502. package/lib/components/table/src/table-body/styles-helper.d.ts +1 -1
  503. package/lib/components/table/src/table-body/styles-helper.js +3 -3
  504. package/lib/components/table/src/table-body/styles-helper.js.map +1 -1
  505. package/lib/components/table/src/table-column/render-helper.js +4 -2
  506. package/lib/components/table/src/table-column/render-helper.js.map +1 -1
  507. package/lib/components/table/src/table-header/event-helper.js +5 -9
  508. package/lib/components/table/src/table-header/event-helper.js.map +1 -1
  509. package/lib/components/table/src/table-header/index.js +1 -2
  510. package/lib/components/table/src/table-header/index.js.map +1 -1
  511. package/lib/components/table/src/table-header/style.helper.js +2 -2
  512. package/lib/components/table/src/table-header/style.helper.js.map +1 -1
  513. package/lib/components/table/src/table-layout.d.ts +1 -6
  514. package/lib/components/table/src/table-layout.js +0 -64
  515. package/lib/components/table/src/table-layout.js.map +1 -1
  516. package/lib/components/table/src/table.js +31 -35
  517. package/lib/components/table/src/table.js.map +1 -1
  518. package/lib/components/table/src/table.vue.d.ts +39 -86
  519. package/lib/components/table/src/util.d.ts +7 -7
  520. package/lib/components/table/src/util.js +68 -52
  521. package/lib/components/table/src/util.js.map +1 -1
  522. package/lib/components/table-v2/src/components/header.d.ts +1 -1
  523. package/lib/components/table-v2/src/table-grid.d.ts +1 -1
  524. package/lib/components/table-v2/src/table-v2.d.ts +1 -1
  525. package/lib/components/tabs/index.js +2 -2
  526. package/lib/components/tabs/src/tab-pane.js +61 -15
  527. package/lib/components/tabs/src/tab-pane.js.map +1 -1
  528. package/lib/components/tabs/src/tab-pane2.js +15 -61
  529. package/lib/components/tabs/src/tab-pane2.js.map +1 -1
  530. package/lib/components/teleport/index.js +2 -2
  531. package/lib/components/teleport/src/teleport.js +18 -43
  532. package/lib/components/teleport/src/teleport.js.map +1 -1
  533. package/lib/components/teleport/src/teleport2.js +43 -18
  534. package/lib/components/teleport/src/teleport2.js.map +1 -1
  535. package/lib/components/time-picker/src/common/picker.vue.d.ts +5 -5
  536. package/lib/components/tooltip/index.d.ts +3 -3
  537. package/lib/components/tooltip/src/tooltip.d.ts +1 -1
  538. package/lib/components/tooltip/src/tooltip.js +1 -1
  539. package/lib/components/tooltip/src/tooltip.vue.d.ts +3 -3
  540. package/lib/components/tooltip/src/trigger.vue.d.ts +3 -3
  541. package/lib/components/tooltip-v2/index.js +1 -1
  542. package/lib/components/tooltip-v2/src/tooltip.js +1 -1
  543. package/lib/components/tooltip-v2/src/tooltip2.js +2 -2
  544. package/lib/components/tooltip-v2/src/trigger.js +89 -11
  545. package/lib/components/tooltip-v2/src/trigger.js.map +1 -1
  546. package/lib/components/tooltip-v2/src/trigger2.js +11 -89
  547. package/lib/components/tooltip-v2/src/trigger2.js.map +1 -1
  548. package/lib/components/upload/index.js +4 -4
  549. package/lib/components/upload/src/upload-content.js +15 -46
  550. package/lib/components/upload/src/upload-content.js.map +1 -1
  551. package/lib/components/upload/src/upload-content2.js +46 -15
  552. package/lib/components/upload/src/upload-content2.js.map +1 -1
  553. package/lib/components/upload/src/upload-list.js +155 -27
  554. package/lib/components/upload/src/upload-list.js.map +1 -1
  555. package/lib/components/upload/src/upload-list2.js +27 -155
  556. package/lib/components/upload/src/upload-list2.js.map +1 -1
  557. package/lib/components/upload/src/upload.js +99 -109
  558. package/lib/components/upload/src/upload.js.map +1 -1
  559. package/lib/components/upload/src/upload2.js +109 -99
  560. package/lib/components/upload/src/upload2.js.map +1 -1
  561. package/lib/index.js +34 -34
  562. package/lib/version.d.ts +1 -1
  563. package/lib/version.js +1 -1
  564. package/lib/version.js.map +1 -1
  565. package/package.json +1 -1
  566. package/web-types.json +1 -1
@@ -1,177 +1,52 @@
1
- import { defineComponent, useSlots, inject, ref, computed, reactive, toRefs, provide, openBlock, createElementBlock, normalizeClass, unref, createVNode, withCtx, normalizeStyle, renderSlot, createTextVNode, toDisplayString, createCommentVNode, createElementVNode, Transition } from 'vue';
2
- import { refDebounced, isBoolean } from '@vueuse/core';
1
+ import '../../../constants/index.mjs';
3
2
  import '../../../utils/index.mjs';
4
- import '../../../tokens/index.mjs';
5
- import '../../../hooks/index.mjs';
6
- import { formItemProps } from './form-item2.mjs';
7
- import FormLabelWrap from './form-label-wrap.mjs';
8
- import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
9
- import { formContextKey, formItemContextKey } from '../../../tokens/form.mjs';
10
- import { useSize } from '../../../hooks/use-common-props/index.mjs';
11
- import { useNamespace } from '../../../hooks/use-namespace/index.mjs';
12
- import { addUnit } from '../../../utils/dom/style.mjs';
13
- import { isString } from '@vue/shared';
14
- import { getProp } from '../../../utils/objects.mjs';
15
- import { castArray } from 'lodash-unified';
3
+ import { buildProps, definePropType } from '../../../utils/vue/props.mjs';
4
+ import { componentSizes } from '../../../constants/size.mjs';
16
5
 
17
- const _hoisted_1 = ["widget"];
18
- const _hoisted_2 = ["for", "widget"];
19
- const _hoisted_3 = ["widget"];
20
- const __default__ = {
21
- name: "PsFormItem"
22
- };
23
- const _sfc_main = /* @__PURE__ */ defineComponent({
24
- ...__default__,
25
- props: formItemProps,
26
- setup(__props, { expose }) {
27
- const props = __props;
28
- const slots = useSlots();
29
- const formContext = inject(formContextKey, void 0);
30
- const parentFormItemContext = inject(formItemContextKey, void 0);
31
- const _size = useSize(void 0, { formItem: false });
32
- const ns = useNamespace("form-item");
33
- const validateState = ref("");
34
- const validateStateDebounced = refDebounced(validateState, 100);
35
- const validateMessage = ref("");
36
- const formItemRef = ref();
37
- const initialValue = void 0;
38
- const labelStyle = computed(() => {
39
- if ((formContext == null ? void 0 : formContext.labelPosition) === "top") {
40
- return {};
41
- }
42
- const labelWidth = addUnit(props.labelWidth || (formContext == null ? void 0 : formContext.labelWidth) || "");
43
- if (labelWidth)
44
- return { width: labelWidth };
45
- return {};
46
- });
47
- const contentStyle = computed(() => {
48
- if ((formContext == null ? void 0 : formContext.labelPosition) === "top" || (formContext == null ? void 0 : formContext.inline)) {
49
- return {};
50
- }
51
- if (!props.label && !props.labelWidth && isNested) {
52
- return {};
53
- }
54
- const labelWidth = addUnit(props.labelWidth || (formContext == null ? void 0 : formContext.labelWidth) || "");
55
- if (!props.label && !slots.label) {
56
- return { marginLeft: labelWidth };
57
- }
58
- return {};
59
- });
60
- const formItemClasses = computed(() => [
61
- ns.b(),
62
- ns.m(_size.value),
63
- ns.is("error", validateState.value === "error"),
64
- ns.is("validating", validateState.value === "validating"),
65
- ns.is("success", validateState.value === "success"),
66
- ns.is("required", isRequired.value || props.required),
67
- ns.is("no-asterisk", formContext == null ? void 0 : formContext.hideRequiredAsterisk),
68
- { [ns.m("feedback")]: formContext == null ? void 0 : formContext.statusIcon }
69
- ]);
70
- const _inlineMessage = computed(() => isBoolean(props.inlineMessage) ? props.inlineMessage : (formContext == null ? void 0 : formContext.inlineMessage) || false);
71
- const validateClasses = computed(() => [
72
- ns.e("error"),
73
- { [ns.em("error", "inline")]: _inlineMessage.value }
74
- ]);
75
- const propString = computed(() => {
76
- if (!props.prop)
77
- return "";
78
- return isString(props.prop) ? props.prop : props.prop.join(".");
79
- });
80
- const labelFor = computed(() => props.for || propString.value);
81
- const isNested = !!parentFormItemContext;
82
- const fieldValue = computed(() => {
83
- const model = formContext == null ? void 0 : formContext.model;
84
- if (!model || !props.prop) {
85
- return;
86
- }
87
- return getProp(model, props.prop).value;
88
- });
89
- const _rules = computed(() => {
90
- const rules = props.rules ? castArray(props.rules) : [];
91
- const formRules = formContext == null ? void 0 : formContext.rules;
92
- if (formRules && props.prop) {
93
- const _rules2 = getProp(formRules, props.prop).value;
94
- if (_rules2) {
95
- rules.push(...castArray(_rules2));
96
- }
97
- }
98
- if (props.required !== void 0) {
99
- rules.push({ required: !!props.required });
100
- }
101
- return rules;
102
- });
103
- const isRequired = computed(() => _rules.value.some((rule) => rule.required === true));
104
- const shouldShowError = computed(() => {
105
- var _a;
106
- return validateStateDebounced.value === "error" && props.showMessage && ((_a = formContext == null ? void 0 : formContext.showMessage) != null ? _a : true);
107
- });
108
- const currentLabel = computed(() => `${props.label || ""}${(formContext == null ? void 0 : formContext.labelSuffix) || ""}`);
109
- const context = reactive({
110
- ...toRefs(props),
111
- $el: formItemRef,
112
- size: _size,
113
- validateState
114
- });
115
- provide(formItemContextKey, context);
116
- expose({
117
- size: _size,
118
- validateMessage,
119
- validateState
120
- });
121
- return (_ctx, _cache) => {
122
- var _a;
123
- return openBlock(), createElementBlock("div", {
124
- ref_key: "formItemRef",
125
- ref: formItemRef,
126
- class: normalizeClass(unref(formItemClasses)),
127
- widget: _ctx.widget
128
- }, [
129
- createVNode(unref(FormLabelWrap), {
130
- "is-auto-width": unref(labelStyle).width === "auto",
131
- "update-all": ((_a = unref(formContext)) == null ? void 0 : _a.labelWidth) === "auto"
132
- }, {
133
- default: withCtx(() => [
134
- _ctx.label || _ctx.$slots.label ? (openBlock(), createElementBlock("label", {
135
- key: 0,
136
- for: unref(labelFor),
137
- class: normalizeClass(unref(ns).e("label")),
138
- style: normalizeStyle(unref(labelStyle)),
139
- widget: _ctx.widget ? "form-item:label:" + _ctx.widget.split(":")[1] : void 0
140
- }, [
141
- renderSlot(_ctx.$slots, "label", { label: unref(currentLabel) }, () => [
142
- createTextVNode(toDisplayString(unref(currentLabel)), 1)
143
- ])
144
- ], 14, _hoisted_2)) : createCommentVNode("v-if", true)
145
- ]),
146
- _: 3
147
- }, 8, ["is-auto-width", "update-all"]),
148
- createElementVNode("div", {
149
- class: normalizeClass(unref(ns).e("content")),
150
- style: normalizeStyle(unref(contentStyle)),
151
- widget: _ctx.widget ? "form-item:default:" + _ctx.widget.split(":")[1] : void 0
152
- }, [
153
- renderSlot(_ctx.$slots, "default"),
154
- createVNode(Transition, {
155
- name: `${unref(ns).namespace.value}-zoom-in-top`
156
- }, {
157
- default: withCtx(() => [
158
- unref(shouldShowError) ? renderSlot(_ctx.$slots, "error", {
159
- key: 0,
160
- error: validateMessage.value
161
- }, () => [
162
- createElementVNode("div", {
163
- class: normalizeClass(unref(validateClasses))
164
- }, toDisplayString(validateMessage.value), 3)
165
- ]) : createCommentVNode("v-if", true)
166
- ]),
167
- _: 3
168
- }, 8, ["name"])
169
- ], 14, _hoisted_3)
170
- ], 10, _hoisted_1);
171
- };
6
+ const formItemValidateStates = [
7
+ "",
8
+ "error",
9
+ "validating",
10
+ "success"
11
+ ];
12
+ const formItemProps = buildProps({
13
+ label: String,
14
+ labelWidth: {
15
+ type: [String, Number],
16
+ default: ""
17
+ },
18
+ prop: {
19
+ type: definePropType([String, Array])
20
+ },
21
+ required: {
22
+ type: Boolean,
23
+ default: void 0
24
+ },
25
+ rules: {
26
+ type: definePropType([Object, Array])
27
+ },
28
+ error: String,
29
+ validateStatus: {
30
+ type: String,
31
+ values: formItemValidateStates
32
+ },
33
+ for: String,
34
+ inlineMessage: {
35
+ type: [String, Boolean],
36
+ default: ""
37
+ },
38
+ showMessage: {
39
+ type: Boolean,
40
+ default: true
41
+ },
42
+ size: {
43
+ type: String,
44
+ values: componentSizes
45
+ },
46
+ widget: {
47
+ type: String
172
48
  }
173
49
  });
174
- var FormItem = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "/Users/meng/workspace/element-ps/packages/components/form/src/form-item.vue"]]);
175
50
 
176
- export { FormItem as default };
51
+ export { formItemProps, formItemValidateStates };
177
52
  //# sourceMappingURL=form-item.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"form-item.mjs","sources":["../../../../../../packages/components/form/src/form-item.vue"],"sourcesContent":["<template>\n <div ref=\"formItemRef\" :class=\"formItemClasses\" :widget=\"widget\">\n <form-label-wrap\n :is-auto-width=\"labelStyle.width === 'auto'\"\n :update-all=\"formContext?.labelWidth === 'auto'\"\n >\n <label\n v-if=\"label || $slots.label\"\n :for=\"labelFor\"\n :class=\"ns.e('label')\"\n :style=\"labelStyle\"\n :widget=\"widget ? 'form-item:label:' + widget.split(':')[1] : undefined\"\n >\n <slot name=\"label\" :label=\"currentLabel\">\n {{ currentLabel }}\n </slot>\n </label>\n </form-label-wrap>\n\n <div\n :class=\"ns.e('content')\"\n :style=\"contentStyle\"\n :widget=\"widget ? 'form-item:default:' + widget.split(':')[1] : undefined\"\n >\n <slot />\n <transition :name=\"`${ns.namespace.value}-zoom-in-top`\">\n <slot v-if=\"shouldShowError\" name=\"error\" :error=\"validateMessage\">\n <div :class=\"validateClasses\">\n {{ validateMessage }}\n </div>\n </slot>\n </transition>\n </div>\n </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport {\n computed,\n inject,\n onBeforeUnmount,\n onMounted,\n provide,\n reactive,\n ref,\n toRefs,\n useSlots,\n} from 'vue'\nimport { clone } from 'lodash-unified'\nimport { refDebounced } from '@vueuse/core'\nimport {\n addUnit,\n ensureArray,\n getProp,\n isBoolean,\n isString,\n} from '@element-ps/utils'\nimport { formContextKey, formItemContextKey } from '@element-ps/tokens'\nimport { useNamespace, useSize } from '@element-ps/hooks'\nimport { formItemProps } from './form-item'\nimport FormLabelWrap from './form-label-wrap'\n\nimport type { CSSProperties } from 'vue'\nimport type { FormItemContext, FormItemRule } from '@element-ps/tokens'\nimport type { Arrayable } from '@element-ps/utils'\nimport type { FormItemValidateState } from './form-item'\n\ndefineOptions({\n name: 'PsFormItem',\n})\nconst props = defineProps(formItemProps)\nconst slots = useSlots()\n\nconst formContext = inject(formContextKey, undefined)\nconst parentFormItemContext = inject(formItemContextKey, undefined)\n\nconst _size = useSize(undefined, { formItem: false })\nconst ns = useNamespace('form-item')\n\nconst validateState = ref<FormItemValidateState>('')\nconst validateStateDebounced = refDebounced(validateState, 100)\nconst validateMessage = ref('')\nconst formItemRef = ref<HTMLDivElement>()\n// special inline value.\nconst initialValue: any = undefined\n\nconst labelStyle = computed<CSSProperties>(() => {\n if (formContext?.labelPosition === 'top') {\n return {}\n }\n\n const labelWidth = addUnit(props.labelWidth || formContext?.labelWidth || '')\n if (labelWidth) return { width: labelWidth }\n return {}\n})\n\nconst contentStyle = computed<CSSProperties>(() => {\n if (formContext?.labelPosition === 'top' || formContext?.inline) {\n return {}\n }\n if (!props.label && !props.labelWidth && isNested) {\n return {}\n }\n const labelWidth = addUnit(props.labelWidth || formContext?.labelWidth || '')\n if (!props.label && !slots.label) {\n return { marginLeft: labelWidth }\n }\n return {}\n})\n\nconst formItemClasses = computed(() => [\n ns.b(),\n ns.m(_size.value),\n ns.is('error', validateState.value === 'error'),\n ns.is('validating', validateState.value === 'validating'),\n ns.is('success', validateState.value === 'success'),\n ns.is('required', isRequired.value || props.required),\n ns.is('no-asterisk', formContext?.hideRequiredAsterisk),\n { [ns.m('feedback')]: formContext?.statusIcon },\n])\n\nconst _inlineMessage = computed(() =>\n isBoolean(props.inlineMessage)\n ? props.inlineMessage\n : formContext?.inlineMessage || false\n)\n\nconst validateClasses = computed(() => [\n ns.e('error'),\n { [ns.em('error', 'inline')]: _inlineMessage.value },\n])\n\nconst propString = computed(() => {\n if (!props.prop) return ''\n return isString(props.prop) ? props.prop : props.prop.join('.')\n})\n\nconst labelFor = computed(() => props.for || propString.value)\n\nconst isNested = !!parentFormItemContext\n\nconst fieldValue = computed(() => {\n const model = formContext?.model\n if (!model || !props.prop) {\n return\n }\n return getProp(model, props.prop).value\n})\n\nconst _rules = computed(() => {\n const rules: FormItemRule[] = props.rules ? ensureArray(props.rules) : []\n\n const formRules = formContext?.rules\n if (formRules && props.prop) {\n const _rules = getProp<Arrayable<FormItemRule> | undefined>(\n formRules,\n props.prop\n ).value\n if (_rules) {\n rules.push(...ensureArray(_rules))\n }\n }\n\n if (props.required !== undefined) {\n rules.push({ required: !!props.required })\n }\n\n return rules\n})\n\nconst isRequired = computed(() =>\n _rules.value.some((rule) => rule.required === true)\n)\n\nconst shouldShowError = computed(\n () =>\n validateStateDebounced.value === 'error' &&\n props.showMessage &&\n (formContext?.showMessage ?? true)\n)\n\nconst currentLabel = computed(\n () => `${props.label || ''}${formContext?.labelSuffix || ''}`\n)\n\nconst context: FormItemContext = reactive({\n ...toRefs(props),\n $el: formItemRef,\n size: _size,\n validateState,\n})\n\nprovide(formItemContextKey, context)\n\ndefineExpose({\n /** @description form item size */\n size: _size,\n /** @description validation message */\n validateMessage,\n /** @description validation state */\n validateState,\n})\n</script>\n"],"names":["ensureArray"],"mappings":"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"}
1
+ {"version":3,"file":"form-item.mjs","sources":["../../../../../../packages/components/form/src/form-item.ts"],"sourcesContent":["import { componentSizes } from '@element-ps/constants'\nimport { buildProps, definePropType } from '@element-ps/utils'\n\nimport type { ExtractPropTypes } from 'vue'\nimport type { Arrayable } from '@element-ps/utils'\nimport type { FormItemRule } from '@element-ps/tokens'\n\nexport const formItemValidateStates = [\n '',\n 'error',\n 'validating',\n 'success',\n] as const\nexport type FormItemValidateState = typeof formItemValidateStates[number]\n\nexport type FormItemProp = Arrayable<string>\n\nexport const formItemProps = buildProps({\n label: String,\n labelWidth: {\n type: [String, Number],\n default: '',\n },\n prop: {\n type: definePropType<FormItemProp>([String, Array]),\n },\n required: {\n type: Boolean,\n default: undefined,\n },\n rules: {\n type: definePropType<Arrayable<FormItemRule>>([Object, Array]),\n },\n error: String,\n validateStatus: {\n type: String,\n values: formItemValidateStates,\n },\n for: String,\n inlineMessage: {\n type: [String, Boolean],\n default: '',\n },\n showMessage: {\n type: Boolean,\n default: true,\n },\n size: {\n type: String,\n values: componentSizes,\n },\n widget: {\n type: String,\n },\n} as const)\nexport type FormItemProps = ExtractPropTypes<typeof formItemProps>\n"],"names":[],"mappings":";;;;;AAEY,MAAC,sBAAsB,GAAG;AACtC,EAAE,EAAE;AACJ,EAAE,OAAO;AACT,EAAE,YAAY;AACd,EAAE,SAAS;AACX,EAAE;AACU,MAAC,aAAa,GAAG,UAAU,CAAC;AACxC,EAAE,KAAK,EAAE,MAAM;AACf,EAAE,UAAU,EAAE;AACd,IAAI,IAAI,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;AAC1B,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,EAAE,IAAI,EAAE;AACR,IAAI,IAAI,EAAE,cAAc,CAAC,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;AACzC,GAAG;AACH,EAAE,QAAQ,EAAE;AACZ,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,KAAK,CAAC;AACnB,GAAG;AACH,EAAE,KAAK,EAAE;AACT,IAAI,IAAI,EAAE,cAAc,CAAC,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;AACzC,GAAG;AACH,EAAE,KAAK,EAAE,MAAM;AACf,EAAE,cAAc,EAAE;AAClB,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,MAAM,EAAE,sBAAsB;AAClC,GAAG;AACH,EAAE,GAAG,EAAE,MAAM;AACb,EAAE,aAAa,EAAE;AACjB,IAAI,IAAI,EAAE,CAAC,MAAM,EAAE,OAAO,CAAC;AAC3B,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,EAAE,WAAW,EAAE;AACf,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,IAAI,EAAE;AACR,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,MAAM,EAAE,cAAc;AAC1B,GAAG;AACH,EAAE,MAAM,EAAE;AACV,IAAI,IAAI,EAAE,MAAM;AAChB,GAAG;AACH,CAAC;;;;"}
@@ -1,52 +1,177 @@
1
- import '../../../constants/index.mjs';
1
+ import { defineComponent, useSlots, inject, ref, computed, reactive, toRefs, provide, openBlock, createElementBlock, normalizeClass, unref, createVNode, withCtx, normalizeStyle, renderSlot, createTextVNode, toDisplayString, createCommentVNode, createElementVNode, Transition } from 'vue';
2
+ import { refDebounced, isBoolean } from '@vueuse/core';
2
3
  import '../../../utils/index.mjs';
3
- import { buildProps, definePropType } from '../../../utils/vue/props.mjs';
4
- import { componentSizes } from '../../../constants/size.mjs';
4
+ import '../../../tokens/index.mjs';
5
+ import '../../../hooks/index.mjs';
6
+ import { formItemProps } from './form-item.mjs';
7
+ import FormLabelWrap from './form-label-wrap.mjs';
8
+ import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
9
+ import { formContextKey, formItemContextKey } from '../../../tokens/form.mjs';
10
+ import { useSize } from '../../../hooks/use-common-props/index.mjs';
11
+ import { useNamespace } from '../../../hooks/use-namespace/index.mjs';
12
+ import { addUnit } from '../../../utils/dom/style.mjs';
13
+ import { isString } from '@vue/shared';
14
+ import { getProp } from '../../../utils/objects.mjs';
15
+ import { castArray } from 'lodash-unified';
5
16
 
6
- const formItemValidateStates = [
7
- "",
8
- "error",
9
- "validating",
10
- "success"
11
- ];
12
- const formItemProps = buildProps({
13
- label: String,
14
- labelWidth: {
15
- type: [String, Number],
16
- default: ""
17
- },
18
- prop: {
19
- type: definePropType([String, Array])
20
- },
21
- required: {
22
- type: Boolean,
23
- default: void 0
24
- },
25
- rules: {
26
- type: definePropType([Object, Array])
27
- },
28
- error: String,
29
- validateStatus: {
30
- type: String,
31
- values: formItemValidateStates
32
- },
33
- for: String,
34
- inlineMessage: {
35
- type: [String, Boolean],
36
- default: ""
37
- },
38
- showMessage: {
39
- type: Boolean,
40
- default: true
41
- },
42
- size: {
43
- type: String,
44
- values: componentSizes
45
- },
46
- widget: {
47
- type: String
17
+ const _hoisted_1 = ["widget"];
18
+ const _hoisted_2 = ["for", "widget"];
19
+ const _hoisted_3 = ["widget"];
20
+ const __default__ = {
21
+ name: "PsFormItem"
22
+ };
23
+ const _sfc_main = /* @__PURE__ */ defineComponent({
24
+ ...__default__,
25
+ props: formItemProps,
26
+ setup(__props, { expose }) {
27
+ const props = __props;
28
+ const slots = useSlots();
29
+ const formContext = inject(formContextKey, void 0);
30
+ const parentFormItemContext = inject(formItemContextKey, void 0);
31
+ const _size = useSize(void 0, { formItem: false });
32
+ const ns = useNamespace("form-item");
33
+ const validateState = ref("");
34
+ const validateStateDebounced = refDebounced(validateState, 100);
35
+ const validateMessage = ref("");
36
+ const formItemRef = ref();
37
+ const initialValue = void 0;
38
+ const labelStyle = computed(() => {
39
+ if ((formContext == null ? void 0 : formContext.labelPosition) === "top") {
40
+ return {};
41
+ }
42
+ const labelWidth = addUnit(props.labelWidth || (formContext == null ? void 0 : formContext.labelWidth) || "");
43
+ if (labelWidth)
44
+ return { width: labelWidth };
45
+ return {};
46
+ });
47
+ const contentStyle = computed(() => {
48
+ if ((formContext == null ? void 0 : formContext.labelPosition) === "top" || (formContext == null ? void 0 : formContext.inline)) {
49
+ return {};
50
+ }
51
+ if (!props.label && !props.labelWidth && isNested) {
52
+ return {};
53
+ }
54
+ const labelWidth = addUnit(props.labelWidth || (formContext == null ? void 0 : formContext.labelWidth) || "");
55
+ if (!props.label && !slots.label) {
56
+ return { marginLeft: labelWidth };
57
+ }
58
+ return {};
59
+ });
60
+ const formItemClasses = computed(() => [
61
+ ns.b(),
62
+ ns.m(_size.value),
63
+ ns.is("error", validateState.value === "error"),
64
+ ns.is("validating", validateState.value === "validating"),
65
+ ns.is("success", validateState.value === "success"),
66
+ ns.is("required", isRequired.value || props.required),
67
+ ns.is("no-asterisk", formContext == null ? void 0 : formContext.hideRequiredAsterisk),
68
+ { [ns.m("feedback")]: formContext == null ? void 0 : formContext.statusIcon }
69
+ ]);
70
+ const _inlineMessage = computed(() => isBoolean(props.inlineMessage) ? props.inlineMessage : (formContext == null ? void 0 : formContext.inlineMessage) || false);
71
+ const validateClasses = computed(() => [
72
+ ns.e("error"),
73
+ { [ns.em("error", "inline")]: _inlineMessage.value }
74
+ ]);
75
+ const propString = computed(() => {
76
+ if (!props.prop)
77
+ return "";
78
+ return isString(props.prop) ? props.prop : props.prop.join(".");
79
+ });
80
+ const labelFor = computed(() => props.for || propString.value);
81
+ const isNested = !!parentFormItemContext;
82
+ const fieldValue = computed(() => {
83
+ const model = formContext == null ? void 0 : formContext.model;
84
+ if (!model || !props.prop) {
85
+ return;
86
+ }
87
+ return getProp(model, props.prop).value;
88
+ });
89
+ const _rules = computed(() => {
90
+ const rules = props.rules ? castArray(props.rules) : [];
91
+ const formRules = formContext == null ? void 0 : formContext.rules;
92
+ if (formRules && props.prop) {
93
+ const _rules2 = getProp(formRules, props.prop).value;
94
+ if (_rules2) {
95
+ rules.push(...castArray(_rules2));
96
+ }
97
+ }
98
+ if (props.required !== void 0) {
99
+ rules.push({ required: !!props.required });
100
+ }
101
+ return rules;
102
+ });
103
+ const isRequired = computed(() => _rules.value.some((rule) => rule.required === true));
104
+ const shouldShowError = computed(() => {
105
+ var _a;
106
+ return validateStateDebounced.value === "error" && props.showMessage && ((_a = formContext == null ? void 0 : formContext.showMessage) != null ? _a : true);
107
+ });
108
+ const currentLabel = computed(() => `${props.label || ""}${(formContext == null ? void 0 : formContext.labelSuffix) || ""}`);
109
+ const context = reactive({
110
+ ...toRefs(props),
111
+ $el: formItemRef,
112
+ size: _size,
113
+ validateState
114
+ });
115
+ provide(formItemContextKey, context);
116
+ expose({
117
+ size: _size,
118
+ validateMessage,
119
+ validateState
120
+ });
121
+ return (_ctx, _cache) => {
122
+ var _a;
123
+ return openBlock(), createElementBlock("div", {
124
+ ref_key: "formItemRef",
125
+ ref: formItemRef,
126
+ class: normalizeClass(unref(formItemClasses)),
127
+ widget: _ctx.widget
128
+ }, [
129
+ createVNode(unref(FormLabelWrap), {
130
+ "is-auto-width": unref(labelStyle).width === "auto",
131
+ "update-all": ((_a = unref(formContext)) == null ? void 0 : _a.labelWidth) === "auto"
132
+ }, {
133
+ default: withCtx(() => [
134
+ _ctx.label || _ctx.$slots.label ? (openBlock(), createElementBlock("label", {
135
+ key: 0,
136
+ for: unref(labelFor),
137
+ class: normalizeClass(unref(ns).e("label")),
138
+ style: normalizeStyle(unref(labelStyle)),
139
+ widget: _ctx.widget ? "form-item:label:" + _ctx.widget.split(":")[1] : void 0
140
+ }, [
141
+ renderSlot(_ctx.$slots, "label", { label: unref(currentLabel) }, () => [
142
+ createTextVNode(toDisplayString(unref(currentLabel)), 1)
143
+ ])
144
+ ], 14, _hoisted_2)) : createCommentVNode("v-if", true)
145
+ ]),
146
+ _: 3
147
+ }, 8, ["is-auto-width", "update-all"]),
148
+ createElementVNode("div", {
149
+ class: normalizeClass(unref(ns).e("content")),
150
+ style: normalizeStyle(unref(contentStyle)),
151
+ widget: _ctx.widget ? "form-item:default:" + _ctx.widget.split(":")[1] : void 0
152
+ }, [
153
+ renderSlot(_ctx.$slots, "default"),
154
+ createVNode(Transition, {
155
+ name: `${unref(ns).namespace.value}-zoom-in-top`
156
+ }, {
157
+ default: withCtx(() => [
158
+ unref(shouldShowError) ? renderSlot(_ctx.$slots, "error", {
159
+ key: 0,
160
+ error: validateMessage.value
161
+ }, () => [
162
+ createElementVNode("div", {
163
+ class: normalizeClass(unref(validateClasses))
164
+ }, toDisplayString(validateMessage.value), 3)
165
+ ]) : createCommentVNode("v-if", true)
166
+ ]),
167
+ _: 3
168
+ }, 8, ["name"])
169
+ ], 14, _hoisted_3)
170
+ ], 10, _hoisted_1);
171
+ };
48
172
  }
49
173
  });
174
+ var FormItem = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "/Users/meng/workspace/element-ps/packages/components/form/src/form-item.vue"]]);
50
175
 
51
- export { formItemProps, formItemValidateStates };
176
+ export { FormItem as default };
52
177
  //# sourceMappingURL=form-item2.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"form-item2.mjs","sources":["../../../../../../packages/components/form/src/form-item.ts"],"sourcesContent":["import { componentSizes } from '@element-ps/constants'\nimport { buildProps, definePropType } from '@element-ps/utils'\n\nimport type { ExtractPropTypes } from 'vue'\nimport type { Arrayable } from '@element-ps/utils'\nimport type { FormItemRule } from '@element-ps/tokens'\n\nexport const formItemValidateStates = [\n '',\n 'error',\n 'validating',\n 'success',\n] as const\nexport type FormItemValidateState = typeof formItemValidateStates[number]\n\nexport type FormItemProp = Arrayable<string>\n\nexport const formItemProps = buildProps({\n label: String,\n labelWidth: {\n type: [String, Number],\n default: '',\n },\n prop: {\n type: definePropType<FormItemProp>([String, Array]),\n },\n required: {\n type: Boolean,\n default: undefined,\n },\n rules: {\n type: definePropType<Arrayable<FormItemRule>>([Object, Array]),\n },\n error: String,\n validateStatus: {\n type: String,\n values: formItemValidateStates,\n },\n for: String,\n inlineMessage: {\n type: [String, Boolean],\n default: '',\n },\n showMessage: {\n type: Boolean,\n default: true,\n },\n size: {\n type: String,\n values: componentSizes,\n },\n widget: {\n type: String,\n },\n} as const)\nexport type FormItemProps = ExtractPropTypes<typeof formItemProps>\n"],"names":[],"mappings":";;;;;AAEY,MAAC,sBAAsB,GAAG;AACtC,EAAE,EAAE;AACJ,EAAE,OAAO;AACT,EAAE,YAAY;AACd,EAAE,SAAS;AACX,EAAE;AACU,MAAC,aAAa,GAAG,UAAU,CAAC;AACxC,EAAE,KAAK,EAAE,MAAM;AACf,EAAE,UAAU,EAAE;AACd,IAAI,IAAI,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;AAC1B,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,EAAE,IAAI,EAAE;AACR,IAAI,IAAI,EAAE,cAAc,CAAC,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;AACzC,GAAG;AACH,EAAE,QAAQ,EAAE;AACZ,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,KAAK,CAAC;AACnB,GAAG;AACH,EAAE,KAAK,EAAE;AACT,IAAI,IAAI,EAAE,cAAc,CAAC,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;AACzC,GAAG;AACH,EAAE,KAAK,EAAE,MAAM;AACf,EAAE,cAAc,EAAE;AAClB,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,MAAM,EAAE,sBAAsB;AAClC,GAAG;AACH,EAAE,GAAG,EAAE,MAAM;AACb,EAAE,aAAa,EAAE;AACjB,IAAI,IAAI,EAAE,CAAC,MAAM,EAAE,OAAO,CAAC;AAC3B,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,EAAE,WAAW,EAAE;AACf,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,IAAI,EAAE;AACR,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,MAAM,EAAE,cAAc;AAC1B,GAAG;AACH,EAAE,MAAM,EAAE;AACV,IAAI,IAAI,EAAE,MAAM;AAChB,GAAG;AACH,CAAC;;;;"}
1
+ {"version":3,"file":"form-item2.mjs","sources":["../../../../../../packages/components/form/src/form-item.vue"],"sourcesContent":["<template>\n <div ref=\"formItemRef\" :class=\"formItemClasses\" :widget=\"widget\">\n <form-label-wrap\n :is-auto-width=\"labelStyle.width === 'auto'\"\n :update-all=\"formContext?.labelWidth === 'auto'\"\n >\n <label\n v-if=\"label || $slots.label\"\n :for=\"labelFor\"\n :class=\"ns.e('label')\"\n :style=\"labelStyle\"\n :widget=\"widget ? 'form-item:label:' + widget.split(':')[1] : undefined\"\n >\n <slot name=\"label\" :label=\"currentLabel\">\n {{ currentLabel }}\n </slot>\n </label>\n </form-label-wrap>\n\n <div\n :class=\"ns.e('content')\"\n :style=\"contentStyle\"\n :widget=\"widget ? 'form-item:default:' + widget.split(':')[1] : undefined\"\n >\n <slot />\n <transition :name=\"`${ns.namespace.value}-zoom-in-top`\">\n <slot v-if=\"shouldShowError\" name=\"error\" :error=\"validateMessage\">\n <div :class=\"validateClasses\">\n {{ validateMessage }}\n </div>\n </slot>\n </transition>\n </div>\n </div>\n</template>\n\n<script lang=\"ts\" setup>\nimport {\n computed,\n inject,\n onBeforeUnmount,\n onMounted,\n provide,\n reactive,\n ref,\n toRefs,\n useSlots,\n} from 'vue'\nimport { clone } from 'lodash-unified'\nimport { refDebounced } from '@vueuse/core'\nimport {\n addUnit,\n ensureArray,\n getProp,\n isBoolean,\n isString,\n} from '@element-ps/utils'\nimport { formContextKey, formItemContextKey } from '@element-ps/tokens'\nimport { useNamespace, useSize } from '@element-ps/hooks'\nimport { formItemProps } from './form-item'\nimport FormLabelWrap from './form-label-wrap'\n\nimport type { CSSProperties } from 'vue'\nimport type { FormItemContext, FormItemRule } from '@element-ps/tokens'\nimport type { Arrayable } from '@element-ps/utils'\nimport type { FormItemValidateState } from './form-item'\n\ndefineOptions({\n name: 'PsFormItem',\n})\nconst props = defineProps(formItemProps)\nconst slots = useSlots()\n\nconst formContext = inject(formContextKey, undefined)\nconst parentFormItemContext = inject(formItemContextKey, undefined)\n\nconst _size = useSize(undefined, { formItem: false })\nconst ns = useNamespace('form-item')\n\nconst validateState = ref<FormItemValidateState>('')\nconst validateStateDebounced = refDebounced(validateState, 100)\nconst validateMessage = ref('')\nconst formItemRef = ref<HTMLDivElement>()\n// special inline value.\nconst initialValue: any = undefined\n\nconst labelStyle = computed<CSSProperties>(() => {\n if (formContext?.labelPosition === 'top') {\n return {}\n }\n\n const labelWidth = addUnit(props.labelWidth || formContext?.labelWidth || '')\n if (labelWidth) return { width: labelWidth }\n return {}\n})\n\nconst contentStyle = computed<CSSProperties>(() => {\n if (formContext?.labelPosition === 'top' || formContext?.inline) {\n return {}\n }\n if (!props.label && !props.labelWidth && isNested) {\n return {}\n }\n const labelWidth = addUnit(props.labelWidth || formContext?.labelWidth || '')\n if (!props.label && !slots.label) {\n return { marginLeft: labelWidth }\n }\n return {}\n})\n\nconst formItemClasses = computed(() => [\n ns.b(),\n ns.m(_size.value),\n ns.is('error', validateState.value === 'error'),\n ns.is('validating', validateState.value === 'validating'),\n ns.is('success', validateState.value === 'success'),\n ns.is('required', isRequired.value || props.required),\n ns.is('no-asterisk', formContext?.hideRequiredAsterisk),\n { [ns.m('feedback')]: formContext?.statusIcon },\n])\n\nconst _inlineMessage = computed(() =>\n isBoolean(props.inlineMessage)\n ? props.inlineMessage\n : formContext?.inlineMessage || false\n)\n\nconst validateClasses = computed(() => [\n ns.e('error'),\n { [ns.em('error', 'inline')]: _inlineMessage.value },\n])\n\nconst propString = computed(() => {\n if (!props.prop) return ''\n return isString(props.prop) ? props.prop : props.prop.join('.')\n})\n\nconst labelFor = computed(() => props.for || propString.value)\n\nconst isNested = !!parentFormItemContext\n\nconst fieldValue = computed(() => {\n const model = formContext?.model\n if (!model || !props.prop) {\n return\n }\n return getProp(model, props.prop).value\n})\n\nconst _rules = computed(() => {\n const rules: FormItemRule[] = props.rules ? ensureArray(props.rules) : []\n\n const formRules = formContext?.rules\n if (formRules && props.prop) {\n const _rules = getProp<Arrayable<FormItemRule> | undefined>(\n formRules,\n props.prop\n ).value\n if (_rules) {\n rules.push(...ensureArray(_rules))\n }\n }\n\n if (props.required !== undefined) {\n rules.push({ required: !!props.required })\n }\n\n return rules\n})\n\nconst isRequired = computed(() =>\n _rules.value.some((rule) => rule.required === true)\n)\n\nconst shouldShowError = computed(\n () =>\n validateStateDebounced.value === 'error' &&\n props.showMessage &&\n (formContext?.showMessage ?? true)\n)\n\nconst currentLabel = computed(\n () => `${props.label || ''}${formContext?.labelSuffix || ''}`\n)\n\nconst context: FormItemContext = reactive({\n ...toRefs(props),\n $el: formItemRef,\n size: _size,\n validateState,\n})\n\nprovide(formItemContextKey, context)\n\ndefineExpose({\n /** @description form item size */\n size: _size,\n /** @description validation message */\n validateMessage,\n /** @description validation state */\n validateState,\n})\n</script>\n"],"names":["ensureArray"],"mappings":"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"}
@@ -1,49 +1,44 @@
1
- import { defineComponent, computed, provide, reactive, toRefs, openBlock, createElementBlock, normalizeClass, unref, renderSlot } from 'vue';
2
- import '../../../tokens/index.mjs';
3
- import '../../../hooks/index.mjs';
4
- import { formProps } from './form2.mjs';
5
- import { useFormLabelWidth } from './utils.mjs';
6
- import _export_sfc from '../../../_virtual/plugin-vue_export-helper.mjs';
7
- import { useSize } from '../../../hooks/use-common-props/index.mjs';
8
- import { useNamespace } from '../../../hooks/use-namespace/index.mjs';
9
- import { formContextKey } from '../../../tokens/form.mjs';
1
+ import '../../../constants/index.mjs';
2
+ import '../../../utils/index.mjs';
3
+ import { buildProps, definePropType } from '../../../utils/vue/props.mjs';
4
+ import { componentSizes } from '../../../constants/size.mjs';
10
5
 
11
- const __default__ = {
12
- name: "PsForm"
13
- };
14
- const _sfc_main = /* @__PURE__ */ defineComponent({
15
- ...__default__,
16
- props: formProps,
17
- setup(__props) {
18
- const props = __props;
19
- const COMPONENT_NAME = "PsForm";
20
- const formSize = useSize();
21
- const ns = useNamespace("form");
22
- const formClasses = computed(() => {
23
- const { labelPosition, inline } = props;
24
- return [
25
- ns.b(),
26
- ns.m(formSize.value || "default"),
27
- {
28
- [ns.m(`label-${labelPosition}`)]: labelPosition,
29
- [ns.m("inline")]: inline
30
- }
31
- ];
32
- });
33
- provide(formContextKey, reactive({
34
- ...toRefs(props),
35
- ...useFormLabelWidth()
36
- }));
37
- return (_ctx, _cache) => {
38
- return openBlock(), createElementBlock("form", {
39
- class: normalizeClass(unref(formClasses))
40
- }, [
41
- renderSlot(_ctx.$slots, "default")
42
- ], 2);
43
- };
44
- }
6
+ const formProps = buildProps({
7
+ model: Object,
8
+ rules: {
9
+ type: definePropType(Object)
10
+ },
11
+ labelPosition: String,
12
+ labelWidth: {
13
+ type: [String, Number],
14
+ default: ""
15
+ },
16
+ labelSuffix: {
17
+ type: String,
18
+ default: ""
19
+ },
20
+ inline: Boolean,
21
+ inlineMessage: Boolean,
22
+ statusIcon: Boolean,
23
+ showMessage: {
24
+ type: Boolean,
25
+ default: true
26
+ },
27
+ size: {
28
+ type: String,
29
+ values: componentSizes
30
+ },
31
+ disabled: Boolean,
32
+ validateOnRuleChange: {
33
+ type: Boolean,
34
+ default: true
35
+ },
36
+ hideRequiredAsterisk: {
37
+ type: Boolean,
38
+ default: false
39
+ },
40
+ scrollToError: Boolean
45
41
  });
46
- var Form = /* @__PURE__ */ _export_sfc(_sfc_main, [["__file", "/Users/meng/workspace/element-ps/packages/components/form/src/form.vue"]]);
47
42
 
48
- export { Form as default };
43
+ export { formProps };
49
44
  //# sourceMappingURL=form.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"form.mjs","sources":["../../../../../../packages/components/form/src/form.vue"],"sourcesContent":["<template>\n <form :class=\"formClasses\">\n <slot />\n </form>\n</template>\n\n<script lang=\"ts\" setup>\nimport { computed, provide, reactive, toRefs } from 'vue'\nimport { formContextKey } from '@element-ps/tokens'\nimport { useNamespace, useSize } from '@element-ps/hooks'\nimport { formProps } from './form'\nimport { useFormLabelWidth } from './utils'\n\nconst COMPONENT_NAME = 'PsForm'\ndefineOptions({\n name: 'PsForm',\n})\nconst props = defineProps(formProps)\n\nconst formSize = useSize()\nconst ns = useNamespace('form')\nconst formClasses = computed(() => {\n const { labelPosition, inline } = props\n return [\n ns.b(),\n // todo: in v2.2.0, we can remove default\n // in fact, remove it doesn't affect the final style\n ns.m(formSize.value || 'default'),\n {\n [ns.m(`label-${labelPosition}`)]: labelPosition,\n [ns.m('inline')]: inline,\n },\n ]\n})\n\nprovide(\n formContextKey,\n reactive({\n ...toRefs(props),\n ...useFormLabelWidth(),\n })\n)\n</script>\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;AAaA,IAAA,MAAA,cAAA,GAAA,QAAA,CAAA;AAMA,IAAA,MAAA,WAAA,OAAA,EAAA,CAAA;AACA,IAAA,MAAA,EAAA,GAAA,aAAA,MAAA,CAAA,CAAA;AACA,IAAA,MAAA,WAAA,GAAA,SAAA,MAAA;AACA,MAAA,MAAA,EAAA,eAAA,MAAA,EAAA,GAAA,KAAA,CAAA;AACA,MAAA,OAAA;AAAA,QACA,GAAA,CAAA,EAAA;AAAA,QAGA,EAAA,CAAA,CAAA,CAAA,QAAA,CAAA,KAAA,IAAA,SAAA,CAAA;AAAA,QACA;AAAA,UAAA,CACA,EAAA,CAAA,CAAA,CAAA,CAAA,MAAA,EAAA,aAAA,CAAA,CAAA,CAAA,GAAA,aAAA;AAAA,UACA,CAAA,EAAA,CAAA,CAAA,CAAA,QAAA,CAAA,GAAA,MAAA;AAAA,SACA;AAAA,OACA,CAAA;AAAA,KACA,CAAA,CAAA;AAEA,IAAA,OAAA,CACA,gBACA,QAAA,CAAA;AAAA,MAAA,GACA,OAAA,KAAA,CAAA;AAAA,MAAA,GACA,iBAAA,EAAA;AAAA,KACA,CACA,CAAA,CAAA;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"form.mjs","sources":["../../../../../../packages/components/form/src/form.ts"],"sourcesContent":["import { componentSizes } from '@element-ps/constants'\nimport {\n buildProps,\n definePropType,\n} from '@element-ps/utils'\n\nimport type { ExtractPropTypes } from 'vue'\nimport type { FormRules } from '@element-ps/tokens'\n\nexport const formProps = buildProps({\n model: Object,\n rules: {\n type: definePropType<FormRules>(Object),\n },\n labelPosition: String,\n labelWidth: {\n type: [String, Number],\n default: '',\n },\n labelSuffix: {\n type: String,\n default: '',\n },\n inline: Boolean,\n inlineMessage: Boolean,\n statusIcon: Boolean,\n showMessage: {\n type: Boolean,\n default: true,\n },\n size: {\n type: String,\n values: componentSizes,\n },\n disabled: Boolean,\n validateOnRuleChange: {\n type: Boolean,\n default: true,\n },\n hideRequiredAsterisk: {\n type: Boolean,\n default: false,\n },\n scrollToError: Boolean,\n} as const)\nexport type FormProps = ExtractPropTypes<typeof formProps>\n"],"names":[],"mappings":";;;;;AAKY,MAAC,SAAS,GAAG,UAAU,CAAC;AACpC,EAAE,KAAK,EAAE,MAAM;AACf,EAAE,KAAK,EAAE;AACT,IAAI,IAAI,EAAE,cAAc,CAAC,MAAM,CAAC;AAChC,GAAG;AACH,EAAE,aAAa,EAAE,MAAM;AACvB,EAAE,UAAU,EAAE;AACd,IAAI,IAAI,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC;AAC1B,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,EAAE,WAAW,EAAE;AACf,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,OAAO,EAAE,EAAE;AACf,GAAG;AACH,EAAE,MAAM,EAAE,OAAO;AACjB,EAAE,aAAa,EAAE,OAAO;AACxB,EAAE,UAAU,EAAE,OAAO;AACrB,EAAE,WAAW,EAAE;AACf,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,IAAI,EAAE;AACR,IAAI,IAAI,EAAE,MAAM;AAChB,IAAI,MAAM,EAAE,cAAc;AAC1B,GAAG;AACH,EAAE,QAAQ,EAAE,OAAO;AACnB,EAAE,oBAAoB,EAAE;AACxB,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,IAAI;AACjB,GAAG;AACH,EAAE,oBAAoB,EAAE;AACxB,IAAI,IAAI,EAAE,OAAO;AACjB,IAAI,OAAO,EAAE,KAAK;AAClB,GAAG;AACH,EAAE,aAAa,EAAE,OAAO;AACxB,CAAC;;;;"}