mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
112 lines
3.8 KiB
JavaScript
Executable File
112 lines
3.8 KiB
JavaScript
Executable File
import React, { useContext } from 'react';
|
|
import { useDispatch, useSelector } from 'react-redux';
|
|
import { useHistory, useParams } from 'react-router-dom';
|
|
import {
|
|
getCurrentChainId,
|
|
getUnapprovedTransactions,
|
|
} from '../../../../selectors';
|
|
import { transactionMatchesNetwork } from '../../../../../shared/modules/transaction.utils';
|
|
import { I18nContext } from '../../../../contexts/i18n';
|
|
import { CONFIRM_TRANSACTION_ROUTE } from '../../../../helpers/constants/routes';
|
|
import { clearConfirmTransaction } from '../../../../ducks/confirm-transaction/confirm-transaction.duck';
|
|
import { hexToDecimal } from '../../../../../shared/modules/conversion.utils';
|
|
|
|
const ConfirmPageContainerNavigation = () => {
|
|
const t = useContext(I18nContext);
|
|
const dispatch = useDispatch();
|
|
const history = useHistory();
|
|
const { id } = useParams();
|
|
|
|
const unapprovedTxs = useSelector(getUnapprovedTransactions);
|
|
const currentChainId = useSelector(getCurrentChainId);
|
|
const network = hexToDecimal(currentChainId);
|
|
|
|
const currentNetworkUnapprovedTxs = Object.keys(unapprovedTxs)
|
|
.filter((key) =>
|
|
transactionMatchesNetwork(unapprovedTxs[key], currentChainId, network),
|
|
)
|
|
.reduce((acc, key) => ({ ...acc, [key]: unapprovedTxs[key] }), {});
|
|
|
|
const enumUnapprovedTxs = Object.keys(currentNetworkUnapprovedTxs);
|
|
|
|
const currentPosition = enumUnapprovedTxs.indexOf(id);
|
|
|
|
const totalTx = enumUnapprovedTxs.length;
|
|
const positionOfCurrentTx = currentPosition + 1;
|
|
const nextTxId = enumUnapprovedTxs[currentPosition + 1];
|
|
const prevTxId = enumUnapprovedTxs[currentPosition - 1];
|
|
const showNavigation = enumUnapprovedTxs.length > 1;
|
|
const firstTx = enumUnapprovedTxs[0];
|
|
const lastTx = enumUnapprovedTxs[enumUnapprovedTxs.length - 1];
|
|
|
|
const onNextTx = (txId) => {
|
|
if (txId) {
|
|
dispatch(clearConfirmTransaction());
|
|
history.push(`${CONFIRM_TRANSACTION_ROUTE}/${txId}`);
|
|
}
|
|
};
|
|
|
|
return (
|
|
<div
|
|
className="confirm-page-container-navigation"
|
|
style={{
|
|
display: showNavigation ? 'flex' : 'none',
|
|
}}
|
|
>
|
|
<div
|
|
className="confirm-page-container-navigation__container"
|
|
data-testid="navigation-container"
|
|
style={{
|
|
visibility: prevTxId ? 'initial' : 'hidden',
|
|
}}
|
|
>
|
|
<button
|
|
className="confirm-page-container-navigation__arrow"
|
|
data-testid="first-page"
|
|
onClick={() => onNextTx(firstTx)}
|
|
>
|
|
<i className="fa fa-angle-double-left fa-2x" />
|
|
</button>
|
|
<button
|
|
className="confirm-page-container-navigation__arrow"
|
|
data-testid="previous-page"
|
|
onClick={() => onNextTx(prevTxId)}
|
|
>
|
|
<i className="fa fa-angle-left fa-2x" />
|
|
</button>
|
|
</div>
|
|
<div className="confirm-page-container-navigation__textcontainer">
|
|
<div className="confirm-page-container-navigation__navtext">
|
|
{positionOfCurrentTx} {t('ofTextNofM')} {totalTx}
|
|
</div>
|
|
<div className="confirm-page-container-navigation__longtext">
|
|
{t('requestsAwaitingAcknowledgement')}
|
|
</div>
|
|
</div>
|
|
<div
|
|
className="confirm-page-container-navigation__container"
|
|
style={{
|
|
visibility: nextTxId ? 'initial' : 'hidden',
|
|
}}
|
|
>
|
|
<button
|
|
className="confirm-page-container-navigation__arrow"
|
|
data-testid="next-page"
|
|
onClick={() => onNextTx(nextTxId)}
|
|
>
|
|
<i className="fa fa-angle-right fa-2x" />
|
|
</button>
|
|
<button
|
|
className="confirm-page-container-navigation__arrow"
|
|
data-testid="last-page"
|
|
onClick={() => onNextTx(lastTx)}
|
|
>
|
|
<i className="fa fa-angle-double-right fa-2x" />
|
|
</button>
|
|
</div>
|
|
</div>
|
|
);
|
|
};
|
|
|
|
export default ConfirmPageContainerNavigation;
|