mirror of
https://github.com/status-im/MyCrypto.git
synced 2025-01-10 11:05:47 +00:00
816ce3180f
* Update account view routing * Temporarily add unicode character to translated strings for testing * Temporarily select add unicode to all untranslated strings * Format changes * Add all english translations for /account & /generate * Add the rest of the english translations * Add a few more missing translations * Update en translations * Get selectedLanguage from localstorage instead of redux sttate * Update snapshots * Add missing translation keys & Update translate functs & change variable prefix * translate all markdown strings & remove old translation strings * Update snapshot * Add a few more translation strs * Move raw strings being translated into json * All translation keys are now Uppercase * Fix up the last few translations * Update snapshot * Uppercase de translation strings * Bring back shapeshift logo on swap * Fix contracts tab translations * Fix a few more translations * Fix translations * remove debugging stuff * Update snapshots * Use react.fragment as markdown root renderer * Seperate markdown translations into their own function * Clean up translation functions * Clean up translation functions * Update snapshot * Fix some broken translation strings * Add prettier ignore file
88 lines
2.5 KiB
TypeScript
88 lines
2.5 KiB
TypeScript
import React from 'react';
|
|
import { connect } from 'react-redux';
|
|
import translate from 'translations';
|
|
import { fetchTransactionData, TFetchTransactionData } from 'actions/transactions';
|
|
import { getTransactionDatas } from 'selectors/transactions';
|
|
import { getNetworkConfig } from 'selectors/config';
|
|
import { Spinner } from 'components/ui';
|
|
import TransactionDataTable from './TransactionDataTable';
|
|
import { AppState } from 'reducers';
|
|
import { NetworkConfig } from 'types/network';
|
|
import { TransactionState } from 'types/transactions';
|
|
import './TransactionStatus.scss';
|
|
|
|
interface OwnProps {
|
|
txHash: string;
|
|
}
|
|
|
|
interface StateProps {
|
|
tx: TransactionState | null;
|
|
network: NetworkConfig;
|
|
}
|
|
|
|
interface ActionProps {
|
|
fetchTransactionData: TFetchTransactionData;
|
|
}
|
|
|
|
type Props = OwnProps & StateProps & ActionProps;
|
|
|
|
class TransactionStatus extends React.Component<Props> {
|
|
public componentDidMount() {
|
|
this.props.fetchTransactionData(this.props.txHash);
|
|
}
|
|
|
|
public componentWillReceiveProps(nextProps: Props) {
|
|
if (this.props.txHash !== nextProps.txHash) {
|
|
this.props.fetchTransactionData(nextProps.txHash);
|
|
}
|
|
}
|
|
|
|
public render() {
|
|
const { tx, network } = this.props;
|
|
let content;
|
|
|
|
if (tx && tx.data) {
|
|
content = (
|
|
<React.Fragment>
|
|
<div className="TxStatus-data">
|
|
<TransactionDataTable network={network} data={tx.data} receipt={tx.receipt} />
|
|
</div>
|
|
</React.Fragment>
|
|
);
|
|
} else if (tx && tx.error) {
|
|
content = (
|
|
<div className="TxStatus-error">
|
|
<h2 className="TxStatus-error-title">{translate('TX_NOTFOUND')}</h2>
|
|
<p className="TxStatus-error-desc">{translate('TX_NOTFOUND_1')}</p>
|
|
<ul className="TxStatus-error-list">
|
|
<li>{translate('TX_NOTFOUND_5')}</li>
|
|
<li>{translate('TX_NOTFOUND_2')}</li>
|
|
<li>{translate('TX_NOTFOUND_3')}</li>
|
|
<li>{translate('TX_NOTFOUND_4')}</li>
|
|
</ul>
|
|
</div>
|
|
);
|
|
} else if (tx && tx.isLoading) {
|
|
// tx.isLoading... probably.
|
|
content = (
|
|
<div className="TxStatus-loading">
|
|
<Spinner size="x3" />
|
|
</div>
|
|
);
|
|
}
|
|
|
|
return <div className="TxStatus">{content}</div>;
|
|
}
|
|
}
|
|
|
|
function mapStateToProps(state: AppState, ownProps: OwnProps): StateProps {
|
|
const { txHash } = ownProps;
|
|
|
|
return {
|
|
tx: getTransactionDatas(state)[txHash],
|
|
network: getNetworkConfig(state)
|
|
};
|
|
}
|
|
|
|
export default connect(mapStateToProps, { fetchTransactionData })(TransactionStatus);
|