/** * 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. * * @flow * @providesModule ScrollViewExample */ 'use strict'; var React = require('react'); var ReactNative = require('react-native'); var { Platform, ScrollView, StyleSheet, Text, TouchableOpacity, View, Image } = ReactNative; exports.displayName = 'ScrollViewExample'; exports.title = ''; exports.description = 'Component that enables scrolling through child components'; exports.examples = [ { title: '', description: 'To make content scrollable, wrap it within a component', render: function() { var _scrollView: ScrollView; return ( =0.53.0 site=react_native_fb,react_native_oss) This * comment suppresses an error when upgrading Flow's support for * React. To see the error delete this comment and run Flow. */ ref={(scrollView) => { _scrollView = scrollView; }} automaticallyAdjustContentInsets={false} onScroll={() => { console.log('onScroll!'); }} scrollEventThrottle={200} style={styles.scrollView}> {THUMB_URLS.map(createThumbRow)} { _scrollView.scrollTo({y: 0}); }}> Scroll to top { _scrollView.scrollToEnd({animated: true}); }}> Scroll to bottom { Platform.OS === 'ios' ? { _scrollView.flashScrollIndicators(); }}> Flash scroll indicators : null } ); } }, { title: ' (horizontal = true)', description: 'You can display \'s child components horizontally rather than vertically', render: function() { function renderScrollView(title: string, addtionalStyles: typeof StyleSheet) { var _scrollView: ScrollView; return ( {title} =0.53.0 site=react_native_fb,react_native_oss) This * comment suppresses an error when upgrading Flow's support for * React. To see the error delete this comment and run Flow. */ ref={(scrollView) => { _scrollView = scrollView; }} automaticallyAdjustContentInsets={false} horizontal={true} style={[styles.scrollView, styles.horizontalScrollView]}> {THUMB_URLS.map(createThumbRow)} { _scrollView.scrollTo({x: 0}); }}> Scroll to start { _scrollView.scrollToEnd({animated: true}); }}> Scroll to end { Platform.OS === 'ios' ? { _scrollView.flashScrollIndicators(); }}> Flash scroll indicators : null } ); } return ( {renderScrollView('LTR layout', {direction: 'ltr'})} {renderScrollView('RTL layout', {direction: 'rtl'})} ); } }]; class Thumb extends React.Component<$FlowFixMeProps, $FlowFixMeState> { shouldComponentUpdate(nextProps, nextState) { return false; } render() { return ( ); } } var THUMB_URLS = [ require('./Thumbnails/like.png'), require('./Thumbnails/dislike.png'), require('./Thumbnails/call.png'), require('./Thumbnails/fist.png'), require('./Thumbnails/bandaged.png'), require('./Thumbnails/flowers.png'), require('./Thumbnails/heart.png'), require('./Thumbnails/liking.png'), require('./Thumbnails/party.png'), require('./Thumbnails/poke.png'), require('./Thumbnails/superlike.png'), require('./Thumbnails/victory.png'), ]; THUMB_URLS = THUMB_URLS.concat(THUMB_URLS); // double length of THUMB_URLS var createThumbRow = (uri, i) => ; var styles = StyleSheet.create({ scrollView: { backgroundColor: '#eeeeee', height: 300, }, horizontalScrollView: { height: 106, }, text: { fontSize: 16, fontWeight: 'bold', margin: 5, }, button: { margin: 5, padding: 5, alignItems: 'center', backgroundColor: '#cccccc', borderRadius: 3, }, thumb: { margin: 5, padding: 5, backgroundColor: '#cccccc', borderRadius: 3, minWidth: 96, }, img: { width: 64, height: 64, } });