mirror of
https://github.com/BlueWallet/BlueWallet.git
synced 2025-01-19 05:45:15 +01:00
ADD: Long press Transaction Row to get shortcuts
This commit is contained in:
parent
74a0018acf
commit
8cc64979bb
@ -1,5 +1,5 @@
|
|||||||
/* eslint react/prop-types: "off", react-native/no-inline-styles: "off" */
|
/* eslint react/prop-types: "off", react-native/no-inline-styles: "off" */
|
||||||
import React, { Component, useState, useMemo, useCallback, useContext } from 'react';
|
import React, { Component, useState, useMemo, useCallback, useContext, useRef } from 'react';
|
||||||
import PropTypes from 'prop-types';
|
import PropTypes from 'prop-types';
|
||||||
import { Icon, Input, Text, Header, ListItem, Avatar } from 'react-native-elements';
|
import { Icon, Input, Text, Header, ListItem, Avatar } from 'react-native-elements';
|
||||||
import {
|
import {
|
||||||
@ -42,6 +42,7 @@ import loc, { formatBalance, formatBalanceWithoutSuffix, formatBalancePlain, rem
|
|||||||
import Lnurl from './class/lnurl';
|
import Lnurl from './class/lnurl';
|
||||||
import { BlueStorageContext } from './blue_modules/storage-context';
|
import { BlueStorageContext } from './blue_modules/storage-context';
|
||||||
import ToolTipMenu from './components/TooltipMenu';
|
import ToolTipMenu from './components/TooltipMenu';
|
||||||
|
|
||||||
/** @type {AppStorage} */
|
/** @type {AppStorage} */
|
||||||
const { height, width } = Dimensions.get('window');
|
const { height, width } = Dimensions.get('window');
|
||||||
const aspectRatio = height / width;
|
const aspectRatio = height / width;
|
||||||
@ -301,7 +302,6 @@ export class BlueWalletNavigationHeader extends Component {
|
|||||||
};
|
};
|
||||||
|
|
||||||
handleToolTipOnPress = item => {
|
handleToolTipOnPress = item => {
|
||||||
console.warn(item);
|
|
||||||
if (item === 'copyToClipboard') {
|
if (item === 'copyToClipboard') {
|
||||||
this.handleCopyPress();
|
this.handleCopyPress();
|
||||||
} else if (item === 'walletBalanceVisibility') {
|
} else if (item === 'walletBalanceVisibility') {
|
||||||
@ -610,6 +610,7 @@ export const BlueListItem = React.memo(props => {
|
|||||||
topDivider={props.topDivider !== undefined ? props.topDivider : false}
|
topDivider={props.topDivider !== undefined ? props.topDivider : false}
|
||||||
testID={props.testID}
|
testID={props.testID}
|
||||||
onPress={props.onPress}
|
onPress={props.onPress}
|
||||||
|
onLongPress={props.onLongPress}
|
||||||
disabled={props.disabled}
|
disabled={props.disabled}
|
||||||
>
|
>
|
||||||
{props.leftAvatar && <Avatar>{props.leftAvatar}</Avatar>}
|
{props.leftAvatar && <Avatar>{props.leftAvatar}</Avatar>}
|
||||||
@ -1260,6 +1261,8 @@ export const BlueTransactionListItem = React.memo(({ item, itemPriceUnit = Bitco
|
|||||||
}),
|
}),
|
||||||
[colors.lightBorder],
|
[colors.lightBorder],
|
||||||
);
|
);
|
||||||
|
const toolTip = useRef();
|
||||||
|
const listItemRef = useRef();
|
||||||
|
|
||||||
const title = useMemo(() => {
|
const title = useMemo(() => {
|
||||||
if (item.confirmations === 0) {
|
if (item.confirmations === 0) {
|
||||||
@ -1446,6 +1449,10 @@ export const BlueTransactionListItem = React.memo(({ item, itemPriceUnit = Bitco
|
|||||||
}, [item, wallets]);
|
}, [item, wallets]);
|
||||||
|
|
||||||
const onLongPress = useCallback(() => {
|
const onLongPress = useCallback(() => {
|
||||||
|
toolTip.current.showMenu();
|
||||||
|
}, []);
|
||||||
|
|
||||||
|
const handleOnExpandNote = useCallback(() => {
|
||||||
if (subtitleNumberOfLines === 1) {
|
if (subtitleNumberOfLines === 1) {
|
||||||
setSubtitleNumberOfLines(0);
|
setSubtitleNumberOfLines(0);
|
||||||
}
|
}
|
||||||
@ -1453,8 +1460,55 @@ export const BlueTransactionListItem = React.memo(({ item, itemPriceUnit = Bitco
|
|||||||
|
|
||||||
const subtitleProps = useMemo(() => ({ numberOfLines: subtitleNumberOfLines }), [subtitleNumberOfLines]);
|
const subtitleProps = useMemo(() => ({ numberOfLines: subtitleNumberOfLines }), [subtitleNumberOfLines]);
|
||||||
|
|
||||||
|
const handleOnCopyAmountTap = useCallback(() => Clipboard.setString(rowTitle), [rowTitle]);
|
||||||
|
const handleOnCopyTransactionID = useCallback(() => Clipboard.setString(item.hash), [item.hash]);
|
||||||
|
const handleOnCopyNote = useCallback(() => Clipboard.setString(subtitle), [subtitle]);
|
||||||
|
|
||||||
|
const toolTipActions = useMemo(() => {
|
||||||
|
const actions = [
|
||||||
|
{
|
||||||
|
id: 'copyAmount',
|
||||||
|
text: loc.transactions.copy_amount,
|
||||||
|
onPress: handleOnCopyAmountTap,
|
||||||
|
},
|
||||||
|
];
|
||||||
|
if (item.hash) {
|
||||||
|
actions.push({
|
||||||
|
id: 'copyTX_ID',
|
||||||
|
text: loc.transactions.copy_transaction_id,
|
||||||
|
onPress: handleOnCopyTransactionID,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
if (subtitle) {
|
||||||
|
actions.push(
|
||||||
|
{
|
||||||
|
id: 'copyNote',
|
||||||
|
text: loc.transactions.copy_note,
|
||||||
|
onPress: handleOnCopyNote,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
id: 'expandNote',
|
||||||
|
text: loc.transactions.expand_note,
|
||||||
|
onPress: handleOnExpandNote,
|
||||||
|
},
|
||||||
|
);
|
||||||
|
}
|
||||||
|
return actions;
|
||||||
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
||||||
|
}, [item.hash, subtitle, rowTitle]);
|
||||||
|
|
||||||
|
const handleOnToolTipActionPress = useCallback(
|
||||||
|
id => {
|
||||||
|
const action = toolTipActions.find(action => action.id === id);
|
||||||
|
action.onPress();
|
||||||
|
},
|
||||||
|
[toolTipActions],
|
||||||
|
);
|
||||||
|
|
||||||
return (
|
return (
|
||||||
|
<TouchableWithoutFeedback ref={listItemRef}>
|
||||||
<View style={{ marginHorizontal: 4 }}>
|
<View style={{ marginHorizontal: 4 }}>
|
||||||
|
<ToolTipMenu ref={toolTip} anchorRef={listItemRef} actions={toolTipActions} onPress={handleOnToolTipActionPress} />
|
||||||
<BlueListItem
|
<BlueListItem
|
||||||
leftAvatar={avatar}
|
leftAvatar={avatar}
|
||||||
title={title}
|
title={title}
|
||||||
@ -1462,14 +1516,15 @@ export const BlueTransactionListItem = React.memo(({ item, itemPriceUnit = Bitco
|
|||||||
subtitle={subtitle}
|
subtitle={subtitle}
|
||||||
subtitleProps={subtitleProps}
|
subtitleProps={subtitleProps}
|
||||||
onPress={onPress}
|
onPress={onPress}
|
||||||
onLongPress={onLongPress}
|
|
||||||
chevron={false}
|
chevron={false}
|
||||||
Component={TouchableOpacity}
|
Component={TouchableOpacity}
|
||||||
rightTitle={rowTitle}
|
rightTitle={rowTitle}
|
||||||
rightTitleStyle={rowTitleStyle}
|
rightTitleStyle={rowTitleStyle}
|
||||||
containerStyle={containerStyle}
|
containerStyle={containerStyle}
|
||||||
|
onLongPress={onLongPress}
|
||||||
/>
|
/>
|
||||||
</View>
|
</View>
|
||||||
|
</TouchableWithoutFeedback>
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -18,13 +18,12 @@ const ToolTipMenu = (props, ref) => {
|
|||||||
// eslint-disable-next-line react-hooks/exhaustive-deps
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
||||||
}, [ref]);
|
}, [ref]);
|
||||||
|
|
||||||
return <View ref={ref}>{props.children}</View>;
|
return <View ref={ref} />;
|
||||||
};
|
};
|
||||||
|
|
||||||
export default forwardRef(ToolTipMenu);
|
export default forwardRef(ToolTipMenu);
|
||||||
ToolTipMenu.propTypes = {
|
ToolTipMenu.propTypes = {
|
||||||
actions: PropTypes.arrayOf(PropTypes.shape).isRequired,
|
actions: PropTypes.arrayOf(PropTypes.shape).isRequired,
|
||||||
anchorRef: PropTypes.node,
|
anchorRef: PropTypes.node,
|
||||||
children: PropTypes.node,
|
|
||||||
onPress: PropTypes.func.isRequired,
|
onPress: PropTypes.func.isRequired,
|
||||||
};
|
};
|
||||||
|
@ -333,6 +333,10 @@
|
|||||||
"cancel_no": "This transaction is not replaceable.",
|
"cancel_no": "This transaction is not replaceable.",
|
||||||
"cancel_title": "Cancel this transaction (RBF)",
|
"cancel_title": "Cancel this transaction (RBF)",
|
||||||
"confirmations_lowercase": "{confirmations} confirmations",
|
"confirmations_lowercase": "{confirmations} confirmations",
|
||||||
|
"copy_transaction_id": "Copy Transaction ID",
|
||||||
|
"copy_note": "Copy Note",
|
||||||
|
"expand_note": "Expand Note",
|
||||||
|
"copy_amount": "Copy Amount",
|
||||||
"cpfp_create": "Create",
|
"cpfp_create": "Create",
|
||||||
"cpfp_exp": "We will create another transaction that spends your unconfirmed transaction. The total fee will be higher than the original transaction fee, so it should be mined faster. This is called CPFP—Child Pays for Parent.",
|
"cpfp_exp": "We will create another transaction that spends your unconfirmed transaction. The total fee will be higher than the original transaction fee, so it should be mined faster. This is called CPFP—Child Pays for Parent.",
|
||||||
"cpfp_no_bump": "This transaction is not bumpable.",
|
"cpfp_no_bump": "This transaction is not bumpable.",
|
||||||
|
Loading…
Reference in New Issue
Block a user