mirror of
https://github.com/BlueWallet/BlueWallet.git
synced 2025-01-18 21:35:21 +01:00
ADD: Copy submenu
This commit is contained in:
parent
a3d7c2a151
commit
ab77ce95fa
@ -1254,6 +1254,7 @@ export const BlueTransactionListItem = React.memo(({ item, itemPriceUnit = Bitco
|
||||
[colors.lightBorder],
|
||||
);
|
||||
const toolTip = useRef();
|
||||
const copyToolTip = useRef();
|
||||
const listItemRef = useRef();
|
||||
|
||||
const title = useMemo(() => {
|
||||
@ -1452,7 +1453,10 @@ export const BlueTransactionListItem = React.memo(({ item, itemPriceUnit = Bitco
|
||||
}, []);
|
||||
|
||||
const subtitleProps = useMemo(() => ({ numberOfLines: subtitleNumberOfLines }), [subtitleNumberOfLines]);
|
||||
|
||||
const handleOnCopyTap = useCallback(() => {
|
||||
toolTip.current.hideMenu();
|
||||
setTimeout(copyToolTip.current.showMenu, 400);
|
||||
}, []);
|
||||
const handleOnCopyAmountTap = useCallback(() => Clipboard.setString(rowTitle), [rowTitle]);
|
||||
const handleOnCopyTransactionID = useCallback(() => Clipboard.setString(item.hash), [item.hash]);
|
||||
const handleOnCopyNote = useCallback(() => Clipboard.setString(subtitle), [subtitle]);
|
||||
@ -1464,50 +1468,75 @@ export const BlueTransactionListItem = React.memo(({ item, itemPriceUnit = Bitco
|
||||
}
|
||||
});
|
||||
}, [item.hash]);
|
||||
const handleCopyOpenInBlockExplorerPress = useCallback(() => {
|
||||
Clipboard.setString(`https://blockstream.info/tx/${item.hash}`);
|
||||
}, [item.hash]);
|
||||
const toolTipActions = useMemo(() => {
|
||||
const actions = [
|
||||
{
|
||||
id: 'copyAmount',
|
||||
text: loc.transactions.copy_amount,
|
||||
onPress: handleOnCopyAmountTap,
|
||||
id: 'copy',
|
||||
text: loc.transactions.details_copy,
|
||||
onPress: handleOnCopyTap,
|
||||
},
|
||||
];
|
||||
if (item.hash) {
|
||||
actions.push({
|
||||
id: 'open_in_blockExplorer',
|
||||
text: loc.transactions.details_show_in_block_explorer,
|
||||
onPress: handleOnViewOnBlockExplorer,
|
||||
});
|
||||
}
|
||||
if (subtitle && subtitleNumberOfLines === 1) {
|
||||
actions.push({
|
||||
id: 'expandNote',
|
||||
text: loc.transactions.expand_note,
|
||||
onPress: handleOnExpandNote,
|
||||
});
|
||||
}
|
||||
return actions;
|
||||
// eslint-disable-next-line react-hooks/exhaustive-deps
|
||||
}, [item.hash, subtitle, rowTitle, subtitleNumberOfLines, txMetadata]);
|
||||
|
||||
const copyToolTipActions = useMemo(() => {
|
||||
const actions = [];
|
||||
if (rowTitle !== loc.lnd.expired) {
|
||||
actions.push({
|
||||
id: 'copyAmount',
|
||||
text: loc.send.create_amount,
|
||||
onPress: handleOnCopyAmountTap,
|
||||
});
|
||||
}
|
||||
|
||||
if (item.hash) {
|
||||
actions.push(
|
||||
{
|
||||
id: 'copyTX_ID',
|
||||
text: loc.transactions.copy_transaction_id,
|
||||
text: loc.transactions.transaction_id,
|
||||
onPress: handleOnCopyTransactionID,
|
||||
},
|
||||
{
|
||||
id: 'open_in_blockexplorer',
|
||||
text: loc.transactions.details_show_in_block_explorer,
|
||||
onPress: handleOnViewOnBlockExplorer,
|
||||
id: 'copy_blockExplorer',
|
||||
text: loc.transactions.block_explorer_link,
|
||||
onPress: handleCopyOpenInBlockExplorerPress,
|
||||
},
|
||||
);
|
||||
}
|
||||
if (subtitle) {
|
||||
actions.push({
|
||||
id: 'copyNote',
|
||||
text: loc.transactions.copy_note,
|
||||
text: loc.transactions.note,
|
||||
onPress: handleOnCopyNote,
|
||||
});
|
||||
if (subtitleNumberOfLines === 1) {
|
||||
actions.push({
|
||||
id: 'expandNote',
|
||||
text: loc.transactions.expand_note,
|
||||
onPress: handleOnExpandNote,
|
||||
});
|
||||
}
|
||||
}
|
||||
return actions;
|
||||
// eslint-disable-next-line react-hooks/exhaustive-deps
|
||||
}, [item.hash, subtitle, rowTitle, subtitleNumberOfLines, txMetadata]);
|
||||
}, [toolTipActions]);
|
||||
|
||||
return (
|
||||
<TouchableWithoutFeedback ref={listItemRef}>
|
||||
<View style={{ marginHorizontal: 4 }}>
|
||||
<ToolTipMenu ref={toolTip} anchorRef={listItemRef} actions={toolTipActions} />
|
||||
<ToolTipMenu ref={copyToolTip} anchorRef={listItemRef} actions={copyToolTipActions} />
|
||||
<BlueListItem
|
||||
leftAvatar={avatar}
|
||||
title={title}
|
||||
|
@ -14,10 +14,15 @@ const ToolTipMenu = (props, ref) => {
|
||||
showPopupMenu(actions, handleToolTipSelection, props.anchorRef.current);
|
||||
};
|
||||
|
||||
const hideMenu = () => {
|
||||
console.log('not implemented');
|
||||
};
|
||||
|
||||
useEffect(() => {
|
||||
ref.current.showMenu = showMenu;
|
||||
ref.current.hideMenu = hideMenu;
|
||||
// eslint-disable-next-line react-hooks/exhaustive-deps
|
||||
}, [ref]);
|
||||
}, [ref, props.actions]);
|
||||
|
||||
return <View ref={ref} />;
|
||||
};
|
||||
|
@ -11,8 +11,14 @@ const ToolTipMenu = (props, ref) => {
|
||||
toolTip.current?.showMenu();
|
||||
};
|
||||
|
||||
const hideMenu = () => {
|
||||
console.log('Hiding ToolTip');
|
||||
toolTip.current?.hideMenu();
|
||||
};
|
||||
|
||||
useEffect(() => {
|
||||
ref.current.showMenu = showMenu;
|
||||
ref.current.hideMenu = hideMenu;
|
||||
}, [ref]);
|
||||
|
||||
return (
|
||||
|
@ -1,5 +1,22 @@
|
||||
const ToolTipMenu = props => {
|
||||
return props.children;
|
||||
import React, { forwardRef, useEffect } from 'react';
|
||||
import { View } from 'react-native';
|
||||
|
||||
const ToolTipMenu = (props, ref) => {
|
||||
const showMenu = () => {
|
||||
console.log('not implemented');
|
||||
};
|
||||
|
||||
const hideMenu = () => {
|
||||
console.log('not implemented');
|
||||
};
|
||||
|
||||
useEffect(() => {
|
||||
ref.current.showMenu = showMenu;
|
||||
ref.current.hideMenu = hideMenu;
|
||||
// eslint-disable-next-line react-hooks/exhaustive-deps
|
||||
}, [ref]);
|
||||
|
||||
return <View ref={ref} />;
|
||||
};
|
||||
|
||||
export default ToolTipMenu;
|
||||
export default forwardRef(ToolTipMenu);
|
||||
|
@ -333,10 +333,10 @@
|
||||
"cancel_no": "This transaction is not replaceable.",
|
||||
"cancel_title": "Cancel this transaction (RBF)",
|
||||
"confirmations_lowercase": "{confirmations} confirmations",
|
||||
"copy_transaction_id": "Copy Transaction ID",
|
||||
"copy_note": "Copy Note",
|
||||
"transaction_id": "Transaction ID",
|
||||
"note": "Note",
|
||||
"expand_note": "Expand Note",
|
||||
"copy_amount": "Copy Amount",
|
||||
"block_explorer_link": "Block Explorer Link",
|
||||
"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_no_bump": "This transaction is not bumpable.",
|
||||
|
Loading…
Reference in New Issue
Block a user