/** * 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'; const React = require('react-native'); const UIExplorerActions = require('./UIExplorerActions'); const { ListView, NavigationExperimental, StyleSheet, Text, TextInput, TouchableHighlight, View, } = React; const createExamplePage = require('./createExamplePage'); const { Container: NavigationContainer, } = NavigationExperimental; import type { UIExplorerExample, } from './UIExplorerList.ios' const ds = new ListView.DataSource({ rowHasChanged: (r1, r2) => r1 !== r2, sectionHeaderHasChanged: (h1, h2) => h1 !== h2, }); class UIExplorerExampleList extends React.Component { constuctor(props: { disableTitleRow: ?boolean, onNavigate: Function, filter: ?string, list: { ComponentExamples: Array, APIExamples: Array, }, style: ?any, }) { } render(): ?ReactElement { const filterText = this.props.filter || ''; const filterRegex = new RegExp(String(filterText), 'i'); const filter = (example) => filterRegex.test(example.module.title); const dataSource = ds.cloneWithRowsAndSections({ components: this.props.list.ComponentExamples.filter(filter), apis: this.props.list.APIExamples.filter(filter), }); return ( {this._renderTitleRow()} {this._renderTextInput()} ); } _renderTitleRow(): ?ReactElement { if (!this.props.displayTitleRow) { return null; } return this._renderRow( 'UIExplorer', 'React Native Examples', 'home_key', () => { this.props.onNavigate( UIExplorerActions.ExampleListWithFilter('') ); } ); } _renderTextInput(): ?ReactElement { if (this.props.disableSearch) { return null; } return ( { this.props.onNavigate(UIExplorerActions.ExampleListWithFilter(text)); }} placeholder="Search..." style={[styles.searchTextInput, this.props.searchTextInputStyle]} testID="explorer_search" value={this.props.filter} /> ); } _renderSectionHeader(data: any, section: string): ?ReactElement { return ( {section.toUpperCase()} ); } _renderExampleRow(example: {key: string, module: Object}): ?ReactElement { return this._renderRow( example.module.title, example.module.description, example.key, () => this._handleRowPress(example.key) ); } _renderRow(title: string, description: string, key: ?string, handler: ?Function): ?ReactElement { return ( {title} {description} ); } _handleRowPress(exampleKey: string): void { this.props.onNavigate(UIExplorerActions.ExampleAction(exampleKey)) } } function makeRenderable(example: any): ReactClass { return example.examples ? createExamplePage(null, example) : example; } UIExplorerExampleList = NavigationContainer.create(UIExplorerExampleList); UIExplorerExampleList.makeRenderable = makeRenderable; var styles = StyleSheet.create({ listContainer: { flex: 1, }, list: { backgroundColor: '#eeeeee', }, sectionHeader: { padding: 5, fontWeight: '500', fontSize: 11, }, group: { backgroundColor: 'white', }, row: { backgroundColor: 'white', justifyContent: 'center', paddingHorizontal: 15, paddingVertical: 8, }, separator: { height: StyleSheet.hairlineWidth, backgroundColor: '#bbbbbb', marginLeft: 15, }, rowTitleText: { fontSize: 17, fontWeight: '500', }, rowDetailText: { fontSize: 15, color: '#888888', lineHeight: 20, }, searchRow: { backgroundColor: '#eeeeee', padding: 10, }, searchTextInput: { backgroundColor: 'white', borderColor: '#cccccc', borderRadius: 3, borderWidth: 1, paddingLeft: 8, height: 35, }, }); module.exports = UIExplorerExampleList;