All files / components/Users RoleEmailTable.jsx

100% Statements 10/10
100% Branches 10/10
100% Functions 6/6
100% Lines 8/8

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 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73                        37x               37x 4x     37x             37x   37x                 101x       5x                                                    
import OurTable from "main/components/OurTable";
import { useBackendMutation } from "main/utils/useBackend";
import { toast } from "react-toastify";
import { Button } from "react-bootstrap";
 
export default function RoleEmailTable({
  data,
  deleteEndpoint = "/api/admin/delete",
  getEndpoint = "/api/admin/all",
  testIdPrefix = "RoleEmailTable",
  customDeleteCallback = null,
}) {
  const cellToAxiosParamsDelete = (cell) => ({
    url: deleteEndpoint,
    method: "DELETE",
    params: {
      email: cell.row.original.email,
    },
  });
 
  const onDeleteSuccess = (message) => {
    toast(message);
  };
 
  const deleteMutation = useBackendMutation(
    cellToAxiosParamsDelete,
    { onSuccess: onDeleteSuccess },
    [getEndpoint],
  );
 
  const deleteCallback =
    customDeleteCallback || ((cell) => deleteMutation.mutate(cell));
 
  const columns = [
    {
      Header: "Email",
      accessor: "email",
    },
    {
      Header: "Delete",
      accessor: "isInAdminEmails",
      Cell: ({ cell }) => {
        if (!cell.row.original.isInAdminEmails) {
          return (
            <Button
              className="btn btn-danger"
              onClick={() => deleteCallback(cell)}
              data-testid={`${testIdPrefix}-cell-row-${cell.row.index}-col-delete-button`}
            >
              Delete
            </Button>
          );
        }
        return (
          <span
            data-testid={`${testIdPrefix}-cell-row-${cell.row.index}-cannot-delete`}
          >
            In <code>ADMIN_EMAILS</code>
          </span>
        );
      },
    },
  ];
 
  return (
    <OurTable
      data={Array.isArray(data) ? data : []}
      columns={columns}
      testid={testIdPrefix}
    />
  );
}