/** * 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 Image = require('Image'); const React = require('React'); const Text = require('Text'); const TouchableHighlight = require('TouchableHighlight'); const View = require('View'); const ViewPropTypes = require('ViewPropTypes'); import type {ImageSource} from 'ImageSource'; /** * Standard set of quick action buttons that can, if the user chooses, be used * with SwipeableListView. Each button takes an image and text with optional * formatting. */ class SwipeableQuickActionButton extends React.Component<{ accessibilityLabel?: string, imageSource?: ?(ImageSource | number), imageStyle?: ?ViewPropTypes.style, mainView?: ?React.Node, onPress?: Function, style?: ?ViewPropTypes.style, testID?: string, text?: ?(string | Object | Array), textStyle?: ?ViewPropTypes.style, }> { render(): React.Node { if (!this.props.imageSource && !this.props.text && !this.props.mainView) { return null; } const mainView = this.props.mainView ? ( this.props.mainView ) : ( {this.props.text} ); return ( {mainView} ); } } module.exports = SwipeableQuickActionButton;