/** * 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. * * @providesModule InspectorOverlay * @flow */ 'use strict'; var Dimensions = require('Dimensions'); var InspectorUtils = require('InspectorUtils'); var React = require('React'); var PropTypes = require('prop-types'); var StyleSheet = require('StyleSheet'); var UIManager = require('UIManager'); var View = require('View'); var ElementBox = require('ElementBox'); type EventLike = { nativeEvent: Object, }; class InspectorOverlay extends React.Component { props: { inspected?: { frame?: Object, style?: any, }, inspectedViewTag?: number, onTouchInstance: Function, }; static propTypes = { inspected: PropTypes.shape({ frame: PropTypes.object, style: PropTypes.any, }), inspectedViewTag: PropTypes.number, onTouchInstance: PropTypes.func.isRequired, }; findViewForTouchEvent = (e: EventLike) => { var {locationX, locationY} = e.nativeEvent.touches[0]; UIManager.findSubviewIn( this.props.inspectedViewTag, [locationX, locationY], (nativeViewTag, left, top, width, height) => { var instance = InspectorUtils.findInstanceByNativeTag(nativeViewTag); if (!instance) { return; } this.props.onTouchInstance(instance, {left, top, width, height}, locationY); } ); }; shouldSetResponser = (e: EventLike): bool => { this.findViewForTouchEvent(e); return true; }; render() { var content = null; if (this.props.inspected) { content = ; } return ( {content} ); } } var styles = StyleSheet.create({ inspector: { backgroundColor: 'transparent', position: 'absolute', left: 0, top: 0, right: 0, }, }); module.exports = InspectorOverlay;