import React, { useMemo } from 'react'; import { useOutletContext } from 'react-router-dom'; import { MaterialReactTable, useMaterialReactTable, type MRT_ColumnDef, } from 'material-react-table'; import type { Guest } from '../models'; import { createTheme, ThemeProvider, useTheme } from '@mui/material'; function Dashboard() { const tableTheme = createTheme({ ...useTheme(), typography: { fontFamily: ['Roboto', 'sans-serif'].join(','), }, }); const guests: Guest[] = useOutletContext(); const columns = useMemo[]>( () => [ { accessorKey: 'firstName', header: 'First Name', size: 50, }, { accessorKey: 'lastName', header: 'Last Name', size: 50, }, { accessorKey: 'attendance', header: 'Attendance', size: 50, }, { accessorKey: 'email', header: 'Email', size: 150, }, { accessorKey: 'message', header: 'Message', size: 200, }, { accessorKey: 'partySize', header: 'Party Size', size: 50, }, ], [] ); const table = useMaterialReactTable({ columns, data: guests, muiPaginationProps: { color: 'primary', shape: 'rounded', showRowsPerPage: false, variant: 'outlined', }, paginationDisplayMode: 'pages', enableExpanding: true, filterFromLeafRows: true, getSubRows: (row) => row.partyList as Guest[], }); return (
); } export default Dashboard;