ele-admin-plus 1.2.1-beta.2 → 1.2.1-beta.4

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 (572) hide show
  1. package/es/core-components.d.ts +1 -0
  2. package/es/core-components.js +60 -58
  3. package/es/ele-admin-layout/components/layout-tabs.d.ts +1 -6
  4. package/es/ele-admin-layout/components/layout-tabs.js +18 -76
  5. package/es/ele-admin-layout/index.d.ts +26 -30
  6. package/es/ele-admin-layout/index.js +7 -2
  7. package/es/ele-admin-layout/props.d.ts +11 -10
  8. package/es/ele-admin-layout/types.d.ts +2 -0
  9. package/es/ele-alert/index.d.ts +14 -14
  10. package/es/ele-alert/props.d.ts +9 -8
  11. package/es/ele-app/components/message-body.d.ts +5 -4
  12. package/es/ele-app/components/message-box-icon.d.ts +7 -6
  13. package/es/ele-app/el.d.ts +3 -0
  14. package/es/ele-app/plus.d.ts +21 -0
  15. package/es/ele-app/style/overwrite/css-var.scss +0 -2
  16. package/es/ele-app/style/overwrite/index.js +0 -1
  17. package/es/ele-app/style/overwrite/index.scss +0 -1
  18. package/es/ele-app/style/overwrite/input/index.scss +2 -0
  19. package/es/ele-app/style/scrollbar/css-var.scss +17 -16
  20. package/es/ele-app/types.d.ts +8 -1
  21. package/es/ele-avatar-group/index.d.ts +15 -14
  22. package/es/ele-avatar-group/props.d.ts +10 -7
  23. package/es/ele-basic-select/index.d.ts +19 -16
  24. package/es/ele-basic-select/index.js +14 -7
  25. package/es/ele-basic-select/props.d.ts +11 -6
  26. package/es/ele-basic-select/props.js +3 -1
  27. package/es/ele-basic-select/util.d.ts +6 -0
  28. package/es/ele-basic-select/util.js +13 -0
  29. package/es/ele-bottom-bar/index.d.ts +13 -6
  30. package/es/ele-bottom-bar/index.js +37 -15
  31. package/es/ele-bottom-bar/props.d.ts +5 -2
  32. package/es/ele-bottom-bar/props.js +3 -1
  33. package/es/ele-bottom-bar/style/index.scss +5 -0
  34. package/es/ele-breadcrumb/index.d.ts +3 -3
  35. package/es/ele-breadcrumb/props.d.ts +1 -1
  36. package/es/ele-card/index.d.ts +14 -14
  37. package/es/ele-card/props.d.ts +8 -6
  38. package/es/ele-check-card/components/card-item.d.ts +3 -2
  39. package/es/ele-check-card/index.d.ts +6 -6
  40. package/es/ele-check-card/index.js +8 -3
  41. package/es/ele-check-card/props.d.ts +3 -2
  42. package/es/ele-config-provider/index.d.ts +4 -4
  43. package/es/ele-config-provider/props.d.ts +3 -3
  44. package/es/ele-config-provider/types.d.ts +1 -0
  45. package/es/ele-copyable/index.d.ts +10 -10
  46. package/es/ele-copyable/props.d.ts +7 -5
  47. package/es/ele-count-up/index.d.ts +1 -1
  48. package/es/ele-cropper/components/cropper-tools.d.ts +12 -5
  49. package/es/ele-cropper/components/cropper-tools.js +41 -13
  50. package/es/ele-cropper/index.d.ts +6 -4
  51. package/es/ele-cropper/index.js +2 -1
  52. package/es/ele-cropper/props.d.ts +5 -2
  53. package/es/ele-cropper/props.js +2 -0
  54. package/es/ele-cropper/style/index.scss +3 -2
  55. package/es/ele-cropper/types.d.ts +16 -0
  56. package/es/ele-cropper-modal/index.d.ts +7 -5
  57. package/es/ele-cropper-modal/index.js +2 -1
  58. package/es/ele-cropper-modal/props.d.ts +2 -4
  59. package/es/ele-data-table/components/table-columns.d.ts +32 -0
  60. package/es/ele-data-table/components/table-columns.js +114 -0
  61. package/es/ele-data-table/index.d.ts +223 -41
  62. package/es/ele-data-table/index.js +202 -120
  63. package/es/ele-data-table/props.d.ts +22 -26
  64. package/es/ele-data-table/style/index.scss +1 -1
  65. package/es/ele-data-table/types.d.ts +2 -0
  66. package/es/ele-data-table/util.d.ts +1 -45
  67. package/es/ele-data-table/util.js +2 -106
  68. package/es/ele-drawer/index.d.ts +22 -22
  69. package/es/ele-drawer/props.d.ts +13 -12
  70. package/es/ele-dropdown/components/pro-dropdown.d.ts +237 -0
  71. package/es/ele-dropdown/components/pro-dropdown.js +204 -0
  72. package/es/ele-dropdown/index.d.ts +534 -48
  73. package/es/ele-dropdown/index.js +110 -25
  74. package/es/ele-dropdown/props.d.ts +120 -25
  75. package/es/ele-dropdown/props.js +54 -7
  76. package/es/ele-dropdown/style/index.js +4 -1
  77. package/es/ele-dropdown/style/index.scss +174 -6
  78. package/es/ele-edit-tag/index.d.ts +22 -20
  79. package/es/ele-edit-tag/index.js +10 -2
  80. package/es/ele-edit-tag/props.d.ts +13 -8
  81. package/es/ele-edit-tag/props.js +3 -1
  82. package/es/ele-ellipsis/index.d.ts +5 -4
  83. package/es/ele-ellipsis/props.d.ts +1 -1
  84. package/es/ele-file-list/components/file-grid-item.d.ts +11 -20
  85. package/es/ele-file-list/components/file-grid-item.js +19 -58
  86. package/es/ele-file-list/components/file-grid.d.ts +15 -19
  87. package/es/ele-file-list/components/file-grid.js +16 -39
  88. package/es/ele-file-list/components/file-table-item.d.ts +11 -20
  89. package/es/ele-file-list/components/file-table-item.js +19 -58
  90. package/es/ele-file-list/components/file-table.d.ts +15 -19
  91. package/es/ele-file-list/components/file-table.js +17 -37
  92. package/es/ele-file-list/index.d.ts +37 -16
  93. package/es/ele-file-list/index.js +118 -20
  94. package/es/ele-file-list/props.d.ts +4 -5
  95. package/es/ele-file-list/props.js +5 -8
  96. package/es/ele-file-list/style/index.scss +10 -5
  97. package/es/ele-file-list/types.d.ts +13 -1
  98. package/es/ele-icon-select/components/icon-grid.d.ts +9 -7
  99. package/es/ele-icon-select/index.d.ts +39 -38
  100. package/es/ele-icon-select/index.js +6 -2
  101. package/es/ele-icon-select/props.d.ts +18 -14
  102. package/es/ele-icon-select/props.js +2 -0
  103. package/es/ele-image-viewer/index.d.ts +120 -0
  104. package/es/ele-image-viewer/index.js +88 -0
  105. package/es/ele-image-viewer/props.d.ts +58 -0
  106. package/es/ele-image-viewer/props.js +35 -0
  107. package/es/ele-image-viewer/style/css-var.scss +8 -0
  108. package/es/ele-image-viewer/style/index.js +2 -0
  109. package/es/ele-image-viewer/style/index.scss +117 -0
  110. package/es/ele-loading/index.d.ts +4 -4
  111. package/es/ele-loading/props.d.ts +3 -2
  112. package/es/ele-map-picker/components/map-view.d.ts +8 -10
  113. package/es/ele-map-picker/components/map-view.js +1 -0
  114. package/es/ele-map-picker/index.d.ts +10 -10
  115. package/es/ele-map-picker/props.d.ts +6 -5
  116. package/es/ele-map-picker/style/index.scss +1 -1
  117. package/es/ele-menus/components/item-title.d.ts +48 -0
  118. package/es/ele-menus/components/item-title.js +108 -0
  119. package/es/ele-menus/components/menu-items.d.ts +78 -0
  120. package/es/ele-menus/components/menu-items.js +269 -0
  121. package/es/ele-menus/index.d.ts +79 -20
  122. package/es/ele-menus/index.js +280 -210
  123. package/es/ele-menus/props.d.ts +3 -3
  124. package/es/ele-menus/style/index.scss +4 -0
  125. package/es/ele-menus/util.d.ts +1 -62
  126. package/es/ele-menus/util.js +3 -244
  127. package/es/ele-modal/index.d.ts +33 -32
  128. package/es/ele-modal/index.js +30 -64
  129. package/es/ele-modal/props.d.ts +16 -15
  130. package/es/ele-modal/util.d.ts +32 -25
  131. package/es/ele-modal/util.js +239 -132
  132. package/es/ele-pagination/index.d.ts +18 -6
  133. package/es/ele-pagination/index.js +3 -2
  134. package/es/ele-pagination/props.d.ts +8 -2
  135. package/es/ele-pagination/style/index.scss +70 -0
  136. package/es/ele-popconfirm/index.d.ts +43 -46
  137. package/es/ele-popconfirm/props.d.ts +22 -21
  138. package/es/ele-popover/index.d.ts +33 -36
  139. package/es/ele-popover/props.d.ts +11 -11
  140. package/es/ele-popover/props.js +1 -1
  141. package/es/ele-printer/index.d.ts +8 -8
  142. package/es/ele-printer/props.d.ts +6 -5
  143. package/es/ele-printer/util.d.ts +5 -5
  144. package/es/ele-printer/util.js +68 -43
  145. package/es/ele-pro-layout/components/pro-iframe.d.ts +6 -6
  146. package/es/ele-pro-layout/components/pro-iframe.js +6 -4
  147. package/es/ele-pro-layout/index.d.ts +44 -48
  148. package/es/ele-pro-layout/index.js +13 -4
  149. package/es/ele-pro-layout/props.d.ts +19 -17
  150. package/es/ele-pro-layout/props.js +3 -3
  151. package/es/ele-pro-layout/types.d.ts +9 -5
  152. package/es/ele-pro-layout/util.d.ts +6 -0
  153. package/es/ele-pro-layout/util.js +12 -0
  154. package/es/ele-pro-table/components/table-tools.d.ts +405 -35
  155. package/es/ele-pro-table/components/table-tools.js +225 -143
  156. package/es/ele-pro-table/components/tool-column-list.d.ts +12 -0
  157. package/es/ele-pro-table/components/tool-column-list.js +33 -6
  158. package/es/ele-pro-table/components/tool-column.d.ts +7 -6
  159. package/es/ele-pro-table/components/tool-column.js +15 -9
  160. package/es/ele-pro-table/components/tool-export.d.ts +30 -27
  161. package/es/ele-pro-table/components/tool-export.js +204 -184
  162. package/es/ele-pro-table/components/tool-print-body-cell.d.ts +5 -4
  163. package/es/ele-pro-table/components/tool-print-body-cell.js +1 -1
  164. package/es/ele-pro-table/components/tool-print-header-cell.d.ts +5 -4
  165. package/es/ele-pro-table/components/tool-print-header-cell.js +3 -2
  166. package/es/ele-pro-table/components/tool-print.d.ts +38 -37
  167. package/es/ele-pro-table/components/tool-print.js +357 -336
  168. package/es/ele-pro-table/index.d.ts +1015 -89
  169. package/es/ele-pro-table/index.js +60 -14
  170. package/es/ele-pro-table/props.d.ts +24 -27
  171. package/es/ele-pro-table/props.js +4 -2
  172. package/es/ele-pro-table/style/index.scss +43 -12
  173. package/es/ele-pro-table/types.d.ts +54 -0
  174. package/es/ele-pro-table/util.d.ts +51 -9
  175. package/es/ele-pro-table/util.js +89 -28
  176. package/es/ele-qr-code/components/canvas-render.d.ts +67 -0
  177. package/es/ele-qr-code/components/canvas-render.js +147 -0
  178. package/es/ele-qr-code/index.d.ts +5 -9
  179. package/es/ele-qr-code/index.js +33 -136
  180. package/es/ele-qr-code/props.d.ts +5 -2
  181. package/es/ele-qr-code/props.js +3 -1
  182. package/es/ele-qr-code/types.d.ts +5 -0
  183. package/es/ele-qr-code-svg/index.d.ts +6 -5
  184. package/es/ele-qr-code-svg/index.js +11 -14
  185. package/es/ele-segmented/index.d.ts +3 -1
  186. package/es/ele-segmented/index.js +30 -3
  187. package/es/ele-segmented/style/index.scss +7 -1
  188. package/es/ele-split-panel/index.d.ts +7 -7
  189. package/es/ele-split-panel/props.d.ts +4 -3
  190. package/es/ele-steps/index.d.ts +10 -10
  191. package/es/ele-steps/props.d.ts +5 -5
  192. package/es/ele-tab-tool/index.d.ts +6 -1
  193. package/es/ele-tab-tool/index.js +44 -3
  194. package/es/ele-tab-tool/props.d.ts +2 -0
  195. package/es/ele-tab-tool/props.js +3 -1
  196. package/es/ele-tab-wrap/components/tab-dropdown.js +9 -26
  197. package/es/ele-tab-wrap/index.js +21 -2
  198. package/es/ele-table/index.d.ts +2 -2
  199. package/es/ele-table/props.d.ts +2 -1
  200. package/es/ele-table/style/index.scss +1 -2
  201. package/es/ele-table-select/index.d.ts +24 -22
  202. package/es/ele-table-select/index.js +5 -2
  203. package/es/ele-table-select/props.d.ts +11 -7
  204. package/es/ele-table-select/props.js +2 -0
  205. package/es/ele-tabs/index.d.ts +39 -52
  206. package/es/ele-tabs/index.js +290 -118
  207. package/es/ele-tabs/props.d.ts +11 -30
  208. package/es/ele-tabs/props.js +4 -2
  209. package/es/ele-tabs/style/index.scss +186 -170
  210. package/es/ele-tabs/types.d.ts +25 -11
  211. package/es/ele-text/index.d.ts +2 -2
  212. package/es/ele-text/props.d.ts +2 -1
  213. package/es/ele-tool/index.d.ts +5 -2
  214. package/es/ele-tool/index.js +5 -3
  215. package/es/ele-tool/props.d.ts +4 -1
  216. package/es/ele-tool/props.js +3 -1
  217. package/es/ele-tool/style/index.scss +13 -0
  218. package/es/ele-toolbar/index.d.ts +18 -18
  219. package/es/ele-toolbar/props.d.ts +4 -3
  220. package/es/ele-tooltip/index.d.ts +27 -26
  221. package/es/ele-tooltip/props.d.ts +9 -8
  222. package/es/ele-tooltip/style/css-var.scss +4 -0
  223. package/es/ele-tour/index.d.ts +1 -1
  224. package/es/ele-tree-select/index.d.ts +19 -19
  225. package/es/ele-tree-select/index.js +5 -2
  226. package/es/ele-tree-select/props.d.ts +12 -8
  227. package/es/ele-tree-select/props.js +3 -1
  228. package/es/ele-upload-list/components/list-item.d.ts +31 -5
  229. package/es/ele-upload-list/components/list-item.js +146 -66
  230. package/es/ele-upload-list/index.d.ts +57 -30
  231. package/es/ele-upload-list/index.js +180 -97
  232. package/es/ele-upload-list/props.d.ts +24 -10
  233. package/es/ele-upload-list/props.js +20 -8
  234. package/es/ele-upload-list/style/css-var.scss +8 -0
  235. package/es/ele-upload-list/style/index.js +1 -1
  236. package/es/ele-upload-list/style/index.scss +426 -132
  237. package/es/ele-upload-list/types.d.ts +35 -11
  238. package/es/ele-virtual-table/components/body-cell.d.ts +13 -29
  239. package/es/ele-virtual-table/components/body-row.d.ts +13 -29
  240. package/es/ele-virtual-table/components/cell-checkbox.d.ts +3 -2
  241. package/es/ele-virtual-table/components/cell-filter.d.ts +6 -6
  242. package/es/ele-virtual-table/components/footer-row.d.ts +3 -3
  243. package/es/ele-virtual-table/components/header-cell.d.ts +8 -8
  244. package/es/ele-virtual-table/components/header-row.d.ts +8 -8
  245. package/es/ele-virtual-table/index.d.ts +27 -36
  246. package/es/ele-virtual-table/index.js +8 -6
  247. package/es/ele-virtual-table/props.d.ts +13 -15
  248. package/es/ele-watermark/index.d.ts +5 -4
  249. package/es/ele-watermark/props.d.ts +2 -1
  250. package/es/ele-xg-player/index.d.ts +3 -3
  251. package/es/icons/CornerLeftFilled.d.ts +2 -0
  252. package/es/icons/CornerLeftFilled.js +26 -0
  253. package/es/icons/CornerRightFilled.d.ts +2 -0
  254. package/es/icons/CornerRightFilled.js +26 -0
  255. package/es/icons/EyeOutlined.d.ts +2 -0
  256. package/es/icons/EyeOutlined.js +30 -0
  257. package/es/icons/FileOutlined.js +4 -4
  258. package/es/icons/SizeCompactOutlined.d.ts +2 -0
  259. package/es/icons/SizeCompactOutlined.js +34 -0
  260. package/es/icons/SizeMiddleOutlined.d.ts +2 -0
  261. package/es/icons/SizeMiddleOutlined.js +34 -0
  262. package/es/icons/SizeSlackOutlined.d.ts +2 -0
  263. package/es/icons/SizeSlackOutlined.js +34 -0
  264. package/es/icons/index.d.ts +6 -0
  265. package/es/icons/index.js +162 -150
  266. package/es/lang/en_US.js +5 -1
  267. package/es/lang/zh_CN.js +5 -1
  268. package/es/lang/zh_TW.js +5 -1
  269. package/es/style/plus.scss +1 -0
  270. package/es/style/themes/default.scss +92 -9
  271. package/es/style/themes/rounded.scss +9 -5
  272. package/es/style/themes/theme-util.scss +4 -0
  273. package/es/style/util.scss +10 -3
  274. package/es/utils/core.d.ts +4 -2
  275. package/es/utils/hook.d.ts +77 -4
  276. package/es/utils/hook.js +159 -6
  277. package/es/utils/menu-util.js +11 -5
  278. package/es/utils/message-box.js +5 -1
  279. package/es/utils/message.js +2 -2
  280. package/lib/core-components.cjs +60 -58
  281. package/lib/core-components.d.ts +1 -0
  282. package/lib/ele-admin-layout/components/layout-tabs.cjs +17 -75
  283. package/lib/ele-admin-layout/components/layout-tabs.d.ts +1 -6
  284. package/lib/ele-admin-layout/index.cjs +7 -2
  285. package/lib/ele-admin-layout/index.d.ts +26 -30
  286. package/lib/ele-admin-layout/props.d.ts +11 -10
  287. package/lib/ele-admin-layout/types.d.ts +2 -0
  288. package/lib/ele-alert/index.d.ts +14 -14
  289. package/lib/ele-alert/props.d.ts +9 -8
  290. package/lib/ele-app/components/message-body.d.ts +5 -4
  291. package/lib/ele-app/components/message-box-icon.d.ts +7 -6
  292. package/lib/ele-app/el.d.ts +3 -0
  293. package/lib/ele-app/plus.d.ts +21 -0
  294. package/lib/ele-app/style/overwrite/css-var.scss +0 -2
  295. package/lib/ele-app/style/overwrite/index.cjs +0 -1
  296. package/lib/ele-app/style/overwrite/index.scss +0 -1
  297. package/lib/ele-app/style/overwrite/input/index.scss +2 -0
  298. package/lib/ele-app/style/scrollbar/css-var.scss +17 -16
  299. package/lib/ele-app/types.d.ts +8 -1
  300. package/lib/ele-avatar-group/index.d.ts +15 -14
  301. package/lib/ele-avatar-group/props.d.ts +10 -7
  302. package/lib/ele-basic-select/index.cjs +14 -7
  303. package/lib/ele-basic-select/index.d.ts +19 -16
  304. package/lib/ele-basic-select/props.cjs +3 -1
  305. package/lib/ele-basic-select/props.d.ts +11 -6
  306. package/lib/ele-basic-select/util.cjs +13 -0
  307. package/lib/ele-basic-select/util.d.ts +6 -0
  308. package/lib/ele-bottom-bar/index.cjs +36 -14
  309. package/lib/ele-bottom-bar/index.d.ts +13 -6
  310. package/lib/ele-bottom-bar/props.cjs +3 -1
  311. package/lib/ele-bottom-bar/props.d.ts +5 -2
  312. package/lib/ele-bottom-bar/style/index.scss +5 -0
  313. package/lib/ele-breadcrumb/index.d.ts +3 -3
  314. package/lib/ele-breadcrumb/props.d.ts +1 -1
  315. package/lib/ele-card/index.d.ts +14 -14
  316. package/lib/ele-card/props.d.ts +8 -6
  317. package/lib/ele-check-card/components/card-item.d.ts +3 -2
  318. package/lib/ele-check-card/index.cjs +8 -3
  319. package/lib/ele-check-card/index.d.ts +6 -6
  320. package/lib/ele-check-card/props.d.ts +3 -2
  321. package/lib/ele-config-provider/index.d.ts +4 -4
  322. package/lib/ele-config-provider/props.d.ts +3 -3
  323. package/lib/ele-config-provider/types.d.ts +1 -0
  324. package/lib/ele-copyable/index.d.ts +10 -10
  325. package/lib/ele-copyable/props.d.ts +7 -5
  326. package/lib/ele-count-up/index.d.ts +1 -1
  327. package/lib/ele-cropper/components/cropper-tools.cjs +40 -12
  328. package/lib/ele-cropper/components/cropper-tools.d.ts +12 -5
  329. package/lib/ele-cropper/index.cjs +2 -1
  330. package/lib/ele-cropper/index.d.ts +6 -4
  331. package/lib/ele-cropper/props.cjs +2 -0
  332. package/lib/ele-cropper/props.d.ts +5 -2
  333. package/lib/ele-cropper/style/index.scss +3 -2
  334. package/lib/ele-cropper/types.d.ts +16 -0
  335. package/lib/ele-cropper-modal/index.cjs +2 -1
  336. package/lib/ele-cropper-modal/index.d.ts +7 -5
  337. package/lib/ele-cropper-modal/props.d.ts +2 -4
  338. package/lib/ele-data-table/components/table-columns.cjs +113 -0
  339. package/lib/ele-data-table/components/table-columns.d.ts +32 -0
  340. package/lib/ele-data-table/index.cjs +199 -117
  341. package/lib/ele-data-table/index.d.ts +223 -41
  342. package/lib/ele-data-table/props.d.ts +22 -26
  343. package/lib/ele-data-table/style/index.scss +1 -1
  344. package/lib/ele-data-table/types.d.ts +2 -0
  345. package/lib/ele-data-table/util.cjs +0 -104
  346. package/lib/ele-data-table/util.d.ts +1 -45
  347. package/lib/ele-drawer/index.d.ts +22 -22
  348. package/lib/ele-drawer/props.d.ts +13 -12
  349. package/lib/ele-dropdown/components/pro-dropdown.cjs +203 -0
  350. package/lib/ele-dropdown/components/pro-dropdown.d.ts +237 -0
  351. package/lib/ele-dropdown/index.cjs +113 -28
  352. package/lib/ele-dropdown/index.d.ts +534 -48
  353. package/lib/ele-dropdown/props.cjs +53 -6
  354. package/lib/ele-dropdown/props.d.ts +120 -25
  355. package/lib/ele-dropdown/style/index.cjs +4 -1
  356. package/lib/ele-dropdown/style/index.scss +174 -6
  357. package/lib/ele-edit-tag/index.cjs +10 -2
  358. package/lib/ele-edit-tag/index.d.ts +22 -20
  359. package/lib/ele-edit-tag/props.cjs +3 -1
  360. package/lib/ele-edit-tag/props.d.ts +13 -8
  361. package/lib/ele-ellipsis/index.d.ts +5 -4
  362. package/lib/ele-ellipsis/props.d.ts +1 -1
  363. package/lib/ele-file-list/components/file-grid-item.cjs +18 -57
  364. package/lib/ele-file-list/components/file-grid-item.d.ts +11 -20
  365. package/lib/ele-file-list/components/file-grid.cjs +15 -38
  366. package/lib/ele-file-list/components/file-grid.d.ts +15 -19
  367. package/lib/ele-file-list/components/file-table-item.cjs +18 -57
  368. package/lib/ele-file-list/components/file-table-item.d.ts +11 -20
  369. package/lib/ele-file-list/components/file-table.cjs +16 -36
  370. package/lib/ele-file-list/components/file-table.d.ts +15 -19
  371. package/lib/ele-file-list/index.cjs +117 -19
  372. package/lib/ele-file-list/index.d.ts +37 -16
  373. package/lib/ele-file-list/props.cjs +4 -7
  374. package/lib/ele-file-list/props.d.ts +4 -5
  375. package/lib/ele-file-list/style/index.scss +10 -5
  376. package/lib/ele-file-list/types.d.ts +13 -1
  377. package/lib/ele-icon-select/components/icon-grid.d.ts +9 -7
  378. package/lib/ele-icon-select/index.cjs +9 -5
  379. package/lib/ele-icon-select/index.d.ts +39 -38
  380. package/lib/ele-icon-select/props.cjs +2 -0
  381. package/lib/ele-icon-select/props.d.ts +18 -14
  382. package/lib/ele-image-viewer/index.cjs +87 -0
  383. package/lib/ele-image-viewer/index.d.ts +120 -0
  384. package/lib/ele-image-viewer/props.cjs +35 -0
  385. package/lib/ele-image-viewer/props.d.ts +58 -0
  386. package/lib/ele-image-viewer/style/css-var.scss +8 -0
  387. package/lib/ele-image-viewer/style/index.cjs +3 -0
  388. package/lib/ele-image-viewer/style/index.scss +117 -0
  389. package/lib/ele-loading/index.d.ts +4 -4
  390. package/lib/ele-loading/props.d.ts +3 -2
  391. package/lib/ele-map-picker/components/map-view.cjs +1 -0
  392. package/lib/ele-map-picker/components/map-view.d.ts +8 -10
  393. package/lib/ele-map-picker/index.d.ts +10 -10
  394. package/lib/ele-map-picker/props.d.ts +6 -5
  395. package/lib/ele-map-picker/style/index.scss +1 -1
  396. package/lib/ele-menus/components/item-title.cjs +107 -0
  397. package/lib/ele-menus/components/item-title.d.ts +48 -0
  398. package/lib/ele-menus/components/menu-items.cjs +268 -0
  399. package/lib/ele-menus/components/menu-items.d.ts +78 -0
  400. package/lib/ele-menus/index.cjs +278 -208
  401. package/lib/ele-menus/index.d.ts +79 -20
  402. package/lib/ele-menus/props.d.ts +3 -3
  403. package/lib/ele-menus/style/index.scss +4 -0
  404. package/lib/ele-menus/util.cjs +1 -242
  405. package/lib/ele-menus/util.d.ts +1 -62
  406. package/lib/ele-modal/index.cjs +28 -62
  407. package/lib/ele-modal/index.d.ts +33 -32
  408. package/lib/ele-modal/props.d.ts +16 -15
  409. package/lib/ele-modal/util.cjs +239 -132
  410. package/lib/ele-modal/util.d.ts +32 -25
  411. package/lib/ele-pagination/index.cjs +3 -2
  412. package/lib/ele-pagination/index.d.ts +18 -6
  413. package/lib/ele-pagination/props.d.ts +8 -2
  414. package/lib/ele-pagination/style/index.scss +70 -0
  415. package/lib/ele-popconfirm/index.d.ts +43 -46
  416. package/lib/ele-popconfirm/props.d.ts +22 -21
  417. package/lib/ele-popover/index.d.ts +33 -36
  418. package/lib/ele-popover/props.cjs +1 -1
  419. package/lib/ele-popover/props.d.ts +11 -11
  420. package/lib/ele-printer/index.d.ts +8 -8
  421. package/lib/ele-printer/props.d.ts +6 -5
  422. package/lib/ele-printer/util.cjs +68 -43
  423. package/lib/ele-printer/util.d.ts +5 -5
  424. package/lib/ele-pro-layout/components/pro-iframe.cjs +6 -4
  425. package/lib/ele-pro-layout/components/pro-iframe.d.ts +6 -6
  426. package/lib/ele-pro-layout/index.cjs +13 -4
  427. package/lib/ele-pro-layout/index.d.ts +44 -48
  428. package/lib/ele-pro-layout/props.cjs +3 -3
  429. package/lib/ele-pro-layout/props.d.ts +19 -17
  430. package/lib/ele-pro-layout/types.d.ts +9 -5
  431. package/lib/ele-pro-layout/util.cjs +12 -0
  432. package/lib/ele-pro-layout/util.d.ts +6 -0
  433. package/lib/ele-pro-table/components/table-tools.cjs +223 -141
  434. package/lib/ele-pro-table/components/table-tools.d.ts +405 -35
  435. package/lib/ele-pro-table/components/tool-column-list.cjs +32 -5
  436. package/lib/ele-pro-table/components/tool-column-list.d.ts +12 -0
  437. package/lib/ele-pro-table/components/tool-column.cjs +14 -8
  438. package/lib/ele-pro-table/components/tool-column.d.ts +7 -6
  439. package/lib/ele-pro-table/components/tool-export.cjs +201 -181
  440. package/lib/ele-pro-table/components/tool-export.d.ts +30 -27
  441. package/lib/ele-pro-table/components/tool-print-body-cell.cjs +1 -1
  442. package/lib/ele-pro-table/components/tool-print-body-cell.d.ts +5 -4
  443. package/lib/ele-pro-table/components/tool-print-header-cell.cjs +3 -2
  444. package/lib/ele-pro-table/components/tool-print-header-cell.d.ts +5 -4
  445. package/lib/ele-pro-table/components/tool-print.cjs +354 -333
  446. package/lib/ele-pro-table/components/tool-print.d.ts +38 -37
  447. package/lib/ele-pro-table/index.cjs +59 -13
  448. package/lib/ele-pro-table/index.d.ts +1015 -89
  449. package/lib/ele-pro-table/props.cjs +4 -2
  450. package/lib/ele-pro-table/props.d.ts +24 -27
  451. package/lib/ele-pro-table/style/index.scss +43 -12
  452. package/lib/ele-pro-table/types.d.ts +54 -0
  453. package/lib/ele-pro-table/util.cjs +89 -28
  454. package/lib/ele-pro-table/util.d.ts +51 -9
  455. package/lib/ele-qr-code/components/canvas-render.cjs +146 -0
  456. package/lib/ele-qr-code/components/canvas-render.d.ts +67 -0
  457. package/lib/ele-qr-code/index.cjs +32 -135
  458. package/lib/ele-qr-code/index.d.ts +5 -9
  459. package/lib/ele-qr-code/props.cjs +3 -1
  460. package/lib/ele-qr-code/props.d.ts +5 -2
  461. package/lib/ele-qr-code/types.d.ts +5 -0
  462. package/lib/ele-qr-code-svg/index.cjs +10 -13
  463. package/lib/ele-qr-code-svg/index.d.ts +6 -5
  464. package/lib/ele-segmented/index.cjs +29 -2
  465. package/lib/ele-segmented/index.d.ts +3 -1
  466. package/lib/ele-segmented/style/index.scss +7 -1
  467. package/lib/ele-split-panel/index.d.ts +7 -7
  468. package/lib/ele-split-panel/props.d.ts +4 -3
  469. package/lib/ele-steps/index.d.ts +10 -10
  470. package/lib/ele-steps/props.d.ts +5 -5
  471. package/lib/ele-tab-tool/index.cjs +43 -2
  472. package/lib/ele-tab-tool/index.d.ts +6 -1
  473. package/lib/ele-tab-tool/props.cjs +3 -1
  474. package/lib/ele-tab-tool/props.d.ts +2 -0
  475. package/lib/ele-tab-wrap/components/tab-dropdown.cjs +8 -25
  476. package/lib/ele-tab-wrap/index.cjs +20 -1
  477. package/lib/ele-table/index.d.ts +2 -2
  478. package/lib/ele-table/props.d.ts +2 -1
  479. package/lib/ele-table/style/index.scss +1 -2
  480. package/lib/ele-table-select/index.cjs +20 -17
  481. package/lib/ele-table-select/index.d.ts +24 -22
  482. package/lib/ele-table-select/props.cjs +2 -0
  483. package/lib/ele-table-select/props.d.ts +11 -7
  484. package/lib/ele-tabs/index.cjs +288 -116
  485. package/lib/ele-tabs/index.d.ts +39 -52
  486. package/lib/ele-tabs/props.cjs +4 -2
  487. package/lib/ele-tabs/props.d.ts +11 -30
  488. package/lib/ele-tabs/style/index.scss +186 -170
  489. package/lib/ele-tabs/types.d.ts +25 -11
  490. package/lib/ele-text/index.d.ts +2 -2
  491. package/lib/ele-text/props.d.ts +2 -1
  492. package/lib/ele-tool/index.cjs +5 -3
  493. package/lib/ele-tool/index.d.ts +5 -2
  494. package/lib/ele-tool/props.cjs +3 -1
  495. package/lib/ele-tool/props.d.ts +4 -1
  496. package/lib/ele-tool/style/index.scss +13 -0
  497. package/lib/ele-toolbar/index.d.ts +18 -18
  498. package/lib/ele-toolbar/props.d.ts +4 -3
  499. package/lib/ele-tooltip/index.d.ts +27 -26
  500. package/lib/ele-tooltip/props.d.ts +9 -8
  501. package/lib/ele-tooltip/style/css-var.scss +4 -0
  502. package/lib/ele-tour/index.d.ts +1 -1
  503. package/lib/ele-tree-select/index.cjs +4 -1
  504. package/lib/ele-tree-select/index.d.ts +19 -19
  505. package/lib/ele-tree-select/props.cjs +3 -1
  506. package/lib/ele-tree-select/props.d.ts +12 -8
  507. package/lib/ele-upload-list/components/list-item.cjs +144 -64
  508. package/lib/ele-upload-list/components/list-item.d.ts +31 -5
  509. package/lib/ele-upload-list/index.cjs +178 -95
  510. package/lib/ele-upload-list/index.d.ts +57 -30
  511. package/lib/ele-upload-list/props.cjs +20 -8
  512. package/lib/ele-upload-list/props.d.ts +24 -10
  513. package/lib/ele-upload-list/style/css-var.scss +8 -0
  514. package/lib/ele-upload-list/style/index.cjs +1 -1
  515. package/lib/ele-upload-list/style/index.scss +426 -132
  516. package/lib/ele-upload-list/types.d.ts +35 -11
  517. package/lib/ele-virtual-table/components/body-cell.d.ts +13 -29
  518. package/lib/ele-virtual-table/components/body-row.d.ts +13 -29
  519. package/lib/ele-virtual-table/components/cell-checkbox.d.ts +3 -2
  520. package/lib/ele-virtual-table/components/cell-filter.d.ts +6 -6
  521. package/lib/ele-virtual-table/components/footer-row.d.ts +3 -3
  522. package/lib/ele-virtual-table/components/header-cell.d.ts +8 -8
  523. package/lib/ele-virtual-table/components/header-row.d.ts +8 -8
  524. package/lib/ele-virtual-table/index.cjs +7 -5
  525. package/lib/ele-virtual-table/index.d.ts +27 -36
  526. package/lib/ele-virtual-table/props.d.ts +13 -15
  527. package/lib/ele-watermark/index.d.ts +5 -4
  528. package/lib/ele-watermark/props.d.ts +2 -1
  529. package/lib/ele-xg-player/index.d.ts +3 -3
  530. package/lib/icons/CornerLeftFilled.cjs +25 -0
  531. package/lib/icons/CornerLeftFilled.d.ts +2 -0
  532. package/lib/icons/CornerRightFilled.cjs +25 -0
  533. package/lib/icons/CornerRightFilled.d.ts +2 -0
  534. package/lib/icons/EyeOutlined.cjs +29 -0
  535. package/lib/icons/EyeOutlined.d.ts +2 -0
  536. package/lib/icons/FileOutlined.cjs +4 -4
  537. package/lib/icons/SizeCompactOutlined.cjs +33 -0
  538. package/lib/icons/SizeCompactOutlined.d.ts +2 -0
  539. package/lib/icons/SizeMiddleOutlined.cjs +33 -0
  540. package/lib/icons/SizeMiddleOutlined.d.ts +2 -0
  541. package/lib/icons/SizeSlackOutlined.cjs +33 -0
  542. package/lib/icons/SizeSlackOutlined.d.ts +2 -0
  543. package/lib/icons/index.cjs +12 -0
  544. package/lib/icons/index.d.ts +6 -0
  545. package/lib/lang/en_US.cjs +5 -1
  546. package/lib/lang/zh_CN.cjs +5 -1
  547. package/lib/lang/zh_TW.cjs +5 -1
  548. package/lib/style/plus.scss +1 -0
  549. package/lib/style/themes/default.scss +92 -9
  550. package/lib/style/themes/rounded.scss +9 -5
  551. package/lib/style/themes/theme-util.scss +4 -0
  552. package/lib/style/util.scss +10 -3
  553. package/lib/utils/core.d.ts +4 -2
  554. package/lib/utils/hook.cjs +158 -5
  555. package/lib/utils/hook.d.ts +77 -4
  556. package/lib/utils/menu-util.cjs +9 -3
  557. package/lib/utils/message-box.cjs +4 -0
  558. package/lib/utils/message.cjs +1 -1
  559. package/package.json +38 -37
  560. package/typings/global.d.ts +1 -0
  561. package/es/ele-app/style/overwrite/image-viewer/css-var.scss +0 -8
  562. package/es/ele-app/style/overwrite/image-viewer/index.js +0 -1
  563. package/es/ele-app/style/overwrite/image-viewer/index.scss +0 -10
  564. package/es/ele-tabs/components/tab-title.d.ts +0 -52
  565. package/es/ele-tabs/components/tab-title.js +0 -115
  566. package/lib/ele-app/style/overwrite/image-viewer/css-var.scss +0 -8
  567. package/lib/ele-app/style/overwrite/image-viewer/index.cjs +0 -2
  568. package/lib/ele-app/style/overwrite/image-viewer/index.scss +0 -10
  569. package/lib/ele-tabs/components/tab-title.cjs +0 -114
  570. package/lib/ele-tabs/components/tab-title.d.ts +0 -52
  571. /package/es/{ele-app/style/overwrite/image-viewer → ele-image-viewer/style}/index.d.ts +0 -0
  572. /package/lib/{ele-app/style/overwrite/image-viewer → ele-image-viewer/style}/index.d.ts +0 -0
@@ -1,184 +1,478 @@
1
1
  @use '../../style/themes/default.scss' as *;
2
2
  @use '../../style/util.scss' as *;
3
+ @use './css-var.scss' as *;
4
+
5
+ @include set-upload-list-var($ele);
3
6
 
4
7
  .ele-upload-list {
5
- font-size: 0;
6
- max-width: 100%;
8
+ display: flex;
9
+ flex-wrap: wrap;
10
+ align-items: flex-start;
11
+ gap: eleVar('upload-list', 'gap');
7
12
  box-sizing: border-box;
13
+ max-width: 100%;
14
+ $inner-radius: calc(#{eleVar('upload-list', 'radius')} - 1px);
8
15
 
9
16
  .ele-upload-item {
10
- width: 100px;
11
- height: 100px;
17
+ flex-shrink: 0;
18
+ width: eleVar('upload-list', 'width');
19
+ height: eleVar('upload-list', 'height');
20
+ padding: eleVar('upload-list', 'padding');
21
+ border-radius: eleVar('upload-list', 'radius');
22
+ border: eleVar('upload-list', 'border');
23
+ box-sizing: border-box;
24
+ position: relative;
25
+ user-select: none;
26
+ overflow: hidden;
12
27
  max-width: 100%;
13
- font-size: 14px;
14
- display: inline-block;
15
- margin: 0 12px 12px 0;
16
- background: elVar('fill-color', 'light');
17
- border: 1px dashed elVar('border-color');
18
- border-radius: elVar('border-radius', 'base');
28
+ cursor: pointer;
29
+ }
30
+
31
+ /* 缩略图片 */
32
+ .ele-upload-image {
33
+ width: 100%;
34
+ height: 100%;
35
+ display: block;
36
+ pointer-events: none;
37
+ }
38
+
39
+ /* 缩略图标 */
40
+ .ele-upload-thumbnail {
41
+ height: 100%;
42
+ display: flex;
43
+ flex-direction: column;
44
+ align-items: center;
45
+ justify-content: center;
46
+ gap: eleVar('upload-list', 'thumbnail-gap');
47
+ color: eleVar('upload-list', 'thumbnail-color');
48
+ font-size: eleVar('upload-list', 'thumbnail-font-size');
49
+ text-align: center;
50
+ }
51
+
52
+ .ele-upload-thumbnail-icon {
53
+ flex-shrink: 0;
54
+ color: eleVar('upload-list', 'thumbnail-icon-color');
55
+ font-size: eleVar('upload-list', 'thumbnail-icon-font-size');
56
+ }
57
+
58
+ .ele-upload-thumbnail-text {
59
+ width: 100%;
60
+ overflow: hidden;
61
+ line-height: 1.15;
62
+ word-break: break-all;
63
+ display: -webkit-box;
64
+ line-clamp: 3;
65
+ -webkit-line-clamp: 3;
66
+ -webkit-box-orient: vertical;
67
+ }
68
+
69
+ /* 操作按钮 */
70
+ .ele-upload-tools {
71
+ display: flex;
72
+ align-items: center;
73
+ justify-content: center;
74
+ border-bottom-left-radius: $inner-radius;
75
+ border-bottom-right-radius: $inner-radius;
76
+ background: eleVar('upload-list', 'tool-bg');
77
+ position: absolute;
78
+ left: 0;
79
+ right: 0;
80
+ bottom: -20px;
81
+ transition: all $transition-base;
82
+ box-sizing: border-box;
83
+ overflow: hidden;
84
+ opacity: 0;
85
+ z-index: 3;
86
+ }
87
+
88
+ .ele-upload-tool {
89
+ flex: 1;
90
+ display: flex;
91
+ align-items: center;
92
+ justify-content: center;
93
+ line-height: 1;
94
+ color: eleVar('upload-list', 'tool-color');
95
+ font-size: eleVar('upload-list', 'tool-font-size');
96
+ padding: eleVar('upload-list', 'tool-padding');
97
+ transition: all $transition-base;
19
98
  box-sizing: border-box;
20
- vertical-align: top;
21
99
  position: relative;
22
- overflow: visible;
23
100
  cursor: pointer;
24
101
 
25
- &.ele-draggable {
26
- cursor: move;
27
- }
28
-
29
- .ele-upload-remove {
30
- width: 18px;
31
- height: 18px;
32
- color: #fff;
33
- font-size: 12px;
34
- border-bottom-left-radius: 18px;
35
- border-top-right-radius: elVar('border-radius', 'base');
36
- background: rgba(0, 0, 0, 0.6);
37
- position: absolute;
38
- top: 0;
39
- right: 0;
40
- line-height: 1;
41
- padding: 2px 0 0 4px;
42
- box-sizing: border-box;
43
- transition: background-color 0.2s ease-in-out;
44
- cursor: pointer;
45
- z-index: 2;
46
-
47
- &:hover {
48
- background: elVar('color-danger');
49
- }
102
+ &:hover {
103
+ background: eleVar('upload-list', 'tool-hover-bg');
50
104
  }
51
105
 
52
- & > .el-image {
53
- width: 100%;
54
- height: 100%;
55
- display: block;
56
- border-radius: elVar('border-radius', 'base');
106
+ & + .ele-upload-tool {
107
+ margin-left: eleVar('upload-list', 'tool-gap');
108
+
109
+ &::before {
110
+ content: '';
111
+ width: 0px;
112
+ height: 56%;
113
+ border-left: 1px solid eleVar('upload-list', 'tool-color');
114
+ box-sizing: border-box;
115
+ position: absolute;
116
+ top: 0;
117
+ bottom: 0;
118
+ left: -0.5px;
119
+ margin: auto 0;
120
+ opacity: 0.6;
121
+ }
57
122
  }
123
+ }
58
124
 
59
- .ele-upload-thumbnail {
60
- height: 100%;
61
- display: flex;
62
- flex-direction: column;
63
- align-items: center;
64
- justify-content: center;
65
- color: elVar('text-color', 'secondary');
66
- text-align: center;
67
- font-size: 22px;
125
+ .ele-upload-item:hover .ele-upload-tools {
126
+ bottom: 0;
127
+ opacity: 1;
128
+ }
68
129
 
69
- & > .el-icon {
70
- color: elVar('text-color', 'placeholder');
71
- }
130
+ .ele-upload-tool-text {
131
+ margin-left: 2px;
132
+ }
133
+
134
+ /* 删除按钮 */
135
+ .ele-upload-remove {
136
+ flex: none;
137
+ padding: 0;
138
+ width: eleVar('upload-list', 'del-size');
139
+ height: eleVar('upload-list', 'del-size');
140
+ color: eleVar('upload-list', 'tool-color');
141
+ font-size: eleVar('upload-list', 'tool-font-size');
142
+ background: eleVar('upload-list', 'tool-bg');
143
+ box-shadow: eleVar('upload-list', 'del-shadow');
144
+ border-top-right-radius: $inner-radius;
145
+ border-bottom-left-radius: 100%;
146
+ position: absolute;
147
+ top: 0;
148
+ right: 0;
149
+ line-height: 1;
150
+ transition: all $transition-base;
151
+ box-sizing: border-box;
152
+ cursor: pointer;
153
+ z-index: 4;
154
+
155
+ & > i {
156
+ margin: eleVar('upload-list', 'del-icon-margin');
72
157
  }
73
158
 
74
- .ele-upload-progress {
75
- position: absolute;
76
- top: 0;
77
- left: 0;
78
- right: 0;
79
- bottom: 0;
80
- background: rgba(0, 0, 0, 0.3);
81
- border-radius: elVar('border-radius', 'base');
82
- z-index: 1;
159
+ &:hover {
160
+ background: eleVar('upload-list', 'del-hover-bg');
83
161
  }
162
+ }
84
163
 
85
- .ele-upload-progress {
86
- color: #fff;
87
- display: flex;
88
- flex-direction: column;
89
- justify-content: center;
90
- background: rgba(0, 0, 0, 0.68);
91
- box-sizing: border-box;
92
- padding: 0 6px;
93
- line-height: 1;
94
-
95
- .ele-upload-text {
96
- margin-bottom: 8px;
97
- text-align: center;
98
- }
164
+ /* 进度条 */
165
+ .ele-upload-progress {
166
+ display: flex;
167
+ flex-direction: column;
168
+ justify-content: center;
169
+ color: eleVar('upload-list', 'progress-color');
170
+ font-size: eleVar('upload-list', 'progress-font-size');
171
+ padding: eleVar('upload-list', 'progress-padding');
172
+ background: eleVar('upload-list', 'progress-bg');
173
+ line-height: 1;
174
+ position: absolute;
175
+ top: eleVar('upload-list', 'padding');
176
+ left: eleVar('upload-list', 'padding');
177
+ right: eleVar('upload-list', 'padding');
178
+ bottom: eleVar('upload-list', 'padding');
179
+ box-sizing: border-box;
99
180
 
100
- .ele-upload-tools {
101
- display: flex;
102
- flex-wrap: wrap;
103
- justify-content: center;
104
- }
181
+ .el-progress-bar__outer {
182
+ background: hsla(0, 0%, 80%, 0.48);
183
+ }
184
+ }
105
185
 
106
- .ele-upload-retry {
107
- flex-shrink: 0;
108
- font-size: 16px;
109
- margin: 8px 3px 0 3px;
110
- display: flex;
111
- align-items: center;
112
- justify-content: center;
113
- cursor: pointer;
114
- }
186
+ .ele-upload-text {
187
+ flex-shrink: 0;
188
+ margin-bottom: 8px;
189
+ text-align: center;
190
+ }
191
+
192
+ /* 重试按钮 */
193
+ .ele-upload-retry {
194
+ flex: none;
195
+ width: max-content;
196
+ margin: 6px auto 0 auto;
197
+ display: flex;
198
+ align-items: center;
199
+ justify-content: center;
200
+ gap: eleVar('upload-list', 'progress-tool-gap');
201
+ font-size: eleVar('upload-list', 'progress-tool-font-size');
202
+ border-radius: eleVar('upload-list', 'progress-tool-radius');
203
+ padding: eleVar('upload-list', 'progress-tool-padding');
204
+ background: eleVar('upload-list', 'progress-tool-bg');
205
+ transition: all $transition-base;
206
+ box-sizing: border-box;
207
+ position: relative;
208
+ cursor: pointer;
209
+ z-index: 3;
210
+
211
+ &:hover {
212
+ background: eleVar('upload-list', 'progress-tool-hover-bg');
115
213
  }
116
214
 
117
- &.sortable-ghost {
118
- opacity: 0;
215
+ .ele-upload-tool-text {
216
+ margin: 0;
119
217
  }
120
218
  }
121
219
 
220
+ /* 上传按钮 */
122
221
  .ele-upload-button {
222
+ padding: 0;
123
223
  text-align: center;
124
- transition: border-color 0.2s ease-in-out;
224
+ border: eleVar('upload-list', 'btn-border');
225
+ background: eleVar('upload-list', 'btn-bg');
226
+ transition: all $transition-base;
227
+ overflow: visible;
125
228
  cursor: pointer;
126
229
 
127
230
  &:hover {
128
- border-color: elVar('color-primary');
231
+ border: eleVar('upload-list', 'btn-hover-border');
129
232
  }
130
233
 
131
234
  & > div {
132
235
  height: 100%;
133
236
  display: block;
237
+ }
134
238
 
135
- & > .el-upload {
136
- height: 100%;
137
- display: flex;
138
- cursor: inherit;
139
-
140
- & > .el-upload-dragger {
141
- width: 100%;
142
- height: 100%;
143
- display: flex;
144
- align-items: center;
145
- justify-content: center;
146
- border-radius: elVar('border-radius', 'base');
147
- background: none;
148
- cursor: inherit;
149
- border: none;
150
- padding: 0;
151
-
152
- &.is-dragover {
153
- outline: 1px dashed elVar('color-primary');
154
- background: elVar('color-primary', 'light-9');
155
- }
156
- }
157
- }
239
+ .el-upload {
240
+ height: 100%;
241
+ display: flex;
242
+ cursor: inherit;
243
+ }
158
244
 
159
- & > .el-upload-list {
160
- display: none;
245
+ .el-upload-dragger {
246
+ width: 100%;
247
+ height: 100%;
248
+ display: flex;
249
+ align-items: center;
250
+ justify-content: center;
251
+ border-radius: eleVar('upload-list', 'radius');
252
+ transition: all $transition-base;
253
+ outline: 1px dashed transparent;
254
+ background: none;
255
+ cursor: inherit;
256
+ border: none;
257
+ padding: 0;
258
+
259
+ &.is-dragover {
260
+ outline: eleVar('upload-list', 'btn-hover-border');
261
+ background: eleVar('upload-list', 'btn-drag-bg');
161
262
  }
162
263
  }
264
+ }
163
265
 
164
- .ele-upload-icon {
165
- font-size: 22px;
166
- color: elVar('text-color', 'secondary');
167
- opacity: 0.68;
266
+ .ele-upload-button-inner {
267
+ width: 100%;
268
+ height: 100%;
269
+ display: flex;
270
+ align-items: center;
271
+ justify-content: center;
272
+ box-sizing: border-box;
273
+ }
168
274
 
169
- & > svg {
170
- stroke-width: 3.8;
171
- }
275
+ .ele-upload-icon {
276
+ color: eleVar('upload-list', 'btn-color');
277
+ font-size: eleVar('upload-list', 'btn-font-size');
278
+
279
+ & > svg {
280
+ stroke-width: 3;
172
281
  }
173
282
  }
174
283
 
175
- &.is-disabled .ele-upload-button {
176
- background: elVar('disabled', 'bg-color');
177
- border-color: elVar('disabled', 'border-color');
284
+ /* 修改时的文件选择输入框 */
285
+ .ele-upload-input {
286
+ display: none;
287
+ }
288
+
289
+ /* 拖动手柄 */
290
+ .ele-upload-handle {
291
+ cursor: move;
292
+ position: absolute;
293
+ top: 0;
294
+ left: 0;
295
+ right: 0;
296
+ bottom: 0;
297
+ z-index: 2;
298
+ }
299
+ }
300
+
301
+ /* 禁用状态 */
302
+ .ele-upload-list.is-disabled {
303
+ .ele-upload-button {
304
+ background: eleVar('upload-list', 'btn-disabled-bg');
305
+ border: eleVar('upload-list', 'btn-disabled-border');
178
306
  cursor: not-allowed;
307
+ }
308
+
309
+ .ele-upload-icon {
310
+ color: eleVar('upload-list', 'btn-disabled-color');
311
+ }
312
+ }
313
+
314
+ /* 拖动状态 */
315
+ .ele-upload-item {
316
+ &.sortable-chosen {
317
+ background: eleVar('upload-list', 'bg');
318
+ }
319
+
320
+ &.sortable-ghost {
321
+ opacity: 0;
322
+ }
323
+
324
+ &.sortable-fallback {
325
+ opacity: 1 !important;
326
+ }
327
+ }
328
+
329
+ .ele-upload-list:has(.ele-upload-item.sortable-ghost) {
330
+ .ele-upload-tools {
331
+ display: none;
332
+ }
333
+
334
+ .ele-upload-button {
335
+ pointer-events: none;
336
+ }
337
+ }
338
+
339
+ /* 列表文件样式 */
340
+ .ele-upload-list.is-file-list {
341
+ width: 100%;
342
+
343
+ .ele-upload-item {
344
+ width: 100%;
345
+ height: eleVar('upload-list', 'file-height');
346
+ padding: 0 eleVar('upload-list', 'file-padding');
347
+ display: flex;
348
+ align-items: center;
349
+ }
350
+
351
+ /* 缩略图标 */
352
+ .ele-upload-thumbnail {
353
+ flex: 1;
354
+ flex-direction: row;
355
+ justify-content: flex-start;
356
+ font-size: eleVar('upload-list', 'file-thumbnail-font-size');
357
+ overflow: hidden;
358
+ text-align: left;
359
+ }
360
+
361
+ .ele-upload-thumbnail-icon {
362
+ color: eleVar('upload-list', 'file-thumbnail-icon-color');
363
+ font-size: eleVar('upload-list', 'file-thumbnail-icon-font-size');
364
+ }
365
+
366
+ .ele-upload-thumbnail-text {
367
+ flex: 1;
368
+ display: block;
369
+ white-space: nowrap;
370
+ text-overflow: ellipsis;
371
+ }
372
+
373
+ /* 操作按钮 */
374
+ .ele-upload-tools {
375
+ background: none;
376
+ position: relative;
377
+ left: auto;
378
+ right: auto;
379
+ bottom: auto;
380
+ opacity: 1;
381
+ }
382
+
383
+ .ele-upload-item:not(:hover) .ele-upload-tools {
384
+ display: none;
385
+ }
386
+
387
+ .ele-upload-tool,
388
+ .ele-upload-remove,
389
+ .ele-upload-retry {
390
+ display: flex;
391
+ align-items: center;
392
+ justify-content: center;
393
+ padding: 0;
394
+ margin: 0 0 0 eleVar('upload-list', 'file-tool-gap');
395
+ width: eleVar('upload-list', 'file-tool-size');
396
+ height: eleVar('upload-list', 'file-tool-size');
397
+ border-radius: eleVar('upload-list', 'file-tool-radius');
398
+ color: eleVar('upload-list', 'file-tool-color');
399
+ box-shadow: none;
400
+ background: none;
401
+
402
+ &:hover {
403
+ color: eleVar('upload-list', 'file-tool-hover-color');
404
+ background: eleVar('upload-list', 'file-tool-hover-bg');
405
+ }
406
+ }
407
+
408
+ .ele-upload-tool::before {
409
+ display: none;
410
+ }
411
+
412
+ .ele-upload-tool-text {
413
+ display: none;
414
+ }
415
+
416
+ /* 删除按钮 */
417
+ .ele-upload-remove {
418
+ position: relative;
419
+ top: auto;
420
+ right: auto;
421
+ margin: eleVar('upload-list', 'file-del-margin');
422
+
423
+ & > i {
424
+ margin: 0;
425
+ }
426
+
427
+ &:hover {
428
+ color: eleVar('upload-list', 'file-del-hover-color');
429
+ }
430
+ }
179
431
 
180
- .ele-upload-icon {
181
- color: elVar('disabled', 'text-color');
432
+ /* 进度条 */
433
+ .ele-upload-progress {
434
+ position: static;
435
+ flex-direction: row;
436
+ background: none;
437
+ padding: 0;
438
+
439
+ .el-progress-bar__outer {
440
+ background: transparent;
182
441
  }
183
442
  }
443
+
444
+ .ele-upload-progress-bar {
445
+ position: absolute;
446
+ left: eleVar('upload-list', 'file-padding');
447
+ right: eleVar('upload-list', 'file-padding');
448
+ bottom: 0;
449
+ }
450
+
451
+ .ele-upload-text {
452
+ display: none;
453
+ }
454
+
455
+ /* 上传按钮 */
456
+ .ele-upload-button {
457
+ padding: 0;
458
+ display: block;
459
+ }
460
+
461
+ .ele-upload-icon {
462
+ font-size: eleVar('upload-list', 'file-btn-font-size');
463
+ }
464
+ }
465
+
466
+ /* 触摸设备始终显示操作按钮 */
467
+ @media (pointer: coarse) {
468
+ .ele-upload-list .ele-upload-item .ele-upload-tools {
469
+ bottom: 0;
470
+ opacity: 1;
471
+ }
472
+
473
+ .ele-upload-list.is-file-list .ele-upload-item .ele-upload-tools,
474
+ .ele-upload-list.is-file-list .ele-upload-item:not(:hover) .ele-upload-tools {
475
+ bottom: auto;
476
+ display: flex;
477
+ }
184
478
  }
@@ -24,17 +24,38 @@ export interface UploadItem extends Record<keyof any, any> {
24
24
  export type UploadStatus = 'uploading' | 'done' | 'exception' | null;
25
25
 
26
26
  /**
27
- * 图片预览配置
28
- */
29
- export interface PreviewOption {
30
- /** 是否打开 */
31
- visible: boolean;
32
- /** 当前图片链接 */
33
- current?: string;
34
- /** 当前图片索引 */
35
- currentIndex: number;
36
- /** 图片列表 */
37
- images: string[];
27
+ * 列表样式
28
+ */
29
+ export type ListType = 'image' | 'file' | null;
30
+
31
+ /**
32
+ * 上传按钮点击前的钩子
33
+ */
34
+ export type BeforeUploadClick = (e: MouseEvent) => boolean | undefined | void;
35
+
36
+ /**
37
+ * 修改按钮点击前的钩子
38
+ */
39
+ export type BeforeItemEdit = (item: UploadItem) => boolean | undefined | void;
40
+
41
+ /**
42
+ * 图片文件预读地址
43
+ */
44
+ export interface ImageObjectUrl {
45
+ /** 文件 */
46
+ file: File;
47
+ /** 预览地址 */
48
+ url: string;
49
+ }
50
+
51
+ /**
52
+ * 修改事件参数
53
+ */
54
+ export interface EditUploadResult {
55
+ /** 修改的数据项 */
56
+ item: UploadItem;
57
+ /** 新的数据项 */
58
+ newItem: UploadItem;
38
59
  }
39
60
 
40
61
  /**
@@ -44,4 +65,7 @@ export interface UploadLocale {
44
65
  uploading: string;
45
66
  exception: string;
46
67
  retry: string;
68
+ remove: string;
69
+ preview: string;
70
+ edit: string;
47
71
  }