UNPKG

antd

Version:

An enterprise-class UI design language and React components implementation

247 lines (246 loc) 8.89 kB
"use strict"; "use client"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _react = _interopRequireDefault(require("react")); var _slider = _interopRequireDefault(require("@rc-component/slider")); var _raf = _interopRequireDefault(require("@rc-component/util/lib/raf")); var _clsx = require("clsx"); var _hooks = require("../_util/hooks"); var _warning = require("../_util/warning"); var _context = require("../config-provider/context"); var _DisabledContext = _interopRequireDefault(require("../config-provider/DisabledContext")); var _Context = _interopRequireDefault(require("./Context")); var _SliderTooltip = _interopRequireDefault(require("./SliderTooltip")); var _style = _interopRequireDefault(require("./style")); var _useRafLock = _interopRequireDefault(require("./useRafLock")); function getTipFormatter(tipFormatter) { if (tipFormatter || tipFormatter === null) { return tipFormatter; } return val => typeof val === 'number' ? val.toString() : ''; } const Slider = /*#__PURE__*/_react.default.forwardRef((props, ref) => { const { prefixCls: customizePrefixCls, range, className, rootClassName, style, disabled, // Deprecated Props tooltip = {}, onChangeComplete, classNames, styles, vertical, orientation, ...restProps } = props; const [, mergedVertical] = (0, _hooks.useOrientation)(orientation, vertical); const { getPrefixCls, direction: contextDirection, className: contextClassName, style: contextStyle, classNames: contextClassNames, styles: contextStyles, getPopupContainer } = (0, _context.useComponentConfig)('slider'); const contextDisabled = _react.default.useContext(_DisabledContext.default); const mergedDisabled = disabled ?? contextDisabled; // =========== Merged Props for Semantic ========== const mergedProps = { ...props, disabled: mergedDisabled, vertical: mergedVertical }; const [mergedClassNames, mergedStyles] = (0, _hooks.useMergeSemantic)([contextClassNames, classNames], [contextStyles, styles], { props: mergedProps }); // ============================= Context ============================== const { handleRender: contextHandleRender, direction: internalContextDirection } = _react.default.useContext(_Context.default); const mergedDirection = internalContextDirection || contextDirection; const isRTL = mergedDirection === 'rtl'; // =============================== Open =============================== const [hoverOpen, setHoverOpen] = (0, _useRafLock.default)(); const [focusOpen, setFocusOpen] = (0, _useRafLock.default)(); const tooltipProps = { ...tooltip }; const { open: tooltipOpen, placement: tooltipPlacement, getPopupContainer: getTooltipPopupContainer, prefixCls: customizeTooltipPrefixCls, formatter: tipFormatter } = tooltipProps; const lockOpen = tooltipOpen; const activeOpen = (hoverOpen || focusOpen) && lockOpen !== false; const mergedTipFormatter = getTipFormatter(tipFormatter); // ============================= Change ============================== const [dragging, setDragging] = (0, _useRafLock.default)(); const onInternalChangeComplete = nextValues => { onChangeComplete?.(nextValues); setDragging(false); }; // ============================ Placement ============================ const getTooltipPlacement = (placement, vert) => { if (placement) { return placement; } if (!vert) { return 'top'; } return isRTL ? 'left' : 'right'; }; // ============================== Style =============================== const prefixCls = getPrefixCls('slider', customizePrefixCls); const [hashId, cssVarCls] = (0, _style.default)(prefixCls); const rootClassNames = (0, _clsx.clsx)(className, contextClassName, mergedClassNames.root, rootClassName, { [`${prefixCls}-rtl`]: isRTL, [`${prefixCls}-lock`]: dragging }, hashId, cssVarCls); // make reverse default on rtl direction if (isRTL && !mergedVertical) { restProps.reverse = !restProps.reverse; } // ============================= Warning ============================== // Warning for deprecated usage if (process.env.NODE_ENV !== 'production') { const warning = (0, _warning.devUseWarning)('Slider'); [['tooltipPrefixCls', 'prefixCls'], ['getTooltipPopupContainer', 'getPopupContainer'], ['tipFormatter', 'formatter'], ['tooltipPlacement', 'placement'], ['tooltipVisible', 'open']].forEach(([deprecatedName, newName]) => { warning.deprecated(!(deprecatedName in props), deprecatedName, `tooltip.${newName}`); }); } // ============================== Handle ============================== _react.default.useEffect(() => { const onMouseUp = () => { // Delay for 1 frame to make the click to enable hide tooltip // even when the handle is focused (0, _raf.default)(() => { setFocusOpen(false); }, 1); }; document.addEventListener('mouseup', onMouseUp); return () => { document.removeEventListener('mouseup', onMouseUp); }; }, []); const useActiveTooltipHandle = range && !lockOpen; const handleRender = contextHandleRender || ((node, info) => { const { index } = info; const nodeProps = node.props; function proxyEvent(eventName, event, triggerRestPropsEvent) { if (triggerRestPropsEvent) { restProps[eventName]?.(event); } nodeProps[eventName]?.(event); } const passedProps = { ...nodeProps, onMouseEnter: e => { setHoverOpen(true); proxyEvent('onMouseEnter', e); }, onMouseLeave: e => { setHoverOpen(false); proxyEvent('onMouseLeave', e); }, onMouseDown: e => { setFocusOpen(true); setDragging(true); proxyEvent('onMouseDown', e); }, onFocus: e => { setFocusOpen(true); restProps.onFocus?.(e); proxyEvent('onFocus', e, true); }, onBlur: e => { setFocusOpen(false); restProps.onBlur?.(e); proxyEvent('onBlur', e, true); } }; const cloneNode = /*#__PURE__*/_react.default.cloneElement(node, passedProps); const open = (!!lockOpen || activeOpen) && mergedTipFormatter !== null; // Wrap on handle with Tooltip when is single mode or multiple with all show tooltip if (!useActiveTooltipHandle) { return /*#__PURE__*/_react.default.createElement(_SliderTooltip.default, { ...tooltipProps, prefixCls: getPrefixCls('tooltip', customizeTooltipPrefixCls), title: mergedTipFormatter ? mergedTipFormatter(info.value) : '', value: info.value, open: open, placement: getTooltipPlacement(tooltipPlacement, mergedVertical), key: index, classNames: { root: `${prefixCls}-tooltip` }, getPopupContainer: getTooltipPopupContainer || getPopupContainer }, cloneNode); } return cloneNode; }); // ========================== Active Handle =========================== const activeHandleRender = useActiveTooltipHandle ? (handle, info) => { const cloneNode = /*#__PURE__*/_react.default.cloneElement(handle, { style: { ...handle.props.style, visibility: 'hidden' } }); return /*#__PURE__*/_react.default.createElement(_SliderTooltip.default, { ...tooltipProps, prefixCls: getPrefixCls('tooltip', customizeTooltipPrefixCls), title: mergedTipFormatter ? mergedTipFormatter(info.value) : '', open: mergedTipFormatter !== null && activeOpen, placement: getTooltipPlacement(tooltipPlacement, mergedVertical), key: "tooltip", classNames: { root: `${prefixCls}-tooltip` }, getPopupContainer: getTooltipPopupContainer || getPopupContainer, draggingDelete: info.draggingDelete }, cloneNode); } : undefined; // ============================== Render ============================== const rootStyle = { ...mergedStyles.root, ...contextStyle, ...style }; return ( /*#__PURE__*/ // @ts-ignore _react.default.createElement(_slider.default, { ...restProps, classNames: mergedClassNames, styles: mergedStyles, step: restProps.step, range: range, className: rootClassNames, style: rootStyle, disabled: mergedDisabled, vertical: mergedVertical, ref: ref, prefixCls: prefixCls, handleRender: handleRender, activeHandleRender: activeHandleRender, onChangeComplete: onInternalChangeComplete }) ); }); if (process.env.NODE_ENV !== 'production') { Slider.displayName = 'Slider'; } var _default = exports.default = Slider;