2023-07-23 22:12:43 +00:00
|
|
|
import _ from 'lodash';
|
2022-01-04 12:16:09 +00:00
|
|
|
import clsx from 'clsx';
|
|
|
|
import { Menu, MenuButton, MenuList } from '@reach/menu-button';
|
2022-11-28 02:00:28 +00:00
|
|
|
import { Columns } from 'lucide-react';
|
2023-05-02 06:42:16 +00:00
|
|
|
import { Column } from '@tanstack/react-table';
|
2022-01-04 12:16:09 +00:00
|
|
|
|
2022-06-17 16:18:42 +00:00
|
|
|
import { Checkbox } from '@@/form-components/Checkbox';
|
2022-01-04 12:16:09 +00:00
|
|
|
|
2022-01-23 19:48:04 +00:00
|
|
|
interface Props<D extends object> {
|
2023-05-02 06:42:16 +00:00
|
|
|
columns: Column<D>[];
|
2022-01-04 12:16:09 +00:00
|
|
|
onChange: (value: string[]) => void;
|
|
|
|
value: string[];
|
|
|
|
}
|
|
|
|
|
2022-01-23 19:48:04 +00:00
|
|
|
export function ColumnVisibilityMenu<D extends object>({
|
|
|
|
columns,
|
|
|
|
onChange,
|
|
|
|
value,
|
|
|
|
}: Props<D>) {
|
2022-01-04 12:16:09 +00:00
|
|
|
return (
|
|
|
|
<Menu className="setting">
|
|
|
|
{({ isExpanded }) => (
|
|
|
|
<>
|
|
|
|
<MenuButton
|
|
|
|
className={clsx('table-setting-menu-btn', {
|
|
|
|
'setting-active': isExpanded,
|
|
|
|
})}
|
|
|
|
>
|
2022-06-23 06:32:18 +00:00
|
|
|
<Columns
|
|
|
|
size="13"
|
|
|
|
className="space-right"
|
|
|
|
strokeWidth="3px"
|
|
|
|
aria-hidden="true"
|
|
|
|
aria-label="Columns"
|
|
|
|
/>
|
2022-01-04 12:16:09 +00:00
|
|
|
</MenuButton>
|
|
|
|
<MenuList>
|
|
|
|
<div className="tableMenu">
|
|
|
|
<div className="menuHeader">Show / Hide Columns</div>
|
|
|
|
<div className="menuContent">
|
|
|
|
{columns.map((column) => (
|
|
|
|
<div key={column.id}>
|
|
|
|
<Checkbox
|
2023-05-02 06:42:16 +00:00
|
|
|
checked={column.getIsVisible()}
|
|
|
|
label={
|
|
|
|
typeof column.columnDef.header === 'string'
|
|
|
|
? column.columnDef.header
|
2023-07-23 22:12:43 +00:00
|
|
|
: _.capitalize(column.columnDef.id)
|
2023-05-02 06:42:16 +00:00
|
|
|
}
|
2022-01-04 12:16:09 +00:00
|
|
|
id={`visibility_${column.id}`}
|
|
|
|
onChange={(e) =>
|
|
|
|
handleChangeColumnVisibility(
|
|
|
|
column.id,
|
|
|
|
e.target.checked
|
|
|
|
)
|
|
|
|
}
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
))}
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</MenuList>
|
|
|
|
</>
|
|
|
|
)}
|
|
|
|
</Menu>
|
|
|
|
);
|
|
|
|
|
|
|
|
function handleChangeColumnVisibility(colId: string, visible: boolean) {
|
|
|
|
if (visible) {
|
|
|
|
onChange(value.filter((id) => id !== colId));
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
onChange([...value, colId]);
|
|
|
|
}
|
|
|
|
}
|