UNPKG

@aplus-frontend/antdv

Version:

Vue basic component library maintained based on ant-design-vue

244 lines (241 loc) 12.3 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = generateSinglePicker; var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2")); var _vue = require("vue"); var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); 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 _useConfigInject = _interopRequireDefault(require("../../config-provider/hooks/useConfigInject")); var _classNames = _interopRequireDefault(require("../../_util/classNames")); var _props2 = require("./props"); var _devWarning = _interopRequireDefault(require("../../vc-util/devWarning")); var _FormItemContext = require("../../form/FormItemContext"); var _statusUtils = require("../../_util/statusUtils"); var _Compact = require("../../space/Compact"); var _style = _interopRequireDefault(require("../style")); var __rest = void 0 && (void 0).__rest || function (s, e) { var t = {}; for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p]; if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) { if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]]; } return t; }; //CSSINJS function generateSinglePicker(generateConfig, extraProps) { function getPicker(picker, displayName) { const comProps = (0, _extends2.default)((0, _extends2.default)((0, _extends2.default)({}, (0, _props2.commonProps)()), (0, _props2.datePickerProps)()), extraProps); return (0, _vue.defineComponent)({ compatConfig: { MODE: 3 }, name: displayName, inheritAttrs: false, props: comProps, slots: Object, setup(_props, _ref) { let { slots, expose, attrs, emit } = _ref; // 兼容 vue 3.2.7 const props = _props; const formItemContext = (0, _FormItemContext.useInjectFormItemContext)(); const formItemInputContext = _FormItemContext.FormItemInputContext.useInject(); // =================== Warning ===================== if (process.env.NODE_ENV !== 'production') { (0, _devWarning.default)(picker !== 'quarter', displayName || 'DatePicker', `DatePicker.${displayName} is legacy usage. Please use DatePicker[picker='${picker}'] directly.`); (0, _devWarning.default)(!props.dropdownClassName, displayName || 'DatePicker', '`dropdownClassName` is deprecated. Please use `popupClassName` instead.'); (0, _devWarning.default)(!(props.monthCellContentRender || slots.monthCellContentRender), displayName || 'DatePicker', '`monthCellContentRender` is deprecated. Please use `monthCellRender"` instead.'); (0, _devWarning.default)(!attrs.getCalendarContainer, displayName || 'DatePicker', '`getCalendarContainer` is deprecated. Please use `getPopupContainer"` instead.'); } const { prefixCls, direction, getPopupContainer, size, rootPrefixCls, disabled } = (0, _useConfigInject.default)('picker', props); const { compactSize, compactItemClassnames } = (0, _Compact.useCompactItemContext)(prefixCls, direction); const mergedSize = (0, _vue.computed)(() => compactSize.value || size.value); // style const [wrapSSR, hashId] = (0, _style.default)(prefixCls); const pickerRef = (0, _vue.ref)(); expose({ focus: () => { var _a; (_a = pickerRef.value) === null || _a === void 0 ? void 0 : _a.focus(); }, blur: () => { var _a; (_a = pickerRef.value) === null || _a === void 0 ? void 0 : _a.blur(); } }); const maybeToString = date => { return props.valueFormat ? generateConfig.toString(date, props.valueFormat) : date; }; const onChange = (date, dateString) => { const value = maybeToString(date); emit('update:value', value); emit('change', value, dateString); formItemContext.onFieldChange(); }; const onOpenChange = open => { emit('update:open', open); emit('openChange', open); }; const onFocus = e => { emit('focus', e); }; const onBlur = e => { emit('blur', e); formItemContext.onFieldBlur(); }; const onPanelChange = (date, mode) => { const value = maybeToString(date); emit('panelChange', value, mode); }; const onOk = date => { const value = maybeToString(date); emit('ok', value); }; const [contextLocale] = (0, _LocaleReceiver.useLocaleReceiver)('DatePicker', _en_US.default); const value = (0, _vue.computed)(() => { if (props.value) { return props.valueFormat ? generateConfig.toDate(props.value, props.valueFormat) : props.value; } return props.value === '' ? undefined : props.value; }); const defaultValue = (0, _vue.computed)(() => { if (props.defaultValue) { return props.valueFormat ? generateConfig.toDate(props.defaultValue, props.valueFormat) : props.defaultValue; } return props.defaultValue === '' ? undefined : props.defaultValue; }); const defaultPickerValue = (0, _vue.computed)(() => { if (props.defaultPickerValue) { return props.valueFormat ? generateConfig.toDate(props.defaultPickerValue, props.valueFormat) : props.defaultPickerValue; } return props.defaultPickerValue === '' ? undefined : props.defaultPickerValue; }); return () => { var _a, _b, _c, _d, _e, _f; const locale = (0, _extends2.default)((0, _extends2.default)({}, contextLocale.value), props.locale); const p = (0, _extends2.default)((0, _extends2.default)({}, props), attrs); const { bordered = true, placeholder, suffixIcon = (_a = slots.suffixIcon) === null || _a === void 0 ? void 0 : _a.call(slots), showToday = true, transitionName, allowClear = true, dateRender = slots.dateRender, renderExtraFooter = slots.renderExtraFooter, monthCellRender = slots.monthCellRender || props.monthCellContentRender || slots.monthCellContentRender, clearIcon = (_b = slots.clearIcon) === null || _b === void 0 ? void 0 : _b.call(slots), id = formItemContext.id.value } = p, restProps = __rest(p, ["bordered", "placeholder", "suffixIcon", "showToday", "transitionName", "allowClear", "dateRender", "renderExtraFooter", "monthCellRender", "clearIcon", "id"]); const showTime = p.showTime === '' ? true : p.showTime; const { format } = p; let additionalOverrideProps = {}; if (picker) { additionalOverrideProps.picker = picker; } const mergedPicker = picker || p.picker || 'date'; additionalOverrideProps = (0, _extends2.default)((0, _extends2.default)((0, _extends2.default)({}, additionalOverrideProps), showTime ? (0, _.getTimeProps)((0, _extends2.default)({ format, picker: mergedPicker }, typeof showTime === 'object' ? showTime : {})) : {}), mergedPicker === 'time' ? (0, _.getTimeProps)((0, _extends2.default)((0, _extends2.default)({ format }, restProps), { picker: mergedPicker })) : {}); const pre = prefixCls.value; const suffixNode = (0, _vue.createVNode)(_vue.Fragment, null, [suffixIcon || (picker === 'time' ? (0, _vue.createVNode)(_ClockCircleOutlined.default, null, null) : (0, _vue.createVNode)(_CalendarOutlined.default, null, null)), formItemInputContext.hasFeedback && formItemInputContext.feedbackIcon]); return wrapSSR((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)(locale, mergedPicker, placeholder), "suffixIcon": suffixNode, "dropdownAlign": (0, _util.transPlacement2DropdownAlign)(direction.value, props.placement), "clearIcon": clearIcon || (0, _vue.createVNode)(_CloseCircleFilled.default, null, null), "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": (0, _classNames.default)({ [`${pre}-${mergedSize.value}`]: mergedSize.value, [`${pre}-borderless`]: !bordered }, (0, _statusUtils.getStatusClassNames)(pre, (0, _statusUtils.getMergedStatus)(formItemInputContext.status, props.status), formItemInputContext.hasFeedback), attrs.class, hashId.value, compactItemClassnames.value), "disabled": disabled.value, "prefixCls": pre, "getPopupContainer": attrs.getCalendarContainer || getPopupContainer.value, "generateConfig": generateConfig, "prevIcon": ((_c = slots.prevIcon) === null || _c === void 0 ? void 0 : _c.call(slots)) || (0, _vue.createVNode)("span", { "class": `${pre}-prev-icon` }, null), "nextIcon": ((_d = slots.nextIcon) === null || _d === void 0 ? void 0 : _d.call(slots)) || (0, _vue.createVNode)("span", { "class": `${pre}-next-icon` }, null), "superPrevIcon": ((_e = slots.superPrevIcon) === null || _e === void 0 ? void 0 : _e.call(slots)) || (0, _vue.createVNode)("span", { "class": `${pre}-super-prev-icon` }, null), "superNextIcon": ((_f = slots.superNextIcon) === null || _f === void 0 ? void 0 : _f.call(slots)) || (0, _vue.createVNode)("span", { "class": `${pre}-super-next-icon` }, null), "components": _.Components, "direction": direction.value, "dropdownClassName": (0, _classNames.default)(hashId.value, props.popupClassName, props.dropdownClassName), "onChange": onChange, "onOpenChange": onOpenChange, "onFocus": onFocus, "onBlur": onBlur, "onPanelChange": onPanelChange, "onOk": onOk }), null)); }; } }); } 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 }; }