import { useMemo, useState, VFC } from 'react'; import { useSortBy, useTable } from 'react-table'; import { Table, TableBody, TableRow, TableCell, SortableTableHeader, } from 'component/common/Table'; import { Avatar, Box, SelectChangeEvent } from '@mui/material'; import { Delete } from '@mui/icons-material'; import { sortTypes } from 'utils/sortTypes'; import { IProjectAccessOutput, IProjectAccessUser, } from 'hooks/api/getters/useProjectAccess/useProjectAccess'; import { ProjectRoleCell } from './ProjectRoleCell/ProjectRoleCell'; import PermissionIconButton from 'component/common/PermissionIconButton/PermissionIconButton'; import { UPDATE_PROJECT } from 'component/providers/AccessProvider/permissions'; import { TextCell } from 'component/common/Table/cells/TextCell/TextCell'; interface IProjectAccessTableProps { access: IProjectAccessOutput; projectId: string; handleRoleChange: ( userId: number ) => (event: SelectChangeEvent) => Promise; handleRemoveAccess: (user: IProjectAccessUser) => void; } export const ProjectAccessTable: VFC = ({ access, projectId, handleRoleChange, handleRemoveAccess, }) => { const [initialState] = useState({}); const data = access.users; const columns = useMemo( () => [ { Header: 'Avatar', accessor: 'imageUrl', disableSortBy: true, width: 80, Cell: ({ value }: { value: string }) => ( ), align: 'center', }, { Header: 'Name', accessor: 'name', }, { Header: 'Username', id: 'username', accessor: 'email', Cell: ({ row: { original: user } }: any) => ( {user.email || user.username} ), }, { Header: 'Role', accessor: 'roleId', Cell: ({ value, row: { original: user }, }: { value: number; row: { original: IProjectAccessUser }; }) => ( ), }, { Header: 'Actions', id: 'actions', disableSortBy: true, align: 'center', width: 80, Cell: ({ row: { original: user } }: any) => ( handleRemoveAccess(user)} disabled={access.users.length === 1} tooltipProps={{ title: access.users.length === 1 ? 'Cannot remove access. A project must have at least one owner' : 'Remove access', }} > ), }, ], [ access.roles, access.users.length, handleRemoveAccess, handleRoleChange, projectId, ] ); const { getTableProps, getTableBodyProps, headerGroups, rows, prepareRow } = useTable( { columns: columns as any[], // TODO: fix after `react-table` v8 update data, initialState, sortTypes, autoResetGlobalFilter: false, autoResetSortBy: false, disableSortRemove: true, defaultColumn: { Cell: TextCell, }, }, useSortBy ); return ( {/* @ts-expect-error -- react-table */} {rows.map(row => { prepareRow(row); return ( {row.cells.map(cell => ( {cell.render('Cell')} ))} ); })}
); };