@react-hookz/web
Version:
React hooks done right, for browser and SSR.
49 lines (48 loc) • 1.46 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", { value: true });
exports.useSet = void 0;
var react_1 = require("react");
var __1 = require("..");
var proto = Set.prototype;
/**
* Tracks the state of a `Set`.
*
* @param values Initial values iterator for underlying `Set` constructor.
*/
// eslint-disable-next-line @typescript-eslint/no-explicit-any
function useSet(values) {
var setRef = (0, react_1.useRef)();
var rerender = (0, __1.useRerender)();
if (!setRef.current) {
var set_1 = new Set(values);
setRef.current = set_1;
set_1.add = function () {
var args = [];
for (var _i = 0; _i < arguments.length; _i++) {
args[_i] = arguments[_i];
}
proto.add.apply(set_1, args);
rerender();
return set_1;
};
set_1.clear = function () {
var args = [];
for (var _i = 0; _i < arguments.length; _i++) {
args[_i] = arguments[_i];
}
proto.clear.apply(set_1, args);
rerender();
};
set_1.delete = function () {
var args = [];
for (var _i = 0; _i < arguments.length; _i++) {
args[_i] = arguments[_i];
}
var res = proto.delete.apply(set_1, args);
rerender();
return res;
};
}
return setRef.current;
}
exports.useSet = useSet;