mirror of
https://github.com/status-im/react-native.git
synced 2025-01-22 07:20:23 +00:00
3ee3d2b4b2
Summary: Basic template using 'react-navigation' to make it easy to get started. Not duplicating all the files in `android` and `ios` folders. These will be taken from the `HelloWorld` template. Let's not duplicate all of these files (it's a lot and they are large, especially the Xcode projects). **Test plan (required)** The app works locally. This PR is just a preparation for a next PR that will add support for 'react-native init --template Navigation'. Will have a proper test plan there. Closes https://github.com/facebook/react-native/pull/12153 Differential Revision: D4494776 Pulled By: mkonicek fbshipit-source-id: b43eafd7a1424477f9493a3eb4083ba4dd3d3846
53 lines
1.1 KiB
JavaScript
53 lines
1.1 KiB
JavaScript
import React, { Component } from 'react';
|
|
import {
|
|
Platform,
|
|
StyleSheet,
|
|
Text,
|
|
TouchableHighlight,
|
|
TouchableNativeFeedback,
|
|
View,
|
|
} from 'react-native';
|
|
|
|
/**
|
|
* Renders the right type of Touchable for the list item, based on platform.
|
|
*/
|
|
const Touchable = ({onPress, children}) => {
|
|
const child = React.Children.only(children);
|
|
if (Platform.OS === 'android') {
|
|
return (
|
|
<TouchableNativeFeedback onPress={onPress}>
|
|
{child}
|
|
</TouchableNativeFeedback>
|
|
);
|
|
} else {
|
|
return (
|
|
<TouchableHighlight onPress={onPress} underlayColor='#ddd'>
|
|
{child}
|
|
</TouchableHighlight>
|
|
);
|
|
}
|
|
}
|
|
|
|
const ListItem = ({label, onPress}) => (
|
|
<Touchable onPress={onPress}>
|
|
<View style={styles.item}>
|
|
<Text style={styles.label}>{label}</Text>
|
|
</View>
|
|
</Touchable>
|
|
);
|
|
|
|
const styles = StyleSheet.create({
|
|
item: {
|
|
height: 48,
|
|
justifyContent: 'center',
|
|
paddingLeft: 12,
|
|
borderBottomWidth: StyleSheet.hairlineWidth,
|
|
borderBottomColor: '#ddd',
|
|
},
|
|
label: {
|
|
fontSize: 16,
|
|
}
|
|
});
|
|
|
|
export default ListItem;
|