element3
Version:
A Component Library for Vue3
44 lines (37 loc) • 824 B
JavaScript
import Picker from '../picker'
import DatePanel from '../panel/date'
import DateRangePanel from '../panel/date-range'
import MonthRangePanel from '../panel/month-range'
const getPanel = function (type) {
if (type === 'daterange' || type === 'datetimerange') {
return DateRangePanel
} else if (type === 'monthrange') {
return MonthRangePanel
}
return DatePanel
}
export default {
mixins: [Picker],
name: 'ElDatePicker',
props: {
type: {
type: String,
default: 'date'
},
timeArrowControl: Boolean
},
watch: {
type(type) {
if (this.picker) {
this.unmountPicker()
this.panel = getPanel(type)
this.mountPicker()
} else {
this.panel = getPanel(type)
}
}
},
created() {
this.panel = getPanel(this.type)
}
}