2022-12-14 16:22:38 +01:00
|
|
|
import { useEffect } from 'react';
|
|
|
|
|
|
|
|
interface IConditionallyHiddenColumns {
|
|
|
|
condition: boolean;
|
|
|
|
columns: string[];
|
|
|
|
}
|
|
|
|
|
|
|
|
export const useConditionallyHiddenColumns = (
|
|
|
|
conditionallyHiddenColumns: IConditionallyHiddenColumns[],
|
2022-12-16 10:46:04 +01:00
|
|
|
setHiddenColumns: (
|
|
|
|
columns: string[] | ((columns: string[]) => string[])
|
|
|
|
) => void,
|
2022-12-14 16:22:38 +01:00
|
|
|
columnsDefinition: unknown[]
|
|
|
|
) => {
|
|
|
|
useEffect(() => {
|
2022-12-16 10:46:04 +01:00
|
|
|
const columnsToHide = conditionallyHiddenColumns
|
2022-12-14 16:22:38 +01:00
|
|
|
.filter(({ condition }) => condition)
|
2022-12-16 10:46:04 +01:00
|
|
|
.flatMap(({ columns }) => columns);
|
|
|
|
|
|
|
|
const columnsToShow = conditionallyHiddenColumns
|
|
|
|
.flatMap(({ columns }) => columns)
|
|
|
|
.filter(column => !columnsToHide.includes(column));
|
2022-12-14 16:22:38 +01:00
|
|
|
|
2022-12-16 10:46:04 +01:00
|
|
|
setHiddenColumns(columns => [
|
|
|
|
...new Set(
|
|
|
|
[...columns, ...columnsToHide].filter(
|
|
|
|
column => !columnsToShow.includes(column)
|
|
|
|
)
|
|
|
|
),
|
|
|
|
]);
|
2022-12-14 16:22:38 +01:00
|
|
|
}, [
|
|
|
|
...conditionallyHiddenColumns.map(({ condition }) => condition),
|
|
|
|
setHiddenColumns,
|
|
|
|
columnsDefinition,
|
|
|
|
]);
|
|
|
|
};
|