Files
mattermost-mobile/app/components/conditional_touchable.js
2018-06-19 19:14:50 -04:00

30 lines
808 B
JavaScript

// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
// See LICENSE.txt for license information.
import PropTypes from 'prop-types';
import React from 'react';
import {TouchableOpacity} from 'react-native';
import CustomPropTypes from 'app/constants/custom_prop_types';
export default class ConditionalTouchable extends React.PureComponent {
static propTypes = {
touchable: PropTypes.bool,
children: CustomPropTypes.Children.isRequired,
};
render() {
const {touchable, children, ...otherProps} = this.props;
if (touchable) {
return (
<TouchableOpacity {...otherProps}>
{children}
</TouchableOpacity>
);
}
return React.Children.only(children);
}
}