// ** React Imports import { ChangeEvent, MouseEvent, useState } from 'react' // ** MUI Imports import Box from '@mui/material/Box' import Table from '@mui/material/Table' import Paper from '@mui/material/Paper' import Toolbar from '@mui/material/Toolbar' import Tooltip from '@mui/material/Tooltip' import { visuallyHidden } from '@mui/utils' import { alpha } from '@mui/material/styles' import Checkbox from '@mui/material/Checkbox' import TableRow from '@mui/material/TableRow' import TableBody from '@mui/material/TableBody' import TableCell from '@mui/material/TableCell' import TableHead from '@mui/material/TableHead' import IconButton from '@mui/material/IconButton' import Typography from '@mui/material/Typography' import TableContainer from '@mui/material/TableContainer' import TableSortLabel from '@mui/material/TableSortLabel' import TablePagination from '@mui/material/TablePagination' // ** Icon Imports import Icon from 'src/@core/components/icon' type Order = 'asc' | 'desc' interface Data { fat: number name: string carbs: number protein: number calories: number } interface HeadCell { disablePadding: boolean id: keyof Data label: string numeric: boolean } interface EnhancedTableProps { numSelected: number onRequestSort: (event: MouseEvent, property: keyof Data) => void onSelectAllClick: (event: ChangeEvent) => void order: Order orderBy: string rowCount: number } interface EnhancedTableToolbarProps { numSelected: number } const createData = (name: string, calories: number, fat: number, carbs: number, protein: number): Data => { return { name, calories, fat, carbs, protein } } const rows = [ createData('Cupcake', 305, 3.7, 67, 4.3), createData('Donut', 452, 25.0, 51, 4.9), createData('Eclair', 262, 16.0, 24, 6.0), createData('Frozen yoghurt', 159, 6.0, 24, 4.0), createData('Gingerbread', 356, 16.0, 49, 3.9), createData('Honeycomb', 408, 3.2, 87, 6.5), createData('Ice cream sandwich', 237, 9.0, 37, 4.3), createData('Jelly Bean', 375, 0.0, 94, 0.0), createData('KitKat', 518, 26.0, 65, 7.0), createData('Lollipop', 392, 0.2, 98, 0.0), createData('Marshmallow', 318, 0, 81, 2.0), createData('Nougat', 360, 19.0, 9, 37.0), createData('Oreo', 437, 18.0, 63, 4.0) ] function descendingComparator(a: T, b: T, orderBy: keyof T) { if (b[orderBy] < a[orderBy]) { return -1 } if (b[orderBy] > a[orderBy]) { return 1 } return 0 } function getComparator( order: Order, orderBy: Key ): (a: { [key in Key]: number | string }, b: { [key in Key]: number | string }) => number { return order === 'desc' ? (a, b) => descendingComparator(a, b, orderBy) : (a, b) => -descendingComparator(a, b, orderBy) } // This method is created for cross-browser compatibility, if you don't // need to support IE11, you can use Array.prototype.sort() directly function stableSort(array: readonly T[], comparator: (a: T, b: T) => number) { const stabilizedThis = array.map((el, index) => [el, index] as [T, number]) stabilizedThis.sort((a, b) => { const order = comparator(a[0], b[0]) if (order !== 0) return order return a[1] - b[1] }) return stabilizedThis.map(el => el[0]) } const headCells: readonly HeadCell[] = [ { id: 'name', numeric: false, disablePadding: true, label: 'Dessert (100g serving)' }, { id: 'calories', numeric: true, disablePadding: false, label: 'Calories' }, { id: 'fat', numeric: true, disablePadding: false, label: 'Fat (g)' }, { id: 'carbs', numeric: true, disablePadding: false, label: 'Carbs (g)' }, { id: 'protein', numeric: true, disablePadding: false, label: 'Protein (g)' } ] function EnhancedTableHead(props: EnhancedTableProps) { // ** Props const { onSelectAllClick, order, orderBy, numSelected, rowCount, onRequestSort } = props const createSortHandler = (property: keyof Data) => (event: MouseEvent) => { onRequestSort(event, property) } return ( 0 && numSelected === rowCount} inputProps={{ 'aria-label': 'select all desserts' }} indeterminate={numSelected > 0 && numSelected < rowCount} /> {headCells.map(headCell => ( {headCell.label} {orderBy === headCell.id ? ( {order === 'desc' ? 'sorted descending' : 'sorted ascending'} ) : null} ))} ) } const EnhancedTableToolbar = (props: EnhancedTableToolbarProps) => { // ** Prop const { numSelected } = props return ( `${theme.spacing(5)} !important`, ...(numSelected > 0 && { bgcolor: theme => alpha(theme.palette.primary.main, theme.palette.action.activatedOpacity) }) }} > {numSelected > 0 ? ( {numSelected} selected ) : ( Sorting & Selecting )} {numSelected > 0 ? ( ) : null} ) } const EnhancedTable = () => { // ** States const [page, setPage] = useState(0) const [order, setOrder] = useState('asc') const [rowsPerPage, setRowsPerPage] = useState(5) const [orderBy, setOrderBy] = useState('calories') const [selected, setSelected] = useState([]) const handleRequestSort = (event: MouseEvent, property: keyof Data) => { const isAsc = orderBy === property && order === 'asc' setOrder(isAsc ? 'desc' : 'asc') setOrderBy(property) } const handleSelectAllClick = (event: ChangeEvent) => { if (event.target.checked) { const newSelecteds = rows.map(n => n.name) setSelected(newSelecteds) return } setSelected([]) } const handleClick = (event: MouseEvent, name: string) => { const selectedIndex = selected.indexOf(name) let newSelected: readonly string[] = [] if (selectedIndex === -1) { newSelected = newSelected.concat(selected, name) } else if (selectedIndex === 0) { newSelected = newSelected.concat(selected.slice(1)) } else if (selectedIndex === selected.length - 1) { newSelected = newSelected.concat(selected.slice(0, -1)) } else if (selectedIndex > 0) { newSelected = newSelected.concat(selected.slice(0, selectedIndex), selected.slice(selectedIndex + 1)) } setSelected(newSelected) } const handleChangePage = (event: unknown, newPage: number) => { setPage(newPage) } const handleChangeRowsPerPage = (event: ChangeEvent) => { setRowsPerPage(parseInt(event.target.value, 10)) setPage(0) } const isSelected = (name: string) => selected.indexOf(name) !== -1 // Avoid a layout jump when reaching the last page with empty rows. const emptyRows = page > 0 ? Math.max(0, (1 + page) * rowsPerPage - rows.length) : 0 return ( <> {/* if you don't need to support IE11, you can replace the `stableSort` call with: rows.slice().sort(getComparator(order, orderBy)) */} {stableSort(rows, getComparator(order, orderBy)) .slice(page * rowsPerPage, page * rowsPerPage + rowsPerPage) .map((row, index) => { const isItemSelected = isSelected(row.name) const labelId = `enhanced-table-checkbox-${index}` return ( handleClick(event, row.name)} > {row.name} {row.calories} {row.fat} {row.carbs} {row.protein} ) })} {emptyRows > 0 && ( )}
) } export default EnhancedTable