Decompose SearchPage: extract SearchFilterSync and useReceiptScanDrop#83602
Draft
adhorodyski wants to merge 1 commit intoExpensify:mainfrom
Draft
Decompose SearchPage: extract SearchFilterSync and useReceiptScanDrop#83602adhorodyski wants to merge 1 commit intoExpensify:mainfrom
adhorodyski wants to merge 1 commit intoExpensify:mainfrom
Conversation
Codecov Report❌ Looks like you've decreased code coverage for some files. Please write tests to increase, or at least maintain, the existing level of code coverage. See our documentation here for how to interpret this table.
|
Move useFilterFormValues + updateAdvancedFilters into a renderless SearchFilterSync component and push useReceiptScanDrop + DragAndDrop into SearchPageNarrow/SearchPageWide, removing ~16 Onyx subscriptions from the parent SearchPage. Also tighten the POLICY collection selector in useReceiptScanDrop to return a boolean instead of the full map. Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
bd29ddf to
c2d8331
Compare
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
@rlinoz @mountiny
Explanation of Change
SearchPagewas accumulating a large number of Onyx subscriptions that caused it to re-render more often than necessary. This PR isolates two groups of those subscriptions into child components/hooks, so re-renders triggered by those subscriptions no longer propagate up toSearchPageitself.SearchFilterSync(new renderless component)Owns the
useFilterFormValueshook (~6 Onyx keys:FORMS.SEARCH_ADVANCED_FILTERS_FORM,COLLECTION.POLICY,PERSONAL_DETAILS_LIST,ALL_POLICIES,CURRENCY_LIST,REPORT_ATTRIBUTES) and theupdateAdvancedFiltersside-effect that kept the filter form in sync with the current search query. BecauseSearchFilterSynchas no visible output, it rendersnulland its re-renders are completely invisible to the rest of the tree.useReceiptScanDropmoved toSearchPageWide/SearchPageNarrowThe hook subscribes to ~7 Onyx keys (notably
COLLECTION.POLICYwith a full-collection subscription). That subscription has also been tightened: the selector now returns a single boolean (hasAtLeastOnePolicy) instead of the entire policy collection, so the hook re-runs only when the policy count changes from zero to non-zero (or vice versa). TheDragAndDropwrapper that depends on this hook was moved alongside it into each layout variant.Net effect: approximately 13 Onyx subscriptions are removed from
SearchPage, isolating those re-renders into the components that actually need them.Fixed Issues
$
PROPOSAL:
Tests
Offline tests
N/A
QA Steps
Same as tests
PR Author Checklist
### Fixed Issuessection aboveTestssectionOffline stepssectionQA stepssectiontoggleReportand notonIconClick)src/languages/*files and using the translation methodSTYLE.md) were followedAvatar, I verified the components usingAvatarare working as expected)StyleUtils.getBackgroundAndBorderStyle(theme.componentBG))npm run compress-svg)Avataris modified, I verified thatAvataris working as expected in all cases)Designlabel and/or tagged@Expensify/designso the design team can review the changes.ScrollViewcomponent to make it scrollable when more elements are added to the page.mainbranch was merged into this PR after a review, I tested again and verified the outcome was still expected according to theTeststeps.Screenshots/Videos
Android: Native
Android: mWeb Chrome
iOS: Native
iOS: mWeb Safari
MacOS: Chrome / Safari