tss-react
Version:
Type safe CSS-in-JS API heavily inspired by react-jss
21 lines (20 loc) • 726 B
JavaScript
;
Object.defineProperty(exports, "__esModule", { value: true });
exports.useGuaranteedMemo = void 0;
const react_1 = require("react");
/** Like react's useMemo but with guarantee that the fn
* won't be invoked again if deps hasn't change */
function useGuaranteedMemo(fn, deps) {
var _a;
const ref = (0, react_1.useRef)();
if (!ref.current ||
deps.length !== ((_a = ref.current.prevDeps) === null || _a === void 0 ? void 0 : _a.length) ||
ref.current.prevDeps.map((v, i) => v === deps[i]).indexOf(false) >= 0) {
ref.current = {
"v": fn(),
"prevDeps": [...deps]
};
}
return ref.current.v;
}
exports.useGuaranteedMemo = useGuaranteedMemo;