Skip to content

Commit

Permalink
feat: migrate legacy auth request to approver ux
Browse files Browse the repository at this point in the history
  • Loading branch information
kyranjamie committed Dec 6, 2024
1 parent 742b38d commit 95bdf23
Show file tree
Hide file tree
Showing 10 changed files with 112 additions and 240 deletions.
5 changes: 1 addition & 4 deletions .eslintrc.cjs
Original file line number Diff line number Diff line change
Expand Up @@ -25,16 +25,13 @@ module.exports = {
'plugin:storybook/csf',
],
ignorePatterns: ['./leather-styles'],
plugins: ['react', 'react-hooks', '@typescript-eslint', 'deprecation'],
plugins: ['react', 'react-hooks', '@typescript-eslint'],
settings: {
react: {
version: 'detect',
},
},
rules: {
// This rule helps highlight areas of the code that use deprecated
// methods, such as implicit use of signed transactions
'deprecation/deprecation': 'warn',
'no-console': ['error'],
'no-duplicate-imports': ['error'],
'prefer-const': [
Expand Down
10 changes: 10 additions & 0 deletions src/app/common/focus-tab.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
export function focusTab(tabId: number | null) {
chrome.tabs.update(tabId ?? 0, { active: true });
}

export function focusTabAndWindow(tabId: number | null) {
chrome.tabs.update(tabId ?? 0, { active: true }, tab => {
if (!tab) return;
chrome.windows.update(tab.windowId, { focused: true });
});
}
Original file line number Diff line number Diff line change
Expand Up @@ -18,20 +18,20 @@ import { closeWindow } from '@shared/utils';
import { useOnMount } from '@app/common/hooks/use-on-mount';
import { FaviconDisplayer } from '@app/components/favicon-displayer/favicon-displayer';

interface GetAddressesLayoutProps {
interface ConnectAccountLayoutProps {
requester: string;
switchAccount: ReactNode;
onBeforeAnimation?(): void;
onUserApprovesGetAddresses(): void;
onUserApprovesGetAddresses(): void | Promise<void>;
onClickRequestedByLink(): void;
}
export function GetAddressesLayout({
export function ConnectAccountLayout({
requester,
switchAccount,
onBeforeAnimation,
onUserApprovesGetAddresses,
onClickRequestedByLink,
}: GetAddressesLayoutProps) {
}: ConnectAccountLayoutProps) {
const originLogoAnimation = useAnimationControls();
const contentDisappears = useAnimationControls();
const checkmarkEnters = useAnimationControls();
Expand Down Expand Up @@ -61,7 +61,7 @@ export function GetAddressesLayout({
});
await checkmarkEnters.start({ scale: 0.5, dur: 0.32 });
await delay(280);
onUserApprovesGetAddresses();
await onUserApprovesGetAddresses();
await delay(280);
await originLogoAnimation.start({
scale: 0,
Expand Down
47 changes: 47 additions & 0 deletions src/app/features/current-account/current-account-displayer.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,47 @@
import { Box } from 'leather-styles/jsx';

import { useAccountDisplayName } from '@app/common/hooks/account/use-account-names';
import { AccountTotalBalance } from '@app/components/account-total-balance';
import { AcccountAddresses } from '@app/components/account/account-addresses';
import { AccountListItemLayout } from '@app/components/account/account-list-item.layout';
import { AccountNameLayout } from '@app/components/account/account-name';
import { useCurrentAccountIndex } from '@app/store/accounts/account';
import { useNativeSegwitSigner } from '@app/store/accounts/blockchain/bitcoin/native-segwit-account.hooks';
import { useStacksAccounts } from '@app/store/accounts/blockchain/stacks/stacks-account.hooks';
import { AccountAvatarItem } from '@app/ui/components/account/account-avatar/account-avatar-item';

interface CurrentAccountDisplayerProps {
onSelectAccount(): void;
}
export function CurrentAccountDisplayer({ onSelectAccount }: CurrentAccountDisplayerProps) {
const index = useCurrentAccountIndex();
const stacksAccounts = useStacksAccounts();
const stxAddress = stacksAccounts[index]?.address || '';
const { data: name = '' } = useAccountDisplayName({ address: stxAddress, index });
const bitcoinSigner = useNativeSegwitSigner(index);
const bitcoinAddress = bitcoinSigner?.(0).address || '';
return (
<AccountListItemLayout
withChevron
accountAddresses={<AcccountAddresses index={index} />}
accountName={<AccountNameLayout isLoading={false}>{name}</AccountNameLayout>}
avatar={
<AccountAvatarItem
index={index}
publicKey={stacksAccounts[index]?.stxPublicKey || ''}
name={name}
/>
}
balanceLabel={
// Hack to center element without adjusting AccountListItemLayout
<Box pos="relative" top={12}>
<AccountTotalBalance stxAddress={stxAddress} btcAddress={bitcoinAddress} />
</Box>
}
index={index}
isLoading={false}
isSelected={false}
onSelectAccount={() => onSelectAccount()}
/>
);
}
53 changes: 0 additions & 53 deletions src/app/pages/choose-account/choose-account.tsx

This file was deleted.

129 changes: 0 additions & 129 deletions src/app/pages/choose-account/components/accounts.tsx

This file was deleted.

41 changes: 41 additions & 0 deletions src/app/pages/legacy-account-auth/legacy-account-auth.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,41 @@
import { closeWindow } from '@shared/utils';

import { useCancelAuthRequest } from '@app/common/authentication/use-cancel-auth-request';
import { useFinishAuthRequest } from '@app/common/authentication/use-finish-auth-request';
import { useAppDetails } from '@app/common/hooks/auth/use-app-details';
import { useOnMount } from '@app/common/hooks/use-on-mount';
import { useSwitchAccountSheet } from '@app/common/switch-account/use-switch-account-sheet-context';
import { openInNewTab } from '@app/common/utils/open-in-new-tab';
import { CurrentAccountDisplayer } from '@app/features/current-account/current-account-displayer';
import { useOnOriginTabClose } from '@app/routes/hooks/use-on-tab-closed';
import { useCurrentAccountIndex } from '@app/store/accounts/account';

import { ConnectAccountLayout } from '../../components/connect-account/connect-account.layout';

export function LegacyAccountAuth() {
const { url } = useAppDetails();
const accountIndex = useCurrentAccountIndex();
const finishSignIn = useFinishAuthRequest();
const { toggleSwitchAccount } = useSwitchAccountSheet();

useOnOriginTabClose(() => closeWindow());

const cancelAuthentication = useCancelAuthRequest();

const handleUnmount = async () => cancelAuthentication();
useOnMount(() => window.addEventListener('beforeunload', handleUnmount));

if (!url) throw new Error('No app details found');

return (
<ConnectAccountLayout
requester={url.origin}
onUserApprovesGetAddresses={async () => finishSignIn(accountIndex)}
// Here we should refocus the tab that initiated the request, however
// because the old auth code doesn't have the tab id and should be
// eventually removed, we just open in a new tab
onClickRequestedByLink={() => openInNewTab(url.origin)}
switchAccount={<CurrentAccountDisplayer onSelectAccount={toggleSwitchAccount} />}
/>
);
}
Loading

0 comments on commit 95bdf23

Please sign in to comment.