Preload the prev/next item search pages

I tried to do this earlier, but the caching problem from the previous commit (where we weren't including `id` for the search result in the GQL query) was causing it to do a like, infinite loop thing, where the preload results would cache-invalidate the current results, and so the 3 queries would just fight for which one's in the cache?

But now that caching is working, this is working too! Makes it all feel a lot snappier :3
This commit is contained in:
Emi Matchu 2022-10-14 19:41:52 -07:00
parent 2ee48250da
commit 78d8cf3739

View file

@ -92,6 +92,16 @@ function SearchResults({
currentPageNumber currentPageNumber
); );
// Preload the previous and next page of search results, with this quick
// ~hacky trick: just `useSearchResults` two more times, with some extra
// attention to skip the query when we don't know if it will exist!
useSearchResults(query, outfitState, currentPageNumber - 1, {
skip: currentPageNumber <= 1,
});
useSearchResults(query, outfitState, currentPageNumber + 1, {
skip: numTotalPages == null || currentPageNumber >= numTotalPages,
});
// This will save the `wornItemIds` when the SearchResults first mounts, and // This will save the `wornItemIds` when the SearchResults first mounts, and
// keep it saved even after the outfit changes. We use this to try to restore // keep it saved even after the outfit changes. We use this to try to restore
// these items after the user makes changes, e.g., after they try on another // these items after the user makes changes, e.g., after they try on another