/** * Copyright (c) Facebook, Inc. and its affiliates. * * This source code is licensed under the MIT license found in the * LICENSE file in the root directory of this source tree. * * @format * @flow */ const React = require('react'); const StyleSheet = require('../../StyleSheet/StyleSheet'); const View = require('../View/View'); import type {ViewProps} from '../View/ViewPropTypes'; import RCTMaskedViewNativeComponent from './RCTMaskedViewNativeComponent'; type Props = $ReadOnly<{| ...ViewProps, children: React.Node, /** * Should be a React element to be rendered and applied as the * mask for the child element. */ maskElement: React.Element, |}>; /** * Renders the child view with a mask specified in the `maskElement` prop. * * ``` * import React from 'react'; * import { MaskedViewIOS, Text, View } from 'react-native'; * * class MyMaskedView extends React.Component { * render() { * return ( * * * Basic Mask * * * } * > * * * ); * } * } * ``` * * The above example will render a view with a blue background that fills its * parent, and then mask that view with text that says "Basic Mask". * * The alpha channel of the view rendered by the `maskElement` prop determines how * much of the view's content and background shows through. Fully or partially * opaque pixels allow the underlying content to show through but fully * transparent pixels block that content. * */ class MaskedViewIOS extends React.Component { _hasWarnedInvalidRenderMask = false; render(): React.Node { const {maskElement, children, ...otherViewProps} = this.props; if (!React.isValidElement(maskElement)) { if (!this._hasWarnedInvalidRenderMask) { console.warn( 'MaskedView: Invalid `maskElement` prop was passed to MaskedView. ' + 'Expected a React Element. No mask will render.', ); this._hasWarnedInvalidRenderMask = true; } return {children}; } return ( {maskElement} {children} ); } } module.exports = MaskedViewIOS;