cy-element-ui 1.1.13 → 1.1.15

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 (523) hide show
  1. package/README.md +35 -5
  2. package/lib/alert.js +68 -68
  3. package/lib/aside.js +11 -11
  4. package/lib/autocomplete.js +287 -287
  5. package/lib/avatar.js +121 -121
  6. package/lib/backtop.js +91 -91
  7. package/lib/badge.js +32 -32
  8. package/lib/breadcrumb-item.js +33 -33
  9. package/lib/breadcrumb.js +27 -27
  10. package/lib/button-group.js +4 -4
  11. package/lib/button.js +53 -53
  12. package/lib/calendar.js +426 -426
  13. package/lib/card.js +11 -11
  14. package/lib/carousel-item.js +108 -108
  15. package/lib/carousel.js +244 -244
  16. package/lib/cascader-panel.js +1045 -1045
  17. package/lib/cascader.js +577 -577
  18. package/lib/checkbox-button.js +137 -137
  19. package/lib/checkbox-group.js +39 -39
  20. package/lib/checkbox.js +151 -151
  21. package/lib/col.js +64 -64
  22. package/lib/collapse-item.js +66 -66
  23. package/lib/collapse.js +63 -63
  24. package/lib/color-picker.js +944 -944
  25. package/lib/container.js +24 -24
  26. package/lib/date-picker.js +2968 -2967
  27. package/lib/descriptions-item.js +29 -29
  28. package/lib/descriptions.js +324 -324
  29. package/lib/dialog.js +170 -170
  30. package/lib/directives/mousewheel.js +9 -9
  31. package/lib/directives/repeat-click.js +22 -22
  32. package/lib/divider.js +20 -20
  33. package/lib/drawer.js +156 -156
  34. package/lib/dropdown-item.js +19 -19
  35. package/lib/dropdown-menu.js +56 -56
  36. package/lib/dropdown.js +329 -329
  37. package/lib/element-ui.common.js +44918 -0
  38. package/lib/empty.js +39 -39
  39. package/lib/footer.js +11 -11
  40. package/lib/form-item.js +369 -369
  41. package/lib/form.js +181 -181
  42. package/lib/header.js +11 -11
  43. package/lib/icon.js +7 -7
  44. package/lib/image.js +520 -520
  45. package/lib/index.js +1 -1
  46. package/lib/infinite-scroll.js +127 -127
  47. package/lib/input-number.js +260 -260
  48. package/lib/input.js +370 -370
  49. package/lib/link.js +28 -28
  50. package/lib/loading.js +219 -219
  51. package/lib/locale/format.js +25 -26
  52. package/lib/locale/index.js +24 -24
  53. package/lib/locale/lang/en.js +121 -121
  54. package/lib/locale/lang/zh-CN.js +121 -121
  55. package/lib/locale/lang/zh-TW.js +121 -121
  56. package/lib/main.js +5 -5
  57. package/lib/menu-item-group.js +33 -33
  58. package/lib/menu-item.js +116 -116
  59. package/lib/menu.js +490 -490
  60. package/lib/message-box.js +421 -421
  61. package/lib/message.js +150 -150
  62. package/lib/mixins/emitter.js +26 -26
  63. package/lib/mixins/focus.js +7 -7
  64. package/lib/mixins/locale.js +8 -8
  65. package/lib/mixins/migrating.js +34 -34
  66. package/lib/notification.js +184 -184
  67. package/lib/option-group.js +46 -46
  68. package/lib/option.js +145 -145
  69. package/lib/page-header.js +14 -14
  70. package/lib/pagination.js +530 -530
  71. package/lib/popconfirm.js +68 -68
  72. package/lib/popover.js +225 -225
  73. package/lib/progress.js +183 -183
  74. package/lib/radio-button.js +78 -78
  75. package/lib/radio-group.js +103 -103
  76. package/lib/radio.js +86 -86
  77. package/lib/rate.js +283 -283
  78. package/lib/result.js +61 -61
  79. package/lib/row.js +32 -32
  80. package/lib/scrollbar.js +247 -247
  81. package/lib/select.js +999 -999
  82. package/lib/selectDisplayInput.js +61 -61
  83. package/lib/skeleton-item.js +19 -19
  84. package/lib/skeleton.js +53 -53
  85. package/lib/slider.js +550 -550
  86. package/lib/spinner.js +19 -19
  87. package/lib/statistic.js +198 -198
  88. package/lib/step.js +125 -125
  89. package/lib/steps.js +54 -54
  90. package/lib/subTitle.js +24 -24
  91. package/lib/submenu.js +405 -406
  92. package/lib/switch.js +135 -135
  93. package/lib/tab-pane.js +43 -43
  94. package/lib/tabDialog.js +508 -508
  95. package/lib/table-column.js +713 -713
  96. package/lib/table.js +3432 -3432
  97. package/lib/tabs.js +578 -578
  98. package/lib/tag.js +60 -60
  99. package/lib/time-picker.js +1350 -1350
  100. package/lib/time-select.js +949 -949
  101. package/lib/timeline-item.js +25 -25
  102. package/lib/timeline.js +30 -30
  103. package/lib/tooltip.js +255 -255
  104. package/lib/transfer.js +385 -385
  105. package/lib/transitions/collapse-transition.js +76 -76
  106. package/lib/tree.js +1547 -1547
  107. package/lib/treeSelect.js +2618 -2618
  108. package/lib/umd/locale/en.js +137 -137
  109. package/lib/umd/locale/zh-CN.js +137 -137
  110. package/lib/umd/locale/zh-TW.js +137 -137
  111. package/lib/upload.js +738 -738
  112. package/lib/utils/after-leave.js +19 -19
  113. package/lib/utils/aria-dialog.js +56 -56
  114. package/lib/utils/aria-utils.js +66 -66
  115. package/lib/utils/clickoutside.js +39 -39
  116. package/lib/utils/date-util.js +177 -177
  117. package/lib/utils/dom.js +161 -161
  118. package/lib/utils/menu/aria-menubar.js +8 -8
  119. package/lib/utils/menu/aria-menuitem.js +38 -38
  120. package/lib/utils/menu/aria-submenu.js +45 -45
  121. package/lib/utils/merge.js +12 -12
  122. package/lib/utils/popup/index.js +201 -201
  123. package/lib/utils/popup/popup-manager.js +171 -171
  124. package/lib/utils/resize-event.js +33 -33
  125. package/lib/utils/scroll-into-view.js +25 -25
  126. package/lib/utils/scrollbar-width.js +18 -18
  127. package/lib/utils/shared.js +3 -3
  128. package/lib/utils/types.js +10 -10
  129. package/lib/utils/util.js +170 -170
  130. package/lib/utils/vdom.js +1 -1
  131. package/lib/utils/vue-popper.js +176 -176
  132. package/package.json +9 -7
  133. package/packages/alert/index.js +1 -1
  134. package/packages/alert/src/main.vue +82 -82
  135. package/packages/aside/index.js +1 -1
  136. package/packages/aside/src/main.vue +13 -13
  137. package/packages/autocomplete/index.js +1 -1
  138. package/packages/autocomplete/src/autocomplete-suggestions.vue +64 -64
  139. package/packages/autocomplete/src/autocomplete.vue +272 -272
  140. package/packages/avatar/index.js +1 -1
  141. package/packages/avatar/src/main.vue +88 -88
  142. package/packages/backtop/index.js +1 -1
  143. package/packages/backtop/src/main.vue +92 -92
  144. package/packages/badge/index.js +1 -1
  145. package/packages/badge/src/main.vue +41 -41
  146. package/packages/breadcrumb/index.js +1 -1
  147. package/packages/breadcrumb/src/breadcrumb-item.vue +35 -35
  148. package/packages/breadcrumb/src/breadcrumb.vue +27 -27
  149. package/packages/breadcrumb-item/index.js +1 -1
  150. package/packages/button/index.js +1 -1
  151. package/packages/button/src/button-group.vue +6 -6
  152. package/packages/button/src/button.vue +70 -70
  153. package/packages/button-group/index.js +1 -1
  154. package/packages/calendar/index.js +1 -1
  155. package/packages/calendar/src/date-table.vue +193 -193
  156. package/packages/calendar/src/main.vue +242 -242
  157. package/packages/card/index.js +1 -1
  158. package/packages/card/src/main.vue +18 -18
  159. package/packages/carousel/index.js +1 -1
  160. package/packages/carousel/src/item.vue +122 -122
  161. package/packages/carousel/src/main.vue +305 -305
  162. package/packages/carousel-item/index.js +1 -1
  163. package/packages/cascader/index.js +1 -1
  164. package/packages/cascader/src/cascader.vue +626 -626
  165. package/packages/cascader-panel/index.js +1 -1
  166. package/packages/cascader-panel/src/cascader-menu.vue +128 -128
  167. package/packages/cascader-panel/src/cascader-node.vue +244 -244
  168. package/packages/cascader-panel/src/cascader-panel.vue +334 -334
  169. package/packages/cascader-panel/src/node.js +157 -158
  170. package/packages/cascader-panel/src/store.js +49 -50
  171. package/packages/checkbox/index.js +1 -1
  172. package/packages/checkbox/src/checkbox-button.vue +195 -195
  173. package/packages/checkbox/src/checkbox-group.vue +43 -43
  174. package/packages/checkbox/src/checkbox.vue +218 -218
  175. package/packages/checkbox-button/index.js +1 -1
  176. package/packages/checkbox-group/index.js +1 -1
  177. package/packages/col/index.js +1 -1
  178. package/packages/col/src/col.js +63 -63
  179. package/packages/collapse/index.js +1 -1
  180. package/packages/collapse/src/collapse-item.vue +101 -101
  181. package/packages/collapse/src/collapse.vue +61 -61
  182. package/packages/collapse-item/index.js +1 -1
  183. package/packages/color-picker/index.js +1 -1
  184. package/packages/color-picker/src/color.js +263 -263
  185. package/packages/color-picker/src/components/alpha-slider.vue +127 -127
  186. package/packages/color-picker/src/components/hue-slider.vue +118 -118
  187. package/packages/color-picker/src/components/picker-dropdown.vue +105 -105
  188. package/packages/color-picker/src/components/predefine.vue +55 -55
  189. package/packages/color-picker/src/components/sv-panel.vue +95 -95
  190. package/packages/color-picker/src/draggable.js +27 -27
  191. package/packages/color-picker/src/main.vue +183 -183
  192. package/packages/container/index.js +1 -1
  193. package/packages/container/src/main.vue +25 -25
  194. package/packages/date-picker/index.js +1 -1
  195. package/packages/date-picker/src/basic/date-table.vue +435 -435
  196. package/packages/date-picker/src/basic/month-table.vue +239 -240
  197. package/packages/date-picker/src/basic/time-spinner.vue +279 -279
  198. package/packages/date-picker/src/basic/year-table.vue +99 -99
  199. package/packages/date-picker/src/panel/date-range.vue +675 -675
  200. package/packages/date-picker/src/panel/date.vue +604 -604
  201. package/packages/date-picker/src/panel/month-range.vue +260 -260
  202. package/packages/date-picker/src/panel/time-range.vue +242 -242
  203. package/packages/date-picker/src/panel/time-select.vue +173 -173
  204. package/packages/date-picker/src/panel/time.vue +181 -181
  205. package/packages/date-picker/src/picker/date-picker.js +29 -29
  206. package/packages/date-picker/src/picker/time-picker.js +28 -28
  207. package/packages/date-picker/src/picker/time-select.js +12 -12
  208. package/packages/date-picker/src/picker.vue +900 -900
  209. package/packages/descriptions/index.js +1 -1
  210. package/packages/descriptions/src/descriptions-item.js +28 -28
  211. package/packages/descriptions/src/descriptions-row.js +114 -114
  212. package/packages/descriptions/src/index.js +168 -168
  213. package/packages/descriptions-item/index.js +1 -1
  214. package/packages/dialog/index.js +1 -1
  215. package/packages/dialog/src/component.vue +207 -207
  216. package/packages/divider/index.js +1 -1
  217. package/packages/divider/src/main.vue +29 -29
  218. package/packages/drawer/index.js +1 -1
  219. package/packages/drawer/src/main.vue +195 -195
  220. package/packages/dropdown/index.js +1 -1
  221. package/packages/dropdown/src/dropdown-item.vue +29 -29
  222. package/packages/dropdown/src/dropdown-menu.vue +59 -59
  223. package/packages/dropdown/src/dropdown.vue +271 -271
  224. package/packages/dropdown-item/index.js +1 -1
  225. package/packages/dropdown-menu/index.js +1 -1
  226. package/packages/empty/index.js +1 -1
  227. package/packages/empty/src/img-empty.vue +124 -124
  228. package/packages/empty/src/index.vue +40 -40
  229. package/packages/footer/index.js +1 -1
  230. package/packages/footer/src/main.vue +13 -13
  231. package/packages/form/index.js +1 -1
  232. package/packages/form/src/form-item.vue +294 -294
  233. package/packages/form/src/form.vue +169 -169
  234. package/packages/form/src/label-wrap.vue +65 -65
  235. package/packages/form-item/index.js +1 -1
  236. package/packages/header/index.js +1 -1
  237. package/packages/header/src/main.vue +13 -13
  238. package/packages/icon/index.js +1 -1
  239. package/packages/icon/src/icon.vue +7 -7
  240. package/packages/image/index.js +1 -1
  241. package/packages/image/src/image-viewer.vue +309 -309
  242. package/packages/image/src/main.vue +242 -242
  243. package/packages/infinite-scroll/index.js +1 -1
  244. package/packages/infinite-scroll/src/main.js +113 -114
  245. package/packages/input/index.js +1 -1
  246. package/packages/input/src/calcTextareaHeight.js +70 -70
  247. package/packages/input/src/input.vue +416 -416
  248. package/packages/input-number/index.js +1 -1
  249. package/packages/input-number/src/input-number.vue +272 -272
  250. package/packages/link/index.js +1 -1
  251. package/packages/link/src/main.vue +40 -40
  252. package/packages/loading/index.js +6 -6
  253. package/packages/loading/src/directive.js +105 -105
  254. package/packages/loading/src/index.js +74 -74
  255. package/packages/loading/src/loading.vue +35 -35
  256. package/packages/main/index.js +1 -1
  257. package/packages/main/src/main.vue +7 -7
  258. package/packages/menu/index.js +1 -1
  259. package/packages/menu/src/menu-item-group.vue +38 -38
  260. package/packages/menu/src/menu-item.vue +103 -103
  261. package/packages/menu/src/menu-mixin.js +39 -39
  262. package/packages/menu/src/menu.vue +298 -298
  263. package/packages/menu/src/submenu.vue +330 -331
  264. package/packages/menu-item/index.js +1 -1
  265. package/packages/menu-item-group/index.js +1 -1
  266. package/packages/message/src/main.js +65 -65
  267. package/packages/message/src/main.vue +105 -105
  268. package/packages/message-box/src/main.js +172 -172
  269. package/packages/message-box/src/main.vue +309 -309
  270. package/packages/notification/src/main.js +63 -63
  271. package/packages/notification/src/main.vue +135 -135
  272. package/packages/option/index.js +1 -1
  273. package/packages/option-group/index.js +1 -1
  274. package/packages/page-header/index.js +1 -1
  275. package/packages/page-header/src/main.vue +21 -21
  276. package/packages/pagination/index.js +1 -1
  277. package/packages/pagination/src/pager.vue +158 -158
  278. package/packages/pagination/src/pagination.js +377 -377
  279. package/packages/popconfirm/index.js +1 -1
  280. package/packages/popconfirm/src/main.vue +94 -94
  281. package/packages/popover/index.js +2 -2
  282. package/packages/popover/src/directive.js +15 -15
  283. package/packages/popover/src/main.vue +214 -214
  284. package/packages/progress/index.js +1 -1
  285. package/packages/progress/src/progress.vue +228 -228
  286. package/packages/radio/index.js +1 -1
  287. package/packages/radio/src/radio-button.vue +106 -106
  288. package/packages/radio/src/radio-group.vue +101 -101
  289. package/packages/radio/src/radio.vue +122 -122
  290. package/packages/radio-button/index.js +1 -1
  291. package/packages/radio-group/index.js +1 -1
  292. package/packages/rate/index.js +1 -1
  293. package/packages/rate/src/main.vue +316 -316
  294. package/packages/result/index.js +1 -1
  295. package/packages/result/src/icon-error.vue +6 -6
  296. package/packages/result/src/icon-info.vue +6 -6
  297. package/packages/result/src/icon-success.vue +6 -6
  298. package/packages/result/src/icon-warning.vue +6 -6
  299. package/packages/result/src/index.vue +51 -51
  300. package/packages/row/index.js +1 -1
  301. package/packages/row/src/row.js +36 -36
  302. package/packages/scrollbar/index.js +1 -1
  303. package/packages/scrollbar/src/bar.js +86 -86
  304. package/packages/scrollbar/src/main.js +120 -120
  305. package/packages/scrollbar/src/util.js +27 -27
  306. package/packages/select/index.js +1 -1
  307. package/packages/select/src/navigation-mixin.js +47 -47
  308. package/packages/select/src/option-group.vue +55 -55
  309. package/packages/select/src/option.vue +163 -163
  310. package/packages/select/src/select-dropdown.vue +57 -57
  311. package/packages/select/src/select.vue +895 -895
  312. package/packages/selectDisplayInput/index.js +1 -1
  313. package/packages/selectDisplayInput/src/main.vue +61 -61
  314. package/packages/skeleton/index.js +1 -1
  315. package/packages/skeleton/src/img-placeholder.vue +9 -9
  316. package/packages/skeleton/src/index.vue +70 -70
  317. package/packages/skeleton/src/item.vue +17 -17
  318. package/packages/skeleton-item/index.js +1 -1
  319. package/packages/slider/index.js +1 -1
  320. package/packages/slider/src/button.vue +230 -230
  321. package/packages/slider/src/main.vue +422 -422
  322. package/packages/slider/src/marker.js +14 -14
  323. package/packages/spinner/index.js +1 -1
  324. package/packages/spinner/src/spinner.vue +23 -23
  325. package/packages/statistic/index.js +1 -1
  326. package/packages/statistic/src/main.vue +196 -197
  327. package/packages/step/index.js +1 -1
  328. package/packages/steps/index.js +1 -1
  329. package/packages/steps/src/step.vue +177 -177
  330. package/packages/steps/src/steps.vue +53 -53
  331. package/packages/subTitle/index.js +1 -1
  332. package/packages/subTitle/src/main.vue +29 -29
  333. package/packages/submenu/index.js +1 -1
  334. package/packages/switch/index.js +1 -1
  335. package/packages/switch/src/component.vue +169 -169
  336. package/packages/tab-pane/index.js +1 -1
  337. package/packages/tabDialog/index.js +10 -10
  338. package/packages/tabDialog/src/dialog/drag.js +50 -50
  339. package/packages/tabDialog/src/dialog/dragHeight.js +27 -27
  340. package/packages/tabDialog/src/dialog/dragWidth.js +23 -23
  341. package/packages/tabDialog/src/main.vue +257 -257
  342. package/packages/table/index.js +1 -1
  343. package/packages/table/src/config.js +108 -108
  344. package/packages/table/src/dropdown.js +19 -19
  345. package/packages/table/src/filter-panel.vue +189 -189
  346. package/packages/table/src/layout-observer.js +60 -60
  347. package/packages/table/src/store/current.js +65 -65
  348. package/packages/table/src/store/expand.js +57 -57
  349. package/packages/table/src/store/helper.js +32 -32
  350. package/packages/table/src/store/index.js +133 -133
  351. package/packages/table/src/store/tree.js +194 -194
  352. package/packages/table/src/store/watcher.js +366 -366
  353. package/packages/table/src/table-body.js +456 -456
  354. package/packages/table/src/table-column.js +311 -311
  355. package/packages/table/src/table-footer.js +139 -139
  356. package/packages/table/src/table-header.js +496 -496
  357. package/packages/table/src/table-layout.js +241 -241
  358. package/packages/table/src/table-row.js +97 -97
  359. package/packages/table/src/table.vue +666 -666
  360. package/packages/table/src/util.js +214 -214
  361. package/packages/table-column/index.js +1 -1
  362. package/packages/tabs/index.js +1 -1
  363. package/packages/tabs/src/tab-bar.vue +47 -47
  364. package/packages/tabs/src/tab-nav.vue +268 -268
  365. package/packages/tabs/src/tab-pane.vue +47 -47
  366. package/packages/tabs/src/tabs.vue +174 -174
  367. package/packages/tag/index.js +1 -1
  368. package/packages/tag/src/tag.vue +55 -55
  369. package/packages/theme-chalk/gulpfile.js +11 -11
  370. package/packages/theme-chalk/src/alert.scss +138 -138
  371. package/packages/theme-chalk/src/aside.scss +3 -3
  372. package/packages/theme-chalk/src/autocomplete.scss +58 -58
  373. package/packages/theme-chalk/src/avatar.scss +46 -46
  374. package/packages/theme-chalk/src/backtop.scss +16 -16
  375. package/packages/theme-chalk/src/badge.scss +47 -47
  376. package/packages/theme-chalk/src/breadcrumb.scss +49 -49
  377. package/packages/theme-chalk/src/button.scss +229 -229
  378. package/packages/theme-chalk/src/calendar.scss +57 -57
  379. package/packages/theme-chalk/src/card.scss +23 -23
  380. package/packages/theme-chalk/src/carousel-item.scss +41 -41
  381. package/packages/theme-chalk/src/carousel.scss +148 -148
  382. package/packages/theme-chalk/src/cascader-panel.scss +106 -106
  383. package/packages/theme-chalk/src/cascader.scss +173 -173
  384. package/packages/theme-chalk/src/checkbox.scss +346 -346
  385. package/packages/theme-chalk/src/col.scss +130 -130
  386. package/packages/theme-chalk/src/collapse.scss +52 -52
  387. package/packages/theme-chalk/src/color-picker.scss +364 -364
  388. package/packages/theme-chalk/src/common/popup.scss +22 -22
  389. package/packages/theme-chalk/src/common/transition.scss +33 -33
  390. package/packages/theme-chalk/src/common/var.scss +16 -16
  391. package/packages/theme-chalk/src/container.scss +9 -9
  392. package/packages/theme-chalk/src/cy/base.scss +1 -1
  393. package/packages/theme-chalk/src/date-picker/date-picker.scss +91 -91
  394. package/packages/theme-chalk/src/date-picker/date-range-picker.scss +97 -97
  395. package/packages/theme-chalk/src/date-picker/date-table.scss +146 -146
  396. package/packages/theme-chalk/src/date-picker/month-table.scss +69 -69
  397. package/packages/theme-chalk/src/date-picker/picker-panel.scss +105 -105
  398. package/packages/theme-chalk/src/date-picker/picker.scss +188 -188
  399. package/packages/theme-chalk/src/date-picker/time-picker.scss +72 -72
  400. package/packages/theme-chalk/src/date-picker/time-range-picker.scss +23 -23
  401. package/packages/theme-chalk/src/date-picker/time-spinner.scss +106 -106
  402. package/packages/theme-chalk/src/date-picker/year-table.scss +47 -47
  403. package/packages/theme-chalk/src/descriptions-item.scss +33 -33
  404. package/packages/theme-chalk/src/descriptions.scss +105 -105
  405. package/packages/theme-chalk/src/dialog.scss +104 -104
  406. package/packages/theme-chalk/src/display.scss +7 -7
  407. package/packages/theme-chalk/src/divider.scss +36 -36
  408. package/packages/theme-chalk/src/drawer.scss +185 -185
  409. package/packages/theme-chalk/src/dropdown.scss +172 -172
  410. package/packages/theme-chalk/src/empty.scss +34 -34
  411. package/packages/theme-chalk/src/footer.scss +3 -3
  412. package/packages/theme-chalk/src/form.scss +149 -149
  413. package/packages/theme-chalk/src/header.scss +3 -3
  414. package/packages/theme-chalk/src/icon.scss +309 -309
  415. package/packages/theme-chalk/src/image.scss +153 -153
  416. package/packages/theme-chalk/src/input-number.scss +255 -255
  417. package/packages/theme-chalk/src/input.scss +345 -345
  418. package/packages/theme-chalk/src/link.scss +67 -67
  419. package/packages/theme-chalk/src/loading.scss +67 -67
  420. package/packages/theme-chalk/src/main.scss +7 -7
  421. package/packages/theme-chalk/src/menu.scss +248 -248
  422. package/packages/theme-chalk/src/message-box.scss +205 -205
  423. package/packages/theme-chalk/src/message.scss +111 -111
  424. package/packages/theme-chalk/src/mixins/_button.scss +64 -64
  425. package/packages/theme-chalk/src/mixins/function.scss +18 -18
  426. package/packages/theme-chalk/src/mixins/mixins.scss +126 -126
  427. package/packages/theme-chalk/src/mixins/utils.scss +26 -26
  428. package/packages/theme-chalk/src/notification.scss +88 -88
  429. package/packages/theme-chalk/src/option-group.scss +31 -31
  430. package/packages/theme-chalk/src/option.scss +27 -27
  431. package/packages/theme-chalk/src/page-header.scss +31 -31
  432. package/packages/theme-chalk/src/pagination.scss +284 -284
  433. package/packages/theme-chalk/src/popconfirm.scss +11 -11
  434. package/packages/theme-chalk/src/popover.scss +30 -30
  435. package/packages/theme-chalk/src/popper.scss +82 -82
  436. package/packages/theme-chalk/src/progress.scss +128 -128
  437. package/packages/theme-chalk/src/radio-button.scss +94 -94
  438. package/packages/theme-chalk/src/radio-group.scss +4 -4
  439. package/packages/theme-chalk/src/radio.scss +192 -192
  440. package/packages/theme-chalk/src/rate.scss +38 -38
  441. package/packages/theme-chalk/src/reset.scss +39 -39
  442. package/packages/theme-chalk/src/result.scss +56 -56
  443. package/packages/theme-chalk/src/row.scss +31 -31
  444. package/packages/theme-chalk/src/scrollbar.scss +57 -57
  445. package/packages/theme-chalk/src/select-dropdown.scss +47 -47
  446. package/packages/theme-chalk/src/select.scss +140 -140
  447. package/packages/theme-chalk/src/skeleton-item.scss +75 -75
  448. package/packages/theme-chalk/src/skeleton.scss +27 -27
  449. package/packages/theme-chalk/src/slider.scss +238 -238
  450. package/packages/theme-chalk/src/spinner.scss +27 -27
  451. package/packages/theme-chalk/src/statistic.scss +32 -32
  452. package/packages/theme-chalk/src/step.scss +312 -312
  453. package/packages/theme-chalk/src/steps.scss +13 -13
  454. package/packages/theme-chalk/src/switch.scss +101 -101
  455. package/packages/theme-chalk/src/table-column.scss +87 -87
  456. package/packages/theme-chalk/src/table.scss +556 -556
  457. package/packages/theme-chalk/src/tabs.scss +576 -576
  458. package/packages/theme-chalk/src/tag.scss +155 -155
  459. package/packages/theme-chalk/src/time-select.scss +14 -14
  460. package/packages/theme-chalk/src/timeline-item.scss +71 -71
  461. package/packages/theme-chalk/src/timeline.scss +8 -8
  462. package/packages/theme-chalk/src/tooltip.scss +136 -136
  463. package/packages/theme-chalk/src/transfer.scss +214 -214
  464. package/packages/theme-chalk/src/tree.scss +110 -110
  465. package/packages/theme-chalk/src/upload.scss +587 -587
  466. package/packages/time-picker/index.js +1 -1
  467. package/packages/time-select/index.js +1 -1
  468. package/packages/timeline/index.js +1 -1
  469. package/packages/timeline/src/item.vue +56 -56
  470. package/packages/timeline/src/main.vue +28 -28
  471. package/packages/timeline-item/index.js +1 -1
  472. package/packages/tooltip/index.js +1 -1
  473. package/packages/tooltip/src/main.js +234 -234
  474. package/packages/transfer/index.js +1 -1
  475. package/packages/transfer/src/main.vue +225 -225
  476. package/packages/transfer/src/transfer-panel.vue +245 -245
  477. package/packages/tree/index.js +1 -1
  478. package/packages/tree/src/model/node.js +467 -467
  479. package/packages/tree/src/model/tree-store.js +335 -335
  480. package/packages/tree/src/model/util.js +17 -17
  481. package/packages/tree/src/tree-node.vue +247 -247
  482. package/packages/tree/src/tree.vue +491 -491
  483. package/packages/treeSelect/index.js +1 -1
  484. package/packages/treeSelect/src/main.vue +275 -275
  485. package/packages/upload/index.js +1 -1
  486. package/packages/upload/src/ajax.js +77 -77
  487. package/packages/upload/src/index.vue +304 -304
  488. package/packages/upload/src/upload-dragger.vue +65 -65
  489. package/packages/upload/src/upload-list.vue +96 -96
  490. package/packages/upload/src/upload.vue +194 -194
  491. package/src/directives/mousewheel.js +9 -9
  492. package/src/directives/repeat-click.js +20 -20
  493. package/src/index.js +209 -210
  494. package/src/locale/format.js +24 -25
  495. package/src/locale/index.js +25 -25
  496. package/src/locale/lang/en.js +121 -121
  497. package/src/locale/lang/zh-CN.js +121 -121
  498. package/src/locale/lang/zh-TW.js +121 -121
  499. package/src/mixins/emitter.js +26 -26
  500. package/src/mixins/focus.js +7 -7
  501. package/src/mixins/locale.js +5 -5
  502. package/src/mixins/migrating.js +28 -28
  503. package/src/transitions/collapse-transition.js +60 -60
  504. package/src/utils/after-leave.js +17 -17
  505. package/src/utils/aria-dialog.js +48 -48
  506. package/src/utils/aria-utils.js +64 -64
  507. package/src/utils/clickoutside.js +34 -34
  508. package/src/utils/date-util.js +163 -163
  509. package/src/utils/dom.js +165 -165
  510. package/src/utils/menu/aria-menubar.js +5 -5
  511. package/src/utils/menu/aria-menuitem.js +36 -36
  512. package/src/utils/menu/aria-submenu.js +44 -44
  513. package/src/utils/merge.js +12 -12
  514. package/src/utils/popup/index.js +203 -203
  515. package/src/utils/popup/popup-manager.js +169 -169
  516. package/src/utils/resize-event.js +20 -20
  517. package/src/utils/scroll-into-view.js +20 -20
  518. package/src/utils/scrollbar-width.js +18 -18
  519. package/src/utils/shared.js +3 -3
  520. package/src/utils/types.js +12 -12
  521. package/src/utils/util.js +157 -157
  522. package/src/utils/vdom.js +1 -1
  523. package/src/utils/vue-popper.js +179 -179
package/lib/form-item.js CHANGED
@@ -220,7 +220,7 @@ module.exports = require("async-validator");
220
220
  // ESM COMPAT FLAG
221
221
  __webpack_require__.r(__webpack_exports__);
222
222
 
223
- // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/form/src/form-item.vue?vue&type=template&id=53447fd0
223
+ // CONCATENATED MODULE: ./node_modules/vue-loader/lib/loaders/templateLoader.js??vue-loader-options!./node_modules/vue-loader/lib??vue-loader-options!./packages/form/src/form-item.vue?vue&type=template&id=a193e2c8
224
224
  var render = function () {
225
225
  var _vm = this
226
226
  var _h = _vm.$createElement
@@ -298,9 +298,9 @@ var render = function () {
298
298
  },
299
299
  [
300
300
  _vm._v(
301
- "\n " +
301
+ "\n\t\t\t\t\t" +
302
302
  _vm._s(_vm.validateMessage) +
303
- "\n "
303
+ "\n\t\t\t\t"
304
304
  ),
305
305
  ]
306
306
  ),
@@ -322,7 +322,7 @@ var staticRenderFns = []
322
322
  render._withStripped = true
323
323
 
324
324
 
325
- // CONCATENATED MODULE: ./packages/form/src/form-item.vue?vue&type=template&id=53447fd0
325
+ // CONCATENATED MODULE: ./packages/form/src/form-item.vue?vue&type=template&id=a193e2c8
326
326
 
327
327
  // EXTERNAL MODULE: external "async-validator"
328
328
  var external_async_validator_ = __webpack_require__(54);
@@ -343,83 +343,83 @@ var util_ = __webpack_require__(3);
343
343
 
344
344
 
345
345
  /* harmony default export */ var label_wrapvue_type_script_lang_js = ({
346
- props: {
347
- isAutoWidth: Boolean,
348
- updateAll: Boolean
349
- },
350
-
351
- inject: ['elForm', 'elFormItem'],
352
-
353
- render: function render() {
354
- var h = arguments[0];
355
-
356
- var slots = this.$slots.default;
357
- if (!slots) return null;
358
- if (this.isAutoWidth) {
359
- var autoLabelWidth = this.elForm.autoLabelWidth;
360
- var style = {};
361
- if (autoLabelWidth && autoLabelWidth !== 'auto') {
362
- var marginLeft = parseInt(autoLabelWidth, 10) - this.computedWidth;
363
- if (marginLeft) {
364
- style.marginLeft = marginLeft + 'px';
365
- }
366
- }
367
- return h(
368
- 'div',
369
- { 'class': 'el-form-item__label-wrap', style: style },
370
- [slots]
371
- );
372
- } else {
373
- return slots[0];
374
- }
375
- },
376
-
377
-
378
- methods: {
379
- getLabelWidth: function getLabelWidth() {
380
- if (this.$el && this.$el.firstElementChild) {
381
- var computedWidth = window.getComputedStyle(this.$el.firstElementChild).width;
382
- return Math.ceil(parseFloat(computedWidth));
383
- } else {
384
- return 0;
385
- }
386
- },
387
- updateLabelWidth: function updateLabelWidth() {
388
- var action = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'update';
389
-
390
- if (this.$slots.default && this.isAutoWidth && this.$el.firstElementChild) {
391
- if (action === 'update') {
392
- this.computedWidth = this.getLabelWidth();
393
- } else if (action === 'remove') {
394
- this.elForm.deregisterLabelWidth(this.computedWidth);
395
- }
396
- }
397
- }
398
- },
399
-
400
- watch: {
401
- computedWidth: function computedWidth(val, oldVal) {
402
- if (this.updateAll) {
403
- this.elForm.registerLabelWidth(val, oldVal);
404
- this.elFormItem.updateComputedLabelWidth(val);
405
- }
406
- }
407
- },
408
-
409
- data: function data() {
410
- return {
411
- computedWidth: 0
412
- };
413
- },
414
- mounted: function mounted() {
415
- this.updateLabelWidth('update');
416
- },
417
- updated: function updated() {
418
- this.updateLabelWidth('update');
419
- },
420
- beforeDestroy: function beforeDestroy() {
421
- this.updateLabelWidth('remove');
422
- }
346
+ props: {
347
+ isAutoWidth: Boolean,
348
+ updateAll: Boolean
349
+ },
350
+
351
+ inject: ['elForm', 'elFormItem'],
352
+
353
+ render: function render() {
354
+ var h = arguments[0];
355
+
356
+ var slots = this.$slots.default;
357
+ if (!slots) return null;
358
+ if (this.isAutoWidth) {
359
+ var autoLabelWidth = this.elForm.autoLabelWidth;
360
+ var style = {};
361
+ if (autoLabelWidth && autoLabelWidth !== 'auto') {
362
+ var marginLeft = parseInt(autoLabelWidth, 10) - this.computedWidth;
363
+ if (marginLeft) {
364
+ style.marginLeft = marginLeft + 'px';
365
+ }
366
+ }
367
+ return h(
368
+ 'div',
369
+ { 'class': 'el-form-item__label-wrap', style: style },
370
+ [slots]
371
+ );
372
+ } else {
373
+ return slots[0];
374
+ }
375
+ },
376
+
377
+
378
+ methods: {
379
+ getLabelWidth: function getLabelWidth() {
380
+ if (this.$el && this.$el.firstElementChild) {
381
+ var computedWidth = window.getComputedStyle(this.$el.firstElementChild).width;
382
+ return Math.ceil(parseFloat(computedWidth));
383
+ } else {
384
+ return 0;
385
+ }
386
+ },
387
+ updateLabelWidth: function updateLabelWidth() {
388
+ var action = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : 'update';
389
+
390
+ if (this.$slots.default && this.isAutoWidth && this.$el.firstElementChild) {
391
+ if (action === 'update') {
392
+ this.computedWidth = this.getLabelWidth();
393
+ } else if (action === 'remove') {
394
+ this.elForm.deregisterLabelWidth(this.computedWidth);
395
+ }
396
+ }
397
+ }
398
+ },
399
+
400
+ watch: {
401
+ computedWidth: function computedWidth(val, oldVal) {
402
+ if (this.updateAll) {
403
+ this.elForm.registerLabelWidth(val, oldVal);
404
+ this.elFormItem.updateComputedLabelWidth(val);
405
+ }
406
+ }
407
+ },
408
+
409
+ data: function data() {
410
+ return {
411
+ computedWidth: 0
412
+ };
413
+ },
414
+ mounted: function mounted() {
415
+ this.updateLabelWidth('update');
416
+ },
417
+ updated: function updated() {
418
+ this.updateLabelWidth('update');
419
+ },
420
+ beforeDestroy: function beforeDestroy() {
421
+ this.updateLabelWidth('remove');
422
+ }
423
423
  });
424
424
  // CONCATENATED MODULE: ./packages/form/src/label-wrap.vue?vue&type=script&lang=js
425
425
  /* harmony default export */ var src_label_wrapvue_type_script_lang_js = (label_wrapvue_type_script_lang_js);
@@ -494,293 +494,293 @@ var component = Object(componentNormalizer["a" /* default */])(
494
494
 
495
495
 
496
496
  /* harmony default export */ var form_itemvue_type_script_lang_js = ({
497
- name: 'ElFormItem',
498
-
499
- componentName: 'ElFormItem',
500
-
501
- mixins: [emitter_default.a],
502
-
503
- provide: function provide() {
504
- return {
505
- elFormItem: this
506
- };
507
- },
508
-
509
-
510
- inject: ['elForm'],
511
-
512
- props: {
513
- label: String,
514
- labelWidth: String,
515
- prop: String,
516
- required: {
517
- type: Boolean,
518
- default: undefined
519
- },
520
- rules: [Object, Array],
521
- error: String,
522
- validateStatus: String,
523
- for: String,
524
- inlineMessage: {
525
- type: [String, Boolean],
526
- default: ''
527
- },
528
- showMessage: {
529
- type: Boolean,
530
- default: true
531
- },
532
- size: String
533
- },
534
- components: {
535
- // use this component to calculate auto width
536
- LabelWrap: label_wrap
537
- },
538
- watch: {
539
- error: {
540
- immediate: true,
541
- handler: function handler(value) {
542
- this.validateMessage = value;
543
- this.validateState = value ? 'error' : '';
544
- }
545
- },
546
- validateStatus: function validateStatus(value) {
547
- this.validateState = value;
548
- },
549
- rules: function rules(value) {
550
- if ((!value || value.length === 0) && this.required === undefined) {
551
- this.clearValidate();
552
- }
553
- }
554
- },
555
- computed: {
556
- labelFor: function labelFor() {
557
- return this.for || this.prop;
558
- },
559
- labelStyle: function labelStyle() {
560
- var ret = {};
561
- if (this.form.labelPosition === 'top') return ret;
562
- var labelWidth = this.labelWidth || this.form.labelWidth;
563
- if (labelWidth) {
564
- ret.width = labelWidth;
565
- }
566
- return ret;
567
- },
568
- contentStyle: function contentStyle() {
569
- var ret = {};
570
- var label = this.label;
571
- if (this.form.labelPosition === 'top' || this.form.inline) return ret;
572
- if (!label && !this.labelWidth && this.isNested) return ret;
573
- var labelWidth = this.labelWidth || this.form.labelWidth;
574
- if (labelWidth === 'auto') {
575
- if (this.labelWidth === 'auto') {
576
- ret.marginLeft = this.computedLabelWidth;
577
- } else if (this.form.labelWidth === 'auto') {
578
- ret.marginLeft = this.elForm.autoLabelWidth;
579
- }
580
- } else {
581
- ret.marginLeft = labelWidth;
582
- }
583
- return ret;
584
- },
585
- form: function form() {
586
- var parent = this.$parent;
587
- var parentName = parent.$options.componentName;
588
- while (parentName !== 'ElForm') {
589
- if (parentName === 'ElFormItem') {
590
- this.isNested = true;
591
- }
592
- parent = parent.$parent;
593
- parentName = parent.$options.componentName;
594
- }
595
- return parent;
596
- },
597
- fieldValue: function fieldValue() {
598
- var model = this.form.model;
599
- if (!model || !this.prop) {
600
- return;
601
- }
602
-
603
- var path = this.prop;
604
- if (path.indexOf(':') !== -1) {
605
- path = path.replace(/:/, '.');
606
- }
607
-
608
- return Object(util_["getPropByPath"])(model, path, true).v;
609
- },
610
- isRequired: function isRequired() {
611
- var rules = this.getRules();
612
- var isRequired = false;
613
-
614
- if (rules && rules.length) {
615
- rules.every(function (rule) {
616
- if (rule.required) {
617
- isRequired = true;
618
- return false;
619
- }
620
- return true;
621
- });
622
- }
623
- return isRequired;
624
- },
625
- _formSize: function _formSize() {
626
- return this.elForm.size;
627
- },
628
- elFormItemSize: function elFormItemSize() {
629
- return this.size || this._formSize;
630
- },
631
- sizeClass: function sizeClass() {
632
- return this.elFormItemSize || (this.$ELEMENT || {}).size;
633
- }
634
- },
635
- data: function data() {
636
- return {
637
- validateState: '',
638
- validateMessage: '',
639
- validateDisabled: false,
640
- validator: {},
641
- isNested: false,
642
- computedLabelWidth: ''
643
- };
644
- },
645
-
646
- methods: {
647
- validate: function validate(trigger) {
648
- var _this = this;
649
-
650
- var callback = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : util_["noop"];
651
-
652
- this.validateDisabled = false;
653
- var rules = this.getFilteredRule(trigger);
654
- if ((!rules || rules.length === 0) && this.required === undefined) {
655
- callback();
656
- return true;
657
- }
658
-
659
- this.validateState = 'validating';
660
-
661
- var descriptor = {};
662
- if (rules && rules.length > 0) {
663
- rules.forEach(function (rule) {
664
- delete rule.trigger;
665
- });
666
- }
667
- descriptor[this.prop] = rules;
668
-
669
- var validator = new external_async_validator_default.a(descriptor);
670
- var model = {};
671
-
672
- model[this.prop] = this.fieldValue;
673
-
674
- validator.validate(model, { firstFields: true }, function (errors, invalidFields) {
675
- _this.validateState = !errors ? 'success' : 'error';
676
- _this.validateMessage = errors ? errors[0].message : '';
677
-
678
- callback(_this.validateMessage, invalidFields);
679
- _this.elForm && _this.elForm.$emit('validate', _this.prop, !errors, _this.validateMessage || null);
680
- });
681
- },
682
- clearValidate: function clearValidate() {
683
- this.validateState = '';
684
- this.validateMessage = '';
685
- this.validateDisabled = false;
686
- },
687
- resetField: function resetField() {
688
- var _this2 = this;
689
-
690
- this.validateState = '';
691
- this.validateMessage = '';
692
-
693
- var model = this.form.model;
694
- var value = this.fieldValue;
695
- var path = this.prop;
696
- if (path.indexOf(':') !== -1) {
697
- path = path.replace(/:/, '.');
698
- }
699
-
700
- var prop = Object(util_["getPropByPath"])(model, path, true);
701
-
702
- this.validateDisabled = true;
703
- if (Array.isArray(value)) {
704
- prop.o[prop.k] = [].concat(this.initialValue);
705
- } else {
706
- prop.o[prop.k] = this.initialValue;
707
- }
708
-
709
- // reset validateDisabled after onFieldChange triggered
710
- this.$nextTick(function () {
711
- _this2.validateDisabled = false;
712
- });
713
-
714
- this.broadcast('ElTimeSelect', 'fieldReset', this.initialValue);
715
- },
716
- getRules: function getRules() {
717
- var formRules = this.form.rules;
718
- var selfRules = this.rules;
719
- var requiredRule = this.required !== undefined ? { required: !!this.required } : [];
720
-
721
- var prop = Object(util_["getPropByPath"])(formRules, this.prop || '');
722
- formRules = formRules ? prop.o[this.prop || ''] || prop.v : [];
723
-
724
- return [].concat(selfRules || formRules || []).concat(requiredRule);
725
- },
726
- getFilteredRule: function getFilteredRule(trigger) {
727
- var rules = this.getRules();
728
-
729
- return rules.filter(function (rule) {
730
- if (!rule.trigger || trigger === '') return true;
731
- if (Array.isArray(rule.trigger)) {
732
- return rule.trigger.indexOf(trigger) > -1;
733
- } else {
734
- return rule.trigger === trigger;
735
- }
736
- }).map(function (rule) {
737
- return merge_default()({}, rule);
738
- });
739
- },
740
- onFieldBlur: function onFieldBlur() {
741
- this.validate('blur');
742
- },
743
- onFieldChange: function onFieldChange() {
744
- if (this.validateDisabled) {
745
- this.validateDisabled = false;
746
- return;
747
- }
748
-
749
- this.validate('change');
750
- },
751
- updateComputedLabelWidth: function updateComputedLabelWidth(width) {
752
- this.computedLabelWidth = width ? width + 'px' : '';
753
- },
754
- addValidateEvents: function addValidateEvents() {
755
- var rules = this.getRules();
756
-
757
- if (rules.length || this.required !== undefined) {
758
- this.$on('el.form.blur', this.onFieldBlur);
759
- this.$on('el.form.change', this.onFieldChange);
760
- }
761
- },
762
- removeValidateEvents: function removeValidateEvents() {
763
- this.$off();
764
- }
765
- },
766
- mounted: function mounted() {
767
- if (this.prop) {
768
- this.dispatch('ElForm', 'el.form.addField', [this]);
769
-
770
- var initialValue = this.fieldValue;
771
- if (Array.isArray(initialValue)) {
772
- initialValue = [].concat(initialValue);
773
- }
774
- Object.defineProperty(this, 'initialValue', {
775
- value: initialValue
776
- });
777
-
778
- this.addValidateEvents();
779
- }
780
- },
781
- beforeDestroy: function beforeDestroy() {
782
- this.dispatch('ElForm', 'el.form.removeField', [this]);
783
- }
497
+ name: 'ElFormItem',
498
+
499
+ componentName: 'ElFormItem',
500
+
501
+ mixins: [emitter_default.a],
502
+
503
+ provide: function provide() {
504
+ return {
505
+ elFormItem: this
506
+ };
507
+ },
508
+
509
+
510
+ inject: ['elForm'],
511
+
512
+ props: {
513
+ label: String,
514
+ labelWidth: String,
515
+ prop: String,
516
+ required: {
517
+ type: Boolean,
518
+ default: undefined
519
+ },
520
+ rules: [Object, Array],
521
+ error: String,
522
+ validateStatus: String,
523
+ for: String,
524
+ inlineMessage: {
525
+ type: [String, Boolean],
526
+ default: ''
527
+ },
528
+ showMessage: {
529
+ type: Boolean,
530
+ default: true
531
+ },
532
+ size: String
533
+ },
534
+ components: {
535
+ // use this component to calculate auto width
536
+ LabelWrap: label_wrap
537
+ },
538
+ watch: {
539
+ error: {
540
+ immediate: true,
541
+ handler: function handler(value) {
542
+ this.validateMessage = value;
543
+ this.validateState = value ? 'error' : '';
544
+ }
545
+ },
546
+ validateStatus: function validateStatus(value) {
547
+ this.validateState = value;
548
+ },
549
+ rules: function rules(value) {
550
+ if ((!value || value.length === 0) && this.required === undefined) {
551
+ this.clearValidate();
552
+ }
553
+ }
554
+ },
555
+ computed: {
556
+ labelFor: function labelFor() {
557
+ return this.for || this.prop;
558
+ },
559
+ labelStyle: function labelStyle() {
560
+ var ret = {};
561
+ if (this.form.labelPosition === 'top') return ret;
562
+ var labelWidth = this.labelWidth || this.form.labelWidth;
563
+ if (labelWidth) {
564
+ ret.width = labelWidth;
565
+ }
566
+ return ret;
567
+ },
568
+ contentStyle: function contentStyle() {
569
+ var ret = {};
570
+ var label = this.label;
571
+ if (this.form.labelPosition === 'top' || this.form.inline) return ret;
572
+ if (!label && !this.labelWidth && this.isNested) return ret;
573
+ var labelWidth = this.labelWidth || this.form.labelWidth;
574
+ if (labelWidth === 'auto') {
575
+ if (this.labelWidth === 'auto') {
576
+ ret.marginLeft = this.computedLabelWidth;
577
+ } else if (this.form.labelWidth === 'auto') {
578
+ ret.marginLeft = this.elForm.autoLabelWidth;
579
+ }
580
+ } else {
581
+ ret.marginLeft = labelWidth;
582
+ }
583
+ return ret;
584
+ },
585
+ form: function form() {
586
+ var parent = this.$parent;
587
+ var parentName = parent.$options.componentName;
588
+ while (parentName !== 'ElForm') {
589
+ if (parentName === 'ElFormItem') {
590
+ this.isNested = true;
591
+ }
592
+ parent = parent.$parent;
593
+ parentName = parent.$options.componentName;
594
+ }
595
+ return parent;
596
+ },
597
+ fieldValue: function fieldValue() {
598
+ var model = this.form.model;
599
+ if (!model || !this.prop) {
600
+ return;
601
+ }
602
+
603
+ var path = this.prop;
604
+ if (path.indexOf(':') !== -1) {
605
+ path = path.replace(/:/, '.');
606
+ }
607
+
608
+ return Object(util_["getPropByPath"])(model, path, true).v;
609
+ },
610
+ isRequired: function isRequired() {
611
+ var rules = this.getRules();
612
+ var isRequired = false;
613
+
614
+ if (rules && rules.length) {
615
+ rules.every(function (rule) {
616
+ if (rule.required) {
617
+ isRequired = true;
618
+ return false;
619
+ }
620
+ return true;
621
+ });
622
+ }
623
+ return isRequired;
624
+ },
625
+ _formSize: function _formSize() {
626
+ return this.elForm.size;
627
+ },
628
+ elFormItemSize: function elFormItemSize() {
629
+ return this.size || this._formSize;
630
+ },
631
+ sizeClass: function sizeClass() {
632
+ return this.elFormItemSize || (this.$ELEMENT || {}).size;
633
+ }
634
+ },
635
+ data: function data() {
636
+ return {
637
+ validateState: '',
638
+ validateMessage: '',
639
+ validateDisabled: false,
640
+ validator: {},
641
+ isNested: false,
642
+ computedLabelWidth: ''
643
+ };
644
+ },
645
+
646
+ methods: {
647
+ validate: function validate(trigger) {
648
+ var _this = this;
649
+
650
+ var callback = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : util_["noop"];
651
+
652
+ this.validateDisabled = false;
653
+ var rules = this.getFilteredRule(trigger);
654
+ if ((!rules || rules.length === 0) && this.required === undefined) {
655
+ callback();
656
+ return true;
657
+ }
658
+
659
+ this.validateState = 'validating';
660
+
661
+ var descriptor = {};
662
+ if (rules && rules.length > 0) {
663
+ rules.forEach(function (rule) {
664
+ delete rule.trigger;
665
+ });
666
+ }
667
+ descriptor[this.prop] = rules;
668
+
669
+ var validator = new external_async_validator_default.a(descriptor);
670
+ var model = {};
671
+
672
+ model[this.prop] = this.fieldValue;
673
+
674
+ validator.validate(model, { firstFields: true }, function (errors, invalidFields) {
675
+ _this.validateState = !errors ? 'success' : 'error';
676
+ _this.validateMessage = errors ? errors[0].message : '';
677
+
678
+ callback(_this.validateMessage, invalidFields);
679
+ _this.elForm && _this.elForm.$emit('validate', _this.prop, !errors, _this.validateMessage || null);
680
+ });
681
+ },
682
+ clearValidate: function clearValidate() {
683
+ this.validateState = '';
684
+ this.validateMessage = '';
685
+ this.validateDisabled = false;
686
+ },
687
+ resetField: function resetField() {
688
+ var _this2 = this;
689
+
690
+ this.validateState = '';
691
+ this.validateMessage = '';
692
+
693
+ var model = this.form.model;
694
+ var value = this.fieldValue;
695
+ var path = this.prop;
696
+ if (path.indexOf(':') !== -1) {
697
+ path = path.replace(/:/, '.');
698
+ }
699
+
700
+ var prop = Object(util_["getPropByPath"])(model, path, true);
701
+
702
+ this.validateDisabled = true;
703
+ if (Array.isArray(value)) {
704
+ prop.o[prop.k] = [].concat(this.initialValue);
705
+ } else {
706
+ prop.o[prop.k] = this.initialValue;
707
+ }
708
+
709
+ // reset validateDisabled after onFieldChange triggered
710
+ this.$nextTick(function () {
711
+ _this2.validateDisabled = false;
712
+ });
713
+
714
+ this.broadcast('ElTimeSelect', 'fieldReset', this.initialValue);
715
+ },
716
+ getRules: function getRules() {
717
+ var formRules = this.form.rules;
718
+ var selfRules = this.rules;
719
+ var requiredRule = this.required !== undefined ? { required: !!this.required } : [];
720
+
721
+ var prop = Object(util_["getPropByPath"])(formRules, this.prop || '');
722
+ formRules = formRules ? prop.o[this.prop || ''] || prop.v : [];
723
+
724
+ return [].concat(selfRules || formRules || []).concat(requiredRule);
725
+ },
726
+ getFilteredRule: function getFilteredRule(trigger) {
727
+ var rules = this.getRules();
728
+
729
+ return rules.filter(function (rule) {
730
+ if (!rule.trigger || trigger === '') return true;
731
+ if (Array.isArray(rule.trigger)) {
732
+ return rule.trigger.indexOf(trigger) > -1;
733
+ } else {
734
+ return rule.trigger === trigger;
735
+ }
736
+ }).map(function (rule) {
737
+ return merge_default()({}, rule);
738
+ });
739
+ },
740
+ onFieldBlur: function onFieldBlur() {
741
+ this.validate('blur');
742
+ },
743
+ onFieldChange: function onFieldChange() {
744
+ if (this.validateDisabled) {
745
+ this.validateDisabled = false;
746
+ return;
747
+ }
748
+
749
+ this.validate('change');
750
+ },
751
+ updateComputedLabelWidth: function updateComputedLabelWidth(width) {
752
+ this.computedLabelWidth = width ? width + 'px' : '';
753
+ },
754
+ addValidateEvents: function addValidateEvents() {
755
+ var rules = this.getRules();
756
+
757
+ if (rules.length || this.required !== undefined) {
758
+ this.$on('el.form.blur', this.onFieldBlur);
759
+ this.$on('el.form.change', this.onFieldChange);
760
+ }
761
+ },
762
+ removeValidateEvents: function removeValidateEvents() {
763
+ this.$off();
764
+ }
765
+ },
766
+ mounted: function mounted() {
767
+ if (this.prop) {
768
+ this.dispatch('ElForm', 'el.form.addField', [this]);
769
+
770
+ var initialValue = this.fieldValue;
771
+ if (Array.isArray(initialValue)) {
772
+ initialValue = [].concat(initialValue);
773
+ }
774
+ Object.defineProperty(this, 'initialValue', {
775
+ value: initialValue
776
+ });
777
+
778
+ this.addValidateEvents();
779
+ }
780
+ },
781
+ beforeDestroy: function beforeDestroy() {
782
+ this.dispatch('ElForm', 'el.form.removeField', [this]);
783
+ }
784
784
  });
785
785
  // CONCATENATED MODULE: ./packages/form/src/form-item.vue?vue&type=script&lang=js
786
786
  /* harmony default export */ var src_form_itemvue_type_script_lang_js = (form_itemvue_type_script_lang_js);
@@ -809,7 +809,7 @@ var form_item_component = Object(componentNormalizer["a" /* default */])(
809
809
 
810
810
  /* istanbul ignore next */
811
811
  form_item.install = function (Vue) {
812
- Vue.component(form_item.name, form_item);
812
+ Vue.component(form_item.name, form_item);
813
813
  };
814
814
 
815
815
  /* harmony default export */ var packages_form_item = __webpack_exports__["default"] = (form_item);