Skip to content

Commit

Permalink
refactor column info stuff
Browse files Browse the repository at this point in the history
  • Loading branch information
KevinVandy committed Feb 26, 2024
1 parent f705a2d commit d02abcc
Show file tree
Hide file tree
Showing 14 changed files with 114 additions and 108 deletions.
8 changes: 8 additions & 0 deletions apps/material-react-table-docs/pages/changelog.mdx
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,14 @@ import Head from 'next/head';

## MRT V2 Changelog

> Note: As of v2.12.0, the React and ReactDom peer dependencies have been moved back down to React v17 in order to help more people upgrade to MRT v2 without having to upgrade to React v18.
### Version 2.12.0 - 2024-02-26

- **Marked React 17 as a peer dependency instead of React 18 since concurrent features are not yet being utilized under the hood in MRT**
- Filter label tooltip will show label instead of value when a label is provided to filterSelectOptions
- Fixed Column and Row Dragging element animation to not go back to where it started when dragging

### Version 2.11.3 - 2024-02-14

- Upgraded to TanStack Table v8.12.0 for new column pinning/sizing/pinning instance APIs and better column resizing performance
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -20,7 +20,7 @@ import { FAQs } from '../../../components/mdx/FAQs';
> 3. `@mui/icons-material` (v5)
> 4. `@emotion/react` (v11)
> 5. `@emotion/styled` (v11)
> 6. `react` and `react-dom` (v18) - (MRT v2 will eventually use React 18 concurrent mode)
> 6. `react` and `react-dom` (v17+)
### Quick Install

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,8 @@ import { InstallCommand } from '../../../components/mdx/InstallCommand';

This should be an easy to moderate upgrade for most developers. The only breaking changes have to do with the removed `tableInstanceRef`, some renamed props/options, and new column sizing behaviors.

> Note: As of v2.12.0, the React and ReactDom peer dependencies have been moved back down to React v17 in order to help more people upgrade to MRT v2 without having to upgrade to React v18.
### New Feature Highlights

1. New optional but recommended `useMaterialReactTable` hook that allows you to create the `table` instance in your own scope
Expand Down
51 changes: 29 additions & 22 deletions packages/material-react-table/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -16,9 +16,6 @@ View [Documentation](https://www.material-react-table.com/)
</a>
<a href="https://github.com/KevinVandy/material-react-table/blob/v2/LICENSE" target="_blank">
<img alt="" src="https://badgen.net/github/license/KevinVandy/material-react-table?color=blue" />
</a>
<a href="http://makeapullrequest.com" target="_blank">
<img alt="" src="https://img.shields.io/badge/PRs-welcome-brightgreen.svg?style=flat-square" />
</a>
<a
href="https://github.com/sponsors/kevinvandy"
Expand All @@ -27,14 +24,21 @@ View [Documentation](https://www.material-react-table.com/)
>
<img alt="" src="https://img.shields.io/badge/sponsor-violet" />
</a>
<a
href="https://discord.gg/5wqyRx6fnm"
target="_blank"
rel="noopener"
>
<img alt="" src="https://dcbadge.vercel.app/api/server/5wqyRx6fnm?style=flat">
</a>
## About

### _Quickly Create React Data Tables with Material Design_

### __Built with [Material UI <sup>V5</sup>](https://mui.com) and [TanStack Table <sup>V8</sup>](https://tanstack.com/table/v8)__
### **Built with [Material UI <sup>V5</sup>](https://mui.com) and [TanStack Table <sup>V8</sup>](https://tanstack.com/table/v8)**

<img src="https://material-react-table.com/banner.png" alt="MRT" height="50"/>
<img src="https://material-react-table.com/banner.png" alt="MRT" height="50" />

> Want to use Mantine instead of Material UI? Check out [Mantine React Table](https://www.mantine-react-table.com)
Expand All @@ -46,19 +50,19 @@ View [Documentation](https://www.material-react-table.com/)

### Quick Examples

- [Basic Table](https://www.material-react-table.com/docs/examples/basic/) (See Default Features)
- [Minimal Table](https://www.material-react-table.com/docs/examples/minimal/) (Turn off Features like Pagination, Sorting, Filtering, and Toolbars)
- [Advanced Table](https://www.material-react-table.com/docs/examples/advanced/) (See some of the Advanced Features)
- [Custom Headless Table](https://www.material-react-table.com/docs/examples/custom-headless/) (Build your own table markup)
- [Dragging / Ordering Examples](https://www.material-react-table.com/docs/examples/column-ordering/) (Drag and Drop)
- [Editing (CRUD) Examples](https://www.material-react-table.com/docs/examples/editing-crud/) (Create, Edit, and Delete Rows)
- [Expanding / Grouping Examples](https://www.material-react-table.com/docs/examples/aggregation-and-grouping/) (Sum, Average, Count, etc.)
- [Filtering Examples](https://www.material-react-table.com/docs/examples/filter-variants/) (Faceted Values, Switching Filters, etc.)
- [Sticky Pinning Examples](https://www.material-react-table.com/docs/examples/sticky-header/) (Sticky Headers, Sticky Columns, Sticky Rows, etc.)
- [Remote Data Fetching Examples](https://www.material-react-table.com/docs/examples/react-query/) (Server-side Pagination, Sorting, and Filtering)
- [Virtualized Examples](https://www.material-react-table.com/docs/examples/virtualized/) (10,000 rows at once!)
- [Infinite Scrolling](https://www.material-react-table.com/docs/examples/infinite-scrolling/) (Fetch data as you scroll)
- [Localization (i18n)](https://www.material-react-table.com/docs/guides/localization#built-in-locale-examples) (Over a dozen languages built-in)
- [Basic Table](https://www.material-react-table.com/docs/examples/basic/) (See Default Features)
- [Minimal Table](https://www.material-react-table.com/docs/examples/minimal/) (Turn off Features like Pagination, Sorting, Filtering, and Toolbars)
- [Advanced Table](https://www.material-react-table.com/docs/examples/advanced/) (See some of the Advanced Features)
- [Custom Headless Table](https://www.material-react-table.com/docs/examples/custom-headless/) (Build your own table markup)
- [Dragging / Ordering Examples](https://www.material-react-table.com/docs/examples/column-ordering/) (Drag and Drop)
- [Editing (CRUD) Examples](https://www.material-react-table.com/docs/examples/editing-crud/) (Create, Edit, and Delete Rows)
- [Expanding / Grouping Examples](https://www.material-react-table.com/docs/examples/aggregation-and-grouping/) (Sum, Average, Count, etc.)
- [Filtering Examples](https://www.material-react-table.com/docs/examples/filter-variants/) (Faceted Values, Switching Filters, etc.)
- [Sticky Pinning Examples](https://www.material-react-table.com/docs/examples/sticky-header/) (Sticky Headers, Sticky Columns, Sticky Rows, etc.)
- [Remote Data Fetching Examples](https://www.material-react-table.com/docs/examples/react-query/) (Server-side Pagination, Sorting, and Filtering)
- [Virtualized Examples](https://www.material-react-table.com/docs/examples/virtualized/) (10,000 rows at once!)
- [Infinite Scrolling](https://www.material-react-table.com/docs/examples/infinite-scrolling/) (Fetch data as you scroll)
- [Localization (i18n)](https://www.material-react-table.com/docs/guides/localization#built-in-locale-examples) (Over a dozen languages built-in)

View additional [storybook examples](https://www.material-react-table.dev/)

Expand All @@ -68,7 +72,7 @@ _All features can easily be enabled/disabled_

_**Fully Fleshed out [Docs](https://www.material-react-table.com/docs/guides#guides) are available for all features**_

- [x] 30-54kb gzipped - [Bundlephobia](https://bundlephobia.com/package/material-react-table)
- [x] 30-56kb gzipped - [Bundlephobia](https://bundlephobia.com/package/material-react-table)
- [x] Advanced TypeScript Generics Support (TypeScript Optional)
- [x] Aggregation and Grouping (Sum, Average, Count, etc.)
- [x] Cell Actions (Right-click Context Menu)
Expand Down Expand Up @@ -132,7 +136,10 @@ npm install material-react-table
```jsx
import { useMemo, useState, useEffect } from 'react';
import { MaterialReactTable, useMaterialReactTable } from 'material-react-table';
import {
MaterialReactTable,
useMaterialReactTable,
} from 'material-react-table';

//data must be stable reference (useState, useMemo, useQuery, defined outside of component, etc.)
const data = [
Expand All @@ -144,7 +151,7 @@ const data = [
name: 'Sara',
age: 25,
},
]
];

export default function App() {
const columns = useMemo(
Expand Down Expand Up @@ -185,7 +192,7 @@ export default function App() {
const someEventHandler = () => {
//read the table state during an event from the table instance
console.log(table.getState().sorting);
}
};

return (
<MaterialReactTable table={table} /> //other more lightweight MRT sub components also available
Expand Down
6 changes: 3 additions & 3 deletions packages/material-react-table/package.json
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
{
"version": "2.11.3",
"version": "2.12.0",
"license": "MIT",
"name": "material-react-table",
"description": "A fully featured Material UI V5 implementation of TanStack React Table V8, written from the ground up in TypeScript.",
Expand Down Expand Up @@ -111,8 +111,8 @@
"@mui/icons-material": ">=5.11",
"@mui/material": ">=5.13",
"@mui/x-date-pickers": ">=6.15.0",
"react": ">=18.0",
"react-dom": ">=18.0"
"react": ">=17.0",
"react-dom": ">=17.0"
},
"dependencies": {
"@tanstack/match-sorter-utils": "8.11.8",
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -211,7 +211,9 @@ export const MRT_TableBodyCell = <TData extends MRT_RowData>({
};

const handleDragOver = (e: DragEvent) => {
e.preventDefault();
if (columnDef.enableColumnOrdering !== false) {
e.preventDefault();
}
};

const handleContextMenu = (e: MouseEvent<HTMLTableCellElement>) => {
Expand Down
22 changes: 11 additions & 11 deletions packages/material-react-table/src/components/head/MRT_TableHead.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -20,8 +20,6 @@ export const MRT_TableHead = <TData extends MRT_RowData>({
...rest
}: MRT_TableHeadProps<TData>) => {
const {
getHeaderGroups,
getSelectedRowModel,
getState,
options: {
enableStickyHeader,
Expand Down Expand Up @@ -60,7 +58,7 @@ export const MRT_TableHead = <TData extends MRT_RowData>({
})}
>
{positionToolbarAlertBanner === 'head-overlay' &&
(showAlertBanner || getSelectedRowModel().rows.length > 0) ? (
(showAlertBanner || table.getSelectedRowModel().rows.length > 0) ? (
<tr
style={{
display: layoutMode?.startsWith('grid') ? 'grid' : undefined,
Expand All @@ -77,14 +75,16 @@ export const MRT_TableHead = <TData extends MRT_RowData>({
</th>
</tr>
) : (
getHeaderGroups().map((headerGroup) => (
<MRT_TableHeadRow
columnVirtualizer={columnVirtualizer}
headerGroup={headerGroup as any}
key={headerGroup.id}
table={table}
/>
))
table
.getHeaderGroups()
.map((headerGroup) => (
<MRT_TableHeadRow
columnVirtualizer={columnVirtualizer}
headerGroup={headerGroup as any}
key={headerGroup.id}
table={table}
/>
))
)}
</TableHead>
);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,6 @@ import {
type MRT_RowData,
type MRT_TableInstance,
} from '../../types';
import { useColumnFilterInfo } from '../../utils/column.utils';
import { getCommonMRTCellStyles } from '../../utils/style.utils';
import { parseFromValuesOrFunc } from '../../utils/utils';

Expand Down Expand Up @@ -75,11 +74,6 @@ export const MRT_TableHeadCell = <TData extends MRT_RowData>({
...rest,
};

const columnFilterInfo = useColumnFilterInfo({
header,
table,
});

const isColumnPinned =
enableColumnPinning &&
columnDef.columnDefType !== 'group' &&
Expand Down Expand Up @@ -148,7 +142,9 @@ export const MRT_TableHeadCell = <TData extends MRT_RowData>({
};

const handleDragOver = (e: DragEvent) => {
e.preventDefault();
if (columnDef.enableColumnOrdering !== false) {
e.preventDefault();
}
};

const HeaderElement =
Expand Down Expand Up @@ -282,11 +278,7 @@ export const MRT_TableHeadCell = <TData extends MRT_RowData>({
{HeaderElement}
</Box>
{column.getCanFilter() && (
<MRT_TableHeadCellFilterLabel
columnFilterInfo={columnFilterInfo}
header={header}
table={table}
/>
<MRT_TableHeadCellFilterLabel header={header} table={table} />
)}
{column.getCanSort() && (
<MRT_TableHeadCellSortLabel header={header} table={table} />
Expand Down Expand Up @@ -322,11 +314,7 @@ export const MRT_TableHeadCell = <TData extends MRT_RowData>({
</Box>
)}
{columnFilterDisplayMode === 'subheader' && column.getCanFilter() && (
<MRT_TableHeadCellFilterContainer
columnFilterInfo={columnFilterInfo}
header={header}
table={table}
/>
<MRT_TableHeadCellFilterContainer header={header} table={table} />
)}
</TableCell>
);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@ import {
type MRT_RowData,
type MRT_TableInstance,
} from '../../types';
import { type ColumnFilterInfo } from '../../utils/column.utils';
import { getColumnFilterInfo } from '../../utils/column.utils';
import { MRT_FilterCheckbox } from '../inputs/MRT_FilterCheckbox';
import { MRT_FilterRangeFields } from '../inputs/MRT_FilterRangeFields';
import { MRT_FilterRangeSlider } from '../inputs/MRT_FilterRangeSlider';
Expand All @@ -13,13 +13,11 @@ import { MRT_FilterTextField } from '../inputs/MRT_FilterTextField';
export interface MRT_TableHeadCellFilterContainerProps<
TData extends MRT_RowData,
> extends CollapseProps {
columnFilterInfo: ColumnFilterInfo;
header: MRT_Header<TData>;
table: MRT_TableInstance<TData>;
}

export const MRT_TableHeadCellFilterContainer = <TData extends MRT_RowData>({
columnFilterInfo,
header,
table,
...rest
Expand All @@ -31,7 +29,7 @@ export const MRT_TableHeadCellFilterContainer = <TData extends MRT_RowData>({
const { showColumnFilters } = getState();
const { column } = header;
const { columnDef } = column;
const { isRangeFilter } = columnFilterInfo;
const { isRangeFilter } = getColumnFilterInfo({ header, table });

return (
<Collapse
Expand All @@ -45,17 +43,9 @@ export const MRT_TableHeadCellFilterContainer = <TData extends MRT_RowData>({
) : columnDef.filterVariant === 'range-slider' ? (
<MRT_FilterRangeSlider header={header} table={table} />
) : isRangeFilter ? (
<MRT_FilterRangeFields
columnFilterInfo={columnFilterInfo}
header={header}
table={table}
/>
<MRT_FilterRangeFields header={header} table={table} />
) : (
<MRT_FilterTextField
columnFilterInfo={columnFilterInfo}
header={header}
table={table}
/>
<MRT_FilterTextField header={header} table={table} />
)}
</Collapse>
);
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,18 +10,19 @@ import {
type MRT_RowData,
type MRT_TableInstance,
} from '../../types';
import { type ColumnFilterInfo } from '../../utils/column.utils';
import {
getColumnFilterInfo,
useDropdownOptions,
} from '../../utils/column.utils';
import { getValueAndLabel, parseFromValuesOrFunc } from '../../utils/utils';

export interface MRT_TableHeadCellFilterLabelProps<TData extends MRT_RowData>
extends IconButtonProps {
columnFilterInfo: ColumnFilterInfo;
header: MRT_Header<TData>;
table: MRT_TableInstance<TData>;
}

export const MRT_TableHeadCellFilterLabel = <TData extends MRT_RowData = {}>({
columnFilterInfo,
header,
table,
...rest
Expand All @@ -44,11 +45,12 @@ export const MRT_TableHeadCellFilterLabel = <TData extends MRT_RowData = {}>({

const {
currentFilterOption,
dropdownOptions,
isMultiSelectFilter,
isRangeFilter,
isSelectFilter,
} = columnFilterInfo;
} = getColumnFilterInfo({ header, table });

const dropdownOptions = useDropdownOptions({ header, table });

const getSelectLabel = (index?: number) =>
getValueAndLabel(
Expand Down Expand Up @@ -169,11 +171,7 @@ export const MRT_TableHeadCellFilterLabel = <TData extends MRT_RowData = {}>({
}}
>
<Box sx={{ p: '1rem' }}>
<MRT_TableHeadCellFilterContainer
columnFilterInfo={columnFilterInfo}
header={header}
table={table}
/>
<MRT_TableHeadCellFilterContainer header={header} table={table} />
</Box>
</Popover>
)}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -5,18 +5,15 @@ import {
type MRT_RowData,
type MRT_TableInstance,
} from '../../types';
import { type ColumnFilterInfo } from '../../utils/column.utils';
import { parseFromValuesOrFunc } from '../../utils/utils';

export interface MRT_FilterRangeFieldsProps<TData extends MRT_RowData>
extends BoxProps {
columnFilterInfo: ColumnFilterInfo;
header: MRT_Header<TData>;
table: MRT_TableInstance<TData>;
}

export const MRT_FilterRangeFields = <TData extends MRT_RowData>({
columnFilterInfo,
header,
table,
...rest
Expand All @@ -33,7 +30,6 @@ export const MRT_FilterRangeFields = <TData extends MRT_RowData>({
>
{[0, 1].map((rangeFilterIndex) => (
<MRT_FilterTextField
columnFilterInfo={columnFilterInfo}
header={header}
key={rangeFilterIndex}
rangeFilterIndex={rangeFilterIndex}
Expand Down
Loading

0 comments on commit d02abcc

Please sign in to comment.