mirror of
https://github.com/status-im/MyCrypto.git
synced 2025-01-11 03:26:14 +00:00
Move up the componentDidCatch to <Fields />
This commit is contained in:
parent
7c52d302ec
commit
b5337a3f78
@ -29,20 +29,6 @@ class BodyClass extends React.Component<StateProps, State> {
|
||||
});
|
||||
};
|
||||
|
||||
public componentDidCatch(error: Error) {
|
||||
if (error.message === 'Serialized transaction not found') {
|
||||
/**
|
||||
* @desc Occasionally, when a new signed transaction matches a previous transaction,
|
||||
* the transaction state is cleared and a warning notification alerts the user. Once the
|
||||
* transaction state is cleared, however, the <Amounts /> component's attempts at selecting
|
||||
* the transaction causes the 'Serialized transaction not found' error.
|
||||
* A longer term fix will involve finding a better way to calculate nonces to avoid
|
||||
* nonce duplication on serial transactions.
|
||||
*/
|
||||
// Pass
|
||||
}
|
||||
}
|
||||
|
||||
public render() {
|
||||
const { showDetails } = this.state;
|
||||
|
||||
|
@ -1,11 +1,12 @@
|
||||
import React, { Component } from 'react';
|
||||
import { connect } from 'react-redux';
|
||||
|
||||
import translate from 'translations';
|
||||
import translate, { translateRaw } from 'translations';
|
||||
import { AppState } from 'features/reducers';
|
||||
import * as selectors from 'features/selectors';
|
||||
import { getOffline, getNetworkConfig } from 'features/config';
|
||||
import { scheduleSelectors } from 'features/schedule';
|
||||
import { notificationsActions } from 'features/notifications';
|
||||
import {
|
||||
AddressField,
|
||||
AmountField,
|
||||
@ -38,7 +39,26 @@ interface StateProps {
|
||||
useScheduling: scheduleSelectors.ICurrentSchedulingToggle['value'];
|
||||
}
|
||||
|
||||
class FieldsClass extends Component<StateProps> {
|
||||
interface DispatchProps {
|
||||
showNotification: notificationsActions.TShowNotification;
|
||||
}
|
||||
|
||||
class FieldsClass extends Component<StateProps & DispatchProps> {
|
||||
public componentDidCatch(error: Error) {
|
||||
if (error.message === 'Serialized transaction not found') {
|
||||
/**
|
||||
* @desc Occasionally, when a new signed transaction matches a previous transaction,
|
||||
* the nonce does not update, since the transaction has not yet been confirmed. This triggers
|
||||
* the <Amounts /> component inside the <ConfirmationModal /> of <TXMetaDataPanel /> to throw
|
||||
* an error when selecting the current transaction's serialized parameters.
|
||||
* A longer term fix will involve finding a better way to calculate nonces to avoid
|
||||
* nonce duplication on serial transactions.
|
||||
*/
|
||||
this.props.showNotification('danger', translateRaw('SIMILAR_TRANSACTION_ERROR'));
|
||||
this.forceUpdate();
|
||||
}
|
||||
}
|
||||
|
||||
public render() {
|
||||
const { shouldDisplay, schedulingAvailable, useScheduling } = this.props;
|
||||
|
||||
@ -106,10 +126,15 @@ class FieldsClass extends Component<StateProps> {
|
||||
}
|
||||
}
|
||||
|
||||
export const Fields = connect((state: AppState) => ({
|
||||
schedulingAvailable:
|
||||
getNetworkConfig(state).name === 'Kovan' && selectors.getUnit(state) === 'ETH',
|
||||
shouldDisplay: !selectors.isAnyOfflineWithWeb3(state),
|
||||
offline: getOffline(state),
|
||||
useScheduling: scheduleSelectors.getCurrentSchedulingToggle(state).value
|
||||
}))(FieldsClass);
|
||||
export const Fields = connect(
|
||||
(state: AppState) => ({
|
||||
schedulingAvailable:
|
||||
getNetworkConfig(state).name === 'Kovan' && selectors.getUnit(state) === 'ETH',
|
||||
shouldDisplay: !selectors.isAnyOfflineWithWeb3(state),
|
||||
offline: getOffline(state),
|
||||
useScheduling: scheduleSelectors.getCurrentSchedulingToggle(state).value
|
||||
}),
|
||||
{
|
||||
showNotification: notificationsActions.showNotification
|
||||
}
|
||||
)(FieldsClass);
|
||||
|
@ -664,6 +664,7 @@
|
||||
"PAYMENT_ID_WARNING": "Don't forget to send your XMR with the payment ID [[?]](https://getmonero.org/resources/moneropedia/paymentid.html) above, or you WILL lose your funds.",
|
||||
"WHAT_IS_PAYMENT_ID": "what's a payment ID?",
|
||||
"ANNOUNCEMENT_MESSAGE": "MyCrypto.com no longer allows the use of private keys, mnemonics, or keystore files in the browser. To continue using them, please download the [MyCrypto Desktop App](https://download.mycrypto.com).",
|
||||
"U2F_NOT_SUPPORTED": "The U2F standard that hardware wallets use does not seem to be supported by your browser. Please try again using Google Chrome."
|
||||
"U2F_NOT_SUPPORTED": "The U2F standard that hardware wallets use does not seem to be supported by your browser. Please try again using Google Chrome.",
|
||||
"SIMILAR_TRANSACTION_ERROR": "This transaction is very similar to a recent transaction. Please wait a few moments and try again, or click 'Advanced' and manually set the nonce to a new value."
|
||||
}
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user