@mantine/hooks
Version:
A collection of 50+ hooks for state and UI management
64 lines (63 loc) • 1.9 kB
JavaScript
"use client";
import { useDidUpdate } from "../use-did-update/use-did-update.mjs";
import { useCallback, useState } from "react";
//#region packages/@mantine/hooks/src/use-selection/use-selection.ts
function useSelection(input) {
const [selectionSet, setSelectionSet] = useState(new Set(input.defaultSelection || []));
useDidUpdate(() => {
if (input.resetSelectionOnDataChange) setSelectionSet(/* @__PURE__ */ new Set());
}, [input.data, input.resetSelectionOnDataChange]);
const select = useCallback((selected) => {
setSelectionSet((state) => {
if (!state.has(selected)) {
const newSet = new Set(state);
newSet.add(selected);
return newSet;
}
return state;
});
}, []);
const deselect = useCallback((deselected) => {
setSelectionSet((state) => {
if (state.has(deselected)) {
const newSet = new Set(state);
newSet.delete(deselected);
return newSet;
}
return state;
});
}, []);
const toggle = useCallback((toggled) => {
setSelectionSet((state) => {
const newSet = new Set(state);
if (state.has(toggled)) newSet.delete(toggled);
else newSet.add(toggled);
return newSet;
});
}, []);
const resetSelection = useCallback(() => {
setSelectionSet(/* @__PURE__ */ new Set());
}, []);
const setSelection = useCallback((selection) => {
setSelectionSet(new Set(selection));
}, []);
const isAllSelected = useCallback(() => {
if (input.data.length === 0) return false;
return input.data.every((item) => selectionSet.has(item));
}, [selectionSet, input.data]);
const isSomeSelected = useCallback(() => {
return input.data.some((item) => selectionSet.has(item));
}, [selectionSet, input.data]);
return [Array.from(selectionSet), {
select,
deselect,
toggle,
isAllSelected,
isSomeSelected,
setSelection,
resetSelection
}];
}
//#endregion
export { useSelection };
//# sourceMappingURL=use-selection.mjs.map