wupengfei
5 天以前 600a0319374e7ff53f801777d3dca25951cac1ca
packages/components/src/Input/ChooseInputWithDatePicker.vue
@@ -16,16 +16,22 @@
type Props = {
  modelValue: string | number;
  minDate?: Date;
  maxDate?: Date;
  type?: string;
  format?: string;
};
const props = withDefaults(defineProps<Props>(), {});
const props = withDefaults(defineProps<Props>(), {
  format: 'YYYY-MM-DD',
});
const emit = defineEmits<{
  (e: 'update:modelValue', val: string | number): void;
  (e: 'change'): void;
}>();
function handleOpen() {
  const _modelValue = [props.modelValue];
  const _modelValue = dayjs(props.modelValue).toDate();
  Portal.add((key) => {
    return h(
      Portal.Container,
@@ -44,10 +50,15 @@
                h(DatePicker, {
                  modelValue: _modelValue,
                  onCancel: onClose,
                  type: props.type,
                  maxDate: props.maxDate,
                  onConfirm: ({ selectedValue }) => {
                    emit('update:modelValue', dayjs(selectedValue.join('-')).format('YYYY-MM-DD'));
                    emit('update:modelValue', dayjs(selectedValue.join('-')).format(props.format));
                    onClose();
                  },
                  onChange: () => {
                    emit('change');
                  },
                  minDate: props.minDate,
                }),
            }