meixioacomponent 1.1.49 → 2.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 (107) hide show
  1. package/lib/components/index.d.ts +1 -1
  2. package/lib/components/index.d.ts.map +1 -1
  3. package/lib/components/index.js +3 -3
  4. package/lib/config/use/UseImg.d.ts.map +1 -1
  5. package/lib/config/use/UseImg.js +1 -0
  6. package/lib/meixioacomponent.common.js +17531 -38668
  7. package/lib/meixioacomponent.umd.js +17584 -38721
  8. package/lib/meixioacomponent.umd.min.js +6 -159
  9. package/lib/style/font-family.less +2 -1
  10. package/lib/style/index.less +9 -2
  11. package/lib/style/meixioacomponenticonfont/TCloudNumberVF.ttf +0 -0
  12. package/lib/style/tableStyle.less +15 -13
  13. package/lib/style/tdesignStyle.less +9 -0
  14. package/lib/style/variables.less +1 -1
  15. package/package.json +3 -3
  16. package/packages/components/base/baseAppendix/baseAppendix.vue +12 -11
  17. package/packages/components/base/baseArea/baseArea.vue +49 -54
  18. package/packages/components/base/baseAvatar/baseAvatar.vue +16 -14
  19. package/packages/components/base/baseButton/baseButton.vue +80 -0
  20. package/packages/components/base/baseButton/index.js +6 -0
  21. package/packages/components/base/baseButtonHandle/baseButtonHandle.vue +36 -4
  22. package/packages/components/base/baseDialog/index.vue +131 -102
  23. package/packages/components/base/baseDialogTable/dialogTable.vue +1 -0
  24. package/packages/components/base/baseDrawer/index.vue +119 -89
  25. package/packages/components/base/baseEdito/baseEdito.vue +56 -50
  26. package/packages/components/base/baseFixedHeader/baseFixedHeader.vue +44 -37
  27. package/packages/components/base/baseImageViewer/image-viewer.vue +29 -311
  28. package/packages/components/base/baseImg/baseImg.vue +8 -7
  29. package/packages/components/base/baseInforWrap/baseInforWrap.vue +14 -7
  30. package/packages/components/base/baseLineInfoItem/baseLineInfoItem.vue +4 -4
  31. package/packages/components/base/baseList/index.vue +10 -23
  32. package/packages/components/base/baseMoverVerifiBar/baseMoverVerifiBar.vue +7 -13
  33. package/packages/components/base/baseNumberInput/index.vue +42 -158
  34. package/packages/components/base/basePagination/index.vue +24 -31
  35. package/packages/components/base/basePlainTable/basePlainTable.vue +89 -183
  36. package/packages/components/base/basePopoverButton/index.vue +45 -36
  37. package/packages/components/base/baseSection/baseSection.vue +17 -8
  38. package/packages/components/base/baseSingleImgUpload/index.vue +2 -2
  39. package/packages/components/base/baseSkeleton/baseSkeleton.vue +0 -1
  40. package/packages/components/base/baseStoreSelect/index.vue +48 -64
  41. package/packages/components/base/baseTag/index.vue +12 -96
  42. package/packages/components/base/baseText/index.vue +66 -79
  43. package/packages/components/base/baseTimeLine/baseTimeLineLeft.vue +1 -1
  44. package/packages/components/base/baseTimeLine/baseTimeLineRight.vue +1 -1
  45. package/packages/components/base/baseTimeTypeSelect/base_time_type_select.vue +73 -78
  46. package/packages/components/base/baseToggle/toggle.vue +28 -48
  47. package/packages/components/base/baseTreeSelect/index.vue +20 -147
  48. package/packages/components/base/baseUpload/baseUploadItem.vue +74 -77
  49. package/packages/components/base/baseUpload/mixins.js +0 -1
  50. package/packages/components/base/baseUpload/uploadMediaView.vue +14 -13
  51. package/packages/components/base/baseUploadImgAndName/index.vue +28 -11
  52. package/packages/components/base/baseUploadTemplate/index.vue +27 -11
  53. package/packages/components/base/baseVideo/index.vue +9 -7
  54. package/packages/components/base/upload/upload.vue +17 -14
  55. package/packages/components/base/upload/uploadItem.vue +40 -46
  56. package/packages/components/dialogCache/index.vue +30 -24
  57. package/packages/components/index.js +3 -3
  58. package/packages/components/index.ts +4 -3
  59. package/packages/components/mixins/tableSectionMixins.js +0 -12
  60. package/packages/components/proForm/dialogForm/baseDialogForm.vue +17 -14
  61. package/packages/components/proForm/proForm/proFormItem/pro_form_item.vue +95 -79
  62. package/packages/components/proForm/proForm/pro_form.vue +47 -52
  63. package/packages/components/proPageTable/oaProTableSearch/oa_pro-table-search.vue +2 -2
  64. package/packages/components/proPageTable/oaProTableSearch/oa_pro_screen.vue +19 -10
  65. package/packages/components/proPageTable/oaProTableSearch/oa_pro_screen_item.vue +28 -27
  66. package/packages/components/proPageTable/oa_pro_colum_config.vue +8 -10
  67. package/packages/components/proPageTable/oa_pro_footer.vue +15 -15
  68. package/packages/components/proPageTable/oa_pro_table-header.vue +19 -31
  69. package/packages/components/proPageTable/oa_pro_table.vue +208 -284
  70. package/packages/components/proPageTable/oa_pro_table_check_handle_bar.vue +28 -16
  71. package/packages/components/searchHeader/searchHeader.vue +16 -17
  72. package/packages/components/style/font-family.less +2 -1
  73. package/packages/components/style/index.less +9 -2
  74. package/packages/components/style/meixioacomponenticonfont/TCloudNumberVF.ttf +0 -0
  75. package/packages/components/style/tableStyle.less +15 -13
  76. package/packages/components/style/tdesignStyle.less +9 -0
  77. package/packages/components/style/variables.less +1 -1
  78. package/packages/config/use/UseImg.js +1 -0
  79. package/packages/config/use/UseImg.ts +1 -0
  80. package/packages/utils/upload.js +61 -72
  81. package/packages/utils/utils.js +316 -276
  82. package/lib/fonts/element-icons.f1a45d74.ttf +0 -0
  83. package/lib/fonts/element-icons.ff18efd1.woff +0 -0
  84. package/lib/style/element/common_class.less +0 -3
  85. package/lib/style/element/fonts/element-icons.ttf +0 -0
  86. package/lib/style/element/fonts/element-icons.woff +0 -0
  87. package/lib/style/element/index.css +0 -30219
  88. package/packages/components/base/elDatePicker/basic/date-table.vue +0 -441
  89. package/packages/components/base/elDatePicker/basic/month-table.vue +0 -269
  90. package/packages/components/base/elDatePicker/basic/time-spinner.vue +0 -304
  91. package/packages/components/base/elDatePicker/basic/year-table.vue +0 -111
  92. package/packages/components/base/elDatePicker/index.js +0 -6
  93. package/packages/components/base/elDatePicker/index.vue +0 -28
  94. package/packages/components/base/elDatePicker/panel/date-range.vue +0 -680
  95. package/packages/components/base/elDatePicker/panel/date.vue +0 -609
  96. package/packages/components/base/elDatePicker/panel/month-range.vue +0 -289
  97. package/packages/components/base/elDatePicker/panel/time-range.vue +0 -248
  98. package/packages/components/base/elDatePicker/panel/time-select.vue +0 -178
  99. package/packages/components/base/elDatePicker/panel/time.vue +0 -186
  100. package/packages/components/base/elDatePicker/picker/date-picker.js +0 -55
  101. package/packages/components/base/elDatePicker/picker/time-picker.js +0 -39
  102. package/packages/components/base/elDatePicker/picker/time-select.js +0 -21
  103. package/packages/components/base/elDatePicker/picker.vue +0 -956
  104. package/packages/components/style/element/common_class.less +0 -3
  105. package/packages/components/style/element/fonts/element-icons.ttf +0 -0
  106. package/packages/components/style/element/fonts/element-icons.woff +0 -0
  107. package/packages/components/style/element/index.css +0 -30219
@@ -1,680 +0,0 @@
1
- <template>
2
- <transition name="el-zoom-in-top" @after-leave="$emit('dodestroy')">
3
- <div
4
- v-show="visible"
5
- class="el-picker-panel el-date-range-picker el-popper"
6
- :class="[{
7
- 'has-sidebar': $slots.sidebar || shortcuts,
8
- 'has-time': showTime
9
- }, popperClass]">
10
- <div class="el-picker-panel__body-wrapper">
11
- <slot name="sidebar" class="el-picker-panel__sidebar"></slot>
12
- <div class="el-picker-panel__sidebar" v-if="shortcuts">
13
- <button
14
- type="button"
15
- class="el-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="el-picker-panel__body">
21
- <div class="el-date-range-picker__time-header" v-if="showTime">
22
- <span class="el-date-range-picker__editors-wrap">
23
- <span class="el-date-range-picker__time-picker-wrap">
24
- <el-input
25
- size="small"
26
- :disabled="rangeState.selecting"
27
- ref="minInput"
28
- :placeholder="t('el.datepicker.startDate')"
29
- class="el-date-range-picker__editor"
30
- :value="minVisibleDate"
31
- @input="val => handleDateInput(val, 'min')"
32
- @change="val => handleDateChange(val, 'min')" />
33
- </span>
34
- <span class="el-date-range-picker__time-picker-wrap" v-clickoutside="handleMinTimeClose">
35
- <el-input
36
- size="small"
37
- class="el-date-range-picker__editor"
38
- :disabled="rangeState.selecting"
39
- :placeholder="t('el.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="el-icon-arrow-right"></span>
54
- <span class="el-date-range-picker__editors-wrap is-right">
55
- <span class="el-date-range-picker__time-picker-wrap">
56
- <el-input
57
- size="small"
58
- class="el-date-range-picker__editor"
59
- :disabled="rangeState.selecting"
60
- :placeholder="t('el.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="el-date-range-picker__time-picker-wrap" v-clickoutside="handleMaxTimeClose">
67
- <el-input
68
- size="small"
69
- class="el-date-range-picker__editor"
70
- :disabled="rangeState.selecting"
71
- :placeholder="t('el.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="el-picker-panel__content el-date-range-picker__content is-left">
88
- <div class="el-date-range-picker__header">
89
- <button
90
- type="button"
91
- @click="leftPrevYear"
92
- class="el-picker-panel__icon-btn el-icon-d-arrow-left"></button>
93
- <button
94
- type="button"
95
- @click="leftPrevMonth"
96
- class="el-picker-panel__icon-btn el-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="el-picker-panel__icon-btn el-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="el-picker-panel__icon-btn el-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="el-picker-panel__content el-date-range-picker__content is-right">
128
- <div class="el-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="el-picker-panel__icon-btn el-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="el-picker-panel__icon-btn el-icon-arrow-left"></button>
143
- <button
144
- type="button"
145
- @click="rightNextYear"
146
- class="el-picker-panel__icon-btn el-icon-d-arrow-right"></button>
147
- <button
148
- type="button"
149
- @click="rightNextMonth"
150
- class="el-picker-panel__icon-btn el-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="el-picker-panel__footer" v-if="showTime">
170
- <el-button
171
- size="mini"
172
- type="text"
173
- class="el-picker-panel__link-btn"
174
- @click="handleClear">
175
- {{ t('el.datepicker.clear') }}
176
- </el-button>
177
- <el-button
178
- plain
179
- size="mini"
180
- class="el-picker-panel__link-btn"
181
- :disabled="btnDisabled"
182
- @click="handleConfirm(false)">
183
- {{ t('el.datepicker.confirm') }}
184
- </el-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 'element-ui/src/utils/date-util';
206
- import Clickoutside from 'element-ui/src/utils/clickoutside';
207
- import Locale from 'element-ui/src/mixins/locale';
208
- import TimePicker from './time';
209
- import DateTable from '../basic/date-table';
210
- import ElInput from 'element-ui/packages/input';
211
- import ElButton from 'element-ui/packages/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('el.datepicker.year') + ' ' + this.t(`el.datepicker.month${ this.leftDate.getMonth() + 1 }`);
235
- },
236
-
237
- rightLabel() {
238
- return this.rightDate.getFullYear() + ' ' + this.t('el.datepicker.year') + ' ' + this.t(`el.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, ElInput, ElButton }
679
- };
680
- </script>