/** * Copyright (c) Meta Platforms, Inc. and affiliates. * * This source code is licensed under the MIT license found in the * LICENSE file in the root directory of this source tree. * * @flow strict-local * @format */ import type {RNTesterModuleExample} from '../../types/RNTesterTypes'; import RNTesterText from '../../components/RNTesterText'; import React from 'react'; import {PanResponder, ScrollView, StyleSheet, View} from 'react-native'; exports.displayName = 'JSResponderHandlerExample'; exports.framework = 'React'; exports.title = 'JSResponderHandler'; exports.category = 'Basic'; exports.description = 'Simple example to test JSResponderHandler.'; const _gesture = PanResponder.create({ onMoveShouldSetPanResponder: (e, gestureState) => { return Math.abs(gestureState.moveX) > 150; }, }); exports.examples = [ { title: 'JSResponderHandlerExample', description: ('This example tests the native JSResponderHandler: when the user ' + 'scrolls on the right side of the ScrollView (white area located on the' + ' right side of the gray area), the touch event is managed by native ' + 'which blocks the scroll event.': string), render: function (): React.Node { const views = []; for (let i = 0; i < 100; i++) { views[i] = ( I am row {i} ); } return ( {views} ); }, }, ] as Array; const styles = StyleSheet.create({ container: { flex: 1, }, scrollview: { flex: 1, }, row: { height: 25, }, rowText: { color: 'black', }, touchable_area: { width: 150, backgroundColor: 'lightgray', }, });