James Prado 816ce3180f Translation Updates (#1323)
* 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
2018-03-21 22:50:25 -05:00

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);