diff --git a/packages/frontend-core/src/components/sheet/cells/RelationshipCell.svelte b/packages/frontend-core/src/components/sheet/cells/RelationshipCell.svelte index de850f0e0f..fde184c8a2 100644 --- a/packages/frontend-core/src/components/sheet/cells/RelationshipCell.svelte +++ b/packages/frontend-core/src/components/sheet/cells/RelationshipCell.svelte @@ -19,9 +19,9 @@ let definition let primaryDisplay let candidateIndex + let lastSearchId $: editable = selected && !readonly - $: search(searchString) $: results = getResults(searchResults, value) $: lookupMap = buildLookupMap(value, isOpen) $: { @@ -48,29 +48,41 @@ return lookupMap?.[row._id] === true } - const search = debounce(async searchString => { - if (!searchString || !schema?.tableId || !isOpen) { + const search = debounce(async value => { + if (!value || !schema?.tableId || !isOpen) { + searchString = value candidateIndex = null searchResults = [] return } + lastSearchId = Math.random() + const thisSearchId = lastSearchId const results = await API.searchTable({ paginate: false, tableId: schema.tableId, limit: 20, query: { string: { - [`1:${primaryDisplay}`]: searchString, + [`1:${primaryDisplay}`]: value, }, }, }) + + // In case searching takes longer than our debounced update, abandon these + // results + if (thisSearchId !== lastSearchId) { + return + } + + // Sort and process results searchResults = results.rows?.map(row => ({ ...row, primaryDisplay: row[primaryDisplay], })) candidateIndex = searchResults?.length ? 0 : null - }, 500) + searchString = value + }, 250) const sortRows = rows => { if (!rows?.length) { @@ -161,7 +173,6 @@ {#if relationship.primaryDisplay}