2018-05-22 16:40:56 -04:00
import ENSSubdomainRegistry from 'Embark/contracts/ENSSubdomainRegistry' ;
2018-06-25 14:47:47 -04:00
import web3 from 'web3' ;
2018-05-25 18:50:16 -04:00
import ENSRegistry from 'Embark/contracts/ENSRegistry' ;
2018-06-25 14:47:47 -04:00
import React from 'react' ;
2018-05-27 16:28:07 -04:00
import { Button } from 'react-bootstrap' ;
2018-06-25 14:47:47 -04:00
import FieldGroup from '../standard/FieldGroup' ;
2018-05-22 16:40:56 -04:00
import { withFormik } from 'formik' ;
2018-06-25 14:47:47 -04:00
import { hash } from 'eth-ens-namehash' ;
import { debounce } from 'lodash/fp' ;
2018-05-25 18:50:16 -04:00
const { methods : { owner } } = ENSRegistry ;
2018-05-24 14:30:01 -04:00
2018-06-25 14:47:47 -04:00
const delay = debounce ( 500 ) ;
2018-05-24 14:30:01 -04:00
const getDomain = ( hashedDomain , domains ) => domains ( hashedDomain ) . call ( ) ;
2018-05-25 18:50:16 -04:00
const registryIsOwner = address => address == ENSSubdomainRegistry . _address ;
2018-05-25 19:06:25 -04:00
const fetchOwner = domainName => owner ( hash ( domainName ) ) . call ( ) ;
const debounceFetchOwner = delay ( fetchOwner ) ;
2018-05-25 18:50:16 -04:00
const getAndIsOwner = async domainName => {
2018-05-25 19:06:25 -04:00
const address = await debounceFetchOwner ( domainName ) ;
2018-05-25 18:50:16 -04:00
return registryIsOwner ( address ) ;
}
2018-05-24 14:30:01 -04:00
const fetchDomain = delay ( getDomain ) ;
2018-05-25 18:50:16 -04:00
const setPrice = ( domainFn , hashedDomain , price ) => domainFn ( hashedDomain , price || 0 ) . send ( ) ;
2018-05-22 16:40:56 -04:00
const InnerForm = ( {
values ,
errors ,
touched ,
handleChange ,
handleBlur ,
handleSubmit ,
isSubmitting ,
} ) => (
< form onSubmit = { handleSubmit } >
< FieldGroup
id = "domainName"
name = "domainName"
type = "text"
label = "Domain Name"
onChange = { handleChange }
onBlur = { handleBlur }
value = { values . domainName }
error = { errors . domainName }
/ >
< FieldGroup
id = "domainPrice"
name = "domainPrice"
type = "number"
label = "Domain Price"
placeholder = "(Optional) Domain will be free if left blank"
onChange = { handleChange }
onBlur = { handleBlur }
value = { values . domainPrice }
/ >
2018-05-25 18:50:16 -04:00
< Button bsStyle = "primary" type = "submit" disabled = { isSubmitting || ! ! Object . keys ( errors ) . length } > { ! isSubmitting ? 'Submit' : 'Submitting to the Blockchain - (this may take awhile)' } < / B u t t o n >
2018-05-22 16:40:56 -04:00
< / f o r m >
)
const AddDomain = withFormik ( {
mapPropsToValues : props => ( { domainName : '' , domainPrice : '' } ) ,
2018-06-25 14:47:47 -04:00
async validate ( values ) {
const { domainName } = values ;
2018-05-22 16:40:56 -04:00
const errors = { } ;
2018-05-24 14:30:01 -04:00
if ( ! domainName ) errors . domainName = 'Required' ;
2018-06-25 14:47:47 -04:00
if ( domainName && ! await getAndIsOwner ( domainName ) ) errors . domainName = 'This domain is not owned by registry' ;
2018-05-25 18:50:16 -04:00
if ( Object . keys ( errors ) . length ) throw errors ;
2018-05-22 16:40:56 -04:00
} ,
2018-05-25 11:39:11 -04:00
async handleSubmit ( values , { setSubmitting } ) {
2018-06-25 14:47:47 -04:00
const { domainName , domainPrice } = values ;
const { methods : { domains , setDomainPrice , updateDomainPrice } } = ENSSubdomainRegistry ;
const hashedDomain = hash ( domainName ) ;
2018-05-25 11:39:11 -04:00
const { state } = await getDomain ( hashedDomain , domains ) ;
2018-08-09 11:56:19 -04:00
console . log (
'Inputs for setPrice' ,
Number ( state ) ? 'updateDomainPrice' : 'setDomainPrice' ,
hashedDomain ,
web3 . utils . toWei ( domainPrice . toString ( ) , 'ether' ) ,
) ;
2018-05-25 11:39:11 -04:00
setPrice (
2018-06-25 14:47:47 -04:00
Number ( state ) ? updateDomainPrice : setDomainPrice ,
2018-05-25 11:39:11 -04:00
hashedDomain ,
2018-06-25 14:47:47 -04:00
web3 . utils . toWei ( domainPrice . toString ( ) , 'ether' ) ,
2018-05-25 11:39:11 -04:00
)
. then ( res => {
setSubmitting ( false ) ;
console . log ( res ) ;
} )
. catch ( err => {
setSubmitting ( false ) ;
console . log ( err ) ;
} )
2018-05-22 16:40:56 -04:00
}
2018-06-25 14:47:47 -04:00
} ) ( InnerForm ) ;
2018-05-22 16:40:56 -04:00
export default AddDomain ;