react-native/Examples/UIExplorer/UIExplorerApp.js

72 lines
1.6 KiB
JavaScript
Raw Normal View History

2015-01-30 01:10:49 +00:00
/**
* Copyright (c) 2015-present, Facebook, Inc.
* All rights reserved.
*
* This source code is licensed under the BSD-style license found in the
* LICENSE file in the root directory of this source tree. An additional grant
* of patent rights can be found in the PATENTS file in the same directory.
2015-01-30 01:10:49 +00:00
*
* @providesModule UIExplorerApp
* @flow
2015-01-30 01:10:49 +00:00
*/
'use strict';
var React = require('react-native');
2015-01-30 01:10:49 +00:00
var UIExplorerList = require('./UIExplorerList');
var {
AppRegistry,
2015-01-30 01:10:49 +00:00
NavigatorIOS,
StyleSheet,
} = React;
var UIExplorerApp = React.createClass({
2015-03-25 02:34:12 +00:00
getInitialState: function() {
return {
openExternalExample: (null: ?React.Component),
};
},
2015-01-30 01:10:49 +00:00
render: function() {
2015-03-25 02:34:12 +00:00
if (this.state.openExternalExample) {
var Example = this.state.openExternalExample;
return (
<Example
onExampleExit={() => {
this.setState({ openExternalExample: null, });
}}
/>
);
}
2015-01-30 01:10:49 +00:00
return (
<NavigatorIOS
style={styles.container}
initialRoute={{
title: 'UIExplorer',
component: UIExplorerList,
2015-03-25 02:34:12 +00:00
passProps: {
onExternalExampleRequested: (example) => {
this.setState({ openExternalExample: example, });
},
}
2015-01-30 01:10:49 +00:00
}}
itemWrapperStyle={styles.itemWrapper}
tintColor='#008888'
/>
2015-01-30 01:10:49 +00:00
);
}
});
var styles = StyleSheet.create({
container: {
flex: 1,
},
itemWrapper: {
backgroundColor: '#eaeaea',
},
});
AppRegistry.registerComponent('UIExplorerApp', () => UIExplorerApp);
2015-01-30 01:10:49 +00:00
module.exports = UIExplorerApp;