mirror of
https://github.com/BlueWallet/BlueWallet.git
synced 2025-01-18 21:35:21 +01:00
54 lines
1.6 KiB
TypeScript
54 lines
1.6 KiB
TypeScript
import React, { useCallback, useMemo } from 'react';
|
|
import { StyleSheet, TouchableOpacity, GestureResponderEvent } from 'react-native';
|
|
import { Icon } from '@rneui/themed';
|
|
import { useTheme } from './themes';
|
|
import ToolTipMenu from './TooltipMenu';
|
|
import { CommonToolTipActions } from '../typings/CommonToolTipActions';
|
|
import loc from '../loc';
|
|
import { navigationRef } from '../NavigationService';
|
|
|
|
type AddWalletButtonProps = {
|
|
onPress?: (event: GestureResponderEvent) => void;
|
|
};
|
|
|
|
const styles = StyleSheet.create({
|
|
ball: {
|
|
width: 30,
|
|
height: 30,
|
|
borderRadius: 15,
|
|
justifyContent: 'center',
|
|
alignContent: 'center',
|
|
},
|
|
});
|
|
|
|
const AddWalletButton: React.FC<AddWalletButtonProps> = ({ onPress }) => {
|
|
const { colors } = useTheme();
|
|
const stylesHook = StyleSheet.create({
|
|
ball: {
|
|
backgroundColor: colors.buttonBackgroundColor,
|
|
},
|
|
});
|
|
|
|
const onPressMenuItem = useCallback((action: string) => {
|
|
switch (action) {
|
|
case CommonToolTipActions.ImportWallet.id:
|
|
navigationRef.current?.navigate('AddWalletRoot', { screen: 'ImportWallet' });
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
}, []);
|
|
|
|
const actions = useMemo(() => [CommonToolTipActions.ImportWallet], []);
|
|
|
|
return (
|
|
<ToolTipMenu accessibilityRole="button" accessibilityLabel={loc.wallets.add_title} onPressMenuItem={onPressMenuItem} actions={actions}>
|
|
<TouchableOpacity style={[styles.ball, stylesHook.ball]} onPress={onPress}>
|
|
<Icon name="add" size={22} type="ionicons" color={colors.foregroundColor} />
|
|
</TouchableOpacity>
|
|
</ToolTipMenu>
|
|
);
|
|
};
|
|
|
|
export default AddWalletButton;
|