All files / components/Users UsersTable.js

100% Statements 9/9
100% Branches 0/0
100% Functions 4/4
100% Lines 9/9

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"} />;
};