From 9020060f17d2b6a633dffd61405b222fe8301c28 Mon Sep 17 00:00:00 2001 From: Andrew Kingston Date: Wed, 8 Mar 2023 10:15:46 +0000 Subject: [PATCH] Remove unnecessary searching through large rows array --- packages/frontend-core/src/components/sheet/stores/rows.js | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/packages/frontend-core/src/components/sheet/stores/rows.js b/packages/frontend-core/src/components/sheet/stores/rows.js index b7b2eb6e7c..fa3ba6caad 100644 --- a/packages/frontend-core/src/components/sheet/stores/rows.js +++ b/packages/frontend-core/src/components/sheet/stores/rows.js @@ -135,7 +135,8 @@ export const createRowsStore = context => { // Get index of row to check if it exists const $rows = get(rows) - const index = $rows.findIndex(row => row._id === id) + const $rowLookupMap = get(rowLookupMap) + const index = $rowLookupMap[id] // Process as either an update, addition or deletion if (newRow) { @@ -167,7 +168,8 @@ export const createRowsStore = context => { // Updates a value of a row const updateRow = async (rowId, column, value) => { const $rows = get(rows) - const index = $rows.findIndex(x => x._id === rowId) + const $rowLookupMap = get(rowLookupMap) + const index = $rowLookupMap[rowId] const row = $rows[index] if (index === -1 || row?.[column] === value) { return