2024-05-12 22:37:30 +02:00
|
|
|
// DrawerRoot.tsx
|
|
|
|
import { createDrawerNavigator, DrawerNavigationOptions } from '@react-navigation/drawer';
|
2024-05-20 11:54:13 +02:00
|
|
|
import React, { useMemo } from 'react';
|
2024-05-12 22:37:30 +02:00
|
|
|
import { I18nManager } from 'react-native';
|
2024-05-20 11:54:13 +02:00
|
|
|
|
2024-05-12 22:37:30 +02:00
|
|
|
import { useIsLargeScreen } from '../hooks/useIsLargeScreen';
|
|
|
|
import DrawerList from '../screen/wallets/DrawerList';
|
2024-05-20 11:54:13 +02:00
|
|
|
import DetailViewStackScreensStack from './DetailViewScreensStack';
|
2024-05-12 22:37:30 +02:00
|
|
|
|
|
|
|
const Drawer = createDrawerNavigator();
|
|
|
|
|
|
|
|
const DrawerListContent = (props: any) => {
|
|
|
|
return <DrawerList {...props} />;
|
|
|
|
};
|
|
|
|
|
|
|
|
const DrawerRoot = () => {
|
|
|
|
const isLargeScreen = useIsLargeScreen();
|
|
|
|
|
|
|
|
const drawerStyle: DrawerNavigationOptions = useMemo(
|
|
|
|
() => ({
|
|
|
|
drawerPosition: I18nManager.isRTL ? 'right' : 'left',
|
|
|
|
drawerStyle: { width: isLargeScreen ? 320 : '0%' },
|
|
|
|
drawerType: isLargeScreen ? 'permanent' : 'back',
|
|
|
|
}),
|
|
|
|
[isLargeScreen],
|
|
|
|
);
|
|
|
|
|
|
|
|
return (
|
|
|
|
<Drawer.Navigator screenOptions={drawerStyle} drawerContent={DrawerListContent}>
|
|
|
|
<Drawer.Screen
|
|
|
|
name="DetailViewStackScreensStack"
|
|
|
|
component={DetailViewStackScreensStack}
|
|
|
|
options={{ headerShown: false, gestureHandlerProps: { enableTrackpadTwoFingerGesture: false } }}
|
|
|
|
/>
|
|
|
|
</Drawer.Navigator>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
export default DrawerRoot;
|