Skip to content

chore(js-ts): Convert Swaps AssetSwapButton, TokenSelectButton to TypeScript#986

Open
devin-ai-integration[bot] wants to merge 1 commit into
mainfrom
chore/js-ts-swaps-buttons-775
Open

chore(js-ts): Convert Swaps AssetSwapButton, TokenSelectButton to TypeScript#986
devin-ai-integration[bot] wants to merge 1 commit into
mainfrom
chore/js-ts-swaps-buttons-775

Conversation

@devin-ai-integration

@devin-ai-integration devin-ai-integration Bot commented Jun 23, 2026

Copy link
Copy Markdown

Summary

Part of Workstream 2 (Base & UI component JS→TS migration). Converts two presentational Swaps UI components from JS to TS. Type-only changes; snapshots identical.

  • app/components/UI/Swaps/components/AssetSwapButton.js.tsx
  • app/components/UI/Swaps/components/TokenSelectButton.js.tsx
  • TokenSelectButton.test.js.test.tsx (and its snapshot file renamed to match)

Worth knowing (rest is mechanical PropTypes→interface):

  • AssetSwapButton: straightforward function component; useModalHandler is already typed (as const tuple), so the destructure types flow through. The consumed AssetActionButton/InfoModal are still untyped JS.
  • TokenSelectButton: SelectorButton's onPress is required-typed (e: GestureResponderEvent) => void, while this component's onPress is optional, so it's passed as onPress as () => void to drop the | undefined (preserves passing undefined exactly).
  • The test snapshot file was renamed TokenSelectButton.test.js.snapTokenSelectButton.test.tsx.snap; its contents are byte-identical (verified), and the 5 snapshots pass as matches (not rewrites).

Validation (local)

  • yarn lint:tsc: passes, 0 errors (full project).
  • eslint on all three files: clean (no any).
  • yarn jest (TokenSelectButton): 5 snapshots pass, identical.

CI note

The install-gated CI jobs on this fork fail before reaching any TS/test step due to a preexisting broken dependency (react-native-tcp pins a GitHub commit that now 404s on yarn install); check-diff/CLABot/label checks also fail on all fork PRs for preexisting infra/governance reasons. None are caused by this diff, which contains file renames + type annotations and no lockfile change.

Link to Devin session: https://app.devin.ai/sessions/a0f7f796d1fb45e88b2feabe5829a4ac
Requested by: @WesternConcrete


Devin Review

Status Commit
⚪ Not started

Run Devin Review

Open in Devin Review (Staging)

…eScript

feature: migrate two presentational Swaps UI components from JS to TS. Replaces
PropTypes with TypeScript interfaces; renames the TokenSelectButton test and
snapshot to .tsx. No behavioral changes; snapshots identical.

Co-Authored-By: Wes Convery <2wconvery@gmail.com>
@devin-ai-integration

Copy link
Copy Markdown
Author

🤖 Devin AI Engineer

I'll be helping with this pull request! Here's what you should know:

✅ I will automatically:

  • Address comments on this PR. Add '(aside)' to your comment to have me ignore it.
  • Look at CI failures and help fix them

Note: I can only respond to comments from users who have write access to this repository.

⚙️ Control Options:

  • Disable automatic comment, CI, and merge conflict monitoring

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Projects

None yet

Development

Successfully merging this pull request may close these issues.

0 participants