@zkwq/business 0.0.1

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 (231) hide show
  1. package/dist/index.css +1 -0
  2. package/dist/index.js +21861 -0
  3. package/dist/index.umd.cjs +46 -0
  4. package/package.json +27 -0
  5. package/src/components/base/ui/alert/Alert.vue +94 -0
  6. package/src/components/base/ui/autocomplete/autocomplete-suggestions.vue +77 -0
  7. package/src/components/base/ui/autocomplete/autocomplete.vue +305 -0
  8. package/src/components/base/ui/backtop/main.vue +112 -0
  9. package/src/components/base/ui/button/Button.vue +84 -0
  10. package/src/components/base/ui/button/ButtonGroup.vue +10 -0
  11. package/src/components/base/ui/carousel/Carousel.vue +304 -0
  12. package/src/components/base/ui/carousel/CarouselItem.vue +137 -0
  13. package/src/components/base/ui/cascader/cascader.vue +650 -0
  14. package/src/components/base/ui/cascader-panel/cascader-menu.vue +138 -0
  15. package/src/components/base/ui/cascader-panel/cascader-node.vue +246 -0
  16. package/src/components/base/ui/cascader-panel/cascader-panel.vue +382 -0
  17. package/src/components/base/ui/cascader-panel/node.js +166 -0
  18. package/src/components/base/ui/cascader-panel/store.js +62 -0
  19. package/src/components/base/ui/checkbox/checkbox-button.vue +199 -0
  20. package/src/components/base/ui/checkbox/checkbox-group.vue +48 -0
  21. package/src/components/base/ui/checkbox/checkbox.vue +222 -0
  22. package/src/components/base/ui/col/col.js +71 -0
  23. package/src/components/base/ui/collapse/collapse-item.vue +180 -0
  24. package/src/components/base/ui/collapse/collapse.vue +73 -0
  25. package/src/components/base/ui/color-picker/color.js +317 -0
  26. package/src/components/base/ui/color-picker/components/alpha-slider.vue +132 -0
  27. package/src/components/base/ui/color-picker/components/hue-slider.vue +123 -0
  28. package/src/components/base/ui/color-picker/components/picker-dropdown.vue +119 -0
  29. package/src/components/base/ui/color-picker/components/predefine.vue +61 -0
  30. package/src/components/base/ui/color-picker/components/sv-panel.vue +100 -0
  31. package/src/components/base/ui/color-picker/draggable.js +36 -0
  32. package/src/components/base/ui/color-picker/index.js +2 -0
  33. package/src/components/base/ui/color-picker/main.vue +188 -0
  34. package/src/components/base/ui/date-picker/basic/date-table.vue +441 -0
  35. package/src/components/base/ui/date-picker/basic/month-table.vue +254 -0
  36. package/src/components/base/ui/date-picker/basic/time-spinner.vue +304 -0
  37. package/src/components/base/ui/date-picker/basic/year-table.vue +101 -0
  38. package/src/components/base/ui/date-picker/panel/date-range.vue +680 -0
  39. package/src/components/base/ui/date-picker/panel/date.vue +597 -0
  40. package/src/components/base/ui/date-picker/panel/month-range.vue +289 -0
  41. package/src/components/base/ui/date-picker/panel/time-range.vue +248 -0
  42. package/src/components/base/ui/date-picker/panel/time-select.vue +178 -0
  43. package/src/components/base/ui/date-picker/panel/time.vue +186 -0
  44. package/src/components/base/ui/date-picker/picker/date-picker.js +43 -0
  45. package/src/components/base/ui/date-picker/picker/time-picker.js +39 -0
  46. package/src/components/base/ui/date-picker/picker/time-select.js +21 -0
  47. package/src/components/base/ui/date-picker/picker.vue +942 -0
  48. package/src/components/base/ui/dialog/Index.vue +212 -0
  49. package/src/components/base/ui/directive/repeat-click.js +24 -0
  50. package/src/components/base/ui/directive/ripple.js +303 -0
  51. package/src/components/base/ui/divider/Divider.vue +37 -0
  52. package/src/components/base/ui/drawer/Drawer.vue +202 -0
  53. package/src/components/base/ui/dropdown/dropdown-item.vue +39 -0
  54. package/src/components/base/ui/dropdown/dropdown-menu.vue +63 -0
  55. package/src/components/base/ui/dropdown/dropdown.vue +308 -0
  56. package/src/components/base/ui/form/Form.vue +167 -0
  57. package/src/components/base/ui/form/FormItem.vue +334 -0
  58. package/src/components/base/ui/form/LabelWrap.vue +69 -0
  59. package/src/components/base/ui/icon/icon.vue +13 -0
  60. package/src/components/base/ui/image/image-viewer.vue +302 -0
  61. package/src/components/base/ui/image/main.vue +248 -0
  62. package/src/components/base/ui/index.js +189 -0
  63. package/src/components/base/ui/input/Input.vue +438 -0
  64. package/src/components/base/ui/input/calcTextareaHeight.js +104 -0
  65. package/src/components/base/ui/input-number/input-number.vue +285 -0
  66. package/src/components/base/ui/locale/format.js +32 -0
  67. package/src/components/base/ui/locale/index.js +48 -0
  68. package/src/components/base/ui/locale/lang/zh-CN.js +120 -0
  69. package/src/components/base/ui/menu/menu-item-group.vue +45 -0
  70. package/src/components/base/ui/menu/menu-item.vue +112 -0
  71. package/src/components/base/ui/menu/menu-mixin.js +44 -0
  72. package/src/components/base/ui/menu/menu.vue +312 -0
  73. package/src/components/base/ui/menu/submenu.vue +408 -0
  74. package/src/components/base/ui/message/index.js +2 -0
  75. package/src/components/base/ui/message/main.js +87 -0
  76. package/src/components/base/ui/message/main.vue +110 -0
  77. package/src/components/base/ui/message-box/main.js +216 -0
  78. package/src/components/base/ui/message-box/main.vue +323 -0
  79. package/src/components/base/ui/mixin/emitter.js +31 -0
  80. package/src/components/base/ui/mixin/focus.js +9 -0
  81. package/src/components/base/ui/mixin/locale.js +9 -0
  82. package/src/components/base/ui/mixin/migrating.js +33 -0
  83. package/src/components/base/ui/pagination/pager.vue +163 -0
  84. package/src/components/base/ui/pagination/pagination.jsx +391 -0
  85. package/src/components/base/ui/popover/directive.js +20 -0
  86. package/src/components/base/ui/popover/index.js +14 -0
  87. package/src/components/base/ui/popover/main.vue +236 -0
  88. package/src/components/base/ui/progress/Progress.vue +227 -0
  89. package/src/components/base/ui/radio/radio-button.vue +114 -0
  90. package/src/components/base/ui/radio/radio-group.vue +111 -0
  91. package/src/components/base/ui/radio/radio.vue +134 -0
  92. package/src/components/base/ui/row/row.js +47 -0
  93. package/src/components/base/ui/scrollbar/bar.jsx +91 -0
  94. package/src/components/base/ui/scrollbar/index.jsx +203 -0
  95. package/src/components/base/ui/scrollbar/util.js +32 -0
  96. package/src/components/base/ui/select/Option.vue +168 -0
  97. package/src/components/base/ui/select/OptionGroup.vue +60 -0
  98. package/src/components/base/ui/select/Select.vue +920 -0
  99. package/src/components/base/ui/select/SelectDropdown.vue +74 -0
  100. package/src/components/base/ui/select/navigation-mixin.js +54 -0
  101. package/src/components/base/ui/skeleton/index.js +8 -0
  102. package/src/components/base/ui/skeleton/src/img-placeholder.vue +16 -0
  103. package/src/components/base/ui/skeleton/src/index.vue +80 -0
  104. package/src/components/base/ui/skeleton/src/item.vue +22 -0
  105. package/src/components/base/ui/skeleton-item/index.js +8 -0
  106. package/src/components/base/ui/slider/button.vue +238 -0
  107. package/src/components/base/ui/slider/main.vue +427 -0
  108. package/src/components/base/ui/slider/marker.js +18 -0
  109. package/src/components/base/ui/style/alert.scss +147 -0
  110. package/src/components/base/ui/style/animations.scss +65 -0
  111. package/src/components/base/ui/style/autocomplete.scss +81 -0
  112. package/src/components/base/ui/style/backtop.scss +20 -0
  113. package/src/components/base/ui/style/button-group.scss +0 -0
  114. package/src/components/base/ui/style/button.scss +380 -0
  115. package/src/components/base/ui/style/carousel-item.scss +50 -0
  116. package/src/components/base/ui/style/carousel.scss +161 -0
  117. package/src/components/base/ui/style/cascader-panel.scss +120 -0
  118. package/src/components/base/ui/style/cascader.scss +185 -0
  119. package/src/components/base/ui/style/checkbox-button.scss +0 -0
  120. package/src/components/base/ui/style/checkbox-group.scss +0 -0
  121. package/src/components/base/ui/style/checkbox.scss +360 -0
  122. package/src/components/base/ui/style/col.scss +156 -0
  123. package/src/components/base/ui/style/collapse-item.scss +0 -0
  124. package/src/components/base/ui/style/collapse.scss +114 -0
  125. package/src/components/base/ui/style/color-picker.scss +387 -0
  126. package/src/components/base/ui/style/config.scss +4 -0
  127. package/src/components/base/ui/style/date-picker/date-picker.scss +97 -0
  128. package/src/components/base/ui/style/date-picker/date-range-picker.scss +101 -0
  129. package/src/components/base/ui/style/date-picker/date-table.scss +151 -0
  130. package/src/components/base/ui/style/date-picker/month-table.scss +82 -0
  131. package/src/components/base/ui/style/date-picker/picker-panel.scss +117 -0
  132. package/src/components/base/ui/style/date-picker/picker.scss +197 -0
  133. package/src/components/base/ui/style/date-picker/time-picker.scss +85 -0
  134. package/src/components/base/ui/style/date-picker/time-range-picker.scss +31 -0
  135. package/src/components/base/ui/style/date-picker/time-spinner.scss +110 -0
  136. package/src/components/base/ui/style/date-picker/year-table.scss +51 -0
  137. package/src/components/base/ui/style/date-picker.scss +12 -0
  138. package/src/components/base/ui/style/dialog.scss +123 -0
  139. package/src/components/base/ui/style/divider.scss +47 -0
  140. package/src/components/base/ui/style/drawer.scss +218 -0
  141. package/src/components/base/ui/style/dropdown-item.scss +0 -0
  142. package/src/components/base/ui/style/dropdown-menu.scss +0 -0
  143. package/src/components/base/ui/style/dropdown.scss +185 -0
  144. package/src/components/base/ui/style/form-item.scss +0 -0
  145. package/src/components/base/ui/style/form.scss +203 -0
  146. package/src/components/base/ui/style/function.scss +43 -0
  147. package/src/components/base/ui/style/icon.scss +1167 -0
  148. package/src/components/base/ui/style/image.scss +184 -0
  149. package/src/components/base/ui/style/index.scss +57 -0
  150. package/src/components/base/ui/style/input-number.scss +187 -0
  151. package/src/components/base/ui/style/input.scss +477 -0
  152. package/src/components/base/ui/style/menu-item-group.scss +0 -0
  153. package/src/components/base/ui/style/menu-item.scss +0 -0
  154. package/src/components/base/ui/style/menu.scss +294 -0
  155. package/src/components/base/ui/style/message-box.scss +231 -0
  156. package/src/components/base/ui/style/message.scss +120 -0
  157. package/src/components/base/ui/style/mixins.scss +196 -0
  158. package/src/components/base/ui/style/option-group.scss +42 -0
  159. package/src/components/base/ui/style/option.scss +36 -0
  160. package/src/components/base/ui/style/pagination.scss +295 -0
  161. package/src/components/base/ui/style/popover.scss +40 -0
  162. package/src/components/base/ui/style/popper.scss +102 -0
  163. package/src/components/base/ui/style/popup.scss +42 -0
  164. package/src/components/base/ui/style/progress.scss +141 -0
  165. package/src/components/base/ui/style/radio-button.scss +113 -0
  166. package/src/components/base/ui/style/radio-group.scss +9 -0
  167. package/src/components/base/ui/style/radio.scss +203 -0
  168. package/src/components/base/ui/style/ripple.scss +35 -0
  169. package/src/components/base/ui/style/row.scss +39 -0
  170. package/src/components/base/ui/style/scrollbar.scss +75 -0
  171. package/src/components/base/ui/style/select-dropdown.scss +59 -0
  172. package/src/components/base/ui/style/select.scss +154 -0
  173. package/src/components/base/ui/style/skeleton-item.scss +84 -0
  174. package/src/components/base/ui/style/skeleton.scss +40 -0
  175. package/src/components/base/ui/style/slider.scss +250 -0
  176. package/src/components/base/ui/style/switch.scss +116 -0
  177. package/src/components/base/ui/style/tabs.scss +602 -0
  178. package/src/components/base/ui/style/tag.scss +174 -0
  179. package/src/components/base/ui/style/tooltip.scss +146 -0
  180. package/src/components/base/ui/style/transition.scss +138 -0
  181. package/src/components/base/ui/style/upload.scss +603 -0
  182. package/src/components/base/ui/style/utils.scss +39 -0
  183. package/src/components/base/ui/style/var.scss +1007 -0
  184. package/src/components/base/ui/switch/index.vue +174 -0
  185. package/src/components/base/ui/tabs/tab-bar.vue +57 -0
  186. package/src/components/base/ui/tabs/tab-nav.vue +294 -0
  187. package/src/components/base/ui/tabs/tab-pane.vue +56 -0
  188. package/src/components/base/ui/tabs/tabs.vue +191 -0
  189. package/src/components/base/ui/tag/Tag.vue +60 -0
  190. package/src/components/base/ui/tooltip/tooltip.jsx +234 -0
  191. package/src/components/base/ui/upload/Index.vue +340 -0
  192. package/src/components/base/ui/upload/Upload.vue +216 -0
  193. package/src/components/base/ui/upload/UploadDragger.vue +70 -0
  194. package/src/components/base/ui/upload/UploadList.vue +100 -0
  195. package/src/components/base/ui/upload/ajax.js +85 -0
  196. package/src/components/base/ui/util/aria-dialog.js +90 -0
  197. package/src/components/base/ui/util/aria-utils.js +122 -0
  198. package/src/components/base/ui/util/clickoutside.js +76 -0
  199. package/src/components/base/ui/util/date-util.js +292 -0
  200. package/src/components/base/ui/util/date.js +370 -0
  201. package/src/components/base/ui/util/debounce.js +21 -0
  202. package/src/components/base/ui/util/deepmerge.js +100 -0
  203. package/src/components/base/ui/util/dom.js +215 -0
  204. package/src/components/base/ui/util/index.js +262 -0
  205. package/src/components/base/ui/util/menu/aria-menubar.js +14 -0
  206. package/src/components/base/ui/util/menu/aria-menuitem.js +49 -0
  207. package/src/components/base/ui/util/menu/aria-submenu.js +59 -0
  208. package/src/components/base/ui/util/merge.js +14 -0
  209. package/src/components/base/ui/util/popper.js +1235 -0
  210. package/src/components/base/ui/util/popup/index.js +218 -0
  211. package/src/components/base/ui/util/popup/popup-manager.js +194 -0
  212. package/src/components/base/ui/util/resize-events.js +32 -0
  213. package/src/components/base/ui/util/scroll-into-view.js +27 -0
  214. package/src/components/base/ui/util/scrollbar-width.js +29 -0
  215. package/src/components/base/ui/util/shared.js +7 -0
  216. package/src/components/base/ui/util/throttle.js +91 -0
  217. package/src/components/base/ui/util/types.js +24 -0
  218. package/src/components/base/ui/util/vdom.js +5 -0
  219. package/src/components/base/ui/util/vue-popper.js +188 -0
  220. package/src/components/normal/AggsItemH.vue +139 -0
  221. package/src/index.js +10 -0
  222. package/src/static/base-icons.ttf +0 -0
  223. package/src/static/base-icons.woff +0 -0
  224. package/src/static/label_bg.png +0 -0
  225. package/src/static/term-label-bg.png +0 -0
  226. package/src/style/app-article.scss +698 -0
  227. package/src/style/app-comment.scss +259 -0
  228. package/src/style/app-recommend.scss +48 -0
  229. package/src/style/app-richtext.scss +176 -0
  230. package/src/style/index.scss +523 -0
  231. package/vite.config.js +38 -0
@@ -0,0 +1,680 @@
1
+ <template>
2
+ <transition name="base-zoom-in-top" @after-leave="$emit('dodestroy')">
3
+ <div
4
+ v-show="visible"
5
+ class="base-picker-panel base-date-range-picker base-popper"
6
+ :class="[{
7
+ 'has-sidebar': $slots.sidebar || shortcuts,
8
+ 'has-time': showTime
9
+ }, popperClass]">
10
+ <div class="base-picker-panel__body-wrapper">
11
+ <slot name="sidebar" class="base-picker-panel__sidebar"></slot>
12
+ <div class="base-picker-panel__sidebar" v-if="shortcuts">
13
+ <button
14
+ type="button"
15
+ class="base-picker-panel__shortcut"
16
+ v-for="(shortcut, key) in shortcuts"
17
+ :key="key"
18
+ @click="handleShortcutClick(shortcut)">{{shortcut.text}}</button>
19
+ </div>
20
+ <div class="base-picker-panel__body">
21
+ <div class="base-date-range-picker__time-header" v-if="showTime">
22
+ <span class="base-date-range-picker__editors-wrap">
23
+ <span class="base-date-range-picker__time-picker-wrap">
24
+ <base-input
25
+ size="small"
26
+ :disabled="rangeState.selecting"
27
+ ref="minInput"
28
+ :placeholder="t('base.datepicker.startDate')"
29
+ class="base-date-range-picker__editor"
30
+ :value="minVisibleDate"
31
+ @input="val => handleDateInput(val, 'min')"
32
+ @change="val => handleDateChange(val, 'min')" />
33
+ </span>
34
+ <span class="base-date-range-picker__time-picker-wrap" v-clickoutside="handleMinTimeClose">
35
+ <base-input
36
+ size="small"
37
+ class="base-date-range-picker__editor"
38
+ :disabled="rangeState.selecting"
39
+ :placeholder="t('base.datepicker.startTime')"
40
+ :value="minVisibleTime"
41
+ @focus="minTimePickerVisible = true"
42
+ @input="val => handleTimeInput(val, 'min')"
43
+ @change="val => handleTimeChange(val, 'min')" />
44
+ <time-picker
45
+ ref="minTimePicker"
46
+ @pick="handleMinTimePick"
47
+ :time-arrow-control="arrowControl"
48
+ :visible="minTimePickerVisible"
49
+ @mounted="$refs.minTimePicker.format=timeFormat">
50
+ </time-picker>
51
+ </span>
52
+ </span>
53
+ <span class="base-icon-arrow-right"></span>
54
+ <span class="base-date-range-picker__editors-wrap is-right">
55
+ <span class="base-date-range-picker__time-picker-wrap">
56
+ <base-input
57
+ size="small"
58
+ class="base-date-range-picker__editor"
59
+ :disabled="rangeState.selecting"
60
+ :placeholder="t('base.datepicker.endDate')"
61
+ :value="maxVisibleDate"
62
+ :readonly="!minDate"
63
+ @input="val => handleDateInput(val, 'max')"
64
+ @change="val => handleDateChange(val, 'max')" />
65
+ </span>
66
+ <span class="base-date-range-picker__time-picker-wrap" v-clickoutside="handleMaxTimeClose">
67
+ <base-input
68
+ size="small"
69
+ class="base-date-range-picker__editor"
70
+ :disabled="rangeState.selecting"
71
+ :placeholder="t('base.datepicker.endTime')"
72
+ :value="maxVisibleTime"
73
+ :readonly="!minDate"
74
+ @focus="minDate && (maxTimePickerVisible = true)"
75
+ @input="val => handleTimeInput(val, 'max')"
76
+ @change="val => handleTimeChange(val, 'max')" />
77
+ <time-picker
78
+ ref="maxTimePicker"
79
+ @pick="handleMaxTimePick"
80
+ :time-arrow-control="arrowControl"
81
+ :visible="maxTimePickerVisible"
82
+ @mounted="$refs.maxTimePicker.format=timeFormat">
83
+ </time-picker>
84
+ </span>
85
+ </span>
86
+ </div>
87
+ <div class="base-picker-panel__content base-date-range-picker__content is-left">
88
+ <div class="base-date-range-picker__header">
89
+ <button
90
+ type="button"
91
+ @click="leftPrevYear"
92
+ class="base-picker-panel__icon-btn base-icon-d-arrow-left"></button>
93
+ <button
94
+ type="button"
95
+ @click="leftPrevMonth"
96
+ class="base-picker-panel__icon-btn base-icon-arrow-left"></button>
97
+ <button
98
+ type="button"
99
+ @click="leftNextYear"
100
+ v-if="unlinkPanels"
101
+ :disabled="!enableYearArrow"
102
+ :class="{ 'is-disabled': !enableYearArrow }"
103
+ class="base-picker-panel__icon-btn base-icon-d-arrow-right"></button>
104
+ <button
105
+ type="button"
106
+ @click="leftNextMonth"
107
+ v-if="unlinkPanels"
108
+ :disabled="!enableMonthArrow"
109
+ :class="{ 'is-disabled': !enableMonthArrow }"
110
+ class="base-picker-panel__icon-btn base-icon-arrow-right"></button>
111
+ <div>{{ leftLabel }}</div>
112
+ </div>
113
+ <date-table
114
+ selection-mode="range"
115
+ :date="leftDate"
116
+ :default-value="defaultValue"
117
+ :min-date="minDate"
118
+ :max-date="maxDate"
119
+ :range-state="rangeState"
120
+ :disabled-date="disabledDate"
121
+ :cell-class-name="cellClassName"
122
+ @changerange="handleChangeRange"
123
+ :first-day-of-week="firstDayOfWeek"
124
+ @pick="handleRangePick">
125
+ </date-table>
126
+ </div>
127
+ <div class="base-picker-panel__content base-date-range-picker__content is-right">
128
+ <div class="base-date-range-picker__header">
129
+ <button
130
+ type="button"
131
+ @click="rightPrevYear"
132
+ v-if="unlinkPanels"
133
+ :disabled="!enableYearArrow"
134
+ :class="{ 'is-disabled': !enableYearArrow }"
135
+ class="base-picker-panel__icon-btn base-icon-d-arrow-left"></button>
136
+ <button
137
+ type="button"
138
+ @click="rightPrevMonth"
139
+ v-if="unlinkPanels"
140
+ :disabled="!enableMonthArrow"
141
+ :class="{ 'is-disabled': !enableMonthArrow }"
142
+ class="base-picker-panel__icon-btn base-icon-arrow-left"></button>
143
+ <button
144
+ type="button"
145
+ @click="rightNextYear"
146
+ class="base-picker-panel__icon-btn base-icon-d-arrow-right"></button>
147
+ <button
148
+ type="button"
149
+ @click="rightNextMonth"
150
+ class="base-picker-panel__icon-btn base-icon-arrow-right"></button>
151
+ <div>{{ rightLabel }}</div>
152
+ </div>
153
+ <date-table
154
+ selection-mode="range"
155
+ :date="rightDate"
156
+ :default-value="defaultValue"
157
+ :min-date="minDate"
158
+ :max-date="maxDate"
159
+ :range-state="rangeState"
160
+ :disabled-date="disabledDate"
161
+ :cell-class-name="cellClassName"
162
+ @changerange="handleChangeRange"
163
+ :first-day-of-week="firstDayOfWeek"
164
+ @pick="handleRangePick">
165
+ </date-table>
166
+ </div>
167
+ </div>
168
+ </div>
169
+ <div class="base-picker-panel__footer" v-if="showTime">
170
+ <base-button
171
+ size="mini"
172
+ type="text"
173
+ class="base-picker-panel__link-btn"
174
+ @click="handleClear">
175
+ {{ t('base.datepicker.clear') }}
176
+ </base-button>
177
+ <base-button
178
+ plain
179
+ size="mini"
180
+ class="base-picker-panel__link-btn"
181
+ :disabled="btnDisabled"
182
+ @click="handleConfirm(false)">
183
+ {{ t('base.datepicker.confirm') }}
184
+ </base-button>
185
+ </div>
186
+ </div>
187
+ </transition>
188
+ </template>
189
+
190
+ <script type="text/babel">
191
+ import {
192
+ formatDate,
193
+ parseDate,
194
+ isDate,
195
+ modifyDate,
196
+ modifyTime,
197
+ modifyWithTimeString,
198
+ prevYear,
199
+ nextYear,
200
+ prevMonth,
201
+ nextMonth,
202
+ nextDate,
203
+ extractDateFormat,
204
+ extractTimeFormat
205
+ } from '../../util/date-util';
206
+ import Clickoutside from '../../util/clickoutside';
207
+ import Locale from '../../mixin/locale';
208
+ import TimePicker from './time';
209
+ import DateTable from '../basic/date-table';
210
+ import BaseInput from '../../input/Input';
211
+ import BaseButton from '../../button/Button';
212
+
213
+ const calcDefaultValue = (defaultValue) => {
214
+ if (Array.isArray(defaultValue)) {
215
+ return [new Date(defaultValue[0]), new Date(defaultValue[1])];
216
+ } else if (defaultValue) {
217
+ return [new Date(defaultValue), nextDate(new Date(defaultValue), 1)];
218
+ } else {
219
+ return [new Date(), nextDate(new Date(), 1)];
220
+ }
221
+ };
222
+
223
+ export default {
224
+ mixins: [Locale],
225
+
226
+ directives: { Clickoutside },
227
+
228
+ computed: {
229
+ btnDisabled() {
230
+ return !(this.minDate && this.maxDate && !this.selecting && this.isValidValue([this.minDate, this.maxDate]));
231
+ },
232
+
233
+ leftLabel() {
234
+ return this.leftDate.getFullYear() + ' ' + this.t('base.datepicker.year') + ' ' + this.t(`base.datepicker.month${ this.leftDate.getMonth() + 1 }`);
235
+ },
236
+
237
+ rightLabel() {
238
+ return this.rightDate.getFullYear() + ' ' + this.t('base.datepicker.year') + ' ' + this.t(`base.datepicker.month${ this.rightDate.getMonth() + 1 }`);
239
+ },
240
+
241
+ leftYear() {
242
+ return this.leftDate.getFullYear();
243
+ },
244
+
245
+ leftMonth() {
246
+ return this.leftDate.getMonth();
247
+ },
248
+
249
+ leftMonthDate() {
250
+ return this.leftDate.getDate();
251
+ },
252
+
253
+ rightYear() {
254
+ return this.rightDate.getFullYear();
255
+ },
256
+
257
+ rightMonth() {
258
+ return this.rightDate.getMonth();
259
+ },
260
+
261
+ rightMonthDate() {
262
+ return this.rightDate.getDate();
263
+ },
264
+
265
+ minVisibleDate() {
266
+ if (this.dateUserInput.min !== null) return this.dateUserInput.min;
267
+ if (this.minDate) return formatDate(this.minDate, this.dateFormat);
268
+ return '';
269
+ },
270
+
271
+ maxVisibleDate() {
272
+ if (this.dateUserInput.max !== null) return this.dateUserInput.max;
273
+ if (this.maxDate || this.minDate) return formatDate(this.maxDate || this.minDate, this.dateFormat);
274
+ return '';
275
+ },
276
+
277
+ minVisibleTime() {
278
+ if (this.timeUserInput.min !== null) return this.timeUserInput.min;
279
+ if (this.minDate) return formatDate(this.minDate, this.timeFormat);
280
+ return '';
281
+ },
282
+
283
+ maxVisibleTime() {
284
+ if (this.timeUserInput.max !== null) return this.timeUserInput.max;
285
+ if (this.maxDate || this.minDate) return formatDate(this.maxDate || this.minDate, this.timeFormat);
286
+ return '';
287
+ },
288
+
289
+ timeFormat() {
290
+ if (this.format) {
291
+ return extractTimeFormat(this.format);
292
+ } else {
293
+ return 'HH:mm:ss';
294
+ }
295
+ },
296
+
297
+ dateFormat() {
298
+ if (this.format) {
299
+ return extractDateFormat(this.format);
300
+ } else {
301
+ return 'yyyy-MM-dd';
302
+ }
303
+ },
304
+
305
+ enableMonthArrow() {
306
+ const nextMonth = (this.leftMonth + 1) % 12;
307
+ const yearOffset = this.leftMonth + 1 >= 12 ? 1 : 0;
308
+ return this.unlinkPanels && new Date(this.leftYear + yearOffset, nextMonth) < new Date(this.rightYear, this.rightMonth);
309
+ },
310
+
311
+ enableYearArrow() {
312
+ return this.unlinkPanels && this.rightYear * 12 + this.rightMonth - (this.leftYear * 12 + this.leftMonth + 1) >= 12;
313
+ }
314
+ },
315
+
316
+ data() {
317
+ return {
318
+ popperClass: '',
319
+ value: [],
320
+ defaultValue: null,
321
+ defaultTime: null,
322
+ minDate: '',
323
+ maxDate: '',
324
+ leftDate: new Date(),
325
+ rightDate: nextMonth(new Date()),
326
+ rangeState: {
327
+ endDate: null,
328
+ selecting: false,
329
+ row: null,
330
+ column: null
331
+ },
332
+ showTime: false,
333
+ shortcuts: '',
334
+ visible: '',
335
+ disabledDate: '',
336
+ cellClassName: '',
337
+ firstDayOfWeek: 7,
338
+ minTimePickerVisible: false,
339
+ maxTimePickerVisible: false,
340
+ format: '',
341
+ arrowControl: false,
342
+ unlinkPanels: false,
343
+ dateUserInput: {
344
+ min: null,
345
+ max: null
346
+ },
347
+ timeUserInput: {
348
+ min: null,
349
+ max: null
350
+ }
351
+ };
352
+ },
353
+
354
+ watch: {
355
+ minDate(val) {
356
+ this.dateUserInput.min = null;
357
+ this.timeUserInput.min = null;
358
+ this.$nextTick(() => {
359
+ if (this.$refs.maxTimePicker && this.maxDate && this.maxDate < this.minDate) {
360
+ const format = 'HH:mm:ss';
361
+ this.$refs.maxTimePicker.selectableRange = [
362
+ [
363
+ parseDate(formatDate(this.minDate, format), format),
364
+ parseDate('23:59:59', format)
365
+ ]
366
+ ];
367
+ }
368
+ });
369
+ if (val && this.$refs.minTimePicker) {
370
+ this.$refs.minTimePicker.date = val;
371
+ this.$refs.minTimePicker.value = val;
372
+ }
373
+ },
374
+
375
+ maxDate(val) {
376
+ this.dateUserInput.max = null;
377
+ this.timeUserInput.max = null;
378
+ if (val && this.$refs.maxTimePicker) {
379
+ this.$refs.maxTimePicker.date = val;
380
+ this.$refs.maxTimePicker.value = val;
381
+ }
382
+ },
383
+
384
+ minTimePickerVisible(val) {
385
+ if (val) {
386
+ this.$nextTick(() => {
387
+ this.$refs.minTimePicker.date = this.minDate;
388
+ this.$refs.minTimePicker.value = this.minDate;
389
+ this.$refs.minTimePicker.adjustSpinners();
390
+ });
391
+ }
392
+ },
393
+
394
+ maxTimePickerVisible(val) {
395
+ if (val) {
396
+ this.$nextTick(() => {
397
+ this.$refs.maxTimePicker.date = this.maxDate;
398
+ this.$refs.maxTimePicker.value = this.maxDate;
399
+ this.$refs.maxTimePicker.adjustSpinners();
400
+ });
401
+ }
402
+ },
403
+
404
+ value(newVal) {
405
+ if (!newVal) {
406
+ this.minDate = null;
407
+ this.maxDate = null;
408
+ } else if (Array.isArray(newVal)) {
409
+ this.minDate = isDate(newVal[0]) ? new Date(newVal[0]) : null;
410
+ this.maxDate = isDate(newVal[1]) ? new Date(newVal[1]) : null;
411
+ if (this.minDate) {
412
+ this.leftDate = this.minDate;
413
+ if (this.unlinkPanels && this.maxDate) {
414
+ const minDateYear = this.minDate.getFullYear();
415
+ const minDateMonth = this.minDate.getMonth();
416
+ const maxDateYear = this.maxDate.getFullYear();
417
+ const maxDateMonth = this.maxDate.getMonth();
418
+ this.rightDate = minDateYear === maxDateYear && minDateMonth === maxDateMonth
419
+ ? nextMonth(this.maxDate)
420
+ : this.maxDate;
421
+ } else {
422
+ this.rightDate = nextMonth(this.leftDate);
423
+ }
424
+ } else {
425
+ this.leftDate = calcDefaultValue(this.defaultValue)[0];
426
+ this.rightDate = nextMonth(this.leftDate);
427
+ }
428
+ }
429
+ },
430
+
431
+ defaultValue(val) {
432
+ if (!Array.isArray(this.value)) {
433
+ const [left, right] = calcDefaultValue(val);
434
+ this.leftDate = left;
435
+ this.rightDate = val && val[1] && this.unlinkPanels
436
+ ? right
437
+ : nextMonth(this.leftDate);
438
+ }
439
+ }
440
+ },
441
+
442
+ methods: {
443
+ handleClear() {
444
+ this.minDate = null;
445
+ this.maxDate = null;
446
+ this.leftDate = calcDefaultValue(this.defaultValue)[0];
447
+ this.rightDate = nextMonth(this.leftDate);
448
+ this.$emit('pick', null);
449
+ },
450
+
451
+ handleChangeRange(val) {
452
+ this.minDate = val.minDate;
453
+ this.maxDate = val.maxDate;
454
+ this.rangeState = val.rangeState;
455
+ },
456
+
457
+ handleDateInput(value, type) {
458
+ this.dateUserInput[type] = value;
459
+ if (value.length !== this.dateFormat.length) return;
460
+ const parsedValue = parseDate(value, this.dateFormat);
461
+
462
+ if (parsedValue) {
463
+ if (typeof this.disabledDate === 'function' &&
464
+ this.disabledDate(new Date(parsedValue))) {
465
+ return;
466
+ }
467
+ if (type === 'min') {
468
+ this.minDate = modifyDate(this.minDate || new Date(), parsedValue.getFullYear(), parsedValue.getMonth(), parsedValue.getDate());
469
+ this.leftDate = new Date(parsedValue);
470
+ if (!this.unlinkPanels) {
471
+ this.rightDate = nextMonth(this.leftDate);
472
+ }
473
+ } else {
474
+ this.maxDate = modifyDate(this.maxDate || new Date(), parsedValue.getFullYear(), parsedValue.getMonth(), parsedValue.getDate());
475
+ this.rightDate = new Date(parsedValue);
476
+ if (!this.unlinkPanels) {
477
+ this.leftDate = prevMonth(parsedValue);
478
+ }
479
+ }
480
+ }
481
+ },
482
+
483
+ handleDateChange(value, type) {
484
+ const parsedValue = parseDate(value, this.dateFormat);
485
+ if (parsedValue) {
486
+ if (type === 'min') {
487
+ this.minDate = modifyDate(this.minDate, parsedValue.getFullYear(), parsedValue.getMonth(), parsedValue.getDate());
488
+ if (this.minDate > this.maxDate) {
489
+ this.maxDate = this.minDate;
490
+ }
491
+ } else {
492
+ this.maxDate = modifyDate(this.maxDate, parsedValue.getFullYear(), parsedValue.getMonth(), parsedValue.getDate());
493
+ if (this.maxDate < this.minDate) {
494
+ this.minDate = this.maxDate;
495
+ }
496
+ }
497
+ }
498
+ },
499
+
500
+ handleTimeInput(value, type) {
501
+ this.timeUserInput[type] = value;
502
+ if (value.length !== this.timeFormat.length) return;
503
+ const parsedValue = parseDate(value, this.timeFormat);
504
+
505
+ if (parsedValue) {
506
+ if (type === 'min') {
507
+ this.minDate = modifyTime(this.minDate, parsedValue.getHours(), parsedValue.getMinutes(), parsedValue.getSeconds());
508
+ this.$nextTick(_ => this.$refs.minTimePicker.adjustSpinners());
509
+ } else {
510
+ this.maxDate = modifyTime(this.maxDate, parsedValue.getHours(), parsedValue.getMinutes(), parsedValue.getSeconds());
511
+ this.$nextTick(_ => this.$refs.maxTimePicker.adjustSpinners());
512
+ }
513
+ }
514
+ },
515
+
516
+ handleTimeChange(value, type) {
517
+ const parsedValue = parseDate(value, this.timeFormat);
518
+ if (parsedValue) {
519
+ if (type === 'min') {
520
+ this.minDate = modifyTime(this.minDate, parsedValue.getHours(), parsedValue.getMinutes(), parsedValue.getSeconds());
521
+ if (this.minDate > this.maxDate) {
522
+ this.maxDate = this.minDate;
523
+ }
524
+ this.$refs.minTimePicker.value = this.minDate;
525
+ this.minTimePickerVisible = false;
526
+ } else {
527
+ this.maxDate = modifyTime(this.maxDate, parsedValue.getHours(), parsedValue.getMinutes(), parsedValue.getSeconds());
528
+ if (this.maxDate < this.minDate) {
529
+ this.minDate = this.maxDate;
530
+ }
531
+ this.$refs.maxTimePicker.value = this.minDate;
532
+ this.maxTimePickerVisible = false;
533
+ }
534
+ }
535
+ },
536
+
537
+ handleRangePick(val, close = true) {
538
+ const defaultTime = this.defaultTime || [];
539
+ const minDate = modifyWithTimeString(val.minDate, defaultTime[0]);
540
+ const maxDate = modifyWithTimeString(val.maxDate, defaultTime[1]);
541
+
542
+ if (this.maxDate === maxDate && this.minDate === minDate) {
543
+ return;
544
+ }
545
+ this.onPick && this.onPick(val);
546
+ this.maxDate = maxDate;
547
+ this.minDate = minDate;
548
+
549
+ // workaround for https://github.com/ElemeFE/element/issues/7539, should remove this block when we don't have to care about Chromium 55 - 57
550
+ setTimeout(() => {
551
+ this.maxDate = maxDate;
552
+ this.minDate = minDate;
553
+ }, 10);
554
+ if (!close || this.showTime) return;
555
+ this.handleConfirm();
556
+ },
557
+
558
+ handleShortcutClick(shortcut) {
559
+ if (shortcut.onClick) {
560
+ shortcut.onClick(this);
561
+ }
562
+ },
563
+
564
+ handleMinTimePick(value, visible, first) {
565
+ this.minDate = this.minDate || new Date();
566
+ if (value) {
567
+ this.minDate = modifyTime(this.minDate, value.getHours(), value.getMinutes(), value.getSeconds());
568
+ }
569
+
570
+ if (!first) {
571
+ this.minTimePickerVisible = visible;
572
+ }
573
+
574
+ if (!this.maxDate || this.maxDate && this.maxDate.getTime() < this.minDate.getTime()) {
575
+ this.maxDate = new Date(this.minDate);
576
+ }
577
+ },
578
+
579
+ handleMinTimeClose() {
580
+ this.minTimePickerVisible = false;
581
+ },
582
+
583
+ handleMaxTimePick(value, visible, first) {
584
+ if (this.maxDate && value) {
585
+ this.maxDate = modifyTime(this.maxDate, value.getHours(), value.getMinutes(), value.getSeconds());
586
+ }
587
+
588
+ if (!first) {
589
+ this.maxTimePickerVisible = visible;
590
+ }
591
+
592
+ if (this.maxDate && this.minDate && this.minDate.getTime() > this.maxDate.getTime()) {
593
+ this.minDate = new Date(this.maxDate);
594
+ }
595
+ },
596
+
597
+ handleMaxTimeClose() {
598
+ this.maxTimePickerVisible = false;
599
+ },
600
+
601
+ // leftPrev*, rightNext* need to take care of `unlinkPanels`
602
+ leftPrevYear() {
603
+ this.leftDate = prevYear(this.leftDate);
604
+ if (!this.unlinkPanels) {
605
+ this.rightDate = nextMonth(this.leftDate);
606
+ }
607
+ },
608
+
609
+ leftPrevMonth() {
610
+ this.leftDate = prevMonth(this.leftDate);
611
+ if (!this.unlinkPanels) {
612
+ this.rightDate = nextMonth(this.leftDate);
613
+ }
614
+ },
615
+
616
+ rightNextYear() {
617
+ if (!this.unlinkPanels) {
618
+ this.leftDate = nextYear(this.leftDate);
619
+ this.rightDate = nextMonth(this.leftDate);
620
+ } else {
621
+ this.rightDate = nextYear(this.rightDate);
622
+ }
623
+ },
624
+
625
+ rightNextMonth() {
626
+ if (!this.unlinkPanels) {
627
+ this.leftDate = nextMonth(this.leftDate);
628
+ this.rightDate = nextMonth(this.leftDate);
629
+ } else {
630
+ this.rightDate = nextMonth(this.rightDate);
631
+ }
632
+ },
633
+
634
+ // leftNext*, rightPrev* are called when `unlinkPanels` is true
635
+ leftNextYear() {
636
+ this.leftDate = nextYear(this.leftDate);
637
+ },
638
+
639
+ leftNextMonth() {
640
+ this.leftDate = nextMonth(this.leftDate);
641
+ },
642
+
643
+ rightPrevYear() {
644
+ this.rightDate = prevYear(this.rightDate);
645
+ },
646
+
647
+ rightPrevMonth() {
648
+ this.rightDate = prevMonth(this.rightDate);
649
+ },
650
+
651
+ handleConfirm(visible = false) {
652
+ if (this.isValidValue([this.minDate, this.maxDate])) {
653
+ this.$emit('pick', [this.minDate, this.maxDate], visible);
654
+ }
655
+ },
656
+
657
+ isValidValue(value) {
658
+ return Array.isArray(value) &&
659
+ value && value[0] && value[1] &&
660
+ isDate(value[0]) && isDate(value[1]) &&
661
+ value[0].getTime() <= value[1].getTime() && (
662
+ typeof this.disabledDate === 'function'
663
+ ? !this.disabledDate(value[0]) && !this.disabledDate(value[1])
664
+ : true
665
+ );
666
+ },
667
+
668
+ resetView() {
669
+ // NOTE: this is a hack to reset {min, max}Date on picker open.
670
+ // TODO: correct way of doing so is to refactor {min, max}Date to be dependent on value and internal selection state
671
+ // an alternative would be resetView whenever picker becomes visible, should also investigate date-panel's resetView
672
+ if (this.minDate && this.maxDate == null) this.rangeState.selecting = false;
673
+ this.minDate = this.value && isDate(this.value[0]) ? new Date(this.value[0]) : null;
674
+ this.maxDate = this.value && isDate(this.value[0]) ? new Date(this.value[1]) : null;
675
+ }
676
+ },
677
+
678
+ components: { TimePicker, DateTable, BaseInput, BaseButton }
679
+ };
680
+ </script>