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

Add support for variable row heights #2384

Merged
merged 20 commits into from
May 4, 2021
Merged

Conversation

amanmahajan7
Copy link
Contributor

@amanmahajan7 amanmahajan7 commented May 3, 2021

  • Change rowHeight to a number/function to support variable row heights
  • Ensure performance is not impacted when rowHeight is a number
  • Add unit tests

I think this can really useful specially on readonly grids

@amanmahajan7 amanmahajan7 self-assigned this May 3, 2021
@@ -94,20 +94,79 @@ export function useViewportRows<R>({
}
}, [expandedGroupIds, groupedRows, rawRows]);

const { totalRowHeight, getRowTop, getRowHeight, findRowIdx } = useMemo(() => {
if (typeof rowHeight === 'number') {
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This change does not impact the performance if rowHeight is a number.


const rowPositions: ({ height: number; top: number })[] = [];
let totalRowHeight = 0;
// Calcule the height of all the rows upfront. This can cause performance issues
Copy link
Contributor Author

@amanmahajan7 amanmahajan7 May 3, 2021

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I did not notice any performance issues even on a large grid. Tried editing, colspan and a few other features. This can be slow if rowHeight itself is expensive

return rowPositions[rowIdx].top;
},
getRowHeight: (rowIdx: number) => rowPositions[rowIdx].height,
findRowIdx(offset: number) {
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Use binary search on a sorted array.

@@ -98,13 +98,13 @@ function createRows(): readonly Row[] {
for (let i = 1; i < 10000; i++) {
rows.push({
id: i,
year: 2015 + faker.random.number(3),
year: 2015 + faker.datatype.number(3),
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

faker.random is deprecated

@amanmahajan7
Copy link
Contributor Author

Working on tests but ready for review.

@amanmahajan7 amanmahajan7 marked this pull request as ready for review May 3, 2021 16:16
@amanmahajan7 amanmahajan7 requested a review from nstepien May 3, 2021 16:16
@amanmahajan7 amanmahajan7 changed the title POC: Variable row heights Add support for variable row heights May 3, 2021
src/DataGrid.tsx Outdated Show resolved Hide resolved
src/DataGrid.tsx Outdated Show resolved Hide resolved
src/DataGrid.tsx Outdated Show resolved Hide resolved
src/DataGrid.tsx Outdated Show resolved Hide resolved
src/DataGrid.tsx Outdated Show resolved Hide resolved
src/hooks/useViewportRows.ts Outdated Show resolved Hide resolved
src/hooks/useViewportRows.ts Outdated Show resolved Hide resolved
src/hooks/useViewportRows.ts Outdated Show resolved Hide resolved
nstepien
nstepien previously approved these changes May 4, 2021
@amanmahajan7 amanmahajan7 merged commit c18dd2c into canary May 4, 2021
@amanmahajan7 amanmahajan7 deleted the am-variable-height-row branch May 4, 2021 16:55
gernotkogler pushed a commit to Garaio-REM/react-data-grid that referenced this pull request May 13, 2021
* Change rowHeight to a function to support variable row heights

* Fix hooks order

* Remove memo

* Add a comment

* Fix tests

* Fix types

* Cleanup

* Use a single array

* Fix pageup/pagedown

* Update src/DataGrid.tsx

Co-authored-by: Nicolas Stepien <[email protected]>

* Update src/hooks/useViewportRows.ts

Co-authored-by: Nicolas Stepien <[email protected]>

* newScrollTop -> nextRowY

* move/deduplicate getRowTop(rowIdx) and getRowHeight(rowIdx) calls outside the ifs

* Validate rowIdx

* Update src/hooks/useViewportRows.ts

Co-authored-by: Nicolas Stepien <[email protected]>

* Fix typo

* Add rowHeight tests

* typo

Co-authored-by: Nicolas Stepien <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants