Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

refactor: abstract hooks from transfer panel #1838

Closed
wants to merge 26 commits into from

Conversation

fionnachan
Copy link
Member

Closes FS-744

Copy link

vercel bot commented Aug 13, 2024

The latest updates on your projects. Learn more about Vercel for Git ↗︎

Name Status Preview Updated (UTC)
arbitrum-token-bridge ✅ Ready (Inspect) Visit Preview Sep 20, 2024 3:29pm

@cla-bot cla-bot bot added the cla-signed label Aug 13, 2024
import { useIsConnectedToOrbitChain } from '../../../hooks/useIsConnectedToOrbitChain'
import { useIsConnectedToArbitrum } from '../../../hooks/useIsConnectedToArbitrum'

export function useTransferRequiresChainSwitch() {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

what if this was a return value from useTransferReadiness?

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

i deleted the hook and used a simple condition const isConnectedToTheWrongChain = chainId !== latestNetworks.current.sourceChain.id instead

also abstracted the relevant code from transferCctp and transfer into a reusable function

@fionnachan fionnachan marked this pull request as draft August 13, 2024 09:52
@fionnachan fionnachan marked this pull request as ready for review August 15, 2024 11:49
selectedToken && warningTokens[selectedToken.address.toLowerCase()]
if (warningToken) {
const description = getWarningTokenDescription(warningToken.type)
warningToast(
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't think we should be showing toasts from this method, it should only tell us if it's warning token or not.

if (isWarningToken()) {
  showWarningTokenToast(warningToken: WarningToken) {
    // here use warningToken.address and warningToken.type
  }
}

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

With this we can just refactor this method to:

function isWarningToken(token: ERC20BridgeToken | null) {
  if (!token) {
    return false
  }
  return typeof warningTokens[token.address.toLowerCase()] !== 'undefined'
}

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Also this could probably be a part of TokenUtils

Copy link
Member Author

@fionnachan fionnachan Aug 19, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

warningTokens is from useAppState() so unless further refactoring is done, it can't be moved out of a hook or component, so i wouldn't move it to the utils file


async function isTransferAllowed(isCctp: boolean) {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Could just get isCctp directly instead of passing the prop

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Also this method uses a lot of hook values directly, are we sure we are not running into stale values or race conditions here?

const hasBothSigners = parentSigner && childSigner
if (isEOA && !hasBothSigners) {
throw signerUndefinedError
if (isConnectedToTheWrongChain) {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't know about this entire code block, I'd expect isTransferAllowed to be pure. I'd have the network switching logic in its own method.

isTeleportMode
})
if (destinationAddressError) {
console.error(destinationAddressError)
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't think this is needed, function like this shouldn't produce side effects like this imho

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We can just

return typeof destinationAddressError !== null

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

But also not sure if we need a helper, we could just use useState for this, and then we can use useMemo for isTransferAllowed

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

i refactored the code for destination address error across files

throw 'Signer is undefined'
const signer = sourceChainSigner

if (!(await isTransferAllowed(true))) {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

this boolean prop is not very clear, but maybe it will be gone if we refactor the method, I don't think we need props here at all, this could probably be done with useMemo

@fionnachan
Copy link
Member Author

no longer needed for reference

@fionnachan fionnachan closed this Oct 1, 2024
@fionnachan fionnachan deleted the abstract-hooks-from-txpanel branch October 1, 2024 16:09
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.

3 participants