import { PREFIX_CLS } from './Constants' import Select from '../select' import { Group, Button } from '../radio' import PropTypes from '../_util/vue-types' import { initDefaultProps } from '../_util/props-util' const Option = Select.Option export const HeaderProps = { prefixCls: PropTypes.string, locale: PropTypes.any, fullscreen: PropTypes.boolean, yearSelectOffset: PropTypes.number, yearSelectTotal: PropTypes.number, type: PropTypes.string, // onValueChange: PropTypes.(value: moment.Moment) => void, // onTypeChange: PropTypes.(type: string) => void, value: PropTypes.any, validRange: PropTypes.array, } export default { props: initDefaultProps(HeaderProps, { prefixCls: `${PREFIX_CLS}-header`, yearSelectOffset: 10, yearSelectTotal: 20, }), // private calenderHeaderNode: HTMLDivElement; methods: { getYearSelectElement (year) { const { yearSelectOffset, yearSelectTotal, locale, prefixCls, fullscreen, validRange, } = this let start = year - yearSelectOffset let end = start + yearSelectTotal if (validRange) { start = validRange[0].get('year') end = validRange[1].get('year') + 1 } const suffix = locale.year === '年' ? '年' : '' const options = [] for (let index = start; index < end; index++) { options.push() } return ( ) }, getMonthsLocale (value) { const current = value.clone() const localeData = value.localeData() const months = [] for (let i = 0; i < 12; i++) { current.month(i) months.push(localeData.monthsShort(current)) } return months }, getMonthSelectElement (month, months) { const { prefixCls, fullscreen, validRange, value } = this const options = [] let start = 0 let end = 12 if (validRange) { const [rangeStart, rangeEnd] = validRange const currentYear = value.get('year') if (rangeEnd.get('year') === currentYear) { end = rangeEnd.get('month') + 1 } else { start = rangeStart.get('month') } } for (let index = start; index < end; index++) { options.push() } return ( ) }, onYearChange (year) { const { value, validRange } = this const newValue = value.clone() newValue.year(parseInt(year, 10)) // switch the month so that it remains within range when year changes if (validRange) { const [start, end] = validRange const newYear = newValue.get('year') const newMonth = newValue.get('month') if (newYear === end.get('year') && newMonth > end.get('month')) { newValue.month(end.get('month')) } if (newYear === start.get('year') && newMonth < start.get('month')) { newValue.month(start.get('month')) } } this.$emit('valueChange', newValue) }, onMonthChange (month) { const newValue = this.value.clone() newValue.month(parseInt(month, 10)) this.$emit('valueChange', newValue) }, onTypeChange (e) { this.$emit('typeChange', e.target.value) }, getCalenderHeaderNode () { return this.$refs.calenderHeaderNode }, }, render () { const { type, value, prefixCls, locale, fullscreen } = this const yearSelect = this.getYearSelectElement(value.year()) const monthSelect = type === 'date' ? this.getMonthSelectElement(value.month(), this.getMonthsLocale(value)) : null const size = fullscreen ? 'default' : 'small' const typeSwitch = ( ) return (
{yearSelect} {monthSelect} {typeSwitch}
) }, }