/** * Copyright (c) 2013-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. * * 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 * @providesModule PointerEventsExample */ 'use strict'; var React = require('react'); var ReactNative = require('react-native'); var { StyleSheet, Text, View, } = ReactNative; class ExampleBox extends React.Component { state = { log: [], }; handleLog = (msg) => { this.state.log = this.state.log.concat([msg]); }; flushReactChanges = () => { this.forceUpdate(); }; /** * Capture phase of bubbling to append separator before any of the bubbling * happens. */ handleTouchCapture = () => { this.state.log = this.state.log.concat(['---']); }; render() { return ( {this.state.log.join('\n')} ); } } class NoneExample extends React.Component { render() { return ( this.props.onLog('A unspecified touched')} style={styles.box}> A: unspecified this.props.onLog('B none touched')} style={[styles.box, styles.boxPassedThrough]}> B: none this.props.onLog('C unspecified touched')} style={[styles.box, styles.boxPassedThrough]}> C: unspecified ); } } /** * Special demo text that makes itself untouchable so that it doesn't destroy * the experiment and confuse the output. */ class DemoText extends React.Component { render() { return ( {this.props.children} ); } } class BoxNoneExample extends React.Component { render() { return ( this.props.onLog('A unspecified touched')} style={styles.box}> A: unspecified this.props.onLog('B box-none touched')} style={[styles.box, styles.boxPassedThrough]}> B: box-none this.props.onLog('C unspecified touched')} style={styles.box}> C: unspecified this.props.onLog('C explicitly unspecified touched')} style={[styles.box]}> C: explicitly unspecified ); } } class BoxOnlyExample extends React.Component { render() { return ( this.props.onLog('A unspecified touched')} style={styles.box}> A: unspecified this.props.onLog('B box-only touched')} style={styles.box}> B: box-only this.props.onLog('C unspecified touched')} style={[styles.box, styles.boxPassedThrough]}> C: unspecified this.props.onLog('C explicitly unspecified touched')} style={[styles.box, styles.boxPassedThrough]}> C: explicitly unspecified ); } } type ExampleClass = { Component: ReactClass, title: string, description: string, }; var exampleClasses: Array = [ { Component: NoneExample, title: '`none`', description: '`none` causes touch events on the container and its child components to pass through to the parent container.', }, { Component: BoxNoneExample, title: '`box-none`', description: '`box-none` causes touch events on the container to pass through and will only detect touch events on its child components.', }, { Component: BoxOnlyExample, title: '`box-only`', description: '`box-only` causes touch events on the container\'s child components to pass through and will only detect touch events on the container itself.', } ]; var infoToExample = (info) => { return { title: info.title, description: info.description, render: function() { return ; }, }; }; var styles = StyleSheet.create({ text: { fontSize: 10, color: '#5577cc', }, textPassedThrough: { color: '#88aadd', }, box: { backgroundColor: '#aaccff', borderWidth: 1, borderColor: '#7799cc', padding: 10, margin: 5, }, boxPassedThrough: { borderColor: '#99bbee', }, logText: { fontSize: 9, }, logBox: { padding: 20, margin: 10, borderWidth: 0.5, borderColor: '#f0f0f0', backgroundColor: '#f9f9f9', }, bottomSpacer: { marginBottom: 100, }, }); exports.framework = 'React'; exports.title = 'Pointer Events'; exports.description = 'Demonstrates the use of the pointerEvents prop of a ' + 'View to control how touches should be handled.'; exports.examples = exampleClasses.map(infoToExample);