generateSinglePicker.js 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244
  1. "use strict";
  2. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
  3. Object.defineProperty(exports, "__esModule", {
  4. value: true
  5. });
  6. exports.default = generateSinglePicker;
  7. var _vue = require("vue");
  8. var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
  9. var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
  10. var _CalendarOutlined = _interopRequireDefault(require("@ant-design/icons-vue/lib/icons/CalendarOutlined"));
  11. var _ClockCircleOutlined = _interopRequireDefault(require("@ant-design/icons-vue/lib/icons/ClockCircleOutlined"));
  12. var _CloseCircleFilled = _interopRequireDefault(require("@ant-design/icons-vue/lib/icons/CloseCircleFilled"));
  13. var _vcPicker = _interopRequireDefault(require("../../vc-picker"));
  14. var _en_US = _interopRequireDefault(require("../locale/en_US"));
  15. var _util = require("../util");
  16. var _LocaleReceiver = require("../../locale-provider/LocaleReceiver");
  17. var _ = require(".");
  18. var _useConfigInject = _interopRequireDefault(require("../../config-provider/hooks/useConfigInject"));
  19. var _classNames = _interopRequireDefault(require("../../_util/classNames"));
  20. var _props2 = require("./props");
  21. var _devWarning = _interopRequireDefault(require("../../vc-util/devWarning"));
  22. var _FormItemContext = require("../../form/FormItemContext");
  23. var _statusUtils = require("../../_util/statusUtils");
  24. var _Compact = require("../../space/Compact");
  25. var _style = _interopRequireDefault(require("../style"));
  26. var __rest = void 0 && (void 0).__rest || function (s, e) {
  27. var t = {};
  28. for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
  29. if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
  30. if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
  31. }
  32. return t;
  33. };
  34. //CSSINJS
  35. function generateSinglePicker(generateConfig, extraProps) {
  36. function getPicker(picker, displayName) {
  37. const comProps = (0, _extends2.default)((0, _extends2.default)((0, _extends2.default)({}, (0, _props2.commonProps)()), (0, _props2.datePickerProps)()), extraProps);
  38. return (0, _vue.defineComponent)({
  39. compatConfig: {
  40. MODE: 3
  41. },
  42. name: displayName,
  43. inheritAttrs: false,
  44. props: comProps,
  45. slots: Object,
  46. setup(_props, _ref) {
  47. let {
  48. slots,
  49. expose,
  50. attrs,
  51. emit
  52. } = _ref;
  53. // 兼容 vue 3.2.7
  54. const props = _props;
  55. const formItemContext = (0, _FormItemContext.useInjectFormItemContext)();
  56. const formItemInputContext = _FormItemContext.FormItemInputContext.useInject();
  57. // =================== Warning =====================
  58. if (process.env.NODE_ENV !== 'production') {
  59. (0, _devWarning.default)(picker !== 'quarter', displayName || 'DatePicker', `DatePicker.${displayName} is legacy usage. Please use DatePicker[picker='${picker}'] directly.`);
  60. (0, _devWarning.default)(!props.dropdownClassName, displayName || 'DatePicker', '`dropdownClassName` is deprecated. Please use `popupClassName` instead.');
  61. (0, _devWarning.default)(!(props.monthCellContentRender || slots.monthCellContentRender), displayName || 'DatePicker', '`monthCellContentRender` is deprecated. Please use `monthCellRender"` instead.');
  62. (0, _devWarning.default)(!attrs.getCalendarContainer, displayName || 'DatePicker', '`getCalendarContainer` is deprecated. Please use `getPopupContainer"` instead.');
  63. }
  64. const {
  65. prefixCls,
  66. direction,
  67. getPopupContainer,
  68. size,
  69. rootPrefixCls,
  70. disabled
  71. } = (0, _useConfigInject.default)('picker', props);
  72. const {
  73. compactSize,
  74. compactItemClassnames
  75. } = (0, _Compact.useCompactItemContext)(prefixCls, direction);
  76. const mergedSize = (0, _vue.computed)(() => compactSize.value || size.value);
  77. // style
  78. const [wrapSSR, hashId] = (0, _style.default)(prefixCls);
  79. const pickerRef = (0, _vue.ref)();
  80. expose({
  81. focus: () => {
  82. var _a;
  83. (_a = pickerRef.value) === null || _a === void 0 ? void 0 : _a.focus();
  84. },
  85. blur: () => {
  86. var _a;
  87. (_a = pickerRef.value) === null || _a === void 0 ? void 0 : _a.blur();
  88. }
  89. });
  90. const maybeToString = date => {
  91. return props.valueFormat ? generateConfig.toString(date, props.valueFormat) : date;
  92. };
  93. const onChange = (date, dateString) => {
  94. const value = maybeToString(date);
  95. emit('update:value', value);
  96. emit('change', value, dateString);
  97. formItemContext.onFieldChange();
  98. };
  99. const onOpenChange = open => {
  100. emit('update:open', open);
  101. emit('openChange', open);
  102. };
  103. const onFocus = e => {
  104. emit('focus', e);
  105. };
  106. const onBlur = e => {
  107. emit('blur', e);
  108. formItemContext.onFieldBlur();
  109. };
  110. const onPanelChange = (date, mode) => {
  111. const value = maybeToString(date);
  112. emit('panelChange', value, mode);
  113. };
  114. const onOk = date => {
  115. const value = maybeToString(date);
  116. emit('ok', value);
  117. };
  118. const [contextLocale] = (0, _LocaleReceiver.useLocaleReceiver)('DatePicker', _en_US.default);
  119. const value = (0, _vue.computed)(() => {
  120. if (props.value) {
  121. return props.valueFormat ? generateConfig.toDate(props.value, props.valueFormat) : props.value;
  122. }
  123. return props.value === '' ? undefined : props.value;
  124. });
  125. const defaultValue = (0, _vue.computed)(() => {
  126. if (props.defaultValue) {
  127. return props.valueFormat ? generateConfig.toDate(props.defaultValue, props.valueFormat) : props.defaultValue;
  128. }
  129. return props.defaultValue === '' ? undefined : props.defaultValue;
  130. });
  131. const defaultPickerValue = (0, _vue.computed)(() => {
  132. if (props.defaultPickerValue) {
  133. return props.valueFormat ? generateConfig.toDate(props.defaultPickerValue, props.valueFormat) : props.defaultPickerValue;
  134. }
  135. return props.defaultPickerValue === '' ? undefined : props.defaultPickerValue;
  136. });
  137. return () => {
  138. var _a, _b, _c, _d, _e, _f;
  139. const locale = (0, _extends2.default)((0, _extends2.default)({}, contextLocale.value), props.locale);
  140. const p = (0, _extends2.default)((0, _extends2.default)({}, props), attrs);
  141. const {
  142. bordered = true,
  143. placeholder,
  144. suffixIcon = (_a = slots.suffixIcon) === null || _a === void 0 ? void 0 : _a.call(slots),
  145. showToday = true,
  146. transitionName,
  147. allowClear = true,
  148. dateRender = slots.dateRender,
  149. renderExtraFooter = slots.renderExtraFooter,
  150. monthCellRender = slots.monthCellRender || props.monthCellContentRender || slots.monthCellContentRender,
  151. clearIcon = (_b = slots.clearIcon) === null || _b === void 0 ? void 0 : _b.call(slots),
  152. id = formItemContext.id.value
  153. } = p,
  154. restProps = __rest(p, ["bordered", "placeholder", "suffixIcon", "showToday", "transitionName", "allowClear", "dateRender", "renderExtraFooter", "monthCellRender", "clearIcon", "id"]);
  155. const showTime = p.showTime === '' ? true : p.showTime;
  156. const {
  157. format
  158. } = p;
  159. let additionalOverrideProps = {};
  160. if (picker) {
  161. additionalOverrideProps.picker = picker;
  162. }
  163. const mergedPicker = picker || p.picker || 'date';
  164. additionalOverrideProps = (0, _extends2.default)((0, _extends2.default)((0, _extends2.default)({}, additionalOverrideProps), showTime ? (0, _.getTimeProps)((0, _extends2.default)({
  165. format,
  166. picker: mergedPicker
  167. }, typeof showTime === 'object' ? showTime : {})) : {}), mergedPicker === 'time' ? (0, _.getTimeProps)((0, _extends2.default)((0, _extends2.default)({
  168. format
  169. }, restProps), {
  170. picker: mergedPicker
  171. })) : {});
  172. const pre = prefixCls.value;
  173. 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]);
  174. return wrapSSR((0, _vue.createVNode)(_vcPicker.default, (0, _objectSpread2.default)((0, _objectSpread2.default)((0, _objectSpread2.default)({
  175. "monthCellRender": monthCellRender,
  176. "dateRender": dateRender,
  177. "renderExtraFooter": renderExtraFooter,
  178. "ref": pickerRef,
  179. "placeholder": (0, _util.getPlaceholder)(locale, mergedPicker, placeholder),
  180. "suffixIcon": suffixNode,
  181. "dropdownAlign": (0, _util.transPlacement2DropdownAlign)(direction.value, props.placement),
  182. "clearIcon": clearIcon || (0, _vue.createVNode)(_CloseCircleFilled.default, null, null),
  183. "allowClear": allowClear,
  184. "transitionName": transitionName || `${rootPrefixCls.value}-slide-up`
  185. }, restProps), additionalOverrideProps), {}, {
  186. "id": id,
  187. "picker": mergedPicker,
  188. "value": value.value,
  189. "defaultValue": defaultValue.value,
  190. "defaultPickerValue": defaultPickerValue.value,
  191. "showToday": showToday,
  192. "locale": locale.lang,
  193. "class": (0, _classNames.default)({
  194. [`${pre}-${mergedSize.value}`]: mergedSize.value,
  195. [`${pre}-borderless`]: !bordered
  196. }, (0, _statusUtils.getStatusClassNames)(pre, (0, _statusUtils.getMergedStatus)(formItemInputContext.status, props.status), formItemInputContext.hasFeedback), attrs.class, hashId.value, compactItemClassnames.value),
  197. "disabled": disabled.value,
  198. "prefixCls": pre,
  199. "getPopupContainer": attrs.getCalendarContainer || getPopupContainer.value,
  200. "generateConfig": generateConfig,
  201. "prevIcon": ((_c = slots.prevIcon) === null || _c === void 0 ? void 0 : _c.call(slots)) || (0, _vue.createVNode)("span", {
  202. "class": `${pre}-prev-icon`
  203. }, null),
  204. "nextIcon": ((_d = slots.nextIcon) === null || _d === void 0 ? void 0 : _d.call(slots)) || (0, _vue.createVNode)("span", {
  205. "class": `${pre}-next-icon`
  206. }, null),
  207. "superPrevIcon": ((_e = slots.superPrevIcon) === null || _e === void 0 ? void 0 : _e.call(slots)) || (0, _vue.createVNode)("span", {
  208. "class": `${pre}-super-prev-icon`
  209. }, null),
  210. "superNextIcon": ((_f = slots.superNextIcon) === null || _f === void 0 ? void 0 : _f.call(slots)) || (0, _vue.createVNode)("span", {
  211. "class": `${pre}-super-next-icon`
  212. }, null),
  213. "components": _.Components,
  214. "direction": direction.value,
  215. "dropdownClassName": (0, _classNames.default)(hashId.value, props.popupClassName, props.dropdownClassName),
  216. "onChange": onChange,
  217. "onOpenChange": onOpenChange,
  218. "onFocus": onFocus,
  219. "onBlur": onBlur,
  220. "onPanelChange": onPanelChange,
  221. "onOk": onOk
  222. }), null));
  223. };
  224. }
  225. });
  226. }
  227. const DatePicker = getPicker(undefined, 'ADatePicker');
  228. const WeekPicker = getPicker('week', 'AWeekPicker');
  229. const MonthPicker = getPicker('month', 'AMonthPicker');
  230. const YearPicker = getPicker('year', 'AYearPicker');
  231. const TimePicker = getPicker('time', 'TimePicker'); // 给独立组件 TimePicker 使用,此处名称不用更改
  232. const QuarterPicker = getPicker('quarter', 'AQuarterPicker');
  233. return {
  234. DatePicker,
  235. WeekPicker,
  236. MonthPicker,
  237. YearPicker,
  238. TimePicker,
  239. QuarterPicker
  240. };
  241. }