/** * The examples provided by Facebook are for non-commercial testing and * evaluation purposes only. * * Facebook reserves all rights not expressly granted. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE AND NON INFRINGEMENT. IN NO EVENT SHALL * FACEBOOK BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN * AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. * * @flow */ 'use strict'; var React = require('react-native'); var { AppRegistry, Settings, SnapshotViewIOS, StyleSheet, } = React; import type { NavigationContext } from 'NavigationContext'; var UIExplorerListBase = require('./UIExplorerListBase'); var COMPONENTS = [ require('./ActivityIndicatorIOSExample'), require('./DatePickerIOSExample'), require('./ImageExample'), require('./LayoutEventsExample'), require('./ListViewExample'), require('./ListViewGridLayoutExample'), require('./ListViewPagingExample'), require('./MapViewExample'), require('./ModalExample'), require('./Navigator/NavigatorExample'), require('./NavigatorIOSColorsExample'), require('./NavigatorIOSExample'), require('./PickerIOSExample'), require('./ProgressViewIOSExample'), require('./RefreshControlExample'), require('./ScrollViewExample'), require('./SegmentedControlIOSExample'), require('./SliderIOSExample'), require('./SwitchExample'), require('./TabBarIOSExample'), require('./TextExample.ios'), require('./TextInputExample.ios'), require('./TouchableExample'), require('./TransparentHitTestExample'), require('./ViewExample'), require('./WebViewExample'), ]; var APIS = [ require('./AccessibilityIOSExample'), require('./ActionSheetIOSExample'), require('./AdSupportIOSExample'), require('./AlertIOSExample'), require('./AnimatedExample'), require('./AnimatedGratuitousApp/AnExApp'), require('./AppStateIOSExample'), require('./AsyncStorageExample'), require('./BorderExample'), require('./BoxShadowExample'), require('./CameraRollExample'), require('./ClipboardExample'), require('./GeolocationExample'), require('./LayoutExample'), require('./NetInfoExample'), require('./PanResponderExample'), require('./PointerEventsExample'), require('./PushNotificationIOSExample'), require('./RCTRootViewIOSExample'), require('./StatusBarIOSExample'), require('./TimerExample'), require('./TransformExample'), require('./VibrationIOSExample'), require('./XHRExample.ios'), require('./ImageEditingExample'), ]; type Props = { navigator: { navigationContext: NavigationContext, push: (route: {title: string, component: ReactClass}) => void, }, onExternalExampleRequested: Function, }; class UIExplorerList extends React.Component { props: Props; render() { return ( ); } renderAdditionalView(renderRow: Function, renderTextInput: Function): React.Component { return renderTextInput(styles.searchTextInput); } search(text: mixed) { Settings.set({searchText: text}); } _openExample(example: any) { if (example.external) { this.props.onExternalExampleRequested(example); return; } var Component = UIExplorerListBase.makeRenderable(example); this.props.navigator.push({ title: Component.title, component: Component, }); } onPressRow(example: any) { this._openExample(example); } // Register suitable examples for snapshot tests static registerComponents() { COMPONENTS.concat(APIS).forEach((Example) => { if (Example.displayName) { var Snapshotter = React.createClass({ render: function() { var Renderable = UIExplorerListBase.makeRenderable(Example); return ( ); }, }); AppRegistry.registerComponent(Example.displayName, () => Snapshotter); } }); } } var styles = StyleSheet.create({ searchTextInput: { height: 30, }, }); module.exports = UIExplorerList;