2018-12-03 15:22:51 -05:00
import React from 'react'
2018-12-03 15:54:24 -05:00
import { Formik } from 'formik'
2018-12-21 14:31:46 -05:00
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'
2018-12-04 17:10:43 -05:00
import { FundingContext } from '../context'
2018-12-04 14:39:45 -05:00
2018-12-21 14:31:46 -05:00
const { transfer } = LiquidPledging . methods
2018-12-03 15:22:51 -05:00
2018-12-04 17:10:43 -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
} ) => (
2018-12-13 13:39:35 -05:00
< 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 || '' }
/ >
2018-12-09 07:10:17 -05:00
< 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