skyline-vue-admin 0.0.1

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 (376) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +5 -0
  3. package/dist/components/auto-complete-array-input/index.cjs +2 -0
  4. package/dist/components/auto-complete-array-input/index.cjs.map +1 -0
  5. package/dist/components/auto-complete-array-input/index.d.ts +12 -0
  6. package/dist/components/auto-complete-array-input/index.mjs +151 -0
  7. package/dist/components/auto-complete-array-input/index.mjs.map +1 -0
  8. package/dist/components/avatar-input/index.cjs +2 -0
  9. package/dist/components/avatar-input/index.cjs.map +1 -0
  10. package/dist/components/avatar-input/index.d.ts +13 -0
  11. package/dist/components/avatar-input/index.mjs +160 -0
  12. package/dist/components/avatar-input/index.mjs.map +1 -0
  13. package/dist/components/can-access/index.cjs +2 -0
  14. package/dist/components/can-access/index.cjs.map +1 -0
  15. package/dist/components/can-access/index.d.ts +2 -0
  16. package/dist/components/can-access/index.mjs +46 -0
  17. package/dist/components/can-access/index.mjs.map +1 -0
  18. package/dist/components/create/index.cjs +2 -0
  19. package/dist/components/create/index.cjs.map +1 -0
  20. package/dist/components/create/index.d.ts +2 -0
  21. package/dist/components/create/index.mjs +96 -0
  22. package/dist/components/create/index.mjs.map +1 -0
  23. package/dist/components/data-table/index.cjs +2 -0
  24. package/dist/components/data-table/index.cjs.map +1 -0
  25. package/dist/components/data-table/index.d.ts +5 -0
  26. package/dist/components/data-table/index.mjs +131 -0
  27. package/dist/components/data-table/index.mjs.map +1 -0
  28. package/dist/components/data-table-col/index.cjs +2 -0
  29. package/dist/components/data-table-col/index.cjs.map +1 -0
  30. package/dist/components/data-table-col/index.d.ts +12 -0
  31. package/dist/components/data-table-col/index.mjs +60 -0
  32. package/dist/components/data-table-col/index.mjs.map +1 -0
  33. package/dist/components/edit/index.cjs +2 -0
  34. package/dist/components/edit/index.cjs.map +1 -0
  35. package/dist/components/edit/index.d.ts +6 -0
  36. package/dist/components/edit/index.mjs +153 -0
  37. package/dist/components/edit/index.mjs.map +1 -0
  38. package/dist/components/edit-button/index.cjs +2 -0
  39. package/dist/components/edit-button/index.cjs.map +1 -0
  40. package/dist/components/edit-button/index.d.ts +6 -0
  41. package/dist/components/edit-button/index.mjs +60 -0
  42. package/dist/components/edit-button/index.mjs.map +1 -0
  43. package/dist/components/file-multiple-input/index.cjs +2 -0
  44. package/dist/components/file-multiple-input/index.cjs.map +1 -0
  45. package/dist/components/file-multiple-input/index.d.ts +18 -0
  46. package/dist/components/file-multiple-input/index.mjs +189 -0
  47. package/dist/components/file-multiple-input/index.mjs.map +1 -0
  48. package/dist/components/filter/index.cjs +2 -0
  49. package/dist/components/filter/index.cjs.map +1 -0
  50. package/dist/components/filter/index.d.ts +2 -0
  51. package/dist/components/filter/index.mjs +63 -0
  52. package/dist/components/filter/index.mjs.map +1 -0
  53. package/dist/components/image-field/index.cjs +2 -0
  54. package/dist/components/image-field/index.cjs.map +1 -0
  55. package/dist/components/image-field/index.d.ts +8 -0
  56. package/dist/components/image-field/index.mjs +62 -0
  57. package/dist/components/image-field/index.mjs.map +1 -0
  58. package/dist/components/index.d.ts +27 -0
  59. package/dist/components/link-field/index.cjs +2 -0
  60. package/dist/components/link-field/index.cjs.map +1 -0
  61. package/dist/components/link-field/index.d.ts +7 -0
  62. package/dist/components/link-field/index.mjs +70 -0
  63. package/dist/components/link-field/index.mjs.map +1 -0
  64. package/dist/components/list/index.cjs +2 -0
  65. package/dist/components/list/index.cjs.map +1 -0
  66. package/dist/components/list/index.d.ts +7 -0
  67. package/dist/components/list/index.mjs +154 -0
  68. package/dist/components/list/index.mjs.map +1 -0
  69. package/dist/components/list/list.cjs +3 -0
  70. package/dist/components/list/list.cjs.map +1 -0
  71. package/dist/components/list/list.d.ts +10 -0
  72. package/dist/components/list/list.mjs +17 -0
  73. package/dist/components/list/list.mjs.map +1 -0
  74. package/dist/components/radio-button-group-input/index.cjs +2 -0
  75. package/dist/components/radio-button-group-input/index.cjs.map +1 -0
  76. package/dist/components/radio-button-group-input/index.d.ts +14 -0
  77. package/dist/components/radio-button-group-input/index.mjs +82 -0
  78. package/dist/components/radio-button-group-input/index.mjs.map +1 -0
  79. package/dist/components/reference-array-field/index.cjs +2 -0
  80. package/dist/components/reference-array-field/index.cjs.map +1 -0
  81. package/dist/components/reference-array-field/index.d.ts +7 -0
  82. package/dist/components/reference-array-field/index.mjs +76 -0
  83. package/dist/components/reference-array-field/index.mjs.map +1 -0
  84. package/dist/components/reference-array-input/index.cjs +2 -0
  85. package/dist/components/reference-array-input/index.cjs.map +1 -0
  86. package/dist/components/reference-array-input/index.d.ts +6 -0
  87. package/dist/components/reference-array-input/index.mjs +74 -0
  88. package/dist/components/reference-array-input/index.mjs.map +1 -0
  89. package/dist/components/reference-field/index.cjs +2 -0
  90. package/dist/components/reference-field/index.cjs.map +1 -0
  91. package/dist/components/reference-field/index.d.ts +10 -0
  92. package/dist/components/reference-field/index.mjs +101 -0
  93. package/dist/components/reference-field/index.mjs.map +1 -0
  94. package/dist/components/reference-image-field/index.cjs +2 -0
  95. package/dist/components/reference-image-field/index.cjs.map +1 -0
  96. package/dist/components/reference-image-field/index.d.ts +9 -0
  97. package/dist/components/reference-image-field/index.mjs +79 -0
  98. package/dist/components/reference-image-field/index.mjs.map +1 -0
  99. package/dist/components/show/index.cjs +2 -0
  100. package/dist/components/show/index.cjs.map +1 -0
  101. package/dist/components/show/index.d.ts +2 -0
  102. package/dist/components/show/index.mjs +66 -0
  103. package/dist/components/show/index.mjs.map +1 -0
  104. package/dist/components/show-button/index.cjs +2 -0
  105. package/dist/components/show-button/index.cjs.map +1 -0
  106. package/dist/components/show-button/index.d.ts +6 -0
  107. package/dist/components/show-button/index.mjs +60 -0
  108. package/dist/components/show-button/index.mjs.map +1 -0
  109. package/dist/components/show-simple-layout/index.cjs +2 -0
  110. package/dist/components/show-simple-layout/index.cjs.map +1 -0
  111. package/dist/components/show-simple-layout/index.d.ts +1 -0
  112. package/dist/components/show-simple-layout/index.mjs +36 -0
  113. package/dist/components/show-simple-layout/index.mjs.map +1 -0
  114. package/dist/components/simple-form/index.cjs +2 -0
  115. package/dist/components/simple-form/index.cjs.map +1 -0
  116. package/dist/components/simple-form/index.d.ts +6 -0
  117. package/dist/components/simple-form/index.mjs +53 -0
  118. package/dist/components/simple-form/index.mjs.map +1 -0
  119. package/dist/components/single-field-list/index.cjs +2 -0
  120. package/dist/components/single-field-list/index.cjs.map +1 -0
  121. package/dist/components/single-field-list/index.d.ts +4 -0
  122. package/dist/components/single-field-list/index.mjs +56 -0
  123. package/dist/components/single-field-list/index.mjs.map +1 -0
  124. package/dist/components/text-field/index.cjs +2 -0
  125. package/dist/components/text-field/index.cjs.map +1 -0
  126. package/dist/components/text-field/index.d.ts +7 -0
  127. package/dist/components/text-field/index.mjs +56 -0
  128. package/dist/components/text-field/index.mjs.map +1 -0
  129. package/dist/components/text-input/index.cjs +2 -0
  130. package/dist/components/text-input/index.cjs.map +1 -0
  131. package/dist/components/text-input/index.d.ts +9 -0
  132. package/dist/components/text-input/index.mjs +70 -0
  133. package/dist/components/text-input/index.mjs.map +1 -0
  134. package/dist/components/tree-select-input/index.cjs +2 -0
  135. package/dist/components/tree-select-input/index.cjs.map +1 -0
  136. package/dist/components/tree-select-input/index.d.ts +15 -0
  137. package/dist/components/tree-select-input/index.mjs +122 -0
  138. package/dist/components/tree-select-input/index.mjs.map +1 -0
  139. package/dist/components/tree-with-details/index.cjs +2 -0
  140. package/dist/components/tree-with-details/index.cjs.map +1 -0
  141. package/dist/components/tree-with-details/index.d.ts +11 -0
  142. package/dist/components/tree-with-details/index.mjs +133 -0
  143. package/dist/components/tree-with-details/index.mjs.map +1 -0
  144. package/dist/hooks/index.d.ts +17 -0
  145. package/dist/hooks/useDelegate.d.ts +4 -0
  146. package/dist/hooks/useForm.cjs +2 -0
  147. package/dist/hooks/useForm.cjs.map +1 -0
  148. package/dist/hooks/useForm.d.ts +9 -0
  149. package/dist/hooks/useForm.mjs +18 -0
  150. package/dist/hooks/useForm.mjs.map +1 -0
  151. package/dist/hooks/useFormGrid.cjs +2 -0
  152. package/dist/hooks/useFormGrid.cjs.map +1 -0
  153. package/dist/hooks/useFormGrid.d.ts +1 -0
  154. package/dist/hooks/useFormGrid.mjs +7 -0
  155. package/dist/hooks/useFormGrid.mjs.map +1 -0
  156. package/dist/hooks/useHiddenTitle.cjs +2 -0
  157. package/dist/hooks/useHiddenTitle.cjs.map +1 -0
  158. package/dist/hooks/useHiddenTitle.d.ts +1 -0
  159. package/dist/hooks/useHiddenTitle.mjs +9 -0
  160. package/dist/hooks/useHiddenTitle.mjs.map +1 -0
  161. package/dist/hooks/useLang.cjs +2 -0
  162. package/dist/hooks/useLang.cjs.map +1 -0
  163. package/dist/hooks/useLang.d.ts +4 -0
  164. package/dist/hooks/useLang.mjs +15 -0
  165. package/dist/hooks/useLang.mjs.map +1 -0
  166. package/dist/hooks/useList.cjs +2 -0
  167. package/dist/hooks/useList.cjs.map +1 -0
  168. package/dist/hooks/useList.d.ts +22 -0
  169. package/dist/hooks/useList.mjs +19 -0
  170. package/dist/hooks/useList.mjs.map +1 -0
  171. package/dist/hooks/useMenu.cjs +2 -0
  172. package/dist/hooks/useMenu.cjs.map +1 -0
  173. package/dist/hooks/useMenu.d.ts +5 -0
  174. package/dist/hooks/useMenu.mjs +26 -0
  175. package/dist/hooks/useMenu.mjs.map +1 -0
  176. package/dist/hooks/usePermission.cjs +2 -0
  177. package/dist/hooks/usePermission.cjs.map +1 -0
  178. package/dist/hooks/usePermission.d.ts +4 -0
  179. package/dist/hooks/usePermission.mjs +13 -0
  180. package/dist/hooks/usePermission.mjs.map +1 -0
  181. package/dist/hooks/useReferenceArrayField.cjs +2 -0
  182. package/dist/hooks/useReferenceArrayField.cjs.map +1 -0
  183. package/dist/hooks/useReferenceArrayField.d.ts +8 -0
  184. package/dist/hooks/useReferenceArrayField.mjs +9 -0
  185. package/dist/hooks/useReferenceArrayField.mjs.map +1 -0
  186. package/dist/hooks/useReferenceArrayInput.cjs +2 -0
  187. package/dist/hooks/useReferenceArrayInput.cjs.map +1 -0
  188. package/dist/hooks/useReferenceArrayInput.d.ts +9 -0
  189. package/dist/hooks/useReferenceArrayInput.mjs +9 -0
  190. package/dist/hooks/useReferenceArrayInput.mjs.map +1 -0
  191. package/dist/hooks/useRouteKeepAlive.cjs +2 -0
  192. package/dist/hooks/useRouteKeepAlive.cjs.map +1 -0
  193. package/dist/hooks/useRouteKeepAlive.d.ts +5 -0
  194. package/dist/hooks/useRouteKeepAlive.mjs +19 -0
  195. package/dist/hooks/useRouteKeepAlive.mjs.map +1 -0
  196. package/dist/hooks/useShow.cjs +2 -0
  197. package/dist/hooks/useShow.cjs.map +1 -0
  198. package/dist/hooks/useShow.d.ts +6 -0
  199. package/dist/hooks/useShow.mjs +9 -0
  200. package/dist/hooks/useShow.mjs.map +1 -0
  201. package/dist/hooks/useSize.cjs +2 -0
  202. package/dist/hooks/useSize.cjs.map +1 -0
  203. package/dist/hooks/useSize.d.ts +28 -0
  204. package/dist/hooks/useSize.mjs +30 -0
  205. package/dist/hooks/useSize.mjs.map +1 -0
  206. package/dist/hooks/useTab.cjs +2 -0
  207. package/dist/hooks/useTab.cjs.map +1 -0
  208. package/dist/hooks/useTab.d.ts +18 -0
  209. package/dist/hooks/useTab.mjs +50 -0
  210. package/dist/hooks/useTab.mjs.map +1 -0
  211. package/dist/hooks/useTheme.cjs +2 -0
  212. package/dist/hooks/useTheme.cjs.map +1 -0
  213. package/dist/hooks/useTheme.d.ts +23 -0
  214. package/dist/hooks/useTheme.mjs +24 -0
  215. package/dist/hooks/useTheme.mjs.map +1 -0
  216. package/dist/hooks/useTreeWithDetails.cjs +2 -0
  217. package/dist/hooks/useTreeWithDetails.cjs.map +1 -0
  218. package/dist/hooks/useTreeWithDetails.d.ts +7 -0
  219. package/dist/hooks/useTreeWithDetails.mjs +9 -0
  220. package/dist/hooks/useTreeWithDetails.mjs.map +1 -0
  221. package/dist/hooks/useUpload.cjs +2 -0
  222. package/dist/hooks/useUpload.cjs.map +1 -0
  223. package/dist/hooks/useUpload.d.ts +8 -0
  224. package/dist/hooks/useUpload.mjs +8 -0
  225. package/dist/hooks/useUpload.mjs.map +1 -0
  226. package/dist/hooks/useUser.cjs +2 -0
  227. package/dist/hooks/useUser.cjs.map +1 -0
  228. package/dist/hooks/useUser.d.ts +9 -0
  229. package/dist/hooks/useUser.mjs +24 -0
  230. package/dist/hooks/useUser.mjs.map +1 -0
  231. package/dist/i18n/locales/en.json.cjs +2 -0
  232. package/dist/i18n/locales/en.json.cjs.map +1 -0
  233. package/dist/i18n/locales/en.json.d.ts +52 -0
  234. package/dist/i18n/locales/en.json.mjs +32 -0
  235. package/dist/i18n/locales/en.json.mjs.map +1 -0
  236. package/dist/icons/EpDelete.cjs +2 -0
  237. package/dist/icons/EpDelete.cjs.map +1 -0
  238. package/dist/icons/EpDelete.d.ts +1 -0
  239. package/dist/icons/EpDelete.mjs +17 -0
  240. package/dist/icons/EpDelete.mjs.map +1 -0
  241. package/dist/icons/EpDocumentAdd.cjs +2 -0
  242. package/dist/icons/EpDocumentAdd.cjs.map +1 -0
  243. package/dist/icons/EpDocumentAdd.d.ts +1 -0
  244. package/dist/icons/EpDocumentAdd.mjs +17 -0
  245. package/dist/icons/EpDocumentAdd.mjs.map +1 -0
  246. package/dist/icons/EpDownload.cjs +2 -0
  247. package/dist/icons/EpDownload.cjs.map +1 -0
  248. package/dist/icons/EpDownload.d.ts +1 -0
  249. package/dist/icons/EpDownload.mjs +17 -0
  250. package/dist/icons/EpDownload.mjs.map +1 -0
  251. package/dist/icons/EpFullScreen.cjs +2 -0
  252. package/dist/icons/EpFullScreen.cjs.map +1 -0
  253. package/dist/icons/EpFullScreen.d.ts +1 -0
  254. package/dist/icons/EpFullScreen.mjs +19 -0
  255. package/dist/icons/EpFullScreen.mjs.map +1 -0
  256. package/dist/icons/EpMoon.cjs +2 -0
  257. package/dist/icons/EpMoon.cjs.map +1 -0
  258. package/dist/icons/EpMoon.d.ts +1 -0
  259. package/dist/icons/EpMoon.mjs +17 -0
  260. package/dist/icons/EpMoon.mjs.map +1 -0
  261. package/dist/icons/EpPlus.cjs +2 -0
  262. package/dist/icons/EpPlus.cjs.map +1 -0
  263. package/dist/icons/EpPlus.d.ts +1 -0
  264. package/dist/icons/EpPlus.mjs +17 -0
  265. package/dist/icons/EpPlus.mjs.map +1 -0
  266. package/dist/icons/EpRefresh.cjs +2 -0
  267. package/dist/icons/EpRefresh.cjs.map +1 -0
  268. package/dist/icons/EpRefresh.d.ts +1 -0
  269. package/dist/icons/EpRefresh.mjs +19 -0
  270. package/dist/icons/EpRefresh.mjs.map +1 -0
  271. package/dist/icons/EpSearch.d.ts +1 -0
  272. package/dist/icons/EpSunny.cjs +2 -0
  273. package/dist/icons/EpSunny.cjs.map +1 -0
  274. package/dist/icons/EpSunny.d.ts +1 -0
  275. package/dist/icons/EpSunny.mjs +17 -0
  276. package/dist/icons/EpSunny.mjs.map +1 -0
  277. package/dist/icons/EpSwitchFilled.cjs +2 -0
  278. package/dist/icons/EpSwitchFilled.cjs.map +1 -0
  279. package/dist/icons/EpSwitchFilled.d.ts +1 -0
  280. package/dist/icons/EpSwitchFilled.mjs +20 -0
  281. package/dist/icons/EpSwitchFilled.mjs.map +1 -0
  282. package/dist/icons/EpUploadFilled.cjs +2 -0
  283. package/dist/icons/EpUploadFilled.cjs.map +1 -0
  284. package/dist/icons/EpUploadFilled.d.ts +1 -0
  285. package/dist/icons/EpUploadFilled.mjs +17 -0
  286. package/dist/icons/EpUploadFilled.mjs.map +1 -0
  287. package/dist/icons/FluentFullScreenMinimize20Regular.cjs +2 -0
  288. package/dist/icons/FluentFullScreenMinimize20Regular.cjs.map +1 -0
  289. package/dist/icons/FluentFullScreenMinimize20Regular.d.ts +1 -0
  290. package/dist/icons/FluentFullScreenMinimize20Regular.mjs +19 -0
  291. package/dist/icons/FluentFullScreenMinimize20Regular.mjs.map +1 -0
  292. package/dist/icons/NimbusTextSize.cjs +2 -0
  293. package/dist/icons/NimbusTextSize.cjs.map +1 -0
  294. package/dist/icons/NimbusTextSize.d.ts +1 -0
  295. package/dist/icons/NimbusTextSize.mjs +20 -0
  296. package/dist/icons/NimbusTextSize.mjs.map +1 -0
  297. package/dist/icons/SkyMenuCollapse.cjs +2 -0
  298. package/dist/icons/SkyMenuCollapse.cjs.map +1 -0
  299. package/dist/icons/SkyMenuCollapse.d.ts +1 -0
  300. package/dist/icons/SkyMenuCollapse.mjs +30 -0
  301. package/dist/icons/SkyMenuCollapse.mjs.map +1 -0
  302. package/dist/icons/SlTrans.cjs +2 -0
  303. package/dist/icons/SlTrans.cjs.map +1 -0
  304. package/dist/icons/SlTrans.d.ts +1 -0
  305. package/dist/icons/SlTrans.mjs +19 -0
  306. package/dist/icons/SlTrans.mjs.map +1 -0
  307. package/dist/index.cjs +2 -0
  308. package/dist/index.cjs.map +1 -0
  309. package/dist/index.d.ts +5 -0
  310. package/dist/index.mjs +114 -0
  311. package/dist/index.mjs.map +1 -0
  312. package/dist/layouts/default.cjs +2 -0
  313. package/dist/layouts/default.cjs.map +1 -0
  314. package/dist/layouts/default.d.ts +8 -0
  315. package/dist/layouts/default.mjs +398 -0
  316. package/dist/layouts/default.mjs.map +1 -0
  317. package/dist/pages/login.cjs +2 -0
  318. package/dist/pages/login.cjs.map +1 -0
  319. package/dist/pages/login.d.ts +2 -0
  320. package/dist/pages/login.mjs +78 -0
  321. package/dist/pages/login.mjs.map +1 -0
  322. package/dist/pages/not-found.cjs +2 -0
  323. package/dist/pages/not-found.cjs.map +1 -0
  324. package/dist/pages/not-found.d.ts +2 -0
  325. package/dist/pages/not-found.mjs +29 -0
  326. package/dist/pages/not-found.mjs.map +1 -0
  327. package/dist/pages/welcome.cjs +2 -0
  328. package/dist/pages/welcome.cjs.map +1 -0
  329. package/dist/pages/welcome.d.ts +2 -0
  330. package/dist/pages/welcome.mjs +13 -0
  331. package/dist/pages/welcome.mjs.map +1 -0
  332. package/dist/provides/dataProvider.d.ts +111 -0
  333. package/dist/provides/index.d.ts +1 -0
  334. package/dist/router/index.cjs +2 -0
  335. package/dist/router/index.cjs.map +1 -0
  336. package/dist/router/index.d.ts +25 -0
  337. package/dist/router/index.mjs +136 -0
  338. package/dist/router/index.mjs.map +1 -0
  339. package/dist/setup/index.cjs +2 -0
  340. package/dist/setup/index.cjs.map +1 -0
  341. package/dist/setup/index.d.ts +68 -0
  342. package/dist/setup/index.mjs +55 -0
  343. package/dist/setup/index.mjs.map +1 -0
  344. package/dist/styles/components/auto-complete-array-input.css +1 -0
  345. package/dist/styles/components/avatar-input.css +1 -0
  346. package/dist/styles/components/can-access.css +1 -0
  347. package/dist/styles/components/create.css +1 -0
  348. package/dist/styles/components/data-table-col.css +1 -0
  349. package/dist/styles/components/data-table.css +1 -0
  350. package/dist/styles/components/edit-button.css +1 -0
  351. package/dist/styles/components/edit.css +1 -0
  352. package/dist/styles/components/file-multiple-input.css +1 -0
  353. package/dist/styles/components/filter.css +1 -0
  354. package/dist/styles/components/image-field.css +1 -0
  355. package/dist/styles/components/link-field.css +1 -0
  356. package/dist/styles/components/list.css +1 -0
  357. package/dist/styles/components/radio-button-group-input.css +1 -0
  358. package/dist/styles/components/reference-array-field.css +1 -0
  359. package/dist/styles/components/reference-array-input.css +1 -0
  360. package/dist/styles/components/reference-field.css +1 -0
  361. package/dist/styles/components/reference-image-field.css +1 -0
  362. package/dist/styles/components/show-button.css +1 -0
  363. package/dist/styles/components/show-simple-layout.css +1 -0
  364. package/dist/styles/components/show.css +1 -0
  365. package/dist/styles/components/simple-form.css +1 -0
  366. package/dist/styles/components/single-field-list.css +1 -0
  367. package/dist/styles/components/text-field.css +1 -0
  368. package/dist/styles/components/text-input.css +1 -0
  369. package/dist/styles/components/tree-select-input.css +1 -0
  370. package/dist/styles/components/tree-with-details.css +1 -0
  371. package/dist/styles/index.css +1 -0
  372. package/dist/styles/layouts/default.css +1 -0
  373. package/dist/styles/pages/login.css +1 -0
  374. package/dist/styles/pages/not-found.css +1 -0
  375. package/dist/styles/pages/welcome.css +1 -0
  376. package/package.json +54 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.cjs","sources":["../../../src/components/simple-form/index.tsx"],"sourcesContent":["import { useForm, useProvideFormGrid } from '@/hooks'\nimport { ElForm, type FormProps, type FormRules } from 'element-plus'\nimport { defineComponent, useTemplateRef, watchEffect } from 'vue'\n\nexport interface SkySimpleFormProps {\n grid?: boolean\n rules?: FormRules\n}\n\nexport const SkySimpleForm = defineComponent<SkySimpleFormProps & Partial<FormProps>>({\n name: 'SkySimpleForm',\n props: {\n grid: {\n type: Boolean,\n default: false,\n },\n rules: Object,\n },\n setup(props, { slots }) {\n useProvideFormGrid(props.grid!)\n const { formData, setFormRef } = useForm()!\n const formRef = useTemplateRef<InstanceType<typeof ElForm> | null>('formRef')\n watchEffect(() => {\n setFormRef(formRef.value)\n })\n return () => (\n <ElForm\n ref=\"formRef\"\n class={`sky-simple-form${props.grid ? ' is-grid' : ''}`}\n model={formData}\n label-position=\"top\"\n rules={props.rules}\n >\n {slots.default?.()}\n </ElForm>\n )\n },\n})\n"],"names":["SkySimpleForm","defineComponent","name","props","grid","type","default","rules","slots","useProvideFormGrid","setFormRef","formRef","useTemplateRef","watchEffect","formData"],"mappings":"g0BASAA,EAAAC,EAAAA,gBAAA,CACEC,KAAAA,gBACAC,MAAAA,CACEC,KAAAA,CACEC,KAAAA,QACAC,QAAAA,IAEFC,MAAAA,iBAEaC,MAAAA,CAAM,EAAA,CACnBC,EAAAA,mBAAAA,EAAAA,IAAAA,mBACkBC,WAAAA,eAClBC,EAAAC,EAAAA,eAAA,SAAA,EACAC,OAAAA,EAAAA,YAAAA,IAAAA,CACEH,EAAAA,EAAAA,KAAAA,CACF,CAAA,8BACO,IAAA,yDAGoD,MAAAI,EACxC,iBAAA,MAAA,MAAAX,EAAA,KAEG,EAAA,CAAAG,QAAAA,IAAAA,CAAAA,EAAAA,UAAAA,CAAAA,GAKxB,CACF,CAAA"}
@@ -0,0 +1,6 @@
1
+ import { FormProps, FormRules } from 'element-plus';
2
+ export interface SkySimpleFormProps {
3
+ grid?: boolean;
4
+ rules?: FormRules;
5
+ }
6
+ export declare const SkySimpleForm: import('vue').DefineComponent<SkySimpleFormProps & Partial<FormProps>, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<SkySimpleFormProps & Partial<FormProps>> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, any>;
@@ -0,0 +1,53 @@
1
+ import "element-plus/es/components/form/style/css";
2
+ import { defineComponent as i, useTemplateRef as p, watchEffect as f, createVNode as l } from "vue";
3
+ import "../../hooks/useUser.mjs";
4
+ import "../../hooks/usePermission.mjs";
5
+ import "../../hooks/useMenu.mjs";
6
+ import "../../hooks/useTab.mjs";
7
+ import "../../hooks/useRouteKeepAlive.mjs";
8
+ import "../../hooks/useSize.mjs";
9
+ import "../../hooks/useLang.mjs";
10
+ import "../../hooks/useTheme.mjs";
11
+ import "../../hooks/useList.mjs";
12
+ import "../../hooks/useHiddenTitle.mjs";
13
+ import { useForm as s } from "../../hooks/useForm.mjs";
14
+ import "../../hooks/useShow.mjs";
15
+ import "../../hooks/useReferenceArrayField.mjs";
16
+ import "../../hooks/useTreeWithDetails.mjs";
17
+ import { useProvideFormGrid as a } from "../../hooks/useFormGrid.mjs";
18
+ import "../../hooks/useReferenceArrayInput.mjs";
19
+ import { ElForm as d } from "element-plus";
20
+ const G = /* @__PURE__ */ i({
21
+ name: "SkySimpleForm",
22
+ props: {
23
+ grid: {
24
+ type: Boolean,
25
+ default: !1
26
+ },
27
+ rules: Object
28
+ },
29
+ setup(o, {
30
+ slots: r
31
+ }) {
32
+ a(o.grid);
33
+ const {
34
+ formData: m,
35
+ setFormRef: e
36
+ } = s(), t = p("formRef");
37
+ return f(() => {
38
+ e(t.value);
39
+ }), () => l(d, {
40
+ ref: "formRef",
41
+ class: `sky-simple-form${o.grid ? " is-grid" : ""}`,
42
+ model: m,
43
+ "label-position": "top",
44
+ rules: o.rules
45
+ }, {
46
+ default: () => [r.default?.()]
47
+ });
48
+ }
49
+ });
50
+ export {
51
+ G as SkySimpleForm
52
+ };
53
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.mjs","sources":["../../../src/components/simple-form/index.tsx"],"sourcesContent":["import { useForm, useProvideFormGrid } from '@/hooks'\nimport { ElForm, type FormProps, type FormRules } from 'element-plus'\nimport { defineComponent, useTemplateRef, watchEffect } from 'vue'\n\nexport interface SkySimpleFormProps {\n grid?: boolean\n rules?: FormRules\n}\n\nexport const SkySimpleForm = defineComponent<SkySimpleFormProps & Partial<FormProps>>({\n name: 'SkySimpleForm',\n props: {\n grid: {\n type: Boolean,\n default: false,\n },\n rules: Object,\n },\n setup(props, { slots }) {\n useProvideFormGrid(props.grid!)\n const { formData, setFormRef } = useForm()!\n const formRef = useTemplateRef<InstanceType<typeof ElForm> | null>('formRef')\n watchEffect(() => {\n setFormRef(formRef.value)\n })\n return () => (\n <ElForm\n ref=\"formRef\"\n class={`sky-simple-form${props.grid ? ' is-grid' : ''}`}\n model={formData}\n label-position=\"top\"\n rules={props.rules}\n >\n {slots.default?.()}\n </ElForm>\n )\n },\n})\n"],"names":["SkySimpleForm","defineComponent","name","props","grid","type","default","rules","slots","useProvideFormGrid","setFormRef","formRef","useTemplateRef","watchEffect","formData"],"mappings":";;;;;;;;;;;;;;;;;;;AASA,MAAAA,IAAA,gBAAAC,EAAA;AAAA,EACEC,MAAAA;AAAAA,EACAC,OAAAA;AAAAA,IACEC,MAAAA;AAAAA,MACEC,MAAAA;AAAAA,MACAC,SAAAA;AAAAA;IAEFC,OAAAA;AAAAA;;IAEaC,OAAAA;AAAAA,EAAM,GAAA;AACnBC,IAAAA,EAAAA,EAAAA,IAAAA;;;MACkBC,YAAAA;AAAAA,aAClBC,IAAAC,EAAA,SAAA;AACAC,WAAAA,EAAAA,MAAAA;AACEH,MAAAA,EAAAA,EAAAA,KAAAA;AAAAA,IACF,CAAA;MACO,KAAA;AAAA;MAGoD,OAAAI;AAAA,MACxC,kBAAA;AAAA,MAAA,OAAAX,EAAA;AAAA,IAEG,GAAA;AAAA,MAAAG,SAAAA,MAAAA,CAAAA,EAAAA,UAAAA,CAAAA;AAAAA;EAKxB;AACF,CAAA;"}
@@ -0,0 +1,2 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("vue");require("../../hooks/useUser.cjs");require("../../hooks/usePermission.cjs");require("../../hooks/useMenu.cjs");require("../../hooks/useTab.cjs");require("../../hooks/useRouteKeepAlive.cjs");require("../../hooks/useSize.cjs");require("../../hooks/useLang.cjs");require("../../hooks/useTheme.cjs");require("../../hooks/useList.cjs");require("../../hooks/useHiddenTitle.cjs");require("../../hooks/useForm.cjs");require("../../hooks/useShow.cjs");const d=require("../../hooks/useReferenceArrayField.cjs");require("../../hooks/useTreeWithDetails.cjs");require("../../hooks/useFormGrid.cjs");require("../../hooks/useReferenceArrayInput.cjs");const c=require("../../setup/index.cjs"),q=require("element-plus"),g=require("vue-router"),m=e.defineComponent({name:"SkySingleFieldList",props:{id:{type:String,default:"id"}},setup(t,{slots:n}){const u=g.useRouter(),{listData:s,listLoading:o,reference:l}=d.useReferenceArrayField(),a=r=>{const i=c.skyConfig.getShowRouteName(l);r?.[t.id]&&u.hasRoute(i)&&u.push({name:i,params:{id:String(r[t.id])}})};return()=>e.withDirectives(e.createVNode("div",{class:"sky-single-field-list"},[s.value?.data?.map(r=>e.createVNode(e.Fragment,null,[n.default?.().map(i=>e.cloneVNode(i,{row:r,onClick:a}))]))]),[[q.ElLoadingDirective,o.value]])}});exports.SkySingleFieldList=m;
2
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.cjs","sources":["../../../src/components/single-field-list/index.tsx"],"sourcesContent":["import { useReferenceArrayField } from '@/hooks'\nimport { skyConfig } from '@/setup'\nimport { ElLoadingDirective } from 'element-plus'\nimport { cloneVNode, defineComponent, withDirectives } from 'vue'\nimport { useRouter } from 'vue-router'\n\nexport interface SkySingleFieldListProps {\n id?: string\n}\n\nexport const SkySingleFieldList = defineComponent<SkySingleFieldListProps>({\n name: 'SkySingleFieldList',\n props: {\n id: {\n type: String,\n default: 'id',\n },\n },\n setup(props, { slots }) {\n const router = useRouter()\n const { listData, listLoading, reference } = useReferenceArrayField()!\n\n const onClick = (row?: Record<string, unknown>) => {\n const routeName = skyConfig.getShowRouteName(reference)\n if (row?.[props.id!] && router.hasRoute(routeName)) {\n router.push({\n name: routeName,\n params: {\n id: String(row[props.id!]),\n },\n })\n }\n }\n\n return () =>\n withDirectives(\n <div class=\"sky-single-field-list\">\n {listData.value?.data?.map((row) => (\n <>{slots.default?.().map((vnode) => cloneVNode(vnode, { row, onClick }))}</>\n ))}\n </div>,\n [[ElLoadingDirective, listLoading.value]],\n )\n },\n})\n"],"names":["SkySingleFieldList","defineComponent","name","props","id","type","String","default","setup","slots","router","useRouter","listData","listLoading","reference","useReferenceArrayField","onClick","row","routeName","skyConfig","getShowRouteName","hasRoute","push","params","withDirectives","_createVNode","value","data","map","_Fragment","vnode","cloneVNode","ElLoadingDirective"],"mappings":"8zBAUaA,EAAqBC,EAAAA,gBAAyC,CACzEC,KAAM,qBACNC,MAAO,CACLC,GAAI,CACFC,KAAMC,OACNC,QAAS,IACX,GAEFC,MAAML,EAAO,CAAEM,MAAAA,CAAM,EAAG,CACtB,MAAMC,EAASC,EAAAA,UAAS,EAClB,CAAEC,SAAAA,EAAUC,YAAAA,EAAaC,UAAAA,GAAcC,yBAAsB,EAE7DC,EAAWC,GAAkC,CACjD,MAAMC,EAAYC,EAAAA,UAAUC,iBAAiBN,CAAS,EAClDG,IAAMd,EAAMC,EAAE,GAAMM,EAAOW,SAASH,CAAS,GAC/CR,EAAOY,KAAK,CACVpB,KAAMgB,EACNK,OAAQ,CACNnB,GAAIE,OAAOW,EAAId,EAAMC,EAAE,CAAE,CAC3B,CACF,CAAC,CAEL,EAEA,MAAO,IACLoB,EAAAA,eAAcC,EAAAA,YAAA,MAAA,CAAA,MAAA,yBAAA,CAETb,EAASc,OAAOC,MAAMC,IAAKX,GAAGQ,cAAAI,EAAAA,SAAA,KAAA,CAC1BpB,EAAMF,UAAO,EAAKqB,IAAKE,GAAUC,EAAAA,WAAWD,EAAO,CAAEb,IAAAA,EAAKD,QAAAA,CAAQ,CAAC,CAAC,CAAC,CAAA,CACzE,CAAC,GAEJ,CAAC,CAACgB,qBAAoBnB,EAAYa,KAAK,CAAC,CAC1C,CACJ,CACF,CAAC"}
@@ -0,0 +1,4 @@
1
+ export interface SkySingleFieldListProps {
2
+ id?: string;
3
+ }
4
+ export declare const SkySingleFieldList: import('vue').DefineComponent<SkySingleFieldListProps, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<SkySingleFieldListProps> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, any>;
@@ -0,0 +1,56 @@
1
+ import { defineComponent as l, withDirectives as d, createVNode as r, Fragment as u, cloneVNode as c } from "vue";
2
+ import "../../hooks/useUser.mjs";
3
+ import "../../hooks/usePermission.mjs";
4
+ import "../../hooks/useMenu.mjs";
5
+ import "../../hooks/useTab.mjs";
6
+ import "../../hooks/useRouteKeepAlive.mjs";
7
+ import "../../hooks/useSize.mjs";
8
+ import "../../hooks/useLang.mjs";
9
+ import "../../hooks/useTheme.mjs";
10
+ import "../../hooks/useList.mjs";
11
+ import "../../hooks/useHiddenTitle.mjs";
12
+ import "../../hooks/useForm.mjs";
13
+ import "../../hooks/useShow.mjs";
14
+ import { useReferenceArrayField as f } from "../../hooks/useReferenceArrayField.mjs";
15
+ import "../../hooks/useTreeWithDetails.mjs";
16
+ import "../../hooks/useFormGrid.mjs";
17
+ import "../../hooks/useReferenceArrayInput.mjs";
18
+ import { skyConfig as g } from "../../setup/index.mjs";
19
+ import { ElLoadingDirective as S } from "element-plus";
20
+ import { useRouter as y } from "vue-router";
21
+ const H = /* @__PURE__ */ l({
22
+ name: "SkySingleFieldList",
23
+ props: {
24
+ id: {
25
+ type: String,
26
+ default: "id"
27
+ }
28
+ },
29
+ setup(e, {
30
+ slots: m
31
+ }) {
32
+ const o = y(), {
33
+ listData: p,
34
+ listLoading: n,
35
+ reference: a
36
+ } = f(), s = (t) => {
37
+ const i = g.getShowRouteName(a);
38
+ t?.[e.id] && o.hasRoute(i) && o.push({
39
+ name: i,
40
+ params: {
41
+ id: String(t[e.id])
42
+ }
43
+ });
44
+ };
45
+ return () => d(r("div", {
46
+ class: "sky-single-field-list"
47
+ }, [p.value?.data?.map((t) => r(u, null, [m.default?.().map((i) => c(i, {
48
+ row: t,
49
+ onClick: s
50
+ }))]))]), [[S, n.value]]);
51
+ }
52
+ });
53
+ export {
54
+ H as SkySingleFieldList
55
+ };
56
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.mjs","sources":["../../../src/components/single-field-list/index.tsx"],"sourcesContent":["import { useReferenceArrayField } from '@/hooks'\nimport { skyConfig } from '@/setup'\nimport { ElLoadingDirective } from 'element-plus'\nimport { cloneVNode, defineComponent, withDirectives } from 'vue'\nimport { useRouter } from 'vue-router'\n\nexport interface SkySingleFieldListProps {\n id?: string\n}\n\nexport const SkySingleFieldList = defineComponent<SkySingleFieldListProps>({\n name: 'SkySingleFieldList',\n props: {\n id: {\n type: String,\n default: 'id',\n },\n },\n setup(props, { slots }) {\n const router = useRouter()\n const { listData, listLoading, reference } = useReferenceArrayField()!\n\n const onClick = (row?: Record<string, unknown>) => {\n const routeName = skyConfig.getShowRouteName(reference)\n if (row?.[props.id!] && router.hasRoute(routeName)) {\n router.push({\n name: routeName,\n params: {\n id: String(row[props.id!]),\n },\n })\n }\n }\n\n return () =>\n withDirectives(\n <div class=\"sky-single-field-list\">\n {listData.value?.data?.map((row) => (\n <>{slots.default?.().map((vnode) => cloneVNode(vnode, { row, onClick }))}</>\n ))}\n </div>,\n [[ElLoadingDirective, listLoading.value]],\n )\n },\n})\n"],"names":["SkySingleFieldList","defineComponent","name","props","id","type","String","default","setup","slots","router","useRouter","listData","listLoading","reference","useReferenceArrayField","onClick","row","routeName","skyConfig","getShowRouteName","hasRoute","push","params","withDirectives","_createVNode","value","data","map","_Fragment","vnode","cloneVNode","ElLoadingDirective"],"mappings":";;;;;;;;;;;;;;;;;;;;AAUO,MAAMA,IAAqBC,gBAAAA,EAAyC;AAAA,EACzEC,MAAM;AAAA,EACNC,OAAO;AAAA,IACLC,IAAI;AAAA,MACFC,MAAMC;AAAAA,MACNC,SAAS;AAAA,IACX;AAAA;EAEFC,MAAML,GAAO;AAAA,IAAEM,OAAAA;AAAAA,EAAM,GAAG;AACtB,UAAMC,IAASC,EAAS,GAClB;AAAA,MAAEC,UAAAA;AAAAA,MAAUC,aAAAA;AAAAA,MAAaC,WAAAA;AAAAA,QAAcC,EAAsB,GAE7DC,IAAWC,CAAAA,MAAkC;AACjD,YAAMC,IAAYC,EAAUC,iBAAiBN,CAAS;AACtD,MAAIG,IAAMd,EAAMC,EAAE,KAAMM,EAAOW,SAASH,CAAS,KAC/CR,EAAOY,KAAK;AAAA,QACVpB,MAAMgB;AAAAA,QACNK,QAAQ;AAAA,UACNnB,IAAIE,OAAOW,EAAId,EAAMC,EAAE,CAAE;AAAA,QAC3B;AAAA,MACF,CAAC;AAAA,IAEL;AAEA,WAAO,MACLoB,EAAcC,EAAA,OAAA;AAAA,MAAA,OAAA;AAAA,OAAA,CAETb,EAASc,OAAOC,MAAMC,IAAKX,CAAAA,MAAGQ,EAAAI,GAAA,MAAA,CAC1BpB,EAAMF,UAAO,EAAKqB,IAAKE,CAAAA,MAAUC,EAAWD,GAAO;AAAA,MAAEb,KAAAA;AAAAA,MAAKD,SAAAA;AAAAA,IAAQ,CAAC,CAAC,CAAC,CAAA,CACzE,CAAC,IAEJ,CAAC,CAACgB,GAAoBnB,EAAYa,KAAK,CAAC,CAC1C;AAAA,EACJ;AACF,CAAC;"}
@@ -0,0 +1,2 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const e=require("vue");require("../../hooks/useUser.cjs");require("../../hooks/usePermission.cjs");require("../../hooks/useMenu.cjs");require("../../hooks/useTab.cjs");require("../../hooks/useRouteKeepAlive.cjs");require("../../hooks/useSize.cjs");require("../../hooks/useLang.cjs");require("../../hooks/useTheme.cjs");require("../../hooks/useList.cjs");const d=require("../../hooks/useHiddenTitle.cjs");require("../../hooks/useForm.cjs");require("../../hooks/useShow.cjs");require("../../hooks/useReferenceArrayField.cjs");require("../../hooks/useTreeWithDetails.cjs");require("../../hooks/useFormGrid.cjs");require("../../hooks/useReferenceArrayInput.cjs");const s=require("vue-router"),a=require("../can-access/index.cjs"),q=e.defineComponent({name:"SkyTextField",inheritAttrs:!1,props:{source:{type:String,required:!0},name:{type:String,default:"name"},label:String,row:Object},setup(r,{attrs:u}){const o=s.useRoute(),c=d.useHiddenTitle(),l=o.meta,i=e.computed(()=>{const t=r.row?.[r.source];return t?typeof t!="object"?String(t):t[r.name]||"":""}),n=e.computed(()=>r.label||r.source);return()=>e.createVNode(a.SkyCanAccess,{resource:l.resource,action:["list","show"],column:r.source},{default:()=>[c?e.createVNode("div",u,[i.value]):e.createVNode("div",e.mergeProps({class:"sky-text-field"},u),[n.value&&e.createVNode("h4",null,[n.value]),e.createVNode("div",null,[i.value])])]})}});exports.SkyTextField=q;
2
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.cjs","sources":["../../../src/components/text-field/index.tsx"],"sourcesContent":["import { useHiddenTitle } from '@/hooks'\r\nimport { computed, defineComponent } from 'vue'\r\nimport { useRoute } from 'vue-router'\r\nimport { SkyCanAccess } from '../can-access'\r\nimport type { SkyLayoutRouteMeta } from '@/router'\r\n\r\nexport interface TextFieldProps {\r\n source: string\r\n name?: string\r\n label?: string\r\n row?: Record<string, unknown>\r\n}\r\n\r\nexport const SkyTextField = defineComponent<TextFieldProps>({\r\n name: 'SkyTextField',\r\n inheritAttrs: false,\r\n props: {\r\n source: {\r\n type: String,\r\n required: true,\r\n },\r\n name: {\r\n type: String,\r\n default: 'name',\r\n },\r\n label: String,\r\n row: Object,\r\n },\r\n setup(props, { attrs }) {\r\n const route = useRoute()\r\n const hiddenTitle = useHiddenTitle()\r\n const routeMeta = route.meta as SkyLayoutRouteMeta\r\n\r\n const field = computed<string>(() => {\r\n const v = props.row?.[props.source]\r\n if (!v) {\r\n return ''\r\n }\r\n if (typeof v !== 'object') {\r\n return String(v)\r\n }\r\n return (v as Record<string, string>)[props.name!] || ''\r\n })\r\n\r\n const title = computed(() => {\r\n return props.label || props.source\r\n })\r\n\r\n return () => (\r\n <SkyCanAccess resource={routeMeta.resource} action={['list', 'show']} column={props.source}>\r\n {hiddenTitle ? (\r\n <div {...attrs}>{field.value}</div>\r\n ) : (\r\n <div class=\"sky-text-field\" {...attrs}>\r\n {title.value && <h4>{title.value}</h4>}\r\n <div>{field.value}</div>\r\n </div>\r\n )}\r\n </SkyCanAccess>\r\n )\r\n },\r\n})\r\n"],"names":["SkyTextField","defineComponent","name","inheritAttrs","props","source","type","String","required","default","label","row","Object","setup","attrs","route","useRoute","hiddenTitle","useHiddenTitle","routeMeta","meta","field","computed","v","title","_createVNode","SkyCanAccess","resource","value","_mergeProps"],"mappings":"syBAaaA,EAAeC,EAAAA,gBAAgC,CAC1DC,KAAM,eACNC,aAAc,GACdC,MAAO,CACLC,OAAQ,CACNC,KAAMC,OACNC,SAAU,IAEZN,KAAM,CACJI,KAAMC,OACNE,QAAS,QAEXC,MAAOH,OACPI,IAAKC,QAEPC,MAAMT,EAAO,CAAEU,MAAAA,CAAM,EAAG,CACtB,MAAMC,EAAQC,EAAAA,SAAQ,EAChBC,EAAcC,EAAAA,eAAc,EAC5BC,EAAYJ,EAAMK,KAElBC,EAAQC,EAAAA,SAAiB,IAAM,CACnC,MAAMC,EAAInB,EAAMO,MAAMP,EAAMC,MAAM,EAClC,OAAKkB,EAGD,OAAOA,GAAM,SACRhB,OAAOgB,CAAC,EAETA,EAA6BnB,EAAMF,IAAI,GAAM,GAL5C,EAMX,CAAC,EAEKsB,EAAQF,EAAAA,SAAS,IACdlB,EAAMM,OAASN,EAAMC,MAC7B,EAED,MAAO,IAAAoB,EAAAA,YAAAC,eAAA,CAAA,SACmBP,EAAUQ,SAAQ,OAAU,CAAC,OAAQ,MAAM,EAAC,OAAUvB,EAAMC,MAAM,EAAA,CAAAI,QAAAA,IAAA,CACvFQ,EAAWQ,EAAAA,YAAA,MACDX,EAAK,CAAGO,EAAMO,KAAK,CAAA,EAAAH,oBAAAI,EAAAA,WAAA,CAAA,MAAA,gBAAA,EAEIf,CAAK,EAAA,CAClCU,EAAMI,OAAKH,cAAA,KAAA,KAAA,CAASD,EAAMI,KAAK,GAAMH,EAAAA,wBAChCJ,EAAMO,KAAK,CAAA,CAAA,CAAA,CAEpB,EAAA,CAGP,CACF,CAAC"}
@@ -0,0 +1,7 @@
1
+ export interface TextFieldProps {
2
+ source: string;
3
+ name?: string;
4
+ label?: string;
5
+ row?: Record<string, unknown>;
6
+ }
7
+ export declare const SkyTextField: import('vue').DefineComponent<TextFieldProps, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<TextFieldProps> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, any>;
@@ -0,0 +1,56 @@
1
+ import { defineComponent as s, computed as n, createVNode as t, mergeProps as p } from "vue";
2
+ import "../../hooks/useUser.mjs";
3
+ import "../../hooks/usePermission.mjs";
4
+ import "../../hooks/useMenu.mjs";
5
+ import "../../hooks/useTab.mjs";
6
+ import "../../hooks/useRouteKeepAlive.mjs";
7
+ import "../../hooks/useSize.mjs";
8
+ import "../../hooks/useLang.mjs";
9
+ import "../../hooks/useTheme.mjs";
10
+ import "../../hooks/useList.mjs";
11
+ import { useHiddenTitle as a } from "../../hooks/useHiddenTitle.mjs";
12
+ import "../../hooks/useForm.mjs";
13
+ import "../../hooks/useShow.mjs";
14
+ import "../../hooks/useReferenceArrayField.mjs";
15
+ import "../../hooks/useTreeWithDetails.mjs";
16
+ import "../../hooks/useFormGrid.mjs";
17
+ import "../../hooks/useReferenceArrayInput.mjs";
18
+ import { useRoute as d } from "vue-router";
19
+ import { SkyCanAccess as f } from "../can-access/index.mjs";
20
+ const P = /* @__PURE__ */ s({
21
+ name: "SkyTextField",
22
+ inheritAttrs: !1,
23
+ props: {
24
+ source: {
25
+ type: String,
26
+ required: !0
27
+ },
28
+ name: {
29
+ type: String,
30
+ default: "name"
31
+ },
32
+ label: String,
33
+ row: Object
34
+ },
35
+ setup(e, {
36
+ attrs: o
37
+ }) {
38
+ const u = d(), l = a(), c = u.meta, i = n(() => {
39
+ const r = e.row?.[e.source];
40
+ return r ? typeof r != "object" ? String(r) : r[e.name] || "" : "";
41
+ }), m = n(() => e.label || e.source);
42
+ return () => t(f, {
43
+ resource: c.resource,
44
+ action: ["list", "show"],
45
+ column: e.source
46
+ }, {
47
+ default: () => [l ? t("div", o, [i.value]) : t("div", p({
48
+ class: "sky-text-field"
49
+ }, o), [m.value && t("h4", null, [m.value]), t("div", null, [i.value])])]
50
+ });
51
+ }
52
+ });
53
+ export {
54
+ P as SkyTextField
55
+ };
56
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.mjs","sources":["../../../src/components/text-field/index.tsx"],"sourcesContent":["import { useHiddenTitle } from '@/hooks'\r\nimport { computed, defineComponent } from 'vue'\r\nimport { useRoute } from 'vue-router'\r\nimport { SkyCanAccess } from '../can-access'\r\nimport type { SkyLayoutRouteMeta } from '@/router'\r\n\r\nexport interface TextFieldProps {\r\n source: string\r\n name?: string\r\n label?: string\r\n row?: Record<string, unknown>\r\n}\r\n\r\nexport const SkyTextField = defineComponent<TextFieldProps>({\r\n name: 'SkyTextField',\r\n inheritAttrs: false,\r\n props: {\r\n source: {\r\n type: String,\r\n required: true,\r\n },\r\n name: {\r\n type: String,\r\n default: 'name',\r\n },\r\n label: String,\r\n row: Object,\r\n },\r\n setup(props, { attrs }) {\r\n const route = useRoute()\r\n const hiddenTitle = useHiddenTitle()\r\n const routeMeta = route.meta as SkyLayoutRouteMeta\r\n\r\n const field = computed<string>(() => {\r\n const v = props.row?.[props.source]\r\n if (!v) {\r\n return ''\r\n }\r\n if (typeof v !== 'object') {\r\n return String(v)\r\n }\r\n return (v as Record<string, string>)[props.name!] || ''\r\n })\r\n\r\n const title = computed(() => {\r\n return props.label || props.source\r\n })\r\n\r\n return () => (\r\n <SkyCanAccess resource={routeMeta.resource} action={['list', 'show']} column={props.source}>\r\n {hiddenTitle ? (\r\n <div {...attrs}>{field.value}</div>\r\n ) : (\r\n <div class=\"sky-text-field\" {...attrs}>\r\n {title.value && <h4>{title.value}</h4>}\r\n <div>{field.value}</div>\r\n </div>\r\n )}\r\n </SkyCanAccess>\r\n )\r\n },\r\n})\r\n"],"names":["SkyTextField","defineComponent","name","inheritAttrs","props","source","type","String","required","default","label","row","Object","setup","attrs","route","useRoute","hiddenTitle","useHiddenTitle","routeMeta","meta","field","computed","v","title","_createVNode","SkyCanAccess","resource","value","_mergeProps"],"mappings":";;;;;;;;;;;;;;;;;;;AAaO,MAAMA,IAAeC,gBAAAA,EAAgC;AAAA,EAC1DC,MAAM;AAAA,EACNC,cAAc;AAAA,EACdC,OAAO;AAAA,IACLC,QAAQ;AAAA,MACNC,MAAMC;AAAAA,MACNC,UAAU;AAAA;IAEZN,MAAM;AAAA,MACJI,MAAMC;AAAAA,MACNE,SAAS;AAAA;IAEXC,OAAOH;AAAAA,IACPI,KAAKC;AAAAA;EAEPC,MAAMT,GAAO;AAAA,IAAEU,OAAAA;AAAAA,EAAM,GAAG;AACtB,UAAMC,IAAQC,EAAQ,GAChBC,IAAcC,EAAc,GAC5BC,IAAYJ,EAAMK,MAElBC,IAAQC,EAAiB,MAAM;AACnC,YAAMC,IAAInB,EAAMO,MAAMP,EAAMC,MAAM;AAClC,aAAKkB,IAGD,OAAOA,KAAM,WACRhB,OAAOgB,CAAC,IAETA,EAA6BnB,EAAMF,IAAI,KAAM,KAL5C;AAAA,IAMX,CAAC,GAEKsB,IAAQF,EAAS,MACdlB,EAAMM,SAASN,EAAMC,MAC7B;AAED,WAAO,MAAAoB,EAAAC,GAAA;AAAA,MAAA,UACmBP,EAAUQ;AAAAA,MAAQ,QAAU,CAAC,QAAQ,MAAM;AAAA,MAAC,QAAUvB,EAAMC;AAAAA,IAAM,GAAA;AAAA,MAAAI,SAAAA,MAAA,CACvFQ,IAAWQ,EAAA,OACDX,GAAK,CAAGO,EAAMO,KAAK,CAAA,IAAAH,SAAAI,EAAA;AAAA,QAAA,OAAA;AAAA,MAAA,GAEIf,CAAK,GAAA,CAClCU,EAAMI,SAAKH,EAAA,MAAA,MAAA,CAASD,EAAMI,KAAK,IAAMH,gBAChCJ,EAAMO,KAAK,CAAA,CAAA,CAAA,CAEpB;AAAA,KAAA;AAAA,EAGP;AACF,CAAC;"}
@@ -0,0 +1,2 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});require("element-plus/es/components/form-item/style/css");require("element-plus/es/components/input/style/css");const u=require("vue");require("../../hooks/useUser.cjs");require("../../hooks/usePermission.cjs");require("../../hooks/useMenu.cjs");require("../../hooks/useTab.cjs");require("../../hooks/useRouteKeepAlive.cjs");require("../../hooks/useSize.cjs");require("../../hooks/useLang.cjs");require("../../hooks/useTheme.cjs");require("../../hooks/useList.cjs");require("../../hooks/useHiddenTitle.cjs");const p=require("../../hooks/useForm.cjs");require("../../hooks/useShow.cjs");require("../../hooks/useReferenceArrayField.cjs");require("../../hooks/useTreeWithDetails.cjs");const q=require("../../hooks/useFormGrid.cjs");require("../../hooks/useReferenceArrayInput.cjs");const o=require("element-plus"),m=require("vue-router"),f=require("../can-access/index.cjs"),y=u.defineComponent({name:"SkyTextInput",inheritAttrs:!1,props:{source:{type:String,required:!0},label:String,rules:Object,parser:Function,defaultValue:{type:String,default:""}},setup(s,{attrs:i}){const e=s,c=m.useRoute(),n=q.useFormGrid(),{formData:r,editData:t}=p.useForm(),a=c.meta,l=u.computed(()=>e.label||e.source);return typeof r[e.source]>"u"&&(r[e.source]=e.defaultValue),t.value&&(r[e.source]=t.value[e.source]),e.parser&&(r[e.source]=e.parser(r[e.source])),()=>u.createVNode(f.SkyCanAccess,{resource:a.resource,action:["create","edit"],column:e.source},{default:()=>[u.createVNode(o.ElFormItem,{label:l.value,prop:e.source,rules:e.rules,style:n?`grid-area: ${e.source}`:""},{default:()=>u.h(o.ElInput,{modelValue:r[e.source]?String(r[e.source]):"","onUpdate:modelValue":d=>r[e.source]=d,parser:e.parser,...i})})]})}});exports.SkyTextInput=y;
2
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.cjs","sources":["../../../src/components/text-input/index.tsx"],"sourcesContent":["import { useForm, useFormGrid } from '@/hooks'\nimport { ElFormItem, ElInput, type FormItemRule, type InputProps } from 'element-plus'\nimport { computed, defineComponent, h } from 'vue'\nimport { useRoute } from 'vue-router'\nimport { SkyCanAccess } from '../can-access'\nimport type { SkyLayoutRouteMeta } from '@/router'\n\nexport interface SkyTextInputProps {\n source: string\n label?: string\n rules?: FormItemRule | FormItemRule[]\n parser?: InputProps['parser']\n defaultValue?: string\n}\n\nexport const SkyTextInput = defineComponent<SkyTextInputProps & Partial<InputProps>>({\n name: 'SkyTextInput',\n inheritAttrs: false,\n props: {\n source: {\n type: String,\n required: true,\n },\n label: String,\n rules: Object,\n parser: Function,\n defaultValue: {\n type: String,\n default: '',\n },\n },\n setup(props, { attrs }) {\n // 防止TS类型爆炸!\n const _props = props as unknown as SkyTextInputProps\n const route = useRoute()\n const formGrid = useFormGrid()\n const { formData, editData } = useForm()!\n const routeMeta = route.meta as SkyLayoutRouteMeta\n\n const title = computed(() => _props.label || _props.source)\n\n if (typeof formData[_props.source] === 'undefined') {\n formData[_props.source] = _props.defaultValue!\n }\n\n if (editData.value) {\n formData[_props.source] = editData.value[_props.source]\n }\n\n // 主动调用一次,归一化参数\n if (_props.parser) {\n formData[_props.source] = _props.parser(formData[_props.source])\n }\n\n return () => (\n <SkyCanAccess\n resource={routeMeta.resource}\n action={['create', 'edit']}\n column={_props.source}\n >\n <ElFormItem\n label={title.value}\n prop={_props.source}\n rules={_props.rules}\n style={formGrid ? `grid-area: ${_props.source}` : ''}\n >\n {() =>\n h(ElInput, {\n modelValue: formData[_props.source] ? String(formData[_props.source]) : '',\n 'onUpdate:modelValue': (v) => (formData[_props.source] = v),\n parser: _props.parser,\n ...attrs,\n })\n }\n </ElFormItem>\n </SkyCanAccess>\n )\n },\n})\n"],"names":["SkyTextInput","defineComponent","name","inheritAttrs","props","source","type","required","label","rules","parser","defaultValue","default","attrs","route","useRoute","formGrid","useFormGrid","editData","routeMeta","title","computed","_props","formData","modelValue"],"mappings":"w7BAeAA,EAAAC,EAAAA,gBAAA,CACEC,KAAAA,eACAC,aAAAA,GACAC,MAAAA,CACEC,OAAAA,CACEC,KAAAA,OACAC,SAAAA,IAEFC,MAAAA,OACAC,MAAAA,OACAC,OAAAA,SACAC,aAAAA,CACEL,KAAAA,OACAM,QAAAA,EACF,YAEaC,MAAAA,CAAM,EAAA,WAGnBC,EAAAC,EAAAA,SAAA,EACAC,EAAAC,EAAAA,YAAA,cACkBC,SAAAA,eAClBC,EAAAL,EAAA,KAEAM,EAAAC,EAAAA,SAAA,IAAAC,EAAA,OAAAA,EAAA,MAAA,wEAOEC,EAAAA,EAAAA,MAAAA,EAAAA,EAAAA,MAAAA,EAAAA,MAAAA,cAKAA,EAAAA,EAAAA,MAAAA,EAAAA,EAAAA,OAAAA,EAAAA,EAAAA,MAAAA,CAAAA,yDAK8B,OAAA,CAAA,SAAA,MAAA,EACF,OAAAD,EAAA,MACL,EAAA,CAAAV,QAAAA,IAAAA,CAAAA,EAAAA,YAAAA,aAAAA,2CAKA,MAAAI,EAAA,cAAAM,EAAA,MAAA,GAAA,EACiC,EAAA,CAAAV,QAAAA,IAAAA,EAAAA,EAAAA,UAAAA,CAIhDY,WAAAA,EAAAA,EAAAA,MAAAA,EAAAA,OAAAA,EAAAA,EAAAA,MAAAA,CAAAA,EAAAA,gEAIA,CAAA,CAAA,GAKZ,CACF,CAAA"}
@@ -0,0 +1,9 @@
1
+ import { FormItemRule, InputProps } from 'element-plus';
2
+ export interface SkyTextInputProps {
3
+ source: string;
4
+ label?: string;
5
+ rules?: FormItemRule | FormItemRule[];
6
+ parser?: InputProps['parser'];
7
+ defaultValue?: string;
8
+ }
9
+ export declare const SkyTextInput: import('vue').DefineComponent<SkyTextInputProps & Partial<InputProps>, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<SkyTextInputProps & Partial<InputProps>> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, any>;
@@ -0,0 +1,70 @@
1
+ import "element-plus/es/components/form-item/style/css";
2
+ import "element-plus/es/components/input/style/css";
3
+ import { defineComponent as l, computed as n, createVNode as t, h as f } from "vue";
4
+ import "../../hooks/useUser.mjs";
5
+ import "../../hooks/usePermission.mjs";
6
+ import "../../hooks/useMenu.mjs";
7
+ import "../../hooks/useTab.mjs";
8
+ import "../../hooks/useRouteKeepAlive.mjs";
9
+ import "../../hooks/useSize.mjs";
10
+ import "../../hooks/useLang.mjs";
11
+ import "../../hooks/useTheme.mjs";
12
+ import "../../hooks/useList.mjs";
13
+ import "../../hooks/useHiddenTitle.mjs";
14
+ import { useForm as d } from "../../hooks/useForm.mjs";
15
+ import "../../hooks/useShow.mjs";
16
+ import "../../hooks/useReferenceArrayField.mjs";
17
+ import "../../hooks/useTreeWithDetails.mjs";
18
+ import { useFormGrid as y } from "../../hooks/useFormGrid.mjs";
19
+ import "../../hooks/useReferenceArrayInput.mjs";
20
+ import { ElFormItem as S, ElInput as g } from "element-plus";
21
+ import { useRoute as V } from "vue-router";
22
+ import { SkyCanAccess as b } from "../can-access/index.mjs";
23
+ const z = /* @__PURE__ */ l({
24
+ name: "SkyTextInput",
25
+ inheritAttrs: !1,
26
+ props: {
27
+ source: {
28
+ type: String,
29
+ required: !0
30
+ },
31
+ label: String,
32
+ rules: Object,
33
+ parser: Function,
34
+ defaultValue: {
35
+ type: String,
36
+ default: ""
37
+ }
38
+ },
39
+ setup(u, {
40
+ attrs: p
41
+ }) {
42
+ const r = u, i = V(), s = y(), {
43
+ formData: e,
44
+ editData: o
45
+ } = d(), m = i.meta, a = n(() => r.label || r.source);
46
+ return typeof e[r.source] > "u" && (e[r.source] = r.defaultValue), o.value && (e[r.source] = o.value[r.source]), r.parser && (e[r.source] = r.parser(e[r.source])), () => t(b, {
47
+ resource: m.resource,
48
+ action: ["create", "edit"],
49
+ column: r.source
50
+ }, {
51
+ default: () => [t(S, {
52
+ label: a.value,
53
+ prop: r.source,
54
+ rules: r.rules,
55
+ style: s ? `grid-area: ${r.source}` : ""
56
+ }, {
57
+ default: () => f(g, {
58
+ modelValue: e[r.source] ? String(e[r.source]) : "",
59
+ "onUpdate:modelValue": (c) => e[r.source] = c,
60
+ parser: r.parser,
61
+ ...p
62
+ })
63
+ })]
64
+ });
65
+ }
66
+ });
67
+ export {
68
+ z as SkyTextInput
69
+ };
70
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.mjs","sources":["../../../src/components/text-input/index.tsx"],"sourcesContent":["import { useForm, useFormGrid } from '@/hooks'\nimport { ElFormItem, ElInput, type FormItemRule, type InputProps } from 'element-plus'\nimport { computed, defineComponent, h } from 'vue'\nimport { useRoute } from 'vue-router'\nimport { SkyCanAccess } from '../can-access'\nimport type { SkyLayoutRouteMeta } from '@/router'\n\nexport interface SkyTextInputProps {\n source: string\n label?: string\n rules?: FormItemRule | FormItemRule[]\n parser?: InputProps['parser']\n defaultValue?: string\n}\n\nexport const SkyTextInput = defineComponent<SkyTextInputProps & Partial<InputProps>>({\n name: 'SkyTextInput',\n inheritAttrs: false,\n props: {\n source: {\n type: String,\n required: true,\n },\n label: String,\n rules: Object,\n parser: Function,\n defaultValue: {\n type: String,\n default: '',\n },\n },\n setup(props, { attrs }) {\n // 防止TS类型爆炸!\n const _props = props as unknown as SkyTextInputProps\n const route = useRoute()\n const formGrid = useFormGrid()\n const { formData, editData } = useForm()!\n const routeMeta = route.meta as SkyLayoutRouteMeta\n\n const title = computed(() => _props.label || _props.source)\n\n if (typeof formData[_props.source] === 'undefined') {\n formData[_props.source] = _props.defaultValue!\n }\n\n if (editData.value) {\n formData[_props.source] = editData.value[_props.source]\n }\n\n // 主动调用一次,归一化参数\n if (_props.parser) {\n formData[_props.source] = _props.parser(formData[_props.source])\n }\n\n return () => (\n <SkyCanAccess\n resource={routeMeta.resource}\n action={['create', 'edit']}\n column={_props.source}\n >\n <ElFormItem\n label={title.value}\n prop={_props.source}\n rules={_props.rules}\n style={formGrid ? `grid-area: ${_props.source}` : ''}\n >\n {() =>\n h(ElInput, {\n modelValue: formData[_props.source] ? String(formData[_props.source]) : '',\n 'onUpdate:modelValue': (v) => (formData[_props.source] = v),\n parser: _props.parser,\n ...attrs,\n })\n }\n </ElFormItem>\n </SkyCanAccess>\n )\n },\n})\n"],"names":["SkyTextInput","defineComponent","name","inheritAttrs","props","source","type","required","label","rules","parser","defaultValue","default","attrs","route","useRoute","formGrid","useFormGrid","editData","routeMeta","title","computed","_props","formData","modelValue"],"mappings":";;;;;;;;;;;;;;;;;;;;;;AAeA,MAAAA,IAAA,gBAAAC,EAAA;AAAA,EACEC,MAAAA;AAAAA,EACAC,cAAAA;AAAAA,EACAC,OAAAA;AAAAA,IACEC,QAAAA;AAAAA,MACEC,MAAAA;AAAAA,MACAC,UAAAA;AAAAA;IAEFC,OAAAA;AAAAA,IACAC,OAAAA;AAAAA,IACAC,QAAAA;AAAAA,IACAC,cAAAA;AAAAA,MACEL,MAAAA;AAAAA,MACAM,SAAAA;AAAAA,IACF;AAAA;;IAEaC,OAAAA;AAAAA,EAAM,GAAA;iBAGnBC,IAAAC,EAAA,GACAC,IAAAC,EAAA;;MACkBC,UAAAA;AAAAA,aAClBC,IAAAL,EAAA,MAEAM,IAAAC,EAAA,MAAAC,EAAA,SAAAA,EAAA,MAAA;mFAOEC,EAAAA,EAAAA,MAAAA,IAAAA,EAAAA,MAAAA,EAAAA,MAAAA,iBAKAA,EAAAA,EAAAA,MAAAA,IAAAA,EAAAA,OAAAA,EAAAA,EAAAA,MAAAA,CAAAA;;MAK8B,QAAA,CAAA,UAAA,MAAA;AAAA,MACF,QAAAD,EAAA;AAAA,IACL,GAAA;AAAA,MAAAV,SAAAA,MAAAA,CAAAA,EAAAA,GAAAA;AAAAA;;;QAKA,OAAAI,IAAA,cAAAM,EAAA,MAAA,KAAA;AAAA,MACiC,GAAA;AAAA,QAAAV,SAAAA,MAAAA,EAAAA,GAAAA;AAAAA,UAIhDY,YAAAA,EAAAA,EAAAA,MAAAA,IAAAA,OAAAA,EAAAA,EAAAA,MAAAA,CAAAA,IAAAA;AAAAA;;;;MAIA,CAAA,CAAA;AAAA;EAKZ;AACF,CAAA;"}
@@ -0,0 +1,2 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});require("element-plus/es/components/form-item/style/css");require("element-plus/es/components/tree-select/style/css");const t=require("vue"),l=require("element-plus"),g=require("vue-i18n"),v=require("vue-router"),b=require("../can-access/index.cjs");require("../../hooks/useUser.cjs");require("../../hooks/usePermission.cjs");require("../../hooks/useMenu.cjs");require("../../hooks/useTab.cjs");require("../../hooks/useRouteKeepAlive.cjs");require("../../hooks/useSize.cjs");require("../../hooks/useLang.cjs");require("../../hooks/useTheme.cjs");require("../../hooks/useList.cjs");require("../../hooks/useHiddenTitle.cjs");const h=require("../../hooks/useForm.cjs");require("../../hooks/useShow.cjs");require("../../hooks/useReferenceArrayField.cjs");require("../../hooks/useTreeWithDetails.cjs");const N=require("../../hooks/useFormGrid.cjs"),V=require("../../hooks/useReferenceArrayInput.cjs");function I(e){return typeof e=="function"||Object.prototype.toString.call(e)==="[object Object]"&&!t.isVNode(e)}const A=t.defineComponent({name:"SkyTreeSelectInput",inheritAttrs:!1,props:{source:{type:String,required:!0},label:String,rules:Object,defaultValue:{type:[String,Number],default:0},optionChildren:{type:String,default:"children"},optionName:{type:String,default:"name"},defaultExpandAll:{type:Boolean,default:!0},nodeKey:{type:String,default:"id"},rootValue:{type:[String,Number],default:0}},setup(e,{attrs:a}){const{t:c}=g.useI18n(),d=v.useRoute(),{formData:u,editData:o}=h.useForm(),s=N.useFormGrid(),{getList:f,listData:i,listLoading:n}=V.useReferenceArrayInput(),y=d.meta;typeof u[e.source]>"u"&&(u[e.source]=e.defaultValue),o.value&&(u[e.source]=o.value[e.source]);const m=t.computed(()=>e.label||e.source),q=t.computed(()=>{const r=[{[e.nodeKey]:e.rootValue,[e.optionName]:c("treeRootNode"),[e.optionChildren]:[]}];return i.value?.data?.length&&(r[0][e.optionChildren]=i.value.data),r});return t.onMounted(()=>{f()}),()=>{let r;return t.createVNode(b.SkyCanAccess,{resource:y.resource,action:["create","edit"],column:e.source},I(r=t.withDirectives(t.createVNode(l.ElFormItem,{label:m.value,prop:e.source,rules:e.rules,style:s?`grid-area: ${e.source}`:""},{default:()=>[t.createVNode(l.ElTreeSelect,t.mergeProps({modelValue:n.value?"":u[e.source],"onUpdate:modelValue":S=>u[e.source]=S,checkStrictly:!0,data:q.value,props:{children:e.optionChildren,label:e.optionName},defaultExpandAll:e.defaultExpandAll,loading:n.value,nodeKey:e.nodeKey,valueKey:e.nodeKey},a),null)]}),[[l.ElLoadingDirective,n.value]]))?r:{default:()=>[r]})}}});exports.SkyTreeSelectInput=A;
2
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.cjs","sources":["../../../src/components/tree-select-input/index.tsx"],"sourcesContent":["import type { Identifier } from '@/provides'\nimport type { SkyLayoutRouteMeta } from '@/router'\nimport { ElFormItem, ElLoadingDirective, ElTreeSelect, type FormItemRule } from 'element-plus'\nimport { computed, defineComponent, onMounted, withDirectives } from 'vue'\nimport { useI18n } from 'vue-i18n'\nimport { useRoute } from 'vue-router'\nimport { SkyCanAccess } from '../can-access'\nimport { useForm, useFormGrid, useReferenceArrayInput } from '@/hooks'\n\nexport interface SkyTreeSelectInputProps {\n source: string\n label?: string\n placeholder?: string\n rules?: FormItemRule | FormItemRule[]\n defaultValue?: Identifier\n optionChildren?: string\n optionName?: string\n defaultExpandAll?: boolean\n nodeKey?: string\n rootValue?: Identifier\n}\n\nexport const SkyTreeSelectInput = defineComponent<SkyTreeSelectInputProps>({\n name: 'SkyTreeSelectInput',\n inheritAttrs: false,\n props: {\n source: {\n type: String,\n required: true,\n },\n label: String,\n // placeholder: String,\n rules: Object,\n defaultValue: {\n type: [String, Number],\n default: 0,\n },\n optionChildren: {\n type: String,\n default: 'children',\n },\n optionName: {\n type: String,\n default: 'name',\n },\n defaultExpandAll: {\n type: Boolean,\n default: true,\n },\n nodeKey: {\n type: String,\n default: 'id',\n },\n rootValue: {\n type: [String, Number],\n default: 0,\n },\n },\n setup(props, { attrs }) {\n const { t } = useI18n()\n const route = useRoute()\n const { formData, editData } = useForm()!\n const formGrid = useFormGrid()\n const { getList, listData, listLoading } = useReferenceArrayInput()!\n const routeMeta = route.meta as SkyLayoutRouteMeta\n\n if (typeof formData[props.source] === 'undefined') {\n formData[props.source] = props.defaultValue!\n }\n\n if (editData.value) {\n formData[props.source] = editData.value[props.source]\n }\n\n const title = computed<string>(() => props.label || props.source)\n\n const data = computed(() => {\n const result = [\n {\n [props.nodeKey!]: props.rootValue!,\n [props.optionName!]: t('treeRootNode'),\n [props.optionChildren!]: [] as Record<string, unknown>[],\n },\n ]\n if (listData.value?.data?.length) {\n result[0]![props.optionChildren!] = listData.value.data\n return result\n }\n return result\n })\n\n onMounted(() => {\n getList()\n })\n\n return () => (\n <SkyCanAccess resource={routeMeta.resource} action={['create', 'edit']} column={props.source}>\n {withDirectives(\n <ElFormItem\n label={title.value}\n prop={props.source}\n rules={props.rules}\n style={formGrid ? `grid-area: ${props.source}` : ''}\n >\n <ElTreeSelect\n modelValue={listLoading.value ? '' : formData[props.source]}\n onUpdate:modelValue={(v: Identifier) => (formData[props.source] = v)}\n checkStrictly\n data={data.value}\n props={{ children: props.optionChildren, label: props.optionName }}\n defaultExpandAll={props.defaultExpandAll}\n loading={listLoading.value}\n nodeKey={props.nodeKey}\n valueKey={props.nodeKey}\n {...attrs}\n />\n </ElFormItem>,\n [[ElLoadingDirective, listLoading.value]],\n )}\n </SkyCanAccess>\n )\n },\n})\n"],"names":["_isSlot","s","_isVNode","SkyTreeSelectInput","defineComponent","name","inheritAttrs","props","source","type","required","label","rules","defaultValue","default","optionChildren","optionName","defaultExpandAll","nodeKey","rootValue","attrs","t","route","useRoute","editData","formGrid","useFormGrid","listLoading","routeMeta","formData","title","computed","data","listData","result","onMounted","getList","_slot"],"mappings":"g9BAOsE,SAAAA,EAAAC,EAAA,CAAA,OAAA,OAAAA,GAAA,YAAA,OAAA,UAAA,SAAA,KAAAA,CAAA,IAAA,mBAAA,CAAAC,EAAAA,QAAAD,CAAA,CAAA,CAetE,MAAAE,EAAAC,EAAAA,gBAAA,CACEC,KAAAA,qBACAC,aAAAA,GACAC,MAAAA,CACEC,OAAAA,CACEC,KAAAA,OACAC,SAAAA,IAEFC,MAAAA,OAEAC,MAAAA,OACAC,aAAAA,CACEJ,KAAAA,CAAAA,OAAAA,MAAAA,EACAK,QAAAA,GAEFC,eAAAA,CACEN,KAAAA,OACAK,QAAAA,YAEFE,WAAAA,CACEP,KAAAA,OACAK,QAAAA,QAEFG,iBAAAA,CACER,KAAAA,QACAK,QAAAA,IAEFI,QAAAA,CACET,KAAAA,OACAK,QAAAA,MAEFK,UAAAA,CACEV,KAAAA,CAAAA,OAAAA,MAAAA,EACAK,QAAAA,CACF,YAEaM,MAAAA,CAAM,EAAA,OACXC,EAAAA,eACRC,EAAAC,EAAAA,SAAA,cACkBC,SAAAA,eAClBC,EAAAC,EAAAA,YAAA,wBAC2BC,YAAAA,8BAC3BC,EAAAN,EAAA,oEAOEO,EAAAA,EAAAA,MAAAA,EAAAA,EAAAA,MAAAA,EAAAA,MAAAA,GAGF,MAAAC,EAAAC,EAAAA,SAAA,IAAAxB,EAAA,OAAAA,EAAA,MAAA,EAEAyB,EAAAD,EAAAA,SAAA,IAAA,WAGM,CAAAxB,EAAA,OAAA,EAAAA,EAAA,UACA,CAAAA,EAAA,UAAA,EAAAc,EAAA,cAAA,uBAEF,CAAA,EAEF,OAAAY,EAAA,OAAA,MAAA,SACEC,EAAAA,CAAAA,EAAAA,EAAAA,cAAAA,EAAAA,EAAAA,MAAAA,MACAA,CAGJ,CAAA,EAEAC,OAAAA,EAAAA,UAAAA,IAAAA,CACEC,EAAAA,CACF,CAAA,OAEO,IAAAC,2DACqC,OAAA,CAAA,SAAA,MAAA,EAA4B,OAAA9B,EAAA,mGAK9C,MAAAkB,EAAA,cAAAlB,EAAA,MAAA,GAAA,EACiC,EAAA,CAAAO,QAAAA,IAAAA,CAAAA,cAAAA,EAAAA,aAAAA,EAAAA,WAAAA,0EAImB,cAAA,2IAM9C,SAAAP,EAAA,OACC,EAAAa,CAAA,EAAA,IAAA,CAAA,yDAK5B,CAAA,EAGP,CACF,CAAA"}
@@ -0,0 +1,15 @@
1
+ import { Identifier } from '../../provides';
2
+ import { FormItemRule } from 'element-plus';
3
+ export interface SkyTreeSelectInputProps {
4
+ source: string;
5
+ label?: string;
6
+ placeholder?: string;
7
+ rules?: FormItemRule | FormItemRule[];
8
+ defaultValue?: Identifier;
9
+ optionChildren?: string;
10
+ optionName?: string;
11
+ defaultExpandAll?: boolean;
12
+ nodeKey?: string;
13
+ rootValue?: Identifier;
14
+ }
15
+ export declare const SkyTreeSelectInput: import('vue').DefineComponent<SkyTreeSelectInputProps, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<SkyTreeSelectInputProps> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, any>;
@@ -0,0 +1,122 @@
1
+ import "element-plus/es/components/form-item/style/css";
2
+ import "element-plus/es/components/tree-select/style/css";
3
+ import { defineComponent as p, computed as n, onMounted as v, createVNode as l, withDirectives as b, mergeProps as h, isVNode as N } from "vue";
4
+ import { ElFormItem as V, ElTreeSelect as A, ElLoadingDirective as C } from "element-plus";
5
+ import { useI18n as E } from "vue-i18n";
6
+ import { useRoute as K } from "vue-router";
7
+ import { SkyCanAccess as D } from "../can-access/index.mjs";
8
+ import "../../hooks/useUser.mjs";
9
+ import "../../hooks/usePermission.mjs";
10
+ import "../../hooks/useMenu.mjs";
11
+ import "../../hooks/useTab.mjs";
12
+ import "../../hooks/useRouteKeepAlive.mjs";
13
+ import "../../hooks/useSize.mjs";
14
+ import "../../hooks/useLang.mjs";
15
+ import "../../hooks/useTheme.mjs";
16
+ import "../../hooks/useList.mjs";
17
+ import "../../hooks/useHiddenTitle.mjs";
18
+ import { useForm as I } from "../../hooks/useForm.mjs";
19
+ import "../../hooks/useShow.mjs";
20
+ import "../../hooks/useReferenceArrayField.mjs";
21
+ import "../../hooks/useTreeWithDetails.mjs";
22
+ import { useFormGrid as j } from "../../hooks/useFormGrid.mjs";
23
+ import { useReferenceArrayInput as k } from "../../hooks/useReferenceArrayInput.mjs";
24
+ function x(e) {
25
+ return typeof e == "function" || Object.prototype.toString.call(e) === "[object Object]" && !N(e);
26
+ }
27
+ const te = /* @__PURE__ */ p({
28
+ name: "SkyTreeSelectInput",
29
+ inheritAttrs: !1,
30
+ props: {
31
+ source: {
32
+ type: String,
33
+ required: !0
34
+ },
35
+ label: String,
36
+ // placeholder: String,
37
+ rules: Object,
38
+ defaultValue: {
39
+ type: [String, Number],
40
+ default: 0
41
+ },
42
+ optionChildren: {
43
+ type: String,
44
+ default: "children"
45
+ },
46
+ optionName: {
47
+ type: String,
48
+ default: "name"
49
+ },
50
+ defaultExpandAll: {
51
+ type: Boolean,
52
+ default: !0
53
+ },
54
+ nodeKey: {
55
+ type: String,
56
+ default: "id"
57
+ },
58
+ rootValue: {
59
+ type: [String, Number],
60
+ default: 0
61
+ }
62
+ },
63
+ setup(e, {
64
+ attrs: a
65
+ }) {
66
+ const {
67
+ t: d
68
+ } = E(), m = K(), {
69
+ formData: o,
70
+ editData: i
71
+ } = I(), c = j(), {
72
+ getList: f,
73
+ listData: u,
74
+ listLoading: r
75
+ } = k(), s = m.meta;
76
+ typeof o[e.source] > "u" && (o[e.source] = e.defaultValue), i.value && (o[e.source] = i.value[e.source]);
77
+ const y = n(() => e.label || e.source), S = n(() => {
78
+ const t = [{
79
+ [e.nodeKey]: e.rootValue,
80
+ [e.optionName]: d("treeRootNode"),
81
+ [e.optionChildren]: []
82
+ }];
83
+ return u.value?.data?.length && (t[0][e.optionChildren] = u.value.data), t;
84
+ });
85
+ return v(() => {
86
+ f();
87
+ }), () => {
88
+ let t;
89
+ return l(D, {
90
+ resource: s.resource,
91
+ action: ["create", "edit"],
92
+ column: e.source
93
+ }, x(t = b(l(V, {
94
+ label: y.value,
95
+ prop: e.source,
96
+ rules: e.rules,
97
+ style: c ? `grid-area: ${e.source}` : ""
98
+ }, {
99
+ default: () => [l(A, h({
100
+ modelValue: r.value ? "" : o[e.source],
101
+ "onUpdate:modelValue": (g) => o[e.source] = g,
102
+ checkStrictly: !0,
103
+ data: S.value,
104
+ props: {
105
+ children: e.optionChildren,
106
+ label: e.optionName
107
+ },
108
+ defaultExpandAll: e.defaultExpandAll,
109
+ loading: r.value,
110
+ nodeKey: e.nodeKey,
111
+ valueKey: e.nodeKey
112
+ }, a), null)]
113
+ }), [[C, r.value]])) ? t : {
114
+ default: () => [t]
115
+ });
116
+ };
117
+ }
118
+ });
119
+ export {
120
+ te as SkyTreeSelectInput
121
+ };
122
+ //# sourceMappingURL=index.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.mjs","sources":["../../../src/components/tree-select-input/index.tsx"],"sourcesContent":["import type { Identifier } from '@/provides'\nimport type { SkyLayoutRouteMeta } from '@/router'\nimport { ElFormItem, ElLoadingDirective, ElTreeSelect, type FormItemRule } from 'element-plus'\nimport { computed, defineComponent, onMounted, withDirectives } from 'vue'\nimport { useI18n } from 'vue-i18n'\nimport { useRoute } from 'vue-router'\nimport { SkyCanAccess } from '../can-access'\nimport { useForm, useFormGrid, useReferenceArrayInput } from '@/hooks'\n\nexport interface SkyTreeSelectInputProps {\n source: string\n label?: string\n placeholder?: string\n rules?: FormItemRule | FormItemRule[]\n defaultValue?: Identifier\n optionChildren?: string\n optionName?: string\n defaultExpandAll?: boolean\n nodeKey?: string\n rootValue?: Identifier\n}\n\nexport const SkyTreeSelectInput = defineComponent<SkyTreeSelectInputProps>({\n name: 'SkyTreeSelectInput',\n inheritAttrs: false,\n props: {\n source: {\n type: String,\n required: true,\n },\n label: String,\n // placeholder: String,\n rules: Object,\n defaultValue: {\n type: [String, Number],\n default: 0,\n },\n optionChildren: {\n type: String,\n default: 'children',\n },\n optionName: {\n type: String,\n default: 'name',\n },\n defaultExpandAll: {\n type: Boolean,\n default: true,\n },\n nodeKey: {\n type: String,\n default: 'id',\n },\n rootValue: {\n type: [String, Number],\n default: 0,\n },\n },\n setup(props, { attrs }) {\n const { t } = useI18n()\n const route = useRoute()\n const { formData, editData } = useForm()!\n const formGrid = useFormGrid()\n const { getList, listData, listLoading } = useReferenceArrayInput()!\n const routeMeta = route.meta as SkyLayoutRouteMeta\n\n if (typeof formData[props.source] === 'undefined') {\n formData[props.source] = props.defaultValue!\n }\n\n if (editData.value) {\n formData[props.source] = editData.value[props.source]\n }\n\n const title = computed<string>(() => props.label || props.source)\n\n const data = computed(() => {\n const result = [\n {\n [props.nodeKey!]: props.rootValue!,\n [props.optionName!]: t('treeRootNode'),\n [props.optionChildren!]: [] as Record<string, unknown>[],\n },\n ]\n if (listData.value?.data?.length) {\n result[0]![props.optionChildren!] = listData.value.data\n return result\n }\n return result\n })\n\n onMounted(() => {\n getList()\n })\n\n return () => (\n <SkyCanAccess resource={routeMeta.resource} action={['create', 'edit']} column={props.source}>\n {withDirectives(\n <ElFormItem\n label={title.value}\n prop={props.source}\n rules={props.rules}\n style={formGrid ? `grid-area: ${props.source}` : ''}\n >\n <ElTreeSelect\n modelValue={listLoading.value ? '' : formData[props.source]}\n onUpdate:modelValue={(v: Identifier) => (formData[props.source] = v)}\n checkStrictly\n data={data.value}\n props={{ children: props.optionChildren, label: props.optionName }}\n defaultExpandAll={props.defaultExpandAll}\n loading={listLoading.value}\n nodeKey={props.nodeKey}\n valueKey={props.nodeKey}\n {...attrs}\n />\n </ElFormItem>,\n [[ElLoadingDirective, listLoading.value]],\n )}\n </SkyCanAccess>\n )\n },\n})\n"],"names":["_isSlot","s","_isVNode","SkyTreeSelectInput","defineComponent","name","inheritAttrs","props","source","type","required","label","rules","defaultValue","default","optionChildren","optionName","defaultExpandAll","nodeKey","rootValue","attrs","t","route","useRoute","editData","formGrid","useFormGrid","listLoading","routeMeta","formData","title","computed","data","listData","result","onMounted","getList","_slot"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;AAOsE,SAAAA,EAAAC,GAAA;AAAA,SAAA,OAAAA,KAAA,cAAA,OAAA,UAAA,SAAA,KAAAA,CAAA,MAAA,qBAAA,CAAAC,EAAAD,CAAA;AAAA;AAetE,MAAAE,KAAA,gBAAAC,EAAA;AAAA,EACEC,MAAAA;AAAAA,EACAC,cAAAA;AAAAA,EACAC,OAAAA;AAAAA,IACEC,QAAAA;AAAAA,MACEC,MAAAA;AAAAA,MACAC,UAAAA;AAAAA;IAEFC,OAAAA;AAAAA;AAAAA,IAEAC,OAAAA;AAAAA,IACAC,cAAAA;AAAAA,MACEJ,MAAAA,CAAAA,QAAAA,MAAAA;AAAAA,MACAK,SAAAA;AAAAA;IAEFC,gBAAAA;AAAAA,MACEN,MAAAA;AAAAA,MACAK,SAAAA;AAAAA;IAEFE,YAAAA;AAAAA,MACEP,MAAAA;AAAAA,MACAK,SAAAA;AAAAA;IAEFG,kBAAAA;AAAAA,MACER,MAAAA;AAAAA,MACAK,SAAAA;AAAAA;IAEFI,SAAAA;AAAAA,MACET,MAAAA;AAAAA,MACAK,SAAAA;AAAAA;IAEFK,WAAAA;AAAAA,MACEV,MAAAA,CAAAA,QAAAA,MAAAA;AAAAA,MACAK,SAAAA;AAAAA,IACF;AAAA;;IAEaM,OAAAA;AAAAA,EAAM,GAAA;;MACXC,GAAAA;AAAAA,aACRC,IAAAC,EAAA;;MACkBC,UAAAA;AAAAA,aAClBC,IAAAC,EAAA;;;MAC2BC,aAAAA;AAAAA,aAC3BC,IAAAN,EAAA;4EAOEO,EAAAA,EAAAA,MAAAA,IAAAA,EAAAA,MAAAA,EAAAA,MAAAA;AAGF,UAAAC,IAAAC,EAAA,MAAAxB,EAAA,SAAAA,EAAA,MAAA,GAEAyB,IAAAD,EAAA,MAAA;;QAGM,CAAAxB,EAAA,OAAA,GAAAA,EAAA;AAAA,QACA,CAAAA,EAAA,UAAA,GAAAc,EAAA,cAAA;AAAA;MAEF,CAAA;AAEF,aAAAY,EAAA,OAAA,MAAA,WACEC,EAAAA,CAAAA,EAAAA,EAAAA,cAAAA,IAAAA,EAAAA,MAAAA,OACAA;AAAA,IAGJ,CAAA;AAEAC,WAAAA,EAAAA,MAAAA;AACEC,MAAAA,EAAAA;AAAAA,IACF,CAAA;AAEO,UAAAC;;;QACqC,QAAA,CAAA,UAAA,MAAA;AAAA,QAA4B,QAAA9B,EAAA;AAAA;;;;QAK9C,OAAAkB,IAAA,cAAAlB,EAAA,MAAA,KAAA;AAAA,MACiC,GAAA;AAAA,QAAAO,SAAAA,MAAAA,CAAAA,EAAAA,GAAAA,EAAAA;AAAAA;;UAImB,eAAA;AAAA;;;;;;;;UAM9C,UAAAP,EAAA;AAAA,QACC,GAAAa,CAAA,GAAA,IAAA,CAAA;AAAA;;MAK5B,CAAA;AAAA;EAGP;AACF,CAAA;"}
@@ -0,0 +1,2 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});require("element-plus/es/components/card/style/css");require("element-plus/es/components/col/style/css");require("element-plus/es/components/row/style/css");require("element-plus/es/components/skeleton/style/css");require("element-plus/es/components/tree/style/css");const e=require("vue");require("../../hooks/useUser.cjs");require("../../hooks/usePermission.cjs");require("../../hooks/useMenu.cjs");require("../../hooks/useTab.cjs");require("../../hooks/useRouteKeepAlive.cjs");require("../../hooks/useSize.cjs");require("../../hooks/useLang.cjs");require("../../hooks/useTheme.cjs");require("../../hooks/useList.cjs");require("../../hooks/useHiddenTitle.cjs");require("../../hooks/useForm.cjs");require("../../hooks/useShow.cjs");require("../../hooks/useReferenceArrayField.cjs");const y=require("../../hooks/useTreeWithDetails.cjs");require("../../hooks/useFormGrid.cjs");const q=require("../../hooks/useReferenceArrayInput.cjs"),g=require("../../setup/index.cjs"),v=require("@vueuse/core"),i=require("element-plus"),h=require("vue-router"),m=e.defineComponent({name:"SkyTreeWithDetails",inheritAttrs:!1,props:{create:Object,edit:Object,optionChildren:{type:String,default:"children"},optionName:{type:String,default:"name"},defaultExpandAll:{type:Boolean,default:!0},nodeKey:{type:String,default:"id"},size:{type:Number,default:30}},setup(t,{attrs:s}){const l=h.useRoute();let n;const{state:d,isLoading:o,execute:u}=v.useAsyncState(async a=>(n=new AbortController,g.skyConfig.dataProvider?.getList?.(l.meta.resource,{pagination:{page:1,perPage:t.size},filter:a,signal:n.signal})),void 0,{immediate:!0}),f=a=>{r.value===a[t.nodeKey]?r.value=void 0:r.value=a[t.nodeKey]},r=e.ref(),c=e.ref(0);return y.useProvideTreeWithDetails({createSuccess:async()=>{await u(),c.value++},editSuccess:async()=>{await u()},deleteSuccess:async()=>{await u(),r.value=void 0}}),q.useProvideReferenceArrayInput({reference:l.meta.resource,getList:a=>u(0,a),listData:d,listLoading:o}),()=>e.createVNode("div",{class:"sky-tree-with-details"},[e.createVNode(i.ElRow,null,{default:()=>[e.createVNode(i.ElCol,{span:8},{default:()=>[e.createVNode(i.ElCard,null,{default:()=>[e.createVNode(i.ElSkeleton,{loading:o.value,animated:!0},{default:()=>[e.createVNode(i.ElTree,e.mergeProps({data:d.value?.data,props:{children:t.optionChildren,label:t.optionName},defaultExpandAll:t.defaultExpandAll,expandOnClickNode:!1,nodeKey:t.nodeKey,"onNode-click":f,highlightCurrent:!0,currentNodeKey:r.value},s),null)]})]})]}),e.createVNode(i.ElCol,{offset:1,span:15},{default:()=>[r.value?t.edit?e.h(t.edit,{key:r.value,dataId:r.value}):null:t.create?e.h(t.create,{key:c.value}):null]})]})])}});exports.SkyTreeWithDetails=m;
2
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.cjs","sources":["../../../src/components/tree-with-details/index.tsx"],"sourcesContent":["import { useProvideReferenceArrayInput, useProvideTreeWithDetails } from '@/hooks'\nimport type { GetListResult, Identifier } from '@/provides'\nimport { skyConfig, type SkyComponent } from '@/setup'\nimport { useAsyncState } from '@vueuse/core'\nimport { ElCard, ElCol, ElRow, ElSkeleton, ElTree } from 'element-plus'\nimport { defineComponent, h, ref } from 'vue'\nimport { useRoute } from 'vue-router'\n\nexport interface SkyTreeWithDetailsProps {\n create?: SkyComponent\n edit?: SkyComponent\n optionChildren?: string\n optionName?: string\n defaultExpandAll?: boolean\n nodeKey?: string\n size?: number\n}\n\nexport const SkyTreeWithDetails = defineComponent<SkyTreeWithDetailsProps>({\n name: 'SkyTreeWithDetails',\n inheritAttrs: false,\n props: {\n create: Object,\n edit: Object,\n optionChildren: {\n type: String,\n default: 'children',\n },\n optionName: {\n type: String,\n default: 'name',\n },\n defaultExpandAll: {\n type: Boolean,\n default: true,\n },\n nodeKey: {\n type: String,\n default: 'id',\n },\n size: {\n type: Number,\n default: 30,\n },\n },\n setup(props, { attrs }) {\n const route = useRoute()\n\n let controller: AbortController | undefined\n const { state, isLoading, execute } = useAsyncState<\n GetListResult | undefined,\n [filter?: Record<string, unknown>]\n >(\n async (filter) => {\n controller = new AbortController()\n return skyConfig.dataProvider?.getList?.(route.meta.resource as string, {\n pagination: { page: 1, perPage: props.size! },\n filter,\n signal: controller.signal,\n })\n },\n undefined,\n {\n immediate: true,\n },\n )\n\n const onNodeClick = (node: Record<string, unknown>) => {\n if (editId.value === node[props.nodeKey!]) {\n // 再次点击选中的节点,退出编辑\n editId.value = undefined\n } else {\n editId.value = node[props.nodeKey!] as Identifier\n }\n }\n\n const editId = ref<Identifier>()\n const createNum = ref(0)\n\n useProvideTreeWithDetails({\n createSuccess: async () => {\n await execute()\n createNum.value++\n // if (result.data?.[props.nodeKey!]) {\n // editId.value = result.data[props.nodeKey!] as Identifier\n // }\n },\n editSuccess: async () => {\n await execute()\n },\n deleteSuccess: async () => {\n await execute()\n editId.value = undefined\n },\n })\n\n // 自动注入一次关联数据\n useProvideReferenceArrayInput({\n reference: route.meta.resource as string,\n getList: (filter?: Record<string, unknown>) => execute(0, filter),\n listData: state,\n listLoading: isLoading,\n })\n\n return () => (\n <div class=\"sky-tree-with-details\">\n <ElRow>\n <ElCol span={8}>\n <ElCard>\n <ElSkeleton loading={isLoading.value} animated>\n <ElTree\n data={state.value?.data}\n props={{ children: props.optionChildren, label: props.optionName }}\n defaultExpandAll={props.defaultExpandAll}\n expandOnClickNode={false}\n nodeKey={props.nodeKey}\n onNode-click={onNodeClick}\n highlightCurrent\n currentNodeKey={editId.value}\n {...attrs}\n ></ElTree>\n </ElSkeleton>\n </ElCard>\n </ElCol>\n <ElCol offset={1} span={15}>\n {editId.value\n ? props.edit\n ? h(props.edit, { key: editId.value, dataId: editId.value })\n : null\n : props.create\n ? h(props.create, { key: createNum.value })\n : null}\n </ElCol>\n </ElRow>\n </div>\n )\n },\n})\n"],"names":["SkyTreeWithDetails","defineComponent","name","inheritAttrs","props","create","edit","optionChildren","type","default","optionName","defaultExpandAll","nodeKey","size","attrs","route","useRoute","controller","execute","useAsyncState","filter","pagination","page","immediate","editId","ref","createNum","useProvideTreeWithDetails","useProvideReferenceArrayInput","reference","listData","listLoading","_createVNode","state","onNodeClick","h"],"mappings":"qmCAkBAA,EAAAC,EAAAA,gBAAA,CACEC,KAAAA,qBACAC,aAAAA,GACAC,MAAAA,CACEC,OAAAA,OACAC,KAAAA,OACAC,eAAAA,CACEC,KAAAA,OACAC,QAAAA,YAEFC,WAAAA,CACEF,KAAAA,OACAC,QAAAA,QAEFE,iBAAAA,CACEH,KAAAA,QACAC,QAAAA,IAEFG,QAAAA,CACEJ,KAAAA,OACAC,QAAAA,MAEFI,KAAAA,CACEL,KAAAA,OACAC,QAAAA,EACF,YAEaK,MAAAA,CAAM,EAAA,CACnB,MAAAC,EAAAC,EAAAA,SAAA,EAEA,IAAAC,4BAC0BC,QAAAA,CAAQ,EAAAC,EAAAA,cAAA,MAAAC,IAK9BH,EAAAA,IAAAA,qEAEEI,WAAAA,CAAcC,KAAAA,0CAGhB,CAAA,WAIAC,UAAAA,EACF,CAAA,oEAYFC,EAAAC,EAAAA,IAAA,EACAC,EAAAD,EAAAA,IAAA,CAAA,EAEAE,OAAAA,4BAAAA,+HAcE,CACF,CAAA,EAGAC,gCAAAA,CACEC,UAAAA,EAAAA,KAAAA,2BAEAC,SAAAA,EACAC,YAAAA,CACF,CAAA,EAEA,IAAAC,EAAAA,YAAA,MAAA,CAAO,MAAA,sDAAAvB,QAAAA,IAAAA,CAAAA,EAAAA,YAAAA,QAAAA,OAGa,EAAA,CAAAA,QAAAA,IAAAA,CAAAA,cAAAA,EAAAA,OAAAA,KAAAA,CAAAA,QAAAA,IAAAA,CAAAA,EAAAA,YAAAA,aAAAA,iBAE0B,SAAA,EAAA,EAAA,CAAAA,QAAAA,IAAAA,CAAAA,cAAAA,EAAAA,OAAAA,EAAAA,WAAAA,CAAA,KAAAwB,EAAA,OAAA,8FAIQ,kBAAA,qBAElB,eAAAC,EACG,iBAAA,GAAA,eAAAV,EAAA,KAEG,EAAAV,CAAA,EAAA,IAAA,CAAA,CACnB,CAAA,CAAA,CAAA,CAAA,CAAA,2BAAA,OAAA,SAKS,EAAA,CAAAL,QAAAA,IAAAA,CAAAA,EAAAA,MAAAA,EAAAA,KAAAA,EAAAA,EAAAA,EAAAA,KAAAA,2BAGsC,CAAA,EAAA,KAAAL,EAAA,OAAA+B,EAAAA,EAAA/B,EAAA,OAAA,oBAIpD,CAAA,CAAA,KAKpB,CACF,CAAA"}
@@ -0,0 +1,11 @@
1
+ import { SkyComponent } from '../../setup';
2
+ export interface SkyTreeWithDetailsProps {
3
+ create?: SkyComponent;
4
+ edit?: SkyComponent;
5
+ optionChildren?: string;
6
+ optionName?: string;
7
+ defaultExpandAll?: boolean;
8
+ nodeKey?: string;
9
+ size?: number;
10
+ }
11
+ export declare const SkyTreeWithDetails: import('vue').DefineComponent<SkyTreeWithDetailsProps, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<SkyTreeWithDetailsProps> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, any>;