2017-10-17 04:01:28 +00:00
|
|
|
import React from 'react';
|
|
|
|
import translate from 'translations';
|
2017-11-12 19:45:52 +00:00
|
|
|
import { decodeTransaction } from 'libs/transaction';
|
|
|
|
import EthTx from 'ethereumjs-tx';
|
2017-10-17 04:01:28 +00:00
|
|
|
import Code from 'components/ui/Code';
|
|
|
|
export interface Props {
|
|
|
|
signedTx: string;
|
|
|
|
}
|
|
|
|
|
|
|
|
export const TxCompare = (props: Props) => {
|
|
|
|
if (!props.signedTx) {
|
|
|
|
return null;
|
|
|
|
}
|
2017-11-12 19:45:52 +00:00
|
|
|
const rawTx = decodeTransaction(new EthTx(props.signedTx), false);
|
|
|
|
|
2017-10-17 04:01:28 +00:00
|
|
|
const Left = () => (
|
|
|
|
<div className="form-group">
|
|
|
|
<h4>{translate('SEND_raw')}</h4>
|
2017-11-12 19:45:52 +00:00
|
|
|
<Code>{JSON.stringify(rawTx, null, 2)}</Code>
|
2017-10-17 04:01:28 +00:00
|
|
|
</div>
|
|
|
|
);
|
|
|
|
const Right = () => (
|
|
|
|
<div className="form-group">
|
|
|
|
<h4> {translate('SEND_signed')} </h4>
|
2017-11-12 19:45:52 +00:00
|
|
|
<Code>{props.signedTx}</Code>
|
2017-10-17 04:01:28 +00:00
|
|
|
</div>
|
|
|
|
);
|
|
|
|
return (
|
|
|
|
<section>
|
|
|
|
<Left />
|
|
|
|
<Right />
|
|
|
|
</section>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
export type TTxCompare = typeof TxCompare;
|