2019-12-04 16:39:53 +00:00
|
|
|
import React from 'react';
|
2022-01-24 20:12:25 +00:00
|
|
|
import { RectButton, RectButtonProps } from 'react-native-gesture-handler';
|
2019-12-04 16:39:53 +00:00
|
|
|
|
2022-04-28 18:44:40 +00:00
|
|
|
import { TSupportedThemes } from '../theme';
|
|
|
|
import { themes } from '../lib/constants';
|
2019-12-04 16:39:53 +00:00
|
|
|
|
2022-01-24 20:12:25 +00:00
|
|
|
interface ITouchProps extends RectButtonProps {
|
|
|
|
children: React.ReactNode;
|
2022-04-28 18:44:40 +00:00
|
|
|
theme: TSupportedThemes;
|
2022-01-24 20:12:25 +00:00
|
|
|
accessibilityLabel?: string;
|
|
|
|
testID?: string;
|
|
|
|
}
|
|
|
|
|
|
|
|
class Touch extends React.Component<ITouchProps> {
|
|
|
|
private ref: any;
|
|
|
|
|
|
|
|
setNativeProps(props: ITouchProps): void {
|
2019-12-04 16:39:53 +00:00
|
|
|
this.ref.setNativeProps(props);
|
|
|
|
}
|
|
|
|
|
2022-01-24 20:12:25 +00:00
|
|
|
getRef = (ref: RectButton): void => {
|
2019-12-04 16:39:53 +00:00
|
|
|
this.ref = ref;
|
|
|
|
};
|
|
|
|
|
2022-01-24 20:12:25 +00:00
|
|
|
render(): JSX.Element {
|
2021-10-01 18:12:19 +00:00
|
|
|
const { children, onPress, theme, underlayColor, ...props } = this.props;
|
2019-12-04 16:39:53 +00:00
|
|
|
|
|
|
|
return (
|
|
|
|
<RectButton
|
|
|
|
ref={this.getRef}
|
|
|
|
onPress={onPress}
|
|
|
|
activeOpacity={1}
|
2021-01-25 17:14:45 +00:00
|
|
|
underlayColor={underlayColor || themes[theme].bannerBackground}
|
2019-12-04 16:39:53 +00:00
|
|
|
rippleColor={themes[theme].bannerBackground}
|
2021-10-01 18:12:19 +00:00
|
|
|
{...props}>
|
2019-12-04 16:39:53 +00:00
|
|
|
{children}
|
|
|
|
</RectButton>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export default Touch;
|