From 4ba4215c530b882b9b81cc9c64227a9fdfc8b29a Mon Sep 17 00:00:00 2001 From: melloware Date: Mon, 20 May 2024 08:29:12 -0400 Subject: [PATCH] Fix #6639: VirtualScroller improve useUpdate comparison --- .../lib/virtualscroller/VirtualScroller.js | 24 ++++++++++++++++++- 1 file changed, 23 insertions(+), 1 deletion(-) diff --git a/components/lib/virtualscroller/VirtualScroller.js b/components/lib/virtualscroller/VirtualScroller.js index 349915172a..64862de642 100644 --- a/components/lib/virtualscroller/VirtualScroller.js +++ b/components/lib/virtualscroller/VirtualScroller.js @@ -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(); }