generateRangePicker.js 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206
  1. import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
  2. import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
  3. import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
  4. import _objectSpread from "@babel/runtime/helpers/esm/objectSpread2";
  5. var _excluded = ["prefixCls", "bordered", "placeholder", "suffixIcon", "picker", "transitionName", "allowClear", "dateRender", "renderExtraFooter", "separator", "clearIcon", "id"];
  6. import { createVNode as _createVNode } from "vue";
  7. import CalendarOutlined from "@ant-design/icons-vue/es/icons/CalendarOutlined";
  8. import ClockCircleOutlined from "@ant-design/icons-vue/es/icons/ClockCircleOutlined";
  9. import CloseCircleFilled from "@ant-design/icons-vue/es/icons/CloseCircleFilled";
  10. import SwapRightOutlined from "@ant-design/icons-vue/es/icons/SwapRightOutlined";
  11. import { RangePicker as VCRangePicker } from '../../vc-picker';
  12. import enUS from '../locale/en_US';
  13. import { useLocaleReceiver } from '../../locale-provider/LocaleReceiver';
  14. import { getRangePlaceholder } from '../util';
  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, rangePickerProps } from './props';
  20. import devWarning from '../../vc-util/devWarning';
  21. import { useInjectFormItemContext } from '../../form/FormItemContext';
  22. import omit from '../../_util/omit';
  23. export default function generateRangePicker(generateConfig, extraProps) {
  24. var RangePicker = defineComponent({
  25. compatConfig: {
  26. MODE: 3
  27. },
  28. name: 'ARangePicker',
  29. inheritAttrs: false,
  30. props: _objectSpread(_objectSpread(_objectSpread({}, commonProps()), rangePickerProps()), extraProps),
  31. slots: ['suffixIcon',
  32. // 'clearIcon',
  33. 'prevIcon', 'nextIcon', 'superPrevIcon', 'superNextIcon',
  34. // 'panelRender',
  35. 'dateRender', 'renderExtraFooter'
  36. // 'separator',
  37. ],
  38. setup: function setup(_props, _ref) {
  39. var expose = _ref.expose,
  40. slots = _ref.slots,
  41. attrs = _ref.attrs,
  42. emit = _ref.emit;
  43. var props = _props;
  44. var formItemContext = useInjectFormItemContext();
  45. devWarning(!attrs.getCalendarContainer, 'DatePicker', '`getCalendarContainer` is deprecated. Please use `getPopupContainer"` instead.');
  46. var _useConfigInject = useConfigInject('picker', props),
  47. prefixCls = _useConfigInject.prefixCls,
  48. direction = _useConfigInject.direction,
  49. getPopupContainer = _useConfigInject.getPopupContainer,
  50. size = _useConfigInject.size,
  51. rootPrefixCls = _useConfigInject.rootPrefixCls;
  52. var pickerRef = ref();
  53. expose({
  54. focus: function focus() {
  55. var _pickerRef$value;
  56. (_pickerRef$value = pickerRef.value) === null || _pickerRef$value === void 0 ? void 0 : _pickerRef$value.focus();
  57. },
  58. blur: function blur() {
  59. var _pickerRef$value2;
  60. (_pickerRef$value2 = pickerRef.value) === null || _pickerRef$value2 === void 0 ? void 0 : _pickerRef$value2.blur();
  61. }
  62. });
  63. var maybeToStrings = function maybeToStrings(dates) {
  64. return props.valueFormat ? generateConfig.toString(dates, props.valueFormat) : dates;
  65. };
  66. var onChange = function onChange(dates, dateStrings) {
  67. var values = maybeToStrings(dates);
  68. emit('update:value', values);
  69. emit('change', values, dateStrings);
  70. formItemContext.onFieldChange();
  71. };
  72. var onOpenChange = function onOpenChange(open) {
  73. emit('update:open', open);
  74. emit('openChange', open);
  75. };
  76. var onFocus = function onFocus(e) {
  77. emit('focus', e);
  78. };
  79. var onBlur = function onBlur(e) {
  80. emit('blur', e);
  81. formItemContext.onFieldBlur();
  82. };
  83. var onPanelChange = function onPanelChange(dates, modes) {
  84. var values = maybeToStrings(dates);
  85. emit('panelChange', values, modes);
  86. };
  87. var onOk = function onOk(dates) {
  88. var value = maybeToStrings(dates);
  89. emit('ok', value);
  90. };
  91. var onCalendarChange = function onCalendarChange(dates, dateStrings, info) {
  92. var values = maybeToStrings(dates);
  93. emit('calendarChange', values, dateStrings, info);
  94. };
  95. var _useLocaleReceiver = useLocaleReceiver('DatePicker', enUS),
  96. _useLocaleReceiver2 = _slicedToArray(_useLocaleReceiver, 1),
  97. contextLocale = _useLocaleReceiver2[0];
  98. var value = computed(function () {
  99. if (props.value) {
  100. return props.valueFormat ? generateConfig.toDate(props.value, props.valueFormat) : props.value;
  101. }
  102. return props.value;
  103. });
  104. var defaultValue = computed(function () {
  105. if (props.defaultValue) {
  106. return props.valueFormat ? generateConfig.toDate(props.defaultValue, props.valueFormat) : props.defaultValue;
  107. }
  108. return props.defaultValue;
  109. });
  110. var defaultPickerValue = computed(function () {
  111. if (props.defaultPickerValue) {
  112. return props.valueFormat ? generateConfig.toDate(props.defaultPickerValue, props.valueFormat) : props.defaultPickerValue;
  113. }
  114. return props.defaultPickerValue;
  115. });
  116. return function () {
  117. var _slots$suffixIcon, _slots$separator, _slots$clearIcon, _classNames, _slots$prevIcon, _slots$nextIcon, _slots$superPrevIcon, _slots$superNextIcon;
  118. var locale = _objectSpread(_objectSpread({}, contextLocale.value), props.locale);
  119. var p = _objectSpread(_objectSpread({}, props), attrs);
  120. var customizePrefixCls = p.prefixCls,
  121. _p$bordered = p.bordered,
  122. bordered = _p$bordered === void 0 ? true : _p$bordered,
  123. placeholder = p.placeholder,
  124. _p$suffixIcon = p.suffixIcon,
  125. suffixIcon = _p$suffixIcon === void 0 ? (_slots$suffixIcon = slots.suffixIcon) === null || _slots$suffixIcon === void 0 ? void 0 : _slots$suffixIcon.call(slots) : _p$suffixIcon,
  126. _p$picker = p.picker,
  127. picker = _p$picker === void 0 ? 'date' : _p$picker,
  128. transitionName = p.transitionName,
  129. _p$allowClear = p.allowClear,
  130. allowClear = _p$allowClear === void 0 ? true : _p$allowClear,
  131. _p$dateRender = p.dateRender,
  132. dateRender = _p$dateRender === void 0 ? slots.dateRender : _p$dateRender,
  133. _p$renderExtraFooter = p.renderExtraFooter,
  134. renderExtraFooter = _p$renderExtraFooter === void 0 ? slots.renderExtraFooter : _p$renderExtraFooter,
  135. _p$separator = p.separator,
  136. separator = _p$separator === void 0 ? (_slots$separator = slots.separator) === null || _slots$separator === void 0 ? void 0 : _slots$separator.call(slots) : _p$separator,
  137. _p$clearIcon = p.clearIcon,
  138. clearIcon = _p$clearIcon === void 0 ? (_slots$clearIcon = slots.clearIcon) === null || _slots$clearIcon === void 0 ? void 0 : _slots$clearIcon.call(slots) : _p$clearIcon,
  139. _p$id = p.id,
  140. id = _p$id === void 0 ? formItemContext.id.value : _p$id,
  141. restProps = _objectWithoutProperties(p, _excluded);
  142. delete restProps['onUpdate:value'];
  143. delete restProps['onUpdate:open'];
  144. var format = p.format,
  145. showTime = p.showTime;
  146. var additionalOverrideProps = {};
  147. additionalOverrideProps = _objectSpread(_objectSpread(_objectSpread({}, additionalOverrideProps), showTime ? getTimeProps(_objectSpread({
  148. format: format,
  149. picker: picker
  150. }, showTime)) : {}), picker === 'time' ? getTimeProps(_objectSpread(_objectSpread({
  151. format: format
  152. }, omit(restProps, ['disabledTime'])), {}, {
  153. picker: picker
  154. })) : {});
  155. var pre = prefixCls.value;
  156. return _createVNode(VCRangePicker, _objectSpread(_objectSpread(_objectSpread({
  157. "dateRender": dateRender,
  158. "renderExtraFooter": renderExtraFooter,
  159. "separator": separator || _createVNode("span", {
  160. "aria-label": "to",
  161. "class": "".concat(pre, "-separator")
  162. }, [_createVNode(SwapRightOutlined, null, null)]),
  163. "ref": pickerRef,
  164. "placeholder": getRangePlaceholder(picker, locale, placeholder),
  165. "suffixIcon": suffixIcon || (picker === 'time' ? _createVNode(ClockCircleOutlined, null, null) : _createVNode(CalendarOutlined, null, null)),
  166. "clearIcon": clearIcon || _createVNode(CloseCircleFilled, null, null),
  167. "allowClear": allowClear,
  168. "transitionName": transitionName || "".concat(rootPrefixCls.value, "-slide-up")
  169. }, restProps), additionalOverrideProps), {}, {
  170. "id": id,
  171. "value": value.value,
  172. "defaultValue": defaultValue.value,
  173. "defaultPickerValue": defaultPickerValue.value,
  174. "picker": picker,
  175. "class": classNames((_classNames = {}, _defineProperty(_classNames, "".concat(pre, "-").concat(size.value), size.value), _defineProperty(_classNames, "".concat(pre, "-borderless"), !bordered), _classNames), attrs.class),
  176. "locale": locale.lang,
  177. "prefixCls": pre,
  178. "getPopupContainer": attrs.getCalendarContainer || getPopupContainer.value,
  179. "generateConfig": generateConfig,
  180. "prevIcon": ((_slots$prevIcon = slots.prevIcon) === null || _slots$prevIcon === void 0 ? void 0 : _slots$prevIcon.call(slots)) || _createVNode("span", {
  181. "class": "".concat(pre, "-prev-icon")
  182. }, null),
  183. "nextIcon": ((_slots$nextIcon = slots.nextIcon) === null || _slots$nextIcon === void 0 ? void 0 : _slots$nextIcon.call(slots)) || _createVNode("span", {
  184. "class": "".concat(pre, "-next-icon")
  185. }, null),
  186. "superPrevIcon": ((_slots$superPrevIcon = slots.superPrevIcon) === null || _slots$superPrevIcon === void 0 ? void 0 : _slots$superPrevIcon.call(slots)) || _createVNode("span", {
  187. "class": "".concat(pre, "-super-prev-icon")
  188. }, null),
  189. "superNextIcon": ((_slots$superNextIcon = slots.superNextIcon) === null || _slots$superNextIcon === void 0 ? void 0 : _slots$superNextIcon.call(slots)) || _createVNode("span", {
  190. "class": "".concat(pre, "-super-next-icon")
  191. }, null),
  192. "components": Components,
  193. "direction": direction.value,
  194. "onChange": onChange,
  195. "onOpenChange": onOpenChange,
  196. "onFocus": onFocus,
  197. "onBlur": onBlur,
  198. "onPanelChange": onPanelChange,
  199. "onOk": onOk,
  200. "onCalendarChange": onCalendarChange
  201. }), null);
  202. };
  203. }
  204. });
  205. return RangePicker;
  206. }