// @flow
import * as React from 'react';
import {createDrawerNavigator, DrawerNavigationProp} from '@react-navigation/drawer';
import TabNavigator from './MainTabNavigator';
import SettingsScreen from '../screens/Other/SettingsScreen';
import AboutScreen from '../screens/About/AboutScreen';
import AboutDependenciesScreen from '../screens/About/AboutDependenciesScreen';
import SelfMenuScreen from '../screens/Other/SelfMenuScreen';
import AvailableRoomScreen from "../screens/Websites/AvailableRoomScreen";
import BibScreen from "../screens/Websites/BibScreen";
import TetrisScreen from "../screens/Tetris/TetrisScreen";
import DebugScreen from '../screens/About/DebugScreen';
import Sidebar from "../components/Sidebar/Sidebar";
import {createStackNavigator, TransitionPresets} from "@react-navigation/stack";
import i18n from "i18n-js";
import LoginScreen from "../screens/Amicale/LoginScreen";
import ProfileScreen from "../screens/Amicale/ProfileScreen";
import ClubListScreen from "../screens/Amicale/Clubs/ClubListScreen";
import ClubDisplayScreen from "../screens/Amicale/Clubs/ClubDisplayScreen";
import ClubAboutScreen from "../screens/Amicale/Clubs/ClubAboutScreen";
import VoteScreen from "../screens/Amicale/VoteScreen";
import AmicaleContactScreen from "../screens/Amicale/AmicaleContactScreen";
import MaterialHeaderButtons, {Item} from "../components/Overrides/CustomHeaderButton";
import {AmicaleWebsiteScreen} from "../screens/Websites/AmicaleWebsiteScreen";
import {TutorInsaWebsiteScreen} from "../screens/Websites/TutorInsaWebsiteScreen";
import {WiketudWebsiteScreen} from "../screens/Websites/WiketudWebsiteScreen";
import {ElusEtudiantsWebsiteScreen} from "../screens/Websites/ElusEtudiantsWebsiteScreen";
import {createCollapsibleStack} from "react-navigation-collapsible";
import {useTheme} from "react-native-paper";
const defaultScreenOptions = {
gestureEnabled: true,
cardOverlayEnabled: true,
...TransitionPresets.SlideFromRightIOS,
};
function getDrawerButton(navigation: DrawerNavigationProp) {
return (
-
);
}
const AboutStack = createStackNavigator();
function AboutStackComponent() {
return (
{
const openDrawer = getDrawerButton.bind(this, navigation);
return {
title: i18n.t('screens.about'),
headerLeft: openDrawer
};
}}
/>
);
}
const SettingsStack = createStackNavigator();
function SettingsStackComponent() {
return (
{
const openDrawer = getDrawerButton.bind(this, navigation);
return {
title: i18n.t('screens.settings'),
headerLeft: openDrawer
};
}}
/>
);
}
const SelfMenuStack = createStackNavigator();
function SelfMenuStackComponent() {
const {colors} = useTheme();
return (
{createCollapsibleStack(
{
const openDrawer = getDrawerButton.bind(this, navigation);
return {
title: i18n.t('screens.menuSelf'),
headerLeft: openDrawer,
headerStyle: {
backgroundColor: colors.surface,
},
};
}}
/>,
{
collapsedColor: 'transparent',
useNativeDriver: true,
}
)}
);
}
const AvailableRoomStack = createStackNavigator();
function AvailableRoomStackComponent() {
const {colors} = useTheme();
return (
{createCollapsibleStack(
{
const openDrawer = getDrawerButton.bind(this, navigation);
return {
title: i18n.t('screens.availableRooms'),
headerLeft: openDrawer,
headerStyle: {
backgroundColor: colors.surface,
},
};
}}
/>,
{
collapsedColor: 'transparent',
useNativeDriver: false, // native driver does not work with webview
}
)}
);
}
const BibStack = createStackNavigator();
function BibStackComponent() {
const {colors} = useTheme();
return (
{createCollapsibleStack(
{
const openDrawer = getDrawerButton.bind(this, navigation);
return {
title: i18n.t('screens.bib'),
headerLeft: openDrawer,
headerStyle: {
backgroundColor: colors.surface,
},
};
}}
/>,
{
collapsedColor: 'transparent',
useNativeDriver: false, // native driver does not work with webview
}
)}
);
}
const AmicaleWebsiteStack = createStackNavigator();
function AmicaleWebsiteStackComponent() {
const {colors} = useTheme();
return (
{createCollapsibleStack(
{
const openDrawer = getDrawerButton.bind(this, navigation);
return {
title: "Amicale",
headerLeft: openDrawer,
headerStyle: {
backgroundColor: colors.surface,
},
};
}}
/>,
{
collapsedColor: 'transparent',
useNativeDriver: false, // native driver does not work with webview
}
)}
);
}
const ElusEtudiantsStack = createStackNavigator();
function ElusEtudiantsStackComponent() {
const {colors} = useTheme();
return (
{createCollapsibleStack(
{
const openDrawer = getDrawerButton.bind(this, navigation);
return {
title: "Élus Étudiants",
headerLeft: openDrawer,
headerStyle: {
backgroundColor: colors.surface,
},
};
}}
/>,
{
collapsedColor: 'transparent',
useNativeDriver: false, // native driver does not work with webview
}
)}
);
}
const WiketudStack = createStackNavigator();
function WiketudStackComponent() {
const {colors} = useTheme();
return (
{createCollapsibleStack(
{
const openDrawer = getDrawerButton.bind(this, navigation);
return {
title: "Wiketud",
headerLeft: openDrawer,
headerStyle: {
backgroundColor: colors.surface,
},
};
}}
/>,
{
collapsedColor: 'transparent',
useNativeDriver: false, // native driver does not work with webview
}
)}
);
}
const TutorInsaStack = createStackNavigator();
function TutorInsaStackComponent() {
const {colors} = useTheme();
return (
{createCollapsibleStack(
{
const openDrawer = getDrawerButton.bind(this, navigation);
return {
title: "Tutor'INSA",
headerLeft: openDrawer,
headerStyle: {
backgroundColor: colors.surface,
},
};
}}
/>,
{
collapsedColor: 'transparent',
useNativeDriver: false, // native driver does not work with webview
}
)}
);
}
const TetrisStack = createStackNavigator();
function TetrisStackComponent() {
return (
{
const openDrawer = getDrawerButton.bind(this, navigation);
return {
title: i18n.t("game.title"),
headerLeft: openDrawer
};
}}
/>
);
}
const LoginStack = createStackNavigator();
function LoginStackComponent() {
return (
{
const openDrawer = getDrawerButton.bind(this, navigation);
return {
title: i18n.t('screens.login'),
headerLeft: openDrawer
};
}}
/>
);
}
const ProfileStack = createStackNavigator();
function ProfileStackComponent() {
return (
{
const openDrawer = getDrawerButton.bind(this, navigation);
return {
title: i18n.t('screens.profile'),
headerLeft: openDrawer
};
}}
/>
);
}
const VoteStack = createStackNavigator();
function VoteStackComponent() {
return (
{
const openDrawer = getDrawerButton.bind(this, navigation);
return {
title: i18n.t('screens.vote'),
headerLeft: openDrawer
};
}}
/>
);
}
const AmicaleContactStack = createStackNavigator();
function AmicaleContactStackComponent() {
return (
{
const openDrawer = getDrawerButton.bind(this, navigation);
return {
title: i18n.t('screens.amicaleAbout'),
headerLeft: openDrawer
};
}}
/>
);
}
const ClubStack = createStackNavigator();
function ClubStackComponent() {
const {colors} = useTheme();
return (
{createCollapsibleStack(
{
const openDrawer = getDrawerButton.bind(this, navigation);
return {
title: i18n.t('clubs.clubList'),
headerLeft: openDrawer,
headerStyle: {
backgroundColor: colors.surface,
},
};
}}
/>,
{
collapsedColor: 'transparent',
useNativeDriver: true,
}
)}
);
}
const Drawer = createDrawerNavigator();
type Props = {
defaultHomeRoute: string | null,
defaultHomeData: { [key: string]: any }
}
export default class DrawerNavigator extends React.Component {
createTabNavigator: () => React.Element;
constructor(props: Props) {
super(props);
this.createTabNavigator = () =>
}
getDrawerContent = (props: { navigation: DrawerNavigationProp }) =>
render() {
return (
);
}
}