Files
mattermost-mobile/app/components/touchable_with_feedback/touchable_with_feedback.android.tsx
Elias Nahum 7aa5bd0611 Update Dependencies and bug fixes (#7000)
* update dependencies

* update dependencies

* feedback review

* update @mattermost/react-native-turbo-mailer
2023-01-24 09:14:23 +02:00

56 lines
1.8 KiB
TypeScript

// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
// See LICENSE.txt for license information.
/* eslint-disable new-cap */
import React, {memo} from 'react';
import {Touchable, TouchableOpacity, TouchableNativeFeedback, TouchableWithoutFeedback, View, StyleProp, ViewStyle} from 'react-native';
type TouchableProps = Touchable & {
children: React.ReactNode | React.ReactNode[];
borderlessRipple?: boolean;
rippleRadius?: number;
style?: StyleProp<ViewStyle>;
testID: string;
type: 'native' | 'opacity' | 'none';
underlayColor: string;
}
const TouchableWithFeedbackAndroid = ({borderlessRipple = false, children, rippleRadius, testID, type = 'native', underlayColor, ...props}: TouchableProps) => {
switch (type) {
case 'native':
return (
<TouchableNativeFeedback
testID={testID}
{...props}
style={[props.style]}
background={TouchableNativeFeedback.Ripple(underlayColor || '#fff', borderlessRipple, rippleRadius)}
>
<View>
{children}
</View>
</TouchableNativeFeedback>
);
case 'opacity':
return (
<TouchableOpacity
testID={testID}
{...props}
>
{children}
</TouchableOpacity>
);
default:
return (
<TouchableWithoutFeedback
testID={testID}
{...props}
>
{children}
</TouchableWithoutFeedback>
);
}
};
export default memo(TouchableWithFeedbackAndroid);