rw-admin-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 (622) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +148 -0
  3. package/package.json +176 -0
  4. package/packages/alert/index.js +8 -0
  5. package/packages/alert/src/main.vue +94 -0
  6. package/packages/api-cascader/index.js +7 -0
  7. package/packages/api-cascader/src/api-cascader.vue +80 -0
  8. package/packages/api-select/index.js +7 -0
  9. package/packages/api-select/src/api-select.vue +226 -0
  10. package/packages/api-tree/index.js +7 -0
  11. package/packages/api-tree/src/api-tree.vue +130 -0
  12. package/packages/aside/index.js +8 -0
  13. package/packages/aside/src/main.vue +20 -0
  14. package/packages/autocomplete/index.js +8 -0
  15. package/packages/autocomplete/src/autocomplete-suggestions.vue +77 -0
  16. package/packages/autocomplete/src/autocomplete.vue +285 -0
  17. package/packages/avatar/index.js +8 -0
  18. package/packages/avatar/src/main.vue +107 -0
  19. package/packages/backtop/index.js +8 -0
  20. package/packages/backtop/src/main.vue +110 -0
  21. package/packages/badge/index.js +8 -0
  22. package/packages/badge/src/main.vue +53 -0
  23. package/packages/basic-form/basic-form-dataflow.md +136 -0
  24. package/packages/basic-form/index.js +12 -0
  25. package/packages/basic-form/src/basic-form-action.vue +71 -0
  26. package/packages/basic-form/src/basic-form-item.vue +179 -0
  27. package/packages/basic-form/src/basic-form-plain.vue +82 -0
  28. package/packages/basic-form/src/basic-form-sections.vue +426 -0
  29. package/packages/basic-form/src/basic-form.vue +48 -0
  30. package/packages/basic-form/src/components/render-vnode.js +21 -0
  31. package/packages/basic-form/src/mixins/basic-form-item.js +326 -0
  32. package/packages/basic-form/src/mixins/basic-form-runtime-factory.js +352 -0
  33. package/packages/basic-form/src/mixins/basic-form-runtime-sections.js +13 -0
  34. package/packages/basic-form/src/mixins/basic-form-runtime.js +12 -0
  35. package/packages/basic-form/src/mixins/basic-form-view.js +180 -0
  36. package/packages/basic-form/src/mixins/normalize-schemas-with-sections.js +52 -0
  37. package/packages/basic-table/index.js +7 -0
  38. package/packages/basic-table/src/actions.js +256 -0
  39. package/packages/basic-table/src/basic-table-column.vue +264 -0
  40. package/packages/basic-table/src/basic-table.vue +336 -0
  41. package/packages/basic-table/src/mixins/actions-context.js +47 -0
  42. package/packages/basic-table/src/mixins/fetch.js +117 -0
  43. package/packages/basic-table/src/mixins/form.js +29 -0
  44. package/packages/basic-table/src/mixins/pagination.js +57 -0
  45. package/packages/basic-table/src/mixins/watchers.js +60 -0
  46. package/packages/basic-table/src/overflow-cell.js +35 -0
  47. package/packages/basic-table/src/table-action.vue +66 -0
  48. package/packages/basic-table/src/utils.js +161 -0
  49. package/packages/basic-table-column/index.js +7 -0
  50. package/packages/breadcrumb/index.js +8 -0
  51. package/packages/breadcrumb/src/breadcrumb-item.vue +44 -0
  52. package/packages/breadcrumb/src/breadcrumb.vue +34 -0
  53. package/packages/breadcrumb-item/index.js +8 -0
  54. package/packages/button/index.js +8 -0
  55. package/packages/button/src/button-group.vue +10 -0
  56. package/packages/button/src/button.vue +79 -0
  57. package/packages/button-group/index.js +8 -0
  58. package/packages/calendar/index.js +8 -0
  59. package/packages/calendar/src/date-table.vue +200 -0
  60. package/packages/calendar/src/main.vue +280 -0
  61. package/packages/card/index.js +8 -0
  62. package/packages/card/src/main.vue +23 -0
  63. package/packages/carousel/index.js +8 -0
  64. package/packages/carousel/src/item.vue +138 -0
  65. package/packages/carousel/src/main.vue +315 -0
  66. package/packages/carousel-item/index.js +8 -0
  67. package/packages/cascader/index.js +8 -0
  68. package/packages/cascader/src/cascader.vue +664 -0
  69. package/packages/cascader-panel/index.js +8 -0
  70. package/packages/cascader-panel/src/cascader-menu.vue +138 -0
  71. package/packages/cascader-panel/src/cascader-node.vue +247 -0
  72. package/packages/cascader-panel/src/cascader-panel.vue +392 -0
  73. package/packages/cascader-panel/src/node.js +166 -0
  74. package/packages/cascader-panel/src/store.js +58 -0
  75. package/packages/checkbox/index.js +8 -0
  76. package/packages/checkbox/src/checkbox-button.vue +200 -0
  77. package/packages/checkbox/src/checkbox-group.vue +48 -0
  78. package/packages/checkbox/src/checkbox.vue +226 -0
  79. package/packages/checkbox-button/index.js +8 -0
  80. package/packages/checkbox-group/index.js +8 -0
  81. package/packages/col/index.js +9 -0
  82. package/packages/col/src/col.js +71 -0
  83. package/packages/collapse/index.js +9 -0
  84. package/packages/collapse/src/collapse-item.vue +115 -0
  85. package/packages/collapse/src/collapse.vue +73 -0
  86. package/packages/collapse-item/index.js +8 -0
  87. package/packages/color-picker/index.js +8 -0
  88. package/packages/color-picker/src/color.js +317 -0
  89. package/packages/color-picker/src/components/alpha-slider.vue +135 -0
  90. package/packages/color-picker/src/components/hue-slider.vue +125 -0
  91. package/packages/color-picker/src/components/picker-dropdown.vue +122 -0
  92. package/packages/color-picker/src/components/predefine.vue +62 -0
  93. package/packages/color-picker/src/components/sv-panel.vue +103 -0
  94. package/packages/color-picker/src/draggable.js +36 -0
  95. package/packages/color-picker/src/main.vue +308 -0
  96. package/packages/container/index.js +8 -0
  97. package/packages/container/src/main.vue +33 -0
  98. package/packages/date-picker/REFACTOR-TASKS.md +63 -0
  99. package/packages/date-picker/index.js +8 -0
  100. package/packages/date-picker/src/basic/date-table.vue +546 -0
  101. package/packages/date-picker/src/basic/month-table.vue +284 -0
  102. package/packages/date-picker/src/basic/quarter-table.vue +229 -0
  103. package/packages/date-picker/src/basic/time-spinner.vue +308 -0
  104. package/packages/date-picker/src/basic/year-table.vue +236 -0
  105. package/packages/date-picker/src/panel/date-range.vue +777 -0
  106. package/packages/date-picker/src/panel/date-time-range.vue +731 -0
  107. package/packages/date-picker/src/panel/date-time.vue +232 -0
  108. package/packages/date-picker/src/panel/date.vue +775 -0
  109. package/packages/date-picker/src/panel/month-range.vue +533 -0
  110. package/packages/date-picker/src/panel/month.vue +203 -0
  111. package/packages/date-picker/src/panel/quarter-range.vue +363 -0
  112. package/packages/date-picker/src/panel/quarter.vue +193 -0
  113. package/packages/date-picker/src/panel/time-range.vue +246 -0
  114. package/packages/date-picker/src/panel/time-select.vue +179 -0
  115. package/packages/date-picker/src/panel/time.vue +177 -0
  116. package/packages/date-picker/src/panel/week-range.vue +666 -0
  117. package/packages/date-picker/src/panel/year-range.vue +374 -0
  118. package/packages/date-picker/src/panel/year.vue +169 -0
  119. package/packages/date-picker/src/picker/date-picker.vue +166 -0
  120. package/packages/date-picker/src/picker/picker-mixin.js +1245 -0
  121. package/packages/date-picker/src/picker/range-picker.vue +377 -0
  122. package/packages/date-picker/src/picker/time-picker.vue +146 -0
  123. package/packages/date-picker/src/picker/time-select.vue +65 -0
  124. package/packages/descriptions/index.js +8 -0
  125. package/packages/descriptions/src/descriptions-item.js +30 -0
  126. package/packages/descriptions/src/descriptions-row.js +116 -0
  127. package/packages/descriptions/src/index.js +180 -0
  128. package/packages/descriptions-item/index.js +8 -0
  129. package/packages/dialog/index.js +8 -0
  130. package/packages/dialog/src/component.vue +212 -0
  131. package/packages/divider/index.js +8 -0
  132. package/packages/divider/src/main.vue +42 -0
  133. package/packages/drawer/index.js +8 -0
  134. package/packages/drawer/src/main.vue +205 -0
  135. package/packages/dropdown/index.js +8 -0
  136. package/packages/dropdown/src/dropdown-item.vue +40 -0
  137. package/packages/dropdown/src/dropdown-menu.vue +63 -0
  138. package/packages/dropdown/src/dropdown.vue +294 -0
  139. package/packages/dropdown-item/index.js +8 -0
  140. package/packages/dropdown-menu/index.js +8 -0
  141. package/packages/empty/index.js +7 -0
  142. package/packages/empty/src/img-empty.vue +132 -0
  143. package/packages/empty/src/index.vue +50 -0
  144. package/packages/footer/index.js +8 -0
  145. package/packages/footer/src/main.vue +20 -0
  146. package/packages/form/index.js +8 -0
  147. package/packages/form/src/form-item.vue +346 -0
  148. package/packages/form/src/form.vue +184 -0
  149. package/packages/form/src/label-wrap.vue +78 -0
  150. package/packages/form-item/index.js +8 -0
  151. package/packages/header/index.js +8 -0
  152. package/packages/header/src/main.vue +20 -0
  153. package/packages/icon/index.js +8 -0
  154. package/packages/icon/src/icon.vue +13 -0
  155. package/packages/image/index.js +8 -0
  156. package/packages/image/src/image-viewer.vue +330 -0
  157. package/packages/image/src/main.vue +249 -0
  158. package/packages/infinite-scroll/index.js +8 -0
  159. package/packages/infinite-scroll/src/main.js +150 -0
  160. package/packages/input/index.js +8 -0
  161. package/packages/input/src/calcTextareaHeight.js +104 -0
  162. package/packages/input/src/input.vue +446 -0
  163. package/packages/input-number/index.js +8 -0
  164. package/packages/input-number/src/input-number.vue +282 -0
  165. package/packages/link/index.js +8 -0
  166. package/packages/link/src/main.vue +53 -0
  167. package/packages/loading/index.js +11 -0
  168. package/packages/loading/src/directive.js +133 -0
  169. package/packages/loading/src/index.js +106 -0
  170. package/packages/loading/src/loading.vue +41 -0
  171. package/packages/main/index.js +8 -0
  172. package/packages/main/src/main.vue +12 -0
  173. package/packages/menu/index.js +8 -0
  174. package/packages/menu/src/menu-item-group.vue +45 -0
  175. package/packages/menu/src/menu-item.vue +113 -0
  176. package/packages/menu/src/menu-mixin.js +44 -0
  177. package/packages/menu/src/menu.vue +325 -0
  178. package/packages/menu/src/submenu.vue +349 -0
  179. package/packages/menu-item/index.js +8 -0
  180. package/packages/menu-item-group/index.js +8 -0
  181. package/packages/message/index.js +2 -0
  182. package/packages/message/src/main.js +91 -0
  183. package/packages/message/src/main.vue +117 -0
  184. package/packages/message-box/index.js +2 -0
  185. package/packages/message-box/src/main.js +216 -0
  186. package/packages/message-box/src/main.vue +337 -0
  187. package/packages/notification/index.js +2 -0
  188. package/packages/notification/src/main.js +94 -0
  189. package/packages/notification/src/main.vue +152 -0
  190. package/packages/option/index.js +8 -0
  191. package/packages/option-group/index.js +8 -0
  192. package/packages/page-header/index.js +8 -0
  193. package/packages/page-header/src/main.vue +30 -0
  194. package/packages/pagination/index.js +8 -0
  195. package/packages/pagination/src/pager.vue +198 -0
  196. package/packages/pagination/src/pagination.js +386 -0
  197. package/packages/popconfirm/index.js +8 -0
  198. package/packages/popconfirm/src/main.vue +108 -0
  199. package/packages/popover/index.js +14 -0
  200. package/packages/popover/src/directive.js +20 -0
  201. package/packages/popover/src/main.vue +242 -0
  202. package/packages/progress/index.js +8 -0
  203. package/packages/progress/src/progress.vue +235 -0
  204. package/packages/radio/index.js +8 -0
  205. package/packages/radio/src/radio-button.vue +118 -0
  206. package/packages/radio/src/radio-group.vue +131 -0
  207. package/packages/radio/src/radio.vue +137 -0
  208. package/packages/radio-button/index.js +8 -0
  209. package/packages/radio-group/index.js +8 -0
  210. package/packages/range-picker/index.js +8 -0
  211. package/packages/rate/index.js +8 -0
  212. package/packages/rate/src/main.vue +348 -0
  213. package/packages/result/index.js +8 -0
  214. package/packages/result/src/icon-error.vue +13 -0
  215. package/packages/result/src/icon-info.vue +13 -0
  216. package/packages/result/src/icon-success.vue +13 -0
  217. package/packages/result/src/icon-warning.vue +13 -0
  218. package/packages/result/src/index.vue +65 -0
  219. package/packages/row/index.js +9 -0
  220. package/packages/row/src/row.js +44 -0
  221. package/packages/scrollbar/index.js +8 -0
  222. package/packages/scrollbar/src/bar.js +92 -0
  223. package/packages/scrollbar/src/main.js +130 -0
  224. package/packages/scrollbar/src/util.js +34 -0
  225. package/packages/select/index.js +8 -0
  226. package/packages/select/src/navigation-mixin.js +54 -0
  227. package/packages/select/src/option-group.vue +60 -0
  228. package/packages/select/src/option.vue +169 -0
  229. package/packages/select/src/select-dropdown.vue +78 -0
  230. package/packages/select/src/select.vue +901 -0
  231. package/packages/skeleton/index.js +8 -0
  232. package/packages/skeleton/src/img-placeholder.vue +16 -0
  233. package/packages/skeleton/src/index.vue +76 -0
  234. package/packages/skeleton/src/item.vue +22 -0
  235. package/packages/skeleton-item/index.js +8 -0
  236. package/packages/slider/index.js +8 -0
  237. package/packages/slider/src/button.vue +238 -0
  238. package/packages/slider/src/main.vue +425 -0
  239. package/packages/slider/src/marker.js +18 -0
  240. package/packages/spinner/index.js +8 -0
  241. package/packages/spinner/src/spinner.vue +27 -0
  242. package/packages/statistic/index.js +8 -0
  243. package/packages/statistic/src/main.vue +204 -0
  244. package/packages/step/index.js +8 -0
  245. package/packages/steps/README.md +69 -0
  246. package/packages/steps/index.js +8 -0
  247. package/packages/steps/src/step.vue +184 -0
  248. package/packages/steps/src/steps.vue +68 -0
  249. package/packages/submenu/index.js +8 -0
  250. package/packages/switch/index.js +9 -0
  251. package/packages/switch/src/component.vue +174 -0
  252. package/packages/tab-pane/index.js +8 -0
  253. package/packages/table/index.js +8 -0
  254. package/packages/table/src/config.js +124 -0
  255. package/packages/table/src/dropdown.js +28 -0
  256. package/packages/table/src/filter-panel.vue +197 -0
  257. package/packages/table/src/layout-observer.js +68 -0
  258. package/packages/table/src/store/current.js +76 -0
  259. package/packages/table/src/store/expand.js +65 -0
  260. package/packages/table/src/store/helper.js +41 -0
  261. package/packages/table/src/store/index.js +147 -0
  262. package/packages/table/src/store/tree.js +209 -0
  263. package/packages/table/src/store/watcher.js +381 -0
  264. package/packages/table/src/table-body.js +469 -0
  265. package/packages/table/src/table-column.js +319 -0
  266. package/packages/table/src/table-footer.js +153 -0
  267. package/packages/table/src/table-header.js +511 -0
  268. package/packages/table/src/table-layout.js +249 -0
  269. package/packages/table/src/table-row.js +101 -0
  270. package/packages/table/src/table.vue +707 -0
  271. package/packages/table/src/util.js +273 -0
  272. package/packages/table-action/index.js +7 -0
  273. package/packages/table-column/index.js +8 -0
  274. package/packages/tabs/index.js +8 -0
  275. package/packages/tabs/src/tab-bar.vue +57 -0
  276. package/packages/tabs/src/tab-nav.vue +294 -0
  277. package/packages/tabs/src/tab-pane.vue +61 -0
  278. package/packages/tabs/src/tabs.vue +193 -0
  279. package/packages/tag/index.js +8 -0
  280. package/packages/tag/src/tag.vue +58 -0
  281. package/packages/theme-chalk/README.md +33 -0
  282. package/packages/theme-chalk/gulpfile.js +25 -0
  283. package/packages/theme-chalk/package.json +35 -0
  284. package/packages/theme-chalk/src/alert.scss +151 -0
  285. package/packages/theme-chalk/src/api-cascader.scss +0 -0
  286. package/packages/theme-chalk/src/api-select.scss +7 -0
  287. package/packages/theme-chalk/src/api-tree.scss +0 -0
  288. package/packages/theme-chalk/src/aside.scss +7 -0
  289. package/packages/theme-chalk/src/autocomplete.scss +80 -0
  290. package/packages/theme-chalk/src/avatar.scss +51 -0
  291. package/packages/theme-chalk/src/backtop.scss +22 -0
  292. package/packages/theme-chalk/src/badge.scss +57 -0
  293. package/packages/theme-chalk/src/base.scss +2 -0
  294. package/packages/theme-chalk/src/basic-form.scss +29 -0
  295. package/packages/theme-chalk/src/basic-table-column.scss +0 -0
  296. package/packages/theme-chalk/src/basic-table.scss +120 -0
  297. package/packages/theme-chalk/src/breadcrumb-item.scss +0 -0
  298. package/packages/theme-chalk/src/breadcrumb.scss +59 -0
  299. package/packages/theme-chalk/src/button-group.scss +0 -0
  300. package/packages/theme-chalk/src/button.scss +306 -0
  301. package/packages/theme-chalk/src/calendar.scss +82 -0
  302. package/packages/theme-chalk/src/card.scss +35 -0
  303. package/packages/theme-chalk/src/carousel-item.scss +50 -0
  304. package/packages/theme-chalk/src/carousel.scss +161 -0
  305. package/packages/theme-chalk/src/cascader-panel.scss +124 -0
  306. package/packages/theme-chalk/src/cascader.scss +183 -0
  307. package/packages/theme-chalk/src/checkbox-button.scss +120 -0
  308. package/packages/theme-chalk/src/checkbox-group.scss +6 -0
  309. package/packages/theme-chalk/src/checkbox.scss +293 -0
  310. package/packages/theme-chalk/src/col.scss +156 -0
  311. package/packages/theme-chalk/src/collapse-item.scss +0 -0
  312. package/packages/theme-chalk/src/collapse.scss +63 -0
  313. package/packages/theme-chalk/src/color-picker.scss +431 -0
  314. package/packages/theme-chalk/src/common/popup.scss +42 -0
  315. package/packages/theme-chalk/src/common/transition.scss +120 -0
  316. package/packages/theme-chalk/src/common/var.scss +1569 -0
  317. package/packages/theme-chalk/src/container.scss +14 -0
  318. package/packages/theme-chalk/src/date-picker/common/picker-panel.scss +143 -0
  319. package/packages/theme-chalk/src/date-picker/common/picker.scss +235 -0
  320. package/packages/theme-chalk/src/date-picker/day/date-picker.scss +104 -0
  321. package/packages/theme-chalk/src/date-picker/day/date-range-picker.scss +162 -0
  322. package/packages/theme-chalk/src/date-picker/day/date-table.scss +212 -0
  323. package/packages/theme-chalk/src/date-picker/month/month-table.scss +133 -0
  324. package/packages/theme-chalk/src/date-picker/quarter/quarter-table.scss +106 -0
  325. package/packages/theme-chalk/src/date-picker/time/time-picker.scss +86 -0
  326. package/packages/theme-chalk/src/date-picker/time/time-range-picker.scss +32 -0
  327. package/packages/theme-chalk/src/date-picker/time/time-spinner.scss +110 -0
  328. package/packages/theme-chalk/src/date-picker/year/year-table.scss +143 -0
  329. package/packages/theme-chalk/src/date-picker.scss +26 -0
  330. package/packages/theme-chalk/src/descriptions-item.scss +45 -0
  331. package/packages/theme-chalk/src/descriptions.scss +112 -0
  332. package/packages/theme-chalk/src/dialog.scss +132 -0
  333. package/packages/theme-chalk/src/display.scss +12 -0
  334. package/packages/theme-chalk/src/divider.scss +47 -0
  335. package/packages/theme-chalk/src/drawer.scss +229 -0
  336. package/packages/theme-chalk/src/dropdown-item.scss +0 -0
  337. package/packages/theme-chalk/src/dropdown-menu.scss +0 -0
  338. package/packages/theme-chalk/src/dropdown.scss +209 -0
  339. package/packages/theme-chalk/src/empty.scss +45 -0
  340. package/packages/theme-chalk/src/fonts/element-icons.ttf +0 -0
  341. package/packages/theme-chalk/src/fonts/element-icons.woff +0 -0
  342. package/packages/theme-chalk/src/footer.scss +8 -0
  343. package/packages/theme-chalk/src/form-item.scss +0 -0
  344. package/packages/theme-chalk/src/form.scss +192 -0
  345. package/packages/theme-chalk/src/header.scss +8 -0
  346. package/packages/theme-chalk/src/icon.scss +1182 -0
  347. package/packages/theme-chalk/src/image.scss +179 -0
  348. package/packages/theme-chalk/src/index.scss +95 -0
  349. package/packages/theme-chalk/src/infinite-scroll.scss +0 -0
  350. package/packages/theme-chalk/src/infiniteScroll.scss +0 -0
  351. package/packages/theme-chalk/src/input-number.scss +187 -0
  352. package/packages/theme-chalk/src/input.scss +365 -0
  353. package/packages/theme-chalk/src/link.scss +81 -0
  354. package/packages/theme-chalk/src/loading.scss +109 -0
  355. package/packages/theme-chalk/src/main.scss +12 -0
  356. package/packages/theme-chalk/src/menu-item-group.scss +0 -0
  357. package/packages/theme-chalk/src/menu-item.scss +0 -0
  358. package/packages/theme-chalk/src/menu.scss +317 -0
  359. package/packages/theme-chalk/src/message-box.scss +231 -0
  360. package/packages/theme-chalk/src/message.scss +123 -0
  361. package/packages/theme-chalk/src/mixins/_button.scss +81 -0
  362. package/packages/theme-chalk/src/mixins/config.scss +4 -0
  363. package/packages/theme-chalk/src/mixins/function.scss +44 -0
  364. package/packages/theme-chalk/src/mixins/mixins.scss +190 -0
  365. package/packages/theme-chalk/src/mixins/utils.scss +39 -0
  366. package/packages/theme-chalk/src/notification.scss +100 -0
  367. package/packages/theme-chalk/src/option-group.scss +42 -0
  368. package/packages/theme-chalk/src/option.scss +36 -0
  369. package/packages/theme-chalk/src/page-header.scss +42 -0
  370. package/packages/theme-chalk/src/pagination.scss +334 -0
  371. package/packages/theme-chalk/src/popconfirm.scss +16 -0
  372. package/packages/theme-chalk/src/popover.scss +40 -0
  373. package/packages/theme-chalk/src/popper.scss +159 -0
  374. package/packages/theme-chalk/src/progress.scss +141 -0
  375. package/packages/theme-chalk/src/radio-button.scss +118 -0
  376. package/packages/theme-chalk/src/radio-group.scss +9 -0
  377. package/packages/theme-chalk/src/radio.scss +384 -0
  378. package/packages/theme-chalk/src/range-picker.scss +0 -0
  379. package/packages/theme-chalk/src/rate.scss +49 -0
  380. package/packages/theme-chalk/src/reset.scss +79 -0
  381. package/packages/theme-chalk/src/result.scss +61 -0
  382. package/packages/theme-chalk/src/row.scss +43 -0
  383. package/packages/theme-chalk/src/scrollbar.scss +72 -0
  384. package/packages/theme-chalk/src/select-dropdown.scss +62 -0
  385. package/packages/theme-chalk/src/select.scss +153 -0
  386. package/packages/theme-chalk/src/skeleton-item.scss +84 -0
  387. package/packages/theme-chalk/src/skeleton.scss +40 -0
  388. package/packages/theme-chalk/src/slider.scss +250 -0
  389. package/packages/theme-chalk/src/spinner.scss +44 -0
  390. package/packages/theme-chalk/src/statistic.scss +46 -0
  391. package/packages/theme-chalk/src/step.scss +317 -0
  392. package/packages/theme-chalk/src/steps.scss +22 -0
  393. package/packages/theme-chalk/src/submenu.scss +0 -0
  394. package/packages/theme-chalk/src/switch.scss +122 -0
  395. package/packages/theme-chalk/src/tab-pane.scss +0 -0
  396. package/packages/theme-chalk/src/table-action.scss +0 -0
  397. package/packages/theme-chalk/src/table-column.scss +97 -0
  398. package/packages/theme-chalk/src/table.scss +577 -0
  399. package/packages/theme-chalk/src/tabs.scss +671 -0
  400. package/packages/theme-chalk/src/tag.scss +168 -0
  401. package/packages/theme-chalk/src/time-picker.scss +8 -0
  402. package/packages/theme-chalk/src/time-select.scss +37 -0
  403. package/packages/theme-chalk/src/timeline-item.scss +92 -0
  404. package/packages/theme-chalk/src/timeline.scss +14 -0
  405. package/packages/theme-chalk/src/tooltip.scss +141 -0
  406. package/packages/theme-chalk/src/transfer.scss +238 -0
  407. package/packages/theme-chalk/src/tree.scss +130 -0
  408. package/packages/theme-chalk/src/upload.scss +621 -0
  409. package/packages/time-picker/index.js +8 -0
  410. package/packages/time-select/index.js +8 -0
  411. package/packages/timeline/index.js +8 -0
  412. package/packages/timeline/src/item.vue +77 -0
  413. package/packages/timeline/src/main.vue +33 -0
  414. package/packages/timeline-item/index.js +8 -0
  415. package/packages/tooltip/index.js +8 -0
  416. package/packages/tooltip/src/main.js +242 -0
  417. package/packages/transfer/index.js +8 -0
  418. package/packages/transfer/src/main.vue +233 -0
  419. package/packages/transfer/src/transfer-panel.vue +252 -0
  420. package/packages/tree/index.js +8 -0
  421. package/packages/tree/src/model/node.js +484 -0
  422. package/packages/tree/src/model/tree-store.js +340 -0
  423. package/packages/tree/src/model/util.js +27 -0
  424. package/packages/tree/src/tree-node.vue +281 -0
  425. package/packages/tree/src/tree.vue +496 -0
  426. package/packages/upload/index.js +8 -0
  427. package/packages/upload/src/ajax.js +85 -0
  428. package/packages/upload/src/index.vue +338 -0
  429. package/packages/upload/src/upload-dragger.vue +70 -0
  430. package/packages/upload/src/upload-list.vue +106 -0
  431. package/packages/upload/src/upload.vue +211 -0
  432. package/src/directives/mousewheel.js +18 -0
  433. package/src/directives/repeat-click.js +26 -0
  434. package/src/index.js +333 -0
  435. package/src/locale/format.js +46 -0
  436. package/src/locale/index.js +48 -0
  437. package/src/locale/lang/af-ZA.js +123 -0
  438. package/src/locale/lang/ar.js +122 -0
  439. package/src/locale/lang/az.js +126 -0
  440. package/src/locale/lang/bg.js +123 -0
  441. package/src/locale/lang/bn.js +126 -0
  442. package/src/locale/lang/ca.js +122 -0
  443. package/src/locale/lang/cs-CZ.js +125 -0
  444. package/src/locale/lang/da.js +122 -0
  445. package/src/locale/lang/de.js +124 -0
  446. package/src/locale/lang/ee.js +123 -0
  447. package/src/locale/lang/el.js +123 -0
  448. package/src/locale/lang/en.js +123 -0
  449. package/src/locale/lang/eo.js +123 -0
  450. package/src/locale/lang/es.js +122 -0
  451. package/src/locale/lang/eu.js +123 -0
  452. package/src/locale/lang/fa.js +123 -0
  453. package/src/locale/lang/fi.js +123 -0
  454. package/src/locale/lang/fr.js +122 -0
  455. package/src/locale/lang/he.js +123 -0
  456. package/src/locale/lang/hr.js +123 -0
  457. package/src/locale/lang/hu.js +122 -0
  458. package/src/locale/lang/hy-AM.js +123 -0
  459. package/src/locale/lang/id.js +123 -0
  460. package/src/locale/lang/is.js +124 -0
  461. package/src/locale/lang/it.js +122 -0
  462. package/src/locale/lang/ja.js +123 -0
  463. package/src/locale/lang/kg.js +123 -0
  464. package/src/locale/lang/km.js +123 -0
  465. package/src/locale/lang/ko.js +123 -0
  466. package/src/locale/lang/ku.js +123 -0
  467. package/src/locale/lang/kz.js +123 -0
  468. package/src/locale/lang/lo-LA.js +126 -0
  469. package/src/locale/lang/lt.js +123 -0
  470. package/src/locale/lang/lv.js +123 -0
  471. package/src/locale/lang/mn.js +123 -0
  472. package/src/locale/lang/ms.js +122 -0
  473. package/src/locale/lang/nb-NO.js +122 -0
  474. package/src/locale/lang/nl.js +123 -0
  475. package/src/locale/lang/pl.js +123 -0
  476. package/src/locale/lang/pt-br.js +123 -0
  477. package/src/locale/lang/pt.js +123 -0
  478. package/src/locale/lang/ro.js +123 -0
  479. package/src/locale/lang/ru-RU.js +123 -0
  480. package/src/locale/lang/si.js +123 -0
  481. package/src/locale/lang/sk.js +125 -0
  482. package/src/locale/lang/sl.js +123 -0
  483. package/src/locale/lang/sr-Latn.js +123 -0
  484. package/src/locale/lang/sr.js +123 -0
  485. package/src/locale/lang/sv-SE.js +123 -0
  486. package/src/locale/lang/sw.js +123 -0
  487. package/src/locale/lang/ta.js +122 -0
  488. package/src/locale/lang/th.js +123 -0
  489. package/src/locale/lang/tk.js +123 -0
  490. package/src/locale/lang/tr-TR.js +123 -0
  491. package/src/locale/lang/ua.js +123 -0
  492. package/src/locale/lang/ug-CN.js +123 -0
  493. package/src/locale/lang/uz-UZ.js +123 -0
  494. package/src/locale/lang/vi.js +123 -0
  495. package/src/locale/lang/zh-CN.js +131 -0
  496. package/src/locale/lang/zh-TW.js +123 -0
  497. package/src/mixins/emitter.js +33 -0
  498. package/src/mixins/focus.js +9 -0
  499. package/src/mixins/locale.js +9 -0
  500. package/src/mixins/migrating.js +54 -0
  501. package/src/transitions/collapse-transition.js +77 -0
  502. package/src/utils/after-leave.js +27 -0
  503. package/src/utils/aria-dialog.js +90 -0
  504. package/src/utils/aria-utils.js +122 -0
  505. package/src/utils/clickoutside.js +76 -0
  506. package/src/utils/date-util.js +282 -0
  507. package/src/utils/date.js +392 -0
  508. package/src/utils/dom.js +227 -0
  509. package/src/utils/lodash.js +18075 -0
  510. package/src/utils/menu/aria-menubar.js +14 -0
  511. package/src/utils/menu/aria-menuitem.js +49 -0
  512. package/src/utils/menu/aria-submenu.js +59 -0
  513. package/src/utils/merge.js +15 -0
  514. package/src/utils/popper.js +1276 -0
  515. package/src/utils/popup/index.js +218 -0
  516. package/src/utils/popup/popup-manager.js +194 -0
  517. package/src/utils/resize-event.js +36 -0
  518. package/src/utils/scroll-into-view.js +27 -0
  519. package/src/utils/scrollbar-width.js +29 -0
  520. package/src/utils/shared.js +7 -0
  521. package/src/utils/types.js +40 -0
  522. package/src/utils/util.js +245 -0
  523. package/src/utils/vdom.js +5 -0
  524. package/src/utils/vue-popper.js +198 -0
  525. package/types/alert.d.ts +31 -0
  526. package/types/api-cascader.d.ts +10 -0
  527. package/types/api-select.d.ts +13 -0
  528. package/types/api-tree.d.ts +10 -0
  529. package/types/aside.d.ts +7 -0
  530. package/types/autocomplete.d.ts +78 -0
  531. package/types/avatar.d.ts +20 -0
  532. package/types/backtop.d.ts +16 -0
  533. package/types/badge.d.ts +16 -0
  534. package/types/basic-form.d.ts +50 -0
  535. package/types/basic-table.d.ts +3 -0
  536. package/types/breadcrumb-item.d.ts +10 -0
  537. package/types/breadcrumb.d.ts +10 -0
  538. package/types/button-group.d.ts +4 -0
  539. package/types/button.d.ts +37 -0
  540. package/types/calendar.d.ts +15 -0
  541. package/types/card.d.ts +26 -0
  542. package/types/carousel-item.d.ts +10 -0
  543. package/types/carousel.d.ts +57 -0
  544. package/types/cascader-panel.d.ts +72 -0
  545. package/types/cascader.d.ts +65 -0
  546. package/types/checkbox-button.d.ts +22 -0
  547. package/types/checkbox-group.d.ts +22 -0
  548. package/types/checkbox.d.ts +34 -0
  549. package/types/col.d.ts +46 -0
  550. package/types/collapse-item.d.ts +26 -0
  551. package/types/collapse.d.ts +10 -0
  552. package/types/color-picker.d.ts +28 -0
  553. package/types/component.d.ts +13 -0
  554. package/types/container.d.ts +7 -0
  555. package/types/date-picker.d.ts +124 -0
  556. package/types/descriptions-item.d.ts +37 -0
  557. package/types/descriptions.d.ts +52 -0
  558. package/types/dialog.d.ts +62 -0
  559. package/types/divider.d.ts +12 -0
  560. package/types/drawer.d.ts +63 -0
  561. package/types/dropdown-item.d.ts +16 -0
  562. package/types/dropdown-menu.d.ts +4 -0
  563. package/types/dropdown.d.ts +38 -0
  564. package/types/empty.d.ts +31 -0
  565. package/types/footer.d.ts +7 -0
  566. package/types/form-item.d.ts +40 -0
  567. package/types/form.d.ts +82 -0
  568. package/types/header.d.ts +7 -0
  569. package/types/icon.d.ts +7 -0
  570. package/types/image.d.ts +43 -0
  571. package/types/index.d.ts +4 -0
  572. package/types/infinite-scroll.d.ts +6 -0
  573. package/types/input-number.d.ts +47 -0
  574. package/types/input.d.ts +107 -0
  575. package/types/link.d.ts +25 -0
  576. package/types/loading.d.ts +62 -0
  577. package/types/main.d.ts +4 -0
  578. package/types/menu-item-group.d.ts +7 -0
  579. package/types/menu-item.d.ts +10 -0
  580. package/types/menu.d.ts +46 -0
  581. package/types/message-box.d.ts +176 -0
  582. package/types/message.d.ts +90 -0
  583. package/types/notification.d.ts +84 -0
  584. package/types/option-group.d.ts +10 -0
  585. package/types/option.d.ts +13 -0
  586. package/types/page-header.d.ts +10 -0
  587. package/types/pagination.d.ts +43 -0
  588. package/types/popconfirm.d.ts +29 -0
  589. package/types/popover.d.ts +71 -0
  590. package/types/progress.d.ts +37 -0
  591. package/types/radio-button.d.ts +16 -0
  592. package/types/radio-group.d.ts +18 -0
  593. package/types/radio.d.ts +19 -0
  594. package/types/rate.d.ts +64 -0
  595. package/types/result.d.ts +33 -0
  596. package/types/row.d.ts +25 -0
  597. package/types/rowinself-ui.d.ts +400 -0
  598. package/types/scrollbar.d.ts +12 -0
  599. package/types/select.d.ts +90 -0
  600. package/types/skeleton-item.d.ts +7 -0
  601. package/types/skeleton.d.ts +33 -0
  602. package/types/slider.d.ts +68 -0
  603. package/types/spinner.d.ts +16 -0
  604. package/types/statistic.d.ts +37 -0
  605. package/types/step.d.ts +34 -0
  606. package/types/steps.d.ts +28 -0
  607. package/types/submenu.d.ts +22 -0
  608. package/types/switch.d.ts +43 -0
  609. package/types/tab-pane.d.ts +19 -0
  610. package/types/table-column.d.ts +117 -0
  611. package/types/table.d.ts +177 -0
  612. package/types/tabs.d.ts +31 -0
  613. package/types/tag.d.ts +28 -0
  614. package/types/time-picker.d.ts +63 -0
  615. package/types/time-select.d.ts +56 -0
  616. package/types/timeline-item.d.ts +20 -0
  617. package/types/timeline.d.ts +6 -0
  618. package/types/tooltip.d.ts +52 -0
  619. package/types/transfer.d.ts +73 -0
  620. package/types/tree.d.ts +266 -0
  621. package/types/upload.d.ts +124 -0
  622. package/web-types.json +4195 -0
@@ -0,0 +1,264 @@
1
+ <script>
2
+ /* eslint-disable no-console */
3
+ /**
4
+ * 组件:ElBasicTableColumn
5
+ * 职责:将业务列配置映射为 ElementUI 的 `el-table-column` 并提供插槽渲染与默认溢出处理
6
+ * 说明:不使用函数式组件 以保证 inject 与组件树的兼容性
7
+ */
8
+ // 列渲染子组件:封装 el-table-column 属性映射与默认溢出处理(Hover 展示完整文本)
9
+ // 注意:不能使用函数式组件 否则在 npm 包环境中 inject 和组件树查找可能失效
10
+ import ElTableColumn from 'rowinself-ui/packages/table-column';
11
+ import OverflowCell from './overflow-cell.js';
12
+ import { getByPath } from './utils';
13
+
14
+ export default {
15
+ name: 'ElBasicTableColumn',
16
+ components: { ElTableColumn, OverflowCell },
17
+ inject: {
18
+ /**
19
+ * 从 ElBasicTable 注入获取插槽的函数 用于获取最新的 `$scopedSlots`。
20
+ * 使用函数可避免直接引用导致的响应性问题
21
+ * @returns {() => Object} 返回一个函数 执行后得到插槽对象
22
+ */
23
+ getBasicTableSlots: { default: () => () => ({}) }
24
+ },
25
+ props: {
26
+ /**
27
+ * 列配置对象(来自父组件 normalizedColumns)
28
+ * @type {Object}
29
+ */
30
+ column: { type: Object, required: true },
31
+ /** 全局溢出省略开关(列级未设置时生效) */
32
+ ellipsis: { type: Boolean, default: false }
33
+ },
34
+ computed: {
35
+ /**
36
+ * 列类型
37
+ * @returns {string}
38
+ */
39
+ colType() {
40
+ return this.column.type || 'default';
41
+ },
42
+ /**
43
+ * 列标题
44
+ * @returns {string}
45
+ */
46
+ colLabel() {
47
+ return this.column.title || this.column.label || '';
48
+ },
49
+ /**
50
+ * 列字段(dataIndex/prop/key/field)
51
+ * @returns {string}
52
+ */
53
+ colProp() {
54
+ return this.column.dataIndex || this.column.prop || this.column.key || this.column.field || '';
55
+ },
56
+ /**
57
+ * 插槽名(具名单元格插槽)
58
+ * @returns {string|null}
59
+ */
60
+ slotName() {
61
+ return this.column.slot || null;
62
+ },
63
+ /**
64
+ * 是否显示溢出提示(列级优先 其次使用全局 ellipsis)
65
+ * @returns {boolean}
66
+ */
67
+ showOverflowTooltip() {
68
+ const raw = this.column.showOverflowTooltip;
69
+ return raw != null ? raw : !!this.ellipsis;
70
+ },
71
+ /**
72
+ * 是否使用自定义 Popover 溢出处理(默认列、无插槽、开启溢出提示且存在字段)
73
+ * @returns {boolean}
74
+ */
75
+ usePopoverOverflow() {
76
+ return this.colType === 'default' && !this.slotName && !!this.showOverflowTooltip && !!this.colProp;
77
+ },
78
+ /**
79
+ * 透传给 el-table-column 的属性集合
80
+ * @returns {Object}
81
+ */
82
+ tableColumnProps() {
83
+ return {
84
+ type: this.colType,
85
+ label: this.colLabel,
86
+ prop: this.colProp,
87
+ width: this.column.width,
88
+ minWidth: this.column.minWidth,
89
+ align: this.column.align,
90
+ headerAlign: this.column.headerAlign,
91
+ fixed: this.column.fixed,
92
+ sortable: this.column.sortable || false,
93
+ index: this.column.index,
94
+ showOverflowTooltip: this.usePopoverOverflow ? false : this.showOverflowTooltip
95
+ };
96
+ },
97
+ /**
98
+ * 是否存在对应的具名插槽(例如:statusCell、roleCell 等)
99
+ * @returns {boolean}
100
+ */
101
+ hasNamedSlot() {
102
+ if (!this.slotName) return false;
103
+ const slots = this.getBasicTableSlots();
104
+ return slots && typeof slots[this.slotName] === 'function';
105
+ },
106
+ /** 是否为手动模拟的索引列 */
107
+ isIndexColumn() {
108
+ return this.column.key === '__index__';
109
+ }
110
+ },
111
+ methods: {
112
+ /**
113
+ * 构造传入插槽的列对象 补充 `field` 别名 兼容示例 `column.field` 写法
114
+ * @returns {Object}
115
+ */
116
+ buildSlotColumn() {
117
+ // 优先使用 dataIndex/prop
118
+ let field = this.colProp || (this.column && this.column.field) || '';
119
+ // 若未提供字段 且存在具名插槽 则尝试根据插槽名推导:去掉尾部 "Cell/cell"
120
+ if (!field && this.slotName) {
121
+ const name = String(this.slotName);
122
+ field = name.replace(/(Cell|cell)$/g, '');
123
+ }
124
+ return { ...(this.column || {}), field };
125
+ },
126
+ /**
127
+ * 渲染具名插槽内容
128
+ * @param {Object} scope ElementUI 提供的作用域对象
129
+ * @returns {VNode|null}
130
+ */
131
+ renderNamedSlot(scope) {
132
+ if (!this.slotName) return null; // 未声明具名插槽时直接返回
133
+ const slots = this.getBasicTableSlots();
134
+ const fn = slots && slots[this.slotName];
135
+ if (!fn) return null; // 未找到对应插槽函数
136
+ try {
137
+ // 传入 record/row 以及补充的 column.field
138
+ return fn({
139
+ row: scope.row,
140
+ record: scope.row,
141
+ column: this.buildSlotColumn(),
142
+ $index: scope.$index
143
+ });
144
+ } catch (err) {
145
+ // 插槽渲染异常仅记录日志 不中断表格渲染
146
+ console.error('[ElBasicTableColumn] renderNamedSlot error:', err);
147
+ return null;
148
+ }
149
+ },
150
+ /**
151
+ * 渲染通用 bodyCell 插槽
152
+ * @param {Object} scope ElementUI 提供的作用域对象
153
+ * @returns {VNode|null}
154
+ */
155
+ renderBodySlot(scope) {
156
+ const slots = this.getBasicTableSlots();
157
+ const fn = slots && slots.bodyCell;
158
+ if (typeof fn !== 'function') return null; // 未提供 bodyCell 插槽
159
+ try {
160
+ return fn({
161
+ row: scope.row,
162
+ record: scope.row,
163
+ column: this.buildSlotColumn(),
164
+ $index: scope.$index
165
+ });
166
+ } catch (err) {
167
+ console.error('[ElBasicTableColumn] renderBodySlot error:', err);
168
+ return null;
169
+ }
170
+ },
171
+ // 判断插槽输出是否为空内容(null/undefined/[]/仅注释或空文本)
172
+ isEmptyRender(vnode) {
173
+ if (vnode == null) return true;
174
+ if (Array.isArray(vnode)) {
175
+ if (!vnode.length) return true;
176
+ return vnode.every((n) => {
177
+ if (!n) return true;
178
+ // Vue2 注释节点:isComment === true;空文本:text === '' 且无 tag
179
+ return (n.isComment === true) || (n.text != null && String(n.text).trim() === '' && !n.tag);
180
+ });
181
+ }
182
+ return (vnode.isComment === true) || (vnode.text != null && String(vnode.text).trim() === '' && !vnode.tag);
183
+ },
184
+ // 默认文本渲染(作为 bodyCell 为空时的回退)
185
+ renderPlainTextCell(scope) {
186
+ const value = scope && scope.row ? getByPath(scope.row, this.colProp) : '';
187
+ const text = value == null ? '' : String(value);
188
+ return this.$createElement('span', text);
189
+ },
190
+ /**
191
+ * 渲染溢出单元格,使用 Popover 展示完整文本
192
+ * @param {Object} scope ElementUI 提供的作用域对象
193
+ * @returns {VNode}
194
+ */
195
+ renderOverflowCell(scope) {
196
+ const value = scope && scope.row ? getByPath(scope.row, this.colProp) : '';
197
+ const text = value == null ? '' : String(value);
198
+ return this.$createElement(OverflowCell, { props: { text } });
199
+ }
200
+ },
201
+ render (h) {
202
+ console.log("::: ",)
203
+ // 分组列:存在 children 时递归渲染子列 并以一个分组列包裹
204
+ const hasChildren = Array.isArray(this.column && this.column.children) && this.column.children.length > 0;
205
+ if (hasChildren) {
206
+ // 递归渲染子列组件 保持 ellipsis 透传
207
+ const childNodes = this.column.children.map((child) =>
208
+ h('ElBasicTableColumn', { props: { column: child, ellipsis: this.ellipsis } })
209
+ );
210
+ // 分组列基本属性(不传递子列专属属性)
211
+ const groupProps = {
212
+ type: 'default',
213
+ label: this.colLabel,
214
+ align: this.column.align,
215
+ headerAlign: this.column.headerAlign,
216
+ fixed: this.column.fixed
217
+ };
218
+ return h(ElTableColumn, { props: groupProps }, childNodes);
219
+ }
220
+
221
+ const scopedSlots = {};
222
+ // 非默认列类型(如 selection/index)不自定义单元格渲染 交由 Element 原生处理
223
+ const validTypes = ['selection', 'index', 'expand'];
224
+ // console.log("::: ",this.colType,validTypes.includes(this.colType))
225
+ if (validTypes.includes(this.colType)) {
226
+ // if (this.colType !== 'default') {
227
+ return h(ElTableColumn, { props: this.tableColumnProps, scopedSlots });
228
+ }
229
+ // 优先使用具名插槽 与示例保持一致
230
+ if (this.slotName && this.hasNamedSlot) {
231
+ scopedSlots.default = (scope) => this.renderNamedSlot(scope);
232
+ } else if (this.isIndexColumn) {
233
+ // 索引列手动渲染
234
+ scopedSlots.default = (scope) => {
235
+ const { index } = this.column;
236
+ let val = scope.$index + 1;
237
+ if (typeof index === 'function') {
238
+ val = index(scope.$index);
239
+ }
240
+ return this.$createElement('span', val);
241
+ };
242
+ } else {
243
+ // 未提供具名插槽时 尝试使用通用 bodyCell 插槽 否则回退到溢出渲染
244
+ const slots = this.getBasicTableSlots();
245
+ const hasBodyCell = slots && typeof slots.bodyCell === 'function';
246
+ if (hasBodyCell) {
247
+ scopedSlots.default = (scope) => {
248
+ const vnode = this.renderBodySlot(scope);
249
+ if (this.isEmptyRender(vnode)) {
250
+ return this.usePopoverOverflow ? this.renderOverflowCell(scope) : this.renderPlainTextCell(scope);
251
+ }
252
+ return vnode;
253
+ };
254
+ } else if (this.usePopoverOverflow) {
255
+ scopedSlots.default = (scope) => this.renderOverflowCell(scope);
256
+ } else {
257
+ scopedSlots.default = (scope) => this.renderPlainTextCell(scope);
258
+ }
259
+ }
260
+ // 返回最终的 table-column VNode 透传属性与 scopedSlots
261
+ return h(ElTableColumn, { props: this.tableColumnProps, scopedSlots });
262
+ }
263
+ };
264
+ </script>
@@ -0,0 +1,336 @@
1
+ <template>
2
+ <div class="el-basic-table">
3
+ <div v-if="useSearchForm" class="el-basic-table__form">
4
+ <el-basic-form
5
+ v-bind="formConfig || {}"
6
+ :table-action="tableActionContext"
7
+ @submit="onFormSubmit"
8
+ @register="onFormRegister"
9
+ />
10
+ </div>
11
+ <!-- v-if="title || titleHelpMessage" -->
12
+ <div class="el-basic-table__header">
13
+ <div class="el-basic-table__title">{{ title }}</div>
14
+ <div v-if="titleHelpMessage" class="el-basic-table__help">{{ titleHelpMessage }}</div>
15
+ <div class="el-basic-table__toolbar">
16
+ <slot name="toolbar"></slot>
17
+ </div>
18
+ </div>
19
+ <el-table
20
+ ref="tableRef"
21
+ v-loading="internalLoading"
22
+ :data="internalData"
23
+ :stripe="striped"
24
+ :border="bordered"
25
+ :max-height="maxHeight"
26
+ :size="size"
27
+ :row-key="rowKey"
28
+ :tree-props="treeProps"
29
+ :highlight-current-row="highlightCurrentRow"
30
+ :empty-text="emptyText"
31
+ :show-summary="showSummary"
32
+ :summary-method="summaryMethod"
33
+ :span-method="handleSpanMethod"
34
+ @selection-change="onSelectionChange"
35
+ @row-click="onRowClick"
36
+ >
37
+ <el-basic-table-column
38
+ v-for="(col, idx) in normalizedColumns"
39
+ :key="col.key || col.prop || idx"
40
+ :column="col"
41
+ :ellipsis="ellipsis"
42
+ />
43
+ <!-- <template v-if="$slots.append" slot="append">
44
+ <slot name="append"></slot>
45
+ </template>
46
+ <template v-if="$slots.empty" slot="empty">
47
+ <slot name="empty"></slot>
48
+ </template> -->
49
+ </el-table>
50
+ <div v-if="showPagination" class="el-basic-table__pagination">
51
+ <el-pagination
52
+ v-bind="internalPagination"
53
+ @current-change="handlePageChange"
54
+ @size-change="handlePageSizeChange"
55
+ />
56
+ </div>
57
+ </div>
58
+ </template>
59
+ <script>
60
+ // 依赖组件:基础表格、分页、搜索表单与列渲染子组件
61
+ // 文件职能:封装基础表格行为(列配置、分页、远程加载、选择行、搜索联动),暴露完整方法集供外部按需控制
62
+ // 说明:该文件聚合 UI 与对外 API,核心行为拆分到 mixins 保持清晰职责
63
+ import ElTable from 'rowinself-ui/packages/table';
64
+ import ElPagination from 'rowinself-ui/packages/pagination';
65
+ import ElBasicForm from 'rowinself-ui/packages/basic-form';
66
+ import ElBasicTableColumn from './basic-table-column.vue';
67
+ import actions from './actions';
68
+ import { mapColumns } from './utils';
69
+ import fetchMixin from './mixins/fetch';
70
+ import paginationMixin from './mixins/pagination';
71
+ import formMixin from './mixins/form';
72
+ import actionsContextMixin from './mixins/actions-context';
73
+ import watchersMixin from './mixins/watchers';
74
+
75
+ export default {
76
+ name: 'ElBasicTable',
77
+ components: { ElTable, ElPagination, ElBasicForm, ElBasicTableColumn },
78
+ mixins: [fetchMixin, paginationMixin, formMixin, actionsContextMixin, watchersMixin],
79
+ provide() {
80
+ return {
81
+ // 提供一个函数来获取最新的 $scopedSlots,保证响应性
82
+ getBasicTableSlots: () => this.$scopedSlots
83
+ };
84
+ },
85
+ props: {
86
+ // 标题与提示
87
+ /**
88
+ * 表格标题
89
+ * @type {String}
90
+ */
91
+ title: String,
92
+ /**
93
+ * 标题右侧提示文案
94
+ * @type {String}
95
+ */
96
+ titleHelpMessage: String,
97
+ // 列配置与数据
98
+ /**
99
+ * 列配置数组,映射到每个列的属性
100
+ * @type {Array<Object>}
101
+ */
102
+ columns: { type: Array, default: () => [] },
103
+ /**
104
+ * 本地数据源(与 api 互斥时以 api 为准)
105
+ * @type {Array<Object>}
106
+ */
107
+ dataSource: { type: Array, default: () => [] },
108
+ // 远程加载
109
+ /**
110
+ * 远程数据请求函数 (params) => Promise<{items,total}> | Array
111
+ * @type {Function}
112
+ */
113
+ api: Function,
114
+ // 外观与行为
115
+ /** 是否显示斑马纹 */
116
+ striped: Boolean,
117
+ /** 是否显示边框 */
118
+ bordered: Boolean,
119
+ /** 表格尺寸 (medium/small/mini) */
120
+ size: String,
121
+ /** 行主键,可为字段名或函数 */
122
+ rowKey: [String, Function],
123
+ /** 空数据文案 */
124
+ emptyText: String,
125
+ /** 高亮当前行 */
126
+ highlightCurrentRow: Boolean,
127
+ /** 是否显示合计 */
128
+ showSummary: Boolean,
129
+ /** 合计计算方法 */
130
+ summaryMethod: Function,
131
+ /** 合并单元格方法 */
132
+ spanMethod: Function,
133
+ /** 分页配置对象,或 false 不显示 */
134
+ pagination: Object,
135
+ /** 表格 loading 状态 */
136
+ loading: Boolean,
137
+ /** 文本溢出省略(全局) */
138
+ ellipsis: { type: Boolean, default: true },
139
+ /** 自动为数据补充 key */
140
+ autoCreateKey: { type: Boolean, default: true },
141
+ /** 点击行是否切换勾选 */
142
+ clickToRowSelect: { type: Boolean, default: false },
143
+ /** 翻页是否清空勾选 */
144
+ clearSelectOnPageChange: { type: Boolean, default: false },
145
+ // 搜索表单
146
+ /** 是否启用搜索表单 */
147
+ useSearchForm: { type: Boolean, default: false },
148
+ /** 搜索表单配置(透传给 ElBasicForm) */
149
+ formConfig: Object,
150
+ // 树形表格
151
+ /** 树形表格子项字段名与是否有子项标志 */
152
+ treeProps: {
153
+ type: Object,
154
+ default: () => ({
155
+ /** 子项字段名 */
156
+ children: 'children',
157
+ /** 是否有子项标志 */
158
+ hasChildren: 'hasChildren'
159
+ })
160
+ },
161
+ // 请求钩子与映射
162
+ /** 请求前对参数处理 */
163
+ beforeFetch: Function,
164
+ /** 请求后对返回值处理 */
165
+ afterFetch: Function,
166
+ /** 搜索条件处理钩子 */
167
+ handleSearchInfoFn: Function,
168
+ /** 字段映射:pageField/sizeField/listField/totalField */
169
+ fetchSetting: {
170
+ type: Object,
171
+ default: () => ({
172
+ /** 列表字段名 */
173
+ listField: 'list',
174
+ /** 总数字段名(支持点号路径如 page.totalRowNum) */
175
+ totalField: 'page.totalRowNum',
176
+ /** 当前页码字段名 */
177
+ pageField: 'page.perPage',
178
+ /** 每页条数字段名 */
179
+ sizeField: 'page.pageNum'
180
+ })
181
+ },
182
+ /** 是否在挂载后立即请求 */
183
+ immediate: { type: Boolean, default: true },
184
+ /** 外部传入的搜索条件(受控) */
185
+ searchInfo: Object,
186
+ // 特殊列控制
187
+ /** 是否显示索引列 */
188
+ showIndexColumn: { type: Boolean, default: true },
189
+ /** 索引列标题 */
190
+ indexColumnTitle: { type: String, default: '序号' },
191
+ /** 索引列属性(宽度/对齐/index 回调) */
192
+ indexColumnProps: { type: Object, default: () => ({}) },
193
+ // 尺寸与滚动
194
+ /** 最大高度,超出滚动 */
195
+ maxHeight: Number,
196
+ /** 选择列配置(true/对象) */
197
+ rowSelection: [Boolean, Object]
198
+ },
199
+ data() {
200
+ return {
201
+ // 内部数据状态
202
+ /** 当前渲染的数据源(应用了 ensureKeys) */
203
+ internalData: this.dataSource || [],
204
+ /** 当前 loading 状态 */
205
+ internalLoading: !!this.loading,
206
+ /** 当前列配置(内部副本) */
207
+ internalColumns: this.columns || [],
208
+ /** 当前分页配置(内部副本) */
209
+ internalPagination: this.normalizePagination(this.pagination),
210
+ /** 最后一次请求错误 */
211
+ lastFetchError: null,
212
+ /** 当前选中的行(表格事件同步) */
213
+ selectedRows: [],
214
+ /** 当前选中行的主键集合 */
215
+ selectedRowKeys: [],
216
+ /** 原始接口返回对象(最近一次) */
217
+ rawResult: null,
218
+ /** 是否显示分页(受控) */
219
+ showPaginationFlag: this.pagination !== false,
220
+ /** 表单动作对象(@register 注入) */
221
+ formActions: null,
222
+ /** 内部搜索条件,避免直接修改 prop */
223
+ internalSearchInfo: this.searchInfo || {}
224
+ };
225
+ },
226
+ computed: {
227
+ /**
228
+ * 组装最终用于渲染的列配置(前置特殊列 + 常规列)
229
+ * @returns {Array<Object>} 渲染列数组
230
+ */
231
+ normalizedColumns() {
232
+ // console.log('BasicTable indexColumnProps:', this.indexColumnProps);
233
+ return mapColumns({
234
+ columns: this.internalColumns,
235
+ ellipsis: this.ellipsis,
236
+ showIndexColumn: this.showIndexColumn,
237
+ indexColumnTitle: this.indexColumnTitle,
238
+ indexColumnProps: this.indexColumnProps,
239
+ rowSelection: this.rowSelection
240
+ });
241
+ }
242
+ // showPagination/tableActionContext 已拆分至 mixins,保持本组件只关注数据与渲染
243
+ },
244
+
245
+ mounted() {
246
+ this.$emit('register', this.tableActionContext);
247
+ if (this.immediate && typeof this.api === 'function') this.reload();
248
+ },
249
+
250
+ methods: {
251
+ ...actions,
252
+ /**
253
+ * 处理单元格合并
254
+ */
255
+ handleSpanMethod({ row, column, rowIndex, columnIndex }) {
256
+ // 获取当前列的配置信息
257
+ const prop = column.property;
258
+ const colConfig = prop ? this.normalizedColumns.find(c => c.prop === prop || c.field === prop) : null;
259
+
260
+ // 补充 column.field 字段,兼容用户在 spanMethod 中使用 column.field
261
+ if (colConfig && colConfig.field && !column.field) {
262
+ column.field = colConfig.field;
263
+ }
264
+
265
+ // 优先使用传入的 spanMethod
266
+ if (typeof this.spanMethod === 'function') {
267
+ return this.spanMethod({ row, column, rowIndex, columnIndex });
268
+ }
269
+
270
+ // 自动合并逻辑:检查列配置是否有 autoSpan
271
+ if (colConfig && colConfig.autoSpan) {
272
+ const data = this.internalData;
273
+ // 使用 getByPath 获取值,以支持嵌套字段
274
+ const getValue = (r, p) => {
275
+ if (!r || !p) return undefined;
276
+ // 简单属性直接获取,避免 getByPath 性能开销(如果 prop 不含点号)
277
+ if (p.indexOf('.') === -1) return r[p];
278
+ // 简单实现 getByPath,避免引入 utils 依赖(或者假设 prop 即为 key)
279
+ // 这里我们假设 data 中 key 与 prop 一致,或者使用 row[prop]
280
+ // Element UI 的 row[column.property] 通常能取到值
281
+ return r[p];
282
+ };
283
+
284
+ const currentValue = row[prop];
285
+ const prevRow = data[rowIndex - 1];
286
+
287
+ // 如果上一行值相同,则合并(当前隐藏)
288
+ if (prevRow && prevRow[prop] === currentValue) {
289
+ return { rowspan: 0, colspan: 0 };
290
+ }
291
+
292
+ // 否则计算向下合并行数
293
+ let rowspan = 1;
294
+ for (let i = rowIndex + 1; i < data.length; i++) {
295
+ if (data[i][prop] === currentValue) {
296
+ rowspan++;
297
+ } else {
298
+ break;
299
+ }
300
+ }
301
+ return { rowspan, colspan: 1 };
302
+ }
303
+ },
304
+ /**
305
+ * 运行时设置表格属性(列/数据/loading/分页/选中/索引列/标题/搜索条件等)
306
+ * @param {Object} nextProps 需更新的属性集合
307
+ */
308
+ setProps(nextProps) {
309
+ const propsToUpdate = nextProps || {};
310
+ if ('columns' in propsToUpdate) this.internalColumns = Array.isArray(propsToUpdate.columns) ? propsToUpdate.columns : [];
311
+ if ('dataSource' in propsToUpdate) this.internalData = Array.isArray(propsToUpdate.dataSource) ? propsToUpdate.dataSource : [];
312
+ if ('loading' in propsToUpdate) this.internalLoading = !!propsToUpdate.loading;
313
+ if ('pagination' in propsToUpdate) this.internalPagination = this.normalizePagination(propsToUpdate.pagination);
314
+ if ('rowSelection' in propsToUpdate) this.$emit('update:rowSelection', propsToUpdate.rowSelection);
315
+ if ('showIndexColumn' in propsToUpdate) this.$emit('update:showIndexColumn', !!propsToUpdate.showIndexColumn);
316
+ if ('searchInfo' in propsToUpdate) { this.internalSearchInfo = propsToUpdate.searchInfo || {}; this.$emit('update:searchInfo', propsToUpdate.searchInfo); }
317
+ if ('title' in propsToUpdate) this.$emit('update:title', propsToUpdate.title);
318
+ if ('indexColumnProps' in propsToUpdate) this.$emit('update:indexColumnProps', propsToUpdate.indexColumnProps);
319
+ if ('indexColumnTitle' in propsToUpdate) this.$emit('update:indexColumnTitle', propsToUpdate.indexColumnTitle);
320
+ },
321
+ setLoading(loading) { this.internalLoading = !!loading; },
322
+ setColumns(nextColumns) { this.internalColumns = Array.isArray(nextColumns) ? nextColumns : []; },
323
+ setDataSource(nextDataSource) { this.internalData = Array.isArray(nextDataSource) ? this.ensureKeys(nextDataSource) : []; },
324
+ /** 获取当前数据源副本 */
325
+ getDataSource() { return this.internalData.slice(); },
326
+ /** 获取原始接口返回 */
327
+ getRawDataSource() { return this.rawResult; },
328
+ /** 获取当前列配置副本 */
329
+ getColumns() { return (this.internalColumns || []).slice(); },
330
+ /** 设置数据源(别名) */
331
+ setTableData(values) { this.setDataSource(values); },
332
+ /** 合并设置分页信息 */
333
+ setPagination(info) { this.internalPagination = { ...this.internalPagination, ...(info || {}) }; }
334
+ }
335
+ };
336
+ </script>
@@ -0,0 +1,47 @@
1
+ /**
2
+ * 动作上下文混入(Actions Context Mixin)
3
+ * 职责:
4
+ * - 生成对外暴露的方法集合,供父级通过 @register 获取以进行外部控制
5
+ * 设计:
6
+ * - 仅聚合现有方法,不承担业务逻辑
7
+ */
8
+ export default {
9
+ computed: {
10
+ /**
11
+ * 对外动作上下文对象
12
+ * @returns {Object} 方法集合
13
+ */
14
+ tableActionContext() {
15
+ return {
16
+ setProps: this.setProps,
17
+ setLoading: this.setLoading,
18
+ reload: this.reload,
19
+ getDataSource: this.getDataSource,
20
+ clearSelection: this.clearSelection,
21
+ setColumns: this.setColumns,
22
+ setDataSource: this.setDataSource,
23
+ getRawDataSource: this.getRawDataSource,
24
+ getColumns: this.getColumns,
25
+ setTableData: this.setTableData,
26
+ setPagination: this.setPagination,
27
+ deleteSelectRowByKey: this.deleteSelectRowByKey,
28
+ getSelectRowKeys: this.getSelectRowKeys,
29
+ getSelectRows: this.getSelectRows,
30
+ clearSelectedRowKeys: this.clearSelectedRowKeys,
31
+ setSelectedRowKeys: this.setSelectedRowKeys,
32
+ getPaginationRef: this.getPaginationRef,
33
+ getShowPagination: this.getShowPagination,
34
+ setShowPagination: this.setShowPagination,
35
+ getRowSelection: this.getRowSelection,
36
+ updateTableData: this.updateTableData,
37
+ updateTableDataRecord: this.updateTableDataRecord,
38
+ deleteTableDataRecord: this.deleteTableDataRecord,
39
+ insertTableDataRecord: this.insertTableDataRecord,
40
+ getForm: this.getForm,
41
+ expandAll: this.expandAll,
42
+ collapseAll: this.collapseAll,
43
+ redoHeight: this.redoHeight
44
+ };
45
+ }
46
+ }
47
+ };