|
@ -51,6 +51,7 @@ type State = { |
|
|
accountsChunk: Array<any>, |
|
|
accountsChunk: Array<any>, |
|
|
allTransactions: Array<Object>, |
|
|
allTransactions: Array<Object>, |
|
|
fakeDatas: Array<any>, |
|
|
fakeDatas: Array<any>, |
|
|
|
|
|
fakeDatasMerge: Array<any>, |
|
|
selectedTime: string, |
|
|
selectedTime: string, |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
@ -73,6 +74,20 @@ const generateFakeData = v => ({ |
|
|
const generateFakeDatas = accounts => |
|
|
const generateFakeDatas = accounts => |
|
|
accounts.map(() => [...Array(25).keys()].map(v => generateFakeData(v + 1))) |
|
|
accounts.map(() => [...Array(25).keys()].map(v => generateFakeData(v + 1))) |
|
|
|
|
|
|
|
|
|
|
|
const mergeFakeDatas = fakeDatas => |
|
|
|
|
|
takeRight( |
|
|
|
|
|
fakeDatas.reduce((res, data) => { |
|
|
|
|
|
data.forEach((d, i) => { |
|
|
|
|
|
res[i] = { |
|
|
|
|
|
name: d.name, |
|
|
|
|
|
value: (res[i] ? res[i].value : 0) + d.value, |
|
|
|
|
|
} |
|
|
|
|
|
}) |
|
|
|
|
|
return res |
|
|
|
|
|
}, []), |
|
|
|
|
|
25, |
|
|
|
|
|
) |
|
|
|
|
|
|
|
|
const getAllTransactions = accounts => { |
|
|
const getAllTransactions = accounts => { |
|
|
const allTransactions = accounts.reduce((result, account) => { |
|
|
const allTransactions = accounts.reduce((result, account) => { |
|
|
const transactions = get(account, 'data.transactions', []) |
|
|
const transactions = get(account, 'data.transactions', []) |
|
@ -107,11 +122,18 @@ const getAccountsChunk = accounts => { |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
class DashboardPage extends PureComponent<Props, State> { |
|
|
class DashboardPage extends PureComponent<Props, State> { |
|
|
state = { |
|
|
constructor(props) { |
|
|
accountsChunk: getAccountsChunk(this.props.accounts), |
|
|
super() |
|
|
allTransactions: getAllTransactions(this.props.accounts), |
|
|
|
|
|
fakeDatas: generateFakeDatas(this.props.accounts), |
|
|
const fakeDatas = generateFakeDatas(props.accounts) |
|
|
selectedTime: 'day', |
|
|
|
|
|
|
|
|
this.state = { |
|
|
|
|
|
accountsChunk: getAccountsChunk(props.accounts), |
|
|
|
|
|
allTransactions: getAllTransactions(props.accounts), |
|
|
|
|
|
fakeDatas: generateFakeDatas(props.accounts), |
|
|
|
|
|
fakeDatasMerge: mergeFakeDatas(fakeDatas), |
|
|
|
|
|
selectedTime: 'day', |
|
|
|
|
|
} |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
componentDidMount() { |
|
|
componentDidMount() { |
|
@ -120,8 +142,11 @@ class DashboardPage extends PureComponent<Props, State> { |
|
|
|
|
|
|
|
|
componentWillReceiveProps(nextProps) { |
|
|
componentWillReceiveProps(nextProps) { |
|
|
if (this.state.fakeDatas.length === 0) { |
|
|
if (this.state.fakeDatas.length === 0) { |
|
|
|
|
|
const fakeDatas = generateFakeDatas(nextProps.accounts) |
|
|
|
|
|
|
|
|
this.setState({ |
|
|
this.setState({ |
|
|
fakeDatas: generateFakeDatas(nextProps.accounts), |
|
|
fakeDatas, |
|
|
|
|
|
fakeDatasMerge: mergeFakeDatas(fakeDatas), |
|
|
}) |
|
|
}) |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
@ -139,19 +164,22 @@ class DashboardPage extends PureComponent<Props, State> { |
|
|
|
|
|
|
|
|
addFakeDatasOnAccounts = () => { |
|
|
addFakeDatasOnAccounts = () => { |
|
|
const { accounts } = this.props |
|
|
const { accounts } = this.props |
|
|
|
|
|
const { fakeDatas } = this.state |
|
|
window.requestAnimationFrame(() => { |
|
|
|
|
|
this.setState(prev => ({ |
|
|
const newFakeDatas = accounts.reduce((res, acc, i) => { |
|
|
fakeDatas: [ |
|
|
if (res[i]) { |
|
|
...accounts.reduce((res, acc, i) => { |
|
|
const nextIndex = res[i].length |
|
|
if (res[i]) { |
|
|
res[i][nextIndex] = generateFakeData(nextIndex) |
|
|
const nextIndex = res[i].length |
|
|
res[i] = takeRight(res[i], 25) |
|
|
res[i][nextIndex] = generateFakeData(nextIndex) |
|
|
} |
|
|
} |
|
|
return res |
|
|
return res |
|
|
}, fakeDatas) |
|
|
}, prev.fakeDatas), |
|
|
|
|
|
], |
|
|
window.requestIdleCallback(() => { |
|
|
})) |
|
|
this.setState({ |
|
|
|
|
|
fakeDatas: newFakeDatas, |
|
|
|
|
|
fakeDatasMerge: mergeFakeDatas(newFakeDatas), |
|
|
|
|
|
}) |
|
|
|
|
|
|
|
|
this._timeout = setTimeout(() => { |
|
|
this._timeout = setTimeout(() => { |
|
|
this.addFakeDatasOnAccounts() |
|
|
this.addFakeDatasOnAccounts() |
|
@ -163,8 +191,9 @@ class DashboardPage extends PureComponent<Props, State> { |
|
|
|
|
|
|
|
|
render() { |
|
|
render() { |
|
|
const { push, accounts } = this.props |
|
|
const { push, accounts } = this.props |
|
|
const { accountsChunk, allTransactions, selectedTime, fakeDatas } = this.state |
|
|
const { accountsChunk, allTransactions, selectedTime, fakeDatas, fakeDatasMerge } = this.state |
|
|
|
|
|
|
|
|
|
|
|
let accountIndex = 0 |
|
|
const totalAccounts = accounts.length |
|
|
const totalAccounts = accounts.length |
|
|
|
|
|
|
|
|
return ( |
|
|
return ( |
|
@ -205,18 +234,7 @@ class DashboardPage extends PureComponent<Props, State> { |
|
|
}} |
|
|
}} |
|
|
color="#5286f7" |
|
|
color="#5286f7" |
|
|
height={250} |
|
|
height={250} |
|
|
data={takeRight( |
|
|
data={fakeDatasMerge} |
|
|
fakeDatas.reduce((res, data) => { |
|
|
|
|
|
data.forEach((d, i) => { |
|
|
|
|
|
res[i] = { |
|
|
|
|
|
name: d.name, |
|
|
|
|
|
value: (res[i] ? res[i].value : 0) + d.value, |
|
|
|
|
|
} |
|
|
|
|
|
}) |
|
|
|
|
|
return res |
|
|
|
|
|
}, []), |
|
|
|
|
|
25, |
|
|
|
|
|
)} |
|
|
|
|
|
/> |
|
|
/> |
|
|
</Box> |
|
|
</Box> |
|
|
</Card> |
|
|
</Card> |
|
@ -251,7 +269,7 @@ class DashboardPage extends PureComponent<Props, State> { |
|
|
<AccountCard |
|
|
<AccountCard |
|
|
key={account.id} |
|
|
key={account.id} |
|
|
account={account} |
|
|
account={account} |
|
|
data={takeRight(fakeDatas[j], 25)} |
|
|
data={fakeDatas[accountIndex++]} |
|
|
onClick={() => push(`/account/${account.id}`)} |
|
|
onClick={() => push(`/account/${account.id}`)} |
|
|
/> |
|
|
/> |
|
|
), |
|
|
), |
|
@ -261,7 +279,11 @@ class DashboardPage extends PureComponent<Props, State> { |
|
|
</Box> |
|
|
</Box> |
|
|
</Box> |
|
|
</Box> |
|
|
<Card p={0} px={4} title="Recent activity"> |
|
|
<Card p={0} px={4} title="Recent activity"> |
|
|
<TransactionsList withAccounts transactions={allTransactions} /> |
|
|
<TransactionsList |
|
|
|
|
|
withAccounts |
|
|
|
|
|
transactions={allTransactions} |
|
|
|
|
|
onAccountClick={account => push(`/account/${account.id}`)} |
|
|
|
|
|
/> |
|
|
</Card> |
|
|
</Card> |
|
|
</Fragment> |
|
|
</Fragment> |
|
|
)} |
|
|
)} |
|
|