Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[DataGrid] Filtering performance: V7 API #9254

Merged
merged 46 commits into from
Jun 28, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
46 commits
Select commit Hold shift + click to select a range
fb1ea84
perf: v7 filters
romgrk Jun 7, 2023
9830c58
lint
romgrk Jun 7, 2023
9608d9d
fix: aggregation filtering
romgrk Jun 7, 2023
fad4bb2
lint
romgrk Jun 7, 2023
030f2a5
fix: some tests
romgrk Jun 7, 2023
1b063cb
Merge branch 'master' into perf-filtering-v7-filters
romgrk Jun 9, 2023
64ba858
fix: some tests
romgrk Jun 9, 2023
2c4d970
fix: rows list
romgrk Jun 9, 2023
40e05b4
fix: quickfilter
romgrk Jun 9, 2023
c24143a
lint
romgrk Jun 9, 2023
e8a8aec
lint
romgrk Jun 9, 2023
a7483b4
lint
romgrk Jun 9, 2023
6fd694f
lint
romgrk Jun 9, 2023
d1be29a
fix: restore column fields
romgrk Jun 12, 2023
3e0a6bc
Merge branch 'master' into perf-filtering-v7-filters
romgrk Jun 14, 2023
b04cb1e
refactor
romgrk Jun 14, 2023
f7cb7b6
docs
romgrk Jun 14, 2023
9fdbe9a
lint
romgrk Jun 14, 2023
5706be9
doc: update
romgrk Jun 14, 2023
3a084e6
doc
romgrk Jun 14, 2023
03e6cd8
Update docs/data/data-grid/filtering/customization.md
romgrk Jun 14, 2023
c66cd40
Update docs/data/data-grid/filtering/customization.md
romgrk Jun 14, 2023
adc8027
fix: missed v7 refactor
romgrk Jun 14, 2023
6223641
Merge branch 'perf-filtering-v7-filters' of github.com:romgrk/mui-x i…
romgrk Jun 14, 2023
f7b30d4
refactor: typings
romgrk Jun 14, 2023
f7b19c6
lint
romgrk Jun 14, 2023
6f5fb73
lint
romgrk Jun 14, 2023
c285417
Merge branch 'master' into perf-filtering-v7-filters
romgrk Jun 20, 2023
1372ed9
refactor: compatibility changes
romgrk Jun 20, 2023
08a3223
doc: update
romgrk Jun 20, 2023
d59889f
lint
romgrk Jun 20, 2023
5c26f45
lint
romgrk Jun 20, 2023
343c385
lint
romgrk Jun 20, 2023
c9146f5
lint
romgrk Jun 21, 2023
dca10c7
fix: quickfilter compatibility
romgrk Jun 21, 2023
cde04ba
lint
romgrk Jun 21, 2023
ff9d602
Update packages/grid/x-data-grid/src/models/api/gridParamsApi.ts
romgrk Jun 21, 2023
441ee98
Update packages/grid/x-data-grid/src/models/api/gridParamsApi.ts
romgrk Jun 21, 2023
3eb9812
lint
romgrk Jun 28, 2023
2dda132
refactor
romgrk Jun 28, 2023
725139e
test: add v7 compat
romgrk Jun 28, 2023
2c6f402
Merge branch 'perf-filtering-v7-filters' of github.com:romgrk/mui-x i…
romgrk Jun 28, 2023
0af6482
test: add v7 qf tests
romgrk Jun 28, 2023
3cbac8f
lint
romgrk Jun 28, 2023
52482e5
lint
romgrk Jun 28, 2023
ffa0250
docs: api
romgrk Jun 28, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
32 changes: 32 additions & 0 deletions docs/data/data-grid/filtering/customization.md
Original file line number Diff line number Diff line change
Expand Up @@ -179,6 +179,38 @@ The demo below shows how to anchor the filter panel to the toolbar button instea

{{"demo": "CustomFilterPanelPosition.js", "bg": "inline", "defaultCodeOpen": false}}

### Optimize performance

There is a new set of APIs with a more efficient interface that are going to be used by default at the next major release, V7.

You can use them right now to make your custom filters faster. Instead of receiving a `GridCellParams` argument, they receive the parameters listed below.

```ts
const noop = () => {};
const operator: GridFilterOperator = {
/* ...other operator properties */
getApplyFilterFn: noop /* It is required to pass a noop function until V7 */,
getApplyFilterFnV7: (filterItem: GridFilterItem) => {
romgrk marked this conversation as resolved.
Show resolved Hide resolved
/* This example is our default string filter function for V7 */

if (!filterItem.value) {
return null;
}
const filterItemValue = disableTrim ? filterItem.value : filterItem.value.trim();
const filterRegex = new RegExp(escapeRegExp(filterItemValue), 'i');

return (
value: any,
row: GridValidRowModel,
column: GridColDef,
apiRef: React.MutableRefObject<GridApiCommunity>,
): boolean => {
return value != null ? filterRegex.test(String(value)) : false;
};
},
};
```

## API

- [GridFilterOperator](/x/api/data-grid/grid-filter-operator/)
Expand Down
4 changes: 4 additions & 0 deletions docs/data/data-grid/performance/performance.md
Original file line number Diff line number Diff line change
Expand Up @@ -48,6 +48,10 @@ shows you which cells re-render in reaction to your interaction with the grid.

{{"demo": "GridVisualization.js", "bg": "inline", "defaultCodeOpen": false}}

## Filtering

For filtering performance, see [the filter customization section](/x/react-data-grid/filtering/customization/#optimize-performance).

## API

- [DataGrid](/x/api/data-grid/data-grid/)
Expand Down
89 changes: 45 additions & 44 deletions docs/pages/x/api/data-grid/grid-actions-col-def.md

Large diffs are not rendered by default.

87 changes: 44 additions & 43 deletions docs/pages/x/api/data-grid/grid-col-def.md

Large diffs are not rendered by default.

21 changes: 11 additions & 10 deletions docs/pages/x/api/data-grid/grid-filter-operator.md
Original file line number Diff line number Diff line change
Expand Up @@ -23,13 +23,14 @@ import { GridFilterOperator } from '@mui/x-data-grid';

## Properties

| Name | Type | Default | Description |
| :---------------------------------------------------------------------------------------------------- | :------------------------------------------------------------------------------------------------------------------------------------------------------------------- | :------------------------------------- | :------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ |
| <span class="prop-name">getApplyFilterFn</span> | <span class="prop-type">(filterItem: GridFilterItem, column: GridColDef&lt;R, V, F&gt;) =&gt; null \| ((params: GridCellParams&lt;R, V, F&gt;) =&gt; boolean)</span> | | The callback that generates a filtering function for a given filter item and column.<br />This function can return `null` to skip filtering for this item and column. |
| <span class="prop-name optional">getValueAsString<sup><abbr title="optional">?</abbr></sup></span> | <span class="prop-type">(value: GridFilterItem['value']) =&gt; string</span> | | Converts the value of a filter item to a human-readable form. |
| <span class="prop-name optional">headerLabel<sup><abbr title="optional">?</abbr></sup></span> | <span class="prop-type">string</span> | | The label of the filter shown in header filter row. |
| <span class="prop-name optional">InputComponent<sup><abbr title="optional">?</abbr></sup></span> | <span class="prop-type">React.JSXElementConstructor&lt;any&gt;</span> | | The input component to render in the filter panel for this filter operator. |
| <span class="prop-name optional">InputComponentProps<sup><abbr title="optional">?</abbr></sup></span> | <span class="prop-type">Record&lt;string, any&gt;</span> | | The props to pass to the input component in the filter panel for this filter operator. |
| <span class="prop-name optional">label<sup><abbr title="optional">?</abbr></sup></span> | <span class="prop-type">string</span> | | The label of the filter operator. |
| <span class="prop-name optional">requiresFilterValue<sup><abbr title="optional">?</abbr></sup></span> | <span class="prop-type">boolean</span> | <span class="prop-default">true</span> | If `false`, filter operator doesn't require user-entered value to work.<br />Usually should be set to `false` for filter operators that don't have `InputComponent` (for example `isEmpty`) |
| <span class="prop-name">value</span> | <span class="prop-type">string</span> | | The name of the filter operator.<br />It will be matched with the `operator` property of the filter items. |
| Name | Type | Default | Description |
| :---------------------------------------------------------------------------------------------------- | :--------------------------------------------------------------------------- | :------------------------------------- | :------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ |
| <span class="prop-name">getApplyFilterFn</span> | <span class="prop-type">GetApplyFilterFnLegacy&lt;R, V, F&gt;</span> | | The callback that generates a filtering function for a given filter item and column.<br />This function can return `null` to skip filtering for this item and column. |
| <span class="prop-name optional">getApplyFilterFnV7<sup><abbr title="optional">?</abbr></sup></span> | <span class="prop-type">GetApplyFilterFnV7&lt;R, V, F&gt;</span> | | The callback that generates a filtering function for a given filter item and column.<br />This function can return `null` to skip filtering for this item and column.<br />This function uses the more performant V7 API. |
| <span class="prop-name optional">getValueAsString<sup><abbr title="optional">?</abbr></sup></span> | <span class="prop-type">(value: GridFilterItem['value']) =&gt; string</span> | | Converts the value of a filter item to a human-readable form. |
| <span class="prop-name optional">headerLabel<sup><abbr title="optional">?</abbr></sup></span> | <span class="prop-type">string</span> | | The label of the filter shown in header filter row. |
| <span class="prop-name optional">InputComponent<sup><abbr title="optional">?</abbr></sup></span> | <span class="prop-type">React.JSXElementConstructor&lt;any&gt;</span> | | The input component to render in the filter panel for this filter operator. |
| <span class="prop-name optional">InputComponentProps<sup><abbr title="optional">?</abbr></sup></span> | <span class="prop-type">Record&lt;string, any&gt;</span> | | The props to pass to the input component in the filter panel for this filter operator. |
| <span class="prop-name optional">label<sup><abbr title="optional">?</abbr></sup></span> | <span class="prop-type">string</span> | | The label of the filter operator. |
| <span class="prop-name optional">requiresFilterValue<sup><abbr title="optional">?</abbr></sup></span> | <span class="prop-type">boolean</span> | <span class="prop-default">true</span> | If `false`, filter operator doesn't require user-entered value to work.<br />Usually should be set to `false` for filter operators that don't have `InputComponent` (for example `isEmpty`) |
| <span class="prop-name">value</span> | <span class="prop-type">string</span> | | The name of the filter operator.<br />It will be matched with the `operator` property of the filter items. |
Loading