import { inject } from 'vue'; import * as moment from 'moment'; import Calendar from '../vc-calendar'; import VcDatePicker from '../vc-calendar/src/Picker'; import CloseCircleFilled from '@ant-design/icons-vue/CloseCircleFilled'; import { ConfigConsumerProps } from '../config-provider'; import { hasProp, getOptionProps, initDefaultProps, getComponent } from '../_util/props-util'; import classNames from 'classnames'; import BaseMixin from '../_util/BaseMixin'; import { WeekPickerProps } from './interface'; import interopDefault from '../_util/interopDefault'; import InputIcon from './InputIcon'; import { getDataAndAriaProps } from '../_util/util'; function formatValue(value, format) { return (value && value.format(format)) || ''; } function noop() {} export default { name: 'AWeekPicker', mixins: [BaseMixin], inheritAttrs: false, props: initDefaultProps(WeekPickerProps(), { format: 'gggg-wo', allowClear: true, }), setup() { return { configProvider: inject('configProvider', ConfigConsumerProps), }; }, data() { const value = this.value || this.defaultValue; if (value && !interopDefault(moment).isMoment(value)) { throw new Error( 'The value/defaultValue of WeekPicker or MonthPicker must be ' + 'a moment object', ); } return { _value: value, _open: this.open, }; }, watch: { value(val) { const state = { _value: val }; this.setState(state); this.prevState = { ...this.$data, ...state }; }, open(val) { const state = { _open: val }; this.setState(state); this.prevState = { ...this.$data, ...state }; }, _open(val, oldVal) { this.$nextTick(() => { if (!hasProp(this, 'open') && oldVal && !val) { this.focus(); } }); }, }, mounted() { this.prevState = { ...this.$data }; }, updated() { this.$nextTick(() => { if (!hasProp(this, 'open') && this.prevState._open && !this._open) { this.focus(); } }); }, methods: { saveInput(node) { this.input = node; }, weekDateRender({ current }) { const selectedValue = this.$data._value; const { _prefixCls: prefixCls, $slots } = this; const dateRender = this.dateRender || $slots.dateRender; const dateNode = dateRender ? dateRender({ current }) : current.date(); if ( selectedValue && current.year() === selectedValue.year() && current.week() === selectedValue.week() ) { return (