BlueWallet/navigation/AddWalletStack.tsx

124 lines
3.7 KiB
TypeScript
Raw Normal View History

2024-05-05 22:33:06 +02:00
import { createNativeStackNavigator } from '@react-navigation/native-stack';
2024-05-20 11:54:13 +02:00
import React from 'react';
import navigationStyle from '../components/navigationStyle';
import { useTheme } from '../components/themes';
import loc from '../loc';
2024-05-05 22:33:06 +02:00
import {
AddComponent,
ImportCustomDerivationPathComponent,
2024-05-20 11:54:13 +02:00
ImportSpeedComponent,
2024-05-06 00:37:01 +02:00
ImportWalletComponent,
2024-05-20 11:54:13 +02:00
ImportWalletDiscoveryComponent,
2024-05-05 22:33:06 +02:00
PleaseBackupComponent,
2024-05-20 11:54:13 +02:00
PleaseBackupLNDHubComponent,
2024-05-05 22:33:06 +02:00
ProvideEntropyComponent,
WalletsAddMultisigComponent,
WalletsAddMultisigHelpComponent,
2024-05-20 11:54:13 +02:00
WalletsAddMultisigStep2Component,
2024-05-05 22:33:06 +02:00
} from './LazyLoadAddWalletStack';
2024-07-14 16:25:35 +02:00
export type AddWalletStackParamList = {
AddWallet: undefined;
ImportWallet: undefined;
ImportWalletDiscovery: undefined;
ImportSpeed: undefined;
ImportCustomDerivationPath: undefined;
PleaseBackup: undefined;
PleaseBackupLNDHub: undefined;
ProvideEntropy: undefined;
WalletsAddMultisig: {
walletLabel: string;
};
WalletsAddMultisigStep2: {
m: number;
n: number;
walletLabel: string;
format: string;
};
WalletsAddMultisigHelp: undefined;
};
2024-05-05 22:33:06 +02:00
const Stack = createNativeStackNavigator<AddWalletStackParamList>();
const AddWalletStack = () => {
const theme = useTheme();
return (
<Stack.Navigator initialRouteName="AddWallet">
<Stack.Screen
name="AddWallet"
component={AddComponent}
options={navigationStyle({
headerBackVisible: false,
title: loc.wallets.add_title,
})(theme)}
/>
<Stack.Screen name="ImportCustomDerivationPath" component={ImportCustomDerivationPathComponent} />
<Stack.Screen
2024-05-06 00:37:01 +02:00
name="ImportWallet"
component={ImportWalletComponent}
2024-05-05 22:33:06 +02:00
options={navigationStyle({ title: loc.wallets.import_title })(theme)}
2024-05-06 05:11:29 +02:00
/>
<Stack.Screen
name="ImportSpeed"
component={ImportSpeedComponent}
options={navigationStyle({ statusBarStyle: 'light', title: loc.wallets.import_title })(theme)}
2024-05-05 22:33:06 +02:00
/>
2024-05-06 00:37:01 +02:00
<Stack.Screen
name="ImportWalletDiscovery"
component={ImportWalletDiscoveryComponent}
options={navigationStyle({
title: loc.wallets.import_discovery_title,
})(theme)}
/>
2024-05-05 22:33:06 +02:00
<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)}
/>
2024-07-14 16:25:35 +02:00
<Stack.Screen
name="WalletsAddMultisig"
component={WalletsAddMultisigComponent}
options={navigationStyle({ title: '' })(theme)}
initialParams={{ walletLabel: loc.multisig.default_label }}
/>
2024-05-05 22:33:06 +02:00
<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;