Press n or j to go to the next uncovered block, b, p or k for the previous block.
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 | 6x 6x 1x 1x 6x 12x 12x 6x 6x | import React from "react";
import OurTable, { ButtonColumn } from "main/components/OurTable"
import { formatTime } from "main/utils/dateUtils";
import { useNavigate } from 'react-router-dom';
export default function UsersTable({ users }) {
const navigate = useNavigate();
const suspendCallback = (row) => {
console.log(row)
navigate(`/admin/suspend/user/${row.row.values.id}`)
}
const columns = [
{
Header: 'id',
accessor: 'id', // accessor is the "key" in the data
},
{
Header: 'First Name',
accessor: 'givenName',
},
{
Header: 'Last Name',
accessor: 'familyName',
},
{
Header: 'Email',
accessor: 'email',
},
{
Header: 'Last Online',
id: 'lastOnline',
accessor: (row) => formatTime(row.lastOnline),
},
{
Header: 'Admin',
id: 'admin',
accessor: (row, _rowIndex) => String(row.admin) // hack needed for boolean values to show up
},
];
// don't need to check for admin because this page will not display if not admin
columns.push(ButtonColumn("Suspend", "danger", suspendCallback, "UsersTable"));
return <OurTable
data={users}
columns={columns}
testid={"UsersTable"} />;
}; |