|
|
|
@ -1,12 +1,13 @@
|
|
|
|
|
/* @flow */
|
|
|
|
|
import * as CONNECT from 'actions/constants/TrezorConnect';
|
|
|
|
|
import * as PENDING from 'actions/constants/pendingTx';
|
|
|
|
|
import * as SEND from 'actions/constants/send';
|
|
|
|
|
|
|
|
|
|
import type { TrezorDevice, Action } from 'flowtype';
|
|
|
|
|
import type { Action } from 'flowtype';
|
|
|
|
|
|
|
|
|
|
export type PendingTx = {
|
|
|
|
|
+type: 'send' | 'recv',
|
|
|
|
|
+deviceState: string,
|
|
|
|
|
+sequence: number,
|
|
|
|
|
+hash: string,
|
|
|
|
|
+network: string,
|
|
|
|
|
+address: string,
|
|
|
|
@ -21,35 +22,15 @@ export type State = Array<PendingTx>;
|
|
|
|
|
|
|
|
|
|
const initialState: State = [];
|
|
|
|
|
|
|
|
|
|
// const add = (state: State, action: SendTxAction): State => {
|
|
|
|
|
// const newState = [...state];
|
|
|
|
|
// newState.push({
|
|
|
|
|
// type: 'send',
|
|
|
|
|
// id: action.txid,
|
|
|
|
|
// network: action.account.network,
|
|
|
|
|
// address: action.account.address,
|
|
|
|
|
// deviceState: action.account.deviceState,
|
|
|
|
|
|
|
|
|
|
// currency: action.selectedCurrency,
|
|
|
|
|
// amount: action.amount,
|
|
|
|
|
// total: action.total,
|
|
|
|
|
// tx: action.tx,
|
|
|
|
|
// nonce: action.nonce,
|
|
|
|
|
// rejected: false,
|
|
|
|
|
// });
|
|
|
|
|
// return newState;
|
|
|
|
|
// };
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const addFromNotification = (state: State, payload: PendingTx): State => {
|
|
|
|
|
const add = (state: State, payload: PendingTx): State => {
|
|
|
|
|
const newState = [...state];
|
|
|
|
|
newState.push(payload);
|
|
|
|
|
return newState;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
//const clear = (state: State, device: TrezorDevice): State => state.filter(tx => tx.deviceState !== device.state);
|
|
|
|
|
const removeByDeviceState = (state: State, deviceState: ?string): State => state.filter(tx => tx.deviceState !== deviceState);
|
|
|
|
|
|
|
|
|
|
const remove = (state: State, hash: string): State => state.filter(tx => tx.hash !== hash);
|
|
|
|
|
const removeByHash = (state: State, hash: string): State => state.filter(tx => tx.hash !== hash);
|
|
|
|
|
|
|
|
|
|
const reject = (state: State, hash: string): State => state.map((tx) => {
|
|
|
|
|
if (tx.hash === hash && !tx.rejected) {
|
|
|
|
@ -60,19 +41,16 @@ const reject = (state: State, hash: string): State => state.map((tx) => {
|
|
|
|
|
|
|
|
|
|
export default function pending(state: State = initialState, action: Action): State {
|
|
|
|
|
switch (action.type) {
|
|
|
|
|
// case SEND.TX_COMPLETE:
|
|
|
|
|
// return add(state, action);
|
|
|
|
|
|
|
|
|
|
// case CONNECT.FORGET:
|
|
|
|
|
// case CONNECT.FORGET_SINGLE:
|
|
|
|
|
// case CONNECT.FORGET_SILENT:
|
|
|
|
|
// case CONNECT.RECEIVE_WALLET_TYPE:
|
|
|
|
|
// return clear(state, action.device);
|
|
|
|
|
case CONNECT.FORGET:
|
|
|
|
|
case CONNECT.FORGET_SINGLE:
|
|
|
|
|
case CONNECT.FORGET_SILENT:
|
|
|
|
|
case CONNECT.RECEIVE_WALLET_TYPE:
|
|
|
|
|
return removeByDeviceState(state, action.device.state);
|
|
|
|
|
|
|
|
|
|
case PENDING.ADD:
|
|
|
|
|
return addFromNotification(state, action.payload);
|
|
|
|
|
return add(state, action.payload);
|
|
|
|
|
case PENDING.TX_RESOLVED:
|
|
|
|
|
return remove(state, action.hash);
|
|
|
|
|
return removeByHash(state, action.hash);
|
|
|
|
|
case PENDING.TX_REJECTED:
|
|
|
|
|
return reject(state, action.hash);
|
|
|
|
|
|
|
|
|
|