BlueWallet/navigation/AddWalletStack.tsx
2024-11-11 00:13:01 +00:00

146 lines
4.2 KiB
TypeScript

import { createNativeStackNavigator } from '@react-navigation/native-stack';
import React from 'react';
import navigationStyle, { CloseButtonPosition } from '../components/navigationStyle';
import { useTheme } from '../components/themes';
import loc from '../loc';
import {
AddComponent,
ImportCustomDerivationPathComponent,
ImportSpeedComponent,
ImportWalletComponent,
ImportWalletDiscoveryComponent,
PleaseBackupComponent,
PleaseBackupLNDHubComponent,
ProvideEntropyComponent,
WalletsAddMultisigComponent,
WalletsAddMultisigHelpComponent,
WalletsAddMultisigStep2Component,
} from './LazyLoadAddWalletStack';
export type AddWalletStackParamList = {
AddWallet: undefined;
ImportWallet?: {
label?: string;
triggerImport?: boolean;
scannedData?: string;
};
ImportWalletDiscovery: {
importText: string;
askPassphrase: boolean;
searchAccounts: boolean;
};
ImportSpeed: undefined;
ImportCustomDerivationPath: {
importText: string;
password: string | undefined;
};
PleaseBackup: {
walletID: string;
};
PleaseBackupLNDHub: {
walletID: string;
};
ProvideEntropy: {
onGenerated: (entropy: Buffer) => void;
words: number;
};
WalletsAddMultisig: {
walletLabel: string;
};
WalletsAddMultisigStep2: {
m: number;
n: number;
walletLabel: string;
format: string;
};
WalletsAddMultisigHelp: undefined;
};
const Stack = createNativeStackNavigator<AddWalletStackParamList>();
const AddWalletStack = () => {
const theme = useTheme();
return (
<Stack.Navigator initialRouteName="AddWallet">
<Stack.Screen
name="AddWallet"
component={AddComponent}
options={navigationStyle({
closeButtonPosition: CloseButtonPosition.Left,
title: loc.wallets.add_title,
})(theme)}
/>
<Stack.Screen
name="ImportCustomDerivationPath"
component={ImportCustomDerivationPathComponent}
options={navigationStyle({ statusBarStyle: 'light', title: loc.wallets.import_derivation_title })(theme)}
/>
<Stack.Screen
name="ImportWallet"
component={ImportWalletComponent}
options={navigationStyle({ title: loc.wallets.import_title })(theme)}
/>
<Stack.Screen
name="ImportSpeed"
component={ImportSpeedComponent}
options={navigationStyle({ statusBarStyle: 'light', title: loc.wallets.import_title })(theme)}
/>
<Stack.Screen
name="ImportWalletDiscovery"
component={ImportWalletDiscoveryComponent}
options={navigationStyle({
title: loc.wallets.import_discovery_title,
})(theme)}
/>
<Stack.Screen
name="PleaseBackup"
component={PleaseBackupComponent}
options={navigationStyle({
gestureEnabled: false,
headerBackVisible: false,
title: loc.pleasebackup.title,
})(theme)}
/>
<Stack.Screen
name="PleaseBackupLNDHub"
component={PleaseBackupLNDHubComponent}
options={navigationStyle({ gestureEnabled: false, headerBackVisible: false, title: loc.pleasebackup.title })(theme)}
/>
<Stack.Screen
name="ProvideEntropy"
component={ProvideEntropyComponent}
options={navigationStyle({ title: loc.entropy.title })(theme)}
/>
<Stack.Screen
name="WalletsAddMultisig"
component={WalletsAddMultisigComponent}
options={navigationStyle({ title: '' })(theme)}
initialParams={{ walletLabel: loc.multisig.default_label }}
/>
<Stack.Screen
name="WalletsAddMultisigStep2"
component={WalletsAddMultisigStep2Component}
options={navigationStyle({ title: '', gestureEnabled: false })(theme)}
/>
<Stack.Screen
name="WalletsAddMultisigHelp"
component={WalletsAddMultisigHelpComponent}
options={navigationStyle({
title: '',
gestureEnabled: false,
headerStyle: {
backgroundColor: '#0070FF',
},
headerTintColor: '#FFFFFF',
headerBackTitleVisible: false,
statusBarStyle: 'light',
headerShadowVisible: false,
})(theme)}
/>
</Stack.Navigator>
);
};
export default AddWalletStack;