Skip to content

[Due for payment 2026-03-30] Migrate ShareTab.tsx from useOptionsList to useFilteredOptions #82181

@mountiny

Description

@mountiny

Problem

ShareTab.tsx currently uses the useOptionsList hook from OptionListContextProvider, which causes unnecessary background recalculations on every personal details or reports change.

This is part of a larger effort to remove OptionListContextProvider entirely. See parent issue #82193 for full context.

Solution

Replace useOptionsList with useFilteredOptions following the pattern established in PR #74071 (NewChatPage migration).

Current usage:

  • Properties used: options, areOptionsInitialized
  • Called with: no arguments (defaults to shouldInitialize: true)
  • File: src/pages/Share/ShareTab.tsx

How options are used:

  • options is passed to getSearchOptions() to build searchOptions
  • areOptionsInitialized gates searchOptions computation and showLoadingPlaceholder
  • areOptionsInitialized controls whether styledRecentReports are shown in list data

Migration steps:

  1. Replace import {useOptionsList} from '@components/OptionListContextProvider' with import useFilteredOptions from '@hooks/useFilteredOptions'
  2. Replace useOptionsList() call with useFilteredOptions({ enabled: true }) (or tie to screen transition if applicable)
  3. Replace areOptionsInitialized checks with !isLoading (or options !== null)
  4. Update showLoadingPlaceholder and list data guards accordingly

Complexity: Simple

Reference PR: #74071

Tests

  • Verify the Share tab displays correctly and lists appear without lag
  • Verify loading placeholders show correctly while options compute
  • Verify search functionality works within the Share tab
  • Verify no errors appear in the JS console
  • Test on all platforms (iOS, Android, Web, Desktop)
Issue OwnerCurrent Issue Owner: @shubham1206agra

Metadata

Metadata

Labels

Awaiting PaymentAuto-added when associated PR is deployed to productionTaskWeeklyKSv2

Type

No type

Projects

No projects

Milestone

No milestone

Relationships

None yet

Development

No branches or pull requests

Issue actions