Column Instance APIs
Each column has a column
instance object associated with it that can be accessed in callback props and other places in the table.
You can access and use a column
instance in quite a few places, but here are some of the most common:
const columns = [{accessorKey: 'username',header: 'Username',//you can access a column instance in many callback functions in a column definition like thismuiTableHeadCellProps: ({ column }) => ({sx: {color: column.getIsSorted() ? 'red' : 'black',},}),//or in the component override callbacksHeader: ({ column }) => <div>{column.columnDef.header}</div>,Cell: ({ cell, column }) => (<Boxsx={{backgroundColor: column.getIsGrouped() ? 'green' : 'white',}}>{cell.getValue()}</Box>),},];return (<MaterialReactTablecolumns={columns}data={data}//or in callback props like thismuiTableBodyCellProps={({ column }) => ({sx:boxShadow: column.getIsPinned() ? '0 0 0 2px red' : 'none',}),}/>);
NOTE: These are NOT column options for Material React Table. These are just static methods on a column instance that you can use.
# | State Option | Type | More Info Links | |
---|---|---|---|---|
1 |
| TanStack Table Column API Docs | ||
2 |
| TanStack Table Sorting API Docs | ||
3 |
| TanStack Table Column API Docs | ||
4 |
| TanStack Table Column API Docs | ||
5 |
| TanStack Table Column API Docs | ||
6 |
| TanStack Table Grouping API Docs | ||
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 | ||||
Wanna see the source code for this table? Check it out down below!
1import { useEffect, useMemo, useState } from 'react';2import Link from 'next/link';3import {4 MaterialReactTable,5 type MRT_ColumnDef,6 type MRT_Column,7} from 'material-react-table';8import { Link as MuiLink, Typography, useMediaQuery } from '@mui/material';9import { SampleCodeSnippet } from '../mdx/SampleCodeSnippet';10import {11 type ColumnInstanceAPI,12 columnInstanceAPIs,13} from './columnInstanceAPIs';1415interface Props {16 onlyOptions?: Set<keyof MRT_Column<ColumnInstanceAPI>>;17}1819const ColumnInstanceAPIsTable = ({ onlyOptions }: Props) => {20 const isDesktop = useMediaQuery('(min-width: 1200px)');2122 const columns = useMemo<MRT_ColumnDef<ColumnInstanceAPI>[]>(23 () => [24 {25 accessorKey: 'columnInstanceAPI',26 enableClickToCopy: true,27 header: 'State Option',28 muiCopyButtonProps: ({ cell }) => ({29 className: 'column-instance-api',30 id: `${cell.getValue<string>()}-column-instance-api`,31 }),32 },33 {34 accessorKey: 'type',35 header: 'Type',36 enableGlobalFilter: false,37 Cell: ({ cell }) => (38 <SampleCodeSnippet39 className="language-ts"40 enableCopyButton={false}41 style={{42 backgroundColor: 'transparent',43 fontSize: '0.9rem',44 margin: 0,45 padding: 0,46 minHeight: 'unset',47 }}48 >49 {cell.getValue<string>()}50 </SampleCodeSnippet>51 ),52 },53 {54 accessorKey: 'link',55 disableFilters: true,56 enableGlobalFilter: false,57 header: 'More Info Links',58 Cell: ({ cell, row }) => (59 <Link href={cell.getValue<string>()} passHref legacyBehavior>60 <MuiLink61 target={62 cell.getValue<string>().startsWith('http')63 ? '_blank'64 : undefined65 }66 rel="noopener"67 >68 {row.original?.linkText}69 </MuiLink>70 </Link>71 ),72 },73 ],74 [],75 );7677 const [columnPinning, setColumnPinning] = useState({});7879 useEffect(() => {80 if (typeof window !== 'undefined') {81 if (isDesktop) {82 setColumnPinning({83 left: ['mrt-row-expand', 'mrt-row-numbers', 'columnInstanceAPI'],84 right: ['link'],85 });86 } else {87 setColumnPinning({});88 }89 }90 }, [isDesktop]);9192 const data = useMemo(() => {93 if (onlyOptions) {94 return columnInstanceAPIs.filter(({ columnInstanceAPI }) =>95 onlyOptions.has(columnInstanceAPI),96 );97 }98 return columnInstanceAPIs;99 }, [onlyOptions]);100101 return (102 <MaterialReactTable103 columns={columns}104 data={data}105 displayColumnDefOptions={{106 'mrt-row-numbers': {107 size: 10,108 },109 'mrt-row-expand': {110 size: 10,111 },112 }}113 enableColumnActions={!onlyOptions}114 enableColumnFilterModes115 enablePagination={false}116 enableColumnPinning117 enableRowNumbers118 enableBottomToolbar={false}119 enableTopToolbar={!onlyOptions}120 initialState={{121 columnVisibility: { description: false },122 density: 'compact',123 showGlobalFilter: true,124 sorting: [{ id: 'columnInstanceAPI', desc: false }],125 }}126 muiSearchTextFieldProps={{127 placeholder: 'Search Column APIs',128 sx: { minWidth: '18rem' },129 variant: 'outlined',130 }}131 muiTablePaperProps={{132 sx: { mb: '1.5rem' },133 id: onlyOptions134 ? 'relevant-column-instance-apis-table'135 : 'column-instance-apis-table',136 }}137 positionGlobalFilter="left"138 renderDetailPanel={({ row }) => (139 <Typography140 color={row.original.description ? 'secondary.main' : 'text.secondary'}141 >142 {row.original.description || 'No Description Provided... Yet...'}143 </Typography>144 )}145 rowNumberMode="static"146 onColumnPinningChange={setColumnPinning}147 state={{ columnPinning }}148 />149 );150};151152export default ColumnInstanceAPIsTable;153