linkmore-design
Version:
π πlmη»δ»ΆεΊγπ
127 lines (124 loc) β’ 5.51 kB
JavaScript
import _extends from "@babel/runtime/helpers/esm/extends";
import _typeof from "@babel/runtime/helpers/esm/typeof";
import _objectWithoutProperties from "@babel/runtime/helpers/esm/objectWithoutProperties";
import _defineProperty from "@babel/runtime/helpers/esm/defineProperty";
import _objectSpread from "@babel/runtime/helpers/esm/objectSpread2";
import _slicedToArray from "@babel/runtime/helpers/esm/slicedToArray";
var _excluded = ["prefixCls", "range", "className"];
import classNames from 'classnames';
import RcSlider from 'rc-slider';
import * as React from 'react';
import { ConfigContext } from "../config-provider";
import warning from "../_util/warning";
import SliderTooltip from "./SliderTooltip";
var Slider = /*#__PURE__*/React.forwardRef(function (props, ref) {
var _React$useContext = React.useContext(ConfigContext),
getPrefixCls = _React$useContext.getPrefixCls,
direction = _React$useContext.direction,
getPopupContainer = _React$useContext.getPopupContainer;
var _React$useState = React.useState({}),
_React$useState2 = _slicedToArray(_React$useState, 2),
opens = _React$useState2[0],
setOpens = _React$useState2[1];
var toggleTooltipOpen = function toggleTooltipOpen(index, open) {
setOpens(function (prev) {
return _objectSpread(_objectSpread({}, prev), {}, _defineProperty({}, index, open));
});
};
var getTooltipPlacement = function getTooltipPlacement(tooltipPlacement, vertical) {
if (tooltipPlacement) {
return tooltipPlacement;
}
if (!vertical) {
return 'top';
}
return direction === 'rtl' ? 'left' : 'right';
};
var customizePrefixCls = props.prefixCls,
range = props.range,
className = props.className,
restProps = _objectWithoutProperties(props, _excluded);
var prefixCls = getPrefixCls('slider', customizePrefixCls);
var cls = classNames(className, _defineProperty({}, "".concat(prefixCls, "-rtl"), direction === 'rtl'));
// make reverse default on rtl direction
if (direction === 'rtl' && !restProps.vertical) {
restProps.reverse = !restProps.reverse;
}
// Range config
var _React$useMemo = React.useMemo(function () {
if (!range) {
return [false];
}
return _typeof(range) === 'object' ? [true, range.draggableTrack] : [true, false];
}, [range]),
_React$useMemo2 = _slicedToArray(_React$useMemo, 2),
mergedRange = _React$useMemo2[0],
draggableTrack = _React$useMemo2[1];
// Warning for deprecated usage
if (process.env.NODE_ENV !== 'production') {
[['tooltipPrefixCls', 'prefixCls'], ['getTooltipPopupContainer', 'getPopupContainer'], ['tipFormatter', 'formatter'], ['tooltipPlacement', 'placement'], ['tooltipVisible', 'open']].forEach(function (_ref) {
var _ref2 = _slicedToArray(_ref, 2),
deprecatedName = _ref2[0],
newName = _ref2[1];
warning(!(deprecatedName in props), 'Slider', "`".concat(deprecatedName, "` is deprecated which will be removed in next major version, please use `tooltip.").concat(newName, "` instead."));
});
}
var handleRender = function handleRender(node, info) {
var _props$tipFormatter;
var index = info.index,
dragging = info.dragging;
var rootPrefixCls = getPrefixCls();
var _props$tooltip = props.tooltip,
tooltip = _props$tooltip === void 0 ? {} : _props$tooltip,
vertical = props.vertical;
var tooltipProps = _objectSpread({
formatter: (_props$tipFormatter = props.tipFormatter) !== null && _props$tipFormatter !== void 0 ? _props$tipFormatter :
// eslint-disable-next-line func-names
function (value) {
return typeof value === 'number' ? value.toString() : '';
},
open: props.tooltipVisible,
placement: props.tooltipPlacement,
getPopupContainer: props.getTooltipPopupContainer
}, tooltip);
var tooltipOpen = tooltipProps.open,
tooltipPlacement = tooltipProps.placement,
getTooltipPopupContainer = tooltipProps.getPopupContainer,
customizeTooltipPrefixCls = tooltipProps.prefixCls,
tipFormatter = tooltipProps.formatter;
var isTipFormatter = tipFormatter ? opens[index] || dragging : false;
var open = tooltipOpen || tooltipOpen === undefined && isTipFormatter;
var passedProps = _objectSpread(_objectSpread({}, node.props), {}, {
onMouseEnter: function onMouseEnter() {
return toggleTooltipOpen(index, true);
},
onMouseLeave: function onMouseLeave() {
return toggleTooltipOpen(index, false);
}
});
var tooltipPrefixCls = getPrefixCls('tooltip', customizeTooltipPrefixCls);
return /*#__PURE__*/React.createElement(SliderTooltip, {
prefixCls: tooltipPrefixCls,
title: tipFormatter ? tipFormatter(info.value) : '',
open: open,
placement: getTooltipPlacement(tooltipPlacement, vertical),
transitionName: "".concat(rootPrefixCls, "-zoom-down"),
key: index,
overlayClassName: "".concat(prefixCls, "-tooltip"),
getPopupContainer: getTooltipPopupContainer || getPopupContainer
}, /*#__PURE__*/React.cloneElement(node, passedProps));
};
return /*#__PURE__*/React.createElement(RcSlider, _extends({}, restProps, {
step: restProps.step,
range: mergedRange,
draggableTrack: draggableTrack,
className: cls,
ref: ref,
prefixCls: prefixCls,
handleRender: handleRender
}));
});
if (process.env.NODE_ENV !== 'production') {
Slider.displayName = 'Slider';
}
export default Slider;