Skip to content

Commit

Permalink
Fix #6639: VirtualScroller improve useUpdate comparison
Browse files Browse the repository at this point in the history
  • Loading branch information
melloware committed May 20, 2024
1 parent 69aed63 commit 4ba4215
Showing 1 changed file with 23 additions and 1 deletion.
24 changes: 23 additions & 1 deletion components/lib/virtualscroller/VirtualScroller.js
Original file line number Diff line number Diff line change
Expand Up @@ -568,7 +568,29 @@ export const VirtualScroller = React.memo(
}, [numToleratedItemsState]);

useUpdateEffect(() => {
if (!prevProps.items || prevProps.items.length !== (props.items || []).length) {
// Check if the previous/current rows array exists
const prevRowsExist = prevProps.items !== undefined && prevProps.items !== null;
const currentRowsExist = props.items !== undefined && props.items !== null;

// Get the length of the previous/current rows array, or 0 if it doesn't exist
const prevRowsLength = prevRowsExist ? prevProps.items.length : 0;
const currentRowsLength = currentRowsExist ? props.items.length : 0;

// Check if the length of the rows arrays has changed
let valuesChanged = prevRowsLength !== currentRowsLength;

// If both is true, we also need to check the lengths of the first element (assuming it's a matrix)
if (both && !valuesChanged) {
// Get the length of the columns or 0
const prevColumnsLength = prevRowsExist && prevProps.items.length > 0 ? prevProps.items[0].length : 0;
const currentColumnsLength = currentRowsExist && props.items.length > 0 ? props.items[0].length : 0;

// Check if the length of the columns has changed
valuesChanged = prevColumnsLength !== currentColumnsLength;
}

// If the previous items array doesn't exist or if any values have changed, call the init function
if (!prevRowsExist || valuesChanged) {
init();
}

Expand Down

0 comments on commit 4ba4215

Please sign in to comment.