liquid-funding/app/components/TransferDialog.jsx

123 lines
4.1 KiB
React
Raw Normal View History

2018-12-03 15:22:51 -05:00
import React from 'react'
2018-12-03 15:54:24 -05:00
import { Formik } from 'formik'
import LiquidPledging from 'Embark/contracts/LiquidPledging'
2018-12-03 15:22:51 -05:00
import Button from '@material-ui/core/Button'
import TextField from '@material-ui/core/TextField'
import Dialog from '@material-ui/core/Dialog'
import DialogActions from '@material-ui/core/DialogActions'
import DialogContent from '@material-ui/core/DialogContent'
import DialogContentText from '@material-ui/core/DialogContentText'
import DialogTitle from '@material-ui/core/DialogTitle'
2018-12-03 15:54:24 -05:00
import { getTokenLabel } from '../utils/currencies'
2018-12-04 14:39:45 -05:00
import { toWei } from '../utils/conversions'
import { FundingContext } from '../context'
2018-12-04 14:39:45 -05:00
const { transfer } = LiquidPledging.methods
2018-12-03 15:22:51 -05:00
const TransferDialog = ({ row, handleClose, transferPledgeAmounts }) => (
2018-12-03 15:54:24 -05:00
<Formik
initialValues={{}}
2018-12-12 15:46:02 -05:00
onSubmit={async (values, { setSubmitting, resetForm, setStatus }) => {
const { id } = row
const { idSender, amount, idReceiver } = values
const args = [idSender, id, toWei(amount.toString()), idReceiver]
const toSend = transfer(...args);
const estimatedGas = await toSend.estimateGas();
toSend.send({gas: estimatedGas + 1000})
.then(res => {
console.log({res})
const { events: { Transfer: { returnValues } } } = res
transferPledgeAmounts(returnValues)
})
.catch(e => {
console.log({e})
})
.finally(() => {
handleClose()
resetForm()
})
}}
2018-12-03 15:54:24 -05:00
>
{({
values,
errors,
touched,
handleChange,
handleBlur,
handleSubmit,
2018-12-04 14:39:45 -05:00
submitForm,
2018-12-03 15:54:24 -05:00
setFieldValue,
setStatus,
status
}) => (
<form onSubmit={handleSubmit} autoComplete="off">
2018-12-03 15:54:24 -05:00
<Dialog
open={!!row}
onClose={handleClose}
aria-labelledby="form-dialog-title"
>
<DialogTitle id="form-dialog-title">Transfer Funds</DialogTitle>
<DialogContent>
<DialogContentText>
2018-12-04 14:39:45 -05:00
{`Transfer ${values.amount || ''} ${values.amount ? getTokenLabel(row[6]) : ''} from Pledge ${row.id} ${values.idReceiver ? 'to Giver/Delegate/Project' : ''} ${values.idReceiver || ''}`}
2018-12-03 15:54:24 -05:00
</DialogContentText>
<TextField
autoFocus
margin="normal"
id="amount"
name="amount"
label="Amount to transfer"
placeholder="Amount to transfer"
variant="outlined"
autoComplete="off"
fullWidth
onChange={handleChange}
onBlur={handleBlur}
value={values.amount || ''}
/>
<TextField
margin="normal"
id="idSender"
name="idSender"
label="Profile Id to send from"
placeholder="Profile Id to send from"
variant="outlined"
type="number"
autoComplete="off"
fullWidth
onChange={handleChange}
onBlur={handleBlur}
value={values.idSender || ''}
/>
2018-12-03 15:54:24 -05:00
<TextField
margin="normal"
id="idReceiver"
name="idReceiver"
label="Receiver of funds"
placeholder="Receiver of funds"
variant="outlined"
helperText="Destination of the amount, can be a Giver/Project sending to a Giver, a Delegate or a Project; a Delegate sending to another Delegate, or a Delegate pre-commiting it to a Project"
autoComplete="off"
fullWidth
onChange={handleChange}
onBlur={handleBlur}
value={values.idReceiver || ''}
/>
</DialogContent>
<DialogActions>
<Button onClick={handleClose} color="primary">
Cancel
</Button>
2018-12-04 14:39:45 -05:00
<Button onClick={submitForm} color="primary" type="submit">
Transfer
2018-12-03 15:54:24 -05:00
</Button>
</DialogActions>
</Dialog>
</form>
)}
</Formik>
)
2018-12-03 15:22:51 -05:00
export default TransferDialog