ant-design-vue
Version:
An enterprise-class UI design language and Vue-based implementation
221 lines (220 loc) • 12.6 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = generateSinglePicker;
var _vue = require("vue");
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
var _CalendarOutlined = _interopRequireDefault(require("@ant-design/icons-vue/lib/icons/CalendarOutlined"));
var _ClockCircleOutlined = _interopRequireDefault(require("@ant-design/icons-vue/lib/icons/ClockCircleOutlined"));
var _CloseCircleFilled = _interopRequireDefault(require("@ant-design/icons-vue/lib/icons/CloseCircleFilled"));
var _vcPicker = _interopRequireDefault(require("../../vc-picker"));
var _en_US = _interopRequireDefault(require("../locale/en_US"));
var _util = require("../util");
var _LocaleReceiver = require("../../locale-provider/LocaleReceiver");
var _ = require(".");
var _useConfigInject2 = _interopRequireDefault(require("../../_util/hooks/useConfigInject"));
var _classNames2 = _interopRequireDefault(require("../../_util/classNames"));
var _props2 = require("./props");
var _devWarning = _interopRequireDefault(require("../../vc-util/devWarning"));
var _FormItemContext = require("../../form/FormItemContext");
var _excluded = ["bordered", "placeholder", "suffixIcon", "showToday", "transitionName", "allowClear", "dateRender", "renderExtraFooter", "monthCellRender", "clearIcon", "id"];
function generateSinglePicker(generateConfig, extraProps) {
function getPicker(picker, displayName) {
var comProps = (0, _objectSpread2.default)((0, _objectSpread2.default)((0, _objectSpread2.default)({}, (0, _props2.commonProps)()), (0, _props2.datePickerProps)()), extraProps);
return (0, _vue.defineComponent)({
compatConfig: {
MODE: 3
},
name: displayName,
inheritAttrs: false,
props: comProps,
slots: ['suffixIcon',
// 'clearIcon',
'prevIcon', 'nextIcon', 'superPrevIcon', 'superNextIcon',
// 'panelRender',
'dateRender', 'renderExtraFooter', 'monthCellRender'],
setup: function setup(_props, _ref) {
var slots = _ref.slots,
expose = _ref.expose,
attrs = _ref.attrs,
emit = _ref.emit;
// 兼容 vue 3.2.7
var props = _props;
var formItemContext = (0, _FormItemContext.useInjectFormItemContext)();
(0, _devWarning.default)(!(props.monthCellContentRender || slots.monthCellContentRender), 'DatePicker', '`monthCellContentRender` is deprecated. Please use `monthCellRender"` instead.');
(0, _devWarning.default)(!attrs.getCalendarContainer, 'DatePicker', '`getCalendarContainer` is deprecated. Please use `getPopupContainer"` instead.');
var _useConfigInject = (0, _useConfigInject2.default)('picker', props),
prefixCls = _useConfigInject.prefixCls,
direction = _useConfigInject.direction,
getPopupContainer = _useConfigInject.getPopupContainer,
size = _useConfigInject.size,
rootPrefixCls = _useConfigInject.rootPrefixCls;
var pickerRef = (0, _vue.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 maybeToString = function maybeToString(date) {
return props.valueFormat ? generateConfig.toString(date, props.valueFormat) : date;
};
var onChange = function onChange(date, dateString) {
var value = maybeToString(date);
emit('update:value', value);
emit('change', value, dateString);
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(date, mode) {
var value = maybeToString(date);
emit('panelChange', value, mode);
};
var onOk = function onOk(date) {
var value = maybeToString(date);
emit('ok', value);
};
var _useLocaleReceiver = (0, _LocaleReceiver.useLocaleReceiver)('DatePicker', _en_US.default),
_useLocaleReceiver2 = (0, _slicedToArray2.default)(_useLocaleReceiver, 1),
contextLocale = _useLocaleReceiver2[0];
var value = (0, _vue.computed)(function () {
if (props.value) {
return props.valueFormat ? generateConfig.toDate(props.value, props.valueFormat) : props.value;
}
return props.value === '' ? undefined : props.value;
});
var defaultValue = (0, _vue.computed)(function () {
if (props.defaultValue) {
return props.valueFormat ? generateConfig.toDate(props.defaultValue, props.valueFormat) : props.defaultValue;
}
return props.defaultValue === '' ? undefined : props.defaultValue;
});
var defaultPickerValue = (0, _vue.computed)(function () {
if (props.defaultPickerValue) {
return props.valueFormat ? generateConfig.toDate(props.defaultPickerValue, props.valueFormat) : props.defaultPickerValue;
}
return props.defaultPickerValue === '' ? undefined : props.defaultPickerValue;
});
return function () {
var _slots$suffixIcon, _slots$clearIcon, _classNames, _slots$prevIcon, _slots$nextIcon, _slots$superPrevIcon, _slots$superNextIcon;
var locale = (0, _objectSpread2.default)((0, _objectSpread2.default)({}, contextLocale.value), props.locale);
var p = (0, _objectSpread2.default)((0, _objectSpread2.default)({}, props), attrs);
var _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$showToday = p.showToday,
showToday = _p$showToday === void 0 ? true : _p$showToday,
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$monthCellRender = p.monthCellRender,
monthCellRender = _p$monthCellRender === void 0 ? slots.monthCellRender || props.monthCellContentRender || slots.monthCellContentRender : _p$monthCellRender,
_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 = (0, _objectWithoutProperties2.default)(p, _excluded);
var showTime = p.showTime === '' ? true : p.showTime;
var format = p.format;
var additionalOverrideProps = {};
if (picker) {
additionalOverrideProps.picker = picker;
}
var mergedPicker = picker || p.picker || 'date';
additionalOverrideProps = (0, _objectSpread2.default)((0, _objectSpread2.default)((0, _objectSpread2.default)({}, additionalOverrideProps), showTime ? (0, _.getTimeProps)((0, _objectSpread2.default)({
format: format,
picker: mergedPicker
}, (0, _typeof2.default)(showTime) === 'object' ? showTime : {})) : {}), mergedPicker === 'time' ? (0, _.getTimeProps)((0, _objectSpread2.default)((0, _objectSpread2.default)({
format: format
}, restProps), {}, {
picker: mergedPicker
})) : {});
var pre = prefixCls.value;
return (0, _vue.createVNode)(_vcPicker.default, (0, _objectSpread2.default)((0, _objectSpread2.default)((0, _objectSpread2.default)({
"monthCellRender": monthCellRender,
"dateRender": dateRender,
"renderExtraFooter": renderExtraFooter,
"ref": pickerRef,
"placeholder": (0, _util.getPlaceholder)(mergedPicker, locale, placeholder),
"suffixIcon": suffixIcon || (mergedPicker === 'time' ? (0, _vue.createVNode)(_ClockCircleOutlined.default, null, null) : (0, _vue.createVNode)(_CalendarOutlined.default, null, null)),
"clearIcon": clearIcon || (0, _vue.createVNode)(_CloseCircleFilled.default, null, null),
"allowClear": allowClear,
"transitionName": transitionName || "".concat(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": (0, _classNames2.default)((_classNames = {}, (0, _defineProperty2.default)(_classNames, "".concat(pre, "-").concat(size.value), size.value), (0, _defineProperty2.default)(_classNames, "".concat(pre, "-borderless"), !bordered), _classNames), attrs.class),
"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)) || (0, _vue.createVNode)("span", {
"class": "".concat(pre, "-prev-icon")
}, null),
"nextIcon": ((_slots$nextIcon = slots.nextIcon) === null || _slots$nextIcon === void 0 ? void 0 : _slots$nextIcon.call(slots)) || (0, _vue.createVNode)("span", {
"class": "".concat(pre, "-next-icon")
}, null),
"superPrevIcon": ((_slots$superPrevIcon = slots.superPrevIcon) === null || _slots$superPrevIcon === void 0 ? void 0 : _slots$superPrevIcon.call(slots)) || (0, _vue.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)) || (0, _vue.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
}), null);
};
}
});
}
var DatePicker = getPicker(undefined, 'ADatePicker');
var WeekPicker = getPicker('week', 'AWeekPicker');
var MonthPicker = getPicker('month', 'AMonthPicker');
var YearPicker = getPicker('year', 'AYearPicker');
var TimePicker = getPicker('time', 'TimePicker'); // 给独立组件 TimePicker 使用,此处名称不用更改
var QuarterPicker = getPicker('quarter', 'AQuarterPicker');
return {
DatePicker: DatePicker,
WeekPicker: WeekPicker,
MonthPicker: MonthPicker,
YearPicker: YearPicker,
TimePicker: TimePicker,
QuarterPicker: QuarterPicker
};
}