import CalendarOutlined from '@ant-design/icons-vue/CalendarOutlined'; import ClockCircleOutlined from '@ant-design/icons-vue/ClockCircleOutlined'; import CloseCircleFilled from '@ant-design/icons-vue/CloseCircleFilled'; import RCPicker from '../../vc-picker'; import type { PanelMode, PickerMode } from '../../vc-picker/interface'; import type { GenerateConfig } from '../../vc-picker/generate/index'; import enUS from '../locale/en_US'; import { getPlaceholder, transPlacement2DropdownAlign } from '../util'; import { useLocaleReceiver } from '../../locale-provider/LocaleReceiver'; import { getTimeProps, Components } from '.'; import { computed, defineComponent, ref } from 'vue'; import useConfigInject from '../../_util/hooks/useConfigInject'; import classNames from '../../_util/classNames'; import type { CommonProps, DatePickerProps } from './props'; import { commonProps, datePickerProps } from './props'; import devWarning from '../../vc-util/devWarning'; import { FormItemInputContext, useInjectFormItemContext } from '../../form/FormItemContext'; import { getMergedStatus, getStatusClassNames } from '../../_util/statusUtils'; export default function generateSinglePicker( generateConfig: GenerateConfig, extraProps: ExtraProps, ) { function getPicker(picker?: PickerMode, displayName?: string) { const comProps = { ...commonProps(), ...datePickerProps(), ...extraProps, }; return defineComponent({ compatConfig: { MODE: 3 }, name: displayName, inheritAttrs: false, props: comProps, slots: [ 'suffixIcon', // 'clearIcon', 'prevIcon', 'nextIcon', 'superPrevIcon', 'superNextIcon', // 'panelRender', 'dateRender', 'renderExtraFooter', 'monthCellRender', ], setup(_props, { slots, expose, attrs, emit }) { // 兼容 vue 3.2.7 const props = _props as unknown as CommonProps & DatePickerProps & ExtraProps; const formItemContext = useInjectFormItemContext(); const formItemInputContext = FormItemInputContext.useInject(); devWarning( !(props.monthCellContentRender || slots.monthCellContentRender), 'DatePicker', '`monthCellContentRender` is deprecated. Please use `monthCellRender"` instead.', ); devWarning( !attrs.getCalendarContainer, 'DatePicker', '`getCalendarContainer` is deprecated. Please use `getPopupContainer"` instead.', ); const { prefixCls, direction, getPopupContainer, size, rootPrefixCls } = useConfigInject( 'picker', props, ); const pickerRef = ref(); expose({ focus: () => { pickerRef.value?.focus(); }, blur: () => { pickerRef.value?.blur(); }, }); const maybeToString = (date: DateType) => { return props.valueFormat ? generateConfig.toString(date, props.valueFormat) : date; }; const onChange = (date: DateType, dateString: string) => { const value = maybeToString(date); emit('update:value', value); emit('change', value, dateString); formItemContext.onFieldChange(); }; const onOpenChange = (open: boolean) => { emit('update:open', open); emit('openChange', open); }; const onFocus = (e: FocusEvent) => { emit('focus', e); }; const onBlur = (e: FocusEvent) => { emit('blur', e); formItemContext.onFieldBlur(); }; const onPanelChange = (date: DateType, mode: PanelMode | null) => { const value = maybeToString(date); emit('panelChange', value, mode); }; const onOk = (date: DateType) => { const value = maybeToString(date); emit('ok', value); }; const [contextLocale] = useLocaleReceiver('DatePicker', enUS); const value = computed(() => { if (props.value) { return props.valueFormat ? generateConfig.toDate(props.value as string | DateType, props.valueFormat) : props.value; } return (props.value === '' ? undefined : props.value) as DateType; }); const defaultValue = computed(() => { if (props.defaultValue) { return props.valueFormat ? generateConfig.toDate(props.defaultValue as string | DateType, props.valueFormat) : props.defaultValue; } return (props.defaultValue === '' ? undefined : props.defaultValue) as DateType; }); const defaultPickerValue = computed(() => { if (props.defaultPickerValue) { return props.valueFormat ? generateConfig.toDate( props.defaultPickerValue as string | DateType, props.valueFormat, ) : props.defaultPickerValue; } return ( props.defaultPickerValue === '' ? undefined : props.defaultPickerValue ) as DateType; }); return () => { const locale = { ...contextLocale.value, ...props.locale }; const p = { ...props, ...attrs }; const { bordered = true, placeholder, suffixIcon = slots.suffixIcon?.(), showToday = true, transitionName, allowClear = true, dateRender = slots.dateRender, renderExtraFooter = slots.renderExtraFooter, monthCellRender = slots.monthCellRender || (props as any).monthCellContentRender || slots.monthCellContentRender, clearIcon = slots.clearIcon?.(), id = formItemContext.id.value, ...restProps } = p; const showTime = p.showTime === '' ? true : p.showTime; const { format } = p as any; let additionalOverrideProps: any = {}; if (picker) { additionalOverrideProps.picker = picker; } const mergedPicker = picker || p.picker || 'date'; additionalOverrideProps = { ...additionalOverrideProps, ...(showTime ? getTimeProps({ format, picker: mergedPicker, ...(typeof showTime === 'object' ? showTime : {}), }) : {}), ...(mergedPicker === 'time' ? getTimeProps({ format, ...restProps, picker: mergedPicker }) : {}), }; const pre = prefixCls.value; const suffixNode = ( <> {suffixIcon || (picker === 'time' ? : )} {formItemInputContext.hasFeedback && formItemInputContext.feedbackIcon} ); return ( } allowClear={allowClear} transitionName={transitionName || `${rootPrefixCls.value}-slide-up`} {...restProps} {...additionalOverrideProps} id={id} picker={mergedPicker} value={value.value} defaultValue={defaultValue.value} defaultPickerValue={defaultPickerValue.value} showToday={showToday} locale={locale!.lang} class={classNames( { [`${pre}-${size.value}`]: size.value, [`${pre}-borderless`]: !bordered, }, getStatusClassNames( pre, getMergedStatus(formItemInputContext.status, props.status), formItemInputContext.hasFeedback, ), attrs.class, )} prefixCls={pre} getPopupContainer={attrs.getCalendarContainer || getPopupContainer.value} generateConfig={generateConfig} prevIcon={slots.prevIcon?.() || } nextIcon={slots.nextIcon?.() || } superPrevIcon={slots.superPrevIcon?.() || } superNextIcon={slots.superNextIcon?.() || } components={Components} direction={direction.value} onChange={onChange} onOpenChange={onOpenChange} onFocus={onFocus} onBlur={onBlur} onPanelChange={onPanelChange} onOk={onOk} /> ); }; }, }); } const DatePicker = getPicker(undefined, 'ADatePicker'); const WeekPicker = getPicker('week', 'AWeekPicker'); const MonthPicker = getPicker('month', 'AMonthPicker'); const YearPicker = getPicker('year', 'AYearPicker'); const TimePicker = getPicker('time', 'TimePicker'); // 给独立组件 TimePicker 使用,此处名称不用更改 const QuarterPicker = getPicker('quarter', 'AQuarterPicker'); return { DatePicker, WeekPicker, MonthPicker, YearPicker, TimePicker, QuarterPicker, }; }