import React, { useContext, useState, useEffect } from 'react'; import { Formik } from 'formik'; import EmbarkJS from 'Embark/EmbarkJS'; import LPVault from 'Embark/contracts/LPVault'; import LiquidPledging from 'Embark/contracts/LiquidPledging'; import Button from '@material-ui/core/Button'; import TextField from '@material-ui/core/TextField'; import Snackbar from '@material-ui/core/Snackbar'; import MenuItem from '@material-ui/core/MenuItem'; import FormControlLabel from '@material-ui/core/FormControlLabel' import Switch from '@material-ui/core/Switch' import web3 from 'Embark/web3' import { MySnackbarContentWrapper } from './base/SnackBars' import { currencies, TOKEN_ICON_API, getTokenLabel } from '../utils/currencies' import { toEther } from '../utils/conversions' import { getLpAllowance, standardTokenApproval } from '../utils/initialize' import { FundingContext } from '../context' const { donate } = LiquidPledging.methods const hoursToSeconds = hours => hours * 60 * 60 const addFunderSucessMsg = response => { const { events: { GiverAdded: { returnValues: { idGiver } } } } = response return `Funder created with ID of ${idGiver}` } const CreateFunding = ({ refreshTable }) => { const context = useContext(FundingContext) const { account } = context const [balances, setBalances] = useState({}) const [allowances, setAllowances] = useState({}) const updateBalancesAllowances = () => { const latestBalances = {} const latestAllowances = {} currencies.forEach(async c => { if (c.contract) { const amount = await c.contract.methods.balanceOf(account).call() const allowance = await getLpAllowance(c.contract) latestBalances[c.value] = toEther(amount) latestAllowances[c.value] = toEther(allowance) } else { latestBalances[c.value] = '0' latestAllowances[c.value] = '0' } }) setBalances(latestBalances) setAllowances(latestAllowances) } const toggleAllowance = e => { const token = currencies[e.target.value] const allowance = allowances[token.value] standardTokenApproval( token.contract, Number(allowance) ? '0' : undefined ).then(res => { const { events: { Approval: { returnValues: { value } } } } = res setAllowances(state => ({ ...state, [token.value]: toEther(value) })) }) } useEffect(() => { if (account) updateBalancesAllowances() }, [account]) return ( { const { funderId, receiverId, tokenAddress, amount } = values const args = [funderId, receiverId, tokenAddress, web3.utils.toWei(amount, 'ether')]; const toSend = donate(...args); const estimateGas = await toSend.estimateGas() toSend.send({ from: account, gas: estimateGas + 2000 }) .then(res => { console.log({res}) setStatus({ snackbar: { variant: 'success', message: 'funding provided!' } }) refreshTable() }) .catch(e => { console.log({e}) setStatus({ snackbar: { variant: 'error', message: 'There was an error' } }) }) }} > {({ values, errors, touched, handleChange, handleBlur, handleSubmit, setFieldValue, setStatus, status }) => (
{currencies.map((option, idx) => (
{option.icon || } {option.label} Your Balance: {balances[option.value]} e.stopPropagation()} control={ } label="Enabled" />
))}
{status && setStatus(null)} > setStatus(null)} variant={status.snackbar.variant} message={status.snackbar.message} /> } )}
)} export default CreateFunding