bi-eleme 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 (989) hide show
  1. package/CHANGELOG.en-US.md +2010 -0
  2. package/CHANGELOG.es.md +2018 -0
  3. package/CHANGELOG.fr-FR.md +2010 -0
  4. package/CHANGELOG.zh-CN.md +2010 -0
  5. package/LICENSE +21 -0
  6. package/README.md +146 -0
  7. package/lib/alert.js +420 -0
  8. package/lib/aside.js +277 -0
  9. package/lib/autocomplete.js +952 -0
  10. package/lib/avatar.js +363 -0
  11. package/lib/backtop.js +404 -0
  12. package/lib/badge.js +334 -0
  13. package/lib/breadcrumb-item.js +322 -0
  14. package/lib/breadcrumb.js +293 -0
  15. package/lib/button-group.js +262 -0
  16. package/lib/button.js +365 -0
  17. package/lib/calendar.js +933 -0
  18. package/lib/card.js +297 -0
  19. package/lib/carousel-item.js +434 -0
  20. package/lib/carousel.js +707 -0
  21. package/lib/cascader-panel.js +1558 -0
  22. package/lib/cascader.js +1439 -0
  23. package/lib/checkbox-button.js +583 -0
  24. package/lib/checkbox-group.js +313 -0
  25. package/lib/checkbox.js +627 -0
  26. package/lib/col.js +177 -0
  27. package/lib/collapse-item.js +497 -0
  28. package/lib/collapse.js +329 -0
  29. package/lib/color-picker.js +1943 -0
  30. package/lib/container.js +288 -0
  31. package/lib/date-picker.js +6330 -0
  32. package/lib/descriptions-item.js +140 -0
  33. package/lib/descriptions.js +457 -0
  34. package/lib/dialog.js +610 -0
  35. package/lib/directives/mousewheel.js +26 -0
  36. package/lib/directives/repeat-click.js +30 -0
  37. package/lib/divider.js +313 -0
  38. package/lib/drawer.js +592 -0
  39. package/lib/dropdown-item.js +316 -0
  40. package/lib/dropdown-menu.js +351 -0
  41. package/lib/dropdown.js +643 -0
  42. package/lib/element-ui.common.js +43250 -0
  43. package/lib/empty.js +730 -0
  44. package/lib/footer.js +277 -0
  45. package/lib/form-item.js +826 -0
  46. package/lib/form.js +466 -0
  47. package/lib/header.js +277 -0
  48. package/lib/icon.js +265 -0
  49. package/lib/image.js +1131 -0
  50. package/lib/index.js +1 -0
  51. package/lib/infinite-scroll.js +301 -0
  52. package/lib/input-number.js +741 -0
  53. package/lib/input.js +998 -0
  54. package/lib/link.js +332 -0
  55. package/lib/loading.js +631 -0
  56. package/lib/locale/format.js +56 -0
  57. package/lib/locale/index.js +63 -0
  58. package/lib/locale/lang/af-ZA.js +126 -0
  59. package/lib/locale/lang/ar.js +125 -0
  60. package/lib/locale/lang/az.js +126 -0
  61. package/lib/locale/lang/bg.js +126 -0
  62. package/lib/locale/lang/bn.js +126 -0
  63. package/lib/locale/lang/ca.js +125 -0
  64. package/lib/locale/lang/cs-CZ.js +128 -0
  65. package/lib/locale/lang/da.js +125 -0
  66. package/lib/locale/lang/de.js +127 -0
  67. package/lib/locale/lang/ee.js +126 -0
  68. package/lib/locale/lang/el.js +126 -0
  69. package/lib/locale/lang/en.js +126 -0
  70. package/lib/locale/lang/eo.js +126 -0
  71. package/lib/locale/lang/es.js +125 -0
  72. package/lib/locale/lang/eu.js +126 -0
  73. package/lib/locale/lang/fa.js +126 -0
  74. package/lib/locale/lang/fi.js +126 -0
  75. package/lib/locale/lang/fr.js +125 -0
  76. package/lib/locale/lang/he.js +126 -0
  77. package/lib/locale/lang/hr.js +126 -0
  78. package/lib/locale/lang/hu.js +125 -0
  79. package/lib/locale/lang/hy-AM.js +126 -0
  80. package/lib/locale/lang/id.js +126 -0
  81. package/lib/locale/lang/is.js +126 -0
  82. package/lib/locale/lang/it.js +125 -0
  83. package/lib/locale/lang/ja.js +126 -0
  84. package/lib/locale/lang/kg.js +126 -0
  85. package/lib/locale/lang/km.js +126 -0
  86. package/lib/locale/lang/ko.js +126 -0
  87. package/lib/locale/lang/ku.js +126 -0
  88. package/lib/locale/lang/kz.js +126 -0
  89. package/lib/locale/lang/lt.js +126 -0
  90. package/lib/locale/lang/lv.js +126 -0
  91. package/lib/locale/lang/mn.js +126 -0
  92. package/lib/locale/lang/ms.js +126 -0
  93. package/lib/locale/lang/nb-NO.js +125 -0
  94. package/lib/locale/lang/nl.js +126 -0
  95. package/lib/locale/lang/pl.js +126 -0
  96. package/lib/locale/lang/pt-br.js +126 -0
  97. package/lib/locale/lang/pt.js +126 -0
  98. package/lib/locale/lang/ro.js +126 -0
  99. package/lib/locale/lang/ru-RU.js +126 -0
  100. package/lib/locale/lang/si.js +126 -0
  101. package/lib/locale/lang/sk.js +128 -0
  102. package/lib/locale/lang/sl.js +126 -0
  103. package/lib/locale/lang/sr.js +126 -0
  104. package/lib/locale/lang/sv-SE.js +126 -0
  105. package/lib/locale/lang/sw.js +126 -0
  106. package/lib/locale/lang/ta.js +125 -0
  107. package/lib/locale/lang/th.js +126 -0
  108. package/lib/locale/lang/tk.js +126 -0
  109. package/lib/locale/lang/tr-TR.js +126 -0
  110. package/lib/locale/lang/ua.js +126 -0
  111. package/lib/locale/lang/ug-CN.js +126 -0
  112. package/lib/locale/lang/uz-UZ.js +126 -0
  113. package/lib/locale/lang/vi.js +126 -0
  114. package/lib/locale/lang/zh-CN.js +126 -0
  115. package/lib/locale/lang/zh-TW.js +126 -0
  116. package/lib/main.js +264 -0
  117. package/lib/menu-item-group.js +308 -0
  118. package/lib/menu-item.js +491 -0
  119. package/lib/menu.js +865 -0
  120. package/lib/message-box.js +1192 -0
  121. package/lib/message.js +548 -0
  122. package/lib/mixins/emitter.js +36 -0
  123. package/lib/mixins/focus.js +15 -0
  124. package/lib/mixins/locale.js +17 -0
  125. package/lib/mixins/migrating.js +69 -0
  126. package/lib/notification.js +615 -0
  127. package/lib/option-group.js +344 -0
  128. package/lib/option.js +474 -0
  129. package/lib/page-header.js +319 -0
  130. package/lib/pagination.js +950 -0
  131. package/lib/popconfirm.js +457 -0
  132. package/lib/popover.js +617 -0
  133. package/lib/progress.js +578 -0
  134. package/lib/radio-button.js +463 -0
  135. package/lib/radio-group.js +391 -0
  136. package/lib/radio.js +497 -0
  137. package/lib/rate.js +670 -0
  138. package/lib/result.js +578 -0
  139. package/lib/row.js +149 -0
  140. package/lib/scrollbar.js +423 -0
  141. package/lib/select.js +2167 -0
  142. package/lib/skeleton-item.js +342 -0
  143. package/lib/skeleton.js +372 -0
  144. package/lib/slider.js +1199 -0
  145. package/lib/spinner.js +301 -0
  146. package/lib/step.js +522 -0
  147. package/lib/steps.js +342 -0
  148. package/lib/submenu.js +701 -0
  149. package/lib/switch.js +554 -0
  150. package/lib/tab-pane.js +332 -0
  151. package/lib/table-column.js +933 -0
  152. package/lib/table.js +5015 -0
  153. package/lib/tabs.js +920 -0
  154. package/lib/tag.js +301 -0
  155. package/lib/theme-chalk/alert.css +1 -0
  156. package/lib/theme-chalk/aside.css +1 -0
  157. package/lib/theme-chalk/autocomplete.css +1 -0
  158. package/lib/theme-chalk/avatar.css +1 -0
  159. package/lib/theme-chalk/backtop.css +1 -0
  160. package/lib/theme-chalk/badge.css +1 -0
  161. package/lib/theme-chalk/base.css +1 -0
  162. package/lib/theme-chalk/breadcrumb-item.css +0 -0
  163. package/lib/theme-chalk/breadcrumb.css +1 -0
  164. package/lib/theme-chalk/button-group.css +0 -0
  165. package/lib/theme-chalk/button.css +1 -0
  166. package/lib/theme-chalk/calendar.css +1 -0
  167. package/lib/theme-chalk/card.css +1 -0
  168. package/lib/theme-chalk/carousel-item.css +1 -0
  169. package/lib/theme-chalk/carousel.css +1 -0
  170. package/lib/theme-chalk/cascader-panel.css +1 -0
  171. package/lib/theme-chalk/cascader.css +1 -0
  172. package/lib/theme-chalk/checkbox-button.css +0 -0
  173. package/lib/theme-chalk/checkbox-group.css +0 -0
  174. package/lib/theme-chalk/checkbox.css +1 -0
  175. package/lib/theme-chalk/col.css +1 -0
  176. package/lib/theme-chalk/collapse-item.css +0 -0
  177. package/lib/theme-chalk/collapse.css +1 -0
  178. package/lib/theme-chalk/color-picker.css +1 -0
  179. package/lib/theme-chalk/container.css +1 -0
  180. package/lib/theme-chalk/date-picker.css +1 -0
  181. package/lib/theme-chalk/descriptions-item.css +1 -0
  182. package/lib/theme-chalk/descriptions.css +1 -0
  183. package/lib/theme-chalk/dialog.css +1 -0
  184. package/lib/theme-chalk/display.css +1 -0
  185. package/lib/theme-chalk/divider.css +1 -0
  186. package/lib/theme-chalk/drawer.css +1 -0
  187. package/lib/theme-chalk/dropdown-item.css +0 -0
  188. package/lib/theme-chalk/dropdown-menu.css +0 -0
  189. package/lib/theme-chalk/dropdown.css +1 -0
  190. package/lib/theme-chalk/empty.css +1 -0
  191. package/lib/theme-chalk/fonts/element-icons.ttf +0 -0
  192. package/lib/theme-chalk/fonts/element-icons.woff +0 -0
  193. package/lib/theme-chalk/footer.css +1 -0
  194. package/lib/theme-chalk/form-item.css +0 -0
  195. package/lib/theme-chalk/form.css +1 -0
  196. package/lib/theme-chalk/header.css +1 -0
  197. package/lib/theme-chalk/icon.css +1 -0
  198. package/lib/theme-chalk/image.css +1 -0
  199. package/lib/theme-chalk/index.css +1 -0
  200. package/lib/theme-chalk/infinite-scroll.css +0 -0
  201. package/lib/theme-chalk/infiniteScroll.css +0 -0
  202. package/lib/theme-chalk/input-number.css +1 -0
  203. package/lib/theme-chalk/input.css +1 -0
  204. package/lib/theme-chalk/link.css +1 -0
  205. package/lib/theme-chalk/loading.css +1 -0
  206. package/lib/theme-chalk/main.css +1 -0
  207. package/lib/theme-chalk/menu-item-group.css +0 -0
  208. package/lib/theme-chalk/menu-item.css +0 -0
  209. package/lib/theme-chalk/menu.css +1 -0
  210. package/lib/theme-chalk/message-box.css +1 -0
  211. package/lib/theme-chalk/message.css +1 -0
  212. package/lib/theme-chalk/notification.css +1 -0
  213. package/lib/theme-chalk/option-group.css +1 -0
  214. package/lib/theme-chalk/option.css +1 -0
  215. package/lib/theme-chalk/page-header.css +1 -0
  216. package/lib/theme-chalk/pagination.css +1 -0
  217. package/lib/theme-chalk/popconfirm.css +1 -0
  218. package/lib/theme-chalk/popover.css +1 -0
  219. package/lib/theme-chalk/popper.css +1 -0
  220. package/lib/theme-chalk/progress.css +1 -0
  221. package/lib/theme-chalk/radio-button.css +1 -0
  222. package/lib/theme-chalk/radio-group.css +1 -0
  223. package/lib/theme-chalk/radio.css +1 -0
  224. package/lib/theme-chalk/rate.css +1 -0
  225. package/lib/theme-chalk/reset.css +1 -0
  226. package/lib/theme-chalk/result.css +1 -0
  227. package/lib/theme-chalk/row.css +1 -0
  228. package/lib/theme-chalk/scrollbar.css +1 -0
  229. package/lib/theme-chalk/select-dropdown.css +1 -0
  230. package/lib/theme-chalk/select.css +1 -0
  231. package/lib/theme-chalk/skeleton-item.css +1 -0
  232. package/lib/theme-chalk/skeleton.css +1 -0
  233. package/lib/theme-chalk/slider.css +1 -0
  234. package/lib/theme-chalk/spinner.css +1 -0
  235. package/lib/theme-chalk/step.css +1 -0
  236. package/lib/theme-chalk/steps.css +1 -0
  237. package/lib/theme-chalk/submenu.css +0 -0
  238. package/lib/theme-chalk/switch.css +1 -0
  239. package/lib/theme-chalk/tab-pane.css +0 -0
  240. package/lib/theme-chalk/table-column.css +1 -0
  241. package/lib/theme-chalk/table.css +1 -0
  242. package/lib/theme-chalk/tabs.css +1 -0
  243. package/lib/theme-chalk/tag.css +1 -0
  244. package/lib/theme-chalk/time-picker.css +1 -0
  245. package/lib/theme-chalk/time-select.css +1 -0
  246. package/lib/theme-chalk/timeline-item.css +1 -0
  247. package/lib/theme-chalk/timeline.css +1 -0
  248. package/lib/theme-chalk/tooltip.css +1 -0
  249. package/lib/theme-chalk/transfer.css +1 -0
  250. package/lib/theme-chalk/tree.css +1 -0
  251. package/lib/theme-chalk/upload.css +1 -0
  252. package/lib/time-picker.js +2956 -0
  253. package/lib/time-select.js +1765 -0
  254. package/lib/timeline-item.js +371 -0
  255. package/lib/timeline.js +275 -0
  256. package/lib/tooltip.js +425 -0
  257. package/lib/transfer.js +1102 -0
  258. package/lib/transitions/collapse-transition.js +91 -0
  259. package/lib/tree.js +2263 -0
  260. package/lib/umd/locale/af-ZA.js +142 -0
  261. package/lib/umd/locale/ar.js +141 -0
  262. package/lib/umd/locale/az.js +141 -0
  263. package/lib/umd/locale/bg.js +142 -0
  264. package/lib/umd/locale/bn.js +141 -0
  265. package/lib/umd/locale/ca.js +141 -0
  266. package/lib/umd/locale/cs-CZ.js +144 -0
  267. package/lib/umd/locale/da.js +141 -0
  268. package/lib/umd/locale/de.js +143 -0
  269. package/lib/umd/locale/ee.js +142 -0
  270. package/lib/umd/locale/el.js +142 -0
  271. package/lib/umd/locale/en.js +142 -0
  272. package/lib/umd/locale/eo.js +142 -0
  273. package/lib/umd/locale/es.js +141 -0
  274. package/lib/umd/locale/eu.js +142 -0
  275. package/lib/umd/locale/fa.js +142 -0
  276. package/lib/umd/locale/fi.js +142 -0
  277. package/lib/umd/locale/fr.js +141 -0
  278. package/lib/umd/locale/he.js +142 -0
  279. package/lib/umd/locale/hr.js +142 -0
  280. package/lib/umd/locale/hu.js +141 -0
  281. package/lib/umd/locale/hy-AM.js +142 -0
  282. package/lib/umd/locale/id.js +142 -0
  283. package/lib/umd/locale/is.js +142 -0
  284. package/lib/umd/locale/it.js +141 -0
  285. package/lib/umd/locale/ja.js +142 -0
  286. package/lib/umd/locale/kg.js +142 -0
  287. package/lib/umd/locale/km.js +142 -0
  288. package/lib/umd/locale/ko.js +142 -0
  289. package/lib/umd/locale/ku.js +142 -0
  290. package/lib/umd/locale/kz.js +142 -0
  291. package/lib/umd/locale/lt.js +142 -0
  292. package/lib/umd/locale/lv.js +142 -0
  293. package/lib/umd/locale/mn.js +142 -0
  294. package/lib/umd/locale/ms.js +142 -0
  295. package/lib/umd/locale/nb-NO.js +141 -0
  296. package/lib/umd/locale/nl.js +142 -0
  297. package/lib/umd/locale/pl.js +142 -0
  298. package/lib/umd/locale/pt-br.js +142 -0
  299. package/lib/umd/locale/pt.js +142 -0
  300. package/lib/umd/locale/ro.js +142 -0
  301. package/lib/umd/locale/ru-RU.js +142 -0
  302. package/lib/umd/locale/si.js +142 -0
  303. package/lib/umd/locale/sk.js +144 -0
  304. package/lib/umd/locale/sl.js +142 -0
  305. package/lib/umd/locale/sr.js +142 -0
  306. package/lib/umd/locale/sv-SE.js +142 -0
  307. package/lib/umd/locale/sw.js +142 -0
  308. package/lib/umd/locale/ta.js +141 -0
  309. package/lib/umd/locale/th.js +142 -0
  310. package/lib/umd/locale/tk.js +142 -0
  311. package/lib/umd/locale/tr-TR.js +142 -0
  312. package/lib/umd/locale/ua.js +142 -0
  313. package/lib/umd/locale/ug-CN.js +142 -0
  314. package/lib/umd/locale/uz-UZ.js +142 -0
  315. package/lib/umd/locale/vi.js +142 -0
  316. package/lib/umd/locale/zh-CN.js +142 -0
  317. package/lib/umd/locale/zh-TW.js +142 -0
  318. package/lib/upload.js +1390 -0
  319. package/lib/utils/after-leave.js +35 -0
  320. package/lib/utils/aria-dialog.js +104 -0
  321. package/lib/utils/aria-utils.js +126 -0
  322. package/lib/utils/clickoutside.js +79 -0
  323. package/lib/utils/date-util.js +310 -0
  324. package/lib/utils/date.js +369 -0
  325. package/lib/utils/dom.js +234 -0
  326. package/lib/utils/menu/aria-menubar.js +24 -0
  327. package/lib/utils/menu/aria-menuitem.js +62 -0
  328. package/lib/utils/menu/aria-submenu.js +69 -0
  329. package/lib/utils/merge.js +21 -0
  330. package/lib/utils/popper.js +1261 -0
  331. package/lib/utils/popup/index.js +233 -0
  332. package/lib/utils/popup/popup-manager.js +205 -0
  333. package/lib/utils/resize-event.js +59 -0
  334. package/lib/utils/scroll-into-view.js +38 -0
  335. package/lib/utils/scrollbar-width.js +39 -0
  336. package/lib/utils/shared.js +12 -0
  337. package/lib/utils/types.js +52 -0
  338. package/lib/utils/util.js +268 -0
  339. package/lib/utils/vdom.js +13 -0
  340. package/lib/utils/vue-popper.js +202 -0
  341. package/package.json +148 -0
  342. package/packages/.DS_Store +0 -0
  343. package/packages/alert/index.js +8 -0
  344. package/packages/alert/src/main.vue +94 -0
  345. package/packages/aside/index.js +8 -0
  346. package/packages/aside/src/main.vue +20 -0
  347. package/packages/autocomplete/index.js +8 -0
  348. package/packages/autocomplete/src/autocomplete-suggestions.vue +76 -0
  349. package/packages/autocomplete/src/autocomplete.vue +285 -0
  350. package/packages/avatar/index.js +8 -0
  351. package/packages/avatar/src/main.vue +107 -0
  352. package/packages/backtop/index.js +8 -0
  353. package/packages/backtop/src/main.vue +110 -0
  354. package/packages/badge/index.js +8 -0
  355. package/packages/badge/src/main.vue +53 -0
  356. package/packages/breadcrumb/index.js +8 -0
  357. package/packages/breadcrumb/src/breadcrumb-item.vue +41 -0
  358. package/packages/breadcrumb/src/breadcrumb.vue +34 -0
  359. package/packages/breadcrumb-item/index.js +8 -0
  360. package/packages/button/index.js +8 -0
  361. package/packages/button/src/button-group.vue +10 -0
  362. package/packages/button/src/button.vue +86 -0
  363. package/packages/button-group/index.js +8 -0
  364. package/packages/calendar/index.js +8 -0
  365. package/packages/calendar/src/date-table.vue +200 -0
  366. package/packages/calendar/src/main.vue +280 -0
  367. package/packages/card/index.js +8 -0
  368. package/packages/card/src/main.vue +23 -0
  369. package/packages/carousel/index.js +8 -0
  370. package/packages/carousel/src/item.vue +138 -0
  371. package/packages/carousel/src/main.vue +315 -0
  372. package/packages/carousel-item/index.js +8 -0
  373. package/packages/cascader/index.js +8 -0
  374. package/packages/cascader/src/cascader.vue +663 -0
  375. package/packages/cascader-panel/index.js +8 -0
  376. package/packages/cascader-panel/src/cascader-menu.vue +138 -0
  377. package/packages/cascader-panel/src/cascader-node.vue +246 -0
  378. package/packages/cascader-panel/src/cascader-panel.vue +391 -0
  379. package/packages/cascader-panel/src/node.js +166 -0
  380. package/packages/cascader-panel/src/store.js +58 -0
  381. package/packages/checkbox/index.js +8 -0
  382. package/packages/checkbox/src/checkbox-button.vue +199 -0
  383. package/packages/checkbox/src/checkbox-group.vue +48 -0
  384. package/packages/checkbox/src/checkbox.vue +222 -0
  385. package/packages/checkbox-button/index.js +8 -0
  386. package/packages/checkbox-group/index.js +8 -0
  387. package/packages/col/index.js +9 -0
  388. package/packages/col/src/col.js +71 -0
  389. package/packages/collapse/index.js +9 -0
  390. package/packages/collapse/src/collapse-item.vue +114 -0
  391. package/packages/collapse/src/collapse.vue +73 -0
  392. package/packages/collapse-item/index.js +8 -0
  393. package/packages/color-picker/index.js +8 -0
  394. package/packages/color-picker/src/color.js +317 -0
  395. package/packages/color-picker/src/components/alpha-slider.vue +132 -0
  396. package/packages/color-picker/src/components/hue-slider.vue +123 -0
  397. package/packages/color-picker/src/components/picker-dropdown.vue +121 -0
  398. package/packages/color-picker/src/components/predefine.vue +61 -0
  399. package/packages/color-picker/src/components/sv-panel.vue +100 -0
  400. package/packages/color-picker/src/draggable.js +36 -0
  401. package/packages/color-picker/src/main.vue +188 -0
  402. package/packages/container/index.js +8 -0
  403. package/packages/container/src/main.vue +33 -0
  404. package/packages/date-picker/index.js +8 -0
  405. package/packages/date-picker/src/basic/date-table.vue +441 -0
  406. package/packages/date-picker/src/basic/month-table.vue +269 -0
  407. package/packages/date-picker/src/basic/time-spinner.vue +304 -0
  408. package/packages/date-picker/src/basic/year-table.vue +111 -0
  409. package/packages/date-picker/src/panel/date-range.vue +680 -0
  410. package/packages/date-picker/src/panel/date.vue +609 -0
  411. package/packages/date-picker/src/panel/month-range.vue +289 -0
  412. package/packages/date-picker/src/panel/time-range.vue +248 -0
  413. package/packages/date-picker/src/panel/time-select.vue +178 -0
  414. package/packages/date-picker/src/panel/time.vue +186 -0
  415. package/packages/date-picker/src/picker/date-picker.js +43 -0
  416. package/packages/date-picker/src/picker/time-picker.js +39 -0
  417. package/packages/date-picker/src/picker/time-select.js +21 -0
  418. package/packages/date-picker/src/picker.vue +956 -0
  419. package/packages/descriptions/index.js +8 -0
  420. package/packages/descriptions/src/descriptions-item.js +30 -0
  421. package/packages/descriptions/src/descriptions-row.js +116 -0
  422. package/packages/descriptions/src/index.js +180 -0
  423. package/packages/descriptions-item/index.js +8 -0
  424. package/packages/dialog/index.js +8 -0
  425. package/packages/dialog/src/component.vue +224 -0
  426. package/packages/divider/index.js +8 -0
  427. package/packages/divider/src/main.vue +37 -0
  428. package/packages/drawer/index.js +8 -0
  429. package/packages/drawer/src/main.vue +205 -0
  430. package/packages/dropdown/index.js +8 -0
  431. package/packages/dropdown/src/dropdown-item.vue +37 -0
  432. package/packages/dropdown/src/dropdown-menu.vue +63 -0
  433. package/packages/dropdown/src/dropdown.vue +293 -0
  434. package/packages/dropdown-item/index.js +8 -0
  435. package/packages/dropdown-menu/index.js +8 -0
  436. package/packages/empty/index.js +7 -0
  437. package/packages/empty/src/img-empty.vue +132 -0
  438. package/packages/empty/src/index.vue +50 -0
  439. package/packages/footer/index.js +8 -0
  440. package/packages/footer/src/main.vue +20 -0
  441. package/packages/form/index.js +8 -0
  442. package/packages/form/src/form-item.vue +324 -0
  443. package/packages/form/src/form.vue +182 -0
  444. package/packages/form/src/label-wrap.vue +78 -0
  445. package/packages/form-item/index.js +8 -0
  446. package/packages/header/index.js +8 -0
  447. package/packages/header/src/main.vue +20 -0
  448. package/packages/icon/index.js +8 -0
  449. package/packages/icon/src/icon.vue +13 -0
  450. package/packages/image/index.js +8 -0
  451. package/packages/image/src/image-viewer.vue +330 -0
  452. package/packages/image/src/main.vue +242 -0
  453. package/packages/infinite-scroll/index.js +8 -0
  454. package/packages/infinite-scroll/src/main.js +150 -0
  455. package/packages/input/index.js +8 -0
  456. package/packages/input/src/calcTextareaHeight.js +104 -0
  457. package/packages/input/src/input.vue +440 -0
  458. package/packages/input-number/index.js +8 -0
  459. package/packages/input-number/src/input-number.vue +283 -0
  460. package/packages/link/index.js +8 -0
  461. package/packages/link/src/main.vue +53 -0
  462. package/packages/loading/index.js +11 -0
  463. package/packages/loading/src/directive.js +133 -0
  464. package/packages/loading/src/index.js +106 -0
  465. package/packages/loading/src/loading.vue +41 -0
  466. package/packages/main/index.js +8 -0
  467. package/packages/main/src/main.vue +12 -0
  468. package/packages/menu/index.js +8 -0
  469. package/packages/menu/src/menu-item-group.vue +45 -0
  470. package/packages/menu/src/menu-item.vue +112 -0
  471. package/packages/menu/src/menu-mixin.js +44 -0
  472. package/packages/menu/src/menu.vue +325 -0
  473. package/packages/menu/src/submenu.vue +349 -0
  474. package/packages/menu-item/index.js +8 -0
  475. package/packages/menu-item-group/index.js +8 -0
  476. package/packages/message/index.js +2 -0
  477. package/packages/message/src/main.js +91 -0
  478. package/packages/message/src/main.vue +117 -0
  479. package/packages/message-box/index.js +2 -0
  480. package/packages/message-box/src/main.js +216 -0
  481. package/packages/message-box/src/main.vue +332 -0
  482. package/packages/notification/index.js +2 -0
  483. package/packages/notification/src/main.js +94 -0
  484. package/packages/notification/src/main.vue +152 -0
  485. package/packages/option/index.js +8 -0
  486. package/packages/option-group/index.js +8 -0
  487. package/packages/page-header/index.js +8 -0
  488. package/packages/page-header/src/main.vue +30 -0
  489. package/packages/pagination/index.js +8 -0
  490. package/packages/pagination/src/pager.vue +163 -0
  491. package/packages/pagination/src/pagination.js +386 -0
  492. package/packages/popconfirm/index.js +8 -0
  493. package/packages/popconfirm/src/main.vue +104 -0
  494. package/packages/popover/index.js +14 -0
  495. package/packages/popover/src/directive.js +20 -0
  496. package/packages/popover/src/main.vue +237 -0
  497. package/packages/progress/index.js +8 -0
  498. package/packages/progress/src/progress.vue +227 -0
  499. package/packages/radio/index.js +8 -0
  500. package/packages/radio/src/radio-button.vue +115 -0
  501. package/packages/radio/src/radio-group.vue +113 -0
  502. package/packages/radio/src/radio.vue +134 -0
  503. package/packages/radio-button/index.js +8 -0
  504. package/packages/radio-group/index.js +8 -0
  505. package/packages/rate/index.js +8 -0
  506. package/packages/rate/src/main.vue +348 -0
  507. package/packages/result/index.js +8 -0
  508. package/packages/result/src/icon-error.vue +13 -0
  509. package/packages/result/src/icon-info.vue +13 -0
  510. package/packages/result/src/icon-success.vue +13 -0
  511. package/packages/result/src/icon-warning.vue +13 -0
  512. package/packages/result/src/index.vue +65 -0
  513. package/packages/row/index.js +9 -0
  514. package/packages/row/src/row.js +44 -0
  515. package/packages/scrollbar/index.js +8 -0
  516. package/packages/scrollbar/src/bar.js +92 -0
  517. package/packages/scrollbar/src/main.js +130 -0
  518. package/packages/scrollbar/src/util.js +34 -0
  519. package/packages/select/index.js +8 -0
  520. package/packages/select/src/navigation-mixin.js +54 -0
  521. package/packages/select/src/option-group.vue +60 -0
  522. package/packages/select/src/option.vue +168 -0
  523. package/packages/select/src/select-dropdown.vue +74 -0
  524. package/packages/select/src/select.vue +900 -0
  525. package/packages/skeleton/index.js +8 -0
  526. package/packages/skeleton/src/img-placeholder.vue +16 -0
  527. package/packages/skeleton/src/index.vue +76 -0
  528. package/packages/skeleton/src/item.vue +22 -0
  529. package/packages/skeleton-item/index.js +8 -0
  530. package/packages/slider/index.js +8 -0
  531. package/packages/slider/src/button.vue +238 -0
  532. package/packages/slider/src/main.vue +427 -0
  533. package/packages/slider/src/marker.js +18 -0
  534. package/packages/spinner/index.js +8 -0
  535. package/packages/spinner/src/spinner.vue +27 -0
  536. package/packages/step/index.js +8 -0
  537. package/packages/steps/README.md +69 -0
  538. package/packages/steps/index.js +8 -0
  539. package/packages/steps/src/step.vue +184 -0
  540. package/packages/steps/src/steps.vue +68 -0
  541. package/packages/submenu/index.js +8 -0
  542. package/packages/switch/index.js +9 -0
  543. package/packages/switch/src/component.vue +174 -0
  544. package/packages/tab-pane/index.js +8 -0
  545. package/packages/table/index.js +8 -0
  546. package/packages/table/src/config.js +124 -0
  547. package/packages/table/src/dropdown.js +28 -0
  548. package/packages/table/src/filter-panel.vue +194 -0
  549. package/packages/table/src/layout-observer.js +68 -0
  550. package/packages/table/src/store/current.js +76 -0
  551. package/packages/table/src/store/expand.js +65 -0
  552. package/packages/table/src/store/helper.js +41 -0
  553. package/packages/table/src/store/index.js +147 -0
  554. package/packages/table/src/store/tree.js +209 -0
  555. package/packages/table/src/store/watcher.js +381 -0
  556. package/packages/table/src/table-body.js +460 -0
  557. package/packages/table/src/table-column.js +319 -0
  558. package/packages/table/src/table-footer.js +160 -0
  559. package/packages/table/src/table-header.js +481 -0
  560. package/packages/table/src/table-layout.js +249 -0
  561. package/packages/table/src/table-row.js +101 -0
  562. package/packages/table/src/table.vue +740 -0
  563. package/packages/table/src/util.js +255 -0
  564. package/packages/table-column/index.js +8 -0
  565. package/packages/tabs/index.js +8 -0
  566. package/packages/tabs/src/tab-bar.vue +57 -0
  567. package/packages/tabs/src/tab-nav.vue +294 -0
  568. package/packages/tabs/src/tab-pane.vue +56 -0
  569. package/packages/tabs/src/tabs.vue +191 -0
  570. package/packages/tag/index.js +8 -0
  571. package/packages/tag/src/tag.vue +47 -0
  572. package/packages/theme-chalk/README.md +33 -0
  573. package/packages/theme-chalk/lib/alert.css +1 -0
  574. package/packages/theme-chalk/lib/aside.css +1 -0
  575. package/packages/theme-chalk/lib/autocomplete.css +1 -0
  576. package/packages/theme-chalk/lib/avatar.css +1 -0
  577. package/packages/theme-chalk/lib/backtop.css +1 -0
  578. package/packages/theme-chalk/lib/badge.css +1 -0
  579. package/packages/theme-chalk/lib/base.css +1 -0
  580. package/packages/theme-chalk/lib/breadcrumb-item.css +0 -0
  581. package/packages/theme-chalk/lib/breadcrumb.css +1 -0
  582. package/packages/theme-chalk/lib/button-group.css +0 -0
  583. package/packages/theme-chalk/lib/button.css +1 -0
  584. package/packages/theme-chalk/lib/calendar.css +1 -0
  585. package/packages/theme-chalk/lib/card.css +1 -0
  586. package/packages/theme-chalk/lib/carousel-item.css +1 -0
  587. package/packages/theme-chalk/lib/carousel.css +1 -0
  588. package/packages/theme-chalk/lib/cascader-panel.css +1 -0
  589. package/packages/theme-chalk/lib/cascader.css +1 -0
  590. package/packages/theme-chalk/lib/checkbox-button.css +0 -0
  591. package/packages/theme-chalk/lib/checkbox-group.css +0 -0
  592. package/packages/theme-chalk/lib/checkbox.css +1 -0
  593. package/packages/theme-chalk/lib/col.css +1 -0
  594. package/packages/theme-chalk/lib/collapse-item.css +0 -0
  595. package/packages/theme-chalk/lib/collapse.css +1 -0
  596. package/packages/theme-chalk/lib/color-picker.css +1 -0
  597. package/packages/theme-chalk/lib/container.css +1 -0
  598. package/packages/theme-chalk/lib/date-picker.css +1 -0
  599. package/packages/theme-chalk/lib/descriptions-item.css +1 -0
  600. package/packages/theme-chalk/lib/descriptions.css +1 -0
  601. package/packages/theme-chalk/lib/dialog.css +1 -0
  602. package/packages/theme-chalk/lib/display.css +1 -0
  603. package/packages/theme-chalk/lib/divider.css +1 -0
  604. package/packages/theme-chalk/lib/drawer.css +1 -0
  605. package/packages/theme-chalk/lib/dropdown-item.css +0 -0
  606. package/packages/theme-chalk/lib/dropdown-menu.css +0 -0
  607. package/packages/theme-chalk/lib/dropdown.css +1 -0
  608. package/packages/theme-chalk/lib/empty.css +1 -0
  609. package/packages/theme-chalk/lib/fonts/element-icons.ttf +0 -0
  610. package/packages/theme-chalk/lib/fonts/element-icons.woff +0 -0
  611. package/packages/theme-chalk/lib/footer.css +1 -0
  612. package/packages/theme-chalk/lib/form-item.css +0 -0
  613. package/packages/theme-chalk/lib/form.css +1 -0
  614. package/packages/theme-chalk/lib/header.css +1 -0
  615. package/packages/theme-chalk/lib/icon.css +1 -0
  616. package/packages/theme-chalk/lib/image.css +1 -0
  617. package/packages/theme-chalk/lib/index.css +1 -0
  618. package/packages/theme-chalk/lib/infinite-scroll.css +0 -0
  619. package/packages/theme-chalk/lib/infiniteScroll.css +0 -0
  620. package/packages/theme-chalk/lib/input-number.css +1 -0
  621. package/packages/theme-chalk/lib/input.css +1 -0
  622. package/packages/theme-chalk/lib/link.css +1 -0
  623. package/packages/theme-chalk/lib/loading.css +1 -0
  624. package/packages/theme-chalk/lib/main.css +1 -0
  625. package/packages/theme-chalk/lib/menu-item-group.css +0 -0
  626. package/packages/theme-chalk/lib/menu-item.css +0 -0
  627. package/packages/theme-chalk/lib/menu.css +1 -0
  628. package/packages/theme-chalk/lib/message-box.css +1 -0
  629. package/packages/theme-chalk/lib/message.css +1 -0
  630. package/packages/theme-chalk/lib/notification.css +1 -0
  631. package/packages/theme-chalk/lib/option-group.css +1 -0
  632. package/packages/theme-chalk/lib/option.css +1 -0
  633. package/packages/theme-chalk/lib/page-header.css +1 -0
  634. package/packages/theme-chalk/lib/pagination.css +1 -0
  635. package/packages/theme-chalk/lib/popconfirm.css +1 -0
  636. package/packages/theme-chalk/lib/popover.css +1 -0
  637. package/packages/theme-chalk/lib/popper.css +1 -0
  638. package/packages/theme-chalk/lib/progress.css +1 -0
  639. package/packages/theme-chalk/lib/radio-button.css +1 -0
  640. package/packages/theme-chalk/lib/radio-group.css +1 -0
  641. package/packages/theme-chalk/lib/radio.css +1 -0
  642. package/packages/theme-chalk/lib/rate.css +1 -0
  643. package/packages/theme-chalk/lib/reset.css +1 -0
  644. package/packages/theme-chalk/lib/result.css +1 -0
  645. package/packages/theme-chalk/lib/row.css +1 -0
  646. package/packages/theme-chalk/lib/scrollbar.css +1 -0
  647. package/packages/theme-chalk/lib/select-dropdown.css +1 -0
  648. package/packages/theme-chalk/lib/select.css +1 -0
  649. package/packages/theme-chalk/lib/skeleton-item.css +1 -0
  650. package/packages/theme-chalk/lib/skeleton.css +1 -0
  651. package/packages/theme-chalk/lib/slider.css +1 -0
  652. package/packages/theme-chalk/lib/spinner.css +1 -0
  653. package/packages/theme-chalk/lib/step.css +1 -0
  654. package/packages/theme-chalk/lib/steps.css +1 -0
  655. package/packages/theme-chalk/lib/submenu.css +0 -0
  656. package/packages/theme-chalk/lib/switch.css +1 -0
  657. package/packages/theme-chalk/lib/tab-pane.css +0 -0
  658. package/packages/theme-chalk/lib/table-column.css +1 -0
  659. package/packages/theme-chalk/lib/table.css +1 -0
  660. package/packages/theme-chalk/lib/tabs.css +1 -0
  661. package/packages/theme-chalk/lib/tag.css +1 -0
  662. package/packages/theme-chalk/lib/time-picker.css +1 -0
  663. package/packages/theme-chalk/lib/time-select.css +1 -0
  664. package/packages/theme-chalk/lib/timeline-item.css +1 -0
  665. package/packages/theme-chalk/lib/timeline.css +1 -0
  666. package/packages/theme-chalk/lib/tooltip.css +1 -0
  667. package/packages/theme-chalk/lib/transfer.css +1 -0
  668. package/packages/theme-chalk/lib/tree.css +1 -0
  669. package/packages/theme-chalk/lib/upload.css +1 -0
  670. package/packages/theme-chalk/package.json +35 -0
  671. package/packages/theme-chalk/src/alert.scss +147 -0
  672. package/packages/theme-chalk/src/aside.scss +7 -0
  673. package/packages/theme-chalk/src/autocomplete.scss +80 -0
  674. package/packages/theme-chalk/src/avatar.scss +51 -0
  675. package/packages/theme-chalk/src/backtop.scss +22 -0
  676. package/packages/theme-chalk/src/badge.scss +57 -0
  677. package/packages/theme-chalk/src/base.scss +2 -0
  678. package/packages/theme-chalk/src/breadcrumb-item.scss +0 -0
  679. package/packages/theme-chalk/src/breadcrumb.scss +55 -0
  680. package/packages/theme-chalk/src/button-group.scss +0 -0
  681. package/packages/theme-chalk/src/button.scss +263 -0
  682. package/packages/theme-chalk/src/calendar.scss +79 -0
  683. package/packages/theme-chalk/src/card.scss +33 -0
  684. package/packages/theme-chalk/src/carousel-item.scss +50 -0
  685. package/packages/theme-chalk/src/carousel.scss +161 -0
  686. package/packages/theme-chalk/src/cascader-panel.scss +120 -0
  687. package/packages/theme-chalk/src/cascader.scss +182 -0
  688. package/packages/theme-chalk/src/checkbox-button.scss +0 -0
  689. package/packages/theme-chalk/src/checkbox-group.scss +0 -0
  690. package/packages/theme-chalk/src/checkbox.scss +359 -0
  691. package/packages/theme-chalk/src/col.scss +156 -0
  692. package/packages/theme-chalk/src/collapse-item.scss +0 -0
  693. package/packages/theme-chalk/src/collapse.scss +63 -0
  694. package/packages/theme-chalk/src/color-picker.scss +384 -0
  695. package/packages/theme-chalk/src/common/popup.scss +42 -0
  696. package/packages/theme-chalk/src/common/transition.scss +99 -0
  697. package/packages/theme-chalk/src/common/var.scss +1052 -0
  698. package/packages/theme-chalk/src/container.scss +14 -0
  699. package/packages/theme-chalk/src/date-picker/date-picker.scss +97 -0
  700. package/packages/theme-chalk/src/date-picker/date-range-picker.scss +101 -0
  701. package/packages/theme-chalk/src/date-picker/date-table.scss +151 -0
  702. package/packages/theme-chalk/src/date-picker/month-table.scss +82 -0
  703. package/packages/theme-chalk/src/date-picker/picker-panel.scss +117 -0
  704. package/packages/theme-chalk/src/date-picker/picker.scss +198 -0
  705. package/packages/theme-chalk/src/date-picker/time-picker.scss +85 -0
  706. package/packages/theme-chalk/src/date-picker/time-range-picker.scss +31 -0
  707. package/packages/theme-chalk/src/date-picker/time-spinner.scss +110 -0
  708. package/packages/theme-chalk/src/date-picker/year-table.scss +51 -0
  709. package/packages/theme-chalk/src/date-picker.scss +12 -0
  710. package/packages/theme-chalk/src/descriptions-item.scss +42 -0
  711. package/packages/theme-chalk/src/descriptions.scss +111 -0
  712. package/packages/theme-chalk/src/dialog.scss +138 -0
  713. package/packages/theme-chalk/src/display.scss +12 -0
  714. package/packages/theme-chalk/src/divider.scss +47 -0
  715. package/packages/theme-chalk/src/drawer.scss +219 -0
  716. package/packages/theme-chalk/src/dropdown-item.scss +0 -0
  717. package/packages/theme-chalk/src/dropdown-menu.scss +0 -0
  718. package/packages/theme-chalk/src/dropdown.scss +182 -0
  719. package/packages/theme-chalk/src/empty.scss +45 -0
  720. package/packages/theme-chalk/src/fonts/element-icons.ttf +0 -0
  721. package/packages/theme-chalk/src/fonts/element-icons.woff +0 -0
  722. package/packages/theme-chalk/src/footer.scss +8 -0
  723. package/packages/theme-chalk/src/form-item.scss +0 -0
  724. package/packages/theme-chalk/src/form.scss +167 -0
  725. package/packages/theme-chalk/src/header.scss +8 -0
  726. package/packages/theme-chalk/src/icon.scss +1167 -0
  727. package/packages/theme-chalk/src/image.scss +179 -0
  728. package/packages/theme-chalk/src/index.scss +86 -0
  729. package/packages/theme-chalk/src/infinite-scroll.scss +0 -0
  730. package/packages/theme-chalk/src/infiniteScroll.scss +0 -0
  731. package/packages/theme-chalk/src/input-number.scss +180 -0
  732. package/packages/theme-chalk/src/input.scss +360 -0
  733. package/packages/theme-chalk/src/link.scss +81 -0
  734. package/packages/theme-chalk/src/loading.scss +96 -0
  735. package/packages/theme-chalk/src/main.scss +12 -0
  736. package/packages/theme-chalk/src/menu-item-group.scss +0 -0
  737. package/packages/theme-chalk/src/menu-item.scss +0 -0
  738. package/packages/theme-chalk/src/menu.scss +289 -0
  739. package/packages/theme-chalk/src/message-box.scss +226 -0
  740. package/packages/theme-chalk/src/message.scss +120 -0
  741. package/packages/theme-chalk/src/mixins/_button.scss +81 -0
  742. package/packages/theme-chalk/src/mixins/config.scss +4 -0
  743. package/packages/theme-chalk/src/mixins/function.scss +44 -0
  744. package/packages/theme-chalk/src/mixins/mixins.scss +190 -0
  745. package/packages/theme-chalk/src/mixins/utils.scss +39 -0
  746. package/packages/theme-chalk/src/notification.scss +99 -0
  747. package/packages/theme-chalk/src/option-group.scss +42 -0
  748. package/packages/theme-chalk/src/option.scss +36 -0
  749. package/packages/theme-chalk/src/page-header.scss +41 -0
  750. package/packages/theme-chalk/src/pagination.scss +295 -0
  751. package/packages/theme-chalk/src/popconfirm.scss +16 -0
  752. package/packages/theme-chalk/src/popover.scss +40 -0
  753. package/packages/theme-chalk/src/popper.scss +101 -0
  754. package/packages/theme-chalk/src/progress.scss +141 -0
  755. package/packages/theme-chalk/src/radio-button.scss +113 -0
  756. package/packages/theme-chalk/src/radio-group.scss +9 -0
  757. package/packages/theme-chalk/src/radio.scss +199 -0
  758. package/packages/theme-chalk/src/rate.scss +49 -0
  759. package/packages/theme-chalk/src/reset.scss +79 -0
  760. package/packages/theme-chalk/src/result.scss +61 -0
  761. package/packages/theme-chalk/src/row.scss +43 -0
  762. package/packages/theme-chalk/src/scrollbar.scss +72 -0
  763. package/packages/theme-chalk/src/select-dropdown.scss +62 -0
  764. package/packages/theme-chalk/src/select.scss +151 -0
  765. package/packages/theme-chalk/src/skeleton-item.scss +84 -0
  766. package/packages/theme-chalk/src/skeleton.scss +40 -0
  767. package/packages/theme-chalk/src/slider.scss +250 -0
  768. package/packages/theme-chalk/src/spinner.scss +44 -0
  769. package/packages/theme-chalk/src/step.scss +317 -0
  770. package/packages/theme-chalk/src/steps.scss +20 -0
  771. package/packages/theme-chalk/src/submenu.scss +0 -0
  772. package/packages/theme-chalk/src/switch.scss +116 -0
  773. package/packages/theme-chalk/src/tab-pane.scss +0 -0
  774. package/packages/theme-chalk/src/table-column.scss +97 -0
  775. package/packages/theme-chalk/src/table.scss +578 -0
  776. package/packages/theme-chalk/src/tabs.scss +602 -0
  777. package/packages/theme-chalk/src/tag.scss +163 -0
  778. package/packages/theme-chalk/src/time-picker.scss +8 -0
  779. package/packages/theme-chalk/src/time-select.scss +37 -0
  780. package/packages/theme-chalk/src/timeline-item.scss +86 -0
  781. package/packages/theme-chalk/src/timeline.scss +14 -0
  782. package/packages/theme-chalk/src/tooltip.scss +141 -0
  783. package/packages/theme-chalk/src/transfer.scss +227 -0
  784. package/packages/theme-chalk/src/tree.scss +123 -0
  785. package/packages/theme-chalk/src/upload.scss +603 -0
  786. package/packages/time-picker/index.js +8 -0
  787. package/packages/time-select/index.js +8 -0
  788. package/packages/timeline/index.js +8 -0
  789. package/packages/timeline/src/item.vue +73 -0
  790. package/packages/timeline/src/main.vue +33 -0
  791. package/packages/timeline-item/index.js +8 -0
  792. package/packages/tooltip/index.js +8 -0
  793. package/packages/tooltip/src/main.js +242 -0
  794. package/packages/transfer/index.js +8 -0
  795. package/packages/transfer/src/main.vue +231 -0
  796. package/packages/transfer/src/transfer-panel.vue +251 -0
  797. package/packages/tree/index.js +8 -0
  798. package/packages/tree/src/model/node.js +484 -0
  799. package/packages/tree/src/model/tree-store.js +340 -0
  800. package/packages/tree/src/model/util.js +27 -0
  801. package/packages/tree/src/tree-node.vue +279 -0
  802. package/packages/tree/src/tree.vue +496 -0
  803. package/packages/upload/index.js +8 -0
  804. package/packages/upload/src/ajax.js +85 -0
  805. package/packages/upload/src/index.vue +338 -0
  806. package/packages/upload/src/upload-dragger.vue +70 -0
  807. package/packages/upload/src/upload-list.vue +105 -0
  808. package/packages/upload/src/upload.vue +211 -0
  809. package/src/.DS_Store +0 -0
  810. package/src/directives/mousewheel.js +18 -0
  811. package/src/directives/repeat-click.js +24 -0
  812. package/src/index.js +306 -0
  813. package/src/locale/format.js +46 -0
  814. package/src/locale/index.js +48 -0
  815. package/src/locale/lang/af-ZA.js +123 -0
  816. package/src/locale/lang/ar.js +122 -0
  817. package/src/locale/lang/az.js +126 -0
  818. package/src/locale/lang/bg.js +123 -0
  819. package/src/locale/lang/bn.js +126 -0
  820. package/src/locale/lang/ca.js +122 -0
  821. package/src/locale/lang/cs-CZ.js +125 -0
  822. package/src/locale/lang/da.js +122 -0
  823. package/src/locale/lang/de.js +124 -0
  824. package/src/locale/lang/ee.js +123 -0
  825. package/src/locale/lang/el.js +123 -0
  826. package/src/locale/lang/en.js +123 -0
  827. package/src/locale/lang/eo.js +123 -0
  828. package/src/locale/lang/es.js +122 -0
  829. package/src/locale/lang/eu.js +123 -0
  830. package/src/locale/lang/fa.js +123 -0
  831. package/src/locale/lang/fi.js +123 -0
  832. package/src/locale/lang/fr.js +122 -0
  833. package/src/locale/lang/he.js +123 -0
  834. package/src/locale/lang/hr.js +123 -0
  835. package/src/locale/lang/hu.js +122 -0
  836. package/src/locale/lang/hy-AM.js +123 -0
  837. package/src/locale/lang/id.js +123 -0
  838. package/src/locale/lang/is.js +124 -0
  839. package/src/locale/lang/it.js +122 -0
  840. package/src/locale/lang/ja.js +123 -0
  841. package/src/locale/lang/kg.js +123 -0
  842. package/src/locale/lang/km.js +123 -0
  843. package/src/locale/lang/ko.js +123 -0
  844. package/src/locale/lang/ku.js +123 -0
  845. package/src/locale/lang/kz.js +123 -0
  846. package/src/locale/lang/lt.js +123 -0
  847. package/src/locale/lang/lv.js +123 -0
  848. package/src/locale/lang/mn.js +123 -0
  849. package/src/locale/lang/ms.js +123 -0
  850. package/src/locale/lang/nb-NO.js +122 -0
  851. package/src/locale/lang/nl.js +123 -0
  852. package/src/locale/lang/pl.js +123 -0
  853. package/src/locale/lang/pt-br.js +123 -0
  854. package/src/locale/lang/pt.js +123 -0
  855. package/src/locale/lang/ro.js +123 -0
  856. package/src/locale/lang/ru-RU.js +123 -0
  857. package/src/locale/lang/si.js +123 -0
  858. package/src/locale/lang/sk.js +125 -0
  859. package/src/locale/lang/sl.js +123 -0
  860. package/src/locale/lang/sr.js +123 -0
  861. package/src/locale/lang/sv-SE.js +123 -0
  862. package/src/locale/lang/sw.js +123 -0
  863. package/src/locale/lang/ta.js +122 -0
  864. package/src/locale/lang/th.js +123 -0
  865. package/src/locale/lang/tk.js +123 -0
  866. package/src/locale/lang/tr-TR.js +123 -0
  867. package/src/locale/lang/ua.js +123 -0
  868. package/src/locale/lang/ug-CN.js +123 -0
  869. package/src/locale/lang/uz-UZ.js +123 -0
  870. package/src/locale/lang/vi.js +123 -0
  871. package/src/locale/lang/zh-CN.js +123 -0
  872. package/src/locale/lang/zh-TW.js +123 -0
  873. package/src/mixins/emitter.js +33 -0
  874. package/src/mixins/focus.js +9 -0
  875. package/src/mixins/locale.js +9 -0
  876. package/src/mixins/migrating.js +54 -0
  877. package/src/transitions/collapse-transition.js +77 -0
  878. package/src/utils/after-leave.js +27 -0
  879. package/src/utils/aria-dialog.js +90 -0
  880. package/src/utils/aria-utils.js +122 -0
  881. package/src/utils/clickoutside.js +76 -0
  882. package/src/utils/date-util.js +282 -0
  883. package/src/utils/date.js +368 -0
  884. package/src/utils/dom.js +227 -0
  885. package/src/utils/menu/aria-menubar.js +14 -0
  886. package/src/utils/menu/aria-menuitem.js +49 -0
  887. package/src/utils/menu/aria-submenu.js +59 -0
  888. package/src/utils/merge.js +15 -0
  889. package/src/utils/popper.js +1276 -0
  890. package/src/utils/popup/index.js +218 -0
  891. package/src/utils/popup/popup-manager.js +194 -0
  892. package/src/utils/resize-event.js +36 -0
  893. package/src/utils/scroll-into-view.js +27 -0
  894. package/src/utils/scrollbar-width.js +29 -0
  895. package/src/utils/shared.js +7 -0
  896. package/src/utils/types.js +40 -0
  897. package/src/utils/util.js +241 -0
  898. package/src/utils/vdom.js +5 -0
  899. package/src/utils/vue-popper.js +198 -0
  900. package/types/alert.d.ts +31 -0
  901. package/types/aside.d.ts +7 -0
  902. package/types/autocomplete.d.ts +78 -0
  903. package/types/avatar.d.ts +20 -0
  904. package/types/backtop.d.ts +16 -0
  905. package/types/badge.d.ts +16 -0
  906. package/types/breadcrumb-item.d.ts +10 -0
  907. package/types/breadcrumb.d.ts +10 -0
  908. package/types/button-group.d.ts +4 -0
  909. package/types/button.d.ts +37 -0
  910. package/types/calendar.d.ts +15 -0
  911. package/types/card.d.ts +26 -0
  912. package/types/carousel-item.d.ts +10 -0
  913. package/types/carousel.d.ts +57 -0
  914. package/types/cascader-panel.d.ts +72 -0
  915. package/types/cascader.d.ts +65 -0
  916. package/types/checkbox-button.d.ts +22 -0
  917. package/types/checkbox-group.d.ts +22 -0
  918. package/types/checkbox.d.ts +34 -0
  919. package/types/col.d.ts +46 -0
  920. package/types/collapse-item.d.ts +26 -0
  921. package/types/collapse.d.ts +10 -0
  922. package/types/color-picker.d.ts +21 -0
  923. package/types/component.d.ts +13 -0
  924. package/types/container.d.ts +7 -0
  925. package/types/date-picker.d.ts +124 -0
  926. package/types/descriptions-item.d.ts +37 -0
  927. package/types/descriptions.d.ts +52 -0
  928. package/types/dialog.d.ts +62 -0
  929. package/types/divider.d.ts +12 -0
  930. package/types/drawer.d.ts +63 -0
  931. package/types/dropdown-item.d.ts +16 -0
  932. package/types/dropdown-menu.d.ts +4 -0
  933. package/types/dropdown.d.ts +38 -0
  934. package/types/element-ui.d.ts +378 -0
  935. package/types/empty.d.ts +31 -0
  936. package/types/footer.d.ts +7 -0
  937. package/types/form-item.d.ts +37 -0
  938. package/types/form.d.ts +82 -0
  939. package/types/header.d.ts +7 -0
  940. package/types/icon.d.ts +7 -0
  941. package/types/image.d.ts +41 -0
  942. package/types/index.d.ts +4 -0
  943. package/types/infinite-scroll.d.ts +6 -0
  944. package/types/input-number.d.ts +47 -0
  945. package/types/input.d.ts +107 -0
  946. package/types/link.d.ts +25 -0
  947. package/types/loading.d.ts +62 -0
  948. package/types/main.d.ts +4 -0
  949. package/types/menu-item-group.d.ts +7 -0
  950. package/types/menu-item.d.ts +10 -0
  951. package/types/menu.d.ts +46 -0
  952. package/types/message-box.d.ts +176 -0
  953. package/types/message.d.ts +90 -0
  954. package/types/notification.d.ts +84 -0
  955. package/types/option-group.d.ts +10 -0
  956. package/types/option.d.ts +13 -0
  957. package/types/page-header.d.ts +10 -0
  958. package/types/pagination.d.ts +43 -0
  959. package/types/popconfirm.d.ts +29 -0
  960. package/types/popover.d.ts +71 -0
  961. package/types/progress.d.ts +37 -0
  962. package/types/radio-button.d.ts +16 -0
  963. package/types/radio-group.d.ts +18 -0
  964. package/types/radio.d.ts +19 -0
  965. package/types/rate.d.ts +64 -0
  966. package/types/result.d.ts +33 -0
  967. package/types/row.d.ts +25 -0
  968. package/types/select.d.ts +90 -0
  969. package/types/skeleton-item.d.ts +7 -0
  970. package/types/skeleton.d.ts +33 -0
  971. package/types/slider.d.ts +68 -0
  972. package/types/spinner.d.ts +16 -0
  973. package/types/step.d.ts +34 -0
  974. package/types/steps.d.ts +28 -0
  975. package/types/submenu.d.ts +22 -0
  976. package/types/switch.d.ts +43 -0
  977. package/types/tab-pane.d.ts +19 -0
  978. package/types/table-column.d.ts +117 -0
  979. package/types/table.d.ts +174 -0
  980. package/types/tabs.d.ts +31 -0
  981. package/types/tag.d.ts +28 -0
  982. package/types/time-picker.d.ts +63 -0
  983. package/types/time-select.d.ts +56 -0
  984. package/types/timeline-item.d.ts +20 -0
  985. package/types/timeline.d.ts +6 -0
  986. package/types/tooltip.d.ts +52 -0
  987. package/types/transfer.d.ts +73 -0
  988. package/types/tree.d.ts +266 -0
  989. package/types/upload.d.ts +124 -0
package/lib/table.js ADDED
@@ -0,0 +1,5015 @@
1
+ module.exports =
2
+ /******/ (function(modules) { // webpackBootstrap
3
+ /******/ // The module cache
4
+ /******/ var installedModules = {};
5
+ /******/
6
+ /******/ // The require function
7
+ /******/ function __webpack_require__(moduleId) {
8
+ /******/
9
+ /******/ // Check if module is in cache
10
+ /******/ if(installedModules[moduleId]) {
11
+ /******/ return installedModules[moduleId].exports;
12
+ /******/ }
13
+ /******/ // Create a new module (and put it into the cache)
14
+ /******/ var module = installedModules[moduleId] = {
15
+ /******/ i: moduleId,
16
+ /******/ l: false,
17
+ /******/ exports: {}
18
+ /******/ };
19
+ /******/
20
+ /******/ // Execute the module function
21
+ /******/ modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
22
+ /******/
23
+ /******/ // Flag the module as loaded
24
+ /******/ module.l = true;
25
+ /******/
26
+ /******/ // Return the exports of the module
27
+ /******/ return module.exports;
28
+ /******/ }
29
+ /******/
30
+ /******/
31
+ /******/ // expose the modules object (__webpack_modules__)
32
+ /******/ __webpack_require__.m = modules;
33
+ /******/
34
+ /******/ // expose the module cache
35
+ /******/ __webpack_require__.c = installedModules;
36
+ /******/
37
+ /******/ // define getter function for harmony exports
38
+ /******/ __webpack_require__.d = function(exports, name, getter) {
39
+ /******/ if(!__webpack_require__.o(exports, name)) {
40
+ /******/ Object.defineProperty(exports, name, { enumerable: true, get: getter });
41
+ /******/ }
42
+ /******/ };
43
+ /******/
44
+ /******/ // define __esModule on exports
45
+ /******/ __webpack_require__.r = function(exports) {
46
+ /******/ if(typeof Symbol !== 'undefined' && Symbol.toStringTag) {
47
+ /******/ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
48
+ /******/ }
49
+ /******/ Object.defineProperty(exports, '__esModule', { value: true });
50
+ /******/ };
51
+ /******/
52
+ /******/ // create a fake namespace object
53
+ /******/ // mode & 1: value is a module id, require it
54
+ /******/ // mode & 2: merge all properties of value into the ns
55
+ /******/ // mode & 4: return value when already ns object
56
+ /******/ // mode & 8|1: behave like require
57
+ /******/ __webpack_require__.t = function(value, mode) {
58
+ /******/ if(mode & 1) value = __webpack_require__(value);
59
+ /******/ if(mode & 8) return value;
60
+ /******/ if((mode & 4) && typeof value === 'object' && value && value.__esModule) return value;
61
+ /******/ var ns = Object.create(null);
62
+ /******/ __webpack_require__.r(ns);
63
+ /******/ Object.defineProperty(ns, 'default', { enumerable: true, value: value });
64
+ /******/ if(mode & 2 && typeof value != 'string') for(var key in value) __webpack_require__.d(ns, key, function(key) { return value[key]; }.bind(null, key));
65
+ /******/ return ns;
66
+ /******/ };
67
+ /******/
68
+ /******/ // getDefaultExport function for compatibility with non-harmony modules
69
+ /******/ __webpack_require__.n = function(module) {
70
+ /******/ var getter = module && module.__esModule ?
71
+ /******/ function getDefault() { return module['default']; } :
72
+ /******/ function getModuleExports() { return module; };
73
+ /******/ __webpack_require__.d(getter, 'a', getter);
74
+ /******/ return getter;
75
+ /******/ };
76
+ /******/
77
+ /******/ // Object.prototype.hasOwnProperty.call
78
+ /******/ __webpack_require__.o = function(object, property) { return Object.prototype.hasOwnProperty.call(object, property); };
79
+ /******/
80
+ /******/ // __webpack_public_path__
81
+ /******/ __webpack_require__.p = "/dist/";
82
+ /******/
83
+ /******/
84
+ /******/ // Load entry module and return exports
85
+ /******/ return __webpack_require__(__webpack_require__.s = 57);
86
+ /******/ })
87
+ /************************************************************************/
88
+ /******/ ([
89
+ /* 0 */
90
+ /***/ (function(module, __webpack_exports__, __webpack_require__) {
91
+
92
+ "use strict";
93
+ /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return normalizeComponent; });
94
+ /* globals __VUE_SSR_CONTEXT__ */
95
+
96
+ // IMPORTANT: Do NOT use ES2015 features in this file (except for modules).
97
+ // This module is a runtime utility for cleaner component module output and will
98
+ // be included in the final webpack user bundle.
99
+
100
+ function normalizeComponent(
101
+ scriptExports,
102
+ render,
103
+ staticRenderFns,
104
+ functionalTemplate,
105
+ injectStyles,
106
+ scopeId,
107
+ moduleIdentifier /* server only */,
108
+ shadowMode /* vue-cli only */
109
+ ) {
110
+ // Vue.extend constructor export interop
111
+ var options =
112
+ typeof scriptExports === 'function' ? scriptExports.options : scriptExports
113
+
114
+ // render functions
115
+ if (render) {
116
+ options.render = render
117
+ options.staticRenderFns = staticRenderFns
118
+ options._compiled = true
119
+ }
120
+
121
+ // functional template
122
+ if (functionalTemplate) {
123
+ options.functional = true
124
+ }
125
+
126
+ // scopedId
127
+ if (scopeId) {
128
+ options._scopeId = 'data-v-' + scopeId
129
+ }
130
+
131
+ var hook
132
+ if (moduleIdentifier) {
133
+ // server build
134
+ hook = function (context) {
135
+ // 2.3 injection
136
+ context =
137
+ context || // cached call
138
+ (this.$vnode && this.$vnode.ssrContext) || // stateful
139
+ (this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext) // functional
140
+ // 2.2 with runInNewContext: true
141
+ if (!context && typeof __VUE_SSR_CONTEXT__ !== 'undefined') {
142
+ context = __VUE_SSR_CONTEXT__
143
+ }
144
+ // inject component styles
145
+ if (injectStyles) {
146
+ injectStyles.call(this, context)
147
+ }
148
+ // register component module identifier for async chunk inferrence
149
+ if (context && context._registeredComponents) {
150
+ context._registeredComponents.add(moduleIdentifier)
151
+ }
152
+ }
153
+ // used by ssr in case component is cached and beforeCreate
154
+ // never gets called
155
+ options._ssrRegister = hook
156
+ } else if (injectStyles) {
157
+ hook = shadowMode
158
+ ? function () {
159
+ injectStyles.call(
160
+ this,
161
+ (options.functional ? this.parent : this).$root.$options.shadowRoot
162
+ )
163
+ }
164
+ : injectStyles
165
+ }
166
+
167
+ if (hook) {
168
+ if (options.functional) {
169
+ // for template-only hot-reload because in that case the render fn doesn't
170
+ // go through the normalizer
171
+ options._injectStyles = hook
172
+ // register for functional component in vue file
173
+ var originalRender = options.render
174
+ options.render = function renderWithStyleInjection(h, context) {
175
+ hook.call(context)
176
+ return originalRender(h, context)
177
+ }
178
+ } else {
179
+ // inject component registration as beforeCreate hook
180
+ var existing = options.beforeCreate
181
+ options.beforeCreate = existing ? [].concat(existing, hook) : [hook]
182
+ }
183
+ }
184
+
185
+ return {
186
+ exports: scriptExports,
187
+ options: options
188
+ }
189
+ }
190
+
191
+
192
+ /***/ }),
193
+ /* 1 */,
194
+ /* 2 */
195
+ /***/ (function(module, exports) {
196
+
197
+ module.exports = require("element-ui/lib/utils/dom");
198
+
199
+ /***/ }),
200
+ /* 3 */
201
+ /***/ (function(module, exports) {
202
+
203
+ module.exports = require("element-ui/lib/utils/util");
204
+
205
+ /***/ }),
206
+ /* 4 */,
207
+ /* 5 */
208
+ /***/ (function(module, exports) {
209
+
210
+ module.exports = require("element-ui/lib/utils/vue-popper");
211
+
212
+ /***/ }),
213
+ /* 6 */
214
+ /***/ (function(module, exports) {
215
+
216
+ module.exports = require("element-ui/lib/mixins/locale");
217
+
218
+ /***/ }),
219
+ /* 7 */
220
+ /***/ (function(module, exports) {
221
+
222
+ module.exports = require("vue");
223
+
224
+ /***/ }),
225
+ /* 8 */
226
+ /***/ (function(module, __webpack_exports__, __webpack_require__) {
227
+
228
+ "use strict";
229
+ /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "b", function() { return getCell; });
230
+ /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "i", function() { return orderBy; });
231
+ /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "d", function() { return getColumnById; });
232
+ /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "e", function() { return getColumnByKey; });
233
+ /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "c", function() { return getColumnByCell; });
234
+ /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "g", function() { return getRowIdentity; });
235
+ /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "f", function() { return getKeysMap; });
236
+ /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "h", function() { return mergeOptions; });
237
+ /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "l", function() { return parseWidth; });
238
+ /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "k", function() { return parseMinWidth; });
239
+ /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "j", function() { return parseHeight; });
240
+ /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "a", function() { return compose; });
241
+ /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "m", function() { return toggleRowStatus; });
242
+ /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "n", function() { return walkTreeNode; });
243
+ /* harmony import */ var element_ui_src_utils_util__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(3);
244
+ /* harmony import */ var element_ui_src_utils_util__WEBPACK_IMPORTED_MODULE_0___default = /*#__PURE__*/__webpack_require__.n(element_ui_src_utils_util__WEBPACK_IMPORTED_MODULE_0__);
245
+ var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; };
246
+
247
+
248
+
249
+ var getCell = function getCell(event) {
250
+ var cell = event.target;
251
+
252
+ while (cell && cell.tagName.toUpperCase() !== 'HTML') {
253
+ if (cell.tagName.toUpperCase() === 'TD') {
254
+ return cell;
255
+ }
256
+ cell = cell.parentNode;
257
+ }
258
+
259
+ return null;
260
+ };
261
+
262
+ var isObject = function isObject(obj) {
263
+ return obj !== null && (typeof obj === 'undefined' ? 'undefined' : _typeof(obj)) === 'object';
264
+ };
265
+
266
+ var orderBy = function orderBy(array, sortKey, reverse, sortMethod, sortBy) {
267
+ if (!sortKey && !sortMethod && (!sortBy || Array.isArray(sortBy) && !sortBy.length)) {
268
+ return array;
269
+ }
270
+ if (typeof reverse === 'string') {
271
+ reverse = reverse === 'descending' ? -1 : 1;
272
+ } else {
273
+ reverse = reverse && reverse < 0 ? -1 : 1;
274
+ }
275
+ var getKey = sortMethod ? null : function (value, index) {
276
+ if (sortBy) {
277
+ if (!Array.isArray(sortBy)) {
278
+ sortBy = [sortBy];
279
+ }
280
+ return sortBy.map(function (by) {
281
+ if (typeof by === 'string') {
282
+ return Object(element_ui_src_utils_util__WEBPACK_IMPORTED_MODULE_0__["getValueByPath"])(value, by);
283
+ } else {
284
+ return by(value, index, array);
285
+ }
286
+ });
287
+ }
288
+ if (sortKey !== '$key') {
289
+ if (isObject(value) && '$value' in value) value = value.$value;
290
+ }
291
+ return [isObject(value) ? Object(element_ui_src_utils_util__WEBPACK_IMPORTED_MODULE_0__["getValueByPath"])(value, sortKey) : value];
292
+ };
293
+ var compare = function compare(a, b) {
294
+ if (sortMethod) {
295
+ return sortMethod(a.value, b.value);
296
+ }
297
+ for (var i = 0, len = a.key.length; i < len; i++) {
298
+ if (a.key[i] < b.key[i]) {
299
+ return -1;
300
+ }
301
+ if (a.key[i] > b.key[i]) {
302
+ return 1;
303
+ }
304
+ }
305
+ return 0;
306
+ };
307
+ return array.map(function (value, index) {
308
+ return {
309
+ value: value,
310
+ index: index,
311
+ key: getKey ? getKey(value, index) : null
312
+ };
313
+ }).sort(function (a, b) {
314
+ var order = compare(a, b);
315
+ if (!order) {
316
+ // make stable https://en.wikipedia.org/wiki/Sorting_algorithm#Stability
317
+ order = a.index - b.index;
318
+ }
319
+ return order * reverse;
320
+ }).map(function (item) {
321
+ return item.value;
322
+ });
323
+ };
324
+
325
+ var getColumnById = function getColumnById(table, columnId) {
326
+ var column = null;
327
+ table.columns.forEach(function (item) {
328
+ if (item.id === columnId) {
329
+ column = item;
330
+ }
331
+ });
332
+ return column;
333
+ };
334
+
335
+ var getColumnByKey = function getColumnByKey(table, columnKey) {
336
+ var column = null;
337
+ for (var i = 0; i < table.columns.length; i++) {
338
+ var item = table.columns[i];
339
+ if (item.columnKey === columnKey) {
340
+ column = item;
341
+ break;
342
+ }
343
+ }
344
+ return column;
345
+ };
346
+
347
+ var getColumnByCell = function getColumnByCell(table, cell) {
348
+ var matches = (cell.className || '').match(/el-table_[^\s]+/gm);
349
+ if (matches) {
350
+ return getColumnById(table, matches[0]);
351
+ }
352
+ return null;
353
+ };
354
+
355
+ var getRowIdentity = function getRowIdentity(row, rowKey) {
356
+ if (!row) throw new Error('row is required when get row identity');
357
+ if (typeof rowKey === 'string') {
358
+ if (rowKey.indexOf('.') < 0) {
359
+ return row[rowKey];
360
+ }
361
+ var key = rowKey.split('.');
362
+ var current = row;
363
+ for (var i = 0; i < key.length; i++) {
364
+ current = current[key[i]];
365
+ }
366
+ return current;
367
+ } else if (typeof rowKey === 'function') {
368
+ return rowKey.call(null, row);
369
+ }
370
+ };
371
+
372
+ var getKeysMap = function getKeysMap(array, rowKey) {
373
+ var arrayMap = {};
374
+ (array || []).forEach(function (row, index) {
375
+ arrayMap[getRowIdentity(row, rowKey)] = { row: row, index: index };
376
+ });
377
+ return arrayMap;
378
+ };
379
+
380
+ function hasOwn(obj, key) {
381
+ return Object.prototype.hasOwnProperty.call(obj, key);
382
+ }
383
+
384
+ function mergeOptions(defaults, config) {
385
+ var options = {};
386
+ var key = void 0;
387
+ for (key in defaults) {
388
+ options[key] = defaults[key];
389
+ }
390
+ for (key in config) {
391
+ if (hasOwn(config, key)) {
392
+ var value = config[key];
393
+ if (typeof value !== 'undefined') {
394
+ options[key] = value;
395
+ }
396
+ }
397
+ }
398
+ return options;
399
+ }
400
+
401
+ function parseWidth(width) {
402
+ if (width !== undefined) {
403
+ width = parseInt(width, 10);
404
+ if (isNaN(width)) {
405
+ width = null;
406
+ }
407
+ }
408
+ return width;
409
+ }
410
+
411
+ function parseMinWidth(minWidth) {
412
+ if (typeof minWidth !== 'undefined') {
413
+ minWidth = parseWidth(minWidth);
414
+ if (isNaN(minWidth)) {
415
+ minWidth = 80;
416
+ }
417
+ }
418
+ return minWidth;
419
+ };
420
+
421
+ function parseHeight(height) {
422
+ if (typeof height === 'number') {
423
+ return height;
424
+ }
425
+ if (typeof height === 'string') {
426
+ if (/^\d+(?:px)?$/.test(height)) {
427
+ return parseInt(height, 10);
428
+ } else {
429
+ return height;
430
+ }
431
+ }
432
+ return null;
433
+ }
434
+
435
+ // https://github.com/reduxjs/redux/blob/master/src/compose.js
436
+ function compose() {
437
+ for (var _len = arguments.length, funcs = Array(_len), _key = 0; _key < _len; _key++) {
438
+ funcs[_key] = arguments[_key];
439
+ }
440
+
441
+ if (funcs.length === 0) {
442
+ return function (arg) {
443
+ return arg;
444
+ };
445
+ }
446
+ if (funcs.length === 1) {
447
+ return funcs[0];
448
+ }
449
+ return funcs.reduce(function (a, b) {
450
+ return function () {
451
+ return a(b.apply(undefined, arguments));
452
+ };
453
+ });
454
+ }
455
+
456
+ function toggleRowStatus(statusArr, row, newVal) {
457
+ var changed = false;
458
+ var index = statusArr.indexOf(row);
459
+ var included = index !== -1;
460
+
461
+ var addRow = function addRow() {
462
+ statusArr.push(row);
463
+ changed = true;
464
+ };
465
+ var removeRow = function removeRow() {
466
+ statusArr.splice(index, 1);
467
+ changed = true;
468
+ };
469
+
470
+ if (typeof newVal === 'boolean') {
471
+ if (newVal && !included) {
472
+ addRow();
473
+ } else if (!newVal && included) {
474
+ removeRow();
475
+ }
476
+ } else {
477
+ if (included) {
478
+ removeRow();
479
+ } else {
480
+ addRow();
481
+ }
482
+ }
483
+ return changed;
484
+ }
485
+
486
+ function walkTreeNode(root, cb) {
487
+ var childrenKey = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'children';
488
+ var lazyKey = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 'hasChildren';
489
+
490
+ var isNil = function isNil(array) {
491
+ return !(Array.isArray(array) && array.length);
492
+ };
493
+
494
+ function _walker(parent, children, level) {
495
+ cb(parent, children, level);
496
+ children.forEach(function (item) {
497
+ if (item[lazyKey]) {
498
+ cb(item, null, level + 1);
499
+ return;
500
+ }
501
+ var children = item[childrenKey];
502
+ if (!isNil(children)) {
503
+ _walker(item, children, level + 1);
504
+ }
505
+ });
506
+ }
507
+
508
+ root.forEach(function (item) {
509
+ if (item[lazyKey]) {
510
+ cb(item, null, 0);
511
+ return;
512
+ }
513
+ var children = item[childrenKey];
514
+ if (!isNil(children)) {
515
+ _walker(item, children, 0);
516
+ }
517
+ });
518
+ }
519
+
520
+ /***/ }),
521
+ /* 9 */
522
+ /***/ (function(module, exports) {
523
+
524
+ module.exports = require("element-ui/lib/utils/merge");
525
+
526
+ /***/ }),
527
+ /* 10 */,
528
+ /* 11 */
529
+ /***/ (function(module, exports) {
530
+
531
+ module.exports = require("element-ui/lib/mixins/migrating");
532
+
533
+ /***/ }),
534
+ /* 12 */
535
+ /***/ (function(module, exports) {
536
+
537
+ module.exports = require("element-ui/lib/utils/clickoutside");
538
+
539
+ /***/ }),
540
+ /* 13 */
541
+ /***/ (function(module, exports) {
542
+
543
+ module.exports = require("element-ui/lib/utils/popup");
544
+
545
+ /***/ }),
546
+ /* 14 */,
547
+ /* 15 */
548
+ /***/ (function(module, exports) {
549
+
550
+ module.exports = require("element-ui/lib/scrollbar");
551
+
552
+ /***/ }),
553
+ /* 16 */
554
+ /***/ (function(module, exports) {
555
+
556
+ module.exports = require("element-ui/lib/utils/resize-event");
557
+
558
+ /***/ }),
559
+ /* 17 */,
560
+ /* 18 */
561
+ /***/ (function(module, exports) {
562
+
563
+ module.exports = require("element-ui/lib/checkbox");
564
+
565
+ /***/ }),
566
+ /* 19 */
567
+ /***/ (function(module, exports) {
568
+
569
+ module.exports = require("throttle-debounce/debounce");
570
+
571
+ /***/ }),
572
+ /* 20 */,
573
+ /* 21 */,
574
+ /* 22 */,
575
+ /* 23 */,
576
+ /* 24 */,
577
+ /* 25 */,
578
+ /* 26 */,
579
+ /* 27 */,
580
+ /* 28 */,
581
+ /* 29 */
582
+ /***/ (function(module, exports) {
583
+
584
+ module.exports = require("element-ui/lib/tooltip");
585
+
586
+ /***/ }),
587
+ /* 30 */,
588
+ /* 31 */,
589
+ /* 32 */,
590
+ /* 33 */,
591
+ /* 34 */,
592
+ /* 35 */,
593
+ /* 36 */,
594
+ /* 37 */,
595
+ /* 38 */
596
+ /***/ (function(module, exports) {
597
+
598
+ module.exports = require("element-ui/lib/utils/scrollbar-width");
599
+
600
+ /***/ }),
601
+ /* 39 */
602
+ /***/ (function(module, exports) {
603
+
604
+ module.exports = require("element-ui/lib/checkbox-group");
605
+
606
+ /***/ }),
607
+ /* 40 */,
608
+ /* 41 */,
609
+ /* 42 */,
610
+ /* 43 */
611
+ /***/ (function(module, exports) {
612
+
613
+ module.exports = require("throttle-debounce");
614
+
615
+ /***/ }),
616
+ /* 44 */,
617
+ /* 45 */,
618
+ /* 46 */
619
+ /***/ (function(module, exports) {
620
+
621
+ module.exports = require("normalize-wheel");
622
+
623
+ /***/ }),
624
+ /* 47 */,
625
+ /* 48 */,
626
+ /* 49 */,
627
+ /* 50 */,
628
+ /* 51 */,
629
+ /* 52 */,
630
+ /* 53 */,
631
+ /* 54 */,
632
+ /* 55 */,
633
+ /* 56 */,
634
+ /* 57 */
635
+ /***/ (function(module, __webpack_exports__, __webpack_require__) {
636
+
637
+ "use strict";
638
+ // ESM COMPAT FLAG
639
+ __webpack_require__.r(__webpack_exports__);
640
+
641
+ // CONCATENATED MODULE: ./node_modules/_vue-loader@15.10.0@vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/_vue-loader@15.10.0@vue-loader/lib??vue-loader-options!./packages/table/src/table.vue?vue&type=template&id=61e75780&
642
+ var render = function () {
643
+ var _vm = this
644
+ var _h = _vm.$createElement
645
+ var _c = _vm._self._c || _h
646
+ return _c(
647
+ "div",
648
+ {
649
+ staticClass: "el-table",
650
+ class: [
651
+ {
652
+ "el-table--fit": _vm.fit,
653
+ "el-table--striped": _vm.stripe,
654
+ "el-table--border": _vm.border || _vm.isGroup,
655
+ "el-table--hidden": _vm.isHidden,
656
+ "el-table--group": _vm.isGroup,
657
+ "el-table--fluid-height": _vm.maxHeight,
658
+ "el-table--scrollable-x": _vm.layout.scrollX,
659
+ "el-table--scrollable-y": _vm.layout.scrollY,
660
+ "el-table--enable-row-hover": !_vm.store.states.isComplex,
661
+ "el-table--enable-row-transition":
662
+ (_vm.store.states.data || []).length !== 0 &&
663
+ (_vm.store.states.data || []).length < 100,
664
+ },
665
+ _vm.tableSize ? "el-table--" + _vm.tableSize : "",
666
+ ],
667
+ on: {
668
+ mouseleave: function ($event) {
669
+ _vm.handleMouseLeave($event)
670
+ },
671
+ },
672
+ },
673
+ [
674
+ _c(
675
+ "div",
676
+ { ref: "hiddenColumns", staticClass: "hidden-columns" },
677
+ [_vm._t("default")],
678
+ 2
679
+ ),
680
+ _vm.showHeader
681
+ ? _c(
682
+ "div",
683
+ {
684
+ directives: [
685
+ {
686
+ name: "mousewheel",
687
+ rawName: "v-mousewheel",
688
+ value: _vm.handleHeaderFooterMousewheel,
689
+ expression: "handleHeaderFooterMousewheel",
690
+ },
691
+ ],
692
+ ref: "headerWrapper",
693
+ staticClass: "el-table__header-wrapper",
694
+ },
695
+ [
696
+ _c("table-header", {
697
+ ref: "tableHeader",
698
+ style: {
699
+ width: _vm.layout.bodyWidth
700
+ ? _vm.layout.bodyWidth + "px"
701
+ : "",
702
+ },
703
+ attrs: {
704
+ store: _vm.store,
705
+ border: _vm.border,
706
+ "default-sort": _vm.defaultSort,
707
+ },
708
+ }),
709
+ ],
710
+ 1
711
+ )
712
+ : _vm._e(),
713
+ _c(
714
+ "div",
715
+ {
716
+ ref: "bodyWrapper",
717
+ staticClass: "el-table__body-wrapper",
718
+ class: [
719
+ _vm.layout.scrollX
720
+ ? "is-scrolling-" + _vm.scrollPosition
721
+ : "is-scrolling-none",
722
+ ],
723
+ style: [_vm.bodyHeight],
724
+ },
725
+ [
726
+ _c("table-body", {
727
+ style: {
728
+ width: _vm.bodyWidth,
729
+ },
730
+ attrs: {
731
+ context: _vm.context,
732
+ store: _vm.store,
733
+ stripe: _vm.stripe,
734
+ "row-class-name": _vm.rowClassName,
735
+ "row-style": _vm.rowStyle,
736
+ highlight: _vm.highlightCurrentRow,
737
+ },
738
+ }),
739
+ !_vm.data || _vm.data.length === 0
740
+ ? _c(
741
+ "div",
742
+ {
743
+ ref: "emptyBlock",
744
+ staticClass: "el-table__empty-block",
745
+ style: _vm.emptyBlockStyle,
746
+ },
747
+ [
748
+ _c(
749
+ "span",
750
+ { staticClass: "el-table__empty-text" },
751
+ [
752
+ _vm._t("empty", [
753
+ _vm._v(
754
+ _vm._s(_vm.emptyText || _vm.t("el.table.emptyText"))
755
+ ),
756
+ ]),
757
+ ],
758
+ 2
759
+ ),
760
+ ]
761
+ )
762
+ : _vm._e(),
763
+ _vm.$slots.append
764
+ ? _c(
765
+ "div",
766
+ {
767
+ ref: "appendWrapper",
768
+ staticClass: "el-table__append-wrapper",
769
+ },
770
+ [_vm._t("append")],
771
+ 2
772
+ )
773
+ : _vm._e(),
774
+ ],
775
+ 1
776
+ ),
777
+ _vm.showSummary
778
+ ? _c(
779
+ "div",
780
+ {
781
+ directives: [
782
+ {
783
+ name: "show",
784
+ rawName: "v-show",
785
+ value: _vm.data && _vm.data.length > 0,
786
+ expression: "data && data.length > 0",
787
+ },
788
+ {
789
+ name: "mousewheel",
790
+ rawName: "v-mousewheel",
791
+ value: _vm.handleHeaderFooterMousewheel,
792
+ expression: "handleHeaderFooterMousewheel",
793
+ },
794
+ ],
795
+ ref: "footerWrapper",
796
+ staticClass: "el-table__footer-wrapper",
797
+ },
798
+ [
799
+ _c("table-footer", {
800
+ style: {
801
+ width: _vm.layout.bodyWidth
802
+ ? _vm.layout.bodyWidth + "px"
803
+ : "",
804
+ },
805
+ attrs: {
806
+ store: _vm.store,
807
+ border: _vm.border,
808
+ "sum-text": _vm.sumText || _vm.t("el.table.sumText"),
809
+ "summary-method": _vm.summaryMethod,
810
+ "default-sort": _vm.defaultSort,
811
+ },
812
+ }),
813
+ ],
814
+ 1
815
+ )
816
+ : _vm._e(),
817
+ _vm.fixedColumns.length > 0
818
+ ? _c(
819
+ "div",
820
+ {
821
+ directives: [
822
+ {
823
+ name: "mousewheel",
824
+ rawName: "v-mousewheel",
825
+ value: _vm.handleFixedMousewheel,
826
+ expression: "handleFixedMousewheel",
827
+ },
828
+ ],
829
+ ref: "fixedWrapper",
830
+ staticClass: "el-table__fixed",
831
+ style: [
832
+ {
833
+ width: _vm.layout.fixedWidth
834
+ ? _vm.layout.fixedWidth + "px"
835
+ : "",
836
+ },
837
+ _vm.fixedHeight,
838
+ ],
839
+ },
840
+ [
841
+ _vm.showHeader
842
+ ? _c(
843
+ "div",
844
+ {
845
+ ref: "fixedHeaderWrapper",
846
+ staticClass: "el-table__fixed-header-wrapper",
847
+ },
848
+ [
849
+ _c("table-header", {
850
+ ref: "fixedTableHeader",
851
+ style: {
852
+ width: _vm.bodyWidth,
853
+ },
854
+ attrs: {
855
+ fixed: "left",
856
+ border: _vm.border,
857
+ store: _vm.store,
858
+ },
859
+ }),
860
+ ],
861
+ 1
862
+ )
863
+ : _vm._e(),
864
+ _c(
865
+ "div",
866
+ {
867
+ ref: "fixedBodyWrapper",
868
+ staticClass: "el-table__fixed-body-wrapper",
869
+ style: [
870
+ {
871
+ top: _vm.layout.headerHeight + "px",
872
+ },
873
+ _vm.fixedBodyHeight,
874
+ ],
875
+ },
876
+ [
877
+ _c("table-body", {
878
+ style: {
879
+ width: _vm.bodyWidth,
880
+ },
881
+ attrs: {
882
+ fixed: "left",
883
+ store: _vm.store,
884
+ stripe: _vm.stripe,
885
+ highlight: _vm.highlightCurrentRow,
886
+ "row-class-name": _vm.rowClassName,
887
+ "row-style": _vm.rowStyle,
888
+ },
889
+ }),
890
+ _vm.$slots.append
891
+ ? _c("div", {
892
+ staticClass: "el-table__append-gutter",
893
+ style: { height: _vm.layout.appendHeight + "px" },
894
+ })
895
+ : _vm._e(),
896
+ ],
897
+ 1
898
+ ),
899
+ _vm.showSummary
900
+ ? _c(
901
+ "div",
902
+ {
903
+ directives: [
904
+ {
905
+ name: "show",
906
+ rawName: "v-show",
907
+ value: _vm.data && _vm.data.length > 0,
908
+ expression: "data && data.length > 0",
909
+ },
910
+ ],
911
+ ref: "fixedFooterWrapper",
912
+ staticClass: "el-table__fixed-footer-wrapper",
913
+ },
914
+ [
915
+ _c("table-footer", {
916
+ style: {
917
+ width: _vm.bodyWidth,
918
+ },
919
+ attrs: {
920
+ fixed: "left",
921
+ border: _vm.border,
922
+ "sum-text": _vm.sumText || _vm.t("el.table.sumText"),
923
+ "summary-method": _vm.summaryMethod,
924
+ store: _vm.store,
925
+ },
926
+ }),
927
+ ],
928
+ 1
929
+ )
930
+ : _vm._e(),
931
+ ]
932
+ )
933
+ : _vm._e(),
934
+ _vm.rightFixedColumns.length > 0
935
+ ? _c(
936
+ "div",
937
+ {
938
+ directives: [
939
+ {
940
+ name: "mousewheel",
941
+ rawName: "v-mousewheel",
942
+ value: _vm.handleFixedMousewheel,
943
+ expression: "handleFixedMousewheel",
944
+ },
945
+ ],
946
+ ref: "rightFixedWrapper",
947
+ staticClass: "el-table__fixed-right",
948
+ style: [
949
+ {
950
+ width: _vm.layout.rightFixedWidth
951
+ ? _vm.layout.rightFixedWidth + "px"
952
+ : "",
953
+ right: _vm.layout.scrollY
954
+ ? (_vm.border
955
+ ? _vm.layout.gutterWidth
956
+ : _vm.layout.gutterWidth || 0) + "px"
957
+ : "",
958
+ },
959
+ _vm.fixedHeight,
960
+ ],
961
+ },
962
+ [
963
+ _vm.showHeader
964
+ ? _c(
965
+ "div",
966
+ {
967
+ ref: "rightFixedHeaderWrapper",
968
+ staticClass: "el-table__fixed-header-wrapper",
969
+ },
970
+ [
971
+ _c("table-header", {
972
+ ref: "rightFixedTableHeader",
973
+ style: {
974
+ width: _vm.bodyWidth,
975
+ },
976
+ attrs: {
977
+ fixed: "right",
978
+ border: _vm.border,
979
+ store: _vm.store,
980
+ },
981
+ }),
982
+ ],
983
+ 1
984
+ )
985
+ : _vm._e(),
986
+ _c(
987
+ "div",
988
+ {
989
+ ref: "rightFixedBodyWrapper",
990
+ staticClass: "el-table__fixed-body-wrapper",
991
+ style: [
992
+ {
993
+ top: _vm.layout.headerHeight + "px",
994
+ },
995
+ _vm.fixedBodyHeight,
996
+ ],
997
+ },
998
+ [
999
+ _c("table-body", {
1000
+ style: {
1001
+ width: _vm.bodyWidth,
1002
+ },
1003
+ attrs: {
1004
+ fixed: "right",
1005
+ store: _vm.store,
1006
+ stripe: _vm.stripe,
1007
+ "row-class-name": _vm.rowClassName,
1008
+ "row-style": _vm.rowStyle,
1009
+ highlight: _vm.highlightCurrentRow,
1010
+ },
1011
+ }),
1012
+ _vm.$slots.append
1013
+ ? _c("div", {
1014
+ staticClass: "el-table__append-gutter",
1015
+ style: { height: _vm.layout.appendHeight + "px" },
1016
+ })
1017
+ : _vm._e(),
1018
+ ],
1019
+ 1
1020
+ ),
1021
+ _vm.showSummary
1022
+ ? _c(
1023
+ "div",
1024
+ {
1025
+ directives: [
1026
+ {
1027
+ name: "show",
1028
+ rawName: "v-show",
1029
+ value: _vm.data && _vm.data.length > 0,
1030
+ expression: "data && data.length > 0",
1031
+ },
1032
+ ],
1033
+ ref: "rightFixedFooterWrapper",
1034
+ staticClass: "el-table__fixed-footer-wrapper",
1035
+ },
1036
+ [
1037
+ _c("table-footer", {
1038
+ style: {
1039
+ width: _vm.bodyWidth,
1040
+ },
1041
+ attrs: {
1042
+ fixed: "right",
1043
+ border: _vm.border,
1044
+ "sum-text": _vm.sumText || _vm.t("el.table.sumText"),
1045
+ "summary-method": _vm.summaryMethod,
1046
+ store: _vm.store,
1047
+ },
1048
+ }),
1049
+ ],
1050
+ 1
1051
+ )
1052
+ : _vm._e(),
1053
+ ]
1054
+ )
1055
+ : _vm._e(),
1056
+ _vm.rightFixedColumns.length > 0
1057
+ ? _c("div", {
1058
+ ref: "rightFixedPatch",
1059
+ staticClass: "el-table__fixed-right-patch",
1060
+ style: {
1061
+ width: _vm.layout.scrollY ? _vm.layout.gutterWidth + "px" : "0",
1062
+ height: _vm.layout.headerHeight + "px",
1063
+ },
1064
+ })
1065
+ : _vm._e(),
1066
+ _c("div", {
1067
+ directives: [
1068
+ {
1069
+ name: "show",
1070
+ rawName: "v-show",
1071
+ value: _vm.resizeProxyVisible,
1072
+ expression: "resizeProxyVisible",
1073
+ },
1074
+ ],
1075
+ ref: "resizeProxy",
1076
+ staticClass: "el-table__column-resize-proxy",
1077
+ }),
1078
+ ]
1079
+ )
1080
+ }
1081
+ var staticRenderFns = []
1082
+ render._withStripped = true
1083
+
1084
+
1085
+ // CONCATENATED MODULE: ./packages/table/src/table.vue?vue&type=template&id=61e75780&
1086
+
1087
+ // EXTERNAL MODULE: external "element-ui/lib/checkbox"
1088
+ var checkbox_ = __webpack_require__(18);
1089
+ var checkbox_default = /*#__PURE__*/__webpack_require__.n(checkbox_);
1090
+
1091
+ // EXTERNAL MODULE: external "throttle-debounce"
1092
+ var external_throttle_debounce_ = __webpack_require__(43);
1093
+
1094
+ // EXTERNAL MODULE: external "element-ui/lib/utils/resize-event"
1095
+ var resize_event_ = __webpack_require__(16);
1096
+
1097
+ // EXTERNAL MODULE: external "normalize-wheel"
1098
+ var external_normalize_wheel_ = __webpack_require__(46);
1099
+ var external_normalize_wheel_default = /*#__PURE__*/__webpack_require__.n(external_normalize_wheel_);
1100
+
1101
+ // CONCATENATED MODULE: ./src/directives/mousewheel.js
1102
+
1103
+
1104
+ var isFirefox = typeof navigator !== 'undefined' && navigator.userAgent.toLowerCase().indexOf('firefox') > -1;
1105
+
1106
+ var mousewheel_mousewheel = function mousewheel(element, callback) {
1107
+ if (element && element.addEventListener) {
1108
+ element.addEventListener(isFirefox ? 'DOMMouseScroll' : 'mousewheel', function (event) {
1109
+ var normalized = external_normalize_wheel_default()(event);
1110
+ callback && callback.apply(this, [event, normalized]);
1111
+ });
1112
+ }
1113
+ };
1114
+
1115
+ /* harmony default export */ var directives_mousewheel = ({
1116
+ bind: function bind(el, binding) {
1117
+ mousewheel_mousewheel(el, binding.value);
1118
+ }
1119
+ });
1120
+ // EXTERNAL MODULE: external "element-ui/lib/mixins/locale"
1121
+ var locale_ = __webpack_require__(6);
1122
+ var locale_default = /*#__PURE__*/__webpack_require__.n(locale_);
1123
+
1124
+ // EXTERNAL MODULE: external "element-ui/lib/mixins/migrating"
1125
+ var migrating_ = __webpack_require__(11);
1126
+ var migrating_default = /*#__PURE__*/__webpack_require__.n(migrating_);
1127
+
1128
+ // EXTERNAL MODULE: external "vue"
1129
+ var external_vue_ = __webpack_require__(7);
1130
+ var external_vue_default = /*#__PURE__*/__webpack_require__.n(external_vue_);
1131
+
1132
+ // EXTERNAL MODULE: external "element-ui/lib/utils/merge"
1133
+ var merge_ = __webpack_require__(9);
1134
+ var merge_default = /*#__PURE__*/__webpack_require__.n(merge_);
1135
+
1136
+ // EXTERNAL MODULE: ./packages/table/src/util.js
1137
+ var util = __webpack_require__(8);
1138
+
1139
+ // CONCATENATED MODULE: ./packages/table/src/store/expand.js
1140
+
1141
+
1142
+ /* harmony default export */ var expand = ({
1143
+ data: function data() {
1144
+ return {
1145
+ states: {
1146
+ defaultExpandAll: false,
1147
+ expandRows: []
1148
+ }
1149
+ };
1150
+ },
1151
+
1152
+
1153
+ methods: {
1154
+ updateExpandRows: function updateExpandRows() {
1155
+ var _states = this.states,
1156
+ _states$data = _states.data,
1157
+ data = _states$data === undefined ? [] : _states$data,
1158
+ rowKey = _states.rowKey,
1159
+ defaultExpandAll = _states.defaultExpandAll,
1160
+ expandRows = _states.expandRows;
1161
+
1162
+ if (defaultExpandAll) {
1163
+ this.states.expandRows = data.slice();
1164
+ } else if (rowKey) {
1165
+ // TODO:这里的代码可以优化
1166
+ var expandRowsMap = Object(util["f" /* getKeysMap */])(expandRows, rowKey);
1167
+ this.states.expandRows = data.reduce(function (prev, row) {
1168
+ var rowId = Object(util["g" /* getRowIdentity */])(row, rowKey);
1169
+ var rowInfo = expandRowsMap[rowId];
1170
+ if (rowInfo) {
1171
+ prev.push(row);
1172
+ }
1173
+ return prev;
1174
+ }, []);
1175
+ } else {
1176
+ this.states.expandRows = [];
1177
+ }
1178
+ },
1179
+ toggleRowExpansion: function toggleRowExpansion(row, expanded) {
1180
+ var changed = Object(util["m" /* toggleRowStatus */])(this.states.expandRows, row, expanded);
1181
+ if (changed) {
1182
+ this.table.$emit('expand-change', row, this.states.expandRows.slice());
1183
+ this.scheduleLayout();
1184
+ }
1185
+ },
1186
+ setExpandRowKeys: function setExpandRowKeys(rowKeys) {
1187
+ this.assertRowKey();
1188
+ // TODO:这里的代码可以优化
1189
+ var _states2 = this.states,
1190
+ data = _states2.data,
1191
+ rowKey = _states2.rowKey;
1192
+
1193
+ var keysMap = Object(util["f" /* getKeysMap */])(data, rowKey);
1194
+ this.states.expandRows = rowKeys.reduce(function (prev, cur) {
1195
+ var info = keysMap[cur];
1196
+ if (info) {
1197
+ prev.push(info.row);
1198
+ }
1199
+ return prev;
1200
+ }, []);
1201
+ },
1202
+ isRowExpanded: function isRowExpanded(row) {
1203
+ var _states3 = this.states,
1204
+ _states3$expandRows = _states3.expandRows,
1205
+ expandRows = _states3$expandRows === undefined ? [] : _states3$expandRows,
1206
+ rowKey = _states3.rowKey;
1207
+
1208
+ if (rowKey) {
1209
+ var expandMap = Object(util["f" /* getKeysMap */])(expandRows, rowKey);
1210
+ return !!expandMap[Object(util["g" /* getRowIdentity */])(row, rowKey)];
1211
+ }
1212
+ return expandRows.indexOf(row) !== -1;
1213
+ }
1214
+ }
1215
+ });
1216
+ // EXTERNAL MODULE: external "element-ui/lib/utils/util"
1217
+ var util_ = __webpack_require__(3);
1218
+
1219
+ // CONCATENATED MODULE: ./packages/table/src/store/current.js
1220
+
1221
+
1222
+
1223
+ /* harmony default export */ var current = ({
1224
+ data: function data() {
1225
+ return {
1226
+ states: {
1227
+ // 不可响应的,设置 currentRowKey 时,data 不一定存在,也许无法算出正确的 currentRow
1228
+ // 把该值缓存一下,当用户点击修改 currentRow 时,把该值重置为 null
1229
+ _currentRowKey: null,
1230
+ currentRow: null
1231
+ }
1232
+ };
1233
+ },
1234
+
1235
+
1236
+ methods: {
1237
+ setCurrentRowKey: function setCurrentRowKey(key) {
1238
+ this.assertRowKey();
1239
+ this.states._currentRowKey = key;
1240
+ this.setCurrentRowByKey(key);
1241
+ },
1242
+ restoreCurrentRowKey: function restoreCurrentRowKey() {
1243
+ this.states._currentRowKey = null;
1244
+ },
1245
+ setCurrentRowByKey: function setCurrentRowByKey(key) {
1246
+ var states = this.states;
1247
+ var _states$data = states.data,
1248
+ data = _states$data === undefined ? [] : _states$data,
1249
+ rowKey = states.rowKey;
1250
+
1251
+ var currentRow = null;
1252
+ if (rowKey) {
1253
+ currentRow = Object(util_["arrayFind"])(data, function (item) {
1254
+ return Object(util["g" /* getRowIdentity */])(item, rowKey) === key;
1255
+ });
1256
+ }
1257
+ states.currentRow = currentRow;
1258
+ },
1259
+ updateCurrentRow: function updateCurrentRow(currentRow) {
1260
+ var states = this.states,
1261
+ table = this.table;
1262
+
1263
+ var oldCurrentRow = states.currentRow;
1264
+ if (currentRow && currentRow !== oldCurrentRow) {
1265
+ states.currentRow = currentRow;
1266
+ table.$emit('current-change', currentRow, oldCurrentRow);
1267
+ return;
1268
+ }
1269
+ if (!currentRow && oldCurrentRow) {
1270
+ states.currentRow = null;
1271
+ table.$emit('current-change', null, oldCurrentRow);
1272
+ }
1273
+ },
1274
+ updateCurrentRowData: function updateCurrentRowData() {
1275
+ var states = this.states,
1276
+ table = this.table;
1277
+ var rowKey = states.rowKey,
1278
+ _currentRowKey = states._currentRowKey;
1279
+ // data 为 null 时,解构时的默认值会被忽略
1280
+
1281
+ var data = states.data || [];
1282
+ var oldCurrentRow = states.currentRow;
1283
+
1284
+ // 当 currentRow 不在 data 中时尝试更新数据
1285
+ if (data.indexOf(oldCurrentRow) === -1 && oldCurrentRow) {
1286
+ if (rowKey) {
1287
+ var currentRowKey = Object(util["g" /* getRowIdentity */])(oldCurrentRow, rowKey);
1288
+ this.setCurrentRowByKey(currentRowKey);
1289
+ } else {
1290
+ states.currentRow = null;
1291
+ }
1292
+ if (states.currentRow === null) {
1293
+ table.$emit('current-change', null, oldCurrentRow);
1294
+ }
1295
+ } else if (_currentRowKey) {
1296
+ // 把初始时下设置的 rowKey 转化成 rowData
1297
+ this.setCurrentRowByKey(_currentRowKey);
1298
+ this.restoreCurrentRowKey();
1299
+ }
1300
+ }
1301
+ }
1302
+ });
1303
+ // CONCATENATED MODULE: ./packages/table/src/store/tree.js
1304
+ var _extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
1305
+
1306
+
1307
+
1308
+ /* harmony default export */ var tree = ({
1309
+ data: function data() {
1310
+ return {
1311
+ states: {
1312
+ // defaultExpandAll 存在于 expand.js 中,这里不重复添加
1313
+ // 在展开行中,expandRowKeys 会被转化成 expandRows,expandRowKeys 这个属性只是记录了 TreeTable 行的展开
1314
+ // TODO: 拆分为独立的 TreeTable,统一用法
1315
+ expandRowKeys: [],
1316
+ treeData: {},
1317
+ indent: 16,
1318
+ lazy: false,
1319
+ lazyTreeNodeMap: {},
1320
+ lazyColumnIdentifier: 'hasChildren',
1321
+ childrenColumnName: 'children'
1322
+ }
1323
+ };
1324
+ },
1325
+
1326
+
1327
+ computed: {
1328
+ // 嵌入型的数据,watch 无法是检测到变化 https://github.com/ElemeFE/element/issues/14998
1329
+ // TODO: 使用 computed 解决该问题,是否会造成性能问题?
1330
+ // @return { id: { level, children } }
1331
+ normalizedData: function normalizedData() {
1332
+ if (!this.states.rowKey) return {};
1333
+ var data = this.states.data || [];
1334
+ return this.normalize(data);
1335
+ },
1336
+
1337
+ // @return { id: { children } }
1338
+ // 针对懒加载的情形,不处理嵌套数据
1339
+ normalizedLazyNode: function normalizedLazyNode() {
1340
+ var _states = this.states,
1341
+ rowKey = _states.rowKey,
1342
+ lazyTreeNodeMap = _states.lazyTreeNodeMap,
1343
+ lazyColumnIdentifier = _states.lazyColumnIdentifier;
1344
+
1345
+ var keys = Object.keys(lazyTreeNodeMap);
1346
+ var res = {};
1347
+ if (!keys.length) return res;
1348
+ keys.forEach(function (key) {
1349
+ if (lazyTreeNodeMap[key].length) {
1350
+ var item = { children: [] };
1351
+ lazyTreeNodeMap[key].forEach(function (row) {
1352
+ var currentRowKey = Object(util["g" /* getRowIdentity */])(row, rowKey);
1353
+ item.children.push(currentRowKey);
1354
+ if (row[lazyColumnIdentifier] && !res[currentRowKey]) {
1355
+ res[currentRowKey] = { children: [] };
1356
+ }
1357
+ });
1358
+ res[key] = item;
1359
+ }
1360
+ });
1361
+ return res;
1362
+ }
1363
+ },
1364
+
1365
+ watch: {
1366
+ normalizedData: 'updateTreeData',
1367
+ normalizedLazyNode: 'updateTreeData'
1368
+ },
1369
+
1370
+ methods: {
1371
+ normalize: function normalize(data) {
1372
+ var _states2 = this.states,
1373
+ childrenColumnName = _states2.childrenColumnName,
1374
+ lazyColumnIdentifier = _states2.lazyColumnIdentifier,
1375
+ rowKey = _states2.rowKey,
1376
+ lazy = _states2.lazy;
1377
+
1378
+ var res = {};
1379
+ Object(util["n" /* walkTreeNode */])(data, function (parent, children, level) {
1380
+ var parentId = Object(util["g" /* getRowIdentity */])(parent, rowKey);
1381
+ if (Array.isArray(children)) {
1382
+ res[parentId] = {
1383
+ children: children.map(function (row) {
1384
+ return Object(util["g" /* getRowIdentity */])(row, rowKey);
1385
+ }),
1386
+ level: level
1387
+ };
1388
+ } else if (lazy) {
1389
+ // 当 children 不存在且 lazy 为 true,该节点即为懒加载的节点
1390
+ res[parentId] = {
1391
+ children: [],
1392
+ lazy: true,
1393
+ level: level
1394
+ };
1395
+ }
1396
+ }, childrenColumnName, lazyColumnIdentifier);
1397
+ return res;
1398
+ },
1399
+ updateTreeData: function updateTreeData() {
1400
+ var nested = this.normalizedData;
1401
+ var normalizedLazyNode = this.normalizedLazyNode;
1402
+ var keys = Object.keys(nested);
1403
+ var newTreeData = {};
1404
+ if (keys.length) {
1405
+ var _states3 = this.states,
1406
+ oldTreeData = _states3.treeData,
1407
+ defaultExpandAll = _states3.defaultExpandAll,
1408
+ expandRowKeys = _states3.expandRowKeys,
1409
+ lazy = _states3.lazy;
1410
+
1411
+ var rootLazyRowKeys = [];
1412
+ var getExpanded = function getExpanded(oldValue, key) {
1413
+ var included = defaultExpandAll || expandRowKeys && expandRowKeys.indexOf(key) !== -1;
1414
+ return !!(oldValue && oldValue.expanded || included);
1415
+ };
1416
+ // 合并 expanded 与 display,确保数据刷新后,状态不变
1417
+ keys.forEach(function (key) {
1418
+ var oldValue = oldTreeData[key];
1419
+ var newValue = _extends({}, nested[key]);
1420
+ newValue.expanded = getExpanded(oldValue, key);
1421
+ if (newValue.lazy) {
1422
+ var _ref = oldValue || {},
1423
+ _ref$loaded = _ref.loaded,
1424
+ loaded = _ref$loaded === undefined ? false : _ref$loaded,
1425
+ _ref$loading = _ref.loading,
1426
+ loading = _ref$loading === undefined ? false : _ref$loading;
1427
+
1428
+ newValue.loaded = !!loaded;
1429
+ newValue.loading = !!loading;
1430
+ rootLazyRowKeys.push(key);
1431
+ }
1432
+ newTreeData[key] = newValue;
1433
+ });
1434
+ // 根据懒加载数据更新 treeData
1435
+ var lazyKeys = Object.keys(normalizedLazyNode);
1436
+ if (lazy && lazyKeys.length && rootLazyRowKeys.length) {
1437
+ lazyKeys.forEach(function (key) {
1438
+ var oldValue = oldTreeData[key];
1439
+ var lazyNodeChildren = normalizedLazyNode[key].children;
1440
+ if (rootLazyRowKeys.indexOf(key) !== -1) {
1441
+ // 懒加载的 root 节点,更新一下原有的数据,原来的 children 一定是空数组
1442
+ if (newTreeData[key].children.length !== 0) {
1443
+ throw new Error('[ElTable]children must be an empty array.');
1444
+ }
1445
+ newTreeData[key].children = lazyNodeChildren;
1446
+ } else {
1447
+ var _ref2 = oldValue || {},
1448
+ _ref2$loaded = _ref2.loaded,
1449
+ loaded = _ref2$loaded === undefined ? false : _ref2$loaded,
1450
+ _ref2$loading = _ref2.loading,
1451
+ loading = _ref2$loading === undefined ? false : _ref2$loading;
1452
+
1453
+ newTreeData[key] = {
1454
+ lazy: true,
1455
+ loaded: !!loaded,
1456
+ loading: !!loading,
1457
+ expanded: getExpanded(oldValue, key),
1458
+ children: lazyNodeChildren,
1459
+ level: ''
1460
+ };
1461
+ }
1462
+ });
1463
+ }
1464
+ }
1465
+ this.states.treeData = newTreeData;
1466
+ this.updateTableScrollY();
1467
+ },
1468
+ updateTreeExpandKeys: function updateTreeExpandKeys(value) {
1469
+ this.states.expandRowKeys = value;
1470
+ this.updateTreeData();
1471
+ },
1472
+ toggleTreeExpansion: function toggleTreeExpansion(row, expanded) {
1473
+ this.assertRowKey();
1474
+
1475
+ var _states4 = this.states,
1476
+ rowKey = _states4.rowKey,
1477
+ treeData = _states4.treeData;
1478
+
1479
+ var id = Object(util["g" /* getRowIdentity */])(row, rowKey);
1480
+ var data = id && treeData[id];
1481
+ if (id && data && 'expanded' in data) {
1482
+ var oldExpanded = data.expanded;
1483
+ expanded = typeof expanded === 'undefined' ? !data.expanded : expanded;
1484
+ treeData[id].expanded = expanded;
1485
+ if (oldExpanded !== expanded) {
1486
+ this.table.$emit('expand-change', row, expanded);
1487
+ }
1488
+ this.updateTableScrollY();
1489
+ }
1490
+ },
1491
+ loadOrToggle: function loadOrToggle(row) {
1492
+ this.assertRowKey();
1493
+ var _states5 = this.states,
1494
+ lazy = _states5.lazy,
1495
+ treeData = _states5.treeData,
1496
+ rowKey = _states5.rowKey;
1497
+
1498
+ var id = Object(util["g" /* getRowIdentity */])(row, rowKey);
1499
+ var data = treeData[id];
1500
+ if (lazy && data && 'loaded' in data && !data.loaded) {
1501
+ this.loadData(row, id, data);
1502
+ } else {
1503
+ this.toggleTreeExpansion(row);
1504
+ }
1505
+ },
1506
+ loadData: function loadData(row, key, treeNode) {
1507
+ var _this = this;
1508
+
1509
+ var load = this.table.load;
1510
+ var rawTreeData = this.states.treeData;
1511
+
1512
+ if (load && !rawTreeData[key].loaded) {
1513
+ rawTreeData[key].loading = true;
1514
+ load(row, treeNode, function (data) {
1515
+ if (!Array.isArray(data)) {
1516
+ throw new Error('[ElTable] data must be an array');
1517
+ }
1518
+ var _states6 = _this.states,
1519
+ lazyTreeNodeMap = _states6.lazyTreeNodeMap,
1520
+ treeData = _states6.treeData;
1521
+
1522
+ treeData[key].loading = false;
1523
+ treeData[key].loaded = true;
1524
+ treeData[key].expanded = true;
1525
+ if (data.length) {
1526
+ _this.$set(lazyTreeNodeMap, key, data);
1527
+ }
1528
+ _this.table.$emit('expand-change', row, true);
1529
+ });
1530
+ }
1531
+ }
1532
+ }
1533
+ });
1534
+ // CONCATENATED MODULE: ./packages/table/src/store/watcher.js
1535
+
1536
+
1537
+
1538
+
1539
+
1540
+
1541
+
1542
+ var watcher_sortData = function sortData(data, states) {
1543
+ var sortingColumn = states.sortingColumn;
1544
+ if (!sortingColumn || typeof sortingColumn.sortable === 'string') {
1545
+ return data;
1546
+ }
1547
+ return Object(util["i" /* orderBy */])(data, states.sortProp, states.sortOrder, sortingColumn.sortMethod, sortingColumn.sortBy);
1548
+ };
1549
+
1550
+ var doFlattenColumns = function doFlattenColumns(columns) {
1551
+ var result = [];
1552
+ columns.forEach(function (column) {
1553
+ if (column.children) {
1554
+ result.push.apply(result, doFlattenColumns(column.children));
1555
+ } else {
1556
+ result.push(column);
1557
+ }
1558
+ });
1559
+ return result;
1560
+ };
1561
+
1562
+ /* harmony default export */ var watcher = (external_vue_default.a.extend({
1563
+ data: function data() {
1564
+ return {
1565
+ states: {
1566
+ // 3.0 版本后要求必须设置该属性
1567
+ rowKey: null,
1568
+
1569
+ // 渲染的数据来源,是对 table 中的 data 过滤排序后的结果
1570
+ data: [],
1571
+
1572
+ // 是否包含固定列
1573
+ isComplex: false,
1574
+
1575
+ // 列
1576
+ _columns: [], // 不可响应的
1577
+ originColumns: [],
1578
+ columns: [],
1579
+ fixedColumns: [],
1580
+ rightFixedColumns: [],
1581
+ leafColumns: [],
1582
+ fixedLeafColumns: [],
1583
+ rightFixedLeafColumns: [],
1584
+ leafColumnsLength: 0,
1585
+ fixedLeafColumnsLength: 0,
1586
+ rightFixedLeafColumnsLength: 0,
1587
+
1588
+ // 选择
1589
+ isAllSelected: false,
1590
+ selection: [],
1591
+ reserveSelection: false,
1592
+ selectOnIndeterminate: false,
1593
+ selectable: null,
1594
+
1595
+ // 过滤
1596
+ filters: {}, // 不可响应的
1597
+ filteredData: null,
1598
+
1599
+ // 排序
1600
+ sortingColumn: null,
1601
+ sortProp: null,
1602
+ sortOrder: null,
1603
+
1604
+ hoverRow: null
1605
+ }
1606
+ };
1607
+ },
1608
+
1609
+
1610
+ mixins: [expand, current, tree],
1611
+
1612
+ methods: {
1613
+ // 检查 rowKey 是否存在
1614
+ assertRowKey: function assertRowKey() {
1615
+ var rowKey = this.states.rowKey;
1616
+ if (!rowKey) throw new Error('[ElTable] prop row-key is required');
1617
+ },
1618
+
1619
+
1620
+ // 更新列
1621
+ updateColumns: function updateColumns() {
1622
+ var states = this.states;
1623
+ var _columns = states._columns || [];
1624
+ states.fixedColumns = _columns.filter(function (column) {
1625
+ return column.fixed === true || column.fixed === 'left';
1626
+ });
1627
+ states.rightFixedColumns = _columns.filter(function (column) {
1628
+ return column.fixed === 'right';
1629
+ });
1630
+
1631
+ if (states.fixedColumns.length > 0 && _columns[0] && _columns[0].type === 'selection' && !_columns[0].fixed) {
1632
+ _columns[0].fixed = true;
1633
+ states.fixedColumns.unshift(_columns[0]);
1634
+ }
1635
+
1636
+ var notFixedColumns = _columns.filter(function (column) {
1637
+ return !column.fixed;
1638
+ });
1639
+ states.originColumns = [].concat(states.fixedColumns).concat(notFixedColumns).concat(states.rightFixedColumns);
1640
+
1641
+ var leafColumns = doFlattenColumns(notFixedColumns);
1642
+ var fixedLeafColumns = doFlattenColumns(states.fixedColumns);
1643
+ var rightFixedLeafColumns = doFlattenColumns(states.rightFixedColumns);
1644
+
1645
+ states.leafColumnsLength = leafColumns.length;
1646
+ states.fixedLeafColumnsLength = fixedLeafColumns.length;
1647
+ states.rightFixedLeafColumnsLength = rightFixedLeafColumns.length;
1648
+
1649
+ states.columns = [].concat(fixedLeafColumns).concat(leafColumns).concat(rightFixedLeafColumns);
1650
+ states.isComplex = states.fixedColumns.length > 0 || states.rightFixedColumns.length > 0;
1651
+ },
1652
+
1653
+
1654
+ // 更新 DOM
1655
+ scheduleLayout: function scheduleLayout(needUpdateColumns) {
1656
+ if (needUpdateColumns) {
1657
+ this.updateColumns();
1658
+ }
1659
+ this.table.debouncedUpdateLayout();
1660
+ },
1661
+
1662
+
1663
+ // 选择
1664
+ isSelected: function isSelected(row) {
1665
+ var _states$selection = this.states.selection,
1666
+ selection = _states$selection === undefined ? [] : _states$selection;
1667
+
1668
+ return selection.indexOf(row) > -1;
1669
+ },
1670
+ clearSelection: function clearSelection() {
1671
+ var states = this.states;
1672
+ states.isAllSelected = false;
1673
+ var oldSelection = states.selection;
1674
+ if (oldSelection.length) {
1675
+ states.selection = [];
1676
+ this.table.$emit('selection-change', []);
1677
+ }
1678
+ },
1679
+ cleanSelection: function cleanSelection() {
1680
+ var states = this.states;
1681
+ var data = states.data,
1682
+ rowKey = states.rowKey,
1683
+ selection = states.selection;
1684
+
1685
+ var deleted = void 0;
1686
+ if (rowKey) {
1687
+ deleted = [];
1688
+ var selectedMap = Object(util["f" /* getKeysMap */])(selection, rowKey);
1689
+ var dataMap = Object(util["f" /* getKeysMap */])(data, rowKey);
1690
+ for (var key in selectedMap) {
1691
+ if (selectedMap.hasOwnProperty(key) && !dataMap[key]) {
1692
+ deleted.push(selectedMap[key].row);
1693
+ }
1694
+ }
1695
+ } else {
1696
+ deleted = selection.filter(function (item) {
1697
+ return data.indexOf(item) === -1;
1698
+ });
1699
+ }
1700
+ if (deleted.length) {
1701
+ var newSelection = selection.filter(function (item) {
1702
+ return deleted.indexOf(item) === -1;
1703
+ });
1704
+ states.selection = newSelection;
1705
+ this.table.$emit('selection-change', newSelection.slice());
1706
+ }
1707
+ },
1708
+ toggleRowSelection: function toggleRowSelection(row, selected) {
1709
+ var emitChange = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : true;
1710
+
1711
+ var changed = Object(util["m" /* toggleRowStatus */])(this.states.selection, row, selected);
1712
+ if (changed) {
1713
+ var newSelection = (this.states.selection || []).slice();
1714
+ // 调用 API 修改选中值,不触发 select 事件
1715
+ if (emitChange) {
1716
+ this.table.$emit('select', newSelection, row);
1717
+ }
1718
+ this.table.$emit('selection-change', newSelection);
1719
+ }
1720
+ },
1721
+ _toggleAllSelection: function _toggleAllSelection() {
1722
+ var states = this.states;
1723
+ var _states$data = states.data,
1724
+ data = _states$data === undefined ? [] : _states$data,
1725
+ selection = states.selection;
1726
+ // when only some rows are selected (but not all), select or deselect all of them
1727
+ // depending on the value of selectOnIndeterminate
1728
+
1729
+ var value = states.selectOnIndeterminate ? !states.isAllSelected : !(states.isAllSelected || selection.length);
1730
+ states.isAllSelected = value;
1731
+
1732
+ var selectionChanged = false;
1733
+ data.forEach(function (row, index) {
1734
+ if (states.selectable) {
1735
+ if (states.selectable.call(null, row, index) && Object(util["m" /* toggleRowStatus */])(selection, row, value)) {
1736
+ selectionChanged = true;
1737
+ }
1738
+ } else {
1739
+ if (Object(util["m" /* toggleRowStatus */])(selection, row, value)) {
1740
+ selectionChanged = true;
1741
+ }
1742
+ }
1743
+ });
1744
+
1745
+ if (selectionChanged) {
1746
+ this.table.$emit('selection-change', selection ? selection.slice() : []);
1747
+ }
1748
+ this.table.$emit('select-all', selection);
1749
+ },
1750
+ updateSelectionByRowKey: function updateSelectionByRowKey() {
1751
+ var states = this.states;
1752
+ var selection = states.selection,
1753
+ rowKey = states.rowKey,
1754
+ data = states.data;
1755
+
1756
+ var selectedMap = Object(util["f" /* getKeysMap */])(selection, rowKey);
1757
+ data.forEach(function (row) {
1758
+ var rowId = Object(util["g" /* getRowIdentity */])(row, rowKey);
1759
+ var rowInfo = selectedMap[rowId];
1760
+ if (rowInfo) {
1761
+ selection[rowInfo.index] = row;
1762
+ }
1763
+ });
1764
+ },
1765
+ updateAllSelected: function updateAllSelected() {
1766
+ var states = this.states;
1767
+ var selection = states.selection,
1768
+ rowKey = states.rowKey,
1769
+ selectable = states.selectable;
1770
+ // data 为 null 时,解构时的默认值会被忽略
1771
+
1772
+ var data = states.data || [];
1773
+ if (data.length === 0) {
1774
+ states.isAllSelected = false;
1775
+ return;
1776
+ }
1777
+
1778
+ var selectedMap = void 0;
1779
+ if (rowKey) {
1780
+ selectedMap = Object(util["f" /* getKeysMap */])(selection, rowKey);
1781
+ }
1782
+ var isSelected = function isSelected(row) {
1783
+ if (selectedMap) {
1784
+ return !!selectedMap[Object(util["g" /* getRowIdentity */])(row, rowKey)];
1785
+ } else {
1786
+ return selection.indexOf(row) !== -1;
1787
+ }
1788
+ };
1789
+ var isAllSelected = true;
1790
+ var selectedCount = 0;
1791
+ for (var i = 0, j = data.length; i < j; i++) {
1792
+ var item = data[i];
1793
+ var isRowSelectable = selectable && selectable.call(null, item, i);
1794
+ if (!isSelected(item)) {
1795
+ if (!selectable || isRowSelectable) {
1796
+ isAllSelected = false;
1797
+ break;
1798
+ }
1799
+ } else {
1800
+ selectedCount++;
1801
+ }
1802
+ }
1803
+
1804
+ if (selectedCount === 0) isAllSelected = false;
1805
+ states.isAllSelected = isAllSelected;
1806
+ },
1807
+
1808
+
1809
+ // 过滤与排序
1810
+ updateFilters: function updateFilters(columns, values) {
1811
+ if (!Array.isArray(columns)) {
1812
+ columns = [columns];
1813
+ }
1814
+ var states = this.states;
1815
+ var filters = {};
1816
+ columns.forEach(function (col) {
1817
+ states.filters[col.id] = values;
1818
+ filters[col.columnKey || col.id] = values;
1819
+ });
1820
+
1821
+ return filters;
1822
+ },
1823
+ updateSort: function updateSort(column, prop, order) {
1824
+ if (this.states.sortingColumn && this.states.sortingColumn !== column) {
1825
+ this.states.sortingColumn.order = null;
1826
+ }
1827
+ this.states.sortingColumn = column;
1828
+ this.states.sortProp = prop;
1829
+ this.states.sortOrder = order;
1830
+ },
1831
+ execFilter: function execFilter() {
1832
+ var _this = this;
1833
+
1834
+ var states = this.states;
1835
+ var _data = states._data,
1836
+ filters = states.filters;
1837
+
1838
+ var data = _data;
1839
+
1840
+ Object.keys(filters).forEach(function (columnId) {
1841
+ var values = states.filters[columnId];
1842
+ if (!values || values.length === 0) return;
1843
+ var column = Object(util["d" /* getColumnById */])(_this.states, columnId);
1844
+ if (column && column.filterMethod) {
1845
+ data = data.filter(function (row) {
1846
+ return values.some(function (value) {
1847
+ return column.filterMethod.call(null, value, row, column);
1848
+ });
1849
+ });
1850
+ }
1851
+ });
1852
+
1853
+ states.filteredData = data;
1854
+ },
1855
+ execSort: function execSort() {
1856
+ var states = this.states;
1857
+ states.data = watcher_sortData(states.filteredData, states);
1858
+ },
1859
+
1860
+
1861
+ // 根据 filters 与 sort 去过滤 data
1862
+ execQuery: function execQuery(ignore) {
1863
+ if (!(ignore && ignore.filter)) {
1864
+ this.execFilter();
1865
+ }
1866
+ this.execSort();
1867
+ },
1868
+ clearFilter: function clearFilter(columnKeys) {
1869
+ var states = this.states;
1870
+ var _table$$refs = this.table.$refs,
1871
+ tableHeader = _table$$refs.tableHeader,
1872
+ fixedTableHeader = _table$$refs.fixedTableHeader,
1873
+ rightFixedTableHeader = _table$$refs.rightFixedTableHeader;
1874
+
1875
+
1876
+ var panels = {};
1877
+ if (tableHeader) panels = merge_default()(panels, tableHeader.filterPanels);
1878
+ if (fixedTableHeader) panels = merge_default()(panels, fixedTableHeader.filterPanels);
1879
+ if (rightFixedTableHeader) panels = merge_default()(panels, rightFixedTableHeader.filterPanels);
1880
+
1881
+ var keys = Object.keys(panels);
1882
+ if (!keys.length) return;
1883
+
1884
+ if (typeof columnKeys === 'string') {
1885
+ columnKeys = [columnKeys];
1886
+ }
1887
+
1888
+ if (Array.isArray(columnKeys)) {
1889
+ var columns = columnKeys.map(function (key) {
1890
+ return Object(util["e" /* getColumnByKey */])(states, key);
1891
+ });
1892
+ keys.forEach(function (key) {
1893
+ var column = columns.find(function (col) {
1894
+ return col.id === key;
1895
+ });
1896
+ if (column) {
1897
+ // TODO: 优化这里的代码
1898
+ panels[key].filteredValue = [];
1899
+ }
1900
+ });
1901
+ this.commit('filterChange', {
1902
+ column: columns,
1903
+ values: [],
1904
+ silent: true,
1905
+ multi: true
1906
+ });
1907
+ } else {
1908
+ keys.forEach(function (key) {
1909
+ // TODO: 优化这里的代码
1910
+ panels[key].filteredValue = [];
1911
+ });
1912
+
1913
+ states.filters = {};
1914
+ this.commit('filterChange', {
1915
+ column: {},
1916
+ values: [],
1917
+ silent: true
1918
+ });
1919
+ }
1920
+ },
1921
+ clearSort: function clearSort() {
1922
+ var states = this.states;
1923
+ if (!states.sortingColumn) return;
1924
+
1925
+ this.updateSort(null, null, null);
1926
+ this.commit('changeSortCondition', {
1927
+ silent: true
1928
+ });
1929
+ },
1930
+
1931
+
1932
+ // 适配层,expand-row-keys 在 Expand 与 TreeTable 中都有使用
1933
+ setExpandRowKeysAdapter: function setExpandRowKeysAdapter(val) {
1934
+ // 这里会触发额外的计算,但为了兼容性,暂时这么做
1935
+ this.setExpandRowKeys(val);
1936
+ this.updateTreeExpandKeys(val);
1937
+ },
1938
+
1939
+
1940
+ // 展开行与 TreeTable 都要使用
1941
+ toggleRowExpansionAdapter: function toggleRowExpansionAdapter(row, expanded) {
1942
+ var hasExpandColumn = this.states.columns.some(function (_ref) {
1943
+ var type = _ref.type;
1944
+ return type === 'expand';
1945
+ });
1946
+ if (hasExpandColumn) {
1947
+ this.toggleRowExpansion(row, expanded);
1948
+ } else {
1949
+ this.toggleTreeExpansion(row, expanded);
1950
+ }
1951
+ }
1952
+ }
1953
+ }));
1954
+ // CONCATENATED MODULE: ./packages/table/src/store/index.js
1955
+
1956
+
1957
+
1958
+
1959
+ watcher.prototype.mutations = {
1960
+ setData: function setData(states, data) {
1961
+ var dataInstanceChanged = states._data !== data;
1962
+ states._data = data;
1963
+
1964
+ this.execQuery();
1965
+ // 数据变化,更新部分数据。
1966
+ // 没有使用 computed,而是手动更新部分数据 https://github.com/vuejs/vue/issues/6660#issuecomment-331417140
1967
+ this.updateCurrentRowData();
1968
+ this.updateExpandRows();
1969
+ if (states.reserveSelection) {
1970
+ this.assertRowKey();
1971
+ this.updateSelectionByRowKey();
1972
+ } else {
1973
+ if (dataInstanceChanged) {
1974
+ this.clearSelection();
1975
+ } else {
1976
+ this.cleanSelection();
1977
+ }
1978
+ }
1979
+ this.updateAllSelected();
1980
+
1981
+ this.updateTableScrollY();
1982
+ },
1983
+ insertColumn: function insertColumn(states, column, index, parent) {
1984
+ var array = states._columns;
1985
+ if (parent) {
1986
+ array = parent.children;
1987
+ if (!array) array = parent.children = [];
1988
+ }
1989
+
1990
+ if (typeof index !== 'undefined') {
1991
+ array.splice(index, 0, column);
1992
+ } else {
1993
+ array.push(column);
1994
+ }
1995
+
1996
+ if (column.type === 'selection') {
1997
+ states.selectable = column.selectable;
1998
+ states.reserveSelection = column.reserveSelection;
1999
+ }
2000
+
2001
+ if (this.table.$ready) {
2002
+ this.updateColumns(); // hack for dynamics insert column
2003
+ this.scheduleLayout();
2004
+ }
2005
+ },
2006
+ removeColumn: function removeColumn(states, column, parent) {
2007
+ var array = states._columns;
2008
+ if (parent) {
2009
+ array = parent.children;
2010
+ if (!array) array = parent.children = [];
2011
+ }
2012
+ if (array) {
2013
+ array.splice(array.indexOf(column), 1);
2014
+ }
2015
+
2016
+ if (this.table.$ready) {
2017
+ this.updateColumns(); // hack for dynamics remove column
2018
+ this.scheduleLayout();
2019
+ }
2020
+ },
2021
+ sort: function sort(states, options) {
2022
+ var prop = options.prop,
2023
+ order = options.order,
2024
+ init = options.init;
2025
+
2026
+ if (prop) {
2027
+ var column = Object(util_["arrayFind"])(states.columns, function (column) {
2028
+ return column.property === prop;
2029
+ });
2030
+ if (column) {
2031
+ column.order = order;
2032
+ this.updateSort(column, prop, order);
2033
+ this.commit('changeSortCondition', { init: init });
2034
+ }
2035
+ }
2036
+ },
2037
+ changeSortCondition: function changeSortCondition(states, options) {
2038
+ // 修复 pr https://github.com/ElemeFE/element/pull/15012 导致的 bug
2039
+ var column = states.sortingColumn,
2040
+ prop = states.sortProp,
2041
+ order = states.sortOrder;
2042
+
2043
+ if (order === null) {
2044
+ states.sortingColumn = null;
2045
+ states.sortProp = null;
2046
+ }
2047
+ var ingore = { filter: true };
2048
+ this.execQuery(ingore);
2049
+
2050
+ if (!options || !(options.silent || options.init)) {
2051
+ this.table.$emit('sort-change', {
2052
+ column: column,
2053
+ prop: prop,
2054
+ order: order
2055
+ });
2056
+ }
2057
+
2058
+ this.updateTableScrollY();
2059
+ },
2060
+ filterChange: function filterChange(states, options) {
2061
+ var column = options.column,
2062
+ values = options.values,
2063
+ silent = options.silent;
2064
+
2065
+ var newFilters = this.updateFilters(column, values);
2066
+
2067
+ this.execQuery();
2068
+
2069
+ if (!silent) {
2070
+ this.table.$emit('filter-change', newFilters);
2071
+ }
2072
+
2073
+ this.updateTableScrollY();
2074
+ },
2075
+ toggleAllSelection: function toggleAllSelection() {
2076
+ this.toggleAllSelection();
2077
+ },
2078
+ rowSelectedChanged: function rowSelectedChanged(states, row) {
2079
+ this.toggleRowSelection(row);
2080
+ this.updateAllSelected();
2081
+ },
2082
+ setHoverRow: function setHoverRow(states, row) {
2083
+ states.hoverRow = row;
2084
+ },
2085
+ setCurrentRow: function setCurrentRow(states, row) {
2086
+ this.updateCurrentRow(row);
2087
+ }
2088
+ };
2089
+
2090
+ watcher.prototype.commit = function (name) {
2091
+ var mutations = this.mutations;
2092
+ if (mutations[name]) {
2093
+ for (var _len = arguments.length, args = Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {
2094
+ args[_key - 1] = arguments[_key];
2095
+ }
2096
+
2097
+ mutations[name].apply(this, [this.states].concat(args));
2098
+ } else {
2099
+ throw new Error('Action not found: ' + name);
2100
+ }
2101
+ };
2102
+
2103
+ watcher.prototype.updateTableScrollY = function () {
2104
+ external_vue_default.a.nextTick(this.table.updateScrollY);
2105
+ };
2106
+
2107
+ /* harmony default export */ var src_store = (watcher);
2108
+ // EXTERNAL MODULE: external "throttle-debounce/debounce"
2109
+ var debounce_ = __webpack_require__(19);
2110
+ var debounce_default = /*#__PURE__*/__webpack_require__.n(debounce_);
2111
+
2112
+ // CONCATENATED MODULE: ./packages/table/src/store/helper.js
2113
+
2114
+
2115
+
2116
+ function createStore(table) {
2117
+ var initialState = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
2118
+
2119
+ if (!table) {
2120
+ throw new Error('Table is required.');
2121
+ }
2122
+
2123
+ var store = new src_store();
2124
+ store.table = table;
2125
+ // fix https://github.com/ElemeFE/element/issues/14075
2126
+ // related pr https://github.com/ElemeFE/element/pull/14146
2127
+ store.toggleAllSelection = debounce_default()(10, store._toggleAllSelection);
2128
+ Object.keys(initialState).forEach(function (key) {
2129
+ store.states[key] = initialState[key];
2130
+ });
2131
+ return store;
2132
+ }
2133
+
2134
+ function mapStates(mapper) {
2135
+ var res = {};
2136
+ Object.keys(mapper).forEach(function (key) {
2137
+ var value = mapper[key];
2138
+ var fn = void 0;
2139
+ if (typeof value === 'string') {
2140
+ fn = function fn() {
2141
+ return this.store.states[value];
2142
+ };
2143
+ } else if (typeof value === 'function') {
2144
+ fn = function fn() {
2145
+ return value.call(this, this.store.states);
2146
+ };
2147
+ } else {
2148
+ console.error('invalid value type');
2149
+ }
2150
+ if (fn) {
2151
+ res[key] = fn;
2152
+ }
2153
+ });
2154
+ return res;
2155
+ };
2156
+ // EXTERNAL MODULE: external "element-ui/lib/utils/scrollbar-width"
2157
+ var scrollbar_width_ = __webpack_require__(38);
2158
+ var scrollbar_width_default = /*#__PURE__*/__webpack_require__.n(scrollbar_width_);
2159
+
2160
+ // CONCATENATED MODULE: ./packages/table/src/table-layout.js
2161
+ function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
2162
+
2163
+
2164
+
2165
+
2166
+
2167
+ var table_layout_TableLayout = function () {
2168
+ function TableLayout(options) {
2169
+ _classCallCheck(this, TableLayout);
2170
+
2171
+ this.observers = [];
2172
+ this.table = null;
2173
+ this.store = null;
2174
+ this.columns = null;
2175
+ this.fit = true;
2176
+ this.showHeader = true;
2177
+
2178
+ this.height = null;
2179
+ this.scrollX = false;
2180
+ this.scrollY = false;
2181
+ this.bodyWidth = null;
2182
+ this.fixedWidth = null;
2183
+ this.rightFixedWidth = null;
2184
+ this.tableHeight = null;
2185
+ this.headerHeight = 44; // Table Header Height
2186
+ this.appendHeight = 0; // Append Slot Height
2187
+ this.footerHeight = 44; // Table Footer Height
2188
+ this.viewportHeight = null; // Table Height - Scroll Bar Height
2189
+ this.bodyHeight = null; // Table Height - Table Header Height
2190
+ this.fixedBodyHeight = null; // Table Height - Table Header Height - Scroll Bar Height
2191
+ this.gutterWidth = scrollbar_width_default()();
2192
+
2193
+ for (var name in options) {
2194
+ if (options.hasOwnProperty(name)) {
2195
+ this[name] = options[name];
2196
+ }
2197
+ }
2198
+
2199
+ if (!this.table) {
2200
+ throw new Error('table is required for Table Layout');
2201
+ }
2202
+ if (!this.store) {
2203
+ throw new Error('store is required for Table Layout');
2204
+ }
2205
+ }
2206
+
2207
+ TableLayout.prototype.updateScrollY = function updateScrollY() {
2208
+ var height = this.height;
2209
+ if (height === null) return false;
2210
+ var bodyWrapper = this.table.bodyWrapper;
2211
+ if (this.table.$el && bodyWrapper) {
2212
+ var body = bodyWrapper.querySelector('.el-table__body');
2213
+ var prevScrollY = this.scrollY;
2214
+ var scrollY = body.offsetHeight > this.bodyHeight;
2215
+ this.scrollY = scrollY;
2216
+ return prevScrollY !== scrollY;
2217
+ }
2218
+ return false;
2219
+ };
2220
+
2221
+ TableLayout.prototype.setHeight = function setHeight(value) {
2222
+ var _this = this;
2223
+
2224
+ var prop = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'height';
2225
+
2226
+ if (external_vue_default.a.prototype.$isServer) return;
2227
+ var el = this.table.$el;
2228
+ value = Object(util["j" /* parseHeight */])(value);
2229
+ this.height = value;
2230
+
2231
+ if (!el && (value || value === 0)) return external_vue_default.a.nextTick(function () {
2232
+ return _this.setHeight(value, prop);
2233
+ });
2234
+
2235
+ if (typeof value === 'number') {
2236
+ el.style[prop] = value + 'px';
2237
+ this.updateElsHeight();
2238
+ } else if (typeof value === 'string') {
2239
+ el.style[prop] = value;
2240
+ this.updateElsHeight();
2241
+ }
2242
+ };
2243
+
2244
+ TableLayout.prototype.setMaxHeight = function setMaxHeight(value) {
2245
+ this.setHeight(value, 'max-height');
2246
+ };
2247
+
2248
+ TableLayout.prototype.getFlattenColumns = function getFlattenColumns() {
2249
+ var flattenColumns = [];
2250
+ var columns = this.table.columns;
2251
+ columns.forEach(function (column) {
2252
+ if (column.isColumnGroup) {
2253
+ flattenColumns.push.apply(flattenColumns, column.columns);
2254
+ } else {
2255
+ flattenColumns.push(column);
2256
+ }
2257
+ });
2258
+
2259
+ return flattenColumns;
2260
+ };
2261
+
2262
+ TableLayout.prototype.updateElsHeight = function updateElsHeight() {
2263
+ var _this2 = this;
2264
+
2265
+ if (!this.table.$ready) return external_vue_default.a.nextTick(function () {
2266
+ return _this2.updateElsHeight();
2267
+ });
2268
+ var _table$$refs = this.table.$refs,
2269
+ headerWrapper = _table$$refs.headerWrapper,
2270
+ appendWrapper = _table$$refs.appendWrapper,
2271
+ footerWrapper = _table$$refs.footerWrapper;
2272
+
2273
+ this.appendHeight = appendWrapper ? appendWrapper.offsetHeight : 0;
2274
+
2275
+ if (this.showHeader && !headerWrapper) return;
2276
+
2277
+ // fix issue (https://github.com/ElemeFE/element/pull/16956)
2278
+ var headerTrElm = headerWrapper ? headerWrapper.querySelector('.el-table__header tr') : null;
2279
+ var noneHeader = this.headerDisplayNone(headerTrElm);
2280
+
2281
+ var headerHeight = this.headerHeight = !this.showHeader ? 0 : headerWrapper.offsetHeight;
2282
+ if (this.showHeader && !noneHeader && headerWrapper.offsetWidth > 0 && (this.table.columns || []).length > 0 && headerHeight < 2) {
2283
+ return external_vue_default.a.nextTick(function () {
2284
+ return _this2.updateElsHeight();
2285
+ });
2286
+ }
2287
+ var tableHeight = this.tableHeight = this.table.$el.clientHeight;
2288
+ var footerHeight = this.footerHeight = footerWrapper ? footerWrapper.offsetHeight : 0;
2289
+ if (this.height !== null) {
2290
+ this.bodyHeight = tableHeight - headerHeight - footerHeight + (footerWrapper ? 1 : 0);
2291
+ }
2292
+ this.fixedBodyHeight = this.scrollX ? this.bodyHeight - this.gutterWidth : this.bodyHeight;
2293
+
2294
+ var noData = !(this.store.states.data && this.store.states.data.length);
2295
+ this.viewportHeight = this.scrollX ? tableHeight - (noData ? 0 : this.gutterWidth) : tableHeight;
2296
+ this.updateScrollY();
2297
+ this.notifyObservers('scrollable');
2298
+ };
2299
+
2300
+ TableLayout.prototype.headerDisplayNone = function headerDisplayNone(elm) {
2301
+ if (!elm) return true;
2302
+ var headerChild = elm;
2303
+ while (headerChild.tagName !== 'DIV') {
2304
+ if (getComputedStyle(headerChild).display === 'none') {
2305
+ return true;
2306
+ }
2307
+ headerChild = headerChild.parentElement;
2308
+ }
2309
+ return false;
2310
+ };
2311
+
2312
+ TableLayout.prototype.updateColumnsWidth = function updateColumnsWidth() {
2313
+ if (external_vue_default.a.prototype.$isServer) return;
2314
+ var fit = this.fit;
2315
+ var bodyWidth = this.table.$el.clientWidth;
2316
+ var bodyMinWidth = 0;
2317
+
2318
+ var flattenColumns = this.getFlattenColumns();
2319
+ var flexColumns = flattenColumns.filter(function (column) {
2320
+ return typeof column.width !== 'number';
2321
+ });
2322
+
2323
+ flattenColumns.forEach(function (column) {
2324
+ // Clean those columns whose width changed from flex to unflex
2325
+ if (typeof column.width === 'number' && column.realWidth) column.realWidth = null;
2326
+ });
2327
+
2328
+ if (flexColumns.length > 0 && fit) {
2329
+ flattenColumns.forEach(function (column) {
2330
+ bodyMinWidth += column.width || column.minWidth || 80;
2331
+ });
2332
+
2333
+ var scrollYWidth = this.scrollY ? this.gutterWidth : 0;
2334
+
2335
+ if (bodyMinWidth <= bodyWidth - scrollYWidth) {
2336
+ // DON'T HAVE SCROLL BAR
2337
+ this.scrollX = false;
2338
+
2339
+ var totalFlexWidth = bodyWidth - scrollYWidth - bodyMinWidth;
2340
+
2341
+ if (flexColumns.length === 1) {
2342
+ flexColumns[0].realWidth = (flexColumns[0].minWidth || 80) + totalFlexWidth;
2343
+ } else {
2344
+ var allColumnsWidth = flexColumns.reduce(function (prev, column) {
2345
+ return prev + (column.minWidth || 80);
2346
+ }, 0);
2347
+ var flexWidthPerPixel = totalFlexWidth / allColumnsWidth;
2348
+ var noneFirstWidth = 0;
2349
+
2350
+ flexColumns.forEach(function (column, index) {
2351
+ if (index === 0) return;
2352
+ var flexWidth = Math.floor((column.minWidth || 80) * flexWidthPerPixel);
2353
+ noneFirstWidth += flexWidth;
2354
+ column.realWidth = (column.minWidth || 80) + flexWidth;
2355
+ });
2356
+
2357
+ flexColumns[0].realWidth = (flexColumns[0].minWidth || 80) + totalFlexWidth - noneFirstWidth;
2358
+ }
2359
+ } else {
2360
+ // HAVE HORIZONTAL SCROLL BAR
2361
+ this.scrollX = true;
2362
+ flexColumns.forEach(function (column) {
2363
+ column.realWidth = column.minWidth;
2364
+ });
2365
+ }
2366
+
2367
+ this.bodyWidth = Math.max(bodyMinWidth, bodyWidth);
2368
+ this.table.resizeState.width = this.bodyWidth;
2369
+ } else {
2370
+ flattenColumns.forEach(function (column) {
2371
+ if (!column.width && !column.minWidth) {
2372
+ column.realWidth = 80;
2373
+ } else {
2374
+ column.realWidth = column.width || column.minWidth;
2375
+ }
2376
+
2377
+ bodyMinWidth += column.realWidth;
2378
+ });
2379
+ this.scrollX = bodyMinWidth > bodyWidth;
2380
+
2381
+ this.bodyWidth = bodyMinWidth;
2382
+ }
2383
+
2384
+ var fixedColumns = this.store.states.fixedColumns;
2385
+
2386
+ if (fixedColumns.length > 0) {
2387
+ var fixedWidth = 0;
2388
+ fixedColumns.forEach(function (column) {
2389
+ fixedWidth += column.realWidth || column.width;
2390
+ });
2391
+
2392
+ this.fixedWidth = fixedWidth;
2393
+ }
2394
+
2395
+ var rightFixedColumns = this.store.states.rightFixedColumns;
2396
+ if (rightFixedColumns.length > 0) {
2397
+ var rightFixedWidth = 0;
2398
+ rightFixedColumns.forEach(function (column) {
2399
+ rightFixedWidth += column.realWidth || column.width;
2400
+ });
2401
+
2402
+ this.rightFixedWidth = rightFixedWidth;
2403
+ }
2404
+
2405
+ this.notifyObservers('columns');
2406
+ };
2407
+
2408
+ TableLayout.prototype.addObserver = function addObserver(observer) {
2409
+ this.observers.push(observer);
2410
+ };
2411
+
2412
+ TableLayout.prototype.removeObserver = function removeObserver(observer) {
2413
+ var index = this.observers.indexOf(observer);
2414
+ if (index !== -1) {
2415
+ this.observers.splice(index, 1);
2416
+ }
2417
+ };
2418
+
2419
+ TableLayout.prototype.notifyObservers = function notifyObservers(event) {
2420
+ var _this3 = this;
2421
+
2422
+ var observers = this.observers;
2423
+ observers.forEach(function (observer) {
2424
+ switch (event) {
2425
+ case 'columns':
2426
+ observer.onColumnsChange(_this3);
2427
+ break;
2428
+ case 'scrollable':
2429
+ observer.onScrollableChange(_this3);
2430
+ break;
2431
+ default:
2432
+ throw new Error('Table Layout don\'t have event ' + event + '.');
2433
+ }
2434
+ });
2435
+ };
2436
+
2437
+ return TableLayout;
2438
+ }();
2439
+
2440
+ /* harmony default export */ var table_layout = (table_layout_TableLayout);
2441
+ // EXTERNAL MODULE: external "element-ui/lib/utils/dom"
2442
+ var dom_ = __webpack_require__(2);
2443
+
2444
+ // EXTERNAL MODULE: external "element-ui/lib/tooltip"
2445
+ var tooltip_ = __webpack_require__(29);
2446
+ var tooltip_default = /*#__PURE__*/__webpack_require__.n(tooltip_);
2447
+
2448
+ // CONCATENATED MODULE: ./packages/table/src/layout-observer.js
2449
+ /* harmony default export */ var layout_observer = ({
2450
+ created: function created() {
2451
+ this.tableLayout.addObserver(this);
2452
+ },
2453
+ destroyed: function destroyed() {
2454
+ this.tableLayout.removeObserver(this);
2455
+ },
2456
+
2457
+
2458
+ computed: {
2459
+ tableLayout: function tableLayout() {
2460
+ var layout = this.layout;
2461
+ if (!layout && this.table) {
2462
+ layout = this.table.layout;
2463
+ }
2464
+ if (!layout) {
2465
+ throw new Error('Can not find table layout.');
2466
+ }
2467
+ return layout;
2468
+ }
2469
+ },
2470
+
2471
+ mounted: function mounted() {
2472
+ this.onColumnsChange(this.tableLayout);
2473
+ this.onScrollableChange(this.tableLayout);
2474
+ },
2475
+ updated: function updated() {
2476
+ if (this.__updated__) return;
2477
+ this.onColumnsChange(this.tableLayout);
2478
+ this.onScrollableChange(this.tableLayout);
2479
+ this.__updated__ = true;
2480
+ },
2481
+
2482
+
2483
+ methods: {
2484
+ onColumnsChange: function onColumnsChange(layout) {
2485
+ var cols = this.$el.querySelectorAll('colgroup > col');
2486
+ if (!cols.length) return;
2487
+ var flattenColumns = layout.getFlattenColumns();
2488
+ var columnsMap = {};
2489
+ flattenColumns.forEach(function (column) {
2490
+ columnsMap[column.id] = column;
2491
+ });
2492
+ for (var i = 0, j = cols.length; i < j; i++) {
2493
+ var col = cols[i];
2494
+ var name = col.getAttribute('name');
2495
+ var column = columnsMap[name];
2496
+ if (column) {
2497
+ col.setAttribute('width', column.realWidth || column.width);
2498
+ }
2499
+ }
2500
+ },
2501
+ onScrollableChange: function onScrollableChange(layout) {
2502
+ var cols = this.$el.querySelectorAll('colgroup > col[name=gutter]');
2503
+ for (var i = 0, j = cols.length; i < j; i++) {
2504
+ var col = cols[i];
2505
+ col.setAttribute('width', layout.scrollY ? layout.gutterWidth : '0');
2506
+ }
2507
+ var ths = this.$el.querySelectorAll('th.gutter');
2508
+ for (var _i = 0, _j = ths.length; _i < _j; _i++) {
2509
+ var th = ths[_i];
2510
+ th.style.width = layout.scrollY ? layout.gutterWidth + 'px' : '0';
2511
+ th.style.display = layout.scrollY ? '' : 'none';
2512
+ }
2513
+ }
2514
+ }
2515
+ });
2516
+ // CONCATENATED MODULE: ./packages/table/src/table-row.js
2517
+ var table_row_extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
2518
+
2519
+
2520
+ /* harmony default export */ var table_row = ({
2521
+ name: 'ElTableRow',
2522
+ props: ['columns', 'row', 'index', 'isSelected', 'isExpanded', 'store', 'context', 'firstDefaultColumnIndex', 'treeRowData', 'treeIndent', 'columnsHidden', 'getSpan', 'getColspanRealWidth', 'getCellStyle', 'getCellClass', 'handleCellMouseLeave', 'handleCellMouseEnter', 'fixed'],
2523
+ components: {
2524
+ ElCheckbox: checkbox_default.a
2525
+ },
2526
+ render: function render() {
2527
+ var _this = this;
2528
+
2529
+ var h = arguments[0];
2530
+ var columns = this.columns,
2531
+ row = this.row,
2532
+ $index = this.index,
2533
+ store = this.store,
2534
+ context = this.context,
2535
+ firstDefaultColumnIndex = this.firstDefaultColumnIndex,
2536
+ treeRowData = this.treeRowData,
2537
+ treeIndent = this.treeIndent,
2538
+ _columnsHidden = this.columnsHidden,
2539
+ columnsHidden = _columnsHidden === undefined ? [] : _columnsHidden,
2540
+ isSelected = this.isSelected,
2541
+ isExpanded = this.isExpanded;
2542
+
2543
+
2544
+ return h('tr', [columns.map(function (column, cellIndex) {
2545
+ var _getSpan = _this.getSpan(row, column, $index, cellIndex),
2546
+ rowspan = _getSpan.rowspan,
2547
+ colspan = _getSpan.colspan;
2548
+
2549
+ if (!rowspan || !colspan) {
2550
+ return null;
2551
+ }
2552
+ var columnData = table_row_extends({}, column);
2553
+ columnData.realWidth = _this.getColspanRealWidth(columns, colspan, cellIndex);
2554
+ var data = {
2555
+ store: store,
2556
+ isSelected: isSelected,
2557
+ isExpanded: isExpanded,
2558
+ _self: context,
2559
+ column: columnData,
2560
+ row: row,
2561
+ $index: $index
2562
+ };
2563
+ if (cellIndex === firstDefaultColumnIndex && treeRowData) {
2564
+ data.treeNode = {
2565
+ indent: treeRowData.level * treeIndent,
2566
+ level: treeRowData.level
2567
+ };
2568
+ if (typeof treeRowData.expanded === 'boolean') {
2569
+ data.treeNode.expanded = treeRowData.expanded;
2570
+ // 表明是懒加载
2571
+ if ('loading' in treeRowData) {
2572
+ data.treeNode.loading = treeRowData.loading;
2573
+ }
2574
+ if ('noLazyChildren' in treeRowData) {
2575
+ data.treeNode.noLazyChildren = treeRowData.noLazyChildren;
2576
+ }
2577
+ }
2578
+ }
2579
+ return h(
2580
+ 'td',
2581
+ {
2582
+ style: _this.getCellStyle($index, cellIndex, row, column),
2583
+ 'class': _this.getCellClass($index, cellIndex, row, column),
2584
+ attrs: { rowspan: rowspan,
2585
+ colspan: colspan
2586
+ },
2587
+ on: {
2588
+ 'mouseenter': function mouseenter($event) {
2589
+ return _this.handleCellMouseEnter($event, row);
2590
+ },
2591
+ 'mouseleave': _this.handleCellMouseLeave
2592
+ }
2593
+ },
2594
+ [column.renderCell.call(_this._renderProxy, _this.$createElement, data, columnsHidden[cellIndex])]
2595
+ );
2596
+ })]);
2597
+ }
2598
+ });
2599
+ // CONCATENATED MODULE: ./packages/table/src/table-body.js
2600
+ var _typeof = typeof Symbol === "function" && typeof Symbol.iterator === "symbol" ? function (obj) { return typeof obj; } : function (obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; };
2601
+
2602
+ var table_body_extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
2603
+
2604
+
2605
+
2606
+
2607
+
2608
+
2609
+
2610
+
2611
+
2612
+
2613
+
2614
+ /* harmony default export */ var table_body = ({
2615
+ name: 'ElTableBody',
2616
+
2617
+ mixins: [layout_observer],
2618
+
2619
+ components: {
2620
+ ElCheckbox: checkbox_default.a,
2621
+ ElTooltip: tooltip_default.a,
2622
+ TableRow: table_row
2623
+ },
2624
+
2625
+ props: {
2626
+ store: {
2627
+ required: true
2628
+ },
2629
+ stripe: Boolean,
2630
+ context: {},
2631
+ rowClassName: [String, Function],
2632
+ rowStyle: [Object, Function],
2633
+ fixed: String,
2634
+ highlight: Boolean
2635
+ },
2636
+
2637
+ render: function render(h) {
2638
+ var _this = this;
2639
+
2640
+ var data = this.data || [];
2641
+ return h(
2642
+ 'table',
2643
+ {
2644
+ 'class': 'el-table__body',
2645
+ attrs: { cellspacing: '0',
2646
+ cellpadding: '0',
2647
+ border: '0' }
2648
+ },
2649
+ [h('colgroup', [this.columns.map(function (column) {
2650
+ return h('col', {
2651
+ attrs: { name: column.id },
2652
+ key: column.id });
2653
+ })]), h('tbody', [data.reduce(function (acc, row) {
2654
+ return acc.concat(_this.wrappedRowRender(row, acc.length));
2655
+ }, []), h('el-tooltip', {
2656
+ attrs: { effect: this.table.tooltipEffect, placement: 'top', content: this.tooltipContent },
2657
+ ref: 'tooltip' })])]
2658
+ );
2659
+ },
2660
+
2661
+
2662
+ computed: table_body_extends({
2663
+ table: function table() {
2664
+ return this.$parent;
2665
+ }
2666
+ }, mapStates({
2667
+ data: 'data',
2668
+ columns: 'columns',
2669
+ treeIndent: 'indent',
2670
+ leftFixedLeafCount: 'fixedLeafColumnsLength',
2671
+ rightFixedLeafCount: 'rightFixedLeafColumnsLength',
2672
+ columnsCount: function columnsCount(states) {
2673
+ return states.columns.length;
2674
+ },
2675
+ leftFixedCount: function leftFixedCount(states) {
2676
+ return states.fixedColumns.length;
2677
+ },
2678
+ rightFixedCount: function rightFixedCount(states) {
2679
+ return states.rightFixedColumns.length;
2680
+ },
2681
+ hasExpandColumn: function hasExpandColumn(states) {
2682
+ return states.columns.some(function (_ref) {
2683
+ var type = _ref.type;
2684
+ return type === 'expand';
2685
+ });
2686
+ }
2687
+ }), {
2688
+ columnsHidden: function columnsHidden() {
2689
+ var _this2 = this;
2690
+
2691
+ return this.columns.map(function (column, index) {
2692
+ return _this2.isColumnHidden(index);
2693
+ });
2694
+ },
2695
+ firstDefaultColumnIndex: function firstDefaultColumnIndex() {
2696
+ return Object(util_["arrayFindIndex"])(this.columns, function (_ref2) {
2697
+ var type = _ref2.type;
2698
+ return type === 'default';
2699
+ });
2700
+ }
2701
+ }),
2702
+
2703
+ watch: {
2704
+ // don't trigger getter of currentRow in getCellClass. see https://jsfiddle.net/oe2b4hqt/
2705
+ // update DOM manually. see https://github.com/ElemeFE/element/pull/13954/files#diff-9b450c00d0a9dec0ffad5a3176972e40
2706
+ 'store.states.hoverRow': function storeStatesHoverRow(newVal, oldVal) {
2707
+ var _this3 = this;
2708
+
2709
+ if (!this.store.states.isComplex || this.$isServer) return;
2710
+ var raf = window.requestAnimationFrame;
2711
+ if (!raf) {
2712
+ raf = function raf(fn) {
2713
+ return setTimeout(fn, 16);
2714
+ };
2715
+ }
2716
+ raf(function () {
2717
+ var rows = _this3.$el.querySelectorAll('.el-table__row');
2718
+ var oldRow = rows[oldVal];
2719
+ var newRow = rows[newVal];
2720
+ if (oldRow) {
2721
+ Object(dom_["removeClass"])(oldRow, 'hover-row');
2722
+ }
2723
+ if (newRow) {
2724
+ Object(dom_["addClass"])(newRow, 'hover-row');
2725
+ }
2726
+ });
2727
+ }
2728
+ },
2729
+
2730
+ data: function data() {
2731
+ return {
2732
+ tooltipContent: ''
2733
+ };
2734
+ },
2735
+ created: function created() {
2736
+ this.activateTooltip = debounce_default()(50, function (tooltip) {
2737
+ return tooltip.handleShowPopper();
2738
+ });
2739
+ },
2740
+
2741
+
2742
+ methods: {
2743
+ getKeyOfRow: function getKeyOfRow(row, index) {
2744
+ var rowKey = this.table.rowKey;
2745
+ if (rowKey) {
2746
+ return Object(util["g" /* getRowIdentity */])(row, rowKey);
2747
+ }
2748
+ return index;
2749
+ },
2750
+ isColumnHidden: function isColumnHidden(index) {
2751
+ if (this.fixed === true || this.fixed === 'left') {
2752
+ return index >= this.leftFixedLeafCount;
2753
+ } else if (this.fixed === 'right') {
2754
+ return index < this.columnsCount - this.rightFixedLeafCount;
2755
+ } else {
2756
+ return index < this.leftFixedLeafCount || index >= this.columnsCount - this.rightFixedLeafCount;
2757
+ }
2758
+ },
2759
+ getSpan: function getSpan(row, column, rowIndex, columnIndex) {
2760
+ var rowspan = 1;
2761
+ var colspan = 1;
2762
+ var fn = this.table.spanMethod;
2763
+ if (typeof fn === 'function') {
2764
+ var result = fn({
2765
+ row: row,
2766
+ column: column,
2767
+ rowIndex: rowIndex,
2768
+ columnIndex: columnIndex
2769
+ });
2770
+ if (Array.isArray(result)) {
2771
+ rowspan = result[0];
2772
+ colspan = result[1];
2773
+ } else if ((typeof result === 'undefined' ? 'undefined' : _typeof(result)) === 'object') {
2774
+ rowspan = result.rowspan;
2775
+ colspan = result.colspan;
2776
+ }
2777
+ }
2778
+ return { rowspan: rowspan, colspan: colspan };
2779
+ },
2780
+ getRowStyle: function getRowStyle(row, rowIndex) {
2781
+ var rowStyle = this.table.rowStyle;
2782
+ if (typeof rowStyle === 'function') {
2783
+ return rowStyle.call(null, {
2784
+ row: row,
2785
+ rowIndex: rowIndex
2786
+ });
2787
+ }
2788
+ return rowStyle || null;
2789
+ },
2790
+ getRowClass: function getRowClass(row, rowIndex) {
2791
+ var classes = ['el-table__row'];
2792
+ if (this.table.highlightCurrentRow && row === this.store.states.currentRow) {
2793
+ classes.push('current-row');
2794
+ }
2795
+
2796
+ if (this.stripe && rowIndex % 2 === 1) {
2797
+ classes.push('el-table__row--striped');
2798
+ }
2799
+ var rowClassName = this.table.rowClassName;
2800
+ if (typeof rowClassName === 'string') {
2801
+ classes.push(rowClassName);
2802
+ } else if (typeof rowClassName === 'function') {
2803
+ classes.push(rowClassName.call(null, {
2804
+ row: row,
2805
+ rowIndex: rowIndex
2806
+ }));
2807
+ }
2808
+
2809
+ if (this.store.states.expandRows.indexOf(row) > -1) {
2810
+ classes.push('expanded');
2811
+ }
2812
+
2813
+ return classes;
2814
+ },
2815
+ getCellStyle: function getCellStyle(rowIndex, columnIndex, row, column) {
2816
+ var cellStyle = this.table.cellStyle;
2817
+ if (typeof cellStyle === 'function') {
2818
+ return cellStyle.call(null, {
2819
+ rowIndex: rowIndex,
2820
+ columnIndex: columnIndex,
2821
+ row: row,
2822
+ column: column
2823
+ });
2824
+ }
2825
+ return cellStyle;
2826
+ },
2827
+ getCellClass: function getCellClass(rowIndex, columnIndex, row, column) {
2828
+ var classes = [column.id, column.align, column.className];
2829
+
2830
+ if (this.isColumnHidden(columnIndex)) {
2831
+ classes.push('is-hidden');
2832
+ }
2833
+
2834
+ var cellClassName = this.table.cellClassName;
2835
+ if (typeof cellClassName === 'string') {
2836
+ classes.push(cellClassName);
2837
+ } else if (typeof cellClassName === 'function') {
2838
+ classes.push(cellClassName.call(null, {
2839
+ rowIndex: rowIndex,
2840
+ columnIndex: columnIndex,
2841
+ row: row,
2842
+ column: column
2843
+ }));
2844
+ }
2845
+
2846
+ classes.push('el-table__cell');
2847
+
2848
+ return classes.join(' ');
2849
+ },
2850
+ getColspanRealWidth: function getColspanRealWidth(columns, colspan, index) {
2851
+ if (colspan < 1) {
2852
+ return columns[index].realWidth;
2853
+ }
2854
+ var widthArr = columns.map(function (_ref3) {
2855
+ var realWidth = _ref3.realWidth;
2856
+ return realWidth;
2857
+ }).slice(index, index + colspan);
2858
+ return widthArr.reduce(function (acc, width) {
2859
+ return acc + width;
2860
+ }, -1);
2861
+ },
2862
+ handleCellMouseEnter: function handleCellMouseEnter(event, row) {
2863
+ var table = this.table;
2864
+ var cell = Object(util["b" /* getCell */])(event);
2865
+
2866
+ if (cell) {
2867
+ var column = Object(util["c" /* getColumnByCell */])(table, cell);
2868
+ var hoverState = table.hoverState = { cell: cell, column: column, row: row };
2869
+ table.$emit('cell-mouse-enter', hoverState.row, hoverState.column, hoverState.cell, event);
2870
+ }
2871
+
2872
+ // 判断是否text-overflow, 如果是就显示tooltip
2873
+ var cellChild = event.target.querySelector('.cell');
2874
+ if (!(Object(dom_["hasClass"])(cellChild, 'el-tooltip') && cellChild.childNodes.length)) {
2875
+ return;
2876
+ }
2877
+ // use range width instead of scrollWidth to determine whether the text is overflowing
2878
+ // to address a potential FireFox bug: https://bugzilla.mozilla.org/show_bug.cgi?id=1074543#c3
2879
+ var range = document.createRange();
2880
+ range.setStart(cellChild, 0);
2881
+ range.setEnd(cellChild, cellChild.childNodes.length);
2882
+ var rangeWidth = range.getBoundingClientRect().width;
2883
+ var padding = (parseInt(Object(dom_["getStyle"])(cellChild, 'paddingLeft'), 10) || 0) + (parseInt(Object(dom_["getStyle"])(cellChild, 'paddingRight'), 10) || 0);
2884
+ if ((rangeWidth + padding > cellChild.offsetWidth || cellChild.scrollWidth > cellChild.offsetWidth) && this.$refs.tooltip) {
2885
+ var tooltip = this.$refs.tooltip;
2886
+ // TODO 会引起整个 Table 的重新渲染,需要优化
2887
+ this.tooltipContent = cell.innerText || cell.textContent;
2888
+ tooltip.referenceElm = cell;
2889
+ tooltip.$refs.popper && (tooltip.$refs.popper.style.display = 'none');
2890
+ tooltip.doDestroy();
2891
+ tooltip.setExpectedState(true);
2892
+ this.activateTooltip(tooltip);
2893
+ }
2894
+ },
2895
+ handleCellMouseLeave: function handleCellMouseLeave(event) {
2896
+ var tooltip = this.$refs.tooltip;
2897
+ if (tooltip) {
2898
+ tooltip.setExpectedState(false);
2899
+ tooltip.handleClosePopper();
2900
+ }
2901
+ var cell = Object(util["b" /* getCell */])(event);
2902
+ if (!cell) return;
2903
+
2904
+ var oldHoverState = this.table.hoverState || {};
2905
+ this.table.$emit('cell-mouse-leave', oldHoverState.row, oldHoverState.column, oldHoverState.cell, event);
2906
+ },
2907
+
2908
+
2909
+ handleMouseEnter: debounce_default()(30, function (index) {
2910
+ this.store.commit('setHoverRow', index);
2911
+ }),
2912
+
2913
+ handleMouseLeave: debounce_default()(30, function () {
2914
+ this.store.commit('setHoverRow', null);
2915
+ }),
2916
+
2917
+ handleContextMenu: function handleContextMenu(event, row) {
2918
+ this.handleEvent(event, row, 'contextmenu');
2919
+ },
2920
+ handleDoubleClick: function handleDoubleClick(event, row) {
2921
+ this.handleEvent(event, row, 'dblclick');
2922
+ },
2923
+ handleClick: function handleClick(event, row) {
2924
+ this.store.commit('setCurrentRow', row);
2925
+ this.handleEvent(event, row, 'click');
2926
+ },
2927
+ handleEvent: function handleEvent(event, row, name) {
2928
+ var table = this.table;
2929
+ var cell = Object(util["b" /* getCell */])(event);
2930
+ var column = void 0;
2931
+ if (cell) {
2932
+ column = Object(util["c" /* getColumnByCell */])(table, cell);
2933
+ if (column) {
2934
+ table.$emit('cell-' + name, row, column, cell, event);
2935
+ }
2936
+ }
2937
+ table.$emit('row-' + name, row, column, event);
2938
+ },
2939
+ rowRender: function rowRender(row, $index, treeRowData) {
2940
+ var _this4 = this;
2941
+
2942
+ var h = this.$createElement;
2943
+ var treeIndent = this.treeIndent,
2944
+ columns = this.columns,
2945
+ firstDefaultColumnIndex = this.firstDefaultColumnIndex;
2946
+
2947
+ var rowClasses = this.getRowClass(row, $index);
2948
+ var display = true;
2949
+ if (treeRowData) {
2950
+ rowClasses.push('el-table__row--level-' + treeRowData.level);
2951
+ display = treeRowData.display;
2952
+ }
2953
+ // 指令 v-show 会覆盖 row-style 中 display
2954
+ // 使用 :style 代替 v-show https://github.com/ElemeFE/element/issues/16995
2955
+ var displayStyle = display ? null : {
2956
+ display: 'none'
2957
+ };
2958
+ return h(table_row, {
2959
+ style: [displayStyle, this.getRowStyle(row, $index)],
2960
+ 'class': rowClasses,
2961
+ key: this.getKeyOfRow(row, $index),
2962
+ nativeOn: {
2963
+ 'dblclick': function dblclick($event) {
2964
+ return _this4.handleDoubleClick($event, row);
2965
+ },
2966
+ 'click': function click($event) {
2967
+ return _this4.handleClick($event, row);
2968
+ },
2969
+ 'contextmenu': function contextmenu($event) {
2970
+ return _this4.handleContextMenu($event, row);
2971
+ },
2972
+ 'mouseenter': function mouseenter(_) {
2973
+ return _this4.handleMouseEnter($index);
2974
+ },
2975
+ 'mouseleave': this.handleMouseLeave
2976
+ },
2977
+ attrs: {
2978
+ columns: columns,
2979
+ row: row,
2980
+ index: $index,
2981
+ store: this.store,
2982
+ context: this.context || this.table.$vnode.context,
2983
+ firstDefaultColumnIndex: firstDefaultColumnIndex,
2984
+ treeRowData: treeRowData,
2985
+ treeIndent: treeIndent,
2986
+ columnsHidden: this.columnsHidden,
2987
+ getSpan: this.getSpan,
2988
+ getColspanRealWidth: this.getColspanRealWidth,
2989
+ getCellStyle: this.getCellStyle,
2990
+ getCellClass: this.getCellClass,
2991
+ handleCellMouseEnter: this.handleCellMouseEnter,
2992
+ handleCellMouseLeave: this.handleCellMouseLeave,
2993
+ isSelected: this.store.isSelected(row),
2994
+ isExpanded: this.store.states.expandRows.indexOf(row) > -1,
2995
+ fixed: this.fixed
2996
+ }
2997
+ });
2998
+ },
2999
+ wrappedRowRender: function wrappedRowRender(row, $index) {
3000
+ var _this5 = this;
3001
+
3002
+ var h = this.$createElement;
3003
+
3004
+ var store = this.store;
3005
+ var isRowExpanded = store.isRowExpanded,
3006
+ assertRowKey = store.assertRowKey;
3007
+ var _store$states = store.states,
3008
+ treeData = _store$states.treeData,
3009
+ lazyTreeNodeMap = _store$states.lazyTreeNodeMap,
3010
+ childrenColumnName = _store$states.childrenColumnName,
3011
+ rowKey = _store$states.rowKey;
3012
+
3013
+ if (this.hasExpandColumn && isRowExpanded(row)) {
3014
+ var renderExpanded = this.table.renderExpanded;
3015
+ var tr = this.rowRender(row, $index);
3016
+ if (!renderExpanded) {
3017
+ console.error('[Element Error]renderExpanded is required.');
3018
+ return tr;
3019
+ }
3020
+ // 使用二维数组,避免修改 $index
3021
+ return [[tr, h(
3022
+ 'tr',
3023
+ { key: 'expanded-row__' + tr.key },
3024
+ [h(
3025
+ 'td',
3026
+ {
3027
+ attrs: { colspan: this.columnsCount },
3028
+ 'class': 'el-table__cell el-table__expanded-cell' },
3029
+ [renderExpanded(this.$createElement, { row: row, $index: $index, store: this.store })]
3030
+ )]
3031
+ )]];
3032
+ } else if (Object.keys(treeData).length) {
3033
+ assertRowKey();
3034
+ // TreeTable 时,rowKey 必须由用户设定,不使用 getKeyOfRow 计算
3035
+ // 在调用 rowRender 函数时,仍然会计算 rowKey,不太好的操作
3036
+ var key = Object(util["g" /* getRowIdentity */])(row, rowKey);
3037
+ var cur = treeData[key];
3038
+ var treeRowData = null;
3039
+ if (cur) {
3040
+ treeRowData = {
3041
+ expanded: cur.expanded,
3042
+ level: cur.level,
3043
+ display: true
3044
+ };
3045
+ if (typeof cur.lazy === 'boolean') {
3046
+ if (typeof cur.loaded === 'boolean' && cur.loaded) {
3047
+ treeRowData.noLazyChildren = !(cur.children && cur.children.length);
3048
+ }
3049
+ treeRowData.loading = cur.loading;
3050
+ }
3051
+ }
3052
+ var tmp = [this.rowRender(row, $index, treeRowData)];
3053
+ // 渲染嵌套数据
3054
+ if (cur) {
3055
+ // currentRow 记录的是 index,所以还需主动增加 TreeTable 的 index
3056
+ var i = 0;
3057
+ var traverse = function traverse(children, parent) {
3058
+ if (!(children && children.length && parent)) return;
3059
+ children.forEach(function (node) {
3060
+ // 父节点的 display 状态影响子节点的显示状态
3061
+ var innerTreeRowData = {
3062
+ display: parent.display && parent.expanded,
3063
+ level: parent.level + 1
3064
+ };
3065
+ var childKey = Object(util["g" /* getRowIdentity */])(node, rowKey);
3066
+ if (childKey === undefined || childKey === null) {
3067
+ throw new Error('for nested data item, row-key is required.');
3068
+ }
3069
+ cur = table_body_extends({}, treeData[childKey]);
3070
+ // 对于当前节点,分成有无子节点两种情况。
3071
+ // 如果包含子节点的,设置 expanded 属性。
3072
+ // 对于它子节点的 display 属性由它本身的 expanded 与 display 共同决定。
3073
+ if (cur) {
3074
+ innerTreeRowData.expanded = cur.expanded;
3075
+ // 懒加载的某些节点,level 未知
3076
+ cur.level = cur.level || innerTreeRowData.level;
3077
+ cur.display = !!(cur.expanded && innerTreeRowData.display);
3078
+ if (typeof cur.lazy === 'boolean') {
3079
+ if (typeof cur.loaded === 'boolean' && cur.loaded) {
3080
+ innerTreeRowData.noLazyChildren = !(cur.children && cur.children.length);
3081
+ }
3082
+ innerTreeRowData.loading = cur.loading;
3083
+ }
3084
+ }
3085
+ i++;
3086
+ tmp.push(_this5.rowRender(node, $index + i, innerTreeRowData));
3087
+ if (cur) {
3088
+ var _nodes = lazyTreeNodeMap[childKey] || node[childrenColumnName];
3089
+ traverse(_nodes, cur);
3090
+ }
3091
+ });
3092
+ };
3093
+ // 对于 root 节点,display 一定为 true
3094
+ cur.display = true;
3095
+ var nodes = lazyTreeNodeMap[key] || row[childrenColumnName];
3096
+ traverse(nodes, cur);
3097
+ }
3098
+ return tmp;
3099
+ } else {
3100
+ return this.rowRender(row, $index);
3101
+ }
3102
+ }
3103
+ }
3104
+ });
3105
+ // CONCATENATED MODULE: ./node_modules/_vue-loader@15.10.0@vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/_vue-loader@15.10.0@vue-loader/lib??vue-loader-options!./packages/table/src/filter-panel.vue?vue&type=template&id=41e2a14f&
3106
+ var filter_panelvue_type_template_id_41e2a14f_render = function () {
3107
+ var _vm = this
3108
+ var _h = _vm.$createElement
3109
+ var _c = _vm._self._c || _h
3110
+ return _c("transition", { attrs: { name: "el-zoom-in-top" } }, [
3111
+ _vm.multiple
3112
+ ? _c(
3113
+ "div",
3114
+ {
3115
+ directives: [
3116
+ {
3117
+ name: "clickoutside",
3118
+ rawName: "v-clickoutside",
3119
+ value: _vm.handleOutsideClick,
3120
+ expression: "handleOutsideClick",
3121
+ },
3122
+ {
3123
+ name: "show",
3124
+ rawName: "v-show",
3125
+ value: _vm.showPopper,
3126
+ expression: "showPopper",
3127
+ },
3128
+ ],
3129
+ staticClass: "el-table-filter",
3130
+ },
3131
+ [
3132
+ _c(
3133
+ "div",
3134
+ { staticClass: "el-table-filter__content" },
3135
+ [
3136
+ _c(
3137
+ "el-scrollbar",
3138
+ { attrs: { "wrap-class": "el-table-filter__wrap" } },
3139
+ [
3140
+ _c(
3141
+ "el-checkbox-group",
3142
+ {
3143
+ staticClass: "el-table-filter__checkbox-group",
3144
+ model: {
3145
+ value: _vm.filteredValue,
3146
+ callback: function ($$v) {
3147
+ _vm.filteredValue = $$v
3148
+ },
3149
+ expression: "filteredValue",
3150
+ },
3151
+ },
3152
+ _vm._l(_vm.filters, function (filter) {
3153
+ return _c(
3154
+ "el-checkbox",
3155
+ { key: filter.value, attrs: { label: filter.value } },
3156
+ [_vm._v(_vm._s(filter.text))]
3157
+ )
3158
+ }),
3159
+ 1
3160
+ ),
3161
+ ],
3162
+ 1
3163
+ ),
3164
+ ],
3165
+ 1
3166
+ ),
3167
+ _c("div", { staticClass: "el-table-filter__bottom" }, [
3168
+ _c(
3169
+ "button",
3170
+ {
3171
+ class: { "is-disabled": _vm.filteredValue.length === 0 },
3172
+ attrs: { disabled: _vm.filteredValue.length === 0 },
3173
+ on: { click: _vm.handleConfirm },
3174
+ },
3175
+ [_vm._v(_vm._s(_vm.t("el.table.confirmFilter")))]
3176
+ ),
3177
+ _c("button", { on: { click: _vm.handleReset } }, [
3178
+ _vm._v(_vm._s(_vm.t("el.table.resetFilter"))),
3179
+ ]),
3180
+ ]),
3181
+ ]
3182
+ )
3183
+ : _c(
3184
+ "div",
3185
+ {
3186
+ directives: [
3187
+ {
3188
+ name: "clickoutside",
3189
+ rawName: "v-clickoutside",
3190
+ value: _vm.handleOutsideClick,
3191
+ expression: "handleOutsideClick",
3192
+ },
3193
+ {
3194
+ name: "show",
3195
+ rawName: "v-show",
3196
+ value: _vm.showPopper,
3197
+ expression: "showPopper",
3198
+ },
3199
+ ],
3200
+ staticClass: "el-table-filter",
3201
+ },
3202
+ [
3203
+ _c(
3204
+ "ul",
3205
+ { staticClass: "el-table-filter__list" },
3206
+ [
3207
+ _c(
3208
+ "li",
3209
+ {
3210
+ staticClass: "el-table-filter__list-item",
3211
+ class: {
3212
+ "is-active":
3213
+ _vm.filterValue === undefined ||
3214
+ _vm.filterValue === null,
3215
+ },
3216
+ on: {
3217
+ click: function ($event) {
3218
+ _vm.handleSelect(null)
3219
+ },
3220
+ },
3221
+ },
3222
+ [_vm._v(_vm._s(_vm.t("el.table.clearFilter")))]
3223
+ ),
3224
+ _vm._l(_vm.filters, function (filter) {
3225
+ return _c(
3226
+ "li",
3227
+ {
3228
+ key: filter.value,
3229
+ staticClass: "el-table-filter__list-item",
3230
+ class: { "is-active": _vm.isActive(filter) },
3231
+ attrs: { label: filter.value },
3232
+ on: {
3233
+ click: function ($event) {
3234
+ _vm.handleSelect(filter.value)
3235
+ },
3236
+ },
3237
+ },
3238
+ [_vm._v(_vm._s(filter.text))]
3239
+ )
3240
+ }),
3241
+ ],
3242
+ 2
3243
+ ),
3244
+ ]
3245
+ ),
3246
+ ])
3247
+ }
3248
+ var filter_panelvue_type_template_id_41e2a14f_staticRenderFns = []
3249
+ filter_panelvue_type_template_id_41e2a14f_render._withStripped = true
3250
+
3251
+
3252
+ // CONCATENATED MODULE: ./packages/table/src/filter-panel.vue?vue&type=template&id=41e2a14f&
3253
+
3254
+ // EXTERNAL MODULE: external "element-ui/lib/utils/vue-popper"
3255
+ var vue_popper_ = __webpack_require__(5);
3256
+ var vue_popper_default = /*#__PURE__*/__webpack_require__.n(vue_popper_);
3257
+
3258
+ // EXTERNAL MODULE: external "element-ui/lib/utils/popup"
3259
+ var popup_ = __webpack_require__(13);
3260
+
3261
+ // EXTERNAL MODULE: external "element-ui/lib/utils/clickoutside"
3262
+ var clickoutside_ = __webpack_require__(12);
3263
+ var clickoutside_default = /*#__PURE__*/__webpack_require__.n(clickoutside_);
3264
+
3265
+ // CONCATENATED MODULE: ./packages/table/src/dropdown.js
3266
+
3267
+ var dropdowns = [];
3268
+
3269
+ !external_vue_default.a.prototype.$isServer && document.addEventListener('click', function (event) {
3270
+ dropdowns.forEach(function (dropdown) {
3271
+ var target = event.target;
3272
+ if (!dropdown || !dropdown.$el) return;
3273
+ if (target === dropdown.$el || dropdown.$el.contains(target)) {
3274
+ return;
3275
+ }
3276
+ dropdown.handleOutsideClick && dropdown.handleOutsideClick(event);
3277
+ });
3278
+ });
3279
+
3280
+ /* harmony default export */ var dropdown = ({
3281
+ open: function open(instance) {
3282
+ if (instance) {
3283
+ dropdowns.push(instance);
3284
+ }
3285
+ },
3286
+ close: function close(instance) {
3287
+ var index = dropdowns.indexOf(instance);
3288
+ if (index !== -1) {
3289
+ dropdowns.splice(instance, 1);
3290
+ }
3291
+ }
3292
+ });
3293
+ // EXTERNAL MODULE: external "element-ui/lib/checkbox-group"
3294
+ var checkbox_group_ = __webpack_require__(39);
3295
+ var checkbox_group_default = /*#__PURE__*/__webpack_require__.n(checkbox_group_);
3296
+
3297
+ // EXTERNAL MODULE: external "element-ui/lib/scrollbar"
3298
+ var scrollbar_ = __webpack_require__(15);
3299
+ var scrollbar_default = /*#__PURE__*/__webpack_require__.n(scrollbar_);
3300
+
3301
+ // CONCATENATED MODULE: ./node_modules/_babel-loader@7.1.5@babel-loader/lib!./node_modules/_vue-loader@15.10.0@vue-loader/lib??vue-loader-options!./packages/table/src/filter-panel.vue?vue&type=script&lang=js&
3302
+ //
3303
+ //
3304
+ //
3305
+ //
3306
+ //
3307
+ //
3308
+ //
3309
+ //
3310
+ //
3311
+ //
3312
+ //
3313
+ //
3314
+ //
3315
+ //
3316
+ //
3317
+ //
3318
+ //
3319
+ //
3320
+ //
3321
+ //
3322
+ //
3323
+ //
3324
+ //
3325
+ //
3326
+ //
3327
+ //
3328
+ //
3329
+ //
3330
+ //
3331
+ //
3332
+ //
3333
+ //
3334
+ //
3335
+ //
3336
+ //
3337
+ //
3338
+ //
3339
+ //
3340
+ //
3341
+ //
3342
+ //
3343
+ //
3344
+ //
3345
+ //
3346
+
3347
+
3348
+
3349
+
3350
+
3351
+
3352
+
3353
+
3354
+
3355
+
3356
+ /* harmony default export */ var filter_panelvue_type_script_lang_js_ = ({
3357
+ name: 'ElTableFilterPanel',
3358
+
3359
+ mixins: [vue_popper_default.a, locale_default.a],
3360
+
3361
+ directives: {
3362
+ Clickoutside: clickoutside_default.a
3363
+ },
3364
+
3365
+ components: {
3366
+ ElCheckbox: checkbox_default.a,
3367
+ ElCheckboxGroup: checkbox_group_default.a,
3368
+ ElScrollbar: scrollbar_default.a
3369
+ },
3370
+
3371
+ props: {
3372
+ placement: {
3373
+ type: String,
3374
+ default: 'bottom-end'
3375
+ }
3376
+ },
3377
+
3378
+ methods: {
3379
+ isActive: function isActive(filter) {
3380
+ return filter.value === this.filterValue;
3381
+ },
3382
+ handleOutsideClick: function handleOutsideClick() {
3383
+ var _this = this;
3384
+
3385
+ setTimeout(function () {
3386
+ _this.showPopper = false;
3387
+ }, 16);
3388
+ },
3389
+ handleConfirm: function handleConfirm() {
3390
+ this.confirmFilter(this.filteredValue);
3391
+ this.handleOutsideClick();
3392
+ },
3393
+ handleReset: function handleReset() {
3394
+ this.filteredValue = [];
3395
+ this.confirmFilter(this.filteredValue);
3396
+ this.handleOutsideClick();
3397
+ },
3398
+ handleSelect: function handleSelect(filterValue) {
3399
+ this.filterValue = filterValue;
3400
+
3401
+ if (typeof filterValue !== 'undefined' && filterValue !== null) {
3402
+ this.confirmFilter(this.filteredValue);
3403
+ } else {
3404
+ this.confirmFilter([]);
3405
+ }
3406
+
3407
+ this.handleOutsideClick();
3408
+ },
3409
+ confirmFilter: function confirmFilter(filteredValue) {
3410
+ this.table.store.commit('filterChange', {
3411
+ column: this.column,
3412
+ values: filteredValue
3413
+ });
3414
+ this.table.store.updateAllSelected();
3415
+ }
3416
+ },
3417
+
3418
+ data: function data() {
3419
+ return {
3420
+ table: null,
3421
+ cell: null,
3422
+ column: null
3423
+ };
3424
+ },
3425
+
3426
+
3427
+ computed: {
3428
+ filters: function filters() {
3429
+ return this.column && this.column.filters;
3430
+ },
3431
+
3432
+
3433
+ filterValue: {
3434
+ get: function get() {
3435
+ return (this.column.filteredValue || [])[0];
3436
+ },
3437
+ set: function set(value) {
3438
+ if (this.filteredValue) {
3439
+ if (typeof value !== 'undefined' && value !== null) {
3440
+ this.filteredValue.splice(0, 1, value);
3441
+ } else {
3442
+ this.filteredValue.splice(0, 1);
3443
+ }
3444
+ }
3445
+ }
3446
+ },
3447
+
3448
+ filteredValue: {
3449
+ get: function get() {
3450
+ if (this.column) {
3451
+ return this.column.filteredValue || [];
3452
+ }
3453
+ return [];
3454
+ },
3455
+ set: function set(value) {
3456
+ if (this.column) {
3457
+ this.column.filteredValue = value;
3458
+ }
3459
+ }
3460
+ },
3461
+
3462
+ multiple: function multiple() {
3463
+ if (this.column) {
3464
+ return this.column.filterMultiple;
3465
+ }
3466
+ return true;
3467
+ }
3468
+ },
3469
+
3470
+ mounted: function mounted() {
3471
+ var _this2 = this;
3472
+
3473
+ this.popperElm = this.$el;
3474
+ this.referenceElm = this.cell;
3475
+ this.table.bodyWrapper.addEventListener('scroll', function () {
3476
+ _this2.updatePopper();
3477
+ });
3478
+
3479
+ this.$watch('showPopper', function (value) {
3480
+ if (_this2.column) _this2.column.filterOpened = value;
3481
+ if (value) {
3482
+ dropdown.open(_this2);
3483
+ } else {
3484
+ dropdown.close(_this2);
3485
+ }
3486
+ });
3487
+ },
3488
+
3489
+ watch: {
3490
+ showPopper: function showPopper(val) {
3491
+ if (val === true && parseInt(this.popperJS._popper.style.zIndex, 10) < popup_["PopupManager"].zIndex) {
3492
+ this.popperJS._popper.style.zIndex = popup_["PopupManager"].nextZIndex();
3493
+ }
3494
+ }
3495
+ }
3496
+ });
3497
+ // CONCATENATED MODULE: ./packages/table/src/filter-panel.vue?vue&type=script&lang=js&
3498
+ /* harmony default export */ var src_filter_panelvue_type_script_lang_js_ = (filter_panelvue_type_script_lang_js_);
3499
+ // EXTERNAL MODULE: ./node_modules/_vue-loader@15.10.0@vue-loader/lib/runtime/componentNormalizer.js
3500
+ var componentNormalizer = __webpack_require__(0);
3501
+
3502
+ // CONCATENATED MODULE: ./packages/table/src/filter-panel.vue
3503
+
3504
+
3505
+
3506
+
3507
+
3508
+ /* normalize component */
3509
+
3510
+ var component = Object(componentNormalizer["a" /* default */])(
3511
+ src_filter_panelvue_type_script_lang_js_,
3512
+ filter_panelvue_type_template_id_41e2a14f_render,
3513
+ filter_panelvue_type_template_id_41e2a14f_staticRenderFns,
3514
+ false,
3515
+ null,
3516
+ null,
3517
+ null
3518
+
3519
+ )
3520
+
3521
+ /* harmony default export */ var filter_panel = (component.exports);
3522
+ // CONCATENATED MODULE: ./packages/table/src/table-header.js
3523
+ var table_header_extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
3524
+
3525
+
3526
+
3527
+
3528
+
3529
+
3530
+
3531
+
3532
+ var getAllColumns = function getAllColumns(columns) {
3533
+ var result = [];
3534
+ columns.forEach(function (column) {
3535
+ if (column.children) {
3536
+ result.push(column);
3537
+ result.push.apply(result, getAllColumns(column.children));
3538
+ } else {
3539
+ result.push(column);
3540
+ }
3541
+ });
3542
+ return result;
3543
+ };
3544
+
3545
+ var convertToRows = function convertToRows(originColumns) {
3546
+ var maxLevel = 1;
3547
+ var traverse = function traverse(column, parent) {
3548
+ if (parent) {
3549
+ column.level = parent.level + 1;
3550
+ if (maxLevel < column.level) {
3551
+ maxLevel = column.level;
3552
+ }
3553
+ }
3554
+ if (column.children) {
3555
+ var colSpan = 0;
3556
+ column.children.forEach(function (subColumn) {
3557
+ traverse(subColumn, column);
3558
+ colSpan += subColumn.colSpan;
3559
+ });
3560
+ column.colSpan = colSpan;
3561
+ } else {
3562
+ column.colSpan = 1;
3563
+ }
3564
+ };
3565
+
3566
+ originColumns.forEach(function (column) {
3567
+ column.level = 1;
3568
+ traverse(column);
3569
+ });
3570
+
3571
+ var rows = [];
3572
+ for (var i = 0; i < maxLevel; i++) {
3573
+ rows.push([]);
3574
+ }
3575
+
3576
+ var allColumns = getAllColumns(originColumns);
3577
+
3578
+ allColumns.forEach(function (column) {
3579
+ if (!column.children) {
3580
+ column.rowSpan = maxLevel - column.level + 1;
3581
+ } else {
3582
+ column.rowSpan = 1;
3583
+ }
3584
+ rows[column.level - 1].push(column);
3585
+ });
3586
+
3587
+ return rows;
3588
+ };
3589
+
3590
+ /* harmony default export */ var table_header = ({
3591
+ name: 'ElTableHeader',
3592
+
3593
+ mixins: [layout_observer],
3594
+
3595
+ render: function render(h) {
3596
+ var _this = this;
3597
+
3598
+ var originColumns = this.store.states.originColumns;
3599
+ var columnRows = convertToRows(originColumns, this.columns);
3600
+ // 是否拥有多级表头
3601
+ var isGroup = columnRows.length > 1;
3602
+ if (isGroup) this.$parent.isGroup = true;
3603
+ return h(
3604
+ 'table',
3605
+ { 'class': 'el-table__header', attrs: { cellspacing: '0', cellpadding: '0', border: '0' }
3606
+ },
3607
+ [h('colgroup', [this.columns.map(function (column) {
3608
+ return h('col', {
3609
+ attrs: { name: column.id },
3610
+ key: column.id });
3611
+ }), this.hasGutter ? h('col', {
3612
+ attrs: { name: 'gutter' }
3613
+ }) : '']), h(
3614
+ 'thead',
3615
+ { 'class': [{ 'is-group': isGroup, 'has-gutter': this.hasGutter }] },
3616
+ [this._l(columnRows, function (columns, rowIndex) {
3617
+ return h(
3618
+ 'tr',
3619
+ { style: _this.getHeaderRowStyle(rowIndex), 'class': _this.getHeaderRowClass(rowIndex) },
3620
+ [columns.map(function (column, cellIndex) {
3621
+ return h(
3622
+ 'th',
3623
+ {
3624
+ attrs: { colspan: column.colSpan, rowspan: column.rowSpan },
3625
+ on: {
3626
+ 'mousemove': function mousemove($event) {
3627
+ return _this.handleMouseMove($event, column);
3628
+ },
3629
+ 'mouseout': _this.handleMouseOut,
3630
+ 'mousedown': function mousedown($event) {
3631
+ return _this.handleMouseDown($event, column);
3632
+ },
3633
+ 'click': function click($event) {
3634
+ return _this.handleHeaderClick($event, column);
3635
+ },
3636
+ 'contextmenu': function contextmenu($event) {
3637
+ return _this.handleHeaderContextMenu($event, column);
3638
+ }
3639
+ },
3640
+ style: _this.getHeaderCellStyle(rowIndex, cellIndex, columns, column), 'class': _this.getHeaderCellClass(rowIndex, cellIndex, columns, column), key: column.id },
3641
+ [h(
3642
+ 'div',
3643
+ { 'class': ['cell', column.filteredValue && column.filteredValue.length > 0 ? 'highlight' : '', column.labelClassName] },
3644
+ [column.renderHeader ? column.renderHeader.call(_this._renderProxy, h, { column: column, $index: cellIndex, store: _this.store, _self: _this.$parent.$vnode.context }) : column.label, column.sortable ? h(
3645
+ 'span',
3646
+ { 'class': 'caret-wrapper', on: {
3647
+ 'click': function click($event) {
3648
+ return _this.handleSortClick($event, column);
3649
+ }
3650
+ }
3651
+ },
3652
+ [h('i', { 'class': 'sort-caret ascending', on: {
3653
+ 'click': function click($event) {
3654
+ return _this.handleSortClick($event, column, 'ascending');
3655
+ }
3656
+ }
3657
+ }), h('i', { 'class': 'sort-caret descending', on: {
3658
+ 'click': function click($event) {
3659
+ return _this.handleSortClick($event, column, 'descending');
3660
+ }
3661
+ }
3662
+ })]
3663
+ ) : '', column.filterable ? h(
3664
+ 'span',
3665
+ { 'class': 'el-table__column-filter-trigger', on: {
3666
+ 'click': function click($event) {
3667
+ return _this.handleFilterClick($event, column);
3668
+ }
3669
+ }
3670
+ },
3671
+ [h('i', { 'class': ['el-icon-arrow-down', column.filterOpened ? 'el-icon-arrow-up' : ''] })]
3672
+ ) : '']
3673
+ )]
3674
+ );
3675
+ }), _this.hasGutter ? h('th', { 'class': 'el-table__cell gutter' }) : '']
3676
+ );
3677
+ })]
3678
+ )]
3679
+ );
3680
+ },
3681
+
3682
+
3683
+ props: {
3684
+ fixed: String,
3685
+ store: {
3686
+ required: true
3687
+ },
3688
+ border: Boolean,
3689
+ defaultSort: {
3690
+ type: Object,
3691
+ default: function _default() {
3692
+ return {
3693
+ prop: '',
3694
+ order: ''
3695
+ };
3696
+ }
3697
+ }
3698
+ },
3699
+
3700
+ components: {
3701
+ ElCheckbox: checkbox_default.a
3702
+ },
3703
+
3704
+ computed: table_header_extends({
3705
+ table: function table() {
3706
+ return this.$parent;
3707
+ },
3708
+ hasGutter: function hasGutter() {
3709
+ return !this.fixed && this.tableLayout.gutterWidth;
3710
+ }
3711
+ }, mapStates({
3712
+ columns: 'columns',
3713
+ isAllSelected: 'isAllSelected',
3714
+ leftFixedLeafCount: 'fixedLeafColumnsLength',
3715
+ rightFixedLeafCount: 'rightFixedLeafColumnsLength',
3716
+ columnsCount: function columnsCount(states) {
3717
+ return states.columns.length;
3718
+ },
3719
+ leftFixedCount: function leftFixedCount(states) {
3720
+ return states.fixedColumns.length;
3721
+ },
3722
+ rightFixedCount: function rightFixedCount(states) {
3723
+ return states.rightFixedColumns.length;
3724
+ }
3725
+ })),
3726
+
3727
+ created: function created() {
3728
+ this.filterPanels = {};
3729
+ },
3730
+ mounted: function mounted() {
3731
+ var _this2 = this;
3732
+
3733
+ // nextTick 是有必要的 https://github.com/ElemeFE/element/pull/11311
3734
+ this.$nextTick(function () {
3735
+ var _defaultSort = _this2.defaultSort,
3736
+ prop = _defaultSort.prop,
3737
+ order = _defaultSort.order;
3738
+
3739
+ var init = true;
3740
+ _this2.store.commit('sort', { prop: prop, order: order, init: init });
3741
+ });
3742
+ },
3743
+ beforeDestroy: function beforeDestroy() {
3744
+ var panels = this.filterPanels;
3745
+ for (var prop in panels) {
3746
+ if (panels.hasOwnProperty(prop) && panels[prop]) {
3747
+ panels[prop].$destroy(true);
3748
+ }
3749
+ }
3750
+ },
3751
+
3752
+
3753
+ methods: {
3754
+ isCellHidden: function isCellHidden(index, columns) {
3755
+ var start = 0;
3756
+ for (var i = 0; i < index; i++) {
3757
+ start += columns[i].colSpan;
3758
+ }
3759
+ var after = start + columns[index].colSpan - 1;
3760
+ if (this.fixed === true || this.fixed === 'left') {
3761
+ return after >= this.leftFixedLeafCount;
3762
+ } else if (this.fixed === 'right') {
3763
+ return start < this.columnsCount - this.rightFixedLeafCount;
3764
+ } else {
3765
+ return after < this.leftFixedLeafCount || start >= this.columnsCount - this.rightFixedLeafCount;
3766
+ }
3767
+ },
3768
+ getHeaderRowStyle: function getHeaderRowStyle(rowIndex) {
3769
+ var headerRowStyle = this.table.headerRowStyle;
3770
+ if (typeof headerRowStyle === 'function') {
3771
+ return headerRowStyle.call(null, { rowIndex: rowIndex });
3772
+ }
3773
+ return headerRowStyle;
3774
+ },
3775
+ getHeaderRowClass: function getHeaderRowClass(rowIndex) {
3776
+ var classes = [];
3777
+
3778
+ var headerRowClassName = this.table.headerRowClassName;
3779
+ if (typeof headerRowClassName === 'string') {
3780
+ classes.push(headerRowClassName);
3781
+ } else if (typeof headerRowClassName === 'function') {
3782
+ classes.push(headerRowClassName.call(null, { rowIndex: rowIndex }));
3783
+ }
3784
+
3785
+ return classes.join(' ');
3786
+ },
3787
+ getHeaderCellStyle: function getHeaderCellStyle(rowIndex, columnIndex, row, column) {
3788
+ var headerCellStyle = this.table.headerCellStyle;
3789
+ if (typeof headerCellStyle === 'function') {
3790
+ return headerCellStyle.call(null, {
3791
+ rowIndex: rowIndex,
3792
+ columnIndex: columnIndex,
3793
+ row: row,
3794
+ column: column
3795
+ });
3796
+ }
3797
+ return headerCellStyle;
3798
+ },
3799
+ getHeaderCellClass: function getHeaderCellClass(rowIndex, columnIndex, row, column) {
3800
+ var classes = [column.id, column.order, column.headerAlign, column.className, column.labelClassName];
3801
+
3802
+ if (rowIndex === 0 && this.isCellHidden(columnIndex, row)) {
3803
+ classes.push('is-hidden');
3804
+ }
3805
+
3806
+ if (!column.children) {
3807
+ classes.push('is-leaf');
3808
+ }
3809
+
3810
+ if (column.sortable) {
3811
+ classes.push('is-sortable');
3812
+ }
3813
+
3814
+ var headerCellClassName = this.table.headerCellClassName;
3815
+ if (typeof headerCellClassName === 'string') {
3816
+ classes.push(headerCellClassName);
3817
+ } else if (typeof headerCellClassName === 'function') {
3818
+ classes.push(headerCellClassName.call(null, {
3819
+ rowIndex: rowIndex,
3820
+ columnIndex: columnIndex,
3821
+ row: row,
3822
+ column: column
3823
+ }));
3824
+ }
3825
+
3826
+ classes.push('el-table__cell');
3827
+
3828
+ return classes.join(' ');
3829
+ },
3830
+ toggleAllSelection: function toggleAllSelection() {
3831
+ this.store.commit('toggleAllSelection');
3832
+ },
3833
+ handleFilterClick: function handleFilterClick(event, column) {
3834
+ event.stopPropagation();
3835
+ var target = event.target;
3836
+ var cell = target.tagName === 'TH' ? target : target.parentNode;
3837
+ if (Object(dom_["hasClass"])(cell, 'noclick')) return;
3838
+ cell = cell.querySelector('.el-table__column-filter-trigger') || cell;
3839
+ var table = this.$parent;
3840
+
3841
+ var filterPanel = this.filterPanels[column.id];
3842
+
3843
+ if (filterPanel && column.filterOpened) {
3844
+ filterPanel.showPopper = false;
3845
+ return;
3846
+ }
3847
+
3848
+ if (!filterPanel) {
3849
+ filterPanel = new external_vue_default.a(filter_panel);
3850
+ this.filterPanels[column.id] = filterPanel;
3851
+ if (column.filterPlacement) {
3852
+ filterPanel.placement = column.filterPlacement;
3853
+ }
3854
+ filterPanel.table = table;
3855
+ filterPanel.cell = cell;
3856
+ filterPanel.column = column;
3857
+ !this.$isServer && filterPanel.$mount(document.createElement('div'));
3858
+ }
3859
+
3860
+ setTimeout(function () {
3861
+ filterPanel.showPopper = true;
3862
+ }, 16);
3863
+ },
3864
+ handleHeaderClick: function handleHeaderClick(event, column) {
3865
+ if (!column.filters && column.sortable) {
3866
+ this.handleSortClick(event, column);
3867
+ } else if (column.filterable && !column.sortable) {
3868
+ this.handleFilterClick(event, column);
3869
+ }
3870
+
3871
+ this.$parent.$emit('header-click', column, event);
3872
+ },
3873
+ handleHeaderContextMenu: function handleHeaderContextMenu(event, column) {
3874
+ this.$parent.$emit('header-contextmenu', column, event);
3875
+ },
3876
+ handleMouseDown: function handleMouseDown(event, column) {
3877
+ var _this3 = this;
3878
+
3879
+ if (this.$isServer) return;
3880
+ if (column.children && column.children.length > 0) return;
3881
+ /* istanbul ignore if */
3882
+ if (this.draggingColumn && this.border) {
3883
+ this.dragging = true;
3884
+
3885
+ this.$parent.resizeProxyVisible = true;
3886
+
3887
+ var table = this.$parent;
3888
+ var tableEl = table.$el;
3889
+ var tableLeft = tableEl.getBoundingClientRect().left;
3890
+ var columnEl = this.$el.querySelector('th.' + column.id);
3891
+ var columnRect = columnEl.getBoundingClientRect();
3892
+ var minLeft = columnRect.left - tableLeft + 30;
3893
+
3894
+ Object(dom_["addClass"])(columnEl, 'noclick');
3895
+
3896
+ this.dragState = {
3897
+ startMouseLeft: event.clientX,
3898
+ startLeft: columnRect.right - tableLeft,
3899
+ startColumnLeft: columnRect.left - tableLeft,
3900
+ tableLeft: tableLeft
3901
+ };
3902
+
3903
+ var resizeProxy = table.$refs.resizeProxy;
3904
+ resizeProxy.style.left = this.dragState.startLeft + 'px';
3905
+
3906
+ document.onselectstart = function () {
3907
+ return false;
3908
+ };
3909
+ document.ondragstart = function () {
3910
+ return false;
3911
+ };
3912
+
3913
+ var handleMouseMove = function handleMouseMove(event) {
3914
+ var deltaLeft = event.clientX - _this3.dragState.startMouseLeft;
3915
+ var proxyLeft = _this3.dragState.startLeft + deltaLeft;
3916
+
3917
+ resizeProxy.style.left = Math.max(minLeft, proxyLeft) + 'px';
3918
+ };
3919
+
3920
+ var handleMouseUp = function handleMouseUp() {
3921
+ if (_this3.dragging) {
3922
+ var _dragState = _this3.dragState,
3923
+ startColumnLeft = _dragState.startColumnLeft,
3924
+ startLeft = _dragState.startLeft;
3925
+
3926
+ var finalLeft = parseInt(resizeProxy.style.left, 10);
3927
+ var columnWidth = finalLeft - startColumnLeft;
3928
+ column.width = column.realWidth = columnWidth;
3929
+ table.$emit('header-dragend', column.width, startLeft - startColumnLeft, column, event);
3930
+
3931
+ _this3.store.scheduleLayout();
3932
+
3933
+ document.body.style.cursor = '';
3934
+ _this3.dragging = false;
3935
+ _this3.draggingColumn = null;
3936
+ _this3.dragState = {};
3937
+
3938
+ table.resizeProxyVisible = false;
3939
+ }
3940
+
3941
+ document.removeEventListener('mousemove', handleMouseMove);
3942
+ document.removeEventListener('mouseup', handleMouseUp);
3943
+ document.onselectstart = null;
3944
+ document.ondragstart = null;
3945
+
3946
+ setTimeout(function () {
3947
+ Object(dom_["removeClass"])(columnEl, 'noclick');
3948
+ }, 0);
3949
+ };
3950
+
3951
+ document.addEventListener('mousemove', handleMouseMove);
3952
+ document.addEventListener('mouseup', handleMouseUp);
3953
+ }
3954
+ },
3955
+ handleMouseMove: function handleMouseMove(event, column) {
3956
+ if (column.children && column.children.length > 0) return;
3957
+ var target = event.target;
3958
+ while (target && target.tagName !== 'TH') {
3959
+ target = target.parentNode;
3960
+ }
3961
+
3962
+ if (!column || !column.resizable) return;
3963
+
3964
+ if (!this.dragging && this.border) {
3965
+ var rect = target.getBoundingClientRect();
3966
+
3967
+ var bodyStyle = document.body.style;
3968
+ if (rect.width > 12 && rect.right - event.pageX < 8) {
3969
+ bodyStyle.cursor = 'col-resize';
3970
+ if (Object(dom_["hasClass"])(target, 'is-sortable')) {
3971
+ target.style.cursor = 'col-resize';
3972
+ }
3973
+ this.draggingColumn = column;
3974
+ } else if (!this.dragging) {
3975
+ bodyStyle.cursor = '';
3976
+ if (Object(dom_["hasClass"])(target, 'is-sortable')) {
3977
+ target.style.cursor = 'pointer';
3978
+ }
3979
+ this.draggingColumn = null;
3980
+ }
3981
+ }
3982
+ },
3983
+ handleMouseOut: function handleMouseOut() {
3984
+ if (this.$isServer) return;
3985
+ document.body.style.cursor = '';
3986
+ },
3987
+ toggleOrder: function toggleOrder(_ref) {
3988
+ var order = _ref.order,
3989
+ sortOrders = _ref.sortOrders;
3990
+
3991
+ if (order === '') return sortOrders[0];
3992
+ var index = sortOrders.indexOf(order || null);
3993
+ return sortOrders[index > sortOrders.length - 2 ? 0 : index + 1];
3994
+ },
3995
+ handleSortClick: function handleSortClick(event, column, givenOrder) {
3996
+ event.stopPropagation();
3997
+ var order = column.order === givenOrder ? null : givenOrder || this.toggleOrder(column);
3998
+
3999
+ var target = event.target;
4000
+ while (target && target.tagName !== 'TH') {
4001
+ target = target.parentNode;
4002
+ }
4003
+
4004
+ if (target && target.tagName === 'TH') {
4005
+ if (Object(dom_["hasClass"])(target, 'noclick')) {
4006
+ Object(dom_["removeClass"])(target, 'noclick');
4007
+ return;
4008
+ }
4009
+ }
4010
+
4011
+ if (!column.sortable) return;
4012
+
4013
+ var states = this.store.states;
4014
+ var sortProp = states.sortProp;
4015
+ var sortOrder = void 0;
4016
+ var sortingColumn = states.sortingColumn;
4017
+
4018
+ if (sortingColumn !== column || sortingColumn === column && sortingColumn.order === null) {
4019
+ if (sortingColumn) {
4020
+ sortingColumn.order = null;
4021
+ }
4022
+ states.sortingColumn = column;
4023
+ sortProp = column.property;
4024
+ }
4025
+
4026
+ if (!order) {
4027
+ sortOrder = column.order = null;
4028
+ } else {
4029
+ sortOrder = column.order = order;
4030
+ }
4031
+
4032
+ states.sortProp = sortProp;
4033
+ states.sortOrder = sortOrder;
4034
+
4035
+ this.store.commit('changeSortCondition');
4036
+ }
4037
+ },
4038
+
4039
+ data: function data() {
4040
+ return {
4041
+ draggingColumn: null,
4042
+ dragging: false,
4043
+ dragState: {}
4044
+ };
4045
+ }
4046
+ });
4047
+ // CONCATENATED MODULE: ./packages/table/src/table-footer.js
4048
+ var table_footer_extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
4049
+
4050
+
4051
+
4052
+
4053
+ /* harmony default export */ var table_footer = ({
4054
+ name: 'ElTableFooter',
4055
+
4056
+ mixins: [layout_observer],
4057
+
4058
+ render: function render(h) {
4059
+ var _this = this;
4060
+
4061
+ var sums = [];
4062
+ if (this.summaryMethod) {
4063
+ sums = this.summaryMethod({ columns: this.columns, data: this.store.states.data });
4064
+ } else {
4065
+ this.columns.forEach(function (column, index) {
4066
+ if (index === 0) {
4067
+ sums[index] = _this.sumText;
4068
+ return;
4069
+ }
4070
+ var values = _this.store.states.data.map(function (item) {
4071
+ return Number(item[column.property]);
4072
+ });
4073
+ var precisions = [];
4074
+ var notNumber = true;
4075
+ values.forEach(function (value) {
4076
+ if (!isNaN(value)) {
4077
+ notNumber = false;
4078
+ var decimal = ('' + value).split('.')[1];
4079
+ precisions.push(decimal ? decimal.length : 0);
4080
+ }
4081
+ });
4082
+ var precision = Math.max.apply(null, precisions);
4083
+ if (!notNumber) {
4084
+ sums[index] = values.reduce(function (prev, curr) {
4085
+ var value = Number(curr);
4086
+ if (!isNaN(value)) {
4087
+ return parseFloat((prev + curr).toFixed(Math.min(precision, 20)));
4088
+ } else {
4089
+ return prev;
4090
+ }
4091
+ }, 0);
4092
+ } else {
4093
+ sums[index] = '';
4094
+ }
4095
+ });
4096
+ }
4097
+ console.log('sums:', sums);
4098
+ if (sums instanceof Array) {
4099
+ return h(
4100
+ 'table',
4101
+ { 'class': 'el-table__footer', attrs: { cellspacing: '0', cellpadding: '0', border: '0' }
4102
+ },
4103
+ [h('colgroup', [this.columns.map(function (column) {
4104
+ return h('col', {
4105
+ attrs: { name: column.id },
4106
+ key: column.id });
4107
+ }), this.hasGutter ? h('col', {
4108
+ attrs: { name: 'gutter' }
4109
+ }) : '']), h(
4110
+ 'tbody',
4111
+ { 'class': [{ 'has-gutter': this.hasGutter }] },
4112
+ [h('tr', [this.columns.map(function (column, cellIndex) {
4113
+ return h(
4114
+ 'td',
4115
+ { key: cellIndex, attrs: { colspan: column.colSpan, rowspan: column.rowSpan },
4116
+ 'class': [].concat(_this.getRowClasses(column, cellIndex), ['el-table__cell']) },
4117
+ [h(
4118
+ 'div',
4119
+ { 'class': ['cell', column.labelClassName] },
4120
+ [sums[cellIndex]]
4121
+ )]
4122
+ );
4123
+ }), this.hasGutter ? h('th', { 'class': 'el-table__cell gutter' }) : ''])]
4124
+ )]
4125
+ );
4126
+ } else {
4127
+ return h(
4128
+ 'table',
4129
+ { 'class': 'el-table__footer', attrs: { cellspacing: '0', cellpadding: '0', border: '0' }
4130
+ },
4131
+ [h('colgroup', [this.columns.map(function (column) {
4132
+ return h('col', {
4133
+ attrs: { name: column.id },
4134
+ key: column.id });
4135
+ }), this.hasGutter ? h('col', {
4136
+ attrs: { name: 'gutter' }
4137
+ }) : '']), h(
4138
+ 'tbody',
4139
+ { 'class': [{ 'has-gutter': this.hasGutter }] },
4140
+ [h('tr', [this.columns.map(function (column, cellIndex) {
4141
+ return h(
4142
+ 'td',
4143
+ { key: cellIndex, attrs: { colspan: column.colSpan, rowspan: column.rowSpan },
4144
+ 'class': [].concat(_this.getRowClasses(column, cellIndex), ['el-table__cell']) },
4145
+ [h(
4146
+ 'div',
4147
+ { 'class': ['cell', column.labelClassName] },
4148
+ [sums[column.property]]
4149
+ )]
4150
+ );
4151
+ }), this.hasGutter ? h('th', { 'class': 'el-table__cell gutter' }) : ''])]
4152
+ )]
4153
+ );
4154
+ }
4155
+ },
4156
+
4157
+
4158
+ props: {
4159
+ fixed: String,
4160
+ store: {
4161
+ required: true
4162
+ },
4163
+ summaryMethod: Function,
4164
+ sumText: String,
4165
+ border: Boolean,
4166
+ defaultSort: {
4167
+ type: Object,
4168
+ default: function _default() {
4169
+ return {
4170
+ prop: '',
4171
+ order: ''
4172
+ };
4173
+ }
4174
+ }
4175
+ },
4176
+
4177
+ computed: table_footer_extends({
4178
+ table: function table() {
4179
+ return this.$parent;
4180
+ },
4181
+ hasGutter: function hasGutter() {
4182
+ return !this.fixed && this.tableLayout.gutterWidth;
4183
+ }
4184
+ }, mapStates({
4185
+ columns: 'columns',
4186
+ isAllSelected: 'isAllSelected',
4187
+ leftFixedLeafCount: 'fixedLeafColumnsLength',
4188
+ rightFixedLeafCount: 'rightFixedLeafColumnsLength',
4189
+ columnsCount: function columnsCount(states) {
4190
+ return states.columns.length;
4191
+ },
4192
+ leftFixedCount: function leftFixedCount(states) {
4193
+ return states.fixedColumns.length;
4194
+ },
4195
+ rightFixedCount: function rightFixedCount(states) {
4196
+ return states.rightFixedColumns.length;
4197
+ }
4198
+ })),
4199
+
4200
+ methods: {
4201
+ isCellHidden: function isCellHidden(index, columns, column) {
4202
+ if (this.fixed === true || this.fixed === 'left') {
4203
+ return index >= this.leftFixedLeafCount;
4204
+ } else if (this.fixed === 'right') {
4205
+ var before = 0;
4206
+ for (var i = 0; i < index; i++) {
4207
+ before += columns[i].colSpan;
4208
+ }
4209
+ return before < this.columnsCount - this.rightFixedLeafCount;
4210
+ } else if (!this.fixed && column.fixed) {
4211
+ // hide cell when footer instance is not fixed and column is fixed
4212
+ return true;
4213
+ } else {
4214
+ return index < this.leftFixedCount || index >= this.columnsCount - this.rightFixedCount;
4215
+ }
4216
+ },
4217
+ getRowClasses: function getRowClasses(column, cellIndex) {
4218
+ var classes = [column.id, column.align, column.labelClassName];
4219
+ if (column.className) {
4220
+ classes.push(column.className);
4221
+ }
4222
+ if (this.isCellHidden(cellIndex, this.columns, column)) {
4223
+ classes.push('is-hidden');
4224
+ }
4225
+ if (!column.children) {
4226
+ classes.push('is-leaf');
4227
+ }
4228
+ return classes;
4229
+ }
4230
+ }
4231
+ });
4232
+ // CONCATENATED MODULE: ./node_modules/_babel-loader@7.1.5@babel-loader/lib!./node_modules/_vue-loader@15.10.0@vue-loader/lib??vue-loader-options!./packages/table/src/table.vue?vue&type=script&lang=js&
4233
+ var tablevue_type_script_lang_js_extends = Object.assign || function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; };
4234
+
4235
+ //
4236
+ //
4237
+ //
4238
+ //
4239
+ //
4240
+ //
4241
+ //
4242
+ //
4243
+ //
4244
+ //
4245
+ //
4246
+ //
4247
+ //
4248
+ //
4249
+ //
4250
+ //
4251
+ //
4252
+ //
4253
+ //
4254
+ //
4255
+ //
4256
+ //
4257
+ //
4258
+ //
4259
+ //
4260
+ //
4261
+ //
4262
+ //
4263
+ //
4264
+ //
4265
+ //
4266
+ //
4267
+ //
4268
+ //
4269
+ //
4270
+ //
4271
+ //
4272
+ //
4273
+ //
4274
+ //
4275
+ //
4276
+ //
4277
+ //
4278
+ //
4279
+ //
4280
+ //
4281
+ //
4282
+ //
4283
+ //
4284
+ //
4285
+ //
4286
+ //
4287
+ //
4288
+ //
4289
+ //
4290
+ //
4291
+ //
4292
+ //
4293
+ //
4294
+ //
4295
+ //
4296
+ //
4297
+ //
4298
+ //
4299
+ //
4300
+ //
4301
+ //
4302
+ //
4303
+ //
4304
+ //
4305
+ //
4306
+ //
4307
+ //
4308
+ //
4309
+ //
4310
+ //
4311
+ //
4312
+ //
4313
+ //
4314
+ //
4315
+ //
4316
+ //
4317
+ //
4318
+ //
4319
+ //
4320
+ //
4321
+ //
4322
+ //
4323
+ //
4324
+ //
4325
+ //
4326
+ //
4327
+ //
4328
+ //
4329
+ //
4330
+ //
4331
+ //
4332
+ //
4333
+ //
4334
+ //
4335
+ //
4336
+ //
4337
+ //
4338
+ //
4339
+ //
4340
+ //
4341
+ //
4342
+ //
4343
+ //
4344
+ //
4345
+ //
4346
+ //
4347
+ //
4348
+ //
4349
+ //
4350
+ //
4351
+ //
4352
+ //
4353
+ //
4354
+ //
4355
+ //
4356
+ //
4357
+ //
4358
+ //
4359
+ //
4360
+ //
4361
+ //
4362
+ //
4363
+ //
4364
+ //
4365
+ //
4366
+ //
4367
+ //
4368
+ //
4369
+ //
4370
+ //
4371
+ //
4372
+ //
4373
+ //
4374
+ //
4375
+ //
4376
+ //
4377
+ //
4378
+ //
4379
+ //
4380
+ //
4381
+ //
4382
+ //
4383
+ //
4384
+ //
4385
+ //
4386
+ //
4387
+ //
4388
+ //
4389
+ //
4390
+ //
4391
+ //
4392
+ //
4393
+ //
4394
+ //
4395
+ //
4396
+ //
4397
+ //
4398
+ //
4399
+ //
4400
+ //
4401
+ //
4402
+ //
4403
+ //
4404
+ //
4405
+ //
4406
+ //
4407
+ //
4408
+ //
4409
+ //
4410
+ //
4411
+ //
4412
+ //
4413
+ //
4414
+ //
4415
+ //
4416
+ //
4417
+ //
4418
+ //
4419
+ //
4420
+ //
4421
+ //
4422
+ //
4423
+ //
4424
+ //
4425
+ //
4426
+ //
4427
+ //
4428
+ //
4429
+ //
4430
+ //
4431
+ //
4432
+ //
4433
+ //
4434
+ //
4435
+ //
4436
+ //
4437
+ //
4438
+ //
4439
+ //
4440
+ //
4441
+ //
4442
+ //
4443
+ //
4444
+ //
4445
+ //
4446
+ //
4447
+ //
4448
+ //
4449
+ //
4450
+ //
4451
+ //
4452
+ //
4453
+ //
4454
+ //
4455
+ //
4456
+ //
4457
+ //
4458
+ //
4459
+ //
4460
+ //
4461
+ //
4462
+ //
4463
+ //
4464
+ //
4465
+ //
4466
+ //
4467
+ //
4468
+ //
4469
+ //
4470
+ //
4471
+ //
4472
+ //
4473
+ //
4474
+ //
4475
+ //
4476
+ //
4477
+ //
4478
+ //
4479
+ //
4480
+ //
4481
+ //
4482
+ //
4483
+ //
4484
+ //
4485
+ //
4486
+
4487
+
4488
+
4489
+
4490
+
4491
+
4492
+
4493
+
4494
+
4495
+
4496
+
4497
+
4498
+
4499
+
4500
+ var tableIdSeed = 1;
4501
+
4502
+ /* harmony default export */ var tablevue_type_script_lang_js_ = ({
4503
+ name: 'ElTable',
4504
+
4505
+ mixins: [locale_default.a, migrating_default.a],
4506
+
4507
+ directives: {
4508
+ Mousewheel: directives_mousewheel
4509
+ },
4510
+
4511
+ props: {
4512
+ data: {
4513
+ type: Array,
4514
+ default: function _default() {
4515
+ return [];
4516
+ }
4517
+ },
4518
+
4519
+ size: String,
4520
+
4521
+ width: [String, Number],
4522
+
4523
+ height: [String, Number],
4524
+
4525
+ maxHeight: [String, Number],
4526
+
4527
+ fit: {
4528
+ type: Boolean,
4529
+ default: true
4530
+ },
4531
+
4532
+ stripe: Boolean,
4533
+
4534
+ border: Boolean,
4535
+
4536
+ rowKey: [String, Function],
4537
+
4538
+ context: {},
4539
+
4540
+ showHeader: {
4541
+ type: Boolean,
4542
+ default: true
4543
+ },
4544
+
4545
+ showSummary: Boolean,
4546
+
4547
+ sumText: String,
4548
+
4549
+ summaryMethod: Function,
4550
+
4551
+ rowClassName: [String, Function],
4552
+
4553
+ rowStyle: [Object, Function],
4554
+
4555
+ cellClassName: [String, Function],
4556
+
4557
+ cellStyle: [Object, Function],
4558
+
4559
+ headerRowClassName: [String, Function],
4560
+
4561
+ headerRowStyle: [Object, Function],
4562
+
4563
+ headerCellClassName: [String, Function],
4564
+
4565
+ headerCellStyle: [Object, Function],
4566
+
4567
+ highlightCurrentRow: Boolean,
4568
+
4569
+ currentRowKey: [String, Number],
4570
+
4571
+ emptyText: String,
4572
+
4573
+ expandRowKeys: Array,
4574
+
4575
+ defaultExpandAll: Boolean,
4576
+
4577
+ defaultSort: Object,
4578
+
4579
+ tooltipEffect: String,
4580
+
4581
+ spanMethod: Function,
4582
+
4583
+ selectOnIndeterminate: {
4584
+ type: Boolean,
4585
+ default: true
4586
+ },
4587
+
4588
+ indent: {
4589
+ type: Number,
4590
+ default: 16
4591
+ },
4592
+
4593
+ treeProps: {
4594
+ type: Object,
4595
+ default: function _default() {
4596
+ return {
4597
+ hasChildren: 'hasChildren',
4598
+ children: 'children'
4599
+ };
4600
+ }
4601
+ },
4602
+
4603
+ lazy: Boolean,
4604
+
4605
+ load: Function
4606
+ },
4607
+
4608
+ components: {
4609
+ TableHeader: table_header,
4610
+ TableFooter: table_footer,
4611
+ TableBody: table_body,
4612
+ ElCheckbox: checkbox_default.a
4613
+ },
4614
+
4615
+ methods: {
4616
+ getMigratingConfig: function getMigratingConfig() {
4617
+ return {
4618
+ events: {
4619
+ expand: 'expand is renamed to expand-change'
4620
+ }
4621
+ };
4622
+ },
4623
+ setCurrentRow: function setCurrentRow(row) {
4624
+ this.store.commit('setCurrentRow', row);
4625
+ },
4626
+ toggleRowSelection: function toggleRowSelection(row, selected) {
4627
+ this.store.toggleRowSelection(row, selected, false);
4628
+ this.store.updateAllSelected();
4629
+ },
4630
+ toggleRowExpansion: function toggleRowExpansion(row, expanded) {
4631
+ this.store.toggleRowExpansionAdapter(row, expanded);
4632
+ },
4633
+ clearSelection: function clearSelection() {
4634
+ this.store.clearSelection();
4635
+ },
4636
+ clearFilter: function clearFilter(columnKeys) {
4637
+ this.store.clearFilter(columnKeys);
4638
+ },
4639
+ clearSort: function clearSort() {
4640
+ this.store.clearSort();
4641
+ },
4642
+ handleMouseLeave: function handleMouseLeave() {
4643
+ this.store.commit('setHoverRow', null);
4644
+ if (this.hoverState) this.hoverState = null;
4645
+ },
4646
+ updateScrollY: function updateScrollY() {
4647
+ var changed = this.layout.updateScrollY();
4648
+ if (changed) {
4649
+ this.layout.notifyObservers('scrollable');
4650
+ this.layout.updateColumnsWidth();
4651
+ }
4652
+ },
4653
+ handleFixedMousewheel: function handleFixedMousewheel(event, data) {
4654
+ var bodyWrapper = this.bodyWrapper;
4655
+ if (Math.abs(data.spinY) > 0) {
4656
+ var currentScrollTop = bodyWrapper.scrollTop;
4657
+ if (data.pixelY < 0 && currentScrollTop !== 0) {
4658
+ event.preventDefault();
4659
+ }
4660
+ if (data.pixelY > 0 && bodyWrapper.scrollHeight - bodyWrapper.clientHeight > currentScrollTop) {
4661
+ event.preventDefault();
4662
+ }
4663
+ bodyWrapper.scrollTop += Math.ceil(data.pixelY / 5);
4664
+ } else {
4665
+ bodyWrapper.scrollLeft += Math.ceil(data.pixelX / 5);
4666
+ }
4667
+ },
4668
+ handleHeaderFooterMousewheel: function handleHeaderFooterMousewheel(event, data) {
4669
+ var pixelX = data.pixelX,
4670
+ pixelY = data.pixelY;
4671
+
4672
+ if (Math.abs(pixelX) >= Math.abs(pixelY)) {
4673
+ this.bodyWrapper.scrollLeft += data.pixelX / 5;
4674
+ }
4675
+ },
4676
+
4677
+
4678
+ // TODO 使用 CSS transform
4679
+ syncPostion: function syncPostion() {
4680
+ var _bodyWrapper = this.bodyWrapper,
4681
+ scrollLeft = _bodyWrapper.scrollLeft,
4682
+ scrollTop = _bodyWrapper.scrollTop,
4683
+ offsetWidth = _bodyWrapper.offsetWidth,
4684
+ scrollWidth = _bodyWrapper.scrollWidth;
4685
+ var _$refs = this.$refs,
4686
+ headerWrapper = _$refs.headerWrapper,
4687
+ footerWrapper = _$refs.footerWrapper,
4688
+ fixedBodyWrapper = _$refs.fixedBodyWrapper,
4689
+ rightFixedBodyWrapper = _$refs.rightFixedBodyWrapper;
4690
+
4691
+ if (headerWrapper) headerWrapper.scrollLeft = scrollLeft;
4692
+ if (footerWrapper) footerWrapper.scrollLeft = scrollLeft;
4693
+ if (fixedBodyWrapper) fixedBodyWrapper.scrollTop = scrollTop;
4694
+ if (rightFixedBodyWrapper) rightFixedBodyWrapper.scrollTop = scrollTop;
4695
+ var maxScrollLeftPosition = scrollWidth - offsetWidth - 1;
4696
+ if (scrollLeft >= maxScrollLeftPosition) {
4697
+ this.scrollPosition = 'right';
4698
+ } else if (scrollLeft === 0) {
4699
+ this.scrollPosition = 'left';
4700
+ } else {
4701
+ this.scrollPosition = 'middle';
4702
+ }
4703
+ },
4704
+
4705
+
4706
+ throttleSyncPostion: Object(external_throttle_debounce_["throttle"])(16, function () {
4707
+ this.syncPostion();
4708
+ }),
4709
+
4710
+ onScroll: function onScroll(evt) {
4711
+ var raf = window.requestAnimationFrame;
4712
+ if (!raf) {
4713
+ this.throttleSyncPostion();
4714
+ } else {
4715
+ raf(this.syncPostion);
4716
+ }
4717
+ },
4718
+ bindEvents: function bindEvents() {
4719
+ this.bodyWrapper.addEventListener('scroll', this.onScroll, { passive: true });
4720
+ if (this.fit) {
4721
+ Object(resize_event_["addResizeListener"])(this.$el, this.resizeListener);
4722
+ }
4723
+ },
4724
+ unbindEvents: function unbindEvents() {
4725
+ this.bodyWrapper.removeEventListener('scroll', this.onScroll, { passive: true });
4726
+ if (this.fit) {
4727
+ Object(resize_event_["removeResizeListener"])(this.$el, this.resizeListener);
4728
+ }
4729
+ },
4730
+ resizeListener: function resizeListener() {
4731
+ if (!this.$ready) return;
4732
+ var shouldUpdateLayout = false;
4733
+ var el = this.$el;
4734
+ var _resizeState = this.resizeState,
4735
+ oldWidth = _resizeState.width,
4736
+ oldHeight = _resizeState.height;
4737
+
4738
+
4739
+ var width = el.offsetWidth;
4740
+ if (oldWidth !== width) {
4741
+ shouldUpdateLayout = true;
4742
+ }
4743
+
4744
+ var height = el.offsetHeight;
4745
+ if ((this.height || this.shouldUpdateHeight) && oldHeight !== height) {
4746
+ shouldUpdateLayout = true;
4747
+ }
4748
+
4749
+ if (shouldUpdateLayout) {
4750
+ this.resizeState.width = width;
4751
+ this.resizeState.height = height;
4752
+ this.doLayout();
4753
+ }
4754
+ },
4755
+ doLayout: function doLayout() {
4756
+ if (this.shouldUpdateHeight) {
4757
+ this.layout.updateElsHeight();
4758
+ }
4759
+ this.layout.updateColumnsWidth();
4760
+ },
4761
+ sort: function sort(prop, order) {
4762
+ this.store.commit('sort', { prop: prop, order: order });
4763
+ },
4764
+ toggleAllSelection: function toggleAllSelection() {
4765
+ this.store.commit('toggleAllSelection');
4766
+ }
4767
+ },
4768
+
4769
+ computed: tablevue_type_script_lang_js_extends({
4770
+ tableSize: function tableSize() {
4771
+ return this.size || 'medium' || (this.$ELEMENT || {}).size;
4772
+ },
4773
+ bodyWrapper: function bodyWrapper() {
4774
+ return this.$refs.bodyWrapper;
4775
+ },
4776
+ shouldUpdateHeight: function shouldUpdateHeight() {
4777
+ return this.height || this.maxHeight || this.fixedColumns.length > 0 || this.rightFixedColumns.length > 0;
4778
+ },
4779
+ bodyWidth: function bodyWidth() {
4780
+ var _layout = this.layout,
4781
+ bodyWidth = _layout.bodyWidth,
4782
+ scrollY = _layout.scrollY,
4783
+ gutterWidth = _layout.gutterWidth;
4784
+
4785
+ return bodyWidth ? bodyWidth - (scrollY ? gutterWidth : 0) + 'px' : '';
4786
+ },
4787
+ bodyHeight: function bodyHeight() {
4788
+ var _layout2 = this.layout,
4789
+ _layout2$headerHeight = _layout2.headerHeight,
4790
+ headerHeight = _layout2$headerHeight === undefined ? 0 : _layout2$headerHeight,
4791
+ bodyHeight = _layout2.bodyHeight,
4792
+ _layout2$footerHeight = _layout2.footerHeight,
4793
+ footerHeight = _layout2$footerHeight === undefined ? 0 : _layout2$footerHeight;
4794
+
4795
+ if (this.height) {
4796
+ return {
4797
+ height: bodyHeight ? bodyHeight + 'px' : ''
4798
+ };
4799
+ } else if (this.maxHeight) {
4800
+ var maxHeight = Object(util["j" /* parseHeight */])(this.maxHeight);
4801
+ if (typeof maxHeight === 'number') {
4802
+ return {
4803
+ 'max-height': maxHeight - footerHeight - (this.showHeader ? headerHeight : 0) + 'px'
4804
+ };
4805
+ }
4806
+ }
4807
+ return {};
4808
+ },
4809
+ fixedBodyHeight: function fixedBodyHeight() {
4810
+ if (this.height) {
4811
+ return {
4812
+ height: this.layout.fixedBodyHeight ? this.layout.fixedBodyHeight + 'px' : ''
4813
+ };
4814
+ } else if (this.maxHeight) {
4815
+ var maxHeight = Object(util["j" /* parseHeight */])(this.maxHeight);
4816
+ if (typeof maxHeight === 'number') {
4817
+ maxHeight = this.layout.scrollX ? maxHeight - this.layout.gutterWidth : maxHeight;
4818
+ if (this.showHeader) {
4819
+ maxHeight -= this.layout.headerHeight;
4820
+ }
4821
+ maxHeight -= this.layout.footerHeight;
4822
+ return {
4823
+ 'max-height': maxHeight + 'px'
4824
+ };
4825
+ }
4826
+ }
4827
+ return {};
4828
+ },
4829
+ fixedHeight: function fixedHeight() {
4830
+ if (this.maxHeight) {
4831
+ if (this.showSummary) {
4832
+ return {
4833
+ bottom: 0
4834
+ };
4835
+ }
4836
+ return {
4837
+ bottom: this.layout.scrollX && this.data.length ? this.layout.gutterWidth + 'px' : ''
4838
+ };
4839
+ } else {
4840
+ if (this.showSummary) {
4841
+ return {
4842
+ height: this.layout.tableHeight ? this.layout.tableHeight + 'px' : ''
4843
+ };
4844
+ }
4845
+ return {
4846
+ height: this.layout.viewportHeight ? this.layout.viewportHeight + 'px' : ''
4847
+ };
4848
+ }
4849
+ },
4850
+ emptyBlockStyle: function emptyBlockStyle() {
4851
+ if (this.data && this.data.length) return null;
4852
+ var height = '100%';
4853
+ if (this.layout.appendHeight) {
4854
+ height = 'calc(100% - ' + this.layout.appendHeight + 'px)';
4855
+ }
4856
+ return {
4857
+ width: this.bodyWidth,
4858
+ height: height
4859
+ };
4860
+ }
4861
+ }, mapStates({
4862
+ selection: 'selection',
4863
+ columns: 'columns',
4864
+ tableData: 'data',
4865
+ fixedColumns: 'fixedColumns',
4866
+ rightFixedColumns: 'rightFixedColumns'
4867
+ })),
4868
+
4869
+ watch: {
4870
+ height: {
4871
+ immediate: true,
4872
+ handler: function handler(value) {
4873
+ this.layout.setHeight(value);
4874
+ }
4875
+ },
4876
+
4877
+ maxHeight: {
4878
+ immediate: true,
4879
+ handler: function handler(value) {
4880
+ this.layout.setMaxHeight(value);
4881
+ }
4882
+ },
4883
+
4884
+ currentRowKey: {
4885
+ immediate: true,
4886
+ handler: function handler(value) {
4887
+ if (!this.rowKey) return;
4888
+ this.store.setCurrentRowKey(value);
4889
+ }
4890
+ },
4891
+
4892
+ data: {
4893
+ immediate: true,
4894
+ handler: function handler(value) {
4895
+ this.store.commit('setData', value);
4896
+ }
4897
+ },
4898
+
4899
+ expandRowKeys: {
4900
+ immediate: true,
4901
+ handler: function handler(newVal) {
4902
+ if (newVal) {
4903
+ this.store.setExpandRowKeysAdapter(newVal);
4904
+ }
4905
+ }
4906
+ }
4907
+ },
4908
+
4909
+ created: function created() {
4910
+ var _this = this;
4911
+
4912
+ this.tableId = 'el-table_' + tableIdSeed++;
4913
+ this.debouncedUpdateLayout = Object(external_throttle_debounce_["debounce"])(50, function () {
4914
+ return _this.doLayout();
4915
+ });
4916
+ },
4917
+ mounted: function mounted() {
4918
+ var _this2 = this;
4919
+
4920
+ this.bindEvents();
4921
+ this.store.updateColumns();
4922
+ this.doLayout();
4923
+
4924
+ this.resizeState = {
4925
+ width: this.$el.offsetWidth,
4926
+ height: this.$el.offsetHeight
4927
+
4928
+ // init filters
4929
+ };this.store.states.columns.forEach(function (column) {
4930
+ if (column.filteredValue && column.filteredValue.length) {
4931
+ _this2.store.commit('filterChange', {
4932
+ column: column,
4933
+ values: column.filteredValue,
4934
+ silent: true
4935
+ });
4936
+ }
4937
+ });
4938
+
4939
+ this.$ready = true;
4940
+ },
4941
+ destroyed: function destroyed() {
4942
+ this.unbindEvents();
4943
+ },
4944
+ data: function data() {
4945
+ var _treeProps = this.treeProps,
4946
+ _treeProps$hasChildre = _treeProps.hasChildren,
4947
+ hasChildren = _treeProps$hasChildre === undefined ? 'hasChildren' : _treeProps$hasChildre,
4948
+ _treeProps$children = _treeProps.children,
4949
+ children = _treeProps$children === undefined ? 'children' : _treeProps$children;
4950
+
4951
+ this.store = createStore(this, {
4952
+ rowKey: this.rowKey,
4953
+ defaultExpandAll: this.defaultExpandAll,
4954
+ selectOnIndeterminate: this.selectOnIndeterminate,
4955
+ // TreeTable 的相关配置
4956
+ indent: this.indent,
4957
+ lazy: this.lazy,
4958
+ lazyColumnIdentifier: hasChildren,
4959
+ childrenColumnName: children
4960
+ });
4961
+ var layout = new table_layout({
4962
+ store: this.store,
4963
+ table: this,
4964
+ fit: this.fit,
4965
+ showHeader: this.showHeader
4966
+ });
4967
+ return {
4968
+ layout: layout,
4969
+ isHidden: false,
4970
+ renderExpanded: null,
4971
+ resizeProxyVisible: false,
4972
+ resizeState: {
4973
+ width: null,
4974
+ height: null
4975
+ },
4976
+ // 是否拥有多级表头
4977
+ isGroup: false,
4978
+ scrollPosition: 'left'
4979
+ };
4980
+ }
4981
+ });
4982
+ // CONCATENATED MODULE: ./packages/table/src/table.vue?vue&type=script&lang=js&
4983
+ /* harmony default export */ var src_tablevue_type_script_lang_js_ = (tablevue_type_script_lang_js_);
4984
+ // CONCATENATED MODULE: ./packages/table/src/table.vue
4985
+
4986
+
4987
+
4988
+
4989
+
4990
+ /* normalize component */
4991
+
4992
+ var table_component = Object(componentNormalizer["a" /* default */])(
4993
+ src_tablevue_type_script_lang_js_,
4994
+ render,
4995
+ staticRenderFns,
4996
+ false,
4997
+ null,
4998
+ null,
4999
+ null
5000
+
5001
+ )
5002
+
5003
+ /* harmony default export */ var src_table = (table_component.exports);
5004
+ // CONCATENATED MODULE: ./packages/table/index.js
5005
+
5006
+
5007
+ /* istanbul ignore next */
5008
+ src_table.install = function (Vue) {
5009
+ Vue.component(src_table.name, src_table);
5010
+ };
5011
+
5012
+ /* harmony default export */ var packages_table = __webpack_exports__["default"] = (src_table);
5013
+
5014
+ /***/ })
5015
+ /******/ ]);