add ipfs upload to create profile
This commit is contained in:
parent
30736c7a9b
commit
b2a2d83d7c
|
@ -1,12 +1,15 @@
|
||||||
import React from 'react'
|
import React, { createRef } from 'react'
|
||||||
import { Formik } from 'formik'
|
import { Formik } from 'formik'
|
||||||
import LiquidPledging from 'Embark/contracts/LiquidPledging'
|
import LiquidPledging from 'Embark/contracts/LiquidPledging'
|
||||||
import Button from '@material-ui/core/Button'
|
import Button from '@material-ui/core/Button'
|
||||||
import MenuItem from '@material-ui/core/MenuItem'
|
import MenuItem from '@material-ui/core/MenuItem'
|
||||||
import TextField from '@material-ui/core/TextField'
|
import TextField from '@material-ui/core/TextField'
|
||||||
import Snackbar from '@material-ui/core/Snackbar'
|
import Snackbar from '@material-ui/core/Snackbar'
|
||||||
|
import InputAdornment from '@material-ui/core/InputAdornment'
|
||||||
|
import CloudUpload from '@material-ui/icons/CloudUpload'
|
||||||
import web3 from 'Embark/web3'
|
import web3 from 'Embark/web3'
|
||||||
import { MySnackbarContentWrapper } from './base/SnackBars'
|
import { MySnackbarContentWrapper } from './base/SnackBars'
|
||||||
|
import { captureFile } from '../utils/ipfs'
|
||||||
|
|
||||||
const { addGiver, addDelegate, addProject } = LiquidPledging.methods
|
const { addGiver, addDelegate, addProject } = LiquidPledging.methods
|
||||||
const FUNDER = 'FUNDER'
|
const FUNDER = 'FUNDER'
|
||||||
|
@ -52,6 +55,7 @@ const successMsg = {
|
||||||
[PROJECT]: addProjectSucessMsg
|
[PROJECT]: addProjectSucessMsg
|
||||||
}
|
}
|
||||||
|
|
||||||
|
let uploadInput = createRef()
|
||||||
const AddFunder = ({ appendFundProfile }) => (
|
const AddFunder = ({ appendFundProfile }) => (
|
||||||
<Formik
|
<Formik
|
||||||
initialValues={{ adminType: FUNDER, funderName: '', funderDescription: '', commitTime : '' }}
|
initialValues={{ adminType: FUNDER, funderName: '', funderDescription: '', commitTime : '' }}
|
||||||
|
@ -89,15 +93,15 @@ const AddFunder = ({ appendFundProfile }) => (
|
||||||
}}
|
}}
|
||||||
>
|
>
|
||||||
{({
|
{({
|
||||||
values,
|
values,
|
||||||
errors,
|
errors,
|
||||||
touched,
|
touched,
|
||||||
handleChange,
|
handleChange,
|
||||||
handleBlur,
|
handleBlur,
|
||||||
handleSubmit,
|
handleSubmit,
|
||||||
setFieldValue,
|
setFieldValue,
|
||||||
setStatus,
|
setStatus,
|
||||||
status
|
status
|
||||||
}) => (
|
}) => (
|
||||||
<form onSubmit={handleSubmit} style={{ display: 'flex', flexDirection: 'column' }}>
|
<form onSubmit={handleSubmit} style={{ display: 'flex', flexDirection: 'column' }}>
|
||||||
<TextField
|
<TextField
|
||||||
|
@ -129,10 +133,22 @@ const AddFunder = ({ appendFundProfile }) => (
|
||||||
onBlur={handleBlur}
|
onBlur={handleBlur}
|
||||||
value={values.funderName || ''}
|
value={values.funderName || ''}
|
||||||
/>
|
/>
|
||||||
|
<input
|
||||||
|
ref={(input) => { uploadInput = input }}
|
||||||
|
type="file"
|
||||||
|
onChange={(e) => captureFile(e, hash => setFieldValue('funderDescription', hash))}
|
||||||
|
style={{ display: 'none' }} />
|
||||||
<TextField
|
<TextField
|
||||||
id="funderDescription"
|
id="funderDescription"
|
||||||
name="funderDescription"
|
name="funderDescription"
|
||||||
label="Description (URL or IPFS Hash)"
|
InputProps={{
|
||||||
|
startAdornment: (
|
||||||
|
<InputAdornment position="start">
|
||||||
|
<CloudUpload style={{ cursor: 'pointer' }} onClick={() => uploadInput.click()} />
|
||||||
|
</InputAdornment>
|
||||||
|
),
|
||||||
|
}}
|
||||||
|
label={<span>Description (URL or IPFS Hash)</span>}
|
||||||
placeholder="Description (URL or IPFS Hash)"
|
placeholder="Description (URL or IPFS Hash)"
|
||||||
margin="normal"
|
margin="normal"
|
||||||
variant="outlined"
|
variant="outlined"
|
||||||
|
|
|
@ -0,0 +1,26 @@
|
||||||
|
import IPFS from 'ipfs'
|
||||||
|
import fileReaderPullStream from 'pull-file-reader'
|
||||||
|
|
||||||
|
const ipfs = new IPFS()
|
||||||
|
|
||||||
|
export const captureFile = (event, cb) => {
|
||||||
|
event.stopPropagation()
|
||||||
|
event.preventDefault()
|
||||||
|
const file = event.target.files[0]
|
||||||
|
saveToIpfs(file, cb)
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
const saveToIpfs = (file, cb) => {
|
||||||
|
let ipfsId
|
||||||
|
const fileStream = fileReaderPullStream(file)
|
||||||
|
ipfs.add(fileStream, { progress: (prog) => console.log(`received: ${prog}`) })
|
||||||
|
.then((response) => {
|
||||||
|
console.log(response)
|
||||||
|
ipfsId = response[0].hash
|
||||||
|
console.log(ipfsId)
|
||||||
|
cb(`ipfs/${ipfsId}`)
|
||||||
|
}).catch((err) => {
|
||||||
|
console.error(err)
|
||||||
|
})
|
||||||
|
}
|
|
@ -107,9 +107,12 @@ module.exports = {
|
||||||
rinkeby: {
|
rinkeby: {
|
||||||
networkType: "rinkeby",
|
networkType: "rinkeby",
|
||||||
syncMode: "light",
|
syncMode: "light",
|
||||||
account: {
|
accounts: [
|
||||||
password: "config/testnet/password"
|
{
|
||||||
}
|
nodeAccounts: true,
|
||||||
|
password: "config/testnet/password"
|
||||||
|
}
|
||||||
|
]
|
||||||
},
|
},
|
||||||
|
|
||||||
// merges with the settings in default
|
// merges with the settings in default
|
||||||
|
|
|
@ -69,8 +69,10 @@
|
||||||
"eslint": "^5.9.0",
|
"eslint": "^5.9.0",
|
||||||
"eth-contract-class": "^0.0.12",
|
"eth-contract-class": "^0.0.12",
|
||||||
"formik": "^1.3.2",
|
"formik": "^1.3.2",
|
||||||
|
"ipfs": "^0.34.4",
|
||||||
"lokijs": "^1.5.6",
|
"lokijs": "^1.5.6",
|
||||||
"material-table": "^1.12.0",
|
"material-table": "^1.12.0",
|
||||||
|
"pull-file-reader": "^1.0.2",
|
||||||
"ramda": "^0.26.1",
|
"ramda": "^0.26.1",
|
||||||
"react": "^16.7.0",
|
"react": "^16.7.0",
|
||||||
"react-chartjs-2": "^2.7.4",
|
"react-chartjs-2": "^2.7.4",
|
||||||
|
|
Loading…
Reference in New Issue