import {useCallback, useState} from 'react' import {msg} from '@lingui/macro' import {useLingui} from '@lingui/react' import {logger} from '#/logger' import {type SessionAccount, useSessionApi} from '#/state/session' import {useLoggedOutViewControls} from '#/state/shell/logged-out' import * as Toast from '#/view/com/util/Toast' import {storeNavigationStateForAccountSwitch} from '#/Navigation' import {logEvent} from '../statsig/statsig' import {type LogEvents} from '../statsig/statsig' export function useAccountSwitcher() { const [pendingDid, setPendingDid] = useState(null) const {_} = useLingui() const {resumeSession} = useSessionApi() const {requestSwitchToAccount} = useLoggedOutViewControls() const onPressSwitchAccount = useCallback( async ( account: SessionAccount, logContext: LogEvents['account:loggedIn']['logContext'], ) => { if (pendingDid) { // The session API isn't resilient to race conditions so let's just ignore this. return } try { setPendingDid(account.did) if (account.accessJwt) { // Store navigation state before switching so user stays on the same page storeNavigationStateForAccountSwitch() await resumeSession(account, true) logEvent('account:loggedIn', {logContext, withPassword: false}) Toast.show(_(msg`Signed in as @${account.handle}`)) } else { requestSwitchToAccount({requestedAccount: account.did}) Toast.show( _(msg`Please sign in as @${account.handle}`), 'circle-exclamation', ) } } catch (e: any) { logger.error(`switch account: selectAccount failed`, { message: e.message, }) requestSwitchToAccount({requestedAccount: account.did}) Toast.show( _(msg`Please sign in as @${account.handle}`), 'circle-exclamation', ) } finally { setPendingDid(null) } }, [_, resumeSession, requestSwitchToAccount, pendingDid], ) return {onPressSwitchAccount, pendingDid} }