import React from 'react' import { Formik } from 'formik' import LiquidPledging from 'Embark/contracts/LiquidPledging' import withObservables from '@nozbe/with-observables' import { Q } from '@nozbe/watermelondb' import { withDatabase } from '@nozbe/watermelondb/DatabaseProvider' import { withStyles } from '@material-ui/core/styles' import { useProjectData, useProfileData } from './hooks' import {TextField, Button, MenuItem, Divider, Typography, Link} from '@material-ui/core' import { toEther, toWei } from '../../utils/conversions' import { getTokenLabel } from '../../utils/currencies' const { transfer } = LiquidPledging.methods const styles = theme => ({ root: { display: 'grid', gridTemplateColumns: 'repeat(12, [col] 1fr)', gridTemplateRows: 'repeat(5, [row] auto)', gridColumnGap: '1em', gridRowGap: '36px', fontFamily: theme.typography.fontFamily, [theme.breakpoints.up('sm')]: { margin: '1.75rem 4.5rem' } }, title: { display: 'grid', fontSize: '2.5rem', gridColumnStart: '1', gridColumnEnd: '13', gridRowStart: '1', gridRowEnd: '6', textAlign: 'center' }, submissionRoot: { gridColumnStart: '1', gridColumnEnd: '13' }, textField: { width: '100%' } }) const Title = ({ className, manifest }) => (
{manifest && manifest.title}
{manifest && `By ${manifest.creator}`}
) const SubmissionSection = ({ classes, profiles, delegatePledges, projectId, openSnackBar }) => { return ( { const { amount, delegateProfile, delegatePledge } = values const args = [delegateProfile.idProfile, delegatePledge, toWei(amount), projectId] console.log({values, args}) const toSend = transfer(...args) const estimatedGas = await toSend.estimateGas() toSend .send({gas: estimatedGas + 1000}) .then(async res => { console.log({res}) const { events: { Transfer } } = res if (Array.isArray(Transfer)) { Transfer.forEach(async t => { const { to, amount } = t.returnValues //await pledge.transferTo(to, amount) }) } else { const { to, amount } = Transfer.returnValues //await pledge.transferTo(to, amount) } }) .catch(e => { openSnackBar('error', e) console.log({e}) }) .finally(() => { openSnackBar('success', 'project backed!') resetForm() }) }} > {({ values, errors, touched, handleChange, handleBlur, handleSubmit, setFieldValue, setStatus, status }) => { const filteredPledges = values.delegateProfile ? delegatePledges.filter( d => d.profile.id === values.delegateProfile.id && d.pledgeData.amount !== '0' && d.pledgeData.pledgeState === 0 && d.pledgeData.intendedProject === 0 ) : null console.log({filteredPledges}) return (
{profiles && profiles.length === 0 && Please create a Delegate profile before backing - Delegate creation page } {profiles && profiles.map(profile => ( {profile.name} ))} {filteredPledges && {filteredPledges.map(pledge => ( {`Pledge no: ${pledge.idPledge} - Amount: ${toEther(pledge.pledgeData.amount)} ${getTokenLabel(pledge.pledgeData.token)}`} ))} } {values.delegatePledge && } {values.amount && } ) } }
)} function BackProject({classes, match, profile, delegates, projectAddedEvents, delegateAddedEvents}) { const projectId = match.params.id const { manifest, delegateProfiles, openSnackBar } = useProjectData(projectId, profile, projectAddedEvents) const delegatePledges = useProfileData(delegateProfiles) return (
<SubmissionSection classes={classes} profiles={delegateProfiles} delegatePledges={delegatePledges} projectId={projectId} openSnackBar={openSnackBar} /> </div> ) } const StyledProject = withStyles(styles)(BackProject) export default withDatabase(withObservables([], ({ database, match }) => ({ profile: database.collections.get('profiles').query( Q.where('id_profile', match.params.id) ).observe(), projectAddedEvents: database.collections.get('lp_events').query( Q.where('event', 'ProjectAdded') ).observe(), delegateAddedEvents: database.collections.get('lp_events').query( Q.where('event', 'DelegateAdded') ).observe() }))(StyledProject))