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
@@ -1,86 +1,86 @@
1
1
  <template>
2
- <el-input
3
- class="el-date-editor"
4
- :class="'el-date-editor--' + type"
5
- :readonly="!editable || readonly || type === 'dates' || type === 'week' || type === 'years' || type === 'months'"
6
- :disabled="pickerDisabled"
7
- :size="pickerSize"
8
- :name="name"
9
- v-bind="firstInputId"
10
- v-if="!ranged"
11
- v-clickoutside="handleClose"
12
- :placeholder="placeholder"
13
- @focus="handleFocus"
14
- @keydown.native="handleKeydown"
15
- :value="displayValue"
16
- @input="value => userInput = value"
17
- @change="handleChange"
18
- @mouseenter.native="handleMouseEnter"
19
- @mouseleave.native="showClose = false"
20
- :validateEvent="false"
21
- ref="reference">
22
- <i slot="prefix"
23
- class="el-input__icon"
24
- :class="triggerClass"
25
- @click="handleFocus">
26
- </i>
27
- <i slot="suffix"
28
- class="el-input__icon"
29
- @click="handleClickIcon"
30
- :class="[showClose ? '' + clearIcon : '']"
31
- v-if="haveTrigger">
32
- </i>
33
- </el-input>
34
- <div
35
- class="el-date-editor el-range-editor el-input__inner"
36
- :class="[
37
- 'el-date-editor--' + type,
38
- pickerSize ? `el-range-editor--${ pickerSize }` : '',
39
- pickerDisabled ? 'is-disabled' : '',
40
- pickerVisible ? 'is-active' : ''
41
- ]"
42
- @click="handleRangeClick"
43
- @mouseenter="handleMouseEnter"
44
- @mouseleave="showClose = false"
45
- @keydown="handleKeydown"
46
- ref="reference"
47
- v-clickoutside="handleClose"
48
- v-else>
49
- <i :class="['el-input__icon', 'el-range__icon', triggerClass]"></i>
50
- <input
51
- autocomplete="off"
52
- :placeholder="startPlaceholder"
53
- :value="displayValue && displayValue[0]"
54
- :disabled="pickerDisabled"
55
- v-bind="firstInputId"
56
- :readonly="!editable || readonly"
57
- :name="name && name[0]"
58
- @input="handleStartInput"
59
- @change="handleStartChange"
60
- @focus="handleFocus"
61
- class="el-range-input">
62
- <slot name="range-separator">
63
- <span class="el-range-separator">{{ rangeSeparator }}</span>
64
- </slot>
65
- <input
66
- autocomplete="off"
67
- :placeholder="endPlaceholder"
68
- :value="displayValue && displayValue[1]"
69
- :disabled="pickerDisabled"
70
- v-bind="secondInputId"
71
- :readonly="!editable || readonly"
72
- :name="name && name[1]"
73
- @input="handleEndInput"
74
- @change="handleEndChange"
75
- @focus="handleFocus"
76
- class="el-range-input">
77
- <i
78
- @click="handleClickIcon"
79
- v-if="haveTrigger"
80
- :class="[showClose ? '' + clearIcon : '']"
81
- class="el-input__icon el-range__close-icon">
82
- </i>
83
- </div>
2
+ <el-input
3
+ class="el-date-editor"
4
+ :class="'el-date-editor--' + type"
5
+ :readonly="!editable || readonly || type === 'dates' || type === 'week' || type === 'years' || type === 'months'"
6
+ :disabled="pickerDisabled"
7
+ :size="pickerSize"
8
+ :name="name"
9
+ v-bind="firstInputId"
10
+ v-if="!ranged"
11
+ v-clickoutside="handleClose"
12
+ :placeholder="placeholder"
13
+ @focus="handleFocus"
14
+ @keydown.native="handleKeydown"
15
+ :value="displayValue"
16
+ @input="value => userInput = value"
17
+ @change="handleChange"
18
+ @mouseenter.native="handleMouseEnter"
19
+ @mouseleave.native="showClose = false"
20
+ :validateEvent="false"
21
+ ref="reference">
22
+ <i slot="prefix"
23
+ class="el-input__icon"
24
+ :class="triggerClass"
25
+ @click="handleFocus">
26
+ </i>
27
+ <i slot="suffix"
28
+ class="el-input__icon"
29
+ @click="handleClickIcon"
30
+ :class="[showClose ? '' + clearIcon : '']"
31
+ v-if="haveTrigger">
32
+ </i>
33
+ </el-input>
34
+ <div
35
+ class="el-date-editor el-range-editor el-input__inner"
36
+ :class="[
37
+ 'el-date-editor--' + type,
38
+ pickerSize ? `el-range-editor--${ pickerSize }` : '',
39
+ pickerDisabled ? 'is-disabled' : '',
40
+ pickerVisible ? 'is-active' : ''
41
+ ]"
42
+ @click="handleRangeClick"
43
+ @mouseenter="handleMouseEnter"
44
+ @mouseleave="showClose = false"
45
+ @keydown="handleKeydown"
46
+ ref="reference"
47
+ v-clickoutside="handleClose"
48
+ v-else>
49
+ <i :class="['el-input__icon', 'el-range__icon', triggerClass]"></i>
50
+ <input
51
+ autocomplete="off"
52
+ :placeholder="startPlaceholder"
53
+ :value="displayValue && displayValue[0]"
54
+ :disabled="pickerDisabled"
55
+ v-bind="firstInputId"
56
+ :readonly="!editable || readonly"
57
+ :name="name && name[0]"
58
+ @input="handleStartInput"
59
+ @change="handleStartChange"
60
+ @focus="handleFocus"
61
+ class="el-range-input">
62
+ <slot name="range-separator">
63
+ <span class="el-range-separator">{{ rangeSeparator }}</span>
64
+ </slot>
65
+ <input
66
+ autocomplete="off"
67
+ :placeholder="endPlaceholder"
68
+ :value="displayValue && displayValue[1]"
69
+ :disabled="pickerDisabled"
70
+ v-bind="secondInputId"
71
+ :readonly="!editable || readonly"
72
+ :name="name && name[1]"
73
+ @input="handleEndInput"
74
+ @change="handleEndChange"
75
+ @focus="handleFocus"
76
+ class="el-range-input">
77
+ <i
78
+ @click="handleClickIcon"
79
+ v-if="haveTrigger"
80
+ :class="[showClose ? '' + clearIcon : '']"
81
+ class="el-input__icon el-range__close-icon">
82
+ </i>
83
+ </div>
84
84
  </template>
85
85
 
86
86
  <script>
@@ -93,216 +93,216 @@ import ElInput from 'element-ui/packages/input';
93
93
  import merge from 'element-ui/src/utils/merge';
94
94
 
95
95
  const NewPopper = {
96
- props: {
97
- appendToBody: Popper.props.appendToBody,
98
- offset: Popper.props.offset,
99
- boundariesPadding: Popper.props.boundariesPadding,
100
- arrowOffset: Popper.props.arrowOffset,
101
- transformOrigin: Popper.props.transformOrigin
102
- },
103
- methods: Popper.methods,
104
- data() {
105
- return merge({ visibleArrow: true }, Popper.data);
106
- },
107
- beforeDestroy: Popper.beforeDestroy
96
+ props: {
97
+ appendToBody: Popper.props.appendToBody,
98
+ offset: Popper.props.offset,
99
+ boundariesPadding: Popper.props.boundariesPadding,
100
+ arrowOffset: Popper.props.arrowOffset,
101
+ transformOrigin: Popper.props.transformOrigin
102
+ },
103
+ methods: Popper.methods,
104
+ data() {
105
+ return merge({ visibleArrow: true }, Popper.data);
106
+ },
107
+ beforeDestroy: Popper.beforeDestroy
108
108
  };
109
109
 
110
110
  const DEFAULT_FORMATS = {
111
- date: 'yyyy-MM-dd',
112
- month: 'yyyy-MM',
113
- months: 'yyyy-MM',
114
- datetime: 'yyyy-MM-dd HH:mm:ss',
115
- time: 'HH:mm:ss',
116
- week: 'yyyywWW',
117
- timerange: 'HH:mm:ss',
118
- daterange: 'yyyy-MM-dd',
119
- monthrange: 'yyyy-MM',
120
- datetimerange: 'yyyy-MM-dd HH:mm:ss',
121
- year: 'yyyy',
122
- years: 'yyyy'
111
+ date: 'yyyy-MM-dd',
112
+ month: 'yyyy-MM',
113
+ months: 'yyyy-MM',
114
+ datetime: 'yyyy-MM-dd HH:mm:ss',
115
+ time: 'HH:mm:ss',
116
+ week: 'yyyywWW',
117
+ timerange: 'HH:mm:ss',
118
+ daterange: 'yyyy-MM-dd',
119
+ monthrange: 'yyyy-MM',
120
+ datetimerange: 'yyyy-MM-dd HH:mm:ss',
121
+ year: 'yyyy',
122
+ years: 'yyyy'
123
123
  };
124
124
  const HAVE_TRIGGER_TYPES = [
125
- 'date',
126
- 'datetime',
127
- 'time',
128
- 'time-select',
129
- 'week',
130
- 'month',
131
- 'year',
132
- 'daterange',
133
- 'monthrange',
134
- 'timerange',
135
- 'datetimerange',
136
- 'dates',
137
- 'months',
138
- 'years'
125
+ 'date',
126
+ 'datetime',
127
+ 'time',
128
+ 'time-select',
129
+ 'week',
130
+ 'month',
131
+ 'year',
132
+ 'daterange',
133
+ 'monthrange',
134
+ 'timerange',
135
+ 'datetimerange',
136
+ 'dates',
137
+ 'months',
138
+ 'years'
139
139
  ];
140
140
  const DATE_FORMATTER = function(value, format) {
141
- if (format === 'timestamp') return value.getTime();
142
- return formatDate(value, format);
141
+ if (format === 'timestamp') return value.getTime();
142
+ return formatDate(value, format);
143
143
  };
144
144
  const DATE_PARSER = function(text, format) {
145
- if (format === 'timestamp') return new Date(Number(text));
146
- return parseDate(text, format);
145
+ if (format === 'timestamp') return new Date(Number(text));
146
+ return parseDate(text, format);
147
147
  };
148
148
  const RANGE_FORMATTER = function(value, format) {
149
- if (Array.isArray(value) && value.length === 2) {
150
- const start = value[0];
151
- const end = value[1];
152
-
153
- if (start && end) {
154
- return [DATE_FORMATTER(start, format), DATE_FORMATTER(end, format)];
155
- }
156
- }
157
- return '';
149
+ if (Array.isArray(value) && value.length === 2) {
150
+ const start = value[0];
151
+ const end = value[1];
152
+
153
+ if (start && end) {
154
+ return [DATE_FORMATTER(start, format), DATE_FORMATTER(end, format)];
155
+ }
156
+ }
157
+ return '';
158
158
  };
159
159
  const RANGE_PARSER = function(array, format, separator) {
160
- if (!Array.isArray(array)) {
161
- array = array.split(separator);
162
- }
163
- if (array.length === 2) {
164
- const range1 = array[0];
165
- const range2 = array[1];
166
-
167
- return [DATE_PARSER(range1, format), DATE_PARSER(range2, format)];
168
- }
169
- return [];
160
+ if (!Array.isArray(array)) {
161
+ array = array.split(separator);
162
+ }
163
+ if (array.length === 2) {
164
+ const range1 = array[0];
165
+ const range2 = array[1];
166
+
167
+ return [DATE_PARSER(range1, format), DATE_PARSER(range2, format)];
168
+ }
169
+ return [];
170
170
  };
171
171
  const TYPE_VALUE_RESOLVER_MAP = {
172
- default: {
173
- formatter(value) {
174
- if (!value) return '';
175
- return '' + value;
176
- },
177
- parser(text) {
178
- if (text === undefined || text === '') return null;
179
- return text;
180
- }
181
- },
182
- week: {
183
- formatter(value, format) {
184
- let week = getWeekNumber(value);
185
- let month = value.getMonth();
186
- const trueDate = new Date(value);
187
- if (week === 1 && month === 11) {
188
- trueDate.setHours(0, 0, 0, 0);
189
- trueDate.setDate(trueDate.getDate() + 3 - (trueDate.getDay() + 6) % 7);
190
- }
191
- let date = formatDate(trueDate, format);
192
-
193
- date = /WW/.test(date)
194
- ? date.replace(/WW/, week < 10 ? '0' + week : week)
195
- : date.replace(/W/, week);
196
- return date;
197
- },
198
- parser(text, format) {
199
- // parse as if a normal date
200
- return TYPE_VALUE_RESOLVER_MAP.date.parser(text, format);
201
- }
202
- },
203
- date: {
204
- formatter: DATE_FORMATTER,
205
- parser: DATE_PARSER
206
- },
207
- datetime: {
208
- formatter: DATE_FORMATTER,
209
- parser: DATE_PARSER
210
- },
211
- daterange: {
212
- formatter: RANGE_FORMATTER,
213
- parser: RANGE_PARSER
214
- },
215
- monthrange: {
216
- formatter: RANGE_FORMATTER,
217
- parser: RANGE_PARSER
218
- },
219
- datetimerange: {
220
- formatter: RANGE_FORMATTER,
221
- parser: RANGE_PARSER
222
- },
223
- timerange: {
224
- formatter: RANGE_FORMATTER,
225
- parser: RANGE_PARSER
226
- },
227
- time: {
228
- formatter: DATE_FORMATTER,
229
- parser: DATE_PARSER
230
- },
231
- month: {
232
- formatter: DATE_FORMATTER,
233
- parser: DATE_PARSER
234
- },
235
- year: {
236
- formatter: DATE_FORMATTER,
237
- parser: DATE_PARSER
238
- },
239
- number: {
240
- formatter(value) {
241
- if (!value) return '';
242
- return '' + value;
243
- },
244
- parser(text) {
245
- let result = Number(text);
246
-
247
- if (!isNaN(text)) {
248
- return result;
249
- } else {
250
- return null;
251
- }
252
- }
253
- },
254
- dates: {
255
- formatter(value, format) {
256
- return value.map(date => DATE_FORMATTER(date, format));
257
- },
258
- parser(value, format) {
259
- return (typeof value === 'string' ? value.split(', ') : value)
260
- .map(date => date instanceof Date ? date : DATE_PARSER(date, format));
261
- }
262
- },
263
- months: {
264
- formatter(value, format) {
265
- return value.map(date => DATE_FORMATTER(date, format));
266
- },
267
- parser(value, format) {
268
- return (typeof value === 'string' ? value.split(', ') : value)
269
- .map(date => date instanceof Date ? date : DATE_PARSER(date, format));
270
- }
271
- },
272
- years: {
273
- formatter(value, format) {
274
- return value.map(date => DATE_FORMATTER(date, format));
275
- },
276
- parser(value, format) {
277
- return (typeof value === 'string' ? value.split(', ') : value)
278
- .map(date => date instanceof Date ? date : DATE_PARSER(date, format));
279
- }
280
- }
172
+ default: {
173
+ formatter(value) {
174
+ if (!value) return '';
175
+ return '' + value;
176
+ },
177
+ parser(text) {
178
+ if (text === undefined || text === '') return null;
179
+ return text;
180
+ }
181
+ },
182
+ week: {
183
+ formatter(value, format) {
184
+ let week = getWeekNumber(value);
185
+ let month = value.getMonth();
186
+ const trueDate = new Date(value);
187
+ if (week === 1 && month === 11) {
188
+ trueDate.setHours(0, 0, 0, 0);
189
+ trueDate.setDate(trueDate.getDate() + 3 - (trueDate.getDay() + 6) % 7);
190
+ }
191
+ let date = formatDate(trueDate, format);
192
+
193
+ date = /WW/.test(date)
194
+ ? date.replace(/WW/, week < 10 ? '0' + week : week)
195
+ : date.replace(/W/, week);
196
+ return date;
197
+ },
198
+ parser(text, format) {
199
+ // parse as if a normal date
200
+ return TYPE_VALUE_RESOLVER_MAP.date.parser(text, format);
201
+ }
202
+ },
203
+ date: {
204
+ formatter: DATE_FORMATTER,
205
+ parser: DATE_PARSER
206
+ },
207
+ datetime: {
208
+ formatter: DATE_FORMATTER,
209
+ parser: DATE_PARSER
210
+ },
211
+ daterange: {
212
+ formatter: RANGE_FORMATTER,
213
+ parser: RANGE_PARSER
214
+ },
215
+ monthrange: {
216
+ formatter: RANGE_FORMATTER,
217
+ parser: RANGE_PARSER
218
+ },
219
+ datetimerange: {
220
+ formatter: RANGE_FORMATTER,
221
+ parser: RANGE_PARSER
222
+ },
223
+ timerange: {
224
+ formatter: RANGE_FORMATTER,
225
+ parser: RANGE_PARSER
226
+ },
227
+ time: {
228
+ formatter: DATE_FORMATTER,
229
+ parser: DATE_PARSER
230
+ },
231
+ month: {
232
+ formatter: DATE_FORMATTER,
233
+ parser: DATE_PARSER
234
+ },
235
+ year: {
236
+ formatter: DATE_FORMATTER,
237
+ parser: DATE_PARSER
238
+ },
239
+ number: {
240
+ formatter(value) {
241
+ if (!value) return '';
242
+ return '' + value;
243
+ },
244
+ parser(text) {
245
+ let result = Number(text);
246
+
247
+ if (!isNaN(text)) {
248
+ return result;
249
+ } else {
250
+ return null;
251
+ }
252
+ }
253
+ },
254
+ dates: {
255
+ formatter(value, format) {
256
+ return value.map(date => DATE_FORMATTER(date, format));
257
+ },
258
+ parser(value, format) {
259
+ return (typeof value === 'string' ? value.split(', ') : value)
260
+ .map(date => date instanceof Date ? date : DATE_PARSER(date, format));
261
+ }
262
+ },
263
+ months: {
264
+ formatter(value, format) {
265
+ return value.map(date => DATE_FORMATTER(date, format));
266
+ },
267
+ parser(value, format) {
268
+ return (typeof value === 'string' ? value.split(', ') : value)
269
+ .map(date => date instanceof Date ? date : DATE_PARSER(date, format));
270
+ }
271
+ },
272
+ years: {
273
+ formatter(value, format) {
274
+ return value.map(date => DATE_FORMATTER(date, format));
275
+ },
276
+ parser(value, format) {
277
+ return (typeof value === 'string' ? value.split(', ') : value)
278
+ .map(date => date instanceof Date ? date : DATE_PARSER(date, format));
279
+ }
280
+ }
281
281
  };
282
282
  const PLACEMENT_MAP = {
283
- left: 'bottom-start',
284
- center: 'bottom',
285
- right: 'bottom-end'
283
+ left: 'bottom-start',
284
+ center: 'bottom',
285
+ right: 'bottom-end'
286
286
  };
287
287
 
288
288
  const parseAsFormatAndType = (value, customFormat, type, rangeSeparator = '-') => {
289
- if (!value) return null;
290
- const parser = (
291
- TYPE_VALUE_RESOLVER_MAP[type] ||
292
- TYPE_VALUE_RESOLVER_MAP['default']
293
- ).parser;
294
- const format = customFormat || DEFAULT_FORMATS[type];
295
- return parser(value, format, rangeSeparator);
289
+ if (!value) return null;
290
+ const parser = (
291
+ TYPE_VALUE_RESOLVER_MAP[type] ||
292
+ TYPE_VALUE_RESOLVER_MAP['default']
293
+ ).parser;
294
+ const format = customFormat || DEFAULT_FORMATS[type];
295
+ return parser(value, format, rangeSeparator);
296
296
  };
297
297
 
298
298
  const formatAsFormatAndType = (value, customFormat, type) => {
299
- if (!value) return null;
300
- const formatter = (
301
- TYPE_VALUE_RESOLVER_MAP[type] ||
302
- TYPE_VALUE_RESOLVER_MAP['default']
303
- ).formatter;
304
- const format = customFormat || DEFAULT_FORMATS[type];
305
- return formatter(value, format);
299
+ if (!value) return null;
300
+ const formatter = (
301
+ TYPE_VALUE_RESOLVER_MAP[type] ||
302
+ TYPE_VALUE_RESOLVER_MAP['default']
303
+ ).formatter;
304
+ const format = customFormat || DEFAULT_FORMATS[type];
305
+ return formatter(value, format);
306
306
  };
307
307
 
308
308
  /*
@@ -312,645 +312,645 @@ const formatAsFormatAndType = (value, customFormat, type) => {
312
312
  * 3. array of 1 or 2
313
313
  */
314
314
  const valueEquals = function(a, b) {
315
- // considers Date object and string
316
- const dateEquals = function(a, b) {
317
- const aIsDate = a instanceof Date;
318
- const bIsDate = b instanceof Date;
319
- if (aIsDate && bIsDate) {
320
- return a.getTime() === b.getTime();
321
- }
322
- if (!aIsDate && !bIsDate) {
323
- return a === b;
324
- }
325
- return false;
326
- };
327
-
328
- const aIsArray = a instanceof Array;
329
- const bIsArray = b instanceof Array;
330
- if (aIsArray && bIsArray) {
331
- if (a.length !== b.length) {
332
- return false;
333
- }
334
- return a.every((item, index) => dateEquals(item, b[index]));
335
- }
336
- if (!aIsArray && !bIsArray) {
337
- return dateEquals(a, b);
338
- }
339
- return false;
315
+ // considers Date object and string
316
+ const dateEquals = function(a, b) {
317
+ const aIsDate = a instanceof Date;
318
+ const bIsDate = b instanceof Date;
319
+ if (aIsDate && bIsDate) {
320
+ return a.getTime() === b.getTime();
321
+ }
322
+ if (!aIsDate && !bIsDate) {
323
+ return a === b;
324
+ }
325
+ return false;
326
+ };
327
+
328
+ const aIsArray = a instanceof Array;
329
+ const bIsArray = b instanceof Array;
330
+ if (aIsArray && bIsArray) {
331
+ if (a.length !== b.length) {
332
+ return false;
333
+ }
334
+ return a.every((item, index) => dateEquals(item, b[index]));
335
+ }
336
+ if (!aIsArray && !bIsArray) {
337
+ return dateEquals(a, b);
338
+ }
339
+ return false;
340
340
  };
341
341
 
342
342
  const isString = function(val) {
343
- return typeof val === 'string' || val instanceof String;
343
+ return typeof val === 'string' || val instanceof String;
344
344
  };
345
345
 
346
346
  const validator = function(val) {
347
- // either: String, Array of String, null / undefined
348
- return (
349
- val === null ||
350
- val === undefined ||
351
- isString(val) ||
352
- (Array.isArray(val) && val.length === 2 && val.every(isString))
353
- );
347
+ // either: String, Array of String, null / undefined
348
+ return (
349
+ val === null ||
350
+ val === undefined ||
351
+ isString(val) ||
352
+ (Array.isArray(val) && val.length === 2 && val.every(isString))
353
+ );
354
354
  };
355
355
 
356
356
  export default {
357
- mixins: [Emitter, NewPopper],
358
-
359
- inject: {
360
- elForm: {
361
- default: ''
362
- },
363
- elFormItem: {
364
- default: ''
365
- }
366
- },
367
-
368
- props: {
369
- size: String,
370
- format: String,
371
- valueFormat: String,
372
- readonly: Boolean,
373
- placeholder: String,
374
- startPlaceholder: String,
375
- endPlaceholder: String,
376
- prefixIcon: String,
377
- clearIcon: {
378
- type: String,
379
- default: 'el-icon-circle-close'
380
- },
381
- name: {
382
- default: '',
383
- validator
384
- },
385
- disabled: Boolean,
386
- clearable: {
387
- type: Boolean,
388
- default: true
389
- },
390
- id: {
391
- default: '',
392
- validator
393
- },
394
- popperClass: String,
395
- editable: {
396
- type: Boolean,
397
- default: true
398
- },
399
- align: {
400
- type: String,
401
- default: 'left'
402
- },
403
- value: {},
404
- defaultValue: {},
405
- defaultTime: {},
406
- rangeSeparator: {
407
- default: '-'
408
- },
409
- pickerOptions: {},
410
- unlinkPanels: Boolean,
411
- validateEvent: {
412
- type: Boolean,
413
- default: true
414
- }
415
- },
416
-
417
- components: { ElInput },
418
-
419
- directives: { Clickoutside },
420
-
421
- data() {
422
- return {
423
- pickerVisible: false,
424
- showClose: false,
425
- userInput: null,
426
- valueOnOpen: null, // value when picker opens, used to determine whether to emit change
427
- unwatchPickerOptions: null
428
- };
429
- },
430
-
431
- watch: {
432
- pickerVisible(val) {
433
- if (this.readonly || this.pickerDisabled) return;
434
- if (val) {
435
- this.showPicker();
436
- this.valueOnOpen = Array.isArray(this.value) ? [...this.value] : this.value;
437
- } else {
438
- this.hidePicker();
439
- this.emitChange(this.value);
440
- this.userInput = null;
441
- if (this.validateEvent) {
442
- this.dispatch('ElFormItem', 'el.form.blur');
443
- }
444
- this.$emit('blur', this);
445
- this.blur();
446
- }
447
- },
448
- parsedValue: {
449
- immediate: true,
450
- handler(val) {
451
- if (this.picker) {
452
- this.picker.value = val;
453
- }
454
- }
455
- },
456
- defaultValue(val) {
457
- // NOTE: should eventually move to jsx style picker + panel ?
458
- if (this.picker) {
459
- this.picker.defaultValue = val;
460
- }
461
- },
462
- value(val, oldVal) {
463
- if (!valueEquals(val, oldVal) && !this.pickerVisible && this.validateEvent) {
464
- this.dispatch('ElFormItem', 'el.form.change', val);
465
- }
466
- }
467
- },
468
-
469
- computed: {
470
- ranged() {
471
- return this.type.indexOf('range') > -1;
472
- },
473
-
474
- reference() {
475
- const reference = this.$refs.reference;
476
- return reference.$el || reference;
477
- },
478
-
479
- refInput() {
480
- if (this.reference) {
481
- return [].slice.call(this.reference.querySelectorAll('input'));
482
- }
483
- return [];
484
- },
485
-
486
- valueIsEmpty() {
487
- const val = this.value;
488
- if (Array.isArray(val)) {
489
- for (let i = 0, len = val.length; i < len; i++) {
490
- if (val[i]) {
491
- return false;
492
- }
493
- }
494
- } else {
495
- if (val) {
496
- return false;
497
- }
498
- }
499
- return true;
500
- },
501
-
502
- triggerClass() {
503
- return this.prefixIcon || (this.type.indexOf('time') !== -1 ? 'el-icon-time' : 'el-icon-date');
504
- },
505
-
506
- selectionMode() {
507
- if (this.type === 'week') {
508
- return 'week';
509
- } else if (this.type === 'month') {
510
- return 'month';
511
- } else if (this.type === 'year') {
512
- return 'year';
513
- } else if (this.type === 'dates') {
514
- return 'dates';
515
- } else if (this.type === 'months') {
516
- return 'months';
517
- } else if (this.type === 'years') {
518
- return 'years';
519
- }
520
-
521
- return 'day';
522
- },
523
-
524
- haveTrigger() {
525
- if (typeof this.showTrigger !== 'undefined') {
526
- return this.showTrigger;
527
- }
528
- return HAVE_TRIGGER_TYPES.indexOf(this.type) !== -1;
529
- },
530
-
531
- displayValue() {
532
- const formattedValue = formatAsFormatAndType(this.parsedValue, this.format, this.type, this.rangeSeparator);
533
- if (Array.isArray(this.userInput)) {
534
- return [
535
- this.userInput[0] || (formattedValue && formattedValue[0]) || '',
536
- this.userInput[1] || (formattedValue && formattedValue[1]) || ''
537
- ];
538
- } else if (this.userInput !== null) {
539
- return this.userInput;
540
- } else if (formattedValue) {
541
- return (this.type === 'dates' || this.type === 'years' || this.type === 'months')
542
- ? formattedValue.join(', ')
543
- : formattedValue;
544
- } else {
545
- return '';
546
- }
547
- },
548
-
549
- parsedValue() {
550
- if (!this.value) return this.value; // component value is not set
551
- if (this.type === 'time-select') return this.value; // time-select does not require parsing, this might change in next major version
552
-
553
- const valueIsDateObject = isDateObject(this.value) || (Array.isArray(this.value) && this.value.every(isDateObject));
554
- if (valueIsDateObject) {
555
- return this.value;
556
- }
557
-
558
- if (this.valueFormat) {
559
- return parseAsFormatAndType(this.value, this.valueFormat, this.type, this.rangeSeparator) || this.value;
560
- }
561
-
562
- // NOTE: deal with common but incorrect usage, should remove in next major version
563
- // user might provide string / timestamp without value-format, coerce them into date (or array of date)
564
- return Array.isArray(this.value) ? this.value.map(val => new Date(val)) : new Date(this.value);
565
- },
566
-
567
- _elFormItemSize() {
568
- return (this.elFormItem || {}).elFormItemSize;
569
- },
570
-
571
- pickerSize() {
572
- return this.size || this._elFormItemSize || (this.$ELEMENT || {}).size;
573
- },
574
-
575
- pickerDisabled() {
576
- return this.disabled || (this.elForm || {}).disabled;
577
- },
578
-
579
- firstInputId() {
580
- const obj = {};
581
- let id;
582
- if (this.ranged) {
583
- id = this.id && this.id[0];
584
- } else {
585
- id = this.id;
586
- }
587
- if (id) obj.id = id;
588
- return obj;
589
- },
590
-
591
- secondInputId() {
592
- const obj = {};
593
- let id;
594
- if (this.ranged) {
595
- id = this.id && this.id[1];
596
- }
597
- if (id) obj.id = id;
598
- return obj;
599
- }
600
- },
601
-
602
- created() {
603
- // vue-popper
604
- this.popperOptions = {
605
- boundariesPadding: 0,
606
- gpuAcceleration: false
607
- };
608
- this.placement = PLACEMENT_MAP[this.align] || PLACEMENT_MAP.left;
609
-
610
- this.$on('fieldReset', this.handleFieldReset);
611
- },
612
-
613
- methods: {
614
- focus() {
615
- if (!this.ranged) {
616
- this.$refs.reference.focus();
617
- } else {
618
- this.handleFocus();
619
- }
620
- },
621
-
622
- blur() {
623
- this.refInput.forEach(input => input.blur());
624
- },
625
-
626
- // {parse, formatTo} Value deals maps component value with internal Date
627
- parseValue(value) {
628
- const isParsed = isDateObject(value) || (Array.isArray(value) && value.every(isDateObject));
629
- if (this.valueFormat && !isParsed) {
630
- return parseAsFormatAndType(value, this.valueFormat, this.type, this.rangeSeparator) || value;
631
- } else {
632
- return value;
633
- }
634
- },
635
-
636
- formatToValue(date) {
637
- const isFormattable = isDateObject(date) || (Array.isArray(date) && date.every(isDateObject));
638
- if (this.valueFormat && isFormattable) {
639
- return formatAsFormatAndType(date, this.valueFormat, this.type, this.rangeSeparator);
640
- } else {
641
- return date;
642
- }
643
- },
644
-
645
- // {parse, formatTo} String deals with user input
646
- parseString(value) {
647
- const type = Array.isArray(value) ? this.type : this.type.replace('range', '');
648
- return parseAsFormatAndType(value, this.format, type);
649
- },
650
-
651
- formatToString(value) {
652
- const type = Array.isArray(value) ? this.type : this.type.replace('range', '');
653
- return formatAsFormatAndType(value, this.format, type);
654
- },
655
-
656
- handleMouseEnter() {
657
- if (this.readonly || this.pickerDisabled) return;
658
- if (!this.valueIsEmpty && this.clearable) {
659
- this.showClose = true;
660
- }
661
- },
662
-
663
- handleChange() {
664
- if (this.userInput) {
665
- const value = this.parseString(this.displayValue);
666
- if (value) {
667
- this.picker.value = value;
668
- if (this.isValidValue(value)) {
669
- this.emitInput(value);
670
- this.userInput = null;
671
- }
672
- }
673
- }
674
- if (this.userInput === '') {
675
- this.emitInput(null);
676
- this.emitChange(null);
677
- this.userInput = null;
678
- }
679
- },
680
-
681
- handleStartInput(event) {
682
- if (this.userInput) {
683
- this.userInput = [event.target.value, this.userInput[1]];
684
- } else {
685
- this.userInput = [event.target.value, null];
686
- }
687
- },
688
-
689
- handleEndInput(event) {
690
- if (this.userInput) {
691
- this.userInput = [this.userInput[0], event.target.value];
692
- } else {
693
- this.userInput = [null, event.target.value];
694
- }
695
- },
696
-
697
- handleStartChange(event) {
698
- const value = this.parseString(this.userInput && this.userInput[0]);
699
- if (value) {
700
- this.userInput = [this.formatToString(value), this.displayValue[1]];
701
- const newValue = [value, this.picker.value && this.picker.value[1]];
702
- this.picker.value = newValue;
703
- if (this.isValidValue(newValue)) {
704
- this.emitInput(newValue);
705
- this.userInput = null;
706
- }
707
- }
708
- },
709
-
710
- handleEndChange(event) {
711
- const value = this.parseString(this.userInput && this.userInput[1]);
712
- if (value) {
713
- this.userInput = [this.displayValue[0], this.formatToString(value)];
714
- const newValue = [this.picker.value && this.picker.value[0], value];
715
- this.picker.value = newValue;
716
- if (this.isValidValue(newValue)) {
717
- this.emitInput(newValue);
718
- this.userInput = null;
719
- }
720
- }
721
- },
722
-
723
- handleClickIcon(event) {
724
- if (this.readonly || this.pickerDisabled) return;
725
- if (this.showClose) {
726
- this.valueOnOpen = this.value;
727
- event.stopPropagation();
728
- this.emitInput(null);
729
- this.emitChange(null);
730
- this.showClose = false;
731
- if (this.picker && typeof this.picker.handleClear === 'function') {
732
- this.picker.handleClear();
733
- }
734
- } else {
735
- this.pickerVisible = !this.pickerVisible;
736
- }
737
- },
738
-
739
- handleClose() {
740
- if (!this.pickerVisible) return;
741
- this.pickerVisible = false;
742
-
743
- if (this.type === 'dates' || this.type === 'years' || this.type === 'months') {
744
- // restore to former value
745
- const oldValue = parseAsFormatAndType(this.valueOnOpen, this.valueFormat, this.type, this.rangeSeparator) || this.valueOnOpen;
746
- this.emitInput(oldValue);
747
- }
748
- },
749
-
750
- handleFieldReset(initialValue) {
751
- this.userInput = initialValue === '' ? null : initialValue;
752
- },
753
-
754
- handleFocus() {
755
- const type = this.type;
756
-
757
- if (HAVE_TRIGGER_TYPES.indexOf(type) !== -1 && !this.pickerVisible) {
758
- this.pickerVisible = true;
759
- }
760
- this.$emit('focus', this);
761
- },
762
-
763
- handleKeydown(event) {
764
- const keyCode = event.keyCode;
765
-
766
- // ESC
767
- if (keyCode === 27) {
768
- this.pickerVisible = false;
769
- event.stopPropagation();
770
- return;
771
- }
772
-
773
- // Tab
774
- if (keyCode === 9) {
775
- if (!this.ranged) {
776
- this.handleChange();
777
- this.pickerVisible = this.picker.visible = false;
778
- this.blur();
779
- event.stopPropagation();
780
- } else {
781
- // user may change focus between two input
782
- setTimeout(() => {
783
- if (this.refInput.indexOf(document.activeElement) === -1) {
784
- this.pickerVisible = false;
785
- this.blur();
786
- event.stopPropagation();
787
- }
788
- }, 0);
789
- }
790
- return;
791
- }
792
-
793
- // Enter
794
- if (keyCode === 13) {
795
- if (this.userInput === '' || this.isValidValue(this.parseString(this.displayValue))) {
796
- this.handleChange();
797
- this.pickerVisible = this.picker.visible = false;
798
- this.blur();
799
- }
800
- event.stopPropagation();
801
- return;
802
- }
803
-
804
- // if user is typing, do not let picker handle key input
805
- if (this.userInput) {
806
- event.stopPropagation();
807
- return;
808
- }
809
-
810
- // delegate other keys to panel
811
- if (this.picker && this.picker.handleKeydown) {
812
- this.picker.handleKeydown(event);
813
- }
814
- },
815
-
816
- handleRangeClick() {
817
- const type = this.type;
818
-
819
- if (HAVE_TRIGGER_TYPES.indexOf(type) !== -1 && !this.pickerVisible) {
820
- this.pickerVisible = true;
821
- }
822
- this.$emit('focus', this);
823
- },
824
-
825
- hidePicker() {
826
- if (this.picker) {
827
- this.picker.resetView && this.picker.resetView();
828
- this.pickerVisible = this.picker.visible = false;
829
- this.destroyPopper();
830
- }
831
- },
832
-
833
- showPicker() {
834
- if (this.$isServer) return;
835
- if (!this.picker) {
836
- this.mountPicker();
837
- }
838
- this.pickerVisible = this.picker.visible = true;
839
-
840
- this.updatePopper();
841
-
842
- this.picker.value = this.parsedValue;
843
- this.picker.resetView && this.picker.resetView();
844
-
845
- this.$nextTick(() => {
846
- this.picker.adjustSpinners && this.picker.adjustSpinners();
847
- });
848
- },
849
-
850
- mountPicker() {
851
- this.picker = new Vue(this.panel).$mount();
852
- this.picker.defaultValue = this.defaultValue;
853
- this.picker.defaultTime = this.defaultTime;
854
- this.picker.popperClass = this.popperClass;
855
- this.popperElm = this.picker.$el;
856
- this.picker.width = this.reference.getBoundingClientRect().width;
857
- this.picker.showTime = this.type === 'datetime' || this.type === 'datetimerange';
858
- this.picker.selectionMode = this.selectionMode;
859
- this.picker.unlinkPanels = this.unlinkPanels;
860
- this.picker.arrowControl = this.arrowControl || this.timeArrowControl || false;
861
- this.$watch('format', (format) => {
862
- this.picker.format = format;
863
- });
864
-
865
- const updateOptions = () => {
866
- const options = this.pickerOptions;
867
-
868
- if (options && options.selectableRange) {
869
- let ranges = options.selectableRange;
870
- const parser = TYPE_VALUE_RESOLVER_MAP.datetimerange.parser;
871
- const format = DEFAULT_FORMATS.timerange;
872
-
873
- ranges = Array.isArray(ranges) ? ranges : [ranges];
874
- this.picker.selectableRange = ranges.map(range => parser(range, format, this.rangeSeparator));
875
- }
876
-
877
- for (const option in options) {
878
- if (options.hasOwnProperty(option) &&
879
- // 忽略 time-picker 的该配置项
880
- option !== 'selectableRange') {
881
- this.picker[option] = options[option];
882
- }
883
- }
884
-
885
- // main format must prevail over undocumented pickerOptions.format
886
- if (this.format) {
887
- this.picker.format = this.format;
888
- }
889
- };
890
- updateOptions();
891
- this.unwatchPickerOptions = this.$watch('pickerOptions', () => updateOptions(), { deep: true });
892
- this.$el.appendChild(this.picker.$el);
893
- this.picker.resetView && this.picker.resetView();
894
-
895
- this.picker.$on('dodestroy', this.doDestroy);
896
- this.picker.$on('pick', (date = '', visible = false) => {
897
- this.userInput = null;
898
- this.pickerVisible = this.picker.visible = visible;
899
- this.emitInput(date);
900
- this.picker.resetView && this.picker.resetView();
901
- });
902
-
903
- this.picker.$on('select-range', (start, end, pos) => {
904
- if (this.refInput.length === 0) return;
905
- if (!pos || pos === 'min') {
906
- this.refInput[0].setSelectionRange(start, end);
907
- this.refInput[0].focus();
908
- } else if (pos === 'max') {
909
- this.refInput[1].setSelectionRange(start, end);
910
- this.refInput[1].focus();
911
- }
912
- });
913
- },
914
-
915
- unmountPicker() {
916
- if (this.picker) {
917
- this.picker.$destroy();
918
- this.picker.$off();
919
- if (typeof this.unwatchPickerOptions === 'function') {
920
- this.unwatchPickerOptions();
921
- }
922
- this.picker.$el.parentNode.removeChild(this.picker.$el);
923
- }
924
- },
925
-
926
- emitChange(val) {
927
- // determine user real change only
928
- if (!valueEquals(val, this.valueOnOpen)) {
929
- this.$emit('change', val);
930
- this.valueOnOpen = val;
931
- if (this.validateEvent) {
932
- this.dispatch('ElFormItem', 'el.form.change', val);
933
- }
934
- }
935
- },
936
-
937
- emitInput(val) {
938
- const formatted = this.formatToValue(val);
939
- if (!valueEquals(this.value, formatted)) {
940
- this.$emit('input', formatted);
941
- }
942
- },
943
-
944
- isValidValue(value) {
945
- if (!this.picker) {
946
- this.mountPicker();
947
- }
948
- if (this.picker.isValidValue) {
949
- return value && this.picker.isValidValue(value);
950
- } else {
951
- return true;
952
- }
953
- }
954
- }
357
+ mixins: [Emitter, NewPopper],
358
+
359
+ inject: {
360
+ elForm: {
361
+ default: ''
362
+ },
363
+ elFormItem: {
364
+ default: ''
365
+ }
366
+ },
367
+
368
+ props: {
369
+ size: String,
370
+ format: String,
371
+ valueFormat: String,
372
+ readonly: Boolean,
373
+ placeholder: String,
374
+ startPlaceholder: String,
375
+ endPlaceholder: String,
376
+ prefixIcon: String,
377
+ clearIcon: {
378
+ type: String,
379
+ default: 'el-icon-circle-close'
380
+ },
381
+ name: {
382
+ default: '',
383
+ validator
384
+ },
385
+ disabled: Boolean,
386
+ clearable: {
387
+ type: Boolean,
388
+ default: true
389
+ },
390
+ id: {
391
+ default: '',
392
+ validator
393
+ },
394
+ popperClass: String,
395
+ editable: {
396
+ type: Boolean,
397
+ default: true
398
+ },
399
+ align: {
400
+ type: String,
401
+ default: 'left'
402
+ },
403
+ value: {},
404
+ defaultValue: {},
405
+ defaultTime: {},
406
+ rangeSeparator: {
407
+ default: '-'
408
+ },
409
+ pickerOptions: {},
410
+ unlinkPanels: Boolean,
411
+ validateEvent: {
412
+ type: Boolean,
413
+ default: true
414
+ }
415
+ },
416
+
417
+ components: { ElInput },
418
+
419
+ directives: { Clickoutside },
420
+
421
+ data() {
422
+ return {
423
+ pickerVisible: false,
424
+ showClose: false,
425
+ userInput: null,
426
+ valueOnOpen: null, // value when picker opens, used to determine whether to emit change
427
+ unwatchPickerOptions: null
428
+ };
429
+ },
430
+
431
+ watch: {
432
+ pickerVisible(val) {
433
+ if (this.readonly || this.pickerDisabled) return;
434
+ if (val) {
435
+ this.showPicker();
436
+ this.valueOnOpen = Array.isArray(this.value) ? [...this.value] : this.value;
437
+ } else {
438
+ this.hidePicker();
439
+ this.emitChange(this.value);
440
+ this.userInput = null;
441
+ if (this.validateEvent) {
442
+ this.dispatch('ElFormItem', 'el.form.blur');
443
+ }
444
+ this.$emit('blur', this);
445
+ this.blur();
446
+ }
447
+ },
448
+ parsedValue: {
449
+ immediate: true,
450
+ handler(val) {
451
+ if (this.picker) {
452
+ this.picker.value = val;
453
+ }
454
+ }
455
+ },
456
+ defaultValue(val) {
457
+ // NOTE: should eventually move to jsx style picker + panel ?
458
+ if (this.picker) {
459
+ this.picker.defaultValue = val;
460
+ }
461
+ },
462
+ value(val, oldVal) {
463
+ if (!valueEquals(val, oldVal) && !this.pickerVisible && this.validateEvent) {
464
+ this.dispatch('ElFormItem', 'el.form.change', val);
465
+ }
466
+ }
467
+ },
468
+
469
+ computed: {
470
+ ranged() {
471
+ return this.type.indexOf('range') > -1;
472
+ },
473
+
474
+ reference() {
475
+ const reference = this.$refs.reference;
476
+ return reference.$el || reference;
477
+ },
478
+
479
+ refInput() {
480
+ if (this.reference) {
481
+ return [].slice.call(this.reference.querySelectorAll('input'));
482
+ }
483
+ return [];
484
+ },
485
+
486
+ valueIsEmpty() {
487
+ const val = this.value;
488
+ if (Array.isArray(val)) {
489
+ for (let i = 0, len = val.length; i < len; i++) {
490
+ if (val[i]) {
491
+ return false;
492
+ }
493
+ }
494
+ } else {
495
+ if (val) {
496
+ return false;
497
+ }
498
+ }
499
+ return true;
500
+ },
501
+
502
+ triggerClass() {
503
+ return this.prefixIcon || (this.type.indexOf('time') !== -1 ? 'el-icon-time' : 'el-icon-date');
504
+ },
505
+
506
+ selectionMode() {
507
+ if (this.type === 'week') {
508
+ return 'week';
509
+ } else if (this.type === 'month') {
510
+ return 'month';
511
+ } else if (this.type === 'year') {
512
+ return 'year';
513
+ } else if (this.type === 'dates') {
514
+ return 'dates';
515
+ } else if (this.type === 'months') {
516
+ return 'months';
517
+ } else if (this.type === 'years') {
518
+ return 'years';
519
+ }
520
+
521
+ return 'day';
522
+ },
523
+
524
+ haveTrigger() {
525
+ if (typeof this.showTrigger !== 'undefined') {
526
+ return this.showTrigger;
527
+ }
528
+ return HAVE_TRIGGER_TYPES.indexOf(this.type) !== -1;
529
+ },
530
+
531
+ displayValue() {
532
+ const formattedValue = formatAsFormatAndType(this.parsedValue, this.format, this.type, this.rangeSeparator);
533
+ if (Array.isArray(this.userInput)) {
534
+ return [
535
+ this.userInput[0] || (formattedValue && formattedValue[0]) || '',
536
+ this.userInput[1] || (formattedValue && formattedValue[1]) || ''
537
+ ];
538
+ } else if (this.userInput !== null) {
539
+ return this.userInput;
540
+ } else if (formattedValue) {
541
+ return (this.type === 'dates' || this.type === 'years' || this.type === 'months')
542
+ ? formattedValue.join(', ')
543
+ : formattedValue;
544
+ } else {
545
+ return '';
546
+ }
547
+ },
548
+
549
+ parsedValue() {
550
+ if (!this.value) return this.value; // component value is not set
551
+ if (this.type === 'time-select') return this.value; // time-select does not require parsing, this might change in next major version
552
+
553
+ const valueIsDateObject = isDateObject(this.value) || (Array.isArray(this.value) && this.value.every(isDateObject));
554
+ if (valueIsDateObject) {
555
+ return this.value;
556
+ }
557
+
558
+ if (this.valueFormat) {
559
+ return parseAsFormatAndType(this.value, this.valueFormat, this.type, this.rangeSeparator) || this.value;
560
+ }
561
+
562
+ // NOTE: deal with common but incorrect usage, should remove in next major version
563
+ // user might provide string / timestamp without value-format, coerce them into date (or array of date)
564
+ return Array.isArray(this.value) ? this.value.map(val => new Date(val)) : new Date(this.value);
565
+ },
566
+
567
+ _elFormItemSize() {
568
+ return (this.elFormItem || {}).elFormItemSize;
569
+ },
570
+
571
+ pickerSize() {
572
+ return this.size || this._elFormItemSize || (this.$ELEMENT || {}).size;
573
+ },
574
+
575
+ pickerDisabled() {
576
+ return this.disabled || (this.elForm || {}).disabled;
577
+ },
578
+
579
+ firstInputId() {
580
+ const obj = {};
581
+ let id;
582
+ if (this.ranged) {
583
+ id = this.id && this.id[0];
584
+ } else {
585
+ id = this.id;
586
+ }
587
+ if (id) obj.id = id;
588
+ return obj;
589
+ },
590
+
591
+ secondInputId() {
592
+ const obj = {};
593
+ let id;
594
+ if (this.ranged) {
595
+ id = this.id && this.id[1];
596
+ }
597
+ if (id) obj.id = id;
598
+ return obj;
599
+ }
600
+ },
601
+
602
+ created() {
603
+ // vue-popper
604
+ this.popperOptions = {
605
+ boundariesPadding: 0,
606
+ gpuAcceleration: false
607
+ };
608
+ this.placement = PLACEMENT_MAP[this.align] || PLACEMENT_MAP.left;
609
+
610
+ this.$on('fieldReset', this.handleFieldReset);
611
+ },
612
+
613
+ methods: {
614
+ focus() {
615
+ if (!this.ranged) {
616
+ this.$refs.reference.focus();
617
+ } else {
618
+ this.handleFocus();
619
+ }
620
+ },
621
+
622
+ blur() {
623
+ this.refInput.forEach(input => input.blur());
624
+ },
625
+
626
+ // {parse, formatTo} Value deals maps component value with internal Date
627
+ parseValue(value) {
628
+ const isParsed = isDateObject(value) || (Array.isArray(value) && value.every(isDateObject));
629
+ if (this.valueFormat && !isParsed) {
630
+ return parseAsFormatAndType(value, this.valueFormat, this.type, this.rangeSeparator) || value;
631
+ } else {
632
+ return value;
633
+ }
634
+ },
635
+
636
+ formatToValue(date) {
637
+ const isFormattable = isDateObject(date) || (Array.isArray(date) && date.every(isDateObject));
638
+ if (this.valueFormat && isFormattable) {
639
+ return formatAsFormatAndType(date, this.valueFormat, this.type, this.rangeSeparator);
640
+ } else {
641
+ return date;
642
+ }
643
+ },
644
+
645
+ // {parse, formatTo} String deals with user input
646
+ parseString(value) {
647
+ const type = Array.isArray(value) ? this.type : this.type.replace('range', '');
648
+ return parseAsFormatAndType(value, this.format, type);
649
+ },
650
+
651
+ formatToString(value) {
652
+ const type = Array.isArray(value) ? this.type : this.type.replace('range', '');
653
+ return formatAsFormatAndType(value, this.format, type);
654
+ },
655
+
656
+ handleMouseEnter() {
657
+ if (this.readonly || this.pickerDisabled) return;
658
+ if (!this.valueIsEmpty && this.clearable) {
659
+ this.showClose = true;
660
+ }
661
+ },
662
+
663
+ handleChange() {
664
+ if (this.userInput) {
665
+ const value = this.parseString(this.displayValue);
666
+ if (value) {
667
+ this.picker.value = value;
668
+ if (this.isValidValue(value)) {
669
+ this.emitInput(value);
670
+ this.userInput = null;
671
+ }
672
+ }
673
+ }
674
+ if (this.userInput === '') {
675
+ this.emitInput(null);
676
+ this.emitChange(null);
677
+ this.userInput = null;
678
+ }
679
+ },
680
+
681
+ handleStartInput(event) {
682
+ if (this.userInput) {
683
+ this.userInput = [event.target.value, this.userInput[1]];
684
+ } else {
685
+ this.userInput = [event.target.value, null];
686
+ }
687
+ },
688
+
689
+ handleEndInput(event) {
690
+ if (this.userInput) {
691
+ this.userInput = [this.userInput[0], event.target.value];
692
+ } else {
693
+ this.userInput = [null, event.target.value];
694
+ }
695
+ },
696
+
697
+ handleStartChange(event) {
698
+ const value = this.parseString(this.userInput && this.userInput[0]);
699
+ if (value) {
700
+ this.userInput = [this.formatToString(value), this.displayValue[1]];
701
+ const newValue = [value, this.picker.value && this.picker.value[1]];
702
+ this.picker.value = newValue;
703
+ if (this.isValidValue(newValue)) {
704
+ this.emitInput(newValue);
705
+ this.userInput = null;
706
+ }
707
+ }
708
+ },
709
+
710
+ handleEndChange(event) {
711
+ const value = this.parseString(this.userInput && this.userInput[1]);
712
+ if (value) {
713
+ this.userInput = [this.displayValue[0], this.formatToString(value)];
714
+ const newValue = [this.picker.value && this.picker.value[0], value];
715
+ this.picker.value = newValue;
716
+ if (this.isValidValue(newValue)) {
717
+ this.emitInput(newValue);
718
+ this.userInput = null;
719
+ }
720
+ }
721
+ },
722
+
723
+ handleClickIcon(event) {
724
+ if (this.readonly || this.pickerDisabled) return;
725
+ if (this.showClose) {
726
+ this.valueOnOpen = this.value;
727
+ event.stopPropagation();
728
+ this.emitInput(null);
729
+ this.emitChange(null);
730
+ this.showClose = false;
731
+ if (this.picker && typeof this.picker.handleClear === 'function') {
732
+ this.picker.handleClear();
733
+ }
734
+ } else {
735
+ this.pickerVisible = !this.pickerVisible;
736
+ }
737
+ },
738
+
739
+ handleClose() {
740
+ if (!this.pickerVisible) return;
741
+ this.pickerVisible = false;
742
+
743
+ if (this.type === 'dates' || this.type === 'years' || this.type === 'months') {
744
+ // restore to former value
745
+ const oldValue = parseAsFormatAndType(this.valueOnOpen, this.valueFormat, this.type, this.rangeSeparator) || this.valueOnOpen;
746
+ this.emitInput(oldValue);
747
+ }
748
+ },
749
+
750
+ handleFieldReset(initialValue) {
751
+ this.userInput = initialValue === '' ? null : initialValue;
752
+ },
753
+
754
+ handleFocus() {
755
+ const type = this.type;
756
+
757
+ if (HAVE_TRIGGER_TYPES.indexOf(type) !== -1 && !this.pickerVisible) {
758
+ this.pickerVisible = true;
759
+ }
760
+ this.$emit('focus', this);
761
+ },
762
+
763
+ handleKeydown(event) {
764
+ const keyCode = event.keyCode;
765
+
766
+ // ESC
767
+ if (keyCode === 27) {
768
+ this.pickerVisible = false;
769
+ event.stopPropagation();
770
+ return;
771
+ }
772
+
773
+ // Tab
774
+ if (keyCode === 9) {
775
+ if (!this.ranged) {
776
+ this.handleChange();
777
+ this.pickerVisible = this.picker.visible = false;
778
+ this.blur();
779
+ event.stopPropagation();
780
+ } else {
781
+ // user may change focus between two input
782
+ setTimeout(() => {
783
+ if (this.refInput.indexOf(document.activeElement) === -1) {
784
+ this.pickerVisible = false;
785
+ this.blur();
786
+ event.stopPropagation();
787
+ }
788
+ }, 0);
789
+ }
790
+ return;
791
+ }
792
+
793
+ // Enter
794
+ if (keyCode === 13) {
795
+ if (this.userInput === '' || this.isValidValue(this.parseString(this.displayValue))) {
796
+ this.handleChange();
797
+ this.pickerVisible = this.picker.visible = false;
798
+ this.blur();
799
+ }
800
+ event.stopPropagation();
801
+ return;
802
+ }
803
+
804
+ // if user is typing, do not let picker handle key input
805
+ if (this.userInput) {
806
+ event.stopPropagation();
807
+ return;
808
+ }
809
+
810
+ // delegate other keys to panel
811
+ if (this.picker && this.picker.handleKeydown) {
812
+ this.picker.handleKeydown(event);
813
+ }
814
+ },
815
+
816
+ handleRangeClick() {
817
+ const type = this.type;
818
+
819
+ if (HAVE_TRIGGER_TYPES.indexOf(type) !== -1 && !this.pickerVisible) {
820
+ this.pickerVisible = true;
821
+ }
822
+ this.$emit('focus', this);
823
+ },
824
+
825
+ hidePicker() {
826
+ if (this.picker) {
827
+ this.picker.resetView && this.picker.resetView();
828
+ this.pickerVisible = this.picker.visible = false;
829
+ this.destroyPopper();
830
+ }
831
+ },
832
+
833
+ showPicker() {
834
+ if (this.$isServer) return;
835
+ if (!this.picker) {
836
+ this.mountPicker();
837
+ }
838
+ this.pickerVisible = this.picker.visible = true;
839
+
840
+ this.updatePopper();
841
+
842
+ this.picker.value = this.parsedValue;
843
+ this.picker.resetView && this.picker.resetView();
844
+
845
+ this.$nextTick(() => {
846
+ this.picker.adjustSpinners && this.picker.adjustSpinners();
847
+ });
848
+ },
849
+
850
+ mountPicker() {
851
+ this.picker = new Vue(this.panel).$mount();
852
+ this.picker.defaultValue = this.defaultValue;
853
+ this.picker.defaultTime = this.defaultTime;
854
+ this.picker.popperClass = this.popperClass;
855
+ this.popperElm = this.picker.$el;
856
+ this.picker.width = this.reference.getBoundingClientRect().width;
857
+ this.picker.showTime = this.type === 'datetime' || this.type === 'datetimerange';
858
+ this.picker.selectionMode = this.selectionMode;
859
+ this.picker.unlinkPanels = this.unlinkPanels;
860
+ this.picker.arrowControl = this.arrowControl || this.timeArrowControl || false;
861
+ this.$watch('format', (format) => {
862
+ this.picker.format = format;
863
+ });
864
+
865
+ const updateOptions = () => {
866
+ const options = this.pickerOptions;
867
+
868
+ if (options && options.selectableRange) {
869
+ let ranges = options.selectableRange;
870
+ const parser = TYPE_VALUE_RESOLVER_MAP.datetimerange.parser;
871
+ const format = DEFAULT_FORMATS.timerange;
872
+
873
+ ranges = Array.isArray(ranges) ? ranges : [ranges];
874
+ this.picker.selectableRange = ranges.map(range => parser(range, format, this.rangeSeparator));
875
+ }
876
+
877
+ for (const option in options) {
878
+ if (options.hasOwnProperty(option) &&
879
+ // 忽略 time-picker 的该配置项
880
+ option !== 'selectableRange') {
881
+ this.picker[option] = options[option];
882
+ }
883
+ }
884
+
885
+ // main format must prevail over undocumented pickerOptions.format
886
+ if (this.format) {
887
+ this.picker.format = this.format;
888
+ }
889
+ };
890
+ updateOptions();
891
+ this.unwatchPickerOptions = this.$watch('pickerOptions', () => updateOptions(), { deep: true });
892
+ this.$el.appendChild(this.picker.$el);
893
+ this.picker.resetView && this.picker.resetView();
894
+
895
+ this.picker.$on('dodestroy', this.doDestroy);
896
+ this.picker.$on('pick', (date = '', visible = false) => {
897
+ this.userInput = null;
898
+ this.pickerVisible = this.picker.visible = visible;
899
+ this.emitInput(date);
900
+ this.picker.resetView && this.picker.resetView();
901
+ });
902
+
903
+ this.picker.$on('select-range', (start, end, pos) => {
904
+ if (this.refInput.length === 0) return;
905
+ if (!pos || pos === 'min') {
906
+ this.refInput[0].setSelectionRange(start, end);
907
+ this.refInput[0].focus();
908
+ } else if (pos === 'max') {
909
+ this.refInput[1].setSelectionRange(start, end);
910
+ this.refInput[1].focus();
911
+ }
912
+ });
913
+ },
914
+
915
+ unmountPicker() {
916
+ if (this.picker) {
917
+ this.picker.$destroy();
918
+ this.picker.$off();
919
+ if (typeof this.unwatchPickerOptions === 'function') {
920
+ this.unwatchPickerOptions();
921
+ }
922
+ this.picker.$el.parentNode.removeChild(this.picker.$el);
923
+ }
924
+ },
925
+
926
+ emitChange(val) {
927
+ // determine user real change only
928
+ if (!valueEquals(val, this.valueOnOpen)) {
929
+ this.$emit('change', val);
930
+ this.valueOnOpen = val;
931
+ if (this.validateEvent) {
932
+ this.dispatch('ElFormItem', 'el.form.change', val);
933
+ }
934
+ }
935
+ },
936
+
937
+ emitInput(val) {
938
+ const formatted = this.formatToValue(val);
939
+ if (!valueEquals(this.value, formatted)) {
940
+ this.$emit('input', formatted);
941
+ }
942
+ },
943
+
944
+ isValidValue(value) {
945
+ if (!this.picker) {
946
+ this.mountPicker();
947
+ }
948
+ if (this.picker.isValidValue) {
949
+ return value && this.picker.isValidValue(value);
950
+ } else {
951
+ return true;
952
+ }
953
+ }
954
+ }
955
955
  };
956
956
  </script>