2018-08-03 14:59:12 -07:00
|
|
|
import React from 'react';
|
|
|
|
import Expo from 'expo';
|
2018-10-10 13:52:38 -07:00
|
|
|
import { FlatList, I18nManager } from 'react-native';
|
2018-10-11 23:11:36 -07:00
|
|
|
import { createSwitchNavigator } from '@react-navigation/core';
|
2018-08-03 14:59:12 -07:00
|
|
|
import { createStackNavigator } from 'react-navigation-stack';
|
|
|
|
import { ListSection, Divider } from 'react-native-paper';
|
2018-09-14 12:48:59 +02:00
|
|
|
|
2018-08-03 14:59:12 -07:00
|
|
|
import SimpleStack from './src/SimpleStack';
|
2018-10-10 13:52:38 -07:00
|
|
|
import ImageStack from './src/ImageStack';
|
2018-09-24 15:11:34 -04:00
|
|
|
import TransparentStack from './src/TransparentStack';
|
2018-10-10 13:52:38 -07:00
|
|
|
import ModalStack from './src/ModalStack';
|
|
|
|
import LifecycleInteraction from './src/LifecycleInteraction';
|
|
|
|
import GestureInteraction from './src/GestureInteraction';
|
|
|
|
|
2018-09-14 12:48:59 +02:00
|
|
|
// Comment the following two lines to stop using react-native-screens
|
|
|
|
import { useScreens } from 'react-native-screens';
|
2018-10-12 11:34:03 -07:00
|
|
|
|
|
|
|
// Uncomment the following line to force RTL. Requires closing and re-opening
|
|
|
|
// your app after you first load it with this option enabled.
|
|
|
|
I18nManager.forceRTL(false);
|
2018-09-14 12:48:59 +02:00
|
|
|
useScreens();
|
|
|
|
|
2018-08-03 14:59:12 -07:00
|
|
|
const data = [
|
|
|
|
{ component: SimpleStack, title: 'Simple', routeName: 'SimpleStack' },
|
2018-10-10 13:52:38 -07:00
|
|
|
{ component: ImageStack, title: 'Image', routeName: 'ImageStack' },
|
|
|
|
{ component: ModalStack, title: 'Modal', routeName: 'ModalStack' },
|
2018-10-12 11:23:17 -07:00
|
|
|
{
|
|
|
|
component: LifecycleInteraction,
|
|
|
|
title: 'Lifecycle',
|
|
|
|
routeName: 'LifecycleStack',
|
|
|
|
},
|
2018-09-24 15:11:34 -04:00
|
|
|
{
|
|
|
|
component: TransparentStack,
|
|
|
|
title: 'Transparent',
|
|
|
|
routeName: 'TransparentStack',
|
|
|
|
},
|
2018-10-12 11:23:17 -07:00
|
|
|
{
|
|
|
|
component: GestureInteraction,
|
|
|
|
title: 'Gesture Interaction',
|
|
|
|
routeName: 'GestureInteraction',
|
|
|
|
},
|
2018-08-03 14:59:12 -07:00
|
|
|
];
|
|
|
|
|
2018-10-12 11:23:17 -07:00
|
|
|
Expo.Asset.loadAsync(
|
|
|
|
require('react-navigation/src/views/assets/back-icon.png')
|
|
|
|
);
|
|
|
|
Expo.Asset.loadAsync(
|
|
|
|
require('react-navigation/src/views/assets/back-icon-mask.png')
|
|
|
|
);
|
2018-10-10 13:52:38 -07:00
|
|
|
|
2018-08-03 14:59:12 -07:00
|
|
|
class Home extends React.Component {
|
|
|
|
static navigationOptions = {
|
|
|
|
title: 'Examples',
|
|
|
|
};
|
|
|
|
|
|
|
|
_renderItem = ({ item }) => (
|
|
|
|
<ListSection.Item
|
|
|
|
title={item.title}
|
|
|
|
onPress={() => this.props.navigation.navigate(item.routeName)}
|
|
|
|
/>
|
|
|
|
);
|
|
|
|
|
|
|
|
_keyExtractor = item => item.routeName;
|
|
|
|
|
|
|
|
render() {
|
|
|
|
return (
|
|
|
|
<FlatList
|
|
|
|
ItemSeparatorComponent={Divider}
|
|
|
|
renderItem={this._renderItem}
|
|
|
|
keyExtractor={this._keyExtractor}
|
|
|
|
data={data}
|
2018-10-10 13:52:38 -07:00
|
|
|
style={{ backgroundColor: '#fff' }}
|
2018-08-03 14:59:12 -07:00
|
|
|
/>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
const App = createSwitchNavigator({
|
|
|
|
Home: createStackNavigator({ Home }),
|
|
|
|
...data.reduce((acc, it) => {
|
|
|
|
acc[it.routeName] = {
|
|
|
|
screen: it.component,
|
|
|
|
navigationOptions: {
|
|
|
|
title: it.title,
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
|
|
|
return acc;
|
|
|
|
}, {}),
|
|
|
|
});
|
|
|
|
|
|
|
|
Expo.registerRootComponent(App);
|