1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-01 00:08:27 +01:00
unleash.unleash/frontend/src/hooks/useConditionallyHiddenColumns.ts

37 lines
1.1 KiB
TypeScript
Raw Normal View History

import { useEffect } from 'react';
interface IConditionallyHiddenColumns {
condition: boolean;
columns: string[];
}
export const useConditionallyHiddenColumns = (
conditionallyHiddenColumns: IConditionallyHiddenColumns[],
setHiddenColumns: (
columns: string[] | ((columns: string[]) => string[]),
) => void,
columnsDefinition: unknown[],
) => {
useEffect(() => {
const columnsToHide = conditionallyHiddenColumns
.filter(({ condition }) => condition)
.flatMap(({ columns }) => columns);
const columnsToShow = conditionallyHiddenColumns
.flatMap(({ columns }) => columns)
.filter((column) => !columnsToHide.includes(column));
setHiddenColumns((columns) => [
...new Set(
[...columns, ...columnsToHide].filter(
(column) => !columnsToShow.includes(column),
),
),
]);
}, [
...conditionallyHiddenColumns.map(({ condition }) => condition),
setHiddenColumns,
columnsDefinition,
]);
};