ant-design-vue
Version:
An enterprise-class UI design language and Vue-based implementation
206 lines • 10.7 kB
JavaScript
import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
import _objectSpread from "@babel/runtime/helpers/esm/objectSpread2";
var _excluded = ["prefixCls", "bordered", "placeholder", "suffixIcon", "picker", "transitionName", "allowClear", "dateRender", "renderExtraFooter", "separator", "clearIcon", "id"];
import { createVNode as _createVNode } from "vue";
import CalendarOutlined from "@ant-design/icons-vue/es/icons/CalendarOutlined";
import ClockCircleOutlined from "@ant-design/icons-vue/es/icons/ClockCircleOutlined";
import CloseCircleFilled from "@ant-design/icons-vue/es/icons/CloseCircleFilled";
import SwapRightOutlined from "@ant-design/icons-vue/es/icons/SwapRightOutlined";
import { RangePicker as VCRangePicker } from '../../vc-picker';
import enUS from '../locale/en_US';
import { useLocaleReceiver } from '../../locale-provider/LocaleReceiver';
import { getRangePlaceholder } from '../util';
import { getTimeProps, Components } from '.';
import { computed, defineComponent, ref } from 'vue';
import useConfigInject from '../../_util/hooks/useConfigInject';
import classNames from '../../_util/classNames';
import { commonProps, rangePickerProps } from './props';
import devWarning from '../../vc-util/devWarning';
import { useInjectFormItemContext } from '../../form/FormItemContext';
import omit from '../../_util/omit';
export default function generateRangePicker(generateConfig, extraProps) {
var RangePicker = defineComponent({
compatConfig: {
MODE: 3
},
name: 'ARangePicker',
inheritAttrs: false,
props: _objectSpread(_objectSpread(_objectSpread({}, commonProps()), rangePickerProps()), extraProps),
slots: ['suffixIcon',
// 'clearIcon',
'prevIcon', 'nextIcon', 'superPrevIcon', 'superNextIcon',
// 'panelRender',
'dateRender', 'renderExtraFooter'
// 'separator',
],
setup: function setup(_props, _ref) {
var expose = _ref.expose,
slots = _ref.slots,
attrs = _ref.attrs,
emit = _ref.emit;
var props = _props;
var formItemContext = useInjectFormItemContext();
devWarning(!attrs.getCalendarContainer, 'DatePicker', '`getCalendarContainer` is deprecated. Please use `getPopupContainer"` instead.');
var _useConfigInject = useConfigInject('picker', props),
prefixCls = _useConfigInject.prefixCls,
direction = _useConfigInject.direction,
getPopupContainer = _useConfigInject.getPopupContainer,
size = _useConfigInject.size,
rootPrefixCls = _useConfigInject.rootPrefixCls;
var pickerRef = ref();
expose({
focus: function focus() {
var _pickerRef$value;
(_pickerRef$value = pickerRef.value) === null || _pickerRef$value === void 0 ? void 0 : _pickerRef$value.focus();
},
blur: function blur() {
var _pickerRef$value2;
(_pickerRef$value2 = pickerRef.value) === null || _pickerRef$value2 === void 0 ? void 0 : _pickerRef$value2.blur();
}
});
var maybeToStrings = function maybeToStrings(dates) {
return props.valueFormat ? generateConfig.toString(dates, props.valueFormat) : dates;
};
var onChange = function onChange(dates, dateStrings) {
var values = maybeToStrings(dates);
emit('update:value', values);
emit('change', values, dateStrings);
formItemContext.onFieldChange();
};
var onOpenChange = function onOpenChange(open) {
emit('update:open', open);
emit('openChange', open);
};
var onFocus = function onFocus(e) {
emit('focus', e);
};
var onBlur = function onBlur(e) {
emit('blur', e);
formItemContext.onFieldBlur();
};
var onPanelChange = function onPanelChange(dates, modes) {
var values = maybeToStrings(dates);
emit('panelChange', values, modes);
};
var onOk = function onOk(dates) {
var value = maybeToStrings(dates);
emit('ok', value);
};
var onCalendarChange = function onCalendarChange(dates, dateStrings, info) {
var values = maybeToStrings(dates);
emit('calendarChange', values, dateStrings, info);
};
var _useLocaleReceiver = useLocaleReceiver('DatePicker', enUS),
_useLocaleReceiver2 = _slicedToArray(_useLocaleReceiver, 1),
contextLocale = _useLocaleReceiver2[0];
var value = computed(function () {
if (props.value) {
return props.valueFormat ? generateConfig.toDate(props.value, props.valueFormat) : props.value;
}
return props.value;
});
var defaultValue = computed(function () {
if (props.defaultValue) {
return props.valueFormat ? generateConfig.toDate(props.defaultValue, props.valueFormat) : props.defaultValue;
}
return props.defaultValue;
});
var defaultPickerValue = computed(function () {
if (props.defaultPickerValue) {
return props.valueFormat ? generateConfig.toDate(props.defaultPickerValue, props.valueFormat) : props.defaultPickerValue;
}
return props.defaultPickerValue;
});
return function () {
var _slots$suffixIcon, _slots$separator, _slots$clearIcon, _classNames, _slots$prevIcon, _slots$nextIcon, _slots$superPrevIcon, _slots$superNextIcon;
var locale = _objectSpread(_objectSpread({}, contextLocale.value), props.locale);
var p = _objectSpread(_objectSpread({}, props), attrs);
var customizePrefixCls = p.prefixCls,
_p$bordered = p.bordered,
bordered = _p$bordered === void 0 ? true : _p$bordered,
placeholder = p.placeholder,
_p$suffixIcon = p.suffixIcon,
suffixIcon = _p$suffixIcon === void 0 ? (_slots$suffixIcon = slots.suffixIcon) === null || _slots$suffixIcon === void 0 ? void 0 : _slots$suffixIcon.call(slots) : _p$suffixIcon,
_p$picker = p.picker,
picker = _p$picker === void 0 ? 'date' : _p$picker,
transitionName = p.transitionName,
_p$allowClear = p.allowClear,
allowClear = _p$allowClear === void 0 ? true : _p$allowClear,
_p$dateRender = p.dateRender,
dateRender = _p$dateRender === void 0 ? slots.dateRender : _p$dateRender,
_p$renderExtraFooter = p.renderExtraFooter,
renderExtraFooter = _p$renderExtraFooter === void 0 ? slots.renderExtraFooter : _p$renderExtraFooter,
_p$separator = p.separator,
separator = _p$separator === void 0 ? (_slots$separator = slots.separator) === null || _slots$separator === void 0 ? void 0 : _slots$separator.call(slots) : _p$separator,
_p$clearIcon = p.clearIcon,
clearIcon = _p$clearIcon === void 0 ? (_slots$clearIcon = slots.clearIcon) === null || _slots$clearIcon === void 0 ? void 0 : _slots$clearIcon.call(slots) : _p$clearIcon,
_p$id = p.id,
id = _p$id === void 0 ? formItemContext.id.value : _p$id,
restProps = _objectWithoutProperties(p, _excluded);
delete restProps['onUpdate:value'];
delete restProps['onUpdate:open'];
var format = p.format,
showTime = p.showTime;
var additionalOverrideProps = {};
additionalOverrideProps = _objectSpread(_objectSpread(_objectSpread({}, additionalOverrideProps), showTime ? getTimeProps(_objectSpread({
format: format,
picker: picker
}, showTime)) : {}), picker === 'time' ? getTimeProps(_objectSpread(_objectSpread({
format: format
}, omit(restProps, ['disabledTime'])), {}, {
picker: picker
})) : {});
var pre = prefixCls.value;
return _createVNode(VCRangePicker, _objectSpread(_objectSpread(_objectSpread({
"dateRender": dateRender,
"renderExtraFooter": renderExtraFooter,
"separator": separator || _createVNode("span", {
"aria-label": "to",
"class": "".concat(pre, "-separator")
}, [_createVNode(SwapRightOutlined, null, null)]),
"ref": pickerRef,
"placeholder": getRangePlaceholder(picker, locale, placeholder),
"suffixIcon": suffixIcon || (picker === 'time' ? _createVNode(ClockCircleOutlined, null, null) : _createVNode(CalendarOutlined, null, null)),
"clearIcon": clearIcon || _createVNode(CloseCircleFilled, null, null),
"allowClear": allowClear,
"transitionName": transitionName || "".concat(rootPrefixCls.value, "-slide-up")
}, restProps), additionalOverrideProps), {}, {
"id": id,
"value": value.value,
"defaultValue": defaultValue.value,
"defaultPickerValue": defaultPickerValue.value,
"picker": picker,
"class": classNames((_classNames = {}, _defineProperty(_classNames, "".concat(pre, "-").concat(size.value), size.value), _defineProperty(_classNames, "".concat(pre, "-borderless"), !bordered), _classNames), attrs.class),
"locale": locale.lang,
"prefixCls": pre,
"getPopupContainer": attrs.getCalendarContainer || getPopupContainer.value,
"generateConfig": generateConfig,
"prevIcon": ((_slots$prevIcon = slots.prevIcon) === null || _slots$prevIcon === void 0 ? void 0 : _slots$prevIcon.call(slots)) || _createVNode("span", {
"class": "".concat(pre, "-prev-icon")
}, null),
"nextIcon": ((_slots$nextIcon = slots.nextIcon) === null || _slots$nextIcon === void 0 ? void 0 : _slots$nextIcon.call(slots)) || _createVNode("span", {
"class": "".concat(pre, "-next-icon")
}, null),
"superPrevIcon": ((_slots$superPrevIcon = slots.superPrevIcon) === null || _slots$superPrevIcon === void 0 ? void 0 : _slots$superPrevIcon.call(slots)) || _createVNode("span", {
"class": "".concat(pre, "-super-prev-icon")
}, null),
"superNextIcon": ((_slots$superNextIcon = slots.superNextIcon) === null || _slots$superNextIcon === void 0 ? void 0 : _slots$superNextIcon.call(slots)) || _createVNode("span", {
"class": "".concat(pre, "-super-next-icon")
}, null),
"components": Components,
"direction": direction.value,
"onChange": onChange,
"onOpenChange": onOpenChange,
"onFocus": onFocus,
"onBlur": onBlur,
"onPanelChange": onPanelChange,
"onOk": onOk,
"onCalendarChange": onCalendarChange
}), null);
};
}
});
return RangePicker;
}