liquid-funding/app/components/PledgesTable.jsx

126 lines
4.0 KiB
React
Raw Normal View History

2019-02-14 14:02:00 -05:00
import React, { Component } from 'react'
2018-12-03 10:29:14 -05:00
import MaterialTable from 'material-table'
import withObservables from '@nozbe/with-observables'
import { withDatabase } from '@nozbe/watermelondb/DatabaseProvider'
2018-12-03 10:29:14 -05:00
import { toEther } from '../utils/conversions'
import { getTokenLabel } from '../utils/currencies'
import TransferCard from './table/TransferCard'
2018-12-06 12:09:43 -05:00
import WithdrawCard from './table/WithdrawCard'
2018-12-03 10:29:14 -05:00
const convertToHours = seconds => seconds / 60 / 60
const projectText = project => project === '0' ? 'N/A' : project
2018-12-07 06:52:02 -05:00
const pledgeStateMap = {
0: 'Pledged',
1: 'Paying',
2: 'Paid'
}
const convertToDatetime = async field => {
const { commitTime } = field
const profile = await field.profile.fetch()
2018-12-12 15:46:02 -05:00
if (!profile || Number(commitTime) === 0) return 0
2018-12-10 10:22:52 -05:00
const time = Number(commitTime) + Number(profile.commitTime)
const date = new Date(time * 1000)
return `${date.toLocaleDateString()} ${date.toLocaleTimeString()}`
}
const formatField = async field => ({
...field.getFields(),
commitTime: await convertToDatetime(field),
2018-12-03 10:29:14 -05:00
amount: toEther(field.amount),
token: getTokenLabel(field.token),
2018-12-07 06:52:02 -05:00
intendedProject: projectText(field.intendedProject),
pledgeState: pledgeStateMap[field.pledgeState],
transferTo: field.transferTo,
pledge: field
2018-12-03 10:29:14 -05:00
})
class PledgesTable extends Component {
2018-12-03 15:22:51 -05:00
state = {
data: [],
2018-12-03 15:22:51 -05:00
row: false,
}
2018-12-03 10:29:14 -05:00
componentDidMount() {
this.setData()
}
componentDidUpdate() {
const { pledges } = this.props
const { data } = this.state
2019-01-25 12:18:44 -05:00
if (data.length) {
pledges.some((pledge, idx) => {
const current = data[idx]
if (current) {
if (toEther(pledge.amount) != current.amount || pledgeStateMap[pledge.pledgeState] != current.pledgeState) this.setData()
}
})
}
if (pledges.length && !data.length) this.setData()
}
setData = async () => {
const { pledges } = this.props
const data = await Promise.all(pledges.map(formatField))
this.setState({ data })
}
2018-12-03 15:22:51 -05:00
handleClickOpen = row => {
this.setState({ row })
2018-12-03 15:22:51 -05:00
}
handleClose = () => {
2019-02-08 22:23:54 -05:00
this.setState({ rowData: null })
2018-12-03 15:22:51 -05:00
}
render() {
2019-02-08 22:23:54 -05:00
const { data, rowData } = this.state
2018-12-03 15:22:51 -05:00
return (
2019-02-08 22:23:54 -05:00
<div>
2018-12-03 15:22:51 -05:00
<MaterialTable
columns={[
{ title: 'Pledge Id', field: 'pledgeId', type: 'numeric' },
2018-12-03 15:22:51 -05:00
{ title: 'Owner', field: 'owner' },
{ title: 'Amount Funded', field: 'amount', type: 'numeric' },
{ title: 'Token', field: 'token' },
{ title: 'Commit Time', field: 'commitTime', type: 'numeric' },
{ title: 'Number of Delegates', field: 'nDelegates', type: 'numeric' },
{ title: 'Intended Project', field: 'intendedProject' },
2018-12-07 06:52:02 -05:00
{ title: 'Pledge State', field: 'pledgeState' },
2018-12-03 15:22:51 -05:00
]}
data={data}
2018-12-03 15:22:51 -05:00
title="Pledges"
2019-01-10 14:37:23 -05:00
options={{ showEmptyDataSourceMessage: true }}
2018-12-03 15:22:51 -05:00
actions={[
{
icon: 'compare_arrows',
tooltip: 'Transfer funds',
onClick: (event, rowData) => {
2019-02-08 22:23:54 -05:00
const { timeStamp } = event
this.setState({
rowData: { ...rowData, timeStamp, type: 'transfer' }
})
2018-12-03 15:22:51 -05:00
}
2018-12-06 12:09:43 -05:00
},
{
icon: 'attach_money',
tooltip: 'Request Withdrawl',
onClick: (event, rowData) => {
const { timeStamp } = event
2018-12-06 12:09:43 -05:00
console.log({rowData})
this.setState({
2019-02-08 22:23:54 -05:00
rowData: { ...rowData, timeStamp, type: 'withdraw' }
})
2018-12-06 12:09:43 -05:00
}
2018-12-03 15:22:51 -05:00
}
]}
/>
2019-02-08 22:23:54 -05:00
{!rowData && <div/>}
{rowData && rowData.type === 'withdraw' && <WithdrawCard rowData={rowData} handleClose={this.handleClose} />}
{rowData && rowData.type === 'transfer' && <TransferCard row={rowData} handleClose={this.handleClose} />}
</div>
2018-12-03 15:22:51 -05:00
)
}
}
export default withDatabase(withObservables([], ({ database }) => ({
pledges: database.collections.get('pledges').query().observeWithColumns(['amount', 'pledge_state']),
}))(PledgesTable))