fast-element-plus 1.0.20 → 1.0.21

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 (413) hide show
  1. package/dist/index.full.js +27739 -28664
  2. package/dist/index.full.js.map +1 -1
  3. package/dist/index.full.min.js +11042 -2
  4. package/dist/index.full.min.js.map +1 -1
  5. package/dist/index.full.min.mjs +11033 -2
  6. package/dist/index.full.min.mjs.map +1 -1
  7. package/dist/index.full.mjs +27730 -28662
  8. package/dist/index.full.mjs.map +1 -1
  9. package/es/_virtual/_rolldown/runtime.mjs +1 -0
  10. package/es/component.mjs +2 -2
  11. package/es/component.mjs.map +1 -1
  12. package/es/components/avatar/index.mjs +2 -2
  13. package/es/components/avatar/index.mjs.map +1 -1
  14. package/es/components/avatar/src/avatar.d.ts +10 -10
  15. package/es/components/avatar/src/avatar.mjs +2 -2
  16. package/es/components/avatar/src/avatar.mjs.map +1 -1
  17. package/es/components/button/index.mjs +2 -2
  18. package/es/components/button/index.mjs.map +1 -1
  19. package/es/components/button/src/button.d.ts +21 -17
  20. package/es/components/button/src/button.mjs +2 -2
  21. package/es/components/button/src/button.mjs.map +1 -1
  22. package/es/components/carNumber/index.mjs +2 -2
  23. package/es/components/carNumber/index.mjs.map +1 -1
  24. package/es/components/carNumber/src/carNumber.d.ts +36 -33
  25. package/es/components/carNumber/src/carNumber.mjs +2 -2
  26. package/es/components/carNumber/src/carNumber.mjs.map +1 -1
  27. package/es/components/carNumber/src/common.mjs +2 -2
  28. package/es/components/carNumber/src/common.mjs.map +1 -1
  29. package/es/components/contextMenu/index.mjs +2 -2
  30. package/es/components/contextMenu/index.mjs.map +1 -1
  31. package/es/components/contextMenu/src/contextMenu.mjs +2 -2
  32. package/es/components/contextMenu/src/contextMenu.mjs.map +1 -1
  33. package/es/components/contextMenu/src/contextMenu.type.mjs +0 -2
  34. package/es/components/dialog/index.mjs +2 -2
  35. package/es/components/dialog/index.mjs.map +1 -1
  36. package/es/components/dialog/src/dialog.d.ts +11 -11
  37. package/es/components/dialog/src/dialog.mjs +2 -2
  38. package/es/components/dialog/src/dialog.mjs.map +1 -1
  39. package/es/components/drawer/index.mjs +2 -2
  40. package/es/components/drawer/index.mjs.map +1 -1
  41. package/es/components/drawer/src/drawer.d.ts +10 -18
  42. package/es/components/drawer/src/drawer.mjs +2 -2
  43. package/es/components/drawer/src/drawer.mjs.map +1 -1
  44. package/es/components/form/index.mjs +2 -2
  45. package/es/components/form/index.mjs.map +1 -1
  46. package/es/components/form/src/form.d.ts +15 -15
  47. package/es/components/form/src/form.mjs +2 -2
  48. package/es/components/form/src/form.mjs.map +1 -1
  49. package/es/components/form/src/formItem.d.ts +14 -14
  50. package/es/components/form/src/formItem.mjs +2 -2
  51. package/es/components/form/src/formItem.mjs.map +1 -1
  52. package/es/components/form/utils/form.mjs +2 -2
  53. package/es/components/form/utils/form.mjs.map +1 -1
  54. package/es/components/formItemTip/index.mjs +2 -2
  55. package/es/components/formItemTip/index.mjs.map +1 -1
  56. package/es/components/formItemTip/src/formItemTip.mjs +2 -2
  57. package/es/components/formItemTip/src/formItemTip.mjs.map +1 -1
  58. package/es/components/icon/index.mjs +2 -2
  59. package/es/components/icon/index.mjs.map +1 -1
  60. package/es/components/icon/src/icon.mjs +2 -2
  61. package/es/components/icon/src/icon.mjs.map +1 -1
  62. package/es/components/iconSelector/index.mjs +2 -2
  63. package/es/components/iconSelector/index.mjs.map +1 -1
  64. package/es/components/iconSelector/src/iconSelector.mjs +2 -2
  65. package/es/components/iconSelector/src/iconSelector.mjs.map +1 -1
  66. package/es/components/image/index.mjs +2 -2
  67. package/es/components/image/index.mjs.map +1 -1
  68. package/es/components/image/src/image.d.ts +13 -13
  69. package/es/components/image/src/image.mjs +2 -2
  70. package/es/components/image/src/image.mjs.map +1 -1
  71. package/es/components/index.mjs +2 -2
  72. package/es/components/index.mjs.map +1 -1
  73. package/es/components/inputDialogPage/index.mjs +2 -2
  74. package/es/components/inputDialogPage/index.mjs.map +1 -1
  75. package/es/components/inputDialogPage/src/inputDialogPage.mjs +2 -2
  76. package/es/components/inputDialogPage/src/inputDialogPage.mjs.map +1 -1
  77. package/es/components/layoutGrid/index.mjs +2 -2
  78. package/es/components/layoutGrid/index.mjs.map +1 -1
  79. package/es/components/layoutGrid/src/layoutGrid.mjs +2 -2
  80. package/es/components/layoutGrid/src/layoutGrid.mjs.map +1 -1
  81. package/es/components/layoutGrid/src/layoutGrid.type.mjs +0 -2
  82. package/es/components/layoutGrid/src/layoutGridItem.mjs +2 -2
  83. package/es/components/layoutGrid/src/layoutGridItem.mjs.map +1 -1
  84. package/es/components/select/index.mjs +2 -2
  85. package/es/components/select/index.mjs.map +1 -1
  86. package/es/components/select/src/select.d.ts +21 -21
  87. package/es/components/select/src/select.mjs +2 -2
  88. package/es/components/select/src/select.mjs.map +1 -1
  89. package/es/components/select/src/select.type.mjs +0 -2
  90. package/es/components/select/src/selectOption.mjs +2 -2
  91. package/es/components/select/src/selectOption.mjs.map +1 -1
  92. package/es/components/selectPage/index.mjs +2 -2
  93. package/es/components/selectPage/index.mjs.map +1 -1
  94. package/es/components/selectPage/src/selectPage.d.ts +27 -27
  95. package/es/components/selectPage/src/selectPage.mjs +2 -2
  96. package/es/components/selectPage/src/selectPage.mjs.map +1 -1
  97. package/es/components/selectV2/index.mjs +2 -2
  98. package/es/components/selectV2/index.mjs.map +1 -1
  99. package/es/components/selectV2/src/selectV2.d.ts +19 -19
  100. package/es/components/selectV2/src/selectV2.mjs +2 -2
  101. package/es/components/selectV2/src/selectV2.mjs.map +1 -1
  102. package/es/components/table/images/artwork.mjs +2 -0
  103. package/es/components/table/images/artwork.mjs.map +1 -0
  104. package/es/components/table/images/notImage.mjs +2 -0
  105. package/es/components/table/images/notImage.mjs.map +1 -0
  106. package/es/components/table/index.mjs +2 -2
  107. package/es/components/table/index.mjs.map +1 -1
  108. package/es/components/table/src/page.type.mjs +2 -2
  109. package/es/components/table/src/page.type.mjs.map +1 -1
  110. package/es/components/table/src/table.d.ts +20 -4
  111. package/es/components/table/src/table.mjs +2 -2
  112. package/es/components/table/src/table.mjs.map +1 -1
  113. package/es/components/table/src/table.state.mjs +0 -2
  114. package/es/components/table/src/table.type.d.ts +1 -1
  115. package/es/components/table/src/table.type.mjs +2 -2
  116. package/es/components/table/src/table.type.mjs.map +1 -1
  117. package/es/components/table/src/tableColumn.mjs +2 -2
  118. package/es/components/table/src/tableColumn.mjs.map +1 -1
  119. package/es/components/table/src/tableColumnSettingDialog.mjs +2 -2
  120. package/es/components/table/src/tableColumnSettingDialog.mjs.map +1 -1
  121. package/es/components/table/src/tablePagination.mjs +2 -2
  122. package/es/components/table/src/tablePagination.mjs.map +1 -1
  123. package/es/components/table/src/tableSearchForm.mjs +2 -2
  124. package/es/components/table/src/tableSearchForm.mjs.map +1 -1
  125. package/es/components/table/src/tableSearchFormItem.mjs +2 -2
  126. package/es/components/table/src/tableSearchFormItem.mjs.map +1 -1
  127. package/es/components/table/src/useTable.mjs +2 -2
  128. package/es/components/table/src/useTable.mjs.map +1 -1
  129. package/es/components/table/utils/table.mjs +2 -2
  130. package/es/components/table/utils/table.mjs.map +1 -1
  131. package/es/components/tree/index.mjs +2 -2
  132. package/es/components/tree/index.mjs.map +1 -1
  133. package/es/components/tree/src/tree.d.ts +40 -40
  134. package/es/components/tree/src/tree.mjs +2 -2
  135. package/es/components/tree/src/tree.mjs.map +1 -1
  136. package/es/components/tree/src/tree.props.mjs +2 -2
  137. package/es/components/tree/src/tree.props.mjs.map +1 -1
  138. package/es/components/tree/src/tree.type.mjs +0 -2
  139. package/es/components/treeSelect/index.mjs +2 -2
  140. package/es/components/treeSelect/index.mjs.map +1 -1
  141. package/es/components/treeSelect/src/treeSelect.d.ts +60 -60
  142. package/es/components/treeSelect/src/treeSelect.mjs +2 -2
  143. package/es/components/treeSelect/src/treeSelect.mjs.map +1 -1
  144. package/es/components/upload/index.mjs +2 -2
  145. package/es/components/upload/index.mjs.map +1 -1
  146. package/es/components/upload/src/upload.d.ts +73 -73
  147. package/es/components/upload/src/upload.mjs +2 -2
  148. package/es/components/upload/src/upload.mjs.map +1 -1
  149. package/es/components/upload/src/useUpload.mjs +2 -2
  150. package/es/components/upload/src/useUpload.mjs.map +1 -1
  151. package/es/components/upload/utils/upload.mjs +2 -2
  152. package/es/components/upload/utils/upload.mjs.map +1 -1
  153. package/es/components/uploadImage/index.mjs +2 -2
  154. package/es/components/uploadImage/index.mjs.map +1 -1
  155. package/es/components/uploadImage/src/uploadImage.d.ts +69 -69
  156. package/es/components/uploadImage/src/uploadImage.mjs +2 -2
  157. package/es/components/uploadImage/src/uploadImage.mjs.map +1 -1
  158. package/es/components/uploadImages/index.mjs +2 -2
  159. package/es/components/uploadImages/index.mjs.map +1 -1
  160. package/es/components/uploadImages/src/uploadImages.d.ts +70 -70
  161. package/es/components/uploadImages/src/uploadImages.mjs +2 -2
  162. package/es/components/uploadImages/src/uploadImages.mjs.map +1 -1
  163. package/es/constants/index.mjs +1 -2
  164. package/es/constants/mime.mjs +2 -2
  165. package/es/constants/mime.mjs.map +1 -1
  166. package/es/constants/regex.mjs +2 -2
  167. package/es/constants/regex.mjs.map +1 -1
  168. package/es/directive.mjs +2 -2
  169. package/es/directive.mjs.map +1 -1
  170. package/es/directives/click-copy/index.mjs +2 -2
  171. package/es/directives/click-copy/index.mjs.map +1 -1
  172. package/es/directives/click-debounce/index.mjs +2 -2
  173. package/es/directives/click-debounce/index.mjs.map +1 -1
  174. package/es/directives/click-draggable/index.mjs +2 -2
  175. package/es/directives/click-draggable/index.mjs.map +1 -1
  176. package/es/directives/click-icon-copy/index.mjs +2 -2
  177. package/es/directives/click-icon-copy/index.mjs.map +1 -1
  178. package/es/directives/click-longpress/index.mjs +2 -2
  179. package/es/directives/click-longpress/index.mjs.map +1 -1
  180. package/es/directives/click-throttle/index.mjs +2 -2
  181. package/es/directives/click-throttle/index.mjs.map +1 -1
  182. package/es/directives/index.mjs +1 -2
  183. package/es/element-plus.mjs +2 -2
  184. package/es/element-plus.mjs.map +1 -1
  185. package/es/hooks/index.mjs +1 -2
  186. package/es/hooks/use-loading/index.mjs +2 -2
  187. package/es/hooks/use-loading/index.mjs.map +1 -1
  188. package/es/hooks/use-overlay/index.mjs +2 -2
  189. package/es/hooks/use-overlay/index.mjs.map +1 -1
  190. package/es/hooks/use-screenFull/index.mjs +2 -2
  191. package/es/hooks/use-screenFull/index.mjs.map +1 -1
  192. package/es/index.mjs +2 -2
  193. package/es/index.mjs.map +1 -1
  194. package/es/make-installer.mjs +2 -2
  195. package/es/make-installer.mjs.map +1 -1
  196. package/es/version.d.ts +1 -1
  197. package/es/version.mjs +2 -2
  198. package/es/version.mjs.map +1 -1
  199. package/lib/_virtual/_rolldown/runtime.js +1 -0
  200. package/lib/component.js +2 -2
  201. package/lib/component.js.map +1 -1
  202. package/lib/components/avatar/index.js +2 -2
  203. package/lib/components/avatar/index.js.map +1 -1
  204. package/lib/components/avatar/src/avatar.d.ts +10 -10
  205. package/lib/components/avatar/src/avatar.js +2 -2
  206. package/lib/components/avatar/src/avatar.js.map +1 -1
  207. package/lib/components/button/index.js +2 -2
  208. package/lib/components/button/index.js.map +1 -1
  209. package/lib/components/button/src/button.d.ts +21 -17
  210. package/lib/components/button/src/button.js +2 -2
  211. package/lib/components/button/src/button.js.map +1 -1
  212. package/lib/components/carNumber/index.js +2 -2
  213. package/lib/components/carNumber/index.js.map +1 -1
  214. package/lib/components/carNumber/src/carNumber.d.ts +36 -33
  215. package/lib/components/carNumber/src/carNumber.js +2 -2
  216. package/lib/components/carNumber/src/carNumber.js.map +1 -1
  217. package/lib/components/carNumber/src/common.js +2 -2
  218. package/lib/components/carNumber/src/common.js.map +1 -1
  219. package/lib/components/contextMenu/index.js +2 -2
  220. package/lib/components/contextMenu/index.js.map +1 -1
  221. package/lib/components/contextMenu/src/contextMenu.js +2 -2
  222. package/lib/components/contextMenu/src/contextMenu.js.map +1 -1
  223. package/lib/components/contextMenu/src/contextMenu.type.js +0 -2
  224. package/lib/components/dialog/index.js +2 -2
  225. package/lib/components/dialog/index.js.map +1 -1
  226. package/lib/components/dialog/src/dialog.d.ts +11 -11
  227. package/lib/components/dialog/src/dialog.js +2 -2
  228. package/lib/components/dialog/src/dialog.js.map +1 -1
  229. package/lib/components/drawer/index.js +2 -2
  230. package/lib/components/drawer/index.js.map +1 -1
  231. package/lib/components/drawer/src/drawer.d.ts +10 -18
  232. package/lib/components/drawer/src/drawer.js +2 -2
  233. package/lib/components/drawer/src/drawer.js.map +1 -1
  234. package/lib/components/form/index.js +2 -2
  235. package/lib/components/form/index.js.map +1 -1
  236. package/lib/components/form/src/form.d.ts +15 -15
  237. package/lib/components/form/src/form.js +2 -2
  238. package/lib/components/form/src/form.js.map +1 -1
  239. package/lib/components/form/src/formItem.d.ts +14 -14
  240. package/lib/components/form/src/formItem.js +2 -2
  241. package/lib/components/form/src/formItem.js.map +1 -1
  242. package/lib/components/form/utils/form.js +2 -2
  243. package/lib/components/form/utils/form.js.map +1 -1
  244. package/lib/components/formItemTip/index.js +2 -2
  245. package/lib/components/formItemTip/index.js.map +1 -1
  246. package/lib/components/formItemTip/src/formItemTip.js +2 -2
  247. package/lib/components/formItemTip/src/formItemTip.js.map +1 -1
  248. package/lib/components/icon/index.js +2 -2
  249. package/lib/components/icon/index.js.map +1 -1
  250. package/lib/components/icon/src/icon.js +2 -2
  251. package/lib/components/icon/src/icon.js.map +1 -1
  252. package/lib/components/iconSelector/index.js +2 -2
  253. package/lib/components/iconSelector/index.js.map +1 -1
  254. package/lib/components/iconSelector/src/iconSelector.js +2 -2
  255. package/lib/components/iconSelector/src/iconSelector.js.map +1 -1
  256. package/lib/components/image/index.js +2 -2
  257. package/lib/components/image/index.js.map +1 -1
  258. package/lib/components/image/src/image.d.ts +13 -13
  259. package/lib/components/image/src/image.js +2 -2
  260. package/lib/components/image/src/image.js.map +1 -1
  261. package/lib/components/index.js +2 -2
  262. package/lib/components/index.js.map +1 -1
  263. package/lib/components/inputDialogPage/index.js +2 -2
  264. package/lib/components/inputDialogPage/index.js.map +1 -1
  265. package/lib/components/inputDialogPage/src/inputDialogPage.js +2 -2
  266. package/lib/components/inputDialogPage/src/inputDialogPage.js.map +1 -1
  267. package/lib/components/layoutGrid/index.js +2 -2
  268. package/lib/components/layoutGrid/index.js.map +1 -1
  269. package/lib/components/layoutGrid/src/layoutGrid.js +2 -2
  270. package/lib/components/layoutGrid/src/layoutGrid.js.map +1 -1
  271. package/lib/components/layoutGrid/src/layoutGrid.type.js +0 -2
  272. package/lib/components/layoutGrid/src/layoutGridItem.js +2 -2
  273. package/lib/components/layoutGrid/src/layoutGridItem.js.map +1 -1
  274. package/lib/components/select/index.js +2 -2
  275. package/lib/components/select/index.js.map +1 -1
  276. package/lib/components/select/src/select.d.ts +21 -21
  277. package/lib/components/select/src/select.js +2 -2
  278. package/lib/components/select/src/select.js.map +1 -1
  279. package/lib/components/select/src/select.type.js +0 -2
  280. package/lib/components/select/src/selectOption.js +2 -2
  281. package/lib/components/select/src/selectOption.js.map +1 -1
  282. package/lib/components/selectPage/index.js +2 -2
  283. package/lib/components/selectPage/index.js.map +1 -1
  284. package/lib/components/selectPage/src/selectPage.d.ts +27 -27
  285. package/lib/components/selectPage/src/selectPage.js +2 -2
  286. package/lib/components/selectPage/src/selectPage.js.map +1 -1
  287. package/lib/components/selectV2/index.js +2 -2
  288. package/lib/components/selectV2/index.js.map +1 -1
  289. package/lib/components/selectV2/src/selectV2.d.ts +19 -19
  290. package/lib/components/selectV2/src/selectV2.js +2 -2
  291. package/lib/components/selectV2/src/selectV2.js.map +1 -1
  292. package/lib/components/table/images/artwork.js +2 -0
  293. package/lib/components/table/images/artwork.js.map +1 -0
  294. package/lib/components/table/images/notImage.js +2 -0
  295. package/lib/components/table/images/notImage.js.map +1 -0
  296. package/lib/components/table/index.js +2 -2
  297. package/lib/components/table/index.js.map +1 -1
  298. package/lib/components/table/src/page.type.js +2 -2
  299. package/lib/components/table/src/page.type.js.map +1 -1
  300. package/lib/components/table/src/table.d.ts +20 -4
  301. package/lib/components/table/src/table.js +2 -2
  302. package/lib/components/table/src/table.js.map +1 -1
  303. package/lib/components/table/src/table.state.js +0 -2
  304. package/lib/components/table/src/table.type.d.ts +1 -1
  305. package/lib/components/table/src/table.type.js +2 -2
  306. package/lib/components/table/src/table.type.js.map +1 -1
  307. package/lib/components/table/src/tableColumn.js +2 -2
  308. package/lib/components/table/src/tableColumn.js.map +1 -1
  309. package/lib/components/table/src/tableColumnSettingDialog.js +2 -2
  310. package/lib/components/table/src/tableColumnSettingDialog.js.map +1 -1
  311. package/lib/components/table/src/tablePagination.js +2 -2
  312. package/lib/components/table/src/tablePagination.js.map +1 -1
  313. package/lib/components/table/src/tableSearchForm.js +2 -2
  314. package/lib/components/table/src/tableSearchForm.js.map +1 -1
  315. package/lib/components/table/src/tableSearchFormItem.js +2 -2
  316. package/lib/components/table/src/tableSearchFormItem.js.map +1 -1
  317. package/lib/components/table/src/useTable.js +2 -2
  318. package/lib/components/table/src/useTable.js.map +1 -1
  319. package/lib/components/table/utils/table.js +2 -2
  320. package/lib/components/table/utils/table.js.map +1 -1
  321. package/lib/components/tree/index.js +2 -2
  322. package/lib/components/tree/index.js.map +1 -1
  323. package/lib/components/tree/src/tree.d.ts +40 -40
  324. package/lib/components/tree/src/tree.js +2 -2
  325. package/lib/components/tree/src/tree.js.map +1 -1
  326. package/lib/components/tree/src/tree.props.js +2 -2
  327. package/lib/components/tree/src/tree.props.js.map +1 -1
  328. package/lib/components/tree/src/tree.type.js +0 -2
  329. package/lib/components/treeSelect/index.js +2 -2
  330. package/lib/components/treeSelect/index.js.map +1 -1
  331. package/lib/components/treeSelect/src/treeSelect.d.ts +60 -60
  332. package/lib/components/treeSelect/src/treeSelect.js +2 -2
  333. package/lib/components/treeSelect/src/treeSelect.js.map +1 -1
  334. package/lib/components/upload/index.js +2 -2
  335. package/lib/components/upload/index.js.map +1 -1
  336. package/lib/components/upload/src/upload.d.ts +73 -73
  337. package/lib/components/upload/src/upload.js +2 -2
  338. package/lib/components/upload/src/upload.js.map +1 -1
  339. package/lib/components/upload/src/useUpload.js +2 -2
  340. package/lib/components/upload/src/useUpload.js.map +1 -1
  341. package/lib/components/upload/utils/upload.js +2 -2
  342. package/lib/components/upload/utils/upload.js.map +1 -1
  343. package/lib/components/uploadImage/index.js +2 -2
  344. package/lib/components/uploadImage/index.js.map +1 -1
  345. package/lib/components/uploadImage/src/uploadImage.d.ts +69 -69
  346. package/lib/components/uploadImage/src/uploadImage.js +2 -2
  347. package/lib/components/uploadImage/src/uploadImage.js.map +1 -1
  348. package/lib/components/uploadImages/index.js +2 -2
  349. package/lib/components/uploadImages/index.js.map +1 -1
  350. package/lib/components/uploadImages/src/uploadImages.d.ts +70 -70
  351. package/lib/components/uploadImages/src/uploadImages.js +2 -2
  352. package/lib/components/uploadImages/src/uploadImages.js.map +1 -1
  353. package/lib/constants/index.js +1 -2
  354. package/lib/constants/mime.js +2 -2
  355. package/lib/constants/mime.js.map +1 -1
  356. package/lib/constants/regex.js +2 -2
  357. package/lib/constants/regex.js.map +1 -1
  358. package/lib/directive.js +2 -2
  359. package/lib/directive.js.map +1 -1
  360. package/lib/directives/click-copy/index.js +2 -2
  361. package/lib/directives/click-copy/index.js.map +1 -1
  362. package/lib/directives/click-debounce/index.js +2 -2
  363. package/lib/directives/click-debounce/index.js.map +1 -1
  364. package/lib/directives/click-draggable/index.js +2 -2
  365. package/lib/directives/click-draggable/index.js.map +1 -1
  366. package/lib/directives/click-icon-copy/index.js +2 -2
  367. package/lib/directives/click-icon-copy/index.js.map +1 -1
  368. package/lib/directives/click-longpress/index.js +2 -2
  369. package/lib/directives/click-longpress/index.js.map +1 -1
  370. package/lib/directives/click-throttle/index.js +2 -2
  371. package/lib/directives/click-throttle/index.js.map +1 -1
  372. package/lib/directives/index.js +1 -2
  373. package/lib/element-plus.js +2 -2
  374. package/lib/element-plus.js.map +1 -1
  375. package/lib/hooks/index.js +1 -2
  376. package/lib/hooks/use-loading/index.js +2 -2
  377. package/lib/hooks/use-loading/index.js.map +1 -1
  378. package/lib/hooks/use-overlay/index.js +2 -2
  379. package/lib/hooks/use-overlay/index.js.map +1 -1
  380. package/lib/hooks/use-screenFull/index.js +2 -2
  381. package/lib/hooks/use-screenFull/index.js.map +1 -1
  382. package/lib/index.js +2 -2
  383. package/lib/index.js.map +1 -1
  384. package/lib/make-installer.js +2 -2
  385. package/lib/make-installer.js.map +1 -1
  386. package/lib/version.d.ts +1 -1
  387. package/lib/version.js +2 -2
  388. package/lib/version.js.map +1 -1
  389. package/package.json +7 -7
  390. package/es/components/contextMenu/src/contextMenu.type.mjs.map +0 -1
  391. package/es/components/layoutGrid/src/layoutGrid.type.mjs.map +0 -1
  392. package/es/components/select/src/select.type.mjs.map +0 -1
  393. package/es/components/table/images/artwork.png.mjs +0 -2
  394. package/es/components/table/images/artwork.png.mjs.map +0 -1
  395. package/es/components/table/images/notImage.png.mjs +0 -2
  396. package/es/components/table/images/notImage.png.mjs.map +0 -1
  397. package/es/components/table/src/table.state.mjs.map +0 -1
  398. package/es/components/tree/src/tree.type.mjs.map +0 -1
  399. package/es/constants/index.mjs.map +0 -1
  400. package/es/directives/index.mjs.map +0 -1
  401. package/es/hooks/index.mjs.map +0 -1
  402. package/lib/components/contextMenu/src/contextMenu.type.js.map +0 -1
  403. package/lib/components/layoutGrid/src/layoutGrid.type.js.map +0 -1
  404. package/lib/components/select/src/select.type.js.map +0 -1
  405. package/lib/components/table/images/artwork.png.js +0 -2
  406. package/lib/components/table/images/artwork.png.js.map +0 -1
  407. package/lib/components/table/images/notImage.png.js +0 -2
  408. package/lib/components/table/images/notImage.png.js.map +0 -1
  409. package/lib/components/table/src/table.state.js.map +0 -1
  410. package/lib/components/tree/src/tree.type.js.map +0 -1
  411. package/lib/constants/index.js.map +0 -1
  412. package/lib/directives/index.js.map +0 -1
  413. package/lib/hooks/index.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"drawer.mjs","sources":["../../../../../packages/components/drawer/src/drawer.tsx"],"sourcesContent":["import { Fragment, computed, defineComponent, nextTick, reactive, ref, watch } from \"vue\";\nimport { ElButton, ElDrawer, ElIcon, ElMessage, ElMessageBox, ElScrollbar, drawerEmits, drawerProps, useGlobalSize } from \"element-plus\";\nimport { Close, Eleme, Refresh } from \"@element-plus/icons-vue\";\nimport { FullScreen, FullScreenExit } from \"@fast-element-plus/icons-vue\";\nimport { consoleError, definePropType, execFunction, makeSlots, useEmits, useExpose, useProps, useRender } from \"@fast-china/utils\";\nimport { isBoolean } from \"lodash-unified\";\nimport type { VNode } from \"vue\";\n\nexport const faDrawerProps = {\n\t...drawerProps,\n\t/** @description whether to append Dialog itself to body. A nested Dialog should have this attribute set to `true` */\n\tappendToBody: {\n\t\ttype: Boolean,\n\t\tdefault: true,\n\t},\n\t/** @description enable dragging feature for Dialog */\n\tdraggable: {\n\t\ttype: Boolean,\n\t\tdefault: true,\n\t},\n\t/** @description destroy elements in Dialog when closed */\n\tdestroyOnClose: {\n\t\ttype: Boolean,\n\t\tdefault: true,\n\t},\n\t/** @description 显示刷新按钮 */\n\tshowRefresh: {\n\t\ttype: Boolean,\n\t\tdefault: true,\n\t},\n\t/** @description 显示全屏图标 */\n\tshowFullscreen: {\n\t\ttype: Boolean,\n\t\tdefault: true,\n\t},\n\t/** @description 显示关闭按钮 */\n\tshowCloseButton: {\n\t\ttype: Boolean,\n\t\tdefault: true,\n\t},\n\t/** @description 显示确认按钮 */\n\tshowConfirmButton: {\n\t\ttype: Boolean,\n\t\tdefault: true,\n\t},\n\t/** @description 禁用确认按钮 */\n\tdisabledConfirmButton: Boolean,\n\t/** @description 关闭按钮文字,默认取消 */\n\tcloseButtonText: {\n\t\ttype: String,\n\t\tdefault: \"取消\",\n\t},\n\t/** @description 确认按钮文字,默认确认 */\n\tconfirmButtonText: {\n\t\ttype: String,\n\t\tdefault: \"确认\",\n\t},\n\t/** @description 隐藏底部操作 */\n\thideFooter: Boolean,\n\t/** @description 显示关闭回调 */\n\tshowBeforeClose: Boolean,\n\t/** @description 打开之后 */\n\tafterOpen: {\n\t\ttype: definePropType<() => void>(Function),\n\t},\n};\n\nexport const faDrawerEmits = {\n\t...drawerEmits,\n\t/** @description v-model 回调 */\n\t\"update:modelValue\": (value: boolean): boolean => isBoolean(value),\n\t/** @description 确认按钮点击事件 */\n\tconfirmClick: (): boolean => true,\n};\n\ntype FaDrawerSlots = {\n\t/** @description 默认内容插槽 */\n\tdefault: { loading: boolean };\n\t/** @description 头部插槽 */\n\theader: { loading: boolean; close: () => void };\n\t/** @description 底部插槽 */\n\tfooter: { loading: boolean; close: () => void };\n};\n\nexport default defineComponent({\n\tname: \"FaDrawer\",\n\tprops: faDrawerProps,\n\temits: faDrawerEmits,\n\tslots: makeSlots<FaDrawerSlots>(),\n\tsetup(props, { attrs, slots, emit, expose }) {\n\t\tconst _globalSize = useGlobalSize();\n\n\t\tconst state = reactive({\n\t\t\tloading: false,\n\t\t\tvisible: false,\n\t\t\tfullscreen: false,\n\t\t\tsize: props.size ?? \"30%\",\n\t\t\tdragging: false,\n\t\t\trefreshing: false,\n\t\t});\n\n\t\tconst drawerRef = ref<InstanceType<typeof ElDrawer>>();\n\n\t\tlet cacheOpenFunction = undefined;\n\n\t\tconst handleOpen = (openFunction?: () => void | Promise<void>): void => {\n\t\t\tstate.visible = true;\n\t\t\tcacheOpenFunction = openFunction;\n\t\t\tnextTick(() => {\n\t\t\t\tstate.loading = true;\n\t\t\t\texecFunction(props.afterOpen ?? openFunction)\n\t\t\t\t\t.then(() => {\n\t\t\t\t\t\temit(\"open\");\n\t\t\t\t\t})\n\t\t\t\t\t.catch((error) => {\n\t\t\t\t\t\tconsoleError(\"FaDrawer\", error);\n\t\t\t\t\t\t// 自动关闭\n\t\t\t\t\t\tstate.visible = false;\n\t\t\t\t\t})\n\t\t\t\t\t.finally(() => {\n\t\t\t\t\t\tstate.loading = false;\n\t\t\t\t\t});\n\t\t\t});\n\t\t};\n\n\t\tconst handleClose = (closeFunction?: () => void | Promise<void>): void => {\n\t\t\tstate.loading = true;\n\t\t\texecFunction(closeFunction)\n\t\t\t\t.then(() => {\n\t\t\t\t\temit(\"close\");\n\t\t\t\t\tstate.visible = false;\n\t\t\t\t})\n\t\t\t\t.catch((error) => {\n\t\t\t\t\tconsoleError(\"FaDrawer\", error);\n\t\t\t\t})\n\t\t\t\t.finally(() => {\n\t\t\t\t\tstate.loading = false;\n\t\t\t\t});\n\t\t};\n\n\t\tconst handleLoading = (loadingFunction: () => void | Promise<void>): void => {\n\t\t\tstate.loading = true;\n\t\t\texecFunction(loadingFunction)\n\t\t\t\t.then()\n\t\t\t\t.catch((error) => {\n\t\t\t\t\tconsoleError(\"FaDrawer\", error);\n\t\t\t\t})\n\t\t\t\t.finally(() => {\n\t\t\t\t\tstate.loading = false;\n\t\t\t\t});\n\t\t};\n\n\t\tconst handleRefresh = (): void => {\n\t\t\tstate.refreshing = true;\n\t\t\tstate.loading = true;\n\t\t\tsetTimeout(() => {\n\t\t\t\tstate.refreshing = false;\n\t\t\t\thandleOpen(cacheOpenFunction);\n\t\t\t\tElMessage.success(\"刷新成功\");\n\t\t\t}, 500);\n\t\t};\n\n\t\tconst handleBeforeClose = (done: () => void): void => {\n\t\t\tif (state.loading) return;\n\t\t\t// 解决 image 预览摁下 ese 会关闭弹窗的问题\n\t\t\tif (document.querySelector(\".el-image-viewer__wrapper\")) return;\n\n\t\t\tconst newDone = (): void => {\n\t\t\t\texecFunction(props.beforeClose)\n\t\t\t\t\t.then(() => {\n\t\t\t\t\t\temit(\"close\");\n\t\t\t\t\t\tdone();\n\t\t\t\t\t})\n\t\t\t\t\t.catch((error) => {\n\t\t\t\t\t\tconsoleError(\"FaDialog\", error);\n\t\t\t\t\t});\n\t\t\t};\n\n\t\t\tif (props.showBeforeClose) {\n\t\t\t\tElMessageBox.confirm(\"确定关闭?\", { type: \"warning\" }).then(() => {\n\t\t\t\t\tnewDone();\n\t\t\t\t});\n\t\t\t} else {\n\t\t\t\tnewDone();\n\t\t\t}\n\t\t};\n\n\t\tconst handleFullscreen = (): void => {\n\t\t\tif (state.loading) return;\n\t\t\tstate.fullscreen = !state.fullscreen;\n\t\t};\n\n\t\tconst handleConfirmClick = (): void => {\n\t\t\tif (state.loading) return;\n\t\t\temit(\"confirmClick\");\n\t\t};\n\n\t\tconst handleCloseClick = (): void => {\n\t\t\tif (state.loading) return;\n\t\t\thandleClose();\n\t\t};\n\n\t\twatch(\n\t\t\t() => state.visible,\n\t\t\t(newValue) => {\n\t\t\t\temit(\"update:modelValue\", newValue);\n\t\t\t}\n\t\t);\n\n\t\t/**\n\t\t * 处理拖拽\n\t\t */\n\t\tconst handleDraggableMousedown = (): void => {\n\t\t\tdocument.onmousemove = (moveEvent: MouseEvent): void => {\n\t\t\t\t// 获取鼠标距离浏览器右边缘的距离\n\t\t\t\tlet realWidth = document.body.clientWidth - moveEvent.pageX;\n\t\t\t\tconst width20 = document.body.clientWidth * 0.2;\n\t\t\t\tconst width95 = document.body.clientWidth * 0.95;\n\t\t\t\t// 宽度不能大于浏览器宽度 95%,不能小于宽度的 20%\n\t\t\t\trealWidth = realWidth > width95 ? width95 : realWidth < width20 ? width20 : realWidth;\n\t\t\t\tstate.size = `${realWidth}px`;\n\t\t\t};\n\t\t\tdocument.onmouseup = (): void => {\n\t\t\t\tdocument.onmousemove = document.onmouseup = null;\n\t\t\t};\n\t\t};\n\n\t\tconst elDrawerProps = useProps(props, drawerProps, [\"modelValue\", \"size\", \"showClose\", \"beforeClose\"]);\n\t\tconst elDrawerEmits = useEmits(drawerEmits, emit, [\"update:modelValue\"]);\n\n\t\tuseRender(() => (\n\t\t\t<ElDrawer\n\t\t\t\t{...elDrawerProps.value}\n\t\t\t\t{...elDrawerEmits.value}\n\t\t\t\tref={drawerRef}\n\t\t\t\tclass={[\"fa-drawer\", `fa-drawer-${_globalSize.value}`, { \"fa-drawer__fullscreen\": state.fullscreen }]}\n\t\t\t\tvModel={state.visible}\n\t\t\t\tsize={state.size}\n\t\t\t\tshowClose={false}\n\t\t\t\tbeforeClose={handleBeforeClose}\n\t\t\t>\n\t\t\t\t{{\n\t\t\t\t\theader: () => (\n\t\t\t\t\t\t<Fragment>\n\t\t\t\t\t\t\t<div class=\"fa-drawer__header-title\">\n\t\t\t\t\t\t\t\t{props.title}\n\t\t\t\t\t\t\t\t{slots.header && slots.header({ loading: state.loading, close: handleCloseClick })}\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t{props.showRefresh && (\n\t\t\t\t\t\t\t\t<div\n\t\t\t\t\t\t\t\t\ttitle=\"刷新\"\n\t\t\t\t\t\t\t\t\tclass={[\n\t\t\t\t\t\t\t\t\t\t\"fa-drawer__header-icon\",\n\t\t\t\t\t\t\t\t\t\tstate.loading ? \"fa__click__disabled fa__click__disabled__cursor \" : \"fa__hover__twinkle\",\n\t\t\t\t\t\t\t\t\t]}\n\t\t\t\t\t\t\t\t\tonClick={handleRefresh}\n\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t<ElIcon class=\"icon\">\n\t\t\t\t\t\t\t\t\t\t<Refresh />\n\t\t\t\t\t\t\t\t\t</ElIcon>\n\t\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t\t{props.showFullscreen && (\n\t\t\t\t\t\t\t\t<div\n\t\t\t\t\t\t\t\t\ttitle={state.fullscreen ? \"关闭全屏显示\" : \"全屏显示\"}\n\t\t\t\t\t\t\t\t\tclass={[\n\t\t\t\t\t\t\t\t\t\t\"fa-drawer__header-icon\",\n\t\t\t\t\t\t\t\t\t\tstate.loading ? \"fa__click__disabled fa__click__disabled__cursor \" : \"fa__hover__twinkle\",\n\t\t\t\t\t\t\t\t\t]}\n\t\t\t\t\t\t\t\t\tonClick={handleFullscreen}\n\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t<ElIcon>{state.fullscreen ? <FullScreenExit /> : <FullScreen />}</ElIcon>\n\t\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t\t{props.showClose && (\n\t\t\t\t\t\t\t\t<div\n\t\t\t\t\t\t\t\t\ttitle=\"关闭\"\n\t\t\t\t\t\t\t\t\tclass={[\n\t\t\t\t\t\t\t\t\t\t\"fa-drawer__header-icon\",\n\t\t\t\t\t\t\t\t\t\tstate.loading ? \"fa__click__disabled fa__click__disabled__cursor \" : \"fa__hover__twinkle\",\n\t\t\t\t\t\t\t\t\t]}\n\t\t\t\t\t\t\t\t\tonClick={handleCloseClick}\n\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t<ElIcon class=\"icon\">\n\t\t\t\t\t\t\t\t\t\t<Close />\n\t\t\t\t\t\t\t\t\t</ElIcon>\n\t\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t</Fragment>\n\t\t\t\t\t),\n\t\t\t\t\tdefault: () => (\n\t\t\t\t\t\t<Fragment>\n\t\t\t\t\t\t\t{props.draggable && <div class=\"fa-drawer__draggable\" onmousedown={handleDraggableMousedown} />}\n\t\t\t\t\t\t\t<ElScrollbar vLoading={state.loading} element-loading-text=\"加载中...\">\n\t\t\t\t\t\t\t\t{!state.refreshing && slots.default && slots.default(state)}\n\t\t\t\t\t\t\t</ElScrollbar>\n\t\t\t\t\t\t</Fragment>\n\t\t\t\t\t),\n\t\t\t\t\t...(!props.hideFooter && {\n\t\t\t\t\t\tfooter: (): VNode[] => (\n\t\t\t\t\t\t\t<Fragment>\n\t\t\t\t\t\t\t\t{slots.footer && slots.footer({ loading: state.loading, close: handleCloseClick })}\n\t\t\t\t\t\t\t\t{props.showCloseButton && (\n\t\t\t\t\t\t\t\t\t<ElButton disabled={state.loading} onClick={handleCloseClick}>\n\t\t\t\t\t\t\t\t\t\t{props.closeButtonText}\n\t\t\t\t\t\t\t\t\t</ElButton>\n\t\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t\t\t{props.showConfirmButton && (\n\t\t\t\t\t\t\t\t\t<ElButton\n\t\t\t\t\t\t\t\t\t\tloading={state.loading}\n\t\t\t\t\t\t\t\t\t\tloadingIcon={Eleme}\n\t\t\t\t\t\t\t\t\t\tdisabled={props.disabledConfirmButton}\n\t\t\t\t\t\t\t\t\t\ttype=\"primary\"\n\t\t\t\t\t\t\t\t\t\tonClick={handleConfirmClick}\n\t\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t\t{state.loading ? \"加载中...\" : props.confirmButtonText}\n\t\t\t\t\t\t\t\t\t</ElButton>\n\t\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t\t</Fragment>\n\t\t\t\t\t\t),\n\t\t\t\t\t}),\n\t\t\t\t}}\n\t\t\t</ElDrawer>\n\t\t));\n\n\t\treturn useExpose(expose, {\n\t\t\t/** @description 用于关闭 Drawer, 该方法会调用传入的 before-close 方法 */\n\t\t\thandleClose: computed(() => drawerRef.value?.handleClose),\n\t\t\t/** @description 进入动画后的回调 */\n\t\t\tafterEnter: computed(() => drawerRef.value?.afterEnter),\n\t\t\t/** @description 离开动画后的回调 */\n\t\t\tafterLeave: computed(() => drawerRef.value?.afterLeave),\n\t\t\t/** @description 加载状态 */\n\t\t\tloading: computed(() => state.loading),\n\t\t\t/** @description 是否显示 */\n\t\t\tvisible: computed(() => state.visible),\n\t\t\t/** @description 打开弹窗 */\n\t\t\topen: handleOpen,\n\t\t\t/** @description 关闭弹窗 */\n\t\t\tclose: handleClose,\n\t\t\t/** @description 刷新弹窗 */\n\t\t\trefresh: handleRefresh,\n\t\t\t/** @description 弹窗加载 */\n\t\t\tdoLoading: handleLoading,\n\t\t});\n\t},\n});\n"],"names":["faDrawerProps","drawerProps","appendToBody","type","Boolean","default","draggable","destroyOnClose","showRefresh","showFullscreen","showCloseButton","showConfirmButton","disabledConfirmButton","closeButtonText","String","confirmButtonText","hideFooter","showBeforeClose","afterOpen","definePropType","Function","faDrawerEmits","drawerEmits","value","isBoolean","confirmClick","Drawer","name","props","emits","slots","makeSlots","setup","attrs","emit","expose","_globalSize","useGlobalSize","state","reactive","loading","visible","fullscreen","size","dragging","refreshing","drawerRef","ref","cacheOpenFunction","handleOpen","openFunction","nextTick","execFunction","then","catch","error","consoleError","finally","handleClose","closeFunction","handleRefresh","setTimeout","ElMessage","success","handleBeforeClose","done","document","querySelector","newDone","beforeClose","ElMessageBox","confirm","handleFullscreen","handleConfirmClick","handleCloseClick","watch","newValue","handleDraggableMousedown","onmousemove","moveEvent","realWidth","body","clientWidth","pageX","width20","width95","onmouseup","elDrawerProps","useProps","elDrawerEmits","useEmits","useRender","_createVNode","ElDrawer","_mergeProps","class","modelValue","$event","showClose","header","_Fragment","title","close","onClick","ElIcon","Refresh","FullScreenExit","FullScreen","Close","onmousedown","_withDirectives","ElScrollbar","_resolveDirective","footer","ElButton","disabled","loadingIcon","Eleme","useExpose","computed","afterEnter","afterLeave","open","refresh","doLoading","loadingFunction"],"mappings":"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"}
1
+ {"version":3,"file":"drawer.mjs","names":["Fragment","computed","defineComponent","nextTick","reactive","ref","watch","createVNode","_createVNode","_Fragment","resolveDirective","_resolveDirective","withDirectives","_withDirectives","mergeProps","_mergeProps","ElButton","ElDrawer","ElIcon","ElMessage","ElMessageBox","ElScrollbar","drawerEmits","drawerProps","useGlobalSize","Close","Eleme","Refresh","FullScreen","FullScreenExit","consoleError","definePropType","execFunction","makeSlots","useEmits","useExpose","useProps","useRender","isBoolean","faDrawerProps","appendToBody","type","Boolean","default","draggable","destroyOnClose","showRefresh","showFullscreen","showCloseButton","showConfirmButton","disabledConfirmButton","closeButtonText","String","confirmButtonText","hideFooter","showBeforeClose","afterOpen","Function","faDrawerEmits","value","confirmClick","name","props","emits","slots","setup","attrs","emit","expose","_globalSize","state","loading","visible","fullscreen","size","dragging","refreshing","drawerRef","cacheOpenFunction","undefined","handleOpen","openFunction","then","catch","error","finally","handleClose","closeFunction","handleLoading","loadingFunction","handleRefresh","setTimeout","success","handleBeforeClose","done","document","querySelector","newDone","beforeClose","confirm","handleFullscreen","handleConfirmClick","handleCloseClick","newValue","handleDraggableMousedown","onmousemove","moveEvent","realWidth","body","clientWidth","pageX","width20","width95","onmouseup","elDrawerProps","elDrawerEmits","$event","header","title","close","showClose","footer","afterEnter","afterLeave","open","refresh","doLoading"],"sources":["../../../../../packages/components/drawer/src/drawer.tsx"],"sourcesContent":["import { Fragment, computed, defineComponent, nextTick, reactive, ref, watch } from \"vue\";\nimport { ElButton, ElDrawer, ElIcon, ElMessage, ElMessageBox, ElScrollbar, drawerEmits, drawerProps, useGlobalSize } from \"element-plus\";\nimport { Close, Eleme, Refresh } from \"@element-plus/icons-vue\";\nimport { FullScreen, FullScreenExit } from \"@fast-element-plus/icons-vue\";\nimport { consoleError, definePropType, execFunction, makeSlots, useEmits, useExpose, useProps, useRender } from \"@fast-china/utils\";\nimport { isBoolean } from \"lodash-unified\";\nimport type { VNode } from \"vue\";\n\nexport const faDrawerProps = {\n\t...drawerProps,\n\t/** @description whether to append Dialog itself to body. A nested Dialog should have this attribute set to `true` */\n\tappendToBody: {\n\t\ttype: Boolean,\n\t\tdefault: true,\n\t},\n\t/** @description enable dragging feature for Dialog */\n\tdraggable: {\n\t\ttype: Boolean,\n\t\tdefault: true,\n\t},\n\t/** @description destroy elements in Dialog when closed */\n\tdestroyOnClose: {\n\t\ttype: Boolean,\n\t\tdefault: true,\n\t},\n\t/** @description 显示刷新按钮 */\n\tshowRefresh: {\n\t\ttype: Boolean,\n\t\tdefault: true,\n\t},\n\t/** @description 显示全屏图标 */\n\tshowFullscreen: {\n\t\ttype: Boolean,\n\t\tdefault: true,\n\t},\n\t/** @description 显示关闭按钮 */\n\tshowCloseButton: {\n\t\ttype: Boolean,\n\t\tdefault: true,\n\t},\n\t/** @description 显示确认按钮 */\n\tshowConfirmButton: {\n\t\ttype: Boolean,\n\t\tdefault: true,\n\t},\n\t/** @description 禁用确认按钮 */\n\tdisabledConfirmButton: Boolean,\n\t/** @description 关闭按钮文字,默认取消 */\n\tcloseButtonText: {\n\t\ttype: String,\n\t\tdefault: \"取消\",\n\t},\n\t/** @description 确认按钮文字,默认确认 */\n\tconfirmButtonText: {\n\t\ttype: String,\n\t\tdefault: \"确认\",\n\t},\n\t/** @description 隐藏底部操作 */\n\thideFooter: Boolean,\n\t/** @description 显示关闭回调 */\n\tshowBeforeClose: Boolean,\n\t/** @description 打开之后 */\n\tafterOpen: {\n\t\ttype: definePropType<() => void>(Function),\n\t},\n};\n\nexport const faDrawerEmits = {\n\t...drawerEmits,\n\t/** @description v-model 回调 */\n\t\"update:modelValue\": (value: boolean): boolean => isBoolean(value),\n\t/** @description 确认按钮点击事件 */\n\tconfirmClick: (): boolean => true,\n};\n\ntype FaDrawerSlots = {\n\t/** @description 默认内容插槽 */\n\tdefault: { loading: boolean };\n\t/** @description 头部插槽 */\n\theader: { loading: boolean; close: () => void };\n\t/** @description 底部插槽 */\n\tfooter: { loading: boolean; close: () => void };\n};\n\nexport default defineComponent({\n\tname: \"FaDrawer\",\n\tprops: faDrawerProps,\n\temits: faDrawerEmits,\n\tslots: makeSlots<FaDrawerSlots>(),\n\tsetup(props, { attrs, slots, emit, expose }) {\n\t\tconst _globalSize = useGlobalSize();\n\n\t\tconst state = reactive({\n\t\t\tloading: false,\n\t\t\tvisible: false,\n\t\t\tfullscreen: false,\n\t\t\tsize: props.size ?? \"30%\",\n\t\t\tdragging: false,\n\t\t\trefreshing: false,\n\t\t});\n\n\t\tconst drawerRef = ref<InstanceType<typeof ElDrawer>>();\n\n\t\tlet cacheOpenFunction = undefined;\n\n\t\tconst handleOpen = (openFunction?: () => void | Promise<void>): void => {\n\t\t\tstate.visible = true;\n\t\t\tcacheOpenFunction = openFunction;\n\t\t\tnextTick(() => {\n\t\t\t\tstate.loading = true;\n\t\t\t\texecFunction(props.afterOpen ?? openFunction)\n\t\t\t\t\t.then(() => {\n\t\t\t\t\t\temit(\"open\");\n\t\t\t\t\t})\n\t\t\t\t\t.catch((error) => {\n\t\t\t\t\t\tconsoleError(\"FaDrawer\", error);\n\t\t\t\t\t\t// 自动关闭\n\t\t\t\t\t\tstate.visible = false;\n\t\t\t\t\t})\n\t\t\t\t\t.finally(() => {\n\t\t\t\t\t\tstate.loading = false;\n\t\t\t\t\t});\n\t\t\t});\n\t\t};\n\n\t\tconst handleClose = (closeFunction?: () => void | Promise<void>): void => {\n\t\t\tstate.loading = true;\n\t\t\texecFunction(closeFunction)\n\t\t\t\t.then(() => {\n\t\t\t\t\temit(\"close\");\n\t\t\t\t\tstate.visible = false;\n\t\t\t\t})\n\t\t\t\t.catch((error) => {\n\t\t\t\t\tconsoleError(\"FaDrawer\", error);\n\t\t\t\t})\n\t\t\t\t.finally(() => {\n\t\t\t\t\tstate.loading = false;\n\t\t\t\t});\n\t\t};\n\n\t\tconst handleLoading = (loadingFunction: () => void | Promise<void>): void => {\n\t\t\tstate.loading = true;\n\t\t\texecFunction(loadingFunction)\n\t\t\t\t.then()\n\t\t\t\t.catch((error) => {\n\t\t\t\t\tconsoleError(\"FaDrawer\", error);\n\t\t\t\t})\n\t\t\t\t.finally(() => {\n\t\t\t\t\tstate.loading = false;\n\t\t\t\t});\n\t\t};\n\n\t\tconst handleRefresh = (): void => {\n\t\t\tstate.refreshing = true;\n\t\t\tstate.loading = true;\n\t\t\tsetTimeout(() => {\n\t\t\t\tstate.refreshing = false;\n\t\t\t\thandleOpen(cacheOpenFunction);\n\t\t\t\tElMessage.success(\"刷新成功\");\n\t\t\t}, 500);\n\t\t};\n\n\t\tconst handleBeforeClose = (done: () => void): void => {\n\t\t\tif (state.loading) return;\n\t\t\t// 解决 image 预览摁下 ese 会关闭弹窗的问题\n\t\t\tif (document.querySelector(\".el-image-viewer__wrapper\")) return;\n\n\t\t\tconst newDone = (): void => {\n\t\t\t\texecFunction(props.beforeClose)\n\t\t\t\t\t.then(() => {\n\t\t\t\t\t\temit(\"close\");\n\t\t\t\t\t\tdone();\n\t\t\t\t\t})\n\t\t\t\t\t.catch((error) => {\n\t\t\t\t\t\tconsoleError(\"FaDialog\", error);\n\t\t\t\t\t});\n\t\t\t};\n\n\t\t\tif (props.showBeforeClose) {\n\t\t\t\tElMessageBox.confirm(\"确定关闭?\", { type: \"warning\" }).then(() => {\n\t\t\t\t\tnewDone();\n\t\t\t\t});\n\t\t\t} else {\n\t\t\t\tnewDone();\n\t\t\t}\n\t\t};\n\n\t\tconst handleFullscreen = (): void => {\n\t\t\tif (state.loading) return;\n\t\t\tstate.fullscreen = !state.fullscreen;\n\t\t};\n\n\t\tconst handleConfirmClick = (): void => {\n\t\t\tif (state.loading) return;\n\t\t\temit(\"confirmClick\");\n\t\t};\n\n\t\tconst handleCloseClick = (): void => {\n\t\t\tif (state.loading) return;\n\t\t\thandleClose();\n\t\t};\n\n\t\twatch(\n\t\t\t() => state.visible,\n\t\t\t(newValue) => {\n\t\t\t\temit(\"update:modelValue\", newValue);\n\t\t\t}\n\t\t);\n\n\t\t/**\n\t\t * 处理拖拽\n\t\t */\n\t\tconst handleDraggableMousedown = (): void => {\n\t\t\tdocument.onmousemove = (moveEvent: MouseEvent): void => {\n\t\t\t\t// 获取鼠标距离浏览器右边缘的距离\n\t\t\t\tlet realWidth = document.body.clientWidth - moveEvent.pageX;\n\t\t\t\tconst width20 = document.body.clientWidth * 0.2;\n\t\t\t\tconst width95 = document.body.clientWidth * 0.95;\n\t\t\t\t// 宽度不能大于浏览器宽度 95%,不能小于宽度的 20%\n\t\t\t\trealWidth = realWidth > width95 ? width95 : realWidth < width20 ? width20 : realWidth;\n\t\t\t\tstate.size = `${realWidth}px`;\n\t\t\t};\n\t\t\tdocument.onmouseup = (): void => {\n\t\t\t\tdocument.onmousemove = document.onmouseup = null;\n\t\t\t};\n\t\t};\n\n\t\tconst elDrawerProps = useProps(props, drawerProps, [\"modelValue\", \"size\", \"showClose\", \"beforeClose\"]);\n\t\tconst elDrawerEmits = useEmits(drawerEmits, emit, [\"update:modelValue\"]);\n\n\t\tuseRender(() => (\n\t\t\t<ElDrawer\n\t\t\t\t{...elDrawerProps.value}\n\t\t\t\t{...elDrawerEmits.value}\n\t\t\t\tref={drawerRef}\n\t\t\t\tclass={[\"fa-drawer\", `fa-drawer-${_globalSize.value}`, { \"fa-drawer__fullscreen\": state.fullscreen }]}\n\t\t\t\tvModel={state.visible}\n\t\t\t\tsize={state.size}\n\t\t\t\tshowClose={false}\n\t\t\t\tbeforeClose={handleBeforeClose}\n\t\t\t>\n\t\t\t\t{{\n\t\t\t\t\theader: () => (\n\t\t\t\t\t\t<Fragment>\n\t\t\t\t\t\t\t<div class=\"fa-drawer__header-title\">\n\t\t\t\t\t\t\t\t{props.title}\n\t\t\t\t\t\t\t\t{slots.header && slots.header({ loading: state.loading, close: handleCloseClick })}\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t{props.showRefresh && (\n\t\t\t\t\t\t\t\t<div\n\t\t\t\t\t\t\t\t\ttitle=\"刷新\"\n\t\t\t\t\t\t\t\t\tclass={[\n\t\t\t\t\t\t\t\t\t\t\"fa-drawer__header-icon\",\n\t\t\t\t\t\t\t\t\t\tstate.loading ? \"fa__click__disabled fa__click__disabled__cursor \" : \"fa__hover__twinkle\",\n\t\t\t\t\t\t\t\t\t]}\n\t\t\t\t\t\t\t\t\tonClick={handleRefresh}\n\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t<ElIcon class=\"icon\">\n\t\t\t\t\t\t\t\t\t\t<Refresh />\n\t\t\t\t\t\t\t\t\t</ElIcon>\n\t\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t\t{props.showFullscreen && (\n\t\t\t\t\t\t\t\t<div\n\t\t\t\t\t\t\t\t\ttitle={state.fullscreen ? \"关闭全屏显示\" : \"全屏显示\"}\n\t\t\t\t\t\t\t\t\tclass={[\n\t\t\t\t\t\t\t\t\t\t\"fa-drawer__header-icon\",\n\t\t\t\t\t\t\t\t\t\tstate.loading ? \"fa__click__disabled fa__click__disabled__cursor \" : \"fa__hover__twinkle\",\n\t\t\t\t\t\t\t\t\t]}\n\t\t\t\t\t\t\t\t\tonClick={handleFullscreen}\n\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t<ElIcon>{state.fullscreen ? <FullScreenExit /> : <FullScreen />}</ElIcon>\n\t\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t\t{props.showClose && (\n\t\t\t\t\t\t\t\t<div\n\t\t\t\t\t\t\t\t\ttitle=\"关闭\"\n\t\t\t\t\t\t\t\t\tclass={[\n\t\t\t\t\t\t\t\t\t\t\"fa-drawer__header-icon\",\n\t\t\t\t\t\t\t\t\t\tstate.loading ? \"fa__click__disabled fa__click__disabled__cursor \" : \"fa__hover__twinkle\",\n\t\t\t\t\t\t\t\t\t]}\n\t\t\t\t\t\t\t\t\tonClick={handleCloseClick}\n\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t<ElIcon class=\"icon\">\n\t\t\t\t\t\t\t\t\t\t<Close />\n\t\t\t\t\t\t\t\t\t</ElIcon>\n\t\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t</Fragment>\n\t\t\t\t\t),\n\t\t\t\t\tdefault: () => (\n\t\t\t\t\t\t<Fragment>\n\t\t\t\t\t\t\t{props.draggable && <div class=\"fa-drawer__draggable\" onmousedown={handleDraggableMousedown} />}\n\t\t\t\t\t\t\t<ElScrollbar vLoading={state.loading} element-loading-text=\"加载中...\">\n\t\t\t\t\t\t\t\t{!state.refreshing && slots.default && slots.default(state)}\n\t\t\t\t\t\t\t</ElScrollbar>\n\t\t\t\t\t\t</Fragment>\n\t\t\t\t\t),\n\t\t\t\t\t...(!props.hideFooter && {\n\t\t\t\t\t\tfooter: (): VNode[] => (\n\t\t\t\t\t\t\t<Fragment>\n\t\t\t\t\t\t\t\t{slots.footer && slots.footer({ loading: state.loading, close: handleCloseClick })}\n\t\t\t\t\t\t\t\t{props.showCloseButton && (\n\t\t\t\t\t\t\t\t\t<ElButton disabled={state.loading} onClick={handleCloseClick}>\n\t\t\t\t\t\t\t\t\t\t{props.closeButtonText}\n\t\t\t\t\t\t\t\t\t</ElButton>\n\t\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t\t\t{props.showConfirmButton && (\n\t\t\t\t\t\t\t\t\t<ElButton\n\t\t\t\t\t\t\t\t\t\tloading={state.loading}\n\t\t\t\t\t\t\t\t\t\tloadingIcon={Eleme}\n\t\t\t\t\t\t\t\t\t\tdisabled={props.disabledConfirmButton}\n\t\t\t\t\t\t\t\t\t\ttype=\"primary\"\n\t\t\t\t\t\t\t\t\t\tonClick={handleConfirmClick}\n\t\t\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t\t\t{state.loading ? \"加载中...\" : props.confirmButtonText}\n\t\t\t\t\t\t\t\t\t</ElButton>\n\t\t\t\t\t\t\t\t)}\n\t\t\t\t\t\t\t</Fragment>\n\t\t\t\t\t\t),\n\t\t\t\t\t}),\n\t\t\t\t}}\n\t\t\t</ElDrawer>\n\t\t));\n\n\t\treturn useExpose(expose, {\n\t\t\t/** @description 用于关闭 Drawer, 该方法会调用传入的 before-close 方法 */\n\t\t\thandleClose: computed(() => drawerRef.value?.handleClose),\n\t\t\t/** @description 进入动画后的回调 */\n\t\t\tafterEnter: computed(() => drawerRef.value?.afterEnter),\n\t\t\t/** @description 离开动画后的回调 */\n\t\t\tafterLeave: computed(() => drawerRef.value?.afterLeave),\n\t\t\t/** @description 加载状态 */\n\t\t\tloading: computed(() => state.loading),\n\t\t\t/** @description 是否显示 */\n\t\t\tvisible: computed(() => state.visible),\n\t\t\t/** @description 打开弹窗 */\n\t\t\topen: handleOpen,\n\t\t\t/** @description 关闭弹窗 */\n\t\t\tclose: handleClose,\n\t\t\t/** @description 刷新弹窗 */\n\t\t\trefresh: handleRefresh,\n\t\t\t/** @description 弹窗加载 */\n\t\t\tdoLoading: handleLoading,\n\t\t});\n\t},\n});\n"],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- import{withInstall as m,withNoopInstall as r}from"@fast-china/utils";import o from"./src/form.mjs";import{faFormProps as t}from"./src/form.mjs";import s from"./src/formItem.mjs";import{faFormItemProps as f}from"./src/formItem.mjs";import{formUtil as i}from"./utils/form.mjs";const p=m(o,{FormItem:s}),c=r(s);export{p as FaForm,c as FaFormItem,p as default,f as faFormItemProps,t as faFormProps,i as formUtil};
2
- //# sourceMappingURL=index.mjs.map
1
+ import{formUtil as m}from"./utils/form.mjs";import r,{faFormProps as o}from"./src/form.mjs";import t,{faFormItemProps as f}from"./src/formItem.mjs";import{withInstall as s,withNoopInstall as i}from"@fast-china/utils";var a=s(r,{FormItem:t}),p=i(t);export{p as FaFormItem,a as default};
2
+ //# sourceMappingURL=index.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.mjs","sources":["../../../../packages/components/form/index.ts"],"sourcesContent":["import { withInstall, withNoopInstall } from \"@fast-china/utils\";\nimport Form, { faFormProps } from \"./src/form\";\nimport FormItem, { faFormItemProps } from \"./src/formItem\";\nimport type { ExtractPropTypes } from \"vue\";\n\nexport const FaForm = withInstall(Form, {\n\tFormItem,\n});\nexport default FaForm;\n\nexport const FaFormItem = withNoopInstall(FormItem);\n\nexport { faFormProps, faFormItemProps };\n\nexport type FaFormInstance = InstanceType<typeof Form>;\n\nexport type FaFormProps = ExtractPropTypes<typeof faFormProps>;\n\nexport type FaFormItemInstance = InstanceType<typeof FormItem>;\n\nexport type FaFormItemProps = ExtractPropTypes<typeof faFormItemProps>;\n\nexport * from \"./utils/form\";\n"],"names":["FaForm","withInstall","Form","FormItem","FaFormItem","withNoopInstall"],"mappings":"mRAKO,MAAMA,EAASC,EAAYC,EAAM,CACvCC,aAIYC,EAAaC,EAAgBF"}
1
+ {"version":3,"file":"index.mjs","names":[],"sources":["../../../../packages/components/form/index.ts"],"sourcesContent":["import { withInstall, withNoopInstall } from \"@fast-china/utils\";\nimport Form, { faFormProps } from \"./src/form\";\nimport FormItem, { faFormItemProps } from \"./src/formItem\";\nimport type { ExtractPropTypes } from \"vue\";\n\nexport const FaForm = withInstall(Form, {\n\tFormItem,\n});\nexport default FaForm;\n\nexport const FaFormItem = withNoopInstall(FormItem);\n\nexport { faFormProps, faFormItemProps };\n\nexport type FaFormInstance = InstanceType<typeof Form>;\n\nexport type FaFormProps = ExtractPropTypes<typeof faFormProps>;\n\nexport type FaFormItemInstance = InstanceType<typeof FormItem>;\n\nexport type FaFormItemProps = ExtractPropTypes<typeof faFormItemProps>;\n\nexport * from \"./utils/form\";\n"],"mappings":"yNAKA,IAAa,EAAS,EAAY,EAAM,CACvC,SAAA,IAIY,EAAa,EAAgB"}
@@ -30,12 +30,12 @@ export declare const faFormProps: {
30
30
  };
31
31
  model: ObjectConstructor;
32
32
  rules: {
33
- readonly type: import('vue').PropType<Partial<Record<string, import('element-plus/es/utils/typescript.mjs').Arrayable<import('element-plus').FormItemRule>>>>;
33
+ readonly type: import('vue').PropType<Partial<Record<string, Record<string, any> | import('element-plus/es/utils/typescript.mjs').Arrayable<import('element-plus').FormItemRule>>>>;
34
34
  readonly required: false;
35
35
  readonly validator: ((val: unknown) => boolean) | undefined;
36
36
  __epPropKey: true;
37
37
  };
38
- labelPosition: import('element-plus/es/utils/index.mjs').EpPropFinalized<StringConstructor, "left" | "right" | "top", unknown, "right", boolean>;
38
+ labelPosition: import('element-plus/es/utils/index.mjs').EpPropFinalized<StringConstructor, "top" | "left" | "right", unknown, "right", boolean>;
39
39
  requireAsteriskPosition: import('element-plus/es/utils/index.mjs').EpPropFinalized<StringConstructor, "left" | "right", unknown, "left", boolean>;
40
40
  inline: BooleanConstructor;
41
41
  inlineMessage: BooleanConstructor;
@@ -43,9 +43,9 @@ export declare const faFormProps: {
43
43
  showMessage: import('element-plus/es/utils/index.mjs').EpPropFinalized<BooleanConstructor, unknown, unknown, true, boolean>;
44
44
  validateOnRuleChange: import('element-plus/es/utils/index.mjs').EpPropFinalized<BooleanConstructor, unknown, unknown, true, boolean>;
45
45
  hideRequiredAsterisk: BooleanConstructor;
46
- scrollIntoViewOptions: import('element-plus/es/utils/index.mjs').EpPropFinalized<(new (...args: any[]) => boolean | ScrollIntoViewOptions) | (() => boolean | ScrollIntoViewOptions) | ((new (...args: any[]) => boolean | ScrollIntoViewOptions) | (() => boolean | ScrollIntoViewOptions))[], unknown, unknown, true, boolean>;
46
+ scrollIntoViewOptions: import('element-plus/es/utils/index.mjs').EpPropFinalized<(new (...args: any[]) => boolean | ScrollIntoViewOptions) | (() => boolean | ScrollIntoViewOptions) | (((new (...args: any[]) => boolean | ScrollIntoViewOptions) | (() => boolean | ScrollIntoViewOptions)) | null)[], unknown, unknown, true, boolean>;
47
47
  size: {
48
- readonly type: import('vue').PropType<import('element-plus/es/utils/index.mjs').EpPropMergeType<StringConstructor, "" | "small" | "default" | "large", unknown>>;
48
+ readonly type: import('vue').PropType<import('element-plus/es/utils/index.mjs').EpPropMergeType<StringConstructor, "" | "default" | "small" | "large", unknown>>;
49
49
  readonly required: false;
50
50
  readonly validator: ((val: unknown) => boolean) | undefined;
51
51
  __epPropKey: true;
@@ -86,12 +86,12 @@ declare const _default: import('vue').DefineComponent<import('vue').ExtractPropT
86
86
  };
87
87
  model: ObjectConstructor;
88
88
  rules: {
89
- readonly type: import('vue').PropType<Partial<Record<string, import('element-plus/es/utils/typescript.mjs').Arrayable<import('element-plus').FormItemRule>>>>;
89
+ readonly type: import('vue').PropType<Partial<Record<string, Record<string, any> | import('element-plus/es/utils/typescript.mjs').Arrayable<import('element-plus').FormItemRule>>>>;
90
90
  readonly required: false;
91
91
  readonly validator: ((val: unknown) => boolean) | undefined;
92
92
  __epPropKey: true;
93
93
  };
94
- labelPosition: import('element-plus/es/utils/index.mjs').EpPropFinalized<StringConstructor, "left" | "right" | "top", unknown, "right", boolean>;
94
+ labelPosition: import('element-plus/es/utils/index.mjs').EpPropFinalized<StringConstructor, "top" | "left" | "right", unknown, "right", boolean>;
95
95
  requireAsteriskPosition: import('element-plus/es/utils/index.mjs').EpPropFinalized<StringConstructor, "left" | "right", unknown, "left", boolean>;
96
96
  inline: BooleanConstructor;
97
97
  inlineMessage: BooleanConstructor;
@@ -99,9 +99,9 @@ declare const _default: import('vue').DefineComponent<import('vue').ExtractPropT
99
99
  showMessage: import('element-plus/es/utils/index.mjs').EpPropFinalized<BooleanConstructor, unknown, unknown, true, boolean>;
100
100
  validateOnRuleChange: import('element-plus/es/utils/index.mjs').EpPropFinalized<BooleanConstructor, unknown, unknown, true, boolean>;
101
101
  hideRequiredAsterisk: BooleanConstructor;
102
- scrollIntoViewOptions: import('element-plus/es/utils/index.mjs').EpPropFinalized<(new (...args: any[]) => boolean | ScrollIntoViewOptions) | (() => boolean | ScrollIntoViewOptions) | ((new (...args: any[]) => boolean | ScrollIntoViewOptions) | (() => boolean | ScrollIntoViewOptions))[], unknown, unknown, true, boolean>;
102
+ scrollIntoViewOptions: import('element-plus/es/utils/index.mjs').EpPropFinalized<(new (...args: any[]) => boolean | ScrollIntoViewOptions) | (() => boolean | ScrollIntoViewOptions) | (((new (...args: any[]) => boolean | ScrollIntoViewOptions) | (() => boolean | ScrollIntoViewOptions)) | null)[], unknown, unknown, true, boolean>;
103
103
  size: {
104
- readonly type: import('vue').PropType<import('element-plus/es/utils/index.mjs').EpPropMergeType<StringConstructor, "" | "small" | "default" | "large", unknown>>;
104
+ readonly type: import('vue').PropType<import('element-plus/es/utils/index.mjs').EpPropMergeType<StringConstructor, "" | "default" | "small" | "large", unknown>>;
105
105
  readonly required: false;
106
106
  readonly validator: ((val: unknown) => boolean) | undefined;
107
107
  __epPropKey: true;
@@ -152,12 +152,12 @@ declare const _default: import('vue').DefineComponent<import('vue').ExtractPropT
152
152
  };
153
153
  model: ObjectConstructor;
154
154
  rules: {
155
- readonly type: import('vue').PropType<Partial<Record<string, import('element-plus/es/utils/typescript.mjs').Arrayable<import('element-plus').FormItemRule>>>>;
155
+ readonly type: import('vue').PropType<Partial<Record<string, Record<string, any> | import('element-plus/es/utils/typescript.mjs').Arrayable<import('element-plus').FormItemRule>>>>;
156
156
  readonly required: false;
157
157
  readonly validator: ((val: unknown) => boolean) | undefined;
158
158
  __epPropKey: true;
159
159
  };
160
- labelPosition: import('element-plus/es/utils/index.mjs').EpPropFinalized<StringConstructor, "left" | "right" | "top", unknown, "right", boolean>;
160
+ labelPosition: import('element-plus/es/utils/index.mjs').EpPropFinalized<StringConstructor, "top" | "left" | "right", unknown, "right", boolean>;
161
161
  requireAsteriskPosition: import('element-plus/es/utils/index.mjs').EpPropFinalized<StringConstructor, "left" | "right", unknown, "left", boolean>;
162
162
  inline: BooleanConstructor;
163
163
  inlineMessage: BooleanConstructor;
@@ -165,9 +165,9 @@ declare const _default: import('vue').DefineComponent<import('vue').ExtractPropT
165
165
  showMessage: import('element-plus/es/utils/index.mjs').EpPropFinalized<BooleanConstructor, unknown, unknown, true, boolean>;
166
166
  validateOnRuleChange: import('element-plus/es/utils/index.mjs').EpPropFinalized<BooleanConstructor, unknown, unknown, true, boolean>;
167
167
  hideRequiredAsterisk: BooleanConstructor;
168
- scrollIntoViewOptions: import('element-plus/es/utils/index.mjs').EpPropFinalized<(new (...args: any[]) => boolean | ScrollIntoViewOptions) | (() => boolean | ScrollIntoViewOptions) | ((new (...args: any[]) => boolean | ScrollIntoViewOptions) | (() => boolean | ScrollIntoViewOptions))[], unknown, unknown, true, boolean>;
168
+ scrollIntoViewOptions: import('element-plus/es/utils/index.mjs').EpPropFinalized<(new (...args: any[]) => boolean | ScrollIntoViewOptions) | (() => boolean | ScrollIntoViewOptions) | (((new (...args: any[]) => boolean | ScrollIntoViewOptions) | (() => boolean | ScrollIntoViewOptions)) | null)[], unknown, unknown, true, boolean>;
169
169
  size: {
170
- readonly type: import('vue').PropType<import('element-plus/es/utils/index.mjs').EpPropMergeType<StringConstructor, "" | "small" | "default" | "large", unknown>>;
170
+ readonly type: import('vue').PropType<import('element-plus/es/utils/index.mjs').EpPropMergeType<StringConstructor, "" | "default" | "small" | "large", unknown>>;
171
171
  readonly required: false;
172
172
  readonly validator: ((val: unknown) => boolean) | undefined;
173
173
  __epPropKey: true;
@@ -175,7 +175,9 @@ declare const _default: import('vue').DefineComponent<import('vue').ExtractPropT
175
175
  disabled: BooleanConstructor;
176
176
  }>> & Readonly<{}>, {
177
177
  disabled: boolean;
178
- labelPosition: import('element-plus/es/utils/index.mjs').EpPropMergeType<StringConstructor, "top" | "left" | "right", unknown>;
178
+ cols: string | number | Record<FaLayoutGridBreakPoint, number>;
179
+ grid: boolean;
180
+ labelPosition: import('element-plus/es/utils/index.mjs').EpPropMergeType<StringConstructor, "left" | "right" | "top", unknown>;
179
181
  requireAsteriskPosition: import('element-plus/es/utils/index.mjs').EpPropMergeType<StringConstructor, "left" | "right", unknown>;
180
182
  labelWidth: string | number;
181
183
  labelSuffix: string;
@@ -187,8 +189,6 @@ declare const _default: import('vue').DefineComponent<import('vue').ExtractPropT
187
189
  hideRequiredAsterisk: boolean;
188
190
  scrollToError: boolean;
189
191
  scrollIntoViewOptions: true;
190
- cols: string | number | Record<FaLayoutGridBreakPoint, number>;
191
- grid: boolean;
192
192
  detailForm: boolean;
193
193
  }, import('vue').SlotsType<Partial<import('@fast-china/utils').MakeSlots<FaFormSlots>>>, {}, {}, string, import('vue').ComponentProvideOptions, true, {}, any>;
194
194
  export default _default;
@@ -1,2 +1,2 @@
1
- import{defineComponent as l,reactive as e,computed as a,ref as o,provide as t,createVNode as r,mergeProps as s}from"vue";import{formProps as d,useGlobalSize as i,ElForm as f}from"element-plus";import{FaLayoutGrid as u}from"../../layoutGrid/index.mjs";import{definePropType as m,useProps as c,useRender as p,useExpose as n,makeSlots as v}from"@fast-china/utils";import{isObject as F,isNumber as g}from"lodash-unified";import{formUtil as x}from"../utils/form.mjs";const b={...d,labelWidth:{type:[String,Number],default:"auto"},labelSuffix:{type:String,default:":"},scrollToError:{type:Boolean,default:!0},detailForm:Boolean,grid:{type:Boolean,default:!0},cols:{type:m([String,Number,Object]),default:()=>({xs:1,sm:2,md:3,lg:4,xl:5})}},y=/* @__PURE__ */l({name:"FaForm",props:b,slots:v(),setup(l,{attrs:m,slots:v,emit:b,expose:y}){const S=i(),T=e({cols:a(()=>{if(F(l.cols))return l.cols;{const e=g(l.cols)?l.cols:Number(l.cols);return{xs:1,sm:e,md:e,lg:e,xl:e}}}),gap:a(()=>"small"===S.value?[15,0]:[20,0])}),h=o();t("faFormCols",T.cols);const j=c(l,d);return p(()=>r(f,s(j.value,{ref:h,class:["fa-form",`fa-form-${S.value}`,{[`fa-form-detail fa-form-detail_${S.value}`]:l.detailForm}]}),{default:()=>l.grid?r(u,{collapsed:!0,gap:T.gap,cols:T.cols},{default:()=>[v.default&&v.default(T)]}):v.default&&v.default(T)})),n(y,{validate:()=>x.validate(h),validateField:a(()=>h.value?.validateField),resetFields:a(()=>h.value?.resetFields),clearValidate:a(()=>h.value?.clearValidate),scrollToField:a(()=>h.value?.scrollToField),fields:a(()=>h.value?.fields),validateScrollToField:()=>x.validateScrollToField(h)})}});export{y as default,b as faFormProps};
2
- //# sourceMappingURL=form.mjs.map
1
+ import l from"../../layoutGrid/index.mjs";import{formUtil as e}from"../utils/form.mjs";import{definePropType as a,makeSlots as o,useExpose as t,useProps as r,useRender as s}from"@fast-china/utils";import{computed as d,createVNode as i,defineComponent as f,mergeProps as u,provide as m,reactive as c,ref as p}from"vue";import{ElForm as n,formProps as v,useGlobalSize as F}from"element-plus";import{isNumber as g,isObject as x}from"lodash-unified";var b={...v,labelWidth:{type:[String,Number],default:"auto"},labelSuffix:{type:String,default:":"},scrollToError:{type:Boolean,default:!0},detailForm:Boolean,grid:{type:Boolean,default:!0},cols:{type:a([String,Number,Object]),default:()=>({xs:1,sm:2,md:3,lg:4,xl:5})}},y=/* @__PURE__ */f({name:"FaForm",props:b,slots:o(),setup(a,{attrs:o,slots:f,emit:b,expose:y}){const S=F(),T=c({cols:d(()=>{if(x(a.cols))return a.cols;{const l=g(a.cols)?a.cols:Number(a.cols);return{xs:1,sm:l,md:l,lg:l,xl:l}}}),gap:d(()=>"small"===S.value?[15,0]:[20,0])}),h=p();m("faFormCols",T.cols);const j=r(a,v);return s(()=>i(n,u(j.value,{ref:h,class:["fa-form",`fa-form-${S.value}`,{[`fa-form-detail fa-form-detail_${S.value}`]:a.detailForm}]}),{default:()=>a.grid?i(l,{collapsed:!0,gap:T.gap,cols:T.cols},{default:()=>[f.default&&f.default(T)]}):f.default&&f.default(T)})),t(y,{validate:()=>e.validate(h),validateField:d(()=>h.value?.validateField),resetFields:d(()=>h.value?.resetFields),clearValidate:d(()=>h.value?.clearValidate),scrollToField:d(()=>h.value?.scrollToField),fields:d(()=>h.value?.fields),validateScrollToField:()=>e.validateScrollToField(h)})}});export{y as default,b as faFormProps};
2
+ //# sourceMappingURL=form.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"form.mjs","sources":["../../../../../packages/components/form/src/form.tsx"],"sourcesContent":["import { computed, defineComponent, provide, reactive, ref } from \"vue\";\nimport { ElForm, formProps, useGlobalSize } from \"element-plus\";\nimport { FaLayoutGrid } from \"@fast-element-plus/components/layoutGrid\";\nimport { definePropType, makeSlots, useExpose, useProps, useRender } from \"@fast-china/utils\";\nimport { isNumber, isObject } from \"lodash-unified\";\nimport { formUtil } from \"../utils/form\";\nimport type { FaLayoutGridBreakPoint } from \"@fast-element-plus/components/layoutGrid\";\nimport type { FormInstance, FormItemContext, FormValidationResult } from \"element-plus\";\n\nexport const faFormProps = {\n\t...formProps,\n\t/** @description Width of label, e.g. `'50px'`. All its direct child form items will inherit this value. `auto` is supported. */\n\tlabelWidth: {\n\t\ttype: [String, Number],\n\t\tdefault: \"auto\",\n\t},\n\t/** @description Suffix of the label. */\n\tlabelSuffix: {\n\t\ttype: String,\n\t\tdefault: \":\",\n\t},\n\t/** @description When validation fails, scroll to the first error form entry. */\n\tscrollToError: {\n\t\ttype: Boolean,\n\t\tdefault: true,\n\t},\n\t/** @description 详情From,会删除 FormItem 的 paddinfa-bottom */\n\tdetailForm: Boolean,\n\t/** @description Grid布局*/\n\tgrid: {\n\t\ttype: Boolean,\n\t\tdefault: true,\n\t},\n\t/** @description Grid布局列配置 */\n\tcols: {\n\t\ttype: definePropType<string | number | Record<FaLayoutGridBreakPoint, number>>([String, Number, Object]),\n\t\tdefault: (): Record<FaLayoutGridBreakPoint, number> => ({ xs: 1, sm: 2, md: 3, lg: 4, xl: 5 }),\n\t},\n};\n\ntype FaFormSlots = {\n\t/** @description 默认内容插槽 */\n\tdefault: unknown;\n};\n\nexport default defineComponent({\n\tname: \"FaForm\",\n\tprops: faFormProps,\n\tslots: makeSlots<FaFormSlots>(),\n\tsetup(props, { attrs, slots, emit, expose }) {\n\t\tconst _globalSize = useGlobalSize();\n\n\t\tconst state = reactive({\n\t\t\tcols: computed(() => {\n\t\t\t\tif (isObject(props.cols)) {\n\t\t\t\t\treturn props.cols;\n\t\t\t\t} else {\n\t\t\t\t\tconst colsNumber = isNumber(props.cols) ? props.cols : Number(props.cols);\n\t\t\t\t\treturn { xs: 1, sm: colsNumber, md: colsNumber, lg: colsNumber, xl: colsNumber };\n\t\t\t\t}\n\t\t\t}),\n\t\t\tgap: computed(() => (_globalSize.value === \"small\" ? [15, 0] : [20, 0])),\n\t\t});\n\n\t\tconst formRef = ref<FormInstance>();\n\n\t\t// 注入 cols\n\t\tprovide(\"faFormCols\", state.cols);\n\n\t\tconst elFormProps = useProps(props, formProps);\n\n\t\tuseRender(() => (\n\t\t\t<ElForm\n\t\t\t\t{...elFormProps.value}\n\t\t\t\tref={formRef}\n\t\t\t\tclass={[\"fa-form\", `fa-form-${_globalSize.value}`, { [`fa-form-detail fa-form-detail_${_globalSize.value}`]: props.detailForm }]}\n\t\t\t>\n\t\t\t\t{{\n\t\t\t\t\tdefault: () =>\n\t\t\t\t\t\tprops.grid ? (\n\t\t\t\t\t\t\t<FaLayoutGrid collapsed gap={state.gap} cols={state.cols}>\n\t\t\t\t\t\t\t\t{slots.default && slots.default(state)}\n\t\t\t\t\t\t\t</FaLayoutGrid>\n\t\t\t\t\t\t) : (\n\t\t\t\t\t\t\tslots.default && slots.default(state)\n\t\t\t\t\t\t),\n\t\t\t\t}}\n\t\t\t</ElForm>\n\t\t));\n\n\t\treturn useExpose(expose, {\n\t\t\t/** @description 对整个表单的内容进行验证。 接收一个回调函数,或返回 Promise。 */\n\t\t\tvalidate: (): FormValidationResult => formUtil.validate(formRef),\n\t\t\t/** @description 验证具体的某个字段。 */\n\t\t\tvalidateField: computed(() => formRef.value?.validateField),\n\t\t\t/** @description 重置该表单项,将其值重置为初始值,并移除校验结果 */\n\t\t\tresetFields: computed(() => formRef.value?.resetFields),\n\t\t\t/** @description 清理某个字段的表单验证信息。 */\n\t\t\tclearValidate: computed(() => formRef.value?.clearValidate),\n\t\t\t/** @description 滚动到指定的字段 */\n\t\t\tscrollToField: computed(() => formRef.value?.scrollToField),\n\t\t\t/** @description 获取所有字段的 context */\n\t\t\tfields: computed(() => formRef.value?.fields as FormItemContext[]),\n\t\t\t/** @description 对整个表单的内容进行验证,带滚动。 接收一个回调函数,或返回 Promise。 */\n\t\t\tvalidateScrollToField: (): FormValidationResult => formUtil.validateScrollToField(formRef),\n\t\t});\n\t},\n});\n"],"names":["faFormProps","formProps","labelWidth","type","String","Number","default","labelSuffix","scrollToError","Boolean","detailForm","grid","cols","definePropType","Object","xs","sm","md","lg","xl","Form","name","props","slots","makeSlots","setup","attrs","emit","expose","_globalSize","useGlobalSize","state","reactive","computed","isObject","colsNumber","isNumber","gap","value","formRef","ref","provide","elFormProps","useProps","useRender","_createVNode","ElForm","_mergeProps","class","FaLayoutGrid","collapsed","useExpose","validate","formUtil","validateField","resetFields","clearValidate","scrollToField","fields","validateScrollToField"],"mappings":"8cASO,MAAMA,EAAc,IACvBC,EAEHC,WAAY,CACXC,KAAM,CAACC,OAAQC,QACfC,QAAS,QAGVC,YAAa,CACZJ,KAAMC,OACNE,QAAS,KAGVE,cAAe,CACdL,KAAMM,QACNH,SAAS,GAGVI,WAAYD,QAEZE,KAAM,CACLR,KAAMM,QACNH,SAAS,GAGVM,KAAM,CACLT,KAAMU,EAAyE,CAACT,OAAQC,OAAQS,SAChGR,QAASA,KAAAA,CAAiDS,GAAI,EAAGC,GAAI,EAAGC,GAAI,EAAGC,GAAI,EAAGC,GAAI,MAS5FC,mBAA+B,CAC9BC,KAAM,SACNC,MAAOtB,EACPuB,MAAOC,IACPC,KAAAA,CAAMH,GAAOI,MAAEA,EAAAA,MAAOH,EAAAA,KAAOI,EAAAA,OAAMC,IAClC,MAAMC,EAAcC,IAEdC,EAAQC,EAAS,CACtBpB,KAAMqB,EAAS,KACd,GAAIC,EAASZ,EAAMV,MAClB,OAAOU,EAAMV,KACP,CACN,MAAMuB,EAAaC,EAASd,EAAMV,MAAQU,EAAMV,KAAOP,OAAOiB,EAAMV,MACpE,MAAO,CAAEG,GAAI,EAAGC,GAAImB,EAAYlB,GAAIkB,EAAYjB,GAAIiB,EAAYhB,GAAIgB,EACrE,IAEDE,IAAKJ,EAAS,IAA6B,UAAtBJ,EAAYS,MAAoB,CAAC,GAAI,GAAK,CAAC,GAAI,MAG/DC,EAAUC,IAGhBC,EAAQ,aAAcV,EAAMnB,MAE5B,MAAM8B,EAAcC,EAASrB,EAAOrB,GAqBpC,OAnBA2C,EAAU,IAAAC,EAAAC,EAAAC,EAEJL,EAAYJ,MAAK,CAAAE,IAChBD,EAAOS,MACL,CAAC,UAAW,WAAWnB,EAAYS,QAAS,CAAE,CAAC,iCAAiCT,EAAYS,SAAUhB,EAAMZ,eAAa,CAG/HJ,QAASA,IACRgB,EAAMX,KAAIkC,EAAAI,EAAA,CAAAC,WAAA,EAAAb,IACoBN,EAAMM,IAAGzB,KAAQmB,EAAMnB,MAAI,CAAAN,QAAAA,IAAA,CACtDiB,EAAMjB,SAAWiB,EAAMjB,QAAQyB,MAGjCR,EAAMjB,SAAWiB,EAAMjB,QAAQyB,MAM7BoB,EAAUvB,EAAQ,CAExBwB,SAAUA,IAA4BC,EAASD,SAASb,GAExDe,cAAerB,EAAS,IAAMM,EAAQD,OAAOgB,eAE7CC,YAAatB,EAAS,IAAMM,EAAQD,OAAOiB,aAE3CC,cAAevB,EAAS,IAAMM,EAAQD,OAAOkB,eAE7CC,cAAexB,EAAS,IAAMM,EAAQD,OAAOmB,eAE7CC,OAAQzB,EAAS,IAAMM,EAAQD,OAAOoB,QAEtCC,sBAAuBA,IAA4BN,EAASM,sBAAsBpB,IAEpF"}
1
+ {"version":3,"file":"form.mjs","names":["computed","defineComponent","provide","reactive","ref","createVNode","_createVNode","mergeProps","_mergeProps","ElForm","formProps","useGlobalSize","FaLayoutGrid","definePropType","makeSlots","useExpose","useProps","useRender","isNumber","isObject","formUtil","faFormProps","labelWidth","type","String","Number","default","labelSuffix","scrollToError","Boolean","detailForm","grid","cols","Object","xs","sm","md","lg","xl","name","props","slots","setup","attrs","emit","expose","_globalSize","state","colsNumber","gap","value","formRef","elFormProps","validate","validateField","resetFields","clearValidate","scrollToField","fields","validateScrollToField"],"sources":["../../../../../packages/components/form/src/form.tsx"],"sourcesContent":["import { computed, defineComponent, provide, reactive, ref } from \"vue\";\nimport { ElForm, formProps, useGlobalSize } from \"element-plus\";\nimport { FaLayoutGrid } from \"@fast-element-plus/components/layoutGrid\";\nimport { definePropType, makeSlots, useExpose, useProps, useRender } from \"@fast-china/utils\";\nimport { isNumber, isObject } from \"lodash-unified\";\nimport { formUtil } from \"../utils/form\";\nimport type { FaLayoutGridBreakPoint } from \"@fast-element-plus/components/layoutGrid\";\nimport type { FormInstance, FormItemContext, FormValidationResult } from \"element-plus\";\n\nexport const faFormProps = {\n\t...formProps,\n\t/** @description Width of label, e.g. `'50px'`. All its direct child form items will inherit this value. `auto` is supported. */\n\tlabelWidth: {\n\t\ttype: [String, Number],\n\t\tdefault: \"auto\",\n\t},\n\t/** @description Suffix of the label. */\n\tlabelSuffix: {\n\t\ttype: String,\n\t\tdefault: \":\",\n\t},\n\t/** @description When validation fails, scroll to the first error form entry. */\n\tscrollToError: {\n\t\ttype: Boolean,\n\t\tdefault: true,\n\t},\n\t/** @description 详情From,会删除 FormItem 的 paddinfa-bottom */\n\tdetailForm: Boolean,\n\t/** @description Grid布局*/\n\tgrid: {\n\t\ttype: Boolean,\n\t\tdefault: true,\n\t},\n\t/** @description Grid布局列配置 */\n\tcols: {\n\t\ttype: definePropType<string | number | Record<FaLayoutGridBreakPoint, number>>([String, Number, Object]),\n\t\tdefault: (): Record<FaLayoutGridBreakPoint, number> => ({ xs: 1, sm: 2, md: 3, lg: 4, xl: 5 }),\n\t},\n};\n\ntype FaFormSlots = {\n\t/** @description 默认内容插槽 */\n\tdefault: unknown;\n};\n\nexport default defineComponent({\n\tname: \"FaForm\",\n\tprops: faFormProps,\n\tslots: makeSlots<FaFormSlots>(),\n\tsetup(props, { attrs, slots, emit, expose }) {\n\t\tconst _globalSize = useGlobalSize();\n\n\t\tconst state = reactive({\n\t\t\tcols: computed(() => {\n\t\t\t\tif (isObject(props.cols)) {\n\t\t\t\t\treturn props.cols;\n\t\t\t\t} else {\n\t\t\t\t\tconst colsNumber = isNumber(props.cols) ? props.cols : Number(props.cols);\n\t\t\t\t\treturn { xs: 1, sm: colsNumber, md: colsNumber, lg: colsNumber, xl: colsNumber };\n\t\t\t\t}\n\t\t\t}),\n\t\t\tgap: computed(() => (_globalSize.value === \"small\" ? [15, 0] : [20, 0])),\n\t\t});\n\n\t\tconst formRef = ref<FormInstance>();\n\n\t\t// 注入 cols\n\t\tprovide(\"faFormCols\", state.cols);\n\n\t\tconst elFormProps = useProps(props, formProps);\n\n\t\tuseRender(() => (\n\t\t\t<ElForm\n\t\t\t\t{...elFormProps.value}\n\t\t\t\tref={formRef}\n\t\t\t\tclass={[\"fa-form\", `fa-form-${_globalSize.value}`, { [`fa-form-detail fa-form-detail_${_globalSize.value}`]: props.detailForm }]}\n\t\t\t>\n\t\t\t\t{{\n\t\t\t\t\tdefault: () =>\n\t\t\t\t\t\tprops.grid ? (\n\t\t\t\t\t\t\t<FaLayoutGrid collapsed gap={state.gap} cols={state.cols}>\n\t\t\t\t\t\t\t\t{slots.default && slots.default(state)}\n\t\t\t\t\t\t\t</FaLayoutGrid>\n\t\t\t\t\t\t) : (\n\t\t\t\t\t\t\tslots.default && slots.default(state)\n\t\t\t\t\t\t),\n\t\t\t\t}}\n\t\t\t</ElForm>\n\t\t));\n\n\t\treturn useExpose(expose, {\n\t\t\t/** @description 对整个表单的内容进行验证。 接收一个回调函数,或返回 Promise。 */\n\t\t\tvalidate: (): FormValidationResult => formUtil.validate(formRef),\n\t\t\t/** @description 验证具体的某个字段。 */\n\t\t\tvalidateField: computed(() => formRef.value?.validateField),\n\t\t\t/** @description 重置该表单项,将其值重置为初始值,并移除校验结果 */\n\t\t\tresetFields: computed(() => formRef.value?.resetFields),\n\t\t\t/** @description 清理某个字段的表单验证信息。 */\n\t\t\tclearValidate: computed(() => formRef.value?.clearValidate),\n\t\t\t/** @description 滚动到指定的字段 */\n\t\t\tscrollToField: computed(() => formRef.value?.scrollToField),\n\t\t\t/** @description 获取所有字段的 context */\n\t\t\tfields: computed(() => formRef.value?.fields as FormItemContext[]),\n\t\t\t/** @description 对整个表单的内容进行验证,带滚动。 接收一个回调函数,或返回 Promise。 */\n\t\t\tvalidateScrollToField: (): FormValidationResult => formUtil.validateScrollToField(formRef),\n\t\t});\n\t},\n});\n"],"mappings":"8bASA,IAAaqB,EAAc,IACvBX,EAEHY,WAAY,CACXC,KAAM,CAACC,OAAQC,QACfC,QAAS,QAGVC,YAAa,CACZJ,KAAMC,OACNE,QAAS,KAGVE,cAAe,CACdL,KAAMM,QACNH,SAAS,GAGVI,WAAYD,QAEZE,KAAM,CACLR,KAAMM,QACNH,SAAS,GAGVM,KAAM,CACLT,KAAMV,EAAyE,CAACW,OAAQC,OAAQQ,SAChGP,QAAAA,KAAAA,CAA0DQ,GAAI,EAAGC,GAAI,EAAGC,GAAI,EAAGC,GAAI,EAAGC,GAAI,MAS5F,iBAAerC,EAAgB,CAC9BsC,KAAM,SACNC,MAAOnB,EACPoB,MAAO3B,IACP4B,KAAAA,CAAMF,GAAO,MAAEG,EAAAA,MAAOF,EAAAA,KAAOG,EAAAA,OAAMC,IAClC,MAAMC,EAAcnC,IAEdoC,EAAQ5C,EAAS,CACtB6B,KAAMhC,EAAAA,KACL,GAAImB,EAASqB,EAAMR,MAClB,OAAOQ,EAAMR,KACP,CACN,MAAMgB,EAAa9B,EAASsB,EAAMR,MAAQQ,EAAMR,KAAOP,OAAOe,EAAMR,MACpE,MAAO,CAAEE,GAAI,EAAGC,GAAIa,EAAYZ,GAAIY,EAAYX,GAAIW,EAAYV,GAAIU,MAGtEC,IAAKjD,EAAAA,IAAsC,UAAtB8C,EAAYI,MAAoB,CAAC,GAAI,GAAK,CAAC,GAAI,MAG/DC,EAAU/C,IAGhBF,EAAQ,aAAc6C,EAAMf,MAE5B,MAAMoB,EAAcpC,EAASwB,EAAO9B,GAqBpC,OAnBAO,EAAAA,IAAUX,EAAAG,EAAAD,EAEJ4C,EAAYF,MAAK,CAAA,IAChBC,EAAO,MACL,CAAC,UAAW,WAAWL,EAAYI,QAAS,CAAA,CAAG,iCAAiCJ,EAAYI,SAAUV,EAAMV,eAAa,CAG/HJ,QAAAA,IACCc,EAAMT,KAAIzB,EAAAM,EAAA,CAAA,WAAA,EAAA,IACoBmC,EAAME,IAAG,KAAQF,EAAMf,MAAI,CAAAN,QAAAA,IAAA,CACtDe,EAAMf,SAAWe,EAAMf,QAAQqB,MAGjCN,EAAMf,SAAWe,EAAMf,QAAQqB,MAM7BhC,EAAU8B,EAAQ,CAExBQ,SAAAA,IAAsCjC,EAASiC,SAASF,GAExDG,cAAetD,EAAAA,IAAemD,EAAQD,OAAOI,eAE7CC,YAAavD,EAAAA,IAAemD,EAAQD,OAAOK,aAE3CC,cAAexD,EAAAA,IAAemD,EAAQD,OAAOM,eAE7CC,cAAezD,EAAAA,IAAemD,EAAQD,OAAOO,eAE7CC,OAAQ1D,EAAAA,IAAemD,EAAQD,OAAOQ,QAEtCC,sBAAAA,IAAmDvC,EAASuC,sBAAsBR"}
@@ -24,16 +24,16 @@ export declare const faFormItemProps: {
24
24
  readonly validator: ((val: unknown) => boolean) | undefined;
25
25
  __epPropKey: true;
26
26
  };
27
- labelPosition: import('element-plus/es/utils/index.mjs').EpPropFinalized<StringConstructor, "" | "left" | "right" | "top", unknown, "", boolean>;
27
+ labelPosition: import('element-plus/es/utils/index.mjs').EpPropFinalized<StringConstructor, "" | "top" | "left" | "right", unknown, "", boolean>;
28
28
  prop: {
29
- readonly type: import('vue').PropType<import('element-plus/es/utils/index.mjs').EpPropMergeType<(new (...args: any[]) => string | string[]) | (() => import('element-plus').FormItemProp) | ((new (...args: any[]) => string | string[]) | (() => import('element-plus').FormItemProp))[], unknown, unknown>>;
29
+ readonly type: import('vue').PropType<import('element-plus/es/utils/index.mjs').EpPropMergeType<(new (...args: any[]) => string | string[]) | (() => import('element-plus').FormItemProp) | (((new (...args: any[]) => string | string[]) | (() => import('element-plus').FormItemProp)) | null)[], unknown, unknown>>;
30
30
  readonly required: false;
31
31
  readonly validator: ((val: unknown) => boolean) | undefined;
32
32
  __epPropKey: true;
33
33
  };
34
34
  required: import('element-plus/es/utils/index.mjs').EpPropFinalized<BooleanConstructor, unknown, unknown, undefined, boolean>;
35
35
  rules: {
36
- readonly type: import('vue').PropType<import('element-plus/es/utils/index.mjs').EpPropMergeType<(new (...args: any[]) => import('element-plus').FormItemRule | import('element-plus').FormItemRule[]) | (() => import('element-plus/es/utils/typescript.mjs').Arrayable<import('element-plus').FormItemRule>) | ((new (...args: any[]) => import('element-plus').FormItemRule | import('element-plus').FormItemRule[]) | (() => import('element-plus/es/utils/typescript.mjs').Arrayable<import('element-plus').FormItemRule>))[], unknown, unknown>>;
36
+ readonly type: import('vue').PropType<import('element-plus/es/utils/index.mjs').EpPropMergeType<(new (...args: any[]) => import('element-plus').FormItemRule | import('element-plus').FormItemRule[]) | (() => import('element-plus/es/utils/typescript.mjs').Arrayable<import('element-plus').FormItemRule>) | (((new (... /** @description 对该表单项进行重置,将其值重置为初始值并移除校验结果 */args: any[]) => import('element-plus').FormItemRule | import('element-plus').FormItemRule[]) | (() => import('element-plus/es/utils/typescript.mjs').Arrayable<import('element-plus').FormItemRule>)) | null)[], unknown, unknown>>;
37
37
  readonly required: false;
38
38
  readonly validator: ((val: unknown) => boolean) | undefined;
39
39
  __epPropKey: true;
@@ -49,7 +49,7 @@ export declare const faFormItemProps: {
49
49
  inlineMessage: import('element-plus/es/utils/index.mjs').EpPropFinalized<BooleanConstructor, unknown, unknown, undefined, boolean>;
50
50
  showMessage: import('element-plus/es/utils/index.mjs').EpPropFinalized<BooleanConstructor, unknown, unknown, true, boolean>;
51
51
  size: {
52
- readonly type: import('vue').PropType<import('element-plus/es/utils/index.mjs').EpPropMergeType<StringConstructor, "" | "small" | "default" | "large", unknown>>;
52
+ readonly type: import('vue').PropType<import('element-plus/es/utils/index.mjs').EpPropMergeType<StringConstructor, "" | "default" | "small" | "large", unknown>>;
53
53
  readonly required: false;
54
54
  readonly validator: ((val: unknown) => boolean) | undefined;
55
55
  __epPropKey: true;
@@ -93,16 +93,16 @@ declare const _default: import('vue').DefineComponent<import('vue').ExtractPropT
93
93
  readonly validator: ((val: unknown) => boolean) | undefined;
94
94
  __epPropKey: true;
95
95
  };
96
- labelPosition: import('element-plus/es/utils/index.mjs').EpPropFinalized<StringConstructor, "" | "left" | "right" | "top", unknown, "", boolean>;
96
+ labelPosition: import('element-plus/es/utils/index.mjs').EpPropFinalized<StringConstructor, "" | "top" | "left" | "right", unknown, "", boolean>;
97
97
  prop: {
98
- readonly type: import('vue').PropType<import('element-plus/es/utils/index.mjs').EpPropMergeType<(new (...args: any[]) => string | string[]) | (() => import('element-plus').FormItemProp) | ((new (...args: any[]) => string | string[]) | (() => import('element-plus').FormItemProp))[], unknown, unknown>>;
98
+ readonly type: import('vue').PropType<import('element-plus/es/utils/index.mjs').EpPropMergeType<(new (...args: any[]) => string | string[]) | (() => import('element-plus').FormItemProp) | (((new (...args: any[]) => string | string[]) | (() => import('element-plus').FormItemProp)) | null)[], unknown, unknown>>;
99
99
  readonly required: false;
100
100
  readonly validator: ((val: unknown) => boolean) | undefined;
101
101
  __epPropKey: true;
102
102
  };
103
103
  required: import('element-plus/es/utils/index.mjs').EpPropFinalized<BooleanConstructor, unknown, unknown, undefined, boolean>;
104
104
  rules: {
105
- readonly type: import('vue').PropType<import('element-plus/es/utils/index.mjs').EpPropMergeType<(new (...args: any[]) => import('element-plus').FormItemRule | import('element-plus').FormItemRule[]) | (() => import('element-plus/es/utils/typescript.mjs').Arrayable<import('element-plus').FormItemRule>) | ((new (...args: any[]) => import('element-plus').FormItemRule | import('element-plus').FormItemRule[]) | (() => import('element-plus/es/utils/typescript.mjs').Arrayable<import('element-plus').FormItemRule>))[], unknown, unknown>>;
105
+ readonly type: import('vue').PropType<import('element-plus/es/utils/index.mjs').EpPropMergeType<(new (...args: any[]) => import('element-plus').FormItemRule | import('element-plus').FormItemRule[]) | (() => import('element-plus/es/utils/typescript.mjs').Arrayable<import('element-plus').FormItemRule>) | (((new (... /** @description 对该表单项进行重置,将其值重置为初始值并移除校验结果 */args: any[]) => import('element-plus').FormItemRule | import('element-plus').FormItemRule[]) | (() => import('element-plus/es/utils/typescript.mjs').Arrayable<import('element-plus').FormItemRule>)) | null)[], unknown, unknown>>;
106
106
  readonly required: false;
107
107
  readonly validator: ((val: unknown) => boolean) | undefined;
108
108
  __epPropKey: true;
@@ -118,7 +118,7 @@ declare const _default: import('vue').DefineComponent<import('vue').ExtractPropT
118
118
  inlineMessage: import('element-plus/es/utils/index.mjs').EpPropFinalized<BooleanConstructor, unknown, unknown, undefined, boolean>;
119
119
  showMessage: import('element-plus/es/utils/index.mjs').EpPropFinalized<BooleanConstructor, unknown, unknown, true, boolean>;
120
120
  size: {
121
- readonly type: import('vue').PropType<import('element-plus/es/utils/index.mjs').EpPropMergeType<StringConstructor, "" | "small" | "default" | "large", unknown>>;
121
+ readonly type: import('vue').PropType<import('element-plus/es/utils/index.mjs').EpPropMergeType<StringConstructor, "" | "default" | "small" | "large", unknown>>;
122
122
  readonly required: false;
123
123
  readonly validator: ((val: unknown) => boolean) | undefined;
124
124
  __epPropKey: true;
@@ -162,16 +162,16 @@ declare const _default: import('vue').DefineComponent<import('vue').ExtractPropT
162
162
  readonly validator: ((val: unknown) => boolean) | undefined;
163
163
  __epPropKey: true;
164
164
  };
165
- labelPosition: import('element-plus/es/utils/index.mjs').EpPropFinalized<StringConstructor, "" | "left" | "right" | "top", unknown, "", boolean>;
165
+ labelPosition: import('element-plus/es/utils/index.mjs').EpPropFinalized<StringConstructor, "" | "top" | "left" | "right", unknown, "", boolean>;
166
166
  prop: {
167
- readonly type: import('vue').PropType<import('element-plus/es/utils/index.mjs').EpPropMergeType<(new (...args: any[]) => string | string[]) | (() => import('element-plus').FormItemProp) | ((new (...args: any[]) => string | string[]) | (() => import('element-plus').FormItemProp))[], unknown, unknown>>;
167
+ readonly type: import('vue').PropType<import('element-plus/es/utils/index.mjs').EpPropMergeType<(new (...args: any[]) => string | string[]) | (() => import('element-plus').FormItemProp) | (((new (...args: any[]) => string | string[]) | (() => import('element-plus').FormItemProp)) | null)[], unknown, unknown>>;
168
168
  readonly required: false;
169
169
  readonly validator: ((val: unknown) => boolean) | undefined;
170
170
  __epPropKey: true;
171
171
  };
172
172
  required: import('element-plus/es/utils/index.mjs').EpPropFinalized<BooleanConstructor, unknown, unknown, undefined, boolean>;
173
173
  rules: {
174
- readonly type: import('vue').PropType<import('element-plus/es/utils/index.mjs').EpPropMergeType<(new (...args: any[]) => import('element-plus').FormItemRule | import('element-plus').FormItemRule[]) | (() => import('element-plus/es/utils/typescript.mjs').Arrayable<import('element-plus').FormItemRule>) | ((new (...args: any[]) => import('element-plus').FormItemRule | import('element-plus').FormItemRule[]) | (() => import('element-plus/es/utils/typescript.mjs').Arrayable<import('element-plus').FormItemRule>))[], unknown, unknown>>;
174
+ readonly type: import('vue').PropType<import('element-plus/es/utils/index.mjs').EpPropMergeType<(new (...args: any[]) => import('element-plus').FormItemRule | import('element-plus').FormItemRule[]) | (() => import('element-plus/es/utils/typescript.mjs').Arrayable<import('element-plus').FormItemRule>) | (((new (... /** @description 对该表单项进行重置,将其值重置为初始值并移除校验结果 */args: any[]) => import('element-plus').FormItemRule | import('element-plus').FormItemRule[]) | (() => import('element-plus/es/utils/typescript.mjs').Arrayable<import('element-plus').FormItemRule>)) | null)[], unknown, unknown>>;
175
175
  readonly required: false;
176
176
  readonly validator: ((val: unknown) => boolean) | undefined;
177
177
  __epPropKey: true;
@@ -187,7 +187,7 @@ declare const _default: import('vue').DefineComponent<import('vue').ExtractPropT
187
187
  inlineMessage: import('element-plus/es/utils/index.mjs').EpPropFinalized<BooleanConstructor, unknown, unknown, undefined, boolean>;
188
188
  showMessage: import('element-plus/es/utils/index.mjs').EpPropFinalized<BooleanConstructor, unknown, unknown, true, boolean>;
189
189
  size: {
190
- readonly type: import('vue').PropType<import('element-plus/es/utils/index.mjs').EpPropMergeType<StringConstructor, "" | "small" | "default" | "large", unknown>>;
190
+ readonly type: import('vue').PropType<import('element-plus/es/utils/index.mjs').EpPropMergeType<StringConstructor, "" | "default" | "small" | "large", unknown>>;
191
191
  readonly required: false;
192
192
  readonly validator: ((val: unknown) => boolean) | undefined;
193
193
  __epPropKey: true;
@@ -195,10 +195,10 @@ declare const _default: import('vue').DefineComponent<import('vue').ExtractPropT
195
195
  }>> & Readonly<{}>, {
196
196
  required: import('element-plus/es/utils/index.mjs').EpPropMergeType<BooleanConstructor, unknown, unknown>;
197
197
  offset: string | number;
198
- labelPosition: import('element-plus/es/utils/index.mjs').EpPropMergeType<StringConstructor, "" | "top" | "left" | "right", unknown>;
198
+ grid: boolean;
199
+ labelPosition: import('element-plus/es/utils/index.mjs').EpPropMergeType<StringConstructor, "" | "left" | "right" | "top", unknown>;
199
200
  inlineMessage: import('element-plus/es/utils/index.mjs').EpPropMergeType<BooleanConstructor, unknown, unknown>;
200
201
  showMessage: import('element-plus/es/utils/index.mjs').EpPropMergeType<BooleanConstructor, unknown, unknown>;
201
- grid: boolean;
202
202
  row: boolean;
203
203
  }, import('vue').SlotsType<Partial<import('@fast-china/utils').MakeSlots<FaFormItemSlots>>>, {}, {}, string, import('vue').ComponentProvideOptions, true, {}, any>;
204
204
  export default _default;
@@ -1,2 +1,2 @@
1
- import{defineComponent as e,ref as l,inject as a,Fragment as t,createVNode as r,mergeProps as s,computed as o}from"vue";import{formItemProps as i,ElFormItem as f}from"element-plus";import{FaFormItemTip as u}from"../../formItemTip/index.mjs";import{FaLayoutGridItem as p}from"../../layoutGrid/index.mjs";import{useProps as n,useRender as m,useExpose as d,makeSlots as b}from"@fast-china/utils";import{isNumber as v}from"lodash-unified";const g={...i,tips:String,grid:{type:Boolean,default:!0},offset:{type:[String,Number],default:0},span:{type:[String,Number]},row:Boolean},c=/* @__PURE__ */e({name:"FaFormItem",props:g,slots:b(),setup(e,{attrs:b,slots:g,emit:c,expose:N}){const S=l(),x=a("cols",l(4)),y=n(e,i),F=e.grid?p:t;return m(()=>r(F,(()=>{if(!e.grid)return{};if(e.span)return{span:v(e.span)?e.span:Number(e.span),offset:v(e.offset)?e.offset:Number(e.offset)};{const l={span:1,offset:v(e.offset)?e.offset:Number(e.offset)};return e.row&&(l.span=x.value),l}})(),{default:()=>[r(f,s({ref:S},y.value),{default:()=>g.default(),...g.label&&!e.tips&&{label:({label:e})=>g.label({label:e})},...g.label&&e.tips&&{label:({label:e})=>r(u,null,{label:()=>g.label({label:e})})},...!g.label&&e.tips&&{label:({label:l})=>r(u,{label:l??e.label,tips:e.tips},null)},...g.error&&{error:({error:e})=>g.error({error:e})}})]})),d(N,{size:o(()=>S.value?.size),validateMessage:o(()=>S.value?.validateMessage),validateState:o(()=>S.value?.validateState),validate:o(()=>S.value?.validate),clearValidate:o(()=>S.value?.clearValidate),resetField:o(()=>S.value?.resetField)})}});export{c as default,g as faFormItemProps};
2
- //# sourceMappingURL=formItem.mjs.map
1
+ import{FaLayoutGridItem as e}from"../../layoutGrid/index.mjs";import l from"../../formItemTip/index.mjs";import{makeSlots as a,useExpose as t,useProps as r,useRender as s}from"@fast-china/utils";import{Fragment as o,computed as i,createVNode as f,defineComponent as u,inject as p,mergeProps as n,ref as m}from"vue";import{ElFormItem as d,formItemProps as b}from"element-plus";import{isNumber as v}from"lodash-unified";var g={...b,tips:String,grid:{type:Boolean,default:!0},offset:{type:[String,Number],default:0},span:{type:[String,Number]},row:Boolean},c=/* @__PURE__ */u({name:"FaFormItem",props:g,slots:a(),setup(a,{attrs:u,slots:g,emit:c,expose:N}){const S=m(),x=p("cols",m(4)),y=r(a,b),F=a.grid?e:o;return s(()=>f(F,(()=>{if(!a.grid)return{};if(a.span)return{span:v(a.span)?a.span:Number(a.span),offset:v(a.offset)?a.offset:Number(a.offset)};{const e={span:1,offset:v(a.offset)?a.offset:Number(a.offset)};return a.row&&(e.span=x.value),e}})(),{default:()=>[f(d,n({ref:S},y.value),{default:()=>g.default(),...g.label&&!a.tips&&{label:({label:e})=>g.label({label:e})},...g.label&&a.tips&&{label:({label:e})=>f(l,null,{label:()=>g.label({label:e})})},...!g.label&&a.tips&&{label:({label:e})=>f(l,{label:e??a.label,tips:a.tips},null)},...g.error&&{error:({error:e})=>g.error({error:e})}})]})),t(N,{size:i(()=>S.value?.size),validateMessage:i(()=>S.value?.validateMessage),validateState:i(()=>S.value?.validateState),validate:i(()=>S.value?.validate),clearValidate:i(()=>S.value?.clearValidate),resetField:i(()=>S.value?.resetField)})}});export{c as default,g as faFormItemProps};
2
+ //# sourceMappingURL=formItem.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"formItem.mjs","sources":["../../../../../packages/components/form/src/formItem.tsx"],"sourcesContent":["import { Fragment, computed, defineComponent, inject, ref } from \"vue\";\nimport { ElFormItem, formItemProps } from \"element-plus\";\nimport { FaFormItemTip } from \"@fast-element-plus/components/formItemTip\";\nimport { FaLayoutGridItem } from \"@fast-element-plus/components/layoutGrid\";\nimport { makeSlots, useExpose, useProps, useRender } from \"@fast-china/utils\";\nimport { isNumber } from \"lodash-unified\";\nimport type { FormItemInstance } from \"element-plus\";\nimport type { Ref, VNode } from \"vue\";\n\nexport const faFormItemProps = {\n\t...formItemProps,\n\t/** @description Label tips 提示 */\n\ttips: String,\n\t/** @description Grid 布局 */\n\tgrid: {\n\t\ttype: Boolean,\n\t\tdefault: true,\n\t},\n\t/** @description 偏移量 */\n\toffset: {\n\t\ttype: [String, Number],\n\t\tdefault: 0,\n\t},\n\t/** @description 栅格跨度 */\n\tspan: {\n\t\ttype: [String, Number],\n\t},\n\t/** @description 独占一行。如果设置 span 则无效 */\n\trow: Boolean,\n};\n\ntype FaFormItemSlots = {\n\t/** @description 默认内容插槽 */\n\tdefault: never;\n\t/** @description 标签位置显示的内容 */\n\tlabel: { label: string };\n\t/** @description 验证错误信息的显示内容 */\n\terror: { error: string };\n};\n\nexport default defineComponent({\n\tname: \"FaFormItem\",\n\tprops: faFormItemProps,\n\tslots: makeSlots<FaFormItemSlots>(),\n\tsetup(props, { attrs, slots, emit, expose }) {\n\t\tconst formItemRef = ref<FormItemInstance>();\n\n\t\tconst cols = inject<Ref<number>>(\"cols\", ref(4));\n\n\t\t// 获取响应式设置\n\t\tconst getResponsive = (): {\n\t\t\tspan?: number;\n\t\t\toffset?: number;\n\t\t} => {\n\t\t\tif (!props.grid) return {};\n\t\t\tif (props.span) {\n\t\t\t\treturn {\n\t\t\t\t\tspan: isNumber(props.span) ? props.span : Number(props.span),\n\t\t\t\t\toffset: isNumber(props.offset) ? props.offset : Number(props.offset),\n\t\t\t\t};\n\t\t\t} else {\n\t\t\t\tconst result = {\n\t\t\t\t\tspan: 1,\n\t\t\t\t\toffset: isNumber(props.offset) ? props.offset : Number(props.offset),\n\t\t\t\t};\n\t\t\t\tif (props.row) {\n\t\t\t\t\tresult.span = cols.value;\n\t\t\t\t}\n\t\t\t\treturn result;\n\t\t\t}\n\t\t};\n\n\t\tconst elFormItemProps = useProps(props, formItemProps);\n\n\t\tconst ParcelComponent = props.grid ? FaLayoutGridItem : Fragment;\n\n\t\tuseRender(() => (\n\t\t\t<ParcelComponent {...getResponsive()}>\n\t\t\t\t<ElFormItem ref={formItemRef} {...elFormItemProps.value}>\n\t\t\t\t\t{{\n\t\t\t\t\t\tdefault: () => slots.default(),\n\t\t\t\t\t\t...(slots.label && !props.tips && { label: ({ label }: { label: string }): VNode[] => slots.label({ label }) }),\n\t\t\t\t\t\t...(slots.label &&\n\t\t\t\t\t\t\tprops.tips && {\n\t\t\t\t\t\t\t\tlabel: ({ label }: { label: string }): VNode[] => (\n\t\t\t\t\t\t\t\t\t<FaFormItemTip>\n\t\t\t\t\t\t\t\t\t\t{{\n\t\t\t\t\t\t\t\t\t\t\tlabel: () => slots.label({ label }),\n\t\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t\t</FaFormItemTip>\n\t\t\t\t\t\t\t\t),\n\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t...(!slots.label &&\n\t\t\t\t\t\t\tprops.tips && {\n\t\t\t\t\t\t\t\tlabel: ({ label }: { label: string }): VNode[] => <FaFormItemTip label={label ?? props.label} tips={props.tips} />,\n\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t...(slots.error && { error: ({ error }: { error: string }): VNode[] => slots.error({ error }) }),\n\t\t\t\t\t}}\n\t\t\t\t</ElFormItem>\n\t\t\t</ParcelComponent>\n\t\t));\n\n\t\treturn useExpose(expose, {\n\t\t\t/** @description 表单项大小 */\n\t\t\tsize: computed(() => formItemRef.value?.size),\n\t\t\t/** @description 校验消息 */\n\t\t\tvalidateMessage: computed(() => formItemRef.value?.validateMessage),\n\t\t\t/** @description 校验状态 */\n\t\t\tvalidateState: computed(() => formItemRef.value?.validateState),\n\t\t\t/** @description 验证表单项 */\n\t\t\tvalidate: computed(() => formItemRef.value?.validate),\n\t\t\t/** @description 移除该表单项的校验结果 */\n\t\t\tclearValidate: computed(() => formItemRef.value?.clearValidate),\n\t\t\t/** @description 对该表单项进行重置,将其值重置为初始值并移除校验结果 */\n\t\t\tresetField: computed(() => formItemRef.value?.resetField),\n\t\t});\n\t},\n});\n"],"names":["faFormItemProps","formItemProps","tips","String","grid","type","Boolean","default","offset","Number","span","row","FormItem","name","props","slots","makeSlots","setup","attrs","emit","expose","formItemRef","ref","cols","inject","elFormItemProps","useProps","ParcelComponent","FaLayoutGridItem","Fragment","useRender","_createVNode","getResponsive","isNumber","result","value","ElFormItem","_mergeProps","label","FaFormItemTip","error","useExpose","size","computed","validateMessage","validateState","validate","clearValidate","resetField"],"mappings":"mbASO,MAAMA,EAAkB,IAC3BC,EAEHC,KAAMC,OAENC,KAAM,CACLC,KAAMC,QACNC,SAAS,GAGVC,OAAQ,CACPH,KAAM,CAACF,OAAQM,QACfF,QAAS,GAGVG,KAAM,CACLL,KAAM,CAACF,OAAQM,SAGhBE,IAAKL,SAYNM,mBAA+B,CAC9BC,KAAM,aACNC,MAAOd,EACPe,MAAOC,IACPC,KAAAA,CAAMH,GAAOI,MAAEA,EAAAA,MAAOH,EAAAA,KAAOI,EAAAA,OAAMC,IAClC,MAAMC,EAAcC,IAEdC,EAAOC,EAAoB,OAAQF,EAAI,IAyBvCG,EAAkBC,EAASZ,EAAOb,GAElC0B,EAAkBb,EAAMV,KAAOwB,EAAmBC,EA4BxD,OA1BAC,EAAU,IAAAC,EAAAJ,EA1BYK,MAIrB,IAAKlB,EAAMV,KAAM,MAAO,CAAA,EACxB,GAAIU,EAAMJ,KACT,MAAO,CACNA,KAAMuB,EAASnB,EAAMJ,MAAQI,EAAMJ,KAAOD,OAAOK,EAAMJ,MACvDF,OAAQyB,EAASnB,EAAMN,QAAUM,EAAMN,OAASC,OAAOK,EAAMN,SAExD,CACN,MAAM0B,EAAS,CACdxB,KAAM,EACNF,OAAQyB,EAASnB,EAAMN,QAAUM,EAAMN,OAASC,OAAOK,EAAMN,SAK9D,OAHIM,EAAMH,MACTuB,EAAOxB,KAAOa,EAAKY,OAEbD,CACR,GAQqBF,GAAe,CAAAzB,QAAAA,IAAA,CAAAwB,EAAAK,EAAAC,EAAA,CAAAf,IAClBD,GAAiBI,EAAgBU,OAAK,CAErD5B,QAASA,IAAMQ,EAAMR,aACjBQ,EAAMuB,QAAUxB,EAAMZ,MAAQ,CAAEoC,MAAOA,EAAGA,WAAwCvB,EAAMuB,MAAM,CAAEA,cAChGvB,EAAMuB,OACTxB,EAAMZ,MAAQ,CACboC,MAAOA,EAAGA,WAA0BP,EAAAQ,EAAA,KAAA,CAGjCD,MAAOA,IAAMvB,EAAMuB,MAAM,CAAEA,iBAK3BvB,EAAMuB,OACVxB,EAAMZ,MAAQ,CACboC,MAAOA,EAAGA,WAA0BP,EAAAQ,EAAA,CAAAD,MAAoCA,GAASxB,EAAMwB,MAAKpC,KAAQY,EAAMZ,MAAI,UAE5Ga,EAAMyB,OAAS,CAAEA,MAAOA,EAAGA,WAAwCzB,EAAMyB,MAAM,CAAEA,iBAMlFC,EAAUrB,EAAQ,CAExBsB,KAAMC,EAAS,IAAMtB,EAAYc,OAAOO,MAExCE,gBAAiBD,EAAS,IAAMtB,EAAYc,OAAOS,iBAEnDC,cAAeF,EAAS,IAAMtB,EAAYc,OAAOU,eAEjDC,SAAUH,EAAS,IAAMtB,EAAYc,OAAOW,UAE5CC,cAAeJ,EAAS,IAAMtB,EAAYc,OAAOY,eAEjDC,WAAYL,EAAS,IAAMtB,EAAYc,OAAOa,aAEhD"}
1
+ {"version":3,"file":"formItem.mjs","names":["Fragment","computed","defineComponent","inject","ref","createVNode","_createVNode","mergeProps","_mergeProps","ElFormItem","formItemProps","FaFormItemTip","FaLayoutGridItem","makeSlots","useExpose","useProps","useRender","isNumber","faFormItemProps","tips","String","grid","type","Boolean","default","offset","Number","span","row","name","props","slots","setup","attrs","emit","expose","formItemRef","cols","getResponsive","result","value","elFormItemProps","ParcelComponent","label","error","size","validateMessage","validateState","validate","clearValidate","resetField"],"sources":["../../../../../packages/components/form/src/formItem.tsx"],"sourcesContent":["import { Fragment, computed, defineComponent, inject, ref } from \"vue\";\nimport { ElFormItem, formItemProps } from \"element-plus\";\nimport { FaFormItemTip } from \"@fast-element-plus/components/formItemTip\";\nimport { FaLayoutGridItem } from \"@fast-element-plus/components/layoutGrid\";\nimport { makeSlots, useExpose, useProps, useRender } from \"@fast-china/utils\";\nimport { isNumber } from \"lodash-unified\";\nimport type { FormItemInstance } from \"element-plus\";\nimport type { Ref, VNode } from \"vue\";\n\nexport const faFormItemProps = {\n\t...formItemProps,\n\t/** @description Label tips 提示 */\n\ttips: String,\n\t/** @description Grid 布局 */\n\tgrid: {\n\t\ttype: Boolean,\n\t\tdefault: true,\n\t},\n\t/** @description 偏移量 */\n\toffset: {\n\t\ttype: [String, Number],\n\t\tdefault: 0,\n\t},\n\t/** @description 栅格跨度 */\n\tspan: {\n\t\ttype: [String, Number],\n\t},\n\t/** @description 独占一行。如果设置 span 则无效 */\n\trow: Boolean,\n};\n\ntype FaFormItemSlots = {\n\t/** @description 默认内容插槽 */\n\tdefault: never;\n\t/** @description 标签位置显示的内容 */\n\tlabel: { label: string };\n\t/** @description 验证错误信息的显示内容 */\n\terror: { error: string };\n};\n\nexport default defineComponent({\n\tname: \"FaFormItem\",\n\tprops: faFormItemProps,\n\tslots: makeSlots<FaFormItemSlots>(),\n\tsetup(props, { attrs, slots, emit, expose }) {\n\t\tconst formItemRef = ref<FormItemInstance>();\n\n\t\tconst cols = inject<Ref<number>>(\"cols\", ref(4));\n\n\t\t// 获取响应式设置\n\t\tconst getResponsive = (): {\n\t\t\tspan?: number;\n\t\t\toffset?: number;\n\t\t} => {\n\t\t\tif (!props.grid) return {};\n\t\t\tif (props.span) {\n\t\t\t\treturn {\n\t\t\t\t\tspan: isNumber(props.span) ? props.span : Number(props.span),\n\t\t\t\t\toffset: isNumber(props.offset) ? props.offset : Number(props.offset),\n\t\t\t\t};\n\t\t\t} else {\n\t\t\t\tconst result = {\n\t\t\t\t\tspan: 1,\n\t\t\t\t\toffset: isNumber(props.offset) ? props.offset : Number(props.offset),\n\t\t\t\t};\n\t\t\t\tif (props.row) {\n\t\t\t\t\tresult.span = cols.value;\n\t\t\t\t}\n\t\t\t\treturn result;\n\t\t\t}\n\t\t};\n\n\t\tconst elFormItemProps = useProps(props, formItemProps);\n\n\t\tconst ParcelComponent = props.grid ? FaLayoutGridItem : Fragment;\n\n\t\tuseRender(() => (\n\t\t\t<ParcelComponent {...getResponsive()}>\n\t\t\t\t<ElFormItem ref={formItemRef} {...elFormItemProps.value}>\n\t\t\t\t\t{{\n\t\t\t\t\t\tdefault: () => slots.default(),\n\t\t\t\t\t\t...(slots.label && !props.tips && { label: ({ label }: { label: string }): VNode[] => slots.label({ label }) }),\n\t\t\t\t\t\t...(slots.label &&\n\t\t\t\t\t\t\tprops.tips && {\n\t\t\t\t\t\t\t\tlabel: ({ label }: { label: string }): VNode[] => (\n\t\t\t\t\t\t\t\t\t<FaFormItemTip>\n\t\t\t\t\t\t\t\t\t\t{{\n\t\t\t\t\t\t\t\t\t\t\tlabel: () => slots.label({ label }),\n\t\t\t\t\t\t\t\t\t\t}}\n\t\t\t\t\t\t\t\t\t</FaFormItemTip>\n\t\t\t\t\t\t\t\t),\n\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t...(!slots.label &&\n\t\t\t\t\t\t\tprops.tips && {\n\t\t\t\t\t\t\t\tlabel: ({ label }: { label: string }): VNode[] => <FaFormItemTip label={label ?? props.label} tips={props.tips} />,\n\t\t\t\t\t\t\t}),\n\t\t\t\t\t\t...(slots.error && { error: ({ error }: { error: string }): VNode[] => slots.error({ error }) }),\n\t\t\t\t\t}}\n\t\t\t\t</ElFormItem>\n\t\t\t</ParcelComponent>\n\t\t));\n\n\t\treturn useExpose(expose, {\n\t\t\t/** @description 表单项大小 */\n\t\t\tsize: computed(() => formItemRef.value?.size),\n\t\t\t/** @description 校验消息 */\n\t\t\tvalidateMessage: computed(() => formItemRef.value?.validateMessage),\n\t\t\t/** @description 校验状态 */\n\t\t\tvalidateState: computed(() => formItemRef.value?.validateState),\n\t\t\t/** @description 验证表单项 */\n\t\t\tvalidate: computed(() => formItemRef.value?.validate),\n\t\t\t/** @description 移除该表单项的校验结果 */\n\t\t\tclearValidate: computed(() => formItemRef.value?.clearValidate),\n\t\t\t/** @description 对该表单项进行重置,将其值重置为初始值并移除校验结果 */\n\t\t\tresetField: computed(() => formItemRef.value?.resetField),\n\t\t});\n\t},\n});\n"],"mappings":"kaASA,IAAakB,EAAkB,IAC3BR,EAEHS,KAAMC,OAENC,KAAM,CACLC,KAAMC,QACNC,SAAS,GAGVC,OAAQ,CACPH,KAAM,CAACF,OAAQM,QACfF,QAAS,GAGVG,KAAM,CACLL,KAAM,CAACF,OAAQM,SAGhBE,IAAKL,SAYN,iBAAerB,EAAgB,CAC9B2B,KAAM,aACNC,MAAOZ,EACPa,MAAOlB,IACPmB,KAAAA,CAAMF,GAAO,MAAEG,EAAAA,MAAOF,EAAAA,KAAOG,EAAAA,OAAMC,IAClC,MAAMC,EAAchC,IAEdiC,EAAOlC,EAAoB,OAAQC,EAAI,IAyBvCqC,EAAkB1B,EAASe,EAAOpB,GAElCgC,EAAkBZ,EAAMT,KAAOT,EAAmBZ,EA4BxD,OA1BAgB,EAAAA,IAAUV,EAAAoC,EA1BJJ,MAIL,IAAKR,EAAMT,KAAM,MAAO,CAAA,EACxB,GAAIS,EAAMH,KACT,MAAO,CACNA,KAAMV,EAASa,EAAMH,MAAQG,EAAMH,KAAOD,OAAOI,EAAMH,MACvDF,OAAQR,EAASa,EAAML,QAAUK,EAAML,OAASC,OAAOI,EAAML,SAExD,CACN,MAAMc,EAAS,CACdZ,KAAM,EACNF,OAAQR,EAASa,EAAML,QAAUK,EAAML,OAASC,OAAOI,EAAML,SAK9D,OAHIK,EAAMF,MACTW,EAAOZ,KAAOU,EAAKG,OAEbD,IASaD,GAAe,CAAAd,QAAAA,IAAA,CAAAlB,EAAAG,EAAAD,EAAA,CAAA,IAClB4B,GAAiBK,EAAgBD,OAAK,CAErDhB,QAAAA,IAAeO,EAAMP,aACjBO,EAAMY,QAAUb,EAAMX,MAAQ,CAAEwB,MAAAA,EAAUA,WAAwCZ,EAAMY,MAAM,CAAEA,cAChGZ,EAAMY,OACTb,EAAMX,MAAQ,CACbwB,MAAAA,EAAUA,WAA0BrC,EAAAK,EAAA,KAAA,CAGjCgC,MAAAA,IAAaZ,EAAMY,MAAM,CAAEA,iBAK3BZ,EAAMY,OACVb,EAAMX,MAAQ,CACbwB,MAAAA,EAAUA,WAA0BrC,EAAAK,EAAA,CAAA,MAAoCgC,GAASb,EAAMa,MAAK,KAAQb,EAAMX,MAAI,UAE5GY,EAAMa,OAAS,CAAEA,MAAAA,EAAUA,WAAwCb,EAAMa,MAAM,CAAEA,iBAMlF9B,EAAUqB,EAAQ,CAExBU,KAAM5C,EAAAA,IAAemC,EAAYI,OAAOK,MAExCC,gBAAiB7C,EAAAA,IAAemC,EAAYI,OAAOM,iBAEnDC,cAAe9C,EAAAA,IAAemC,EAAYI,OAAOO,eAEjDC,SAAU/C,EAAAA,IAAemC,EAAYI,OAAOQ,UAE5CC,cAAehD,EAAAA,IAAemC,EAAYI,OAAOS,eAEjDC,WAAYjD,EAAAA,IAAemC,EAAYI,OAAOU"}
@@ -1,2 +1,2 @@
1
- import"../../../constants/index.mjs";import{consoleWarn as r}from"@fast-china/utils";import{RegExps as e}from"../../../constants/regex.mjs";const t={validate:e=>new Promise((t,o)=>{e.value.validate((e,s)=>{e?t(e):(s&&r("formUtil",!1,s),o(e))})}),validateScrollToField:e=>new Promise((t,o)=>{e.value.validate((s,n)=>{s?t(s):(e.value.scrollToField(Object.keys(n)),n&&r("formUtil",!1,n),o(s))})}),mobile(r,t,o){t?e.Mobile.test(t)?o():o(new Error("请输入正确的手机号码")):o(new Error("请输入手机号码"))},phone(r,t,o){t?e.Phone.test(t)?o():o(new Error("请输入正确的电话号码")):o()},email(r,t,o){t?e.Email.test(t)?o():o(new Error("请输入正确的邮箱地址")):o()},idCard(r,t,o){e.IdCard.test(t)||!t?o():o(new Error("请输入正确的身份证号码"))},carNumber(r,t,o){let s=!1;7===t?.length?s=e.CarNumber.test(t):8===t?.length&&(s=e.NewEnergyCarNumber.test(t)),s?o():o(new Error("请输入正确的车牌号码"))},editorRequired:(r,e,t)=>"<p><br></p>"===e?t(new Error("内容不能为空")):t(),external(r,t,o){e.External.test(t)?o():o(new Error("请输入正确的外部链接"))},url(r,t,o){e.Url.test(t)?o():o(new Error("请输入有效的Url"))},postCode(r,t,o){e.PostCode.test(t)?o():o(new Error("请输入有效的邮政编码"))},account(r,t,o){e.Account.test(t)?o():o(new Error("请输入有效的账号(6-20位字母或数字,必须以字母开头,不能全为数字)"))},password(r,t,o){e.Password.test(t)?o():o(new Error("请输入有效的密码(只包含字母和数字,长度为6到18位)"))},strongPassword(r,t,o){e.StrongPassword.test(t)?o():o(new Error("请输入有效的密码(8到20位,包含大小写字母、数字及特殊字符)"))},chinese(r,t,o){e.Chinese.test(t)?o():o(new Error("请输入有效的中文字符"))},english(r,t,o){e.English.test(t)?o():o(new Error("请输入有效的英文字符"))},inputRequired:(r,e="blur")=>({required:!0,message:r,trigger:e}),selectRequired:(r,e="change")=>({required:!0,message:r,trigger:e})};export{t as formUtil};
2
- //# sourceMappingURL=form.mjs.map
1
+ import{RegExps as r}from"../../../constants/regex.mjs";import"../../../constants/index.mjs";import{consoleWarn as e}from"@fast-china/utils";var t={validate:r=>new Promise((t,o)=>{r.value.validate((r,s)=>{r?t(r):(s&&e("formUtil",!1,s),o(r))})}),validateScrollToField:r=>new Promise((t,o)=>{r.value.validate((s,n)=>{s?t(s):(r.value.scrollToField(Object.keys(n)),n&&e("formUtil",!1,n),o(s))})}),mobile(e,t,o){t?r.Mobile.test(t)?o():o(new Error("请输入正确的手机号码")):o(new Error("请输入手机号码"))},phone(e,t,o){t?r.Phone.test(t)?o():o(new Error("请输入正确的电话号码")):o()},email(e,t,o){t?r.Email.test(t)?o():o(new Error("请输入正确的邮箱地址")):o()},idCard(e,t,o){r.IdCard.test(t)||!t?o():o(new Error("请输入正确的身份证号码"))},carNumber(e,t,o){let s=!1;7===t?.length?s=r.CarNumber.test(t):8===t?.length&&(s=r.NewEnergyCarNumber.test(t)),s?o():o(new Error("请输入正确的车牌号码"))},editorRequired:(r,e,t)=>"<p><br></p>"===e?t(new Error("内容不能为空")):t(),external(e,t,o){r.External.test(t)?o():o(new Error("请输入正确的外部链接"))},url(e,t,o){r.Url.test(t)?o():o(new Error("请输入有效的Url"))},postCode(e,t,o){r.PostCode.test(t)?o():o(new Error("请输入有效的邮政编码"))},account(e,t,o){r.Account.test(t)?o():o(new Error("请输入有效的账号(6-20位字母或数字,必须以字母开头,不能全为数字)"))},password(e,t,o){r.Password.test(t)?o():o(new Error("请输入有效的密码(只包含字母和数字,长度为6到18位)"))},strongPassword(e,t,o){r.StrongPassword.test(t)?o():o(new Error("请输入有效的密码(8到20位,包含大小写字母、数字及特殊字符)"))},chinese(e,t,o){r.Chinese.test(t)?o():o(new Error("请输入有效的中文字符"))},english(e,t,o){r.English.test(t)?o():o(new Error("请输入有效的英文字符"))},inputRequired:(r,e="blur")=>({required:!0,message:r,trigger:e}),selectRequired:(r,e="change")=>({required:!0,message:r,trigger:e})};export{t as formUtil};
2
+ //# sourceMappingURL=form.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"form.mjs","sources":["../../../../../packages/components/form/utils/form.ts"],"sourcesContent":["import { RegExps } from \"@fast-element-plus/constants\";\nimport { consoleWarn } from \"@fast-china/utils\";\nimport type { FormInstance, FormItemRule, FormValidationResult } from \"element-plus\";\nimport type { Ref } from \"vue\";\n\n/**\n * 表单工具类\n */\nexport const formUtil = {\n\t/**\n\t * ElForm 表单验证\n\t * @param elFormRef ElForm 组件ref\n\t */\n\tvalidate(elFormRef: Ref<FormInstance, FormInstance>): FormValidationResult {\n\t\treturn new Promise<boolean>((resolve, reject) => {\n\t\t\telFormRef.value.validate((isValid: boolean, invalidFields?) => {\n\t\t\t\tif (isValid) {\n\t\t\t\t\tresolve(isValid);\n\t\t\t\t} else {\n\t\t\t\t\tif (invalidFields) {\n\t\t\t\t\t\tconsoleWarn(\"formUtil\", false, invalidFields);\n\t\t\t\t\t}\n\t\t\t\t\treject(isValid);\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\t},\n\t/**\n\t * ElForm 表单验证,带滚动\n\t * @param elFormRef ElForm 组件ref\n\t */\n\tvalidateScrollToField(elFormRef: Ref<FormInstance>): FormValidationResult {\n\t\treturn new Promise<boolean>((resolve, reject) => {\n\t\t\telFormRef.value.validate((isValid: boolean, invalidFields?) => {\n\t\t\t\tif (isValid) {\n\t\t\t\t\tresolve(isValid);\n\t\t\t\t} else {\n\t\t\t\t\telFormRef.value.scrollToField(Object.keys(invalidFields));\n\t\t\t\t\tif (invalidFields) {\n\t\t\t\t\t\tconsoleWarn(\"formUtil\", false, invalidFields);\n\t\t\t\t\t}\n\t\t\t\t\treject(isValid);\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\t},\n\t/**\n\t * 手机号\n\t */\n\tmobile(rule: any, value: string, callback: any): void {\n\t\tif (!value) {\n\t\t\tcallback(new Error(\"请输入手机号码\"));\n\t\t} else if (RegExps.Mobile.test(value)) {\n\t\t\tcallback();\n\t\t} else {\n\t\t\tcallback(new Error(\"请输入正确的手机号码\"));\n\t\t}\n\t},\n\t/**\n\t * 电话号码\n\t */\n\tphone(rule: any, value: string, callback: any): void {\n\t\tif (!value) {\n\t\t\tcallback();\n\t\t} else if (RegExps.Phone.test(value)) {\n\t\t\tcallback();\n\t\t} else {\n\t\t\tcallback(new Error(\"请输入正确的电话号码\"));\n\t\t}\n\t},\n\t/**\n\t * 邮箱\n\t */\n\temail(rule: any, value: string, callback: any): void {\n\t\tif (!value) {\n\t\t\tcallback();\n\t\t} else if (RegExps.Email.test(value)) {\n\t\t\tcallback();\n\t\t} else {\n\t\t\tcallback(new Error(\"请输入正确的邮箱地址\"));\n\t\t}\n\t},\n\t/**\n\t * 身份证\n\t */\n\tidCard(rule: any, value: string, callback: any): void {\n\t\tif (RegExps.IdCard.test(value) || !value) {\n\t\t\tcallback();\n\t\t} else {\n\t\t\tcallback(new Error(\"请输入正确的身份证号码\"));\n\t\t}\n\t},\n\t/**\n\t * 车牌号\n\t */\n\tcarNumber(rule: any, value: string, callback: any): void {\n\t\tlet success = false;\n\t\tif (value?.length === 7) {\n\t\t\tsuccess = RegExps.CarNumber.test(value);\n\t\t} else if (value?.length === 8) {\n\t\t\tsuccess = RegExps.NewEnergyCarNumber.test(value);\n\t\t}\n\t\tif (success) {\n\t\t\tcallback();\n\t\t} else {\n\t\t\tcallback(new Error(\"请输入正确的车牌号码\"));\n\t\t}\n\t},\n\t/**\n\t * editor 必填\n\t */\n\teditorRequired(rule: any, value: string, callback: any): void {\n\t\tif (value === \"<p><br></p>\") {\n\t\t\treturn callback(new Error(\"内容不能为空\"));\n\t\t}\n\t\treturn callback();\n\t},\n\t/**\n\t * 外部链接\n\t */\n\texternal(rule: any, value: string, callback: any): void {\n\t\tif (RegExps.External.test(value)) {\n\t\t\tcallback();\n\t\t} else {\n\t\t\tcallback(new Error(\"请输入正确的外部链接\"));\n\t\t}\n\t},\n\t/**\n\t * 有效的URL\n\t */\n\turl(rule: any, value: string, callback: any): void {\n\t\tif (RegExps.Url.test(value)) {\n\t\t\tcallback();\n\t\t} else {\n\t\t\tcallback(new Error(\"请输入有效的Url\"));\n\t\t}\n\t},\n\t/**\n\t * 邮政编码\n\t */\n\tpostCode(rule: any, value: string, callback: any): void {\n\t\tif (RegExps.PostCode.test(value)) {\n\t\t\tcallback();\n\t\t} else {\n\t\t\tcallback(new Error(\"请输入有效的邮政编码\"));\n\t\t}\n\t},\n\t/**\n\t * 账号(6-20位字母或数字,必须以字母开头,不能全为数字)\n\t */\n\taccount(rule: any, value: string, callback: any): void {\n\t\tif (RegExps.Account.test(value)) {\n\t\t\tcallback();\n\t\t} else {\n\t\t\tcallback(new Error(\"请输入有效的账号(6-20位字母或数字,必须以字母开头,不能全为数字)\"));\n\t\t}\n\t},\n\t/**\n\t * 弱密码(只包含字母和数字,长度为6到18位)\n\t */\n\tpassword(rule: any, value: string, callback: any): void {\n\t\tif (RegExps.Password.test(value)) {\n\t\t\tcallback();\n\t\t} else {\n\t\t\tcallback(new Error(\"请输入有效的密码(只包含字母和数字,长度为6到18位)\"));\n\t\t}\n\t},\n\t/**\n\t * 强密码(8到20位,包含大小写字母、数字及特殊字符)\n\t */\n\tstrongPassword(rule: any, value: string, callback: any): void {\n\t\tif (RegExps.StrongPassword.test(value)) {\n\t\t\tcallback();\n\t\t} else {\n\t\t\tcallback(new Error(\"请输入有效的密码(8到20位,包含大小写字母、数字及特殊字符)\"));\n\t\t}\n\t},\n\t/**\n\t * 中文字符\n\t */\n\tchinese(rule: any, value: string, callback: any): void {\n\t\tif (RegExps.Chinese.test(value)) {\n\t\t\tcallback();\n\t\t} else {\n\t\t\tcallback(new Error(\"请输入有效的中文字符\"));\n\t\t}\n\t},\n\t/**\n\t * 英文字符\n\t */\n\tenglish(rule: any, value: string, callback: any): void {\n\t\tif (RegExps.English.test(value)) {\n\t\t\tcallback();\n\t\t} else {\n\t\t\tcallback(new Error(\"请输入有效的英文字符\"));\n\t\t}\n\t},\n\t/**\n\t * 文本框必填\n\t */\n\tinputRequired(message: string, trigger = \"blur\"): FormItemRule {\n\t\treturn {\n\t\t\trequired: true,\n\t\t\tmessage,\n\t\t\ttrigger,\n\t\t};\n\t},\n\t/**\n\t * 选择器必选\n\t */\n\tselectRequired(message: string, trigger = \"change\"): FormItemRule {\n\t\treturn {\n\t\t\trequired: true,\n\t\t\tmessage,\n\t\t\ttrigger,\n\t\t};\n\t},\n};\n"],"names":["formUtil","validate","elFormRef","Promise","resolve","reject","value","isValid","invalidFields","consoleWarn","validateScrollToField","scrollToField","Object","keys","mobile","rule","callback","RegExps","Mobile","test","Error","phone","Phone","email","Email","idCard","IdCard","carNumber","success","length","CarNumber","NewEnergyCarNumber","editorRequired","external","External","url","Url","postCode","PostCode","account","Account","password","Password","strongPassword","StrongPassword","chinese","Chinese","english","English","inputRequired","message","trigger","required","selectRequired"],"mappings":"4IAQO,MAAMA,EAAW,CAKvBC,SAASC,GACD,IAAIC,QAAiB,CAACC,EAASC,KACrCH,EAAUI,MAAML,SAAS,CAACM,EAAkBC,KACvCD,EACHH,EAAQG,IAEJC,GACHC,EAAY,YAAY,EAAOD,GAEhCH,EAAOE,QASXG,sBAAsBR,GACd,IAAIC,QAAiB,CAACC,EAASC,KACrCH,EAAUI,MAAML,SAAS,CAACM,EAAkBC,KACvCD,EACHH,EAAQG,IAERL,EAAUI,MAAMK,cAAcC,OAAOC,KAAKL,IACtCA,GACHC,EAAY,YAAY,EAAOD,GAEhCH,EAAOE,QAQX,MAAAO,CAAOC,EAAWT,EAAeU,GAC3BV,EAEMW,EAAQC,OAAOC,KAAKb,GAC9BU,IAEAA,EAAS,IAAII,MAAM,eAJnBJ,EAAS,IAAII,MAAM,WAMrB,EAIA,KAAAC,CAAMN,EAAWT,EAAeU,GAC1BV,EAEMW,EAAQK,MAAMH,KAAKb,GAC7BU,IAEAA,EAAS,IAAII,MAAM,eAJnBJ,GAMF,EAIA,KAAAO,CAAMR,EAAWT,EAAeU,GAC1BV,EAEMW,EAAQO,MAAML,KAAKb,GAC7BU,IAEAA,EAAS,IAAII,MAAM,eAJnBJ,GAMF,EAIA,MAAAS,CAAOV,EAAWT,EAAeU,GAC5BC,EAAQS,OAAOP,KAAKb,KAAWA,EAClCU,IAEAA,EAAS,IAAII,MAAM,eAErB,EAIA,SAAAO,CAAUZ,EAAWT,EAAeU,GACnC,IAAIY,GAAU,EACQ,IAAlBtB,GAAOuB,OACVD,EAAUX,EAAQa,UAAUX,KAAKb,GACL,IAAlBA,GAAOuB,SACjBD,EAAUX,EAAQc,mBAAmBZ,KAAKb,IAEvCsB,EACHZ,IAEAA,EAAS,IAAII,MAAM,cAErB,EAIAY,eAAA,CAAejB,EAAWT,EAAeU,IAC1B,gBAAVV,EACIU,EAAS,IAAII,MAAM,WAEpBJ,IAKR,QAAAiB,CAASlB,EAAWT,EAAeU,GAC9BC,EAAQiB,SAASf,KAAKb,GACzBU,IAEAA,EAAS,IAAII,MAAM,cAErB,EAIA,GAAAe,CAAIpB,EAAWT,EAAeU,GACzBC,EAAQmB,IAAIjB,KAAKb,GACpBU,IAEAA,EAAS,IAAII,MAAM,aAErB,EAIA,QAAAiB,CAAStB,EAAWT,EAAeU,GAC9BC,EAAQqB,SAASnB,KAAKb,GACzBU,IAEAA,EAAS,IAAII,MAAM,cAErB,EAIA,OAAAmB,CAAQxB,EAAWT,EAAeU,GAC7BC,EAAQuB,QAAQrB,KAAKb,GACxBU,IAEAA,EAAS,IAAII,MAAM,uCAErB,EAIA,QAAAqB,CAAS1B,EAAWT,EAAeU,GAC9BC,EAAQyB,SAASvB,KAAKb,GACzBU,IAEAA,EAAS,IAAII,MAAM,+BAErB,EAIA,cAAAuB,CAAe5B,EAAWT,EAAeU,GACpCC,EAAQ2B,eAAezB,KAAKb,GAC/BU,IAEAA,EAAS,IAAII,MAAM,mCAErB,EAIA,OAAAyB,CAAQ9B,EAAWT,EAAeU,GAC7BC,EAAQ6B,QAAQ3B,KAAKb,GACxBU,IAEAA,EAAS,IAAII,MAAM,cAErB,EAIA,OAAA2B,CAAQhC,EAAWT,EAAeU,GAC7BC,EAAQ+B,QAAQ7B,KAAKb,GACxBU,IAEAA,EAAS,IAAII,MAAM,cAErB,EAIA6B,cAAA,CAAcC,EAAiBC,EAAU,UACjC,CACNC,UAAU,EACVF,UACAC,YAMFE,eAAA,CAAeH,EAAiBC,EAAU,YAClC,CACNC,UAAU,EACVF,UACAC"}
1
+ {"version":3,"file":"form.mjs","names":[],"sources":["../../../../../packages/components/form/utils/form.ts"],"sourcesContent":["import { RegExps } from \"@fast-element-plus/constants\";\nimport { consoleWarn } from \"@fast-china/utils\";\nimport type { FormInstance, FormItemRule, FormValidationResult } from \"element-plus\";\nimport type { Ref } from \"vue\";\n\n/**\n * 表单工具类\n */\nexport const formUtil = {\n\t/**\n\t * ElForm 表单验证\n\t * @param elFormRef ElForm 组件ref\n\t */\n\tvalidate(elFormRef: Ref<FormInstance, FormInstance>): FormValidationResult {\n\t\treturn new Promise<boolean>((resolve, reject) => {\n\t\t\telFormRef.value.validate((isValid: boolean, invalidFields?) => {\n\t\t\t\tif (isValid) {\n\t\t\t\t\tresolve(isValid);\n\t\t\t\t} else {\n\t\t\t\t\tif (invalidFields) {\n\t\t\t\t\t\tconsoleWarn(\"formUtil\", false, invalidFields);\n\t\t\t\t\t}\n\t\t\t\t\treject(isValid);\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\t},\n\t/**\n\t * ElForm 表单验证,带滚动\n\t * @param elFormRef ElForm 组件ref\n\t */\n\tvalidateScrollToField(elFormRef: Ref<FormInstance>): FormValidationResult {\n\t\treturn new Promise<boolean>((resolve, reject) => {\n\t\t\telFormRef.value.validate((isValid: boolean, invalidFields?) => {\n\t\t\t\tif (isValid) {\n\t\t\t\t\tresolve(isValid);\n\t\t\t\t} else {\n\t\t\t\t\telFormRef.value.scrollToField(Object.keys(invalidFields));\n\t\t\t\t\tif (invalidFields) {\n\t\t\t\t\t\tconsoleWarn(\"formUtil\", false, invalidFields);\n\t\t\t\t\t}\n\t\t\t\t\treject(isValid);\n\t\t\t\t}\n\t\t\t});\n\t\t});\n\t},\n\t/**\n\t * 手机号\n\t */\n\tmobile(rule: any, value: string, callback: any): void {\n\t\tif (!value) {\n\t\t\tcallback(new Error(\"请输入手机号码\"));\n\t\t} else if (RegExps.Mobile.test(value)) {\n\t\t\tcallback();\n\t\t} else {\n\t\t\tcallback(new Error(\"请输入正确的手机号码\"));\n\t\t}\n\t},\n\t/**\n\t * 电话号码\n\t */\n\tphone(rule: any, value: string, callback: any): void {\n\t\tif (!value) {\n\t\t\tcallback();\n\t\t} else if (RegExps.Phone.test(value)) {\n\t\t\tcallback();\n\t\t} else {\n\t\t\tcallback(new Error(\"请输入正确的电话号码\"));\n\t\t}\n\t},\n\t/**\n\t * 邮箱\n\t */\n\temail(rule: any, value: string, callback: any): void {\n\t\tif (!value) {\n\t\t\tcallback();\n\t\t} else if (RegExps.Email.test(value)) {\n\t\t\tcallback();\n\t\t} else {\n\t\t\tcallback(new Error(\"请输入正确的邮箱地址\"));\n\t\t}\n\t},\n\t/**\n\t * 身份证\n\t */\n\tidCard(rule: any, value: string, callback: any): void {\n\t\tif (RegExps.IdCard.test(value) || !value) {\n\t\t\tcallback();\n\t\t} else {\n\t\t\tcallback(new Error(\"请输入正确的身份证号码\"));\n\t\t}\n\t},\n\t/**\n\t * 车牌号\n\t */\n\tcarNumber(rule: any, value: string, callback: any): void {\n\t\tlet success = false;\n\t\tif (value?.length === 7) {\n\t\t\tsuccess = RegExps.CarNumber.test(value);\n\t\t} else if (value?.length === 8) {\n\t\t\tsuccess = RegExps.NewEnergyCarNumber.test(value);\n\t\t}\n\t\tif (success) {\n\t\t\tcallback();\n\t\t} else {\n\t\t\tcallback(new Error(\"请输入正确的车牌号码\"));\n\t\t}\n\t},\n\t/**\n\t * editor 必填\n\t */\n\teditorRequired(rule: any, value: string, callback: any): void {\n\t\tif (value === \"<p><br></p>\") {\n\t\t\treturn callback(new Error(\"内容不能为空\"));\n\t\t}\n\t\treturn callback();\n\t},\n\t/**\n\t * 外部链接\n\t */\n\texternal(rule: any, value: string, callback: any): void {\n\t\tif (RegExps.External.test(value)) {\n\t\t\tcallback();\n\t\t} else {\n\t\t\tcallback(new Error(\"请输入正确的外部链接\"));\n\t\t}\n\t},\n\t/**\n\t * 有效的URL\n\t */\n\turl(rule: any, value: string, callback: any): void {\n\t\tif (RegExps.Url.test(value)) {\n\t\t\tcallback();\n\t\t} else {\n\t\t\tcallback(new Error(\"请输入有效的Url\"));\n\t\t}\n\t},\n\t/**\n\t * 邮政编码\n\t */\n\tpostCode(rule: any, value: string, callback: any): void {\n\t\tif (RegExps.PostCode.test(value)) {\n\t\t\tcallback();\n\t\t} else {\n\t\t\tcallback(new Error(\"请输入有效的邮政编码\"));\n\t\t}\n\t},\n\t/**\n\t * 账号(6-20位字母或数字,必须以字母开头,不能全为数字)\n\t */\n\taccount(rule: any, value: string, callback: any): void {\n\t\tif (RegExps.Account.test(value)) {\n\t\t\tcallback();\n\t\t} else {\n\t\t\tcallback(new Error(\"请输入有效的账号(6-20位字母或数字,必须以字母开头,不能全为数字)\"));\n\t\t}\n\t},\n\t/**\n\t * 弱密码(只包含字母和数字,长度为6到18位)\n\t */\n\tpassword(rule: any, value: string, callback: any): void {\n\t\tif (RegExps.Password.test(value)) {\n\t\t\tcallback();\n\t\t} else {\n\t\t\tcallback(new Error(\"请输入有效的密码(只包含字母和数字,长度为6到18位)\"));\n\t\t}\n\t},\n\t/**\n\t * 强密码(8到20位,包含大小写字母、数字及特殊字符)\n\t */\n\tstrongPassword(rule: any, value: string, callback: any): void {\n\t\tif (RegExps.StrongPassword.test(value)) {\n\t\t\tcallback();\n\t\t} else {\n\t\t\tcallback(new Error(\"请输入有效的密码(8到20位,包含大小写字母、数字及特殊字符)\"));\n\t\t}\n\t},\n\t/**\n\t * 中文字符\n\t */\n\tchinese(rule: any, value: string, callback: any): void {\n\t\tif (RegExps.Chinese.test(value)) {\n\t\t\tcallback();\n\t\t} else {\n\t\t\tcallback(new Error(\"请输入有效的中文字符\"));\n\t\t}\n\t},\n\t/**\n\t * 英文字符\n\t */\n\tenglish(rule: any, value: string, callback: any): void {\n\t\tif (RegExps.English.test(value)) {\n\t\t\tcallback();\n\t\t} else {\n\t\t\tcallback(new Error(\"请输入有效的英文字符\"));\n\t\t}\n\t},\n\t/**\n\t * 文本框必填\n\t */\n\tinputRequired(message: string, trigger = \"blur\"): FormItemRule {\n\t\treturn {\n\t\t\trequired: true,\n\t\t\tmessage,\n\t\t\ttrigger,\n\t\t};\n\t},\n\t/**\n\t * 选择器必选\n\t */\n\tselectRequired(message: string, trigger = \"change\"): FormItemRule {\n\t\treturn {\n\t\t\trequired: true,\n\t\t\tmessage,\n\t\t\ttrigger,\n\t\t};\n\t},\n};\n"],"mappings":"4IAQA,IAAa,EAAW,CAKvB,SAAS,GACD,IAAI,QAAA,CAAkB,EAAS,KACrC,EAAU,MAAM,SAAA,CAAU,EAAkB,KACvC,EACH,EAAQ,IAEJ,GACH,EAAY,YAAY,EAAO,GAEhC,EAAO,QASX,sBAAsB,GACd,IAAI,QAAA,CAAkB,EAAS,KACrC,EAAU,MAAM,SAAA,CAAU,EAAkB,KACvC,EACH,EAAQ,IAER,EAAU,MAAM,cAAc,OAAO,KAAK,IACtC,GACH,EAAY,YAAY,EAAO,GAEhC,EAAO,QAQX,MAAA,CAAO,EAAW,EAAe,GAC3B,EAEM,EAAQ,OAAO,KAAK,GAC9B,IAEA,EAAS,IAAI,MAAM,eAJnB,EAAS,IAAI,MAAM,aAUrB,KAAA,CAAM,EAAW,EAAe,GAC1B,EAEM,EAAQ,MAAM,KAAK,GAC7B,IAEA,EAAS,IAAI,MAAM,eAJnB,KAUF,KAAA,CAAM,EAAW,EAAe,GAC1B,EAEM,EAAQ,MAAM,KAAK,GAC7B,IAEA,EAAS,IAAI,MAAM,eAJnB,KAUF,MAAA,CAAO,EAAW,EAAe,GAC5B,EAAQ,OAAO,KAAK,KAAW,EAClC,IAEA,EAAS,IAAI,MAAM,iBAMrB,SAAA,CAAU,EAAW,EAAe,GACnC,IAAI,GAAU,EACQ,IAAlB,GAAO,OACV,EAAU,EAAQ,UAAU,KAAK,GACL,IAAlB,GAAO,SACjB,EAAU,EAAQ,mBAAmB,KAAK,IAEvC,EACH,IAEA,EAAS,IAAI,MAAM,gBAMrB,eAAA,CAAe,EAAW,EAAe,IAC1B,gBAAV,EACI,EAAS,IAAI,MAAM,WAEpB,IAKR,QAAA,CAAS,EAAW,EAAe,GAC9B,EAAQ,SAAS,KAAK,GACzB,IAEA,EAAS,IAAI,MAAM,gBAMrB,GAAA,CAAI,EAAW,EAAe,GACzB,EAAQ,IAAI,KAAK,GACpB,IAEA,EAAS,IAAI,MAAM,eAMrB,QAAA,CAAS,EAAW,EAAe,GAC9B,EAAQ,SAAS,KAAK,GACzB,IAEA,EAAS,IAAI,MAAM,gBAMrB,OAAA,CAAQ,EAAW,EAAe,GAC7B,EAAQ,QAAQ,KAAK,GACxB,IAEA,EAAS,IAAI,MAAM,yCAMrB,QAAA,CAAS,EAAW,EAAe,GAC9B,EAAQ,SAAS,KAAK,GACzB,IAEA,EAAS,IAAI,MAAM,iCAMrB,cAAA,CAAe,EAAW,EAAe,GACpC,EAAQ,eAAe,KAAK,GAC/B,IAEA,EAAS,IAAI,MAAM,qCAMrB,OAAA,CAAQ,EAAW,EAAe,GAC7B,EAAQ,QAAQ,KAAK,GACxB,IAEA,EAAS,IAAI,MAAM,gBAMrB,OAAA,CAAQ,EAAW,EAAe,GAC7B,EAAQ,QAAQ,KAAK,GACxB,IAEA,EAAS,IAAI,MAAM,gBAMrB,cAAA,CAAc,EAAiB,EAAU,UACjC,CACN,UAAU,EACV,UACA,YAMF,eAAA,CAAe,EAAiB,EAAU,YAClC,CACN,UAAU,EACV,UACA"}
@@ -1,2 +1,2 @@
1
- import{withInstall as m}from"@fast-china/utils";import r from"./src/formItemTip.mjs";import{faFormItemTipProps as o}from"./src/formItemTip.mjs";const t=m(r);export{t as FaFormItemTip,t as default,o as faFormItemTipProps};
2
- //# sourceMappingURL=index.mjs.map
1
+ import r,{faFormItemTipProps as m}from"./src/formItemTip.mjs";import{withInstall as t}from"@fast-china/utils";var o=t(r);export{o as default};
2
+ //# sourceMappingURL=index.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.mjs","sources":["../../../../packages/components/formItemTip/index.ts"],"sourcesContent":["import { withInstall } from \"@fast-china/utils\";\nimport FormItemTip, { faFormItemTipProps } from \"./src/formItemTip\";\nimport type { ExtractPropTypes } from \"vue\";\n\nexport const FaFormItemTip = withInstall(FormItemTip);\nexport default FaFormItemTip;\n\nexport { faFormItemTipProps };\n\nexport type FaFormItemTipInstance = InstanceType<typeof FormItemTip>;\n\nexport type FaFormItemTipProps = ExtractPropTypes<typeof faFormItemTipProps>;\n"],"names":["FaFormItemTip","withInstall","FormItemTip"],"mappings":"gJAIO,MAAMA,EAAgBC,EAAYC"}
1
+ {"version":3,"file":"index.mjs","names":[],"sources":["../../../../packages/components/formItemTip/index.ts"],"sourcesContent":["import { withInstall } from \"@fast-china/utils\";\nimport FormItemTip, { faFormItemTipProps } from \"./src/formItemTip\";\nimport type { ExtractPropTypes } from \"vue\";\n\nexport const FaFormItemTip = withInstall(FormItemTip);\nexport default FaFormItemTip;\n\nexport { faFormItemTipProps };\n\nexport type FaFormItemTipInstance = InstanceType<typeof FormItemTip>;\n\nexport type FaFormItemTipProps = ExtractPropTypes<typeof faFormItemTipProps>;\n"],"mappings":"8GAIA,IAAa,EAAgB,EAAY"}
@@ -1,2 +1,2 @@
1
- import{defineComponent as t,createVNode as e}from"vue";import{ElTooltip as l,ElIcon as a}from"element-plus";import{QuestionFilled as s}from"@element-plus/icons-vue";import{useRender as o,makeSlots as m}from"@fast-china/utils";const p={tips:String,label:String},i=/* @__PURE__ */t({name:"FaFormItemTip",props:p,slots:m(),setup(t,{attrs:m,slots:p,emit:i,expose:r}){o(()=>e("div",{class:"fa-form-item-tip"},[e(l,{effect:"dark",rawContent:!0,content:t.tips,placement:"top"},{default:()=>[e(a,null,{default:()=>[e(s,null,null)]})]}),e("span",{class:"fa-form-item-tip__label"},[p.label?p.label():t.label])]))}});export{i as default,p as faFormItemTipProps};
2
- //# sourceMappingURL=formItemTip.mjs.map
1
+ import{makeSlots as t,useRender as e}from"@fast-china/utils";import{createVNode as l,defineComponent as a}from"vue";import{ElIcon as s,ElTooltip as o}from"element-plus";import{QuestionFilled as m}from"@element-plus/icons-vue";var p={tips:String,label:String},r=/* @__PURE__ */a({name:"FaFormItemTip",props:p,slots:t(),setup(t,{attrs:a,slots:p,emit:r,expose:i}){e(()=>l("div",{class:"fa-form-item-tip"},[l(o,{effect:"dark",rawContent:!0,content:t.tips,placement:"top"},{default:()=>[l(s,null,{default:()=>[l(m,null,null)]})]}),l("span",{class:"fa-form-item-tip__label"},[p.label?p.label():t.label])]))}});export{r as default,p as faFormItemTipProps};
2
+ //# sourceMappingURL=formItemTip.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"formItemTip.mjs","sources":["../../../../../packages/components/formItemTip/src/formItemTip.tsx"],"sourcesContent":["import { defineComponent } from \"vue\";\nimport { ElIcon, ElTooltip } from \"element-plus\";\nimport { QuestionFilled } from \"@element-plus/icons-vue\";\nimport { makeSlots, useRender } from \"@fast-china/utils\";\n\nexport const faFormItemTipProps = {\n\t/** @description 提示 */\n\ttips: String,\n\t/** @description 显示 */\n\tlabel: String,\n};\n\ntype FaFormItemTipSlots = {\n\t/** @description 显示插槽 */\n\tlabel: never;\n};\n\nexport default defineComponent({\n\tname: \"FaFormItemTip\",\n\tprops: faFormItemTipProps,\n\tslots: makeSlots<FaFormItemTipSlots>(),\n\tsetup(props, { attrs, slots, emit, expose }) {\n\t\tuseRender(() => (\n\t\t\t<div class=\"fa-form-item-tip\">\n\t\t\t\t<ElTooltip effect=\"dark\" rawContent content={props.tips} placement=\"top\">\n\t\t\t\t\t<ElIcon>\n\t\t\t\t\t\t<QuestionFilled />\n\t\t\t\t\t</ElIcon>\n\t\t\t\t</ElTooltip>\n\t\t\t\t<span class=\"fa-form-item-tip__label\">{slots.label ? slots.label() : props.label}</span>\n\t\t\t</div>\n\t\t));\n\t},\n});\n"],"names":["faFormItemTipProps","tips","String","label","FormItemTip","name","props","slots","makeSlots","setup","attrs","emit","expose","useRender","_createVNode","class","ElTooltip","effect","rawContent","content","placement","default","ElIcon","QuestionFilled"],"mappings":"kOAKO,MAAMA,EAAqB,CAEjCC,KAAMC,OAENC,MAAOD,QAQRE,mBAA+B,CAC9BC,KAAM,gBACNC,MAAON,EACPO,MAAOC,IACPC,KAAAA,CAAMH,GAAOI,MAAEA,EAAAA,MAAOH,EAAAA,KAAOI,EAAAA,OAAMC,IAClCC,EAAU,IAAAC,EAAA,MAAA,CAAAC,MAAA,oBAAA,CAAAD,EAAAE,EAAA,CAAAC,OAAA,OAAAC,YAAA,EAAAC,QAEqCb,EAAML,KAAImB,UAAA,OAAA,CAAAC,QAAAA,IAAA,CAAAP,EAAAQ,EAAA,KAAA,CAAAD,QAAAA,IAAA,CAAAP,EAAAS,EAAA,KAAA,YAAAT,EAAA,OAAA,CAAAC,MAAA,2BAAA,CAKhBR,EAAMJ,MAAQI,EAAMJ,QAAUG,EAAMH,UAG9E"}
1
+ {"version":3,"file":"formItemTip.mjs","names":["defineComponent","createVNode","_createVNode","ElIcon","ElTooltip","QuestionFilled","makeSlots","useRender","faFormItemTipProps","tips","String","label","name","props","slots","setup","attrs","emit","expose","default"],"sources":["../../../../../packages/components/formItemTip/src/formItemTip.tsx"],"sourcesContent":["import { defineComponent } from \"vue\";\nimport { ElIcon, ElTooltip } from \"element-plus\";\nimport { QuestionFilled } from \"@element-plus/icons-vue\";\nimport { makeSlots, useRender } from \"@fast-china/utils\";\n\nexport const faFormItemTipProps = {\n\t/** @description 提示 */\n\ttips: String,\n\t/** @description 显示 */\n\tlabel: String,\n};\n\ntype FaFormItemTipSlots = {\n\t/** @description 显示插槽 */\n\tlabel: never;\n};\n\nexport default defineComponent({\n\tname: \"FaFormItemTip\",\n\tprops: faFormItemTipProps,\n\tslots: makeSlots<FaFormItemTipSlots>(),\n\tsetup(props, { attrs, slots, emit, expose }) {\n\t\tuseRender(() => (\n\t\t\t<div class=\"fa-form-item-tip\">\n\t\t\t\t<ElTooltip effect=\"dark\" rawContent content={props.tips} placement=\"top\">\n\t\t\t\t\t<ElIcon>\n\t\t\t\t\t\t<QuestionFilled />\n\t\t\t\t\t</ElIcon>\n\t\t\t\t</ElTooltip>\n\t\t\t\t<span class=\"fa-form-item-tip__label\">{slots.label ? slots.label() : props.label}</span>\n\t\t\t</div>\n\t\t));\n\t},\n});\n"],"mappings":"kOAKA,IAAaQ,EAAqB,CAEjCC,KAAMC,OAENC,MAAOD,QAQR,iBAAeV,EAAgB,CAC9BY,KAAM,gBACNC,MAAOL,EACPM,MAAOR,IACPS,KAAAA,CAAMF,GAAO,MAAEG,EAAAA,MAAOF,EAAAA,KAAOG,EAAAA,OAAMC,IAClCX,EAAAA,IAAUL,EAAA,MAAA,CAAA,MAAA,oBAAA,CAAAA,EAAAE,EAAA,CAAA,OAAA,OAAA,YAAA,EAAA,QAEqCS,EAAMJ,KAAI,UAAA,OAAA,CAAAU,QAAAA,IAAA,CAAAjB,EAAAC,EAAA,KAAA,CAAAgB,QAAAA,IAAA,CAAAjB,EAAAG,EAAA,KAAA,YAAAH,EAAA,OAAA,CAAA,MAAA,2BAAA,CAKhBY,EAAMH,MAAQG,EAAMH,QAAUE,EAAMF"}
@@ -1,2 +1,2 @@
1
- import{withInstall as o}from"@fast-china/utils";import t from"./src/icon.mjs";const r=o(t);export{r as FaIcon,r as default};
2
- //# sourceMappingURL=index.mjs.map
1
+ import r from"./src/icon.mjs";import{withInstall as o}from"@fast-china/utils";var t=o(r);export{t as default};
2
+ //# sourceMappingURL=index.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.mjs","sources":["../../../../packages/components/icon/index.ts"],"sourcesContent":["import { withInstall } from \"@fast-china/utils\";\nimport Icon from \"./src/icon\";\nimport type { faIconProps } from \"./src/icon\";\nimport type { ExtractPropTypes } from \"vue\";\n\nexport const FaIcon = withInstall(Icon);\nexport default FaIcon;\n\nexport { faIconProps };\n\nexport type FaIconInstance = InstanceType<typeof Icon>;\n\nexport type FaIconProps = ExtractPropTypes<typeof faIconProps>;\n"],"names":["FaIcon","withInstall","Icon"],"mappings":"8EAKO,MAAMA,EAASC,EAAYC"}
1
+ {"version":3,"file":"index.mjs","names":[],"sources":["../../../../packages/components/icon/index.ts"],"sourcesContent":["import { withInstall } from \"@fast-china/utils\";\nimport Icon from \"./src/icon\";\nimport type { faIconProps } from \"./src/icon\";\nimport type { ExtractPropTypes } from \"vue\";\n\nexport const FaIcon = withInstall(Icon);\nexport default FaIcon;\n\nexport { faIconProps };\n\nexport type FaIconInstance = InstanceType<typeof Icon>;\n\nexport type FaIconProps = ExtractPropTypes<typeof faIconProps>;\n"],"mappings":"8EAKA,IAAa,EAAS,EAAY"}