@rc-component/input-number
Version:
React input-number component
115 lines (108 loc) • 5.12 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = StepHandler;
var React = _interopRequireWildcard(require("react"));
var _classnames = _interopRequireDefault(require("classnames"));
var _useMobile = _interopRequireDefault(require("@rc-component/util/lib/hooks/useMobile"));
var _raf = _interopRequireDefault(require("@rc-component/util/lib/raf"));
var _SemanticContext = _interopRequireDefault(require("./SemanticContext"));
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); } /* eslint-disable react/no-unknown-property */
/**
* When click and hold on a button - the speed of auto changing the value.
*/
const STEP_INTERVAL = 200;
/**
* When click and hold on a button - the delay before auto changing the value.
*/
const STEP_DELAY = 600;
function StepHandler({
prefixCls,
upNode,
downNode,
upDisabled,
downDisabled,
onStep
}) {
// ======================== Step ========================
const stepTimeoutRef = React.useRef();
const frameIds = React.useRef([]);
const onStepRef = React.useRef();
onStepRef.current = onStep;
const {
classNames,
styles
} = React.useContext(_SemanticContext.default) || {};
const onStopStep = () => {
clearTimeout(stepTimeoutRef.current);
};
// We will interval update step when hold mouse down
const onStepMouseDown = (e, up) => {
e.preventDefault();
onStopStep();
onStepRef.current(up, 'handler');
// Loop step for interval
function loopStep() {
onStepRef.current(up, 'handler');
stepTimeoutRef.current = setTimeout(loopStep, STEP_INTERVAL);
}
// First time press will wait some time to trigger loop step update
stepTimeoutRef.current = setTimeout(loopStep, STEP_DELAY);
};
React.useEffect(() => () => {
onStopStep();
frameIds.current.forEach(id => _raf.default.cancel(id));
}, []);
// ======================= Render =======================
const isMobile = (0, _useMobile.default)();
if (isMobile) {
return null;
}
const handlerClassName = `${prefixCls}-handler`;
const upClassName = (0, _classnames.default)(handlerClassName, `${handlerClassName}-up`, {
[`${handlerClassName}-up-disabled`]: upDisabled
});
const downClassName = (0, _classnames.default)(handlerClassName, `${handlerClassName}-down`, {
[`${handlerClassName}-down-disabled`]: downDisabled
});
// fix: https://github.com/ant-design/ant-design/issues/43088
// In Safari, When we fire onmousedown and onmouseup events in quick succession,
// there may be a problem that the onmouseup events are executed first,
// resulting in a disordered program execution.
// So, we need to use requestAnimationFrame to ensure that the onmouseup event is executed after the onmousedown event.
const safeOnStopStep = () => frameIds.current.push((0, _raf.default)(onStopStep));
const sharedHandlerProps = {
unselectable: 'on',
role: 'button',
onMouseUp: safeOnStopStep,
onMouseLeave: safeOnStopStep
};
return /*#__PURE__*/React.createElement("div", {
className: (0, _classnames.default)(`${handlerClassName}-wrap`, classNames?.actions),
style: styles?.actions
}, /*#__PURE__*/React.createElement("span", _extends({}, sharedHandlerProps, {
onMouseDown: e => {
onStepMouseDown(e, true);
},
"aria-label": "Increase Value",
"aria-disabled": upDisabled,
className: upClassName
}), upNode || /*#__PURE__*/React.createElement("span", {
unselectable: "on",
className: `${prefixCls}-handler-up-inner`
})), /*#__PURE__*/React.createElement("span", _extends({}, sharedHandlerProps, {
onMouseDown: e => {
onStepMouseDown(e, false);
},
"aria-label": "Decrease Value",
"aria-disabled": downDisabled,
className: downClassName
}), downNode || /*#__PURE__*/React.createElement("span", {
unselectable: "on",
className: `${prefixCls}-handler-down-inner`
})));
}