fetching transactions wip

This commit is contained in:
mmv 2019-06-18 18:37:02 +04:00
parent eb3708a623
commit 1a5beb16a4
7 changed files with 43 additions and 15 deletions

View File

@ -38,6 +38,6 @@ export const setOwners = async (safeAddress: string, owners: List<Owner>) => {
export const getOwners = async (safeAddress: string): Map<string, string> => { export const getOwners = async (safeAddress: string): Map<string, string> => {
const data: Object = await loadFromStorage(`${OWNERS_KEY}-${safeAddress}`) const data: Object = await loadFromStorage(`${OWNERS_KEY}-${safeAddress}`)
console.log(data)
return data ? Map(data) : Map() return data ? Map(data) : Map()
} }

View File

@ -25,6 +25,7 @@ type Props = SelectorProps & {
classes: Object, classes: Object,
granted: boolean, granted: boolean,
createTransaction: Function, createTransaction: Function,
fetchTransactions: Function,
} }
type State = { type State = {
@ -90,7 +91,15 @@ class Layout extends React.Component<Props, State> {
render() { render() {
const { const {
safe, provider, network, classes, granted, tokens, activeTokens, createTransaction, safe,
provider,
network,
classes,
granted,
tokens,
activeTokens,
createTransaction,
fetchTransactions,
} = this.props } = this.props
const { tabIndex } = this.state const { tabIndex } = this.state
@ -142,7 +151,7 @@ class Layout extends React.Component<Props, State> {
createTransaction={createTransaction} createTransaction={createTransaction}
/> />
)} )}
{tabIndex === 1 && <Transactions />} {tabIndex === 1 && <Transactions fetchTransactions={fetchTransactions} safeAddress={address} />}
</React.Fragment> </React.Fragment>
) )
} }

View File

@ -3,13 +3,18 @@ import * as React from 'react'
import { List } from 'immutable' import { List } from 'immutable'
import NoTransactions from '~/routes/safe/components/Transactions/NoTransactions' import NoTransactions from '~/routes/safe/components/Transactions/NoTransactions'
type Props = SelectorProps & type Props = {
Actions & {
safeName: string,
safeAddress: string, safeAddress: string,
threshold: number, threshold: number,
} }
class Transactions extends React.Component<Props, {}> { class Transactions extends React.Component<Props, {}> {
componentDidMount() {
const { safeAddress, fetchTransactions } = this.props
fetchTransactions(safeAddress)
}
render() { render() {
const { transactions = List(), safeName, threshold } = this.props const { transactions = List(), safeName, threshold } = this.props
const hasTransactions = false const hasTransactions = false

View File

@ -2,15 +2,18 @@
import fetchSafe from '~/routes/safe/store/actions/fetchSafe' import fetchSafe from '~/routes/safe/store/actions/fetchSafe'
import fetchTokenBalances from '~/routes/safe/store/actions/fetchTokenBalances' import fetchTokenBalances from '~/routes/safe/store/actions/fetchTokenBalances'
import createTransaction from '~/routes/safe/store/actions/createTransaction' import createTransaction from '~/routes/safe/store/actions/createTransaction'
import fetchTransactions from '~/routes/safe/store/actions/fetchTransactions'
export type Actions = { export type Actions = {
fetchSafe: typeof fetchSafe, fetchSafe: typeof fetchSafe,
fetchTokenBalances: typeof fetchTokenBalances, fetchTokenBalances: typeof fetchTokenBalances,
createTransaction: typeof createTransaction, createTransaction: typeof createTransaction,
fetchTransactions: typeof fetchTransactions,
} }
export default { export default {
fetchSafe, fetchSafe,
fetchTokenBalances, fetchTokenBalances,
createTransaction, createTransaction,
fetchTransactions,
} }

View File

@ -52,7 +52,15 @@ class SafeView extends React.Component<Props> {
render() { render() {
const { const {
safe, provider, activeTokens, granted, userAddress, network, tokens, createTransaction, safe,
provider,
activeTokens,
granted,
userAddress,
network,
tokens,
createTransaction,
fetchTransactions,
} = this.props } = this.props
return ( return (
@ -66,6 +74,7 @@ class SafeView extends React.Component<Props> {
network={network} network={network}
granted={granted} granted={granted}
createTransaction={createTransaction} createTransaction={createTransaction}
fetchTransactions={fetchTransactions}
/> />
</Page> </Page>
) )

View File

@ -10,7 +10,7 @@ import { loadSafeSubjects } from '~/utils/storage/transactions'
import { buildTxServiceUrl, type TxServiceType } from '~/logic/safe/transactions/txHistory' import { buildTxServiceUrl, type TxServiceType } from '~/logic/safe/transactions/txHistory'
import { getOwners } from '~/logic/safe/utils' import { getOwners } from '~/logic/safe/utils'
import { EMPTY_DATA } from '~/logic/wallets/ethTransactions' import { EMPTY_DATA } from '~/logic/wallets/ethTransactions'
import addTransactions from './addTransactions' import { addTransactions } from './addTransactions'
type ConfirmationServiceModel = { type ConfirmationServiceModel = {
owner: string, owner: string,
@ -31,9 +31,9 @@ type TxServiceModel = {
isExecuted: boolean, isExecuted: boolean,
} }
const buildTransactionFrom = (safeAddress: string, tx: TxServiceModel, safeSubjects: Map<string, string>) => { const buildTransactionFrom = async (safeAddress: string, tx: TxServiceModel, safeSubjects: Map<string, string>) => {
const name = safeSubjects.get(String(tx.nonce)) || 'Unknown' const name = safeSubjects.get(String(tx.nonce)) || 'Unknown'
const storedOwners = getOwners(safeAddress) const storedOwners = await getOwners(safeAddress)
const confirmations = List( const confirmations = List(
tx.confirmations.map((conf: ConfirmationServiceModel) => { tx.confirmations.map((conf: ConfirmationServiceModel) => {
const ownerName = storedOwners.get(conf.owner.toLowerCase()) || 'UNKNOWN' const ownerName = storedOwners.get(conf.owner.toLowerCase()) || 'UNKNOWN'
@ -62,7 +62,9 @@ export const loadSafeTransactions = async (safeAddress: string) => {
const response = await axios.get(url) const response = await axios.get(url)
const transactions: TxServiceModel[] = response.data.results const transactions: TxServiceModel[] = response.data.results
const safeSubjects = loadSafeSubjects(safeAddress) const safeSubjects = loadSafeSubjects(safeAddress)
const txsRecord = transactions.map((tx: TxServiceModel) => buildTransactionFrom(safeAddress, tx, safeSubjects)) const txsRecord = transactions.map(
async (tx: TxServiceModel) => await buildTransactionFrom(safeAddress, tx, safeSubjects),
)
return Map().set(safeAddress, List(txsRecord)) return Map().set(safeAddress, List(txsRecord))
} }

View File

@ -1,7 +1,7 @@
// @flow // @flow
import { List, Map } from 'immutable' import { List, Map } from 'immutable'
import { handleActions, type ActionType } from 'redux-actions' import { handleActions, type ActionType } from 'redux-actions'
import { ADD_TRANSACTIONS } from '~/routes/safe/store/actions/createTransaction' import { ADD_TRANSACTIONS } from '~/routes/safe/store/actions/addTransactions'
import { type Transaction } from '~/routes/safe/store/models/transaction' import { type Transaction } from '~/routes/safe/store/models/transaction'
export const TRANSACTIONS_REDUCER_ID = 'transactions' export const TRANSACTIONS_REDUCER_ID = 'transactions'