mirror of
https://github.com/status-im/MyCrypto.git
synced 2025-01-23 01:19:02 +00:00
be61d804e0
* Component layer and routing for transaction status. * Initial start on redux for transactions. * Initial crack at reducer / actions / saga for transactions. * Finish off check transaction saga, reducer, component, and page.
40 lines
1.4 KiB
TypeScript
40 lines
1.4 KiB
TypeScript
import { setTransactionData, FetchTransactionDataAction, TypeKeys } from 'actions/transactions';
|
|
import { SagaIterator } from 'redux-saga';
|
|
import { put, select, apply, takeEvery } from 'redux-saga/effects';
|
|
import { getNodeLib } from 'selectors/config';
|
|
import { INode, TransactionData, TransactionReceipt } from 'libs/nodes';
|
|
|
|
export function* fetchTxData(action: FetchTransactionDataAction): SagaIterator {
|
|
const txhash = action.payload;
|
|
let data: TransactionData | null = null;
|
|
let receipt: TransactionReceipt | null = null;
|
|
let error: string | null = null;
|
|
|
|
const node: INode = yield select(getNodeLib);
|
|
|
|
// Fetch data and receipt separately, not in parallel. Receipt should only be
|
|
// fetched if the tx is mined, and throws if it's not, but that's not really
|
|
// an "error", since we'd still want to show the unmined tx data.
|
|
try {
|
|
data = yield apply(node, node.getTransactionByHash, [txhash]);
|
|
} catch (err) {
|
|
console.warn('Failed to fetch transaction data', err);
|
|
error = err.message;
|
|
}
|
|
|
|
if (data && data.blockHash) {
|
|
try {
|
|
receipt = yield apply(node, node.getTransactionReceipt, [txhash]);
|
|
} catch (err) {
|
|
console.warn('Failed to fetch transaction receipt', err);
|
|
receipt = null;
|
|
}
|
|
}
|
|
|
|
yield put(setTransactionData({ txhash, data, receipt, error }));
|
|
}
|
|
|
|
export default function* transactions(): SagaIterator {
|
|
yield takeEvery(TypeKeys.TRANSACTIONS_FETCH_TRANSACTION_DATA, fetchTxData);
|
|
}
|