@dt-frames/ui 1.0.0

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 (363) hide show
  1. package/README.md +15 -0
  2. package/es/assets/app-antd-dark-theme-style.e3b0c442.css +0 -0
  3. package/es/assets/app-theme-style.e3b0c442.css +0 -0
  4. package/es/assets/data/icon.d.ts +4 -0
  5. package/es/assets/data/icon.ts +69 -0
  6. package/es/assets/data/icon11.ts +69 -0
  7. package/es/assets/data/icons/actions.d.ts +1 -0
  8. package/es/assets/data/icons/actions.ts +427 -0
  9. package/es/assets/data/icons/code.d.ts +1 -0
  10. package/es/assets/data/icons/code.ts +10 -0
  11. package/es/assets/data/icons/commuticate.d.ts +1 -0
  12. package/es/assets/data/icons/commuticate.ts +190 -0
  13. package/es/assets/data/icons/currency.d.ts +1 -0
  14. package/es/assets/data/icons/currency.ts +46 -0
  15. package/es/assets/data/icons/devices.d.ts +1 -0
  16. package/es/assets/data/icons/devices.ts +128 -0
  17. package/es/assets/data/icons/edit.d.ts +1 -0
  18. package/es/assets/data/icons/edit.ts +165 -0
  19. package/es/assets/data/icons/file.d.ts +1 -0
  20. package/es/assets/data/icons/file.ts +104 -0
  21. package/es/assets/data/icons/math.d.ts +1 -0
  22. package/es/assets/data/icons/math.ts +53 -0
  23. package/es/assets/data/icons/message.d.ts +1 -0
  24. package/es/assets/data/icons/message.ts +75 -0
  25. package/es/assets/data/icons/navigate.d.ts +1 -0
  26. package/es/assets/data/icons/navigate.ts +181 -0
  27. package/es/assets/data/icons/other.d.ts +1 -0
  28. package/es/assets/data/icons/other.ts +333 -0
  29. package/es/assets/data/icons.d.ts +4 -0
  30. package/es/assets/data/icons.ts +58 -0
  31. package/es/assets/imgs/logo/logo.png +0 -0
  32. package/es/assets/locales/en_US.json +3 -0
  33. package/es/assets/locales/zh_CN.json +3 -0
  34. package/es/assets/style/index.less +10 -0
  35. package/es/assets/style/reset.less +20 -0
  36. package/es/assets/style/var.less +42 -0
  37. package/es/components/container/index.d.ts +3 -0
  38. package/es/components/container/src/bar.d.ts +14 -0
  39. package/es/components/container/src/scroll-bar.d.ts +93 -0
  40. package/es/components/container/src/scroll-container.d.ts +99 -0
  41. package/es/components/curd/index.d.ts +2 -0
  42. package/es/components/curd/src/components/dialog.d.ts +1494 -0
  43. package/es/components/curd/src/components/props.d.ts +33 -0
  44. package/es/components/curd/src/hooks/useCurd.d.ts +11 -0
  45. package/es/components/curd/src/types/curd.type.d.ts +19 -0
  46. package/es/components/excel/index.d.ts +2 -0
  47. package/es/components/excel/src/export2Excel.d.ts +3 -0
  48. package/es/components/forms/index.d.ts +5 -0
  49. package/es/components/forms/src/componentMap.d.ts +4 -0
  50. package/es/components/forms/src/components/formButton.d.ts +75 -0
  51. package/es/components/forms/src/components/formIcon.d.ts +2845 -0
  52. package/es/components/forms/src/components/formItem.d.ts +59 -0
  53. package/es/components/forms/src/components/radioButton.d.ts +33 -0
  54. package/es/components/forms/src/const/form.const.d.ts +7 -0
  55. package/es/components/forms/src/hooks/helper.d.ts +6 -0
  56. package/es/components/forms/src/hooks/useForm.d.ts +5 -0
  57. package/es/components/forms/src/hooks/useFormActions.d.ts +13 -0
  58. package/es/components/forms/src/hooks/useFormEvents.d.ts +26 -0
  59. package/es/components/forms/src/hooks/useFormValue.d.ts +3 -0
  60. package/es/components/forms/src/hooks/useFormValues.d.ts +14 -0
  61. package/es/components/forms/src/hooks/useLabelWidth.d.ts +35 -0
  62. package/es/components/forms/src/index.d.ts +186 -0
  63. package/es/components/forms/src/prop.d.ts +79 -0
  64. package/es/components/forms/src/types/form.type.d.ts +124 -0
  65. package/es/components/icons/index.d.ts +3 -0
  66. package/es/components/icons/pick-icon.d.ts +529 -0
  67. package/es/components/icons/src/pick-icon.d.ts +432 -0
  68. package/es/components/icons/src/svg-icon.d.ts +44 -0
  69. package/es/components/icons/svg-icon.d.ts +44 -0
  70. package/es/components/iframe/index.d.ts +2 -0
  71. package/es/components/iframe/src/index.d.ts +967 -0
  72. package/es/components/index.d.ts +14 -0
  73. package/es/components/modal/index.d.ts +3 -0
  74. package/es/components/modal/src/components/close-icon.d.ts +344 -0
  75. package/es/components/modal/src/components/modal-wrap.d.ts +236 -0
  76. package/es/components/modal/src/components/modal.d.ts +194 -0
  77. package/es/components/modal/src/components/modalFooter.d.ts +102 -0
  78. package/es/components/modal/src/hooks/useDrag.d.ts +7 -0
  79. package/es/components/modal/src/hooks/useFullScreen.d.ts +12 -0
  80. package/es/components/modal/src/hooks/useModal.d.ts +4 -0
  81. package/es/components/modal/src/index.d.ts +1187 -0
  82. package/es/components/modal/src/props.d.ts +89 -0
  83. package/es/components/modal/src/types/modal.type.d.ts +22 -0
  84. package/es/components/router/base-router.d.ts +2 -0
  85. package/es/components/router/index.d.ts +2 -0
  86. package/es/components/source/index.d.ts +1 -0
  87. package/es/components/source/src/hooks/useFetch.d.ts +5 -0
  88. package/es/components/source/src/hooks/useSource.d.ts +33 -0
  89. package/es/components/source/src/index.d.ts +2 -0
  90. package/es/components/source/src/types/source.type.d.ts +31 -0
  91. package/es/components/source/src/types/table.type.d.ts +7 -0
  92. package/es/components/table/index.d.ts +3 -0
  93. package/es/components/table/src/components/TableActions.d.ts +1279 -0
  94. package/es/components/table/src/components/TableHeader.d.ts +28 -0
  95. package/es/components/table/src/components/TableRender.d.ts +25 -0
  96. package/es/components/table/src/components/setting/Column.d.ts +1349 -0
  97. package/es/components/table/src/components/setting/Download.d.ts +1144 -0
  98. package/es/components/table/src/components/setting/Fullscreen.d.ts +270 -0
  99. package/es/components/table/src/components/setting/Size.d.ts +1145 -0
  100. package/es/components/table/src/components/setting/index.d.ts +26 -0
  101. package/es/components/table/src/const.d.ts +12 -0
  102. package/es/components/table/src/hooks/useColumns.d.ts +12 -0
  103. package/es/components/table/src/hooks/useDataSource.d.ts +16 -0
  104. package/es/components/table/src/hooks/useFormat.d.ts +2 -0
  105. package/es/components/table/src/hooks/useLoading.d.ts +6 -0
  106. package/es/components/table/src/hooks/usePagination.d.ts +122 -0
  107. package/es/components/table/src/hooks/useRowSelection.d.ts +13 -0
  108. package/es/components/table/src/hooks/useRows.d.ts +5 -0
  109. package/es/components/table/src/hooks/useTable.d.ts +5 -0
  110. package/es/components/table/src/hooks/useTableHeader.d.ts +8 -0
  111. package/es/components/table/src/hooks/useTableInstance.d.ts +13 -0
  112. package/es/components/table/src/hooks/useTableScroll.d.ts +12 -0
  113. package/es/components/table/src/hooks/useVirtualScroll.d.ts +5 -0
  114. package/es/components/table/src/index.d.ts +565 -0
  115. package/es/components/table/src/props.d.ts +192 -0
  116. package/es/components/table/src/types/table.type.d.ts +89 -0
  117. package/es/components/table/src/types/tableHeader.type.d.ts +23 -0
  118. package/es/components/table/src/utils/format.d.ts +1 -0
  119. package/es/directives/icon.d.ts +2 -0
  120. package/es/directives/index.d.ts +6 -0
  121. package/es/directives/permission.d.ts +2 -0
  122. package/es/global.d.ts +8 -0
  123. package/es/index.css +1 -0
  124. package/es/index.d.ts +3 -0
  125. package/es/index.js +8867 -0
  126. package/es/style/assets/style/index.less +10 -0
  127. package/es/style/assets/style/reset.less +20 -0
  128. package/es/style/assets/style/var.less +42 -0
  129. package/es/style/components/container/index.less +85 -0
  130. package/es/style/components/forms/src/index.less +82 -0
  131. package/es/style/components/icons/index.less +96 -0
  132. package/es/style/components/icons/src/index.less +96 -0
  133. package/es/style/components/iframe/src/index.less +3 -0
  134. package/es/style/components/modal/src/index.less +60 -0
  135. package/es/style/components/table/src/index.less +162 -0
  136. package/es/style/theme/footer/index.less +16 -0
  137. package/es/style/theme/header/index.less +438 -0
  138. package/es/style/theme/header/set-theme.less +68 -0
  139. package/es/style/theme/sider/index.less +203 -0
  140. package/es/style/theme/tabs/index.less +165 -0
  141. package/es/style/theme/theme.less +66 -0
  142. package/es/style/theme/transition.less +99 -0
  143. package/es/theme/content/index.d.ts +29 -0
  144. package/es/theme/feature/back-top.d.ts +105 -0
  145. package/es/theme/feature/index.d.ts +107 -0
  146. package/es/theme/footer/index.d.ts +30 -0
  147. package/es/theme/header/components/bread-crumb.d.ts +127 -0
  148. package/es/theme/header/components/fullscreen.d.ts +5 -0
  149. package/es/theme/header/components/handler.d.ts +2 -0
  150. package/es/theme/header/components/index.d.ts +10 -0
  151. package/es/theme/header/components/lang-picker.d.ts +290 -0
  152. package/es/theme/header/components/logo.d.ts +40 -0
  153. package/es/theme/header/components/menu-search.d.ts +528 -0
  154. package/es/theme/header/components/notify.d.ts +269 -0
  155. package/es/theme/header/components/setting-theme.d.ts +2550 -0
  156. package/es/theme/header/components/theme-drawer/enum.d.ts +5 -0
  157. package/es/theme/header/components/theme-drawer/feature.d.ts +1096 -0
  158. package/es/theme/header/components/theme-drawer/index.d.ts +3 -0
  159. package/es/theme/header/components/theme-drawer/menu-type.d.ts +273 -0
  160. package/es/theme/header/components/theme-drawer/select-item.d.ts +778 -0
  161. package/es/theme/header/components/theme-drawer/switch-item.d.ts +289 -0
  162. package/es/theme/header/components/trigger.d.ts +14 -0
  163. package/es/theme/header/components/user-info.d.ts +452 -0
  164. package/es/theme/header/const/index.d.ts +20 -0
  165. package/es/theme/header/helper/menu-tree.d.ts +3 -0
  166. package/es/theme/header/index.d.ts +4369 -0
  167. package/es/theme/header/multiple-header.d.ts +2001 -0
  168. package/es/theme/index.d.ts +2 -0
  169. package/es/theme/sider/components/basic-menu/basic-menu-item.d.ts +121 -0
  170. package/es/theme/sider/components/basic-menu/basic-menu.d.ts +752 -0
  171. package/es/theme/sider/components/basic-menu/basic-sub-menu-item.d.ts +250 -0
  172. package/es/theme/sider/components/basic-menu/menu-item-content.d.ts +34 -0
  173. package/es/theme/sider/components/drag-bar.d.ts +14 -0
  174. package/es/theme/sider/components/layout-menu.d.ts +22 -0
  175. package/es/theme/sider/components/props.d.ts +69 -0
  176. package/es/theme/sider/components/sider-trigger.d.ts +68 -0
  177. package/es/theme/sider/helper/sider.d.ts +12 -0
  178. package/es/theme/sider/helper/split-menu.d.ts +10 -0
  179. package/es/theme/sider/hooks/useDragLine.d.ts +2 -0
  180. package/es/theme/sider/hooks/useOpenKeys.d.ts +13 -0
  181. package/es/theme/sider/index.d.ts +152 -0
  182. package/es/theme/styles/hooks/changeTheme.d.ts +1 -0
  183. package/es/theme/styles/hooks/generate.d.ts +13 -0
  184. package/es/theme/styles/index.d.ts +2 -0
  185. package/es/theme/tabs/components/TabContent.d.ts +887 -0
  186. package/es/theme/tabs/components/TabRedo.d.ts +49 -0
  187. package/es/theme/tabs/hooks/useMultifyTabs.d.ts +7 -0
  188. package/es/theme/tabs/hooks/useTabDropdown.d.ts +6 -0
  189. package/es/theme/tabs/index.d.ts +1399 -0
  190. package/es/theme/tabs/types/tabs.type.d.ts +7 -0
  191. package/es/theme/theme/initTheme.d.ts +3 -0
  192. package/es/theme/theme/util.d.ts +5 -0
  193. package/es/theme/theme.d.ts +4911 -0
  194. package/es/themes/generate.ts +74 -0
  195. package/es/themes/index.ts +10 -0
  196. package/es/themes/modifyVars.ts +33 -0
  197. package/es/themes/themePlugiin.ts +74 -0
  198. package/package.json +49 -0
  199. package/src/assets/data/icons/actions.ts +427 -0
  200. package/src/assets/data/icons/code.ts +10 -0
  201. package/src/assets/data/icons/commuticate.ts +190 -0
  202. package/src/assets/data/icons/currency.ts +46 -0
  203. package/src/assets/data/icons/devices.ts +128 -0
  204. package/src/assets/data/icons/edit.ts +165 -0
  205. package/src/assets/data/icons/file.ts +104 -0
  206. package/src/assets/data/icons/math.ts +53 -0
  207. package/src/assets/data/icons/message.ts +75 -0
  208. package/src/assets/data/icons/navigate.ts +181 -0
  209. package/src/assets/data/icons/other.ts +333 -0
  210. package/src/assets/data/icons.ts +58 -0
  211. package/src/assets/imgs/logo/logo.png +0 -0
  212. package/src/assets/locales/en_US.json +3 -0
  213. package/src/assets/locales/zh_CN.json +3 -0
  214. package/src/assets/style/index.less +10 -0
  215. package/src/assets/style/reset.less +20 -0
  216. package/src/components/container/index.less +85 -0
  217. package/src/components/container/index.ts +8 -0
  218. package/src/components/container/src/bar.ts +107 -0
  219. package/src/components/container/src/lazy-container.vue +9 -0
  220. package/src/components/container/src/scroll-bar.vue +117 -0
  221. package/src/components/container/src/scroll-container.vue +61 -0
  222. package/src/components/curd/index.ts +5 -0
  223. package/src/components/curd/src/components/dialog.vue +65 -0
  224. package/src/components/curd/src/components/props.ts +32 -0
  225. package/src/components/curd/src/hooks/useCurd.tsx +72 -0
  226. package/src/components/curd/src/types/curd.type.ts +29 -0
  227. package/src/components/excel/index.ts +6 -0
  228. package/src/components/excel/src/export2Excel.ts +44 -0
  229. package/src/components/forms/index.ts +12 -0
  230. package/src/components/forms/src/componentMap.ts +44 -0
  231. package/src/components/forms/src/components/formButton.vue +150 -0
  232. package/src/components/forms/src/components/formIcon.vue +50 -0
  233. package/src/components/forms/src/components/formItem.vue +407 -0
  234. package/src/components/forms/src/components/radioButton.vue +58 -0
  235. package/src/components/forms/src/const/form.const.ts +7 -0
  236. package/src/components/forms/src/hooks/helper.ts +70 -0
  237. package/src/components/forms/src/hooks/useForm.ts +130 -0
  238. package/src/components/forms/src/hooks/useFormActions.ts +63 -0
  239. package/src/components/forms/src/hooks/useFormEvents.ts +247 -0
  240. package/src/components/forms/src/hooks/useFormValue.ts +49 -0
  241. package/src/components/forms/src/hooks/useFormValues.ts +131 -0
  242. package/src/components/forms/src/hooks/useLabelWidth.ts +57 -0
  243. package/src/components/forms/src/index.less +82 -0
  244. package/src/components/forms/src/index.vue +306 -0
  245. package/src/components/forms/src/prop.ts +80 -0
  246. package/src/components/forms/src/types/form.type.ts +269 -0
  247. package/src/components/icons/index.ts +7 -0
  248. package/src/components/icons/src/index.less +96 -0
  249. package/src/components/icons/src/pick-icon.vue +117 -0
  250. package/src/components/icons/src/svg-icon.vue +117 -0
  251. package/src/components/iframe/index.ts +5 -0
  252. package/src/components/iframe/src/index.less +3 -0
  253. package/src/components/iframe/src/index.vue +38 -0
  254. package/src/components/index.ts +46 -0
  255. package/src/components/modal/index.ts +8 -0
  256. package/src/components/modal/src/components/close-icon.vue +47 -0
  257. package/src/components/modal/src/components/modal-wrap.vue +118 -0
  258. package/src/components/modal/src/components/modal.tsx +30 -0
  259. package/src/components/modal/src/components/modalFooter.vue +38 -0
  260. package/src/components/modal/src/hooks/useDrag.ts +107 -0
  261. package/src/components/modal/src/hooks/useFullScreen.ts +27 -0
  262. package/src/components/modal/src/hooks/useModal.ts +177 -0
  263. package/src/components/modal/src/index.less +60 -0
  264. package/src/components/modal/src/index.vue +173 -0
  265. package/src/components/modal/src/props.ts +43 -0
  266. package/src/components/modal/src/types/modal.type.ts +27 -0
  267. package/src/components/router/base-router.vue +11 -0
  268. package/src/components/router/index.ts +3 -0
  269. package/src/components/source/index.ts +1 -0
  270. package/src/components/source/src/hooks/useFetch.ts +70 -0
  271. package/src/components/source/src/hooks/usePage.ts +3 -0
  272. package/src/components/source/src/hooks/useSource.ts +178 -0
  273. package/src/components/source/src/index.ts +5 -0
  274. package/src/components/source/src/types/source.type.ts +68 -0
  275. package/src/components/source/src/types/table.type.ts +8 -0
  276. package/src/components/table/index.ts +7 -0
  277. package/src/components/table/src/components/TableActions.vue +108 -0
  278. package/src/components/table/src/components/TableHeader.vue +77 -0
  279. package/src/components/table/src/components/TableRender.vue +76 -0
  280. package/src/components/table/src/components/setting/Column.vue +355 -0
  281. package/src/components/table/src/components/setting/Download.vue +55 -0
  282. package/src/components/table/src/components/setting/Fullscreen.vue +43 -0
  283. package/src/components/table/src/components/setting/Size.vue +42 -0
  284. package/src/components/table/src/components/setting/index.vue +64 -0
  285. package/src/components/table/src/const.ts +13 -0
  286. package/src/components/table/src/hooks/useColumns.ts +319 -0
  287. package/src/components/table/src/hooks/useCustomRow.ts +0 -0
  288. package/src/components/table/src/hooks/useDataSource.ts +99 -0
  289. package/src/components/table/src/hooks/useLoading.ts +29 -0
  290. package/src/components/table/src/hooks/usePagination.ts +76 -0
  291. package/src/components/table/src/hooks/useRowSelection.ts +146 -0
  292. package/src/components/table/src/hooks/useRows.ts +30 -0
  293. package/src/components/table/src/hooks/useTable.ts +77 -0
  294. package/src/components/table/src/hooks/useTableHeader.ts +48 -0
  295. package/src/components/table/src/hooks/useTableInstance.ts +29 -0
  296. package/src/components/table/src/hooks/useTableScroll.ts +227 -0
  297. package/src/components/table/src/index.less +162 -0
  298. package/src/components/table/src/index.vue +198 -0
  299. package/src/components/table/src/props.ts +152 -0
  300. package/src/components/table/src/types/table.type.ts +133 -0
  301. package/src/components/table/src/types/tableHeader.type.ts +27 -0
  302. package/src/components/type.ts +0 -0
  303. package/src/directives/icon.ts +36 -0
  304. package/src/directives/index.ts +26 -0
  305. package/src/directives/permission.ts +21 -0
  306. package/src/global.d.ts +8 -0
  307. package/src/index.ts +4 -0
  308. package/src/theme/content/index.vue +37 -0
  309. package/src/theme/feature/back-top.vue +11 -0
  310. package/src/theme/feature/index.vue +7 -0
  311. package/src/theme/footer/index.less +16 -0
  312. package/src/theme/footer/index.vue +24 -0
  313. package/src/theme/header/components/bread-crumb.vue +26 -0
  314. package/src/theme/header/components/fullscreen.vue +14 -0
  315. package/src/theme/header/components/handler.ts +81 -0
  316. package/src/theme/header/components/index.ts +21 -0
  317. package/src/theme/header/components/lang-picker.vue +36 -0
  318. package/src/theme/header/components/logo.vue +33 -0
  319. package/src/theme/header/components/menu-search.vue +62 -0
  320. package/src/theme/header/components/notify.vue +23 -0
  321. package/src/theme/header/components/setting-theme.vue +123 -0
  322. package/src/theme/header/components/theme-drawer/enum.ts +12 -0
  323. package/src/theme/header/components/theme-drawer/feature.vue +75 -0
  324. package/src/theme/header/components/theme-drawer/index.ts +7 -0
  325. package/src/theme/header/components/theme-drawer/menu-type.vue +40 -0
  326. package/src/theme/header/components/theme-drawer/select-item.vue +46 -0
  327. package/src/theme/header/components/theme-drawer/switch-item.vue +39 -0
  328. package/src/theme/header/components/theme-drawer/theme-color.vue +26 -0
  329. package/src/theme/header/components/trigger.vue +14 -0
  330. package/src/theme/header/components/user-info.vue +43 -0
  331. package/src/theme/header/const/index.ts +40 -0
  332. package/src/theme/header/helper/menu-tree.ts +67 -0
  333. package/src/theme/header/index.less +438 -0
  334. package/src/theme/header/index.ts +0 -0
  335. package/src/theme/header/index.vue +96 -0
  336. package/src/theme/header/multiple-header.vue +67 -0
  337. package/src/theme/header/set-theme.less +68 -0
  338. package/src/theme/index.ts +3 -0
  339. package/src/theme/sider/components/basic-menu/basic-menu-item.vue +14 -0
  340. package/src/theme/sider/components/basic-menu/basic-menu.vue +122 -0
  341. package/src/theme/sider/components/basic-menu/basic-sub-menu-item.vue +46 -0
  342. package/src/theme/sider/components/basic-menu/menu-item-content.vue +13 -0
  343. package/src/theme/sider/components/drag-bar.vue +26 -0
  344. package/src/theme/sider/components/layout-menu.vue +132 -0
  345. package/src/theme/sider/components/props.ts +97 -0
  346. package/src/theme/sider/components/sider-trigger.vue +24 -0
  347. package/src/theme/sider/helper/sider.ts +52 -0
  348. package/src/theme/sider/helper/split-menu.ts +147 -0
  349. package/src/theme/sider/hooks/useDragLine.ts +86 -0
  350. package/src/theme/sider/hooks/useOpenKeys.ts +57 -0
  351. package/src/theme/sider/index.less +203 -0
  352. package/src/theme/sider/index.vue +88 -0
  353. package/src/theme/tabs/components/TabContent.vue +37 -0
  354. package/src/theme/tabs/components/TabRedo.vue +18 -0
  355. package/src/theme/tabs/hooks/useMultifyTabs.ts +96 -0
  356. package/src/theme/tabs/hooks/useTabDropdown.ts +89 -0
  357. package/src/theme/tabs/index.less +165 -0
  358. package/src/theme/tabs/index.vue +98 -0
  359. package/src/theme/tabs/types/tabs.type.ts +8 -0
  360. package/src/theme/theme.less +66 -0
  361. package/src/theme/theme.vue +89 -0
  362. package/src/theme/transition.less +99 -0
  363. package/tsconfig.json +28 -0
@@ -0,0 +1,146 @@
1
+ /**
2
+ * 处理表格选中事件
3
+ */
4
+
5
+ import { isFunction, Recordable } from "@dt-frames/core";
6
+ import type { TableRowSelection } from 'ant-design-vue/lib/table/interface'
7
+ import { computed, ComputedRef, ref, Ref, toRaw, unref, watch, nextTick } from "vue";
8
+ import { BasicTableProps } from "../types/table.type";
9
+ import { omit } from 'lodash-es'
10
+
11
+ interface TreeHelperConfig {
12
+ id: string;
13
+ children: string;
14
+ pid: string;
15
+ }
16
+
17
+ const DEFAULT_CONFIG: TreeHelperConfig = {
18
+ id: 'id',
19
+ children: 'children',
20
+ pid: 'pid',
21
+ }
22
+
23
+ export function useRowSelection(
24
+ propsRef: ComputedRef<BasicTableProps>,
25
+ emit
26
+ ) {
27
+ // 选中的节点 不包含子节点
28
+ const selectedRowKeysRef = ref<string[]>([])
29
+ // 选中的节点 包含子节点
30
+ const selectedRowRef = ref<Recordable[]>([])
31
+
32
+ // 获取选中的行数据
33
+ const getRowSelectionRef = computed((): TableRowSelection | null => {
34
+ const { rowSelection } = unref(propsRef)
35
+
36
+ if (!rowSelection) {
37
+ return null;
38
+ }
39
+
40
+ return {
41
+ ...rowSelection,
42
+ selectedRowKeys: toRaw(unref(selectedRowKeysRef)),
43
+ onChange: (selectedRowKeys: string[]) => {
44
+ setSelectedRowKeys(selectedRowKeys)
45
+ },
46
+ }
47
+ })
48
+
49
+ watch(
50
+ () => unref(propsRef).rowSelection?.selectedRowKeys,
51
+ (v: string[]) => {
52
+ setSelectedRowKeys(v);
53
+ },
54
+ )
55
+
56
+ watch(
57
+ () => unref(selectedRowKeysRef),
58
+ () => {
59
+ nextTick(() => {
60
+ const { rowSelection } = unref(propsRef)
61
+
62
+ if (rowSelection){
63
+ const { onChange } = rowSelection
64
+ if (onChange && isFunction(onChange)) onChange(getSelectRowKeys(), getSelectRows())
65
+ }
66
+
67
+ emit('selection-change', {
68
+ keys: getSelectRowKeys(),
69
+ rows: getSelectRows(),
70
+ })
71
+ })
72
+ },
73
+ { deep: true }
74
+ )
75
+
76
+ // 设置树节点的选中
77
+ function findeNodeAll(
78
+ tree: any,
79
+ func: Function,
80
+ config: Partial<TreeHelperConfig> = {}
81
+ ) {
82
+ config = Object.assign({}, DEFAULT_CONFIG, config)
83
+ const { children } = config
84
+
85
+ const result: any[] = []
86
+ const list = [...tree]
87
+
88
+ for (const node of list) {
89
+ func(node) && result.push(node);
90
+ node.children && list.push(...node.children);
91
+ }
92
+
93
+ return result
94
+ }
95
+
96
+ // 设置选中的key
97
+ function setSelectedRowKeys( rowKeys: string[] ) {
98
+ selectedRowKeysRef.value = rowKeys
99
+
100
+ const allSelectedRows = findeNodeAll(
101
+ toRaw(unref(propsRef).dataSource).concat(toRaw(unref(selectedRowRef))),
102
+ (item) => rowKeys.includes(item[ unref( propsRef ).rowKey]),
103
+ {
104
+ children: propsRef.value.childrenColumnName ?? 'children',
105
+ },
106
+ )
107
+
108
+ const trueSelectedRows: any[] = []
109
+
110
+ rowKeys.forEach( (key: string) => {
111
+ const found = allSelectedRows.find((item) => item[ unref( propsRef ).rowKey] === key)
112
+ found && trueSelectedRows.push(found)
113
+ } )
114
+
115
+ selectedRowRef.value = trueSelectedRows
116
+ }
117
+
118
+
119
+ // 清除所有的选中数据
120
+ function clearSelectedRowKeys() {
121
+ selectedRowKeysRef.value = []
122
+ selectedRowRef.value = []
123
+ }
124
+
125
+ // 获取选中的行数据
126
+ function getRowSelection() {
127
+ return unref( getRowSelectionRef )
128
+ }
129
+
130
+ function getSelectRowKeys() {
131
+ return unref(selectedRowKeysRef);
132
+ }
133
+
134
+ function getSelectRows() {
135
+ return unref(selectedRowRef)
136
+ }
137
+
138
+ return {
139
+ getRowSelectionRef,
140
+ clearSelectedRowKeys,
141
+ getRowSelection,
142
+ getSelectRowKeys,
143
+ getSelectRows,
144
+ setSelectedRowKeys
145
+ }
146
+ }
@@ -0,0 +1,30 @@
1
+ import { isFunction } from "@dt-frames/core";
2
+ import { ComputedRef, unref } from "vue";
3
+ import { BasicTableProps } from "../types/table.type";
4
+
5
+
6
+ export function useRows(propsRef: ComputedRef<BasicTableProps>) {
7
+ /**
8
+ * 获取行的class
9
+ */
10
+ function getRowClassName(record: any, index: number) {
11
+
12
+ const { striped, rowClassName } = unref(propsRef)
13
+ const classNames: string[] = []
14
+
15
+ if( striped ) {
16
+ classNames.push( index % 2 === 1 ? 'table-striped' : '' )
17
+ }
18
+
19
+ if( rowClassName && isFunction(rowClassName) ) {
20
+ classNames.push( rowClassName( record, index ) )
21
+ }
22
+
23
+ return classNames.join(' ')
24
+ }
25
+
26
+ return {
27
+ getRowClassName
28
+ }
29
+
30
+ }
@@ -0,0 +1,77 @@
1
+ import { DynamicProps, Nullable, getDynamicProps, error } from '@dt-frames/core'
2
+ import { onUnmounted, ref, toRaw, unref, watch } from 'vue'
3
+ import { BasicColumn, BasicTableProps, TableActionType } from '../types/table.type'
4
+
5
+
6
+ type Props = Partial<DynamicProps<BasicTableProps>>
7
+
8
+ export function useTable(tableProps?: Props) {
9
+ const tableRef = ref<Nullable<TableActionType>>(null)
10
+ const loadedRef = ref<Nullable<boolean>>(false)
11
+
12
+ function registerTable( instance: TableActionType ) {
13
+ onUnmounted(() => {
14
+ tableRef.value = null;
15
+ loadedRef.value = null;
16
+ })
17
+
18
+ if( unref(loadedRef) && instance === unref(tableRef) ) return
19
+
20
+ tableRef.value = instance
21
+ tableProps && instance.setProps(getDynamicProps(tableProps))
22
+
23
+ watch(
24
+ () => tableProps,
25
+ () => {
26
+ tableProps && instance.setProps(getDynamicProps(tableProps));
27
+ },
28
+ {
29
+ immediate: true,
30
+ deep: true,
31
+ },
32
+ )
33
+
34
+ }
35
+
36
+ function getTableInstance(): TableActionType {
37
+ const table = unref(tableRef);
38
+ if (!table) {
39
+ error('没有table表单实例');
40
+ }
41
+
42
+ return table as TableActionType;
43
+ }
44
+
45
+ const methods: TableActionType = {
46
+ setProps: (props: Partial<BasicTableProps>) => {
47
+ getTableInstance().setProps(props);
48
+ },
49
+ setLoading: (loading: boolean) => {
50
+ getTableInstance().setLoading( loading )
51
+ },
52
+ getColumns: ({ ignoreIndex = false }: { ignoreIndex?: boolean } = {}) => {
53
+ const columns = getTableInstance().getColumns({ ignoreIndex }) || []
54
+ return toRaw(columns);
55
+ },
56
+ setColumns: (columns: BasicColumn[]) => {
57
+ getTableInstance().setColumns(columns)
58
+ },
59
+ getRowSelection: () => {
60
+ return toRaw(getTableInstance().getRowSelection())
61
+ },
62
+ getCacheColumns: () => {
63
+ return toRaw(getTableInstance().getCacheColumns())
64
+ },
65
+ getSize: () => {
66
+ return toRaw(getTableInstance().getSize())
67
+ },
68
+ getSelectRowKeys: () => {
69
+ return getTableInstance().getSelectRowKeys()
70
+ },
71
+ getSelectRows: () => {
72
+ return getTableInstance().getSelectRows()
73
+ }
74
+ }
75
+
76
+ return [registerTable as any, methods]
77
+ }
@@ -0,0 +1,48 @@
1
+ import { Recordable, useSlots } from "@dt-frames/core"
2
+ import { computed, ComputedRef, h, Slots, unref } from "vue"
3
+ import TableHeader from '../components/TableHeader.vue'
4
+ import { BasicTableProps, ColumnChangeParam } from "../types/table.type";
5
+
6
+ export function useTableHeader(
7
+ propsRef: ComputedRef<BasicTableProps>,
8
+ slots: Slots,
9
+ handlers: { onColumnsChange: (data: ColumnChangeParam[]) => void }
10
+ ) {
11
+ const getHeaderProps = computed((): Recordable => {
12
+ const { tableSetting, toolbar } = unref(propsRef)
13
+
14
+ const { getSlot } = useSlots()
15
+ const hideTitle = !slots.toolbar && !slots.headerTop && (!tableSetting || !tableSetting.length)
16
+
17
+ return {
18
+ title: hideTitle
19
+ ? null
20
+ : () =>
21
+ h(
22
+ TableHeader,
23
+ {
24
+ tableSetting,
25
+ toolbar,
26
+ onColumnsChange: handlers.onColumnsChange
27
+ } as Recordable,
28
+ {
29
+ ...(slots.toolbar
30
+ ? {
31
+ toolbar: () => getSlot(slots, 'toolbar'),
32
+ }
33
+ : {}),
34
+ ...(slots.headerTop
35
+ ? {
36
+ headerTop: () => getSlot(slots, 'headerTop'),
37
+ }
38
+ : {}),
39
+ },
40
+ )
41
+ }
42
+
43
+ })
44
+
45
+ return {
46
+ getHeaderProps
47
+ }
48
+ }
@@ -0,0 +1,29 @@
1
+ /** ======================================
2
+ * 保存table实例对象
3
+ * ======================================*/
4
+
5
+ import { Nullable, Recordable } from "@dt-frames/core"
6
+ import { ComputedRef, inject, provide, Ref } from "vue"
7
+ import { BasicTableProps, TableActionType } from "../types/table.type"
8
+
9
+
10
+ const tableKey = Symbol('dt-page')
11
+
12
+ type Instance = TableActionType & {
13
+ tableElRef: Ref<Nullable<HTMLElement>>
14
+ getBind: ComputedRef<Recordable>
15
+ }
16
+
17
+ type RetInstance = Omit<Instance, 'getBind'> & {
18
+ getBind: ComputedRef<BasicTableProps>
19
+ }
20
+
21
+ // 创建table实例
22
+ export function createTableInstance(instance: Instance) {
23
+ provide(tableKey, instance)
24
+ }
25
+
26
+ // 获取table实例
27
+ export function getTableInstance(): RetInstance {
28
+ return inject(tableKey) as RetInstance
29
+ }
@@ -0,0 +1,227 @@
1
+ import { isBoolean, windowResizeFn } from "@dt-frames/core"
2
+ import { useDebounceFn } from "@vueuse/core"
3
+ import { ComputedRef, ref, Ref, nextTick, watch, computed, unref, onMounted, h } from "vue"
4
+ import { TABLE_SIZE_HEIGHT } from "../const"
5
+ import { BasicColumn, BasicTableProps, TableRowSelection } from "../types/table.type"
6
+
7
+ /**
8
+ * 计算table横向和纵向的滚动条
9
+ */
10
+ export function useTableScroll(
11
+ propsRef: ComputedRef<BasicTableProps>,
12
+ tableElRef: Ref<HTMLDivElement & {$el: any} | null>,
13
+ columnsRef: ComputedRef<BasicColumn[]>,
14
+ rowSelectionRef: ComputedRef<TableRowSelection | null>
15
+ ) {
16
+ // 默认表格的高度
17
+ const tableHeightRef = ref(0)
18
+ const filterSource = ref([])
19
+
20
+ const debounceRedoHeight = useDebounceFn( redoHeight, 100 )
21
+
22
+ watch(
23
+ () => unref(propsRef)?.dataSource?.length,
24
+ () => {
25
+ debounceRedoHeight()
26
+ },
27
+ {
28
+ flush: 'post' // 在dom渲染之后监听
29
+ }
30
+ )
31
+
32
+ windowResizeFn(calcTableHeight, 280)
33
+
34
+ function redoHeight() {
35
+ nextTick(() => {
36
+ calcTableHeight()
37
+ })
38
+ }
39
+
40
+ let footerEl: HTMLElement | null
41
+ let bodyEl: HTMLElement | null
42
+
43
+ function setHeight(height: number) {
44
+ tableHeightRef.value = height
45
+ }
46
+
47
+ async function calcTableHeight() {
48
+ const { pagination, virtual } = unref(propsRef)
49
+
50
+ const table = unref(tableElRef)
51
+
52
+ if( !table ) return
53
+
54
+ const tableEl = table?.$el
55
+
56
+ if( !bodyEl ) {
57
+ bodyEl = tableEl.querySelector('.ant-table-body')
58
+ if( !bodyEl ) return
59
+ }
60
+
61
+ const hasScrollBarY = bodyEl.scrollHeight > bodyEl.clientHeight
62
+ const hasScrollBarX = bodyEl.scrollWidth > bodyEl.clientWidth
63
+
64
+ if( hasScrollBarY ) {
65
+ tableEl.classList.contains('hide-scrollbar-y') && tableEl.classList.remove('hide-scrollbar-y')
66
+ } else {
67
+ !tableEl.classList.contains('hide-scrollbar-y') && tableEl.classList.add('hide-scrollbar-y')
68
+ }
69
+
70
+ if (hasScrollBarX) {
71
+ tableEl.classList.contains('hide-scrollbar-x') && tableEl.classList.remove('hide-scrollbar-x')
72
+ } else {
73
+ !tableEl.classList.contains('hide-scrollbar-x') && tableEl.classList.add('hide-scrollbar-x')
74
+ }
75
+
76
+ bodyEl!.style.height = 'unset'
77
+ if( unref(propsRef).dataSource.length === 0 ) return
78
+
79
+ await nextTick()
80
+
81
+ let
82
+ headerHeight = 0,
83
+ paginationHeight = 2,
84
+ footerHeight = 0,
85
+ titleHeight = (tableEl.querySelector('.ant-table-title') as HTMLElement)?.offsetHeight ?? 0,
86
+ marginHeight = 15
87
+
88
+ const headEl = tableEl.querySelector('.ant-table-thead ')
89
+ if( headEl ) {
90
+ headerHeight = (headEl as HTMLElement).offsetHeight
91
+ }
92
+
93
+ if( !isBoolean(pagination) ) {
94
+ let paginationEl = tableEl.querySelector('.ant-pagination') as HTMLElement
95
+
96
+ if( paginationEl ) {
97
+ const offsetHeight = paginationEl.offsetHeight
98
+ paginationHeight += offsetHeight || 0
99
+ } else {
100
+ paginationHeight += 24
101
+ }
102
+
103
+ if( !footerEl ) {
104
+ footerEl = tableEl.querySelector('.ant-table-footer') as HTMLElement
105
+ } else {
106
+ const offsetHeight = footerEl.offsetHeight
107
+ footerHeight += offsetHeight || 0
108
+ }
109
+
110
+ } else {
111
+ paginationHeight = -8
112
+ }
113
+
114
+ const tableHeight = table?.$el?.offsetHeight ?? 0
115
+
116
+ let height = tableHeight - paginationHeight - footerHeight - headerHeight - titleHeight - marginHeight
117
+ height = Math.max(height, 167)
118
+
119
+ setHeight(height)
120
+
121
+ bodyEl!.style.height = `${height}px`
122
+
123
+ // 表格虚拟滚动
124
+ virtual ? calcTableScroll( ) : filterSource.value = unref(propsRef)?.dataSource
125
+ }
126
+
127
+ onMounted(() => {
128
+ calcTableHeight();
129
+ nextTick(() => {
130
+ debounceRedoHeight();
131
+ });
132
+ });
133
+
134
+ const getScrollX = computed(() => {
135
+ let width = 0
136
+
137
+ // 如果有复选框或者单选框
138
+ if( unref(rowSelectionRef) ) {
139
+ width += 32
140
+ }
141
+
142
+ const NORMAL_WIDTH = 120
143
+
144
+ const columns = unref(columnsRef).filter((item) => !item.defaultHidden)
145
+
146
+ columns.forEach( item => {
147
+ width += Number.parseInt(item.width as string) || NORMAL_WIDTH
148
+ } )
149
+
150
+ const table = unref(tableElRef)
151
+ const tableWidth = table?.$el?.offsetWidth ?? 0
152
+
153
+ return tableWidth > width ? '100%' : width
154
+ })
155
+
156
+ const getScrollRef = computed(() => {
157
+ const tableHeight = unref(tableHeightRef)
158
+ const { scroll } = unref(propsRef)
159
+
160
+ return {
161
+ x: unref(getScrollX),
162
+ y: tableHeight,
163
+ scrollToFirstRowOnChange: false,
164
+ ...scroll,
165
+ };
166
+ })
167
+
168
+ // 创建滚动元素
169
+ function createScrollWrap(el: Element) {
170
+ let data = unref(propsRef)?.dataSource?.length
171
+ const { size } = unref(propsRef)
172
+ const rowHeight = TABLE_SIZE_HEIGHT[size]
173
+
174
+ let scrollWrap = el.querySelector('.tableScrollWrap')
175
+ let wrapHeight = data * rowHeight + 'px'
176
+
177
+ if( scrollWrap ) {
178
+ (scrollWrap as any).style.height = wrapHeight
179
+ } else {
180
+ let div = document.createElement('div')
181
+ div.className = 'tableScrollWrap'
182
+ div.style.height = wrapHeight
183
+ el.insertBefore(div, el.querySelector('table')[0])
184
+ }
185
+ }
186
+
187
+ async function calcTableScroll() {
188
+ const tableEl = unref(tableElRef)?.$el
189
+ bodyEl = tableEl.querySelector('.ant-table-body')
190
+
191
+ // 添加一个滚动div元素
192
+ createScrollWrap(bodyEl)
193
+
194
+ calcScroll(bodyEl)
195
+
196
+ bodyEl.addEventListener('scroll', (e) => {
197
+ calcScroll(bodyEl)
198
+ })
199
+ }
200
+
201
+ async function calcScroll(el: Element) {
202
+ const { size } = unref(propsRef)
203
+ const rowHeight = TABLE_SIZE_HEIGHT[size]
204
+ const scrollTop = el.scrollTop
205
+
206
+ // 留闲高度,默认留3个表格高度
207
+ const remainCount = 3
208
+ const remainH = remainCount * rowHeight
209
+
210
+ // 最小高度
211
+ const minItemHeight = scrollTop > remainH ? Math.floor((scrollTop - remainH) / rowHeight) * rowHeight : 0
212
+
213
+ // 最小索引
214
+ const minIndex = minItemHeight / rowHeight
215
+ // 最大索引
216
+ const maxIndex = minIndex + Math.ceil(tableHeightRef.value / rowHeight) + (minItemHeight && remainCount) + remainCount * 2
217
+
218
+ bodyEl.querySelector('table').style.transform = `translateY(${minItemHeight}px)`
219
+
220
+ filterSource.value = unref(propsRef)?.dataSource.slice(minIndex, maxIndex)
221
+ }
222
+
223
+ return {
224
+ getScrollRef,
225
+ filterSource
226
+ }
227
+ }