/** * Copyright (c) 2015-present, Facebook, Inc. * * This source code is licensed under the MIT license found in the * LICENSE file in the root directory of this source tree. * * @format * @flow */ 'use strict'; const React = require('React'); const TextAncestor = require('TextAncestor'); const invariant = require('fbjs/lib/invariant'); const requireNativeComponent = require('requireNativeComponent'); import type {NativeComponent} from 'ReactNative'; import type {ViewProps} from 'ViewPropTypes'; export type Props = ViewProps; /** * The most fundamental component for building a UI, View is a container that * supports layout with flexbox, style, some touch handling, and accessibility * controls. * * @see http://facebook.github.io/react-native/docs/view.html */ const RCTView = requireNativeComponent('RCTView'); let ViewToExport = RCTView; if (__DEV__) { const View = (props: Props, forwardedRef: ?React.Ref<'RCTView'>) => { return ( {hasTextAncestor => { invariant( !hasTextAncestor, 'Nesting of within is not currently supported.', ); return ; }} ); }; // $FlowFixMe - TODO T29156721 `React.forwardRef` is not defined in Flow, yet. ViewToExport = React.forwardRef(View); } module.exports = ((ViewToExport: $FlowFixMe): Class< NativeComponent, >);