generateSinglePicker.js 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215
  1. import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
  2. import _typeof from "@babel/runtime/helpers/esm/typeof";
  3. import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
  4. import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
  5. import _objectSpread from "@babel/runtime/helpers/esm/objectSpread2";
  6. var _excluded = ["bordered", "placeholder", "suffixIcon", "showToday", "transitionName", "allowClear", "dateRender", "renderExtraFooter", "monthCellRender", "clearIcon", "id"];
  7. import { createVNode as _createVNode } from "vue";
  8. import CalendarOutlined from "@ant-design/icons-vue/es/icons/CalendarOutlined";
  9. import ClockCircleOutlined from "@ant-design/icons-vue/es/icons/ClockCircleOutlined";
  10. import CloseCircleFilled from "@ant-design/icons-vue/es/icons/CloseCircleFilled";
  11. import RCPicker from '../../vc-picker';
  12. import enUS from '../locale/en_US';
  13. import { getPlaceholder } from '../util';
  14. import { useLocaleReceiver } from '../../locale-provider/LocaleReceiver';
  15. import { getTimeProps, Components } from '.';
  16. import { computed, defineComponent, ref } from 'vue';
  17. import useConfigInject from '../../_util/hooks/useConfigInject';
  18. import classNames from '../../_util/classNames';
  19. import { commonProps, datePickerProps } from './props';
  20. import devWarning from '../../vc-util/devWarning';
  21. import { useInjectFormItemContext } from '../../form/FormItemContext';
  22. export default function generateSinglePicker(generateConfig, extraProps) {
  23. function getPicker(picker, displayName) {
  24. var comProps = _objectSpread(_objectSpread(_objectSpread({}, commonProps()), datePickerProps()), extraProps);
  25. return defineComponent({
  26. compatConfig: {
  27. MODE: 3
  28. },
  29. name: displayName,
  30. inheritAttrs: false,
  31. props: comProps,
  32. slots: ['suffixIcon',
  33. // 'clearIcon',
  34. 'prevIcon', 'nextIcon', 'superPrevIcon', 'superNextIcon',
  35. // 'panelRender',
  36. 'dateRender', 'renderExtraFooter', 'monthCellRender'],
  37. setup: function setup(_props, _ref) {
  38. var slots = _ref.slots,
  39. expose = _ref.expose,
  40. attrs = _ref.attrs,
  41. emit = _ref.emit;
  42. // 兼容 vue 3.2.7
  43. var props = _props;
  44. var formItemContext = useInjectFormItemContext();
  45. devWarning(!(props.monthCellContentRender || slots.monthCellContentRender), 'DatePicker', '`monthCellContentRender` is deprecated. Please use `monthCellRender"` instead.');
  46. devWarning(!attrs.getCalendarContainer, 'DatePicker', '`getCalendarContainer` is deprecated. Please use `getPopupContainer"` instead.');
  47. var _useConfigInject = useConfigInject('picker', props),
  48. prefixCls = _useConfigInject.prefixCls,
  49. direction = _useConfigInject.direction,
  50. getPopupContainer = _useConfigInject.getPopupContainer,
  51. size = _useConfigInject.size,
  52. rootPrefixCls = _useConfigInject.rootPrefixCls;
  53. var pickerRef = ref();
  54. expose({
  55. focus: function focus() {
  56. var _pickerRef$value;
  57. (_pickerRef$value = pickerRef.value) === null || _pickerRef$value === void 0 ? void 0 : _pickerRef$value.focus();
  58. },
  59. blur: function blur() {
  60. var _pickerRef$value2;
  61. (_pickerRef$value2 = pickerRef.value) === null || _pickerRef$value2 === void 0 ? void 0 : _pickerRef$value2.blur();
  62. }
  63. });
  64. var maybeToString = function maybeToString(date) {
  65. return props.valueFormat ? generateConfig.toString(date, props.valueFormat) : date;
  66. };
  67. var onChange = function onChange(date, dateString) {
  68. var value = maybeToString(date);
  69. emit('update:value', value);
  70. emit('change', value, dateString);
  71. formItemContext.onFieldChange();
  72. };
  73. var onOpenChange = function onOpenChange(open) {
  74. emit('update:open', open);
  75. emit('openChange', open);
  76. };
  77. var onFocus = function onFocus(e) {
  78. emit('focus', e);
  79. };
  80. var onBlur = function onBlur(e) {
  81. emit('blur', e);
  82. formItemContext.onFieldBlur();
  83. };
  84. var onPanelChange = function onPanelChange(date, mode) {
  85. var value = maybeToString(date);
  86. emit('panelChange', value, mode);
  87. };
  88. var onOk = function onOk(date) {
  89. var value = maybeToString(date);
  90. emit('ok', value);
  91. };
  92. var _useLocaleReceiver = useLocaleReceiver('DatePicker', enUS),
  93. _useLocaleReceiver2 = _slicedToArray(_useLocaleReceiver, 1),
  94. contextLocale = _useLocaleReceiver2[0];
  95. var value = computed(function () {
  96. if (props.value) {
  97. return props.valueFormat ? generateConfig.toDate(props.value, props.valueFormat) : props.value;
  98. }
  99. return props.value === '' ? undefined : props.value;
  100. });
  101. var defaultValue = computed(function () {
  102. if (props.defaultValue) {
  103. return props.valueFormat ? generateConfig.toDate(props.defaultValue, props.valueFormat) : props.defaultValue;
  104. }
  105. return props.defaultValue === '' ? undefined : props.defaultValue;
  106. });
  107. var defaultPickerValue = computed(function () {
  108. if (props.defaultPickerValue) {
  109. return props.valueFormat ? generateConfig.toDate(props.defaultPickerValue, props.valueFormat) : props.defaultPickerValue;
  110. }
  111. return props.defaultPickerValue === '' ? undefined : props.defaultPickerValue;
  112. });
  113. return function () {
  114. var _slots$suffixIcon, _slots$clearIcon, _classNames, _slots$prevIcon, _slots$nextIcon, _slots$superPrevIcon, _slots$superNextIcon;
  115. var locale = _objectSpread(_objectSpread({}, contextLocale.value), props.locale);
  116. var p = _objectSpread(_objectSpread({}, props), attrs);
  117. var _p$bordered = p.bordered,
  118. bordered = _p$bordered === void 0 ? true : _p$bordered,
  119. placeholder = p.placeholder,
  120. _p$suffixIcon = p.suffixIcon,
  121. suffixIcon = _p$suffixIcon === void 0 ? (_slots$suffixIcon = slots.suffixIcon) === null || _slots$suffixIcon === void 0 ? void 0 : _slots$suffixIcon.call(slots) : _p$suffixIcon,
  122. _p$showToday = p.showToday,
  123. showToday = _p$showToday === void 0 ? true : _p$showToday,
  124. transitionName = p.transitionName,
  125. _p$allowClear = p.allowClear,
  126. allowClear = _p$allowClear === void 0 ? true : _p$allowClear,
  127. _p$dateRender = p.dateRender,
  128. dateRender = _p$dateRender === void 0 ? slots.dateRender : _p$dateRender,
  129. _p$renderExtraFooter = p.renderExtraFooter,
  130. renderExtraFooter = _p$renderExtraFooter === void 0 ? slots.renderExtraFooter : _p$renderExtraFooter,
  131. _p$monthCellRender = p.monthCellRender,
  132. monthCellRender = _p$monthCellRender === void 0 ? slots.monthCellRender || props.monthCellContentRender || slots.monthCellContentRender : _p$monthCellRender,
  133. _p$clearIcon = p.clearIcon,
  134. clearIcon = _p$clearIcon === void 0 ? (_slots$clearIcon = slots.clearIcon) === null || _slots$clearIcon === void 0 ? void 0 : _slots$clearIcon.call(slots) : _p$clearIcon,
  135. _p$id = p.id,
  136. id = _p$id === void 0 ? formItemContext.id.value : _p$id,
  137. restProps = _objectWithoutProperties(p, _excluded);
  138. var showTime = p.showTime === '' ? true : p.showTime;
  139. var format = p.format;
  140. var additionalOverrideProps = {};
  141. if (picker) {
  142. additionalOverrideProps.picker = picker;
  143. }
  144. var mergedPicker = picker || p.picker || 'date';
  145. additionalOverrideProps = _objectSpread(_objectSpread(_objectSpread({}, additionalOverrideProps), showTime ? getTimeProps(_objectSpread({
  146. format: format,
  147. picker: mergedPicker
  148. }, _typeof(showTime) === 'object' ? showTime : {})) : {}), mergedPicker === 'time' ? getTimeProps(_objectSpread(_objectSpread({
  149. format: format
  150. }, restProps), {}, {
  151. picker: mergedPicker
  152. })) : {});
  153. var pre = prefixCls.value;
  154. return _createVNode(RCPicker, _objectSpread(_objectSpread(_objectSpread({
  155. "monthCellRender": monthCellRender,
  156. "dateRender": dateRender,
  157. "renderExtraFooter": renderExtraFooter,
  158. "ref": pickerRef,
  159. "placeholder": getPlaceholder(mergedPicker, locale, placeholder),
  160. "suffixIcon": suffixIcon || (mergedPicker === 'time' ? _createVNode(ClockCircleOutlined, null, null) : _createVNode(CalendarOutlined, null, null)),
  161. "clearIcon": clearIcon || _createVNode(CloseCircleFilled, null, null),
  162. "allowClear": allowClear,
  163. "transitionName": transitionName || "".concat(rootPrefixCls.value, "-slide-up")
  164. }, restProps), additionalOverrideProps), {}, {
  165. "id": id,
  166. "picker": mergedPicker,
  167. "value": value.value,
  168. "defaultValue": defaultValue.value,
  169. "defaultPickerValue": defaultPickerValue.value,
  170. "showToday": showToday,
  171. "locale": locale.lang,
  172. "class": classNames((_classNames = {}, _defineProperty(_classNames, "".concat(pre, "-").concat(size.value), size.value), _defineProperty(_classNames, "".concat(pre, "-borderless"), !bordered), _classNames), attrs.class),
  173. "prefixCls": pre,
  174. "getPopupContainer": attrs.getCalendarContainer || getPopupContainer.value,
  175. "generateConfig": generateConfig,
  176. "prevIcon": ((_slots$prevIcon = slots.prevIcon) === null || _slots$prevIcon === void 0 ? void 0 : _slots$prevIcon.call(slots)) || _createVNode("span", {
  177. "class": "".concat(pre, "-prev-icon")
  178. }, null),
  179. "nextIcon": ((_slots$nextIcon = slots.nextIcon) === null || _slots$nextIcon === void 0 ? void 0 : _slots$nextIcon.call(slots)) || _createVNode("span", {
  180. "class": "".concat(pre, "-next-icon")
  181. }, null),
  182. "superPrevIcon": ((_slots$superPrevIcon = slots.superPrevIcon) === null || _slots$superPrevIcon === void 0 ? void 0 : _slots$superPrevIcon.call(slots)) || _createVNode("span", {
  183. "class": "".concat(pre, "-super-prev-icon")
  184. }, null),
  185. "superNextIcon": ((_slots$superNextIcon = slots.superNextIcon) === null || _slots$superNextIcon === void 0 ? void 0 : _slots$superNextIcon.call(slots)) || _createVNode("span", {
  186. "class": "".concat(pre, "-super-next-icon")
  187. }, null),
  188. "components": Components,
  189. "direction": direction.value,
  190. "onChange": onChange,
  191. "onOpenChange": onOpenChange,
  192. "onFocus": onFocus,
  193. "onBlur": onBlur,
  194. "onPanelChange": onPanelChange,
  195. "onOk": onOk
  196. }), null);
  197. };
  198. }
  199. });
  200. }
  201. var DatePicker = getPicker(undefined, 'ADatePicker');
  202. var WeekPicker = getPicker('week', 'AWeekPicker');
  203. var MonthPicker = getPicker('month', 'AMonthPicker');
  204. var YearPicker = getPicker('year', 'AYearPicker');
  205. var TimePicker = getPicker('time', 'TimePicker'); // 给独立组件 TimePicker 使用,此处名称不用更改
  206. var QuarterPicker = getPicker('quarter', 'AQuarterPicker');
  207. return {
  208. DatePicker: DatePicker,
  209. WeekPicker: WeekPicker,
  210. MonthPicker: MonthPicker,
  211. YearPicker: YearPicker,
  212. TimePicker: TimePicker,
  213. QuarterPicker: QuarterPicker
  214. };
  215. }