ahooks
Version:
react hooks library
131 lines (130 loc) • 3.81 kB
JavaScript
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = useHistoryTravel;
var _tslib = require("tslib");
var _react = require("react");
var _useMemoizedFn = _interopRequireDefault(require("../useMemoizedFn"));
var _utils = require("../utils");
var dumpIndex = function dumpIndex(step, arr) {
var index = step > 0 ? step - 1 // move forward
: arr.length + step; // move backward
if (index >= arr.length - 1) {
index = arr.length - 1;
}
if (index < 0) {
index = 0;
}
return index;
};
var split = function split(step, targetArr) {
var index = dumpIndex(step, targetArr);
return {
_current: targetArr[index],
_before: targetArr.slice(0, index),
_after: targetArr.slice(index + 1)
};
};
function useHistoryTravel(initialValue, maxLength) {
if (maxLength === void 0) {
maxLength = 0;
}
var _a = (0, _tslib.__read)((0, _react.useState)({
present: initialValue,
past: [],
future: []
}), 2),
history = _a[0],
setHistory = _a[1];
var present = history.present,
past = history.past,
future = history.future;
var initialValueRef = (0, _react.useRef)(initialValue);
var reset = function reset() {
var params = [];
for (var _i = 0; _i < arguments.length; _i++) {
params[_i] = arguments[_i];
}
var _initial = params.length > 0 ? params[0] : initialValueRef.current;
initialValueRef.current = _initial;
setHistory({
present: _initial,
future: [],
past: []
});
};
var updateValue = function updateValue(val) {
var _past = (0, _tslib.__spreadArray)((0, _tslib.__spreadArray)([], (0, _tslib.__read)(past), false), [present], false);
var maxLengthNum = (0, _utils.isNumber)(maxLength) ? maxLength : Number(maxLength);
// maximum number of records exceeded
if (maxLengthNum > 0 && _past.length > maxLengthNum) {
//delete first
_past.splice(0, 1);
}
setHistory({
present: val,
future: [],
past: _past
});
};
var _forward = function _forward(step) {
if (step === void 0) {
step = 1;
}
if (future.length === 0) {
return;
}
var _a = split(step, future),
_before = _a._before,
_current = _a._current,
_after = _a._after;
setHistory({
past: (0, _tslib.__spreadArray)((0, _tslib.__spreadArray)((0, _tslib.__spreadArray)([], (0, _tslib.__read)(past), false), [present], false), (0, _tslib.__read)(_before), false),
present: _current,
future: _after
});
};
var _backward = function _backward(step) {
if (step === void 0) {
step = -1;
}
if (past.length === 0) {
return;
}
var _a = split(step, past),
_before = _a._before,
_current = _a._current,
_after = _a._after;
setHistory({
past: _before,
present: _current,
future: (0, _tslib.__spreadArray)((0, _tslib.__spreadArray)((0, _tslib.__spreadArray)([], (0, _tslib.__read)(_after), false), [present], false), (0, _tslib.__read)(future), false)
});
};
var go = function go(step) {
var stepNum = (0, _utils.isNumber)(step) ? step : Number(step);
if (stepNum === 0) {
return;
}
if (stepNum > 0) {
return _forward(stepNum);
}
_backward(stepNum);
};
return {
value: present,
backLength: past.length,
forwardLength: future.length,
setValue: (0, _useMemoizedFn["default"])(updateValue),
go: (0, _useMemoizedFn["default"])(go),
back: (0, _useMemoizedFn["default"])(function () {
go(-1);
}),
forward: (0, _useMemoizedFn["default"])(function () {
go(1);
}),
reset: (0, _useMemoizedFn["default"])(reset)
};
}
;