Skip to content

Commit

Permalink
Wallet Groups (#6314)
Browse files Browse the repository at this point in the history
* wallet groups
  • Loading branch information
greg-schrammel authored Jan 9, 2025
1 parent 3b9c474 commit 2d41255
Show file tree
Hide file tree
Showing 7 changed files with 243 additions and 104 deletions.
Binary file added src/assets/CreateNewWalletGroup.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
8 changes: 8 additions & 0 deletions src/languages/en_US.json
Original file line number Diff line number Diff line change
Expand Up @@ -2668,6 +2668,14 @@
"my_account_address": "My account address:",
"network_title": "Network",
"new": {
"choose_wallet_group": {
"title": "Choose Wallet Group",
"description": "Choose the wallet group you’d like to create a new wallet within, or create a new one."
},
"new_wallet_group": {
"title": "New Wallet Group",
"description": "Create a new wallet group"
},
"add_wallet_sheet": {
"options": {
"cloud": {
Expand Down
11 changes: 11 additions & 0 deletions src/navigation/AddWalletNavigator.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ import React, { useState } from 'react';
import Routes from '@/navigation/routesNames';
import { deviceUtils } from '@/utils';
import { AddWalletSheet, AddWalletSheetParams } from '@/screens/AddWalletSheet';
import { ChooseWalletGroup } from '@/screens/ChooseWalletGroup';
import { ImportOrWatchWalletSheet, ImportOrWatchWalletSheetParams } from '@/screens/ImportOrWatchWalletSheet';
import { BackgroundProvider } from '@/design-system';
import { RouteProp, useRoute } from '@react-navigation/native';
Expand Down Expand Up @@ -41,6 +42,16 @@ export const AddWalletNavigator = () => {
},
}}
/>
<Swipe.Screen
component={ChooseWalletGroup}
initialParams={{ isFirstWallet }}
name={Routes.CHOOSE_WALLET_GROUP}
listeners={{
focus: () => {
setScrollEnabled(true);
},
}}
/>
<Swipe.Screen
component={ImportOrWatchWalletSheet}
initialParams={{ type }}
Expand Down
1 change: 1 addition & 0 deletions src/navigation/routesNames.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ const Routes = {
ADD_CASH_SCREEN_NAVIGATOR: 'AddCashSheetNavigator',
ADD_CASH_SHEET: 'AddCashSheet',
ADD_WALLET_NAVIGATOR: 'AddWalletNavigator',
CHOOSE_WALLET_GROUP: 'ChooseWalletGroup',
ADD_WALLET_SHEET: 'AddWalletSheet',
APP_ICON_UNLOCK_SHEET: 'AppIconUnlockSheet',
AVATAR_BUILDER: 'AvatarBuilder',
Expand Down
105 changes: 2 additions & 103 deletions src/screens/AddWalletSheet.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -3,28 +3,20 @@ import { AddWalletItem } from '@/components/add-wallet/AddWalletRow';
import { Box, globalColors, Inset } from '@/design-system';
import { useNavigation } from '@/navigation';
import Routes from '@/navigation/routesNames';
import React, { useRef } from 'react';
import React from 'react';
import * as i18n from '@/languages';
import { HARDWARE_WALLETS, useExperimentalFlag } from '@/config';
import { analytics, analyticsV2 } from '@/analytics';
import { InteractionManager } from 'react-native';
import { createAccountForWallet, walletsLoadState } from '@/redux/wallets';
import { createWallet } from '@/model/wallet';
import WalletTypes from '@/helpers/walletTypes';
import { logger, RainbowError } from '@/logger';
import WalletsAndBackup from '@/assets/WalletsAndBackup.png';
import CreateNewWallet from '@/assets/CreateNewWallet.png';
import PairHairwareWallet from '@/assets/PairHardwareWallet.png';
import ImportSecretPhraseOrPrivateKey from '@/assets/ImportSecretPhraseOrPrivateKey.png';
import WatchWalletIcon from '@/assets/watchWallet.png';
import { useDispatch } from 'react-redux';
import showWalletErrorAlert from '@/helpers/support';
import { cloudPlatform } from '@/utils/platform';
import { RouteProp, useRoute } from '@react-navigation/native';
import { useInitializeWallet, useWallets } from '@/hooks';
import { WalletLoadingStates } from '@/helpers/walletLoadingStates';
import { executeFnIfCloudBackupAvailable } from '@/model/backup';
import { walletLoadingStore } from '@/state/walletLoading/walletLoading';

const TRANSLATIONS = i18n.l.wallet.new.add_wallet_sheet;

Expand All @@ -44,10 +36,6 @@ export const AddWalletSheet = () => {
const { goBack, navigate } = useNavigation();

const hardwareWalletsEnabled = useExperimentalFlag(HARDWARE_WALLETS);
const dispatch = useDispatch();
const initializeWallet = useInitializeWallet();
const creatingWallet = useRef<boolean>();
const { isDamaged, selectedWallet, wallets } = useWallets();

const onPressCreate = async () => {
try {
Expand All @@ -56,97 +44,8 @@ export const AddWalletSheet = () => {
type: 'new',
});
analytics.track('Tapped "Create a new wallet"');
if (creatingWallet.current) return;
creatingWallet.current = true;

// Show naming modal
InteractionManager.runAfterInteractions(() => {
goBack();
});
InteractionManager.runAfterInteractions(() => {
setTimeout(() => {
navigate(Routes.MODAL_SCREEN, {
actionType: 'Create',
asset: [],
isNewProfile: true,
onCancel: () => {
creatingWallet.current = false;
},
onCloseModal: async (args: any) => {
if (args) {
walletLoadingStore.setState({
loadingState: WalletLoadingStates.CREATING_WALLET,
});

const name = args?.name ?? '';
const color = args?.color ?? null;
// Check if the selected wallet is the primary
let primaryWalletKey = selectedWallet.primary ? selectedWallet.id : null;

// If it's not, then find it
!primaryWalletKey &&
Object.keys(wallets as any).some(key => {
const wallet = wallets?.[key];
if (wallet?.type === WalletTypes.mnemonic && wallet.primary) {
primaryWalletKey = key;
return true;
}
return false;
});

// If there's no primary wallet at all,
// we fallback to an imported one with a seed phrase
!primaryWalletKey &&
Object.keys(wallets as any).some(key => {
const wallet = wallets?.[key];
if (wallet?.type === WalletTypes.mnemonic && wallet.imported) {
primaryWalletKey = key;
return true;
}
return false;
});
try {
// If we found it and it's not damaged use it to create the new account
if (primaryWalletKey && !wallets?.[primaryWalletKey].damaged) {
await dispatch(createAccountForWallet(primaryWalletKey, color, name));
// @ts-ignore
await initializeWallet();
} else {
// If doesn't exist, we need to create a new wallet
await createWallet({
color,
name,
clearCallbackOnStartCreation: true,
});
await dispatch(walletsLoadState());
// @ts-expect-error - needs refactor to object params
await initializeWallet();
}
} catch (e) {
logger.error(new RainbowError('[AddWalletSheet]: Error while trying to add account'), {
error: e,
});
if (isDamaged) {
setTimeout(() => {
showWalletErrorAlert();
}, 1000);
}
} finally {
walletLoadingStore.setState({
loadingState: null,
});
}
}
creatingWallet.current = false;
},
profile: {
color: null,
name: ``,
},
type: 'wallet_profile',
});
}, 50);
});
navigate(Routes.CHOOSE_WALLET_GROUP, {});
} catch (e) {
logger.error(new RainbowError('[AddWalletSheet]: Error while trying to add account'), {
error: e,
Expand Down
Loading

0 comments on commit 2d41255

Please sign in to comment.