generateRangePicker.js 8.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180
  1. "use strict";
  2. "use client";
  3. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
  4. var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
  5. Object.defineProperty(exports, "__esModule", {
  6. value: true
  7. });
  8. exports.default = void 0;
  9. var _react = _interopRequireWildcard(require("react"));
  10. var React = _react;
  11. var _CalendarOutlined = _interopRequireDefault(require("@ant-design/icons/CalendarOutlined"));
  12. var _ClockCircleOutlined = _interopRequireDefault(require("@ant-design/icons/ClockCircleOutlined"));
  13. var _SwapRightOutlined = _interopRequireDefault(require("@ant-design/icons/SwapRightOutlined"));
  14. var _classnames = _interopRequireDefault(require("classnames"));
  15. var _rcPicker = require("rc-picker");
  16. var _ContextIsolator = _interopRequireDefault(require("../../_util/ContextIsolator"));
  17. var _useZIndex = require("../../_util/hooks/useZIndex");
  18. var _statusUtils = require("../../_util/statusUtils");
  19. var _warning = require("../../_util/warning");
  20. var _configProvider = require("../../config-provider");
  21. var _DisabledContext = _interopRequireDefault(require("../../config-provider/DisabledContext"));
  22. var _useCSSVarCls = _interopRequireDefault(require("../../config-provider/hooks/useCSSVarCls"));
  23. var _useSize = _interopRequireDefault(require("../../config-provider/hooks/useSize"));
  24. var _context = require("../../form/context");
  25. var _useVariants = _interopRequireDefault(require("../../form/hooks/useVariants"));
  26. var _locale = require("../../locale");
  27. var _Compact = require("../../space/Compact");
  28. var _en_US = _interopRequireDefault(require("../locale/en_US"));
  29. var _style = _interopRequireDefault(require("../style"));
  30. var _util = require("../util");
  31. var _constant = require("./constant");
  32. var _useComponents = _interopRequireDefault(require("./useComponents"));
  33. var _useMergedPickerSemantic = _interopRequireDefault(require("../hooks/useMergedPickerSemantic"));
  34. var __rest = void 0 && (void 0).__rest || function (s, e) {
  35. var t = {};
  36. for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p];
  37. if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
  38. if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]];
  39. }
  40. return t;
  41. };
  42. const generateRangePicker = generateConfig => {
  43. const RangePicker = /*#__PURE__*/(0, _react.forwardRef)((props, ref) => {
  44. var _a;
  45. const {
  46. prefixCls: customizePrefixCls,
  47. getPopupContainer: customGetPopupContainer,
  48. components,
  49. className,
  50. style,
  51. placement,
  52. size: customizeSize,
  53. disabled: customDisabled,
  54. bordered = true,
  55. placeholder,
  56. popupStyle,
  57. popupClassName,
  58. dropdownClassName,
  59. status: customStatus,
  60. rootClassName,
  61. variant: customVariant,
  62. picker,
  63. styles,
  64. classNames
  65. } = props,
  66. restProps = __rest(props, ["prefixCls", "getPopupContainer", "components", "className", "style", "placement", "size", "disabled", "bordered", "placeholder", "popupStyle", "popupClassName", "dropdownClassName", "status", "rootClassName", "variant", "picker", "styles", "classNames"]);
  67. const pickerType = picker === _constant.TIME ? 'timePicker' : 'datePicker';
  68. const innerRef = React.useRef(null);
  69. const {
  70. getPrefixCls,
  71. direction,
  72. getPopupContainer,
  73. rangePicker
  74. } = (0, _react.useContext)(_configProvider.ConfigContext);
  75. const prefixCls = getPrefixCls('picker', customizePrefixCls);
  76. const {
  77. compactSize,
  78. compactItemClassnames
  79. } = (0, _Compact.useCompactItemContext)(prefixCls, direction);
  80. const rootPrefixCls = getPrefixCls();
  81. const [variant, enableVariantCls] = (0, _useVariants.default)('rangePicker', customVariant, bordered);
  82. const rootCls = (0, _useCSSVarCls.default)(prefixCls);
  83. const [wrapCSSVar, hashId, cssVarCls] = (0, _style.default)(prefixCls, rootCls);
  84. // =================== Warning =====================
  85. if (process.env.NODE_ENV !== 'production') {
  86. const warning = (0, _warning.devUseWarning)('DatePicker.RangePicker');
  87. // ==================== Deprecated =====================
  88. const deprecatedProps = {
  89. dropdownClassName: 'classNames.popup.root',
  90. popupClassName: 'classNames.popup.root',
  91. popupStyle: 'styles.popup.root',
  92. bordered: 'variant',
  93. onSelect: 'onCalendarChange'
  94. };
  95. Object.entries(deprecatedProps).forEach(([oldProp, newProp]) => {
  96. warning.deprecated(!(oldProp in props), oldProp, newProp);
  97. });
  98. }
  99. const [mergedClassNames, mergedStyles] = (0, _useMergedPickerSemantic.default)(pickerType, classNames, styles, popupClassName || dropdownClassName, popupStyle);
  100. // ===================== Icon =====================
  101. const [mergedAllowClear] = (0, _util.useIcons)(props, prefixCls);
  102. // ================== components ==================
  103. const mergedComponents = (0, _useComponents.default)(components);
  104. // ===================== Size =====================
  105. const mergedSize = (0, _useSize.default)(ctx => {
  106. var _a;
  107. return (_a = customizeSize !== null && customizeSize !== void 0 ? customizeSize : compactSize) !== null && _a !== void 0 ? _a : ctx;
  108. });
  109. // ===================== Disabled =====================
  110. const disabled = React.useContext(_DisabledContext.default);
  111. const mergedDisabled = customDisabled !== null && customDisabled !== void 0 ? customDisabled : disabled;
  112. // ===================== FormItemInput =====================
  113. const formItemContext = (0, _react.useContext)(_context.FormItemInputContext);
  114. const {
  115. hasFeedback,
  116. status: contextStatus,
  117. feedbackIcon
  118. } = formItemContext;
  119. const suffixNode = /*#__PURE__*/React.createElement(React.Fragment, null, picker === _constant.TIME ? /*#__PURE__*/React.createElement(_ClockCircleOutlined.default, null) : /*#__PURE__*/React.createElement(_CalendarOutlined.default, null), hasFeedback && feedbackIcon);
  120. (0, _react.useImperativeHandle)(ref, () => innerRef.current);
  121. const [contextLocale] = (0, _locale.useLocale)('Calendar', _en_US.default);
  122. const locale = Object.assign(Object.assign({}, contextLocale), props.locale);
  123. // ============================ zIndex ============================
  124. const [zIndex] = (0, _useZIndex.useZIndex)('DatePicker', (_a = mergedStyles.popup.root) === null || _a === void 0 ? void 0 : _a.zIndex);
  125. return wrapCSSVar(/*#__PURE__*/React.createElement(_ContextIsolator.default, {
  126. space: true
  127. }, /*#__PURE__*/React.createElement(_rcPicker.RangePicker, Object.assign({
  128. separator: /*#__PURE__*/React.createElement("span", {
  129. "aria-label": "to",
  130. className: `${prefixCls}-separator`
  131. }, /*#__PURE__*/React.createElement(_SwapRightOutlined.default, null)),
  132. disabled: mergedDisabled,
  133. ref: innerRef,
  134. placement: placement,
  135. placeholder: (0, _util.getRangePlaceholder)(locale, picker, placeholder),
  136. suffixIcon: suffixNode,
  137. prevIcon: /*#__PURE__*/React.createElement("span", {
  138. className: `${prefixCls}-prev-icon`
  139. }),
  140. nextIcon: /*#__PURE__*/React.createElement("span", {
  141. className: `${prefixCls}-next-icon`
  142. }),
  143. superPrevIcon: /*#__PURE__*/React.createElement("span", {
  144. className: `${prefixCls}-super-prev-icon`
  145. }),
  146. superNextIcon: /*#__PURE__*/React.createElement("span", {
  147. className: `${prefixCls}-super-next-icon`
  148. }),
  149. transitionName: `${rootPrefixCls}-slide-up`,
  150. picker: picker
  151. }, restProps, {
  152. className: (0, _classnames.default)({
  153. [`${prefixCls}-${mergedSize}`]: mergedSize,
  154. [`${prefixCls}-${variant}`]: enableVariantCls
  155. }, (0, _statusUtils.getStatusClassNames)(prefixCls, (0, _statusUtils.getMergedStatus)(contextStatus, customStatus), hasFeedback), hashId, compactItemClassnames, className, rangePicker === null || rangePicker === void 0 ? void 0 : rangePicker.className, cssVarCls, rootCls, rootClassName, mergedClassNames.root),
  156. style: Object.assign(Object.assign(Object.assign({}, rangePicker === null || rangePicker === void 0 ? void 0 : rangePicker.style), style), mergedStyles.root),
  157. locale: locale.lang,
  158. prefixCls: prefixCls,
  159. getPopupContainer: customGetPopupContainer || getPopupContainer,
  160. generateConfig: generateConfig,
  161. components: mergedComponents,
  162. direction: direction,
  163. classNames: {
  164. popup: (0, _classnames.default)(hashId, cssVarCls, rootCls, rootClassName, mergedClassNames.popup.root)
  165. },
  166. styles: {
  167. popup: Object.assign(Object.assign({}, mergedStyles.popup.root), {
  168. zIndex
  169. })
  170. },
  171. allowClear: mergedAllowClear
  172. }))));
  173. });
  174. if (process.env.NODE_ENV !== 'production') {
  175. RangePicker.displayName = 'RangePicker';
  176. }
  177. return RangePicker;
  178. };
  179. var _default = exports.default = generateRangePicker;