2018-05-10 16:31:10 +00:00
|
|
|
import EmbarkJS from 'Embark/EmbarkJS';
|
|
|
|
import {{contractName}} from 'Embark/contracts/{{contractName}}';
|
|
|
|
|
2018-05-10 16:16:13 +00:00
|
|
|
import React from 'react';
|
|
|
|
import ReactDOM from 'react-dom';
|
2018-05-11 14:13:42 +00:00
|
|
|
import { FormGroup, ControlLabel, FormControl, Checkbox, Button, Alert } from 'react-bootstrap';
|
2018-05-10 21:02:47 +00:00
|
|
|
|
|
|
|
|
|
|
|
{{#each functions}}
|
|
|
|
class {{capitalize name}}_{{@index}}_Form extends React.Component {
|
|
|
|
constructor(props){
|
|
|
|
super(props);
|
|
|
|
this.state = {
|
|
|
|
{{#if inputs.length}}
|
|
|
|
input: {
|
|
|
|
{{#each inputs}}
|
2018-05-11 13:26:27 +00:00
|
|
|
{{name}}: {{#ifeq type 'bool'}}false{{else}}''{{/ifeq}}{{#unless @last}},{{/unless}}
|
2018-05-10 21:02:47 +00:00
|
|
|
{{/each}}
|
|
|
|
},
|
|
|
|
{{/if}}
|
|
|
|
{{#ifview stateMutability}}
|
|
|
|
output: null,
|
|
|
|
{{/ifview}}
|
2018-05-11 16:34:16 +00:00
|
|
|
error: null,
|
|
|
|
mined: null
|
2018-05-10 21:02:47 +00:00
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
handleChange(e, name){
|
2018-05-11 13:26:27 +00:00
|
|
|
this.state.input[name] = e.target.value;
|
|
|
|
this.setState(this.state);
|
|
|
|
}
|
|
|
|
|
|
|
|
handleCheckbox(e, name){
|
|
|
|
this.state.input[name] = e.target.checked;
|
2018-05-10 21:02:47 +00:00
|
|
|
this.setState(this.state);
|
|
|
|
}
|
|
|
|
|
|
|
|
async handleClick(e){
|
|
|
|
e.preventDefault();
|
2018-05-11 16:34:16 +00:00
|
|
|
this.setState({output: null, error: null, receipt: null});
|
2018-05-10 21:02:47 +00:00
|
|
|
|
2018-05-11 14:13:42 +00:00
|
|
|
try {
|
2018-05-11 16:34:16 +00:00
|
|
|
{{#ifview stateMutability}}
|
2018-05-11 14:13:42 +00:00
|
|
|
{{../contractName}}.methods{{methodname ../functions name inputs}}({{#each inputs}}this.state.input.{{name}}{{#unless @last}}, {{/unless}}{{/each}})
|
|
|
|
.call()
|
|
|
|
.then((result) => {
|
|
|
|
{{#iflengthgt outputs 1}}
|
|
|
|
this.setState({output: {
|
|
|
|
{{#each outputs}}
|
|
|
|
{{emptyname name @index}}: result[{{@index}}]{{#unless @last}},{{/unless}}
|
|
|
|
{{/each}}
|
|
|
|
}});
|
|
|
|
{{else}}
|
|
|
|
this.setState({output: result});
|
|
|
|
{{/iflengthgt}}
|
|
|
|
})
|
|
|
|
.catch((err) => {
|
|
|
|
this.setState({error: err.message});
|
|
|
|
});
|
2018-05-11 16:34:16 +00:00
|
|
|
{{else}}
|
|
|
|
{{../contractName}}.methods{{methodname ../functions name inputs}}({{#each inputs}}this.state.input.{{name}}{{#unless @last}}, {{/unless}}{{/each}})
|
|
|
|
.send({
|
|
|
|
from: web3.eth.defaultAccount
|
|
|
|
})
|
|
|
|
.then((_receipt) => {
|
|
|
|
console.log(_receipt);
|
|
|
|
this.setState({receipt: _receipt})
|
|
|
|
})
|
|
|
|
.catch((err) => {
|
|
|
|
console.log(err);
|
|
|
|
this.setState({error: err.message});
|
|
|
|
});
|
|
|
|
// TODO payable
|
|
|
|
{{/ifview}}
|
2018-05-11 14:13:42 +00:00
|
|
|
} catch(err) {
|
|
|
|
this.setState({error: err.message});
|
|
|
|
}
|
2018-05-11 16:34:16 +00:00
|
|
|
|
2018-05-10 21:02:47 +00:00
|
|
|
// TODO validate
|
|
|
|
}
|
|
|
|
|
|
|
|
render(){
|
|
|
|
return <div className="formSection">
|
|
|
|
<h3>{{name}}</h3>
|
|
|
|
<form>
|
|
|
|
{{#if inputs.length}}
|
|
|
|
{{#each inputs}}
|
2018-05-11 16:34:16 +00:00
|
|
|
<FormGroup>
|
|
|
|
<ControlLabel>{{name}}</ControlLabel>
|
|
|
|
{{#ifeq type 'bool'}}
|
|
|
|
<Checkbox
|
|
|
|
onClick={(e) => this.handleCheckbox(e, '{{name}}')}
|
|
|
|
/>
|
|
|
|
{{else}}
|
|
|
|
<FormControl
|
|
|
|
type="text"
|
|
|
|
defaultValue={ this.state.input.{{name}} }
|
|
|
|
placeholder="{{type}}"
|
|
|
|
onChange={(e) => this.handleChange(e, '{{name}}')}
|
|
|
|
/>
|
|
|
|
{{/ifeq}}
|
|
|
|
</FormGroup>
|
2018-05-10 21:02:47 +00:00
|
|
|
{{/each}}
|
|
|
|
{{/if}}
|
2018-05-11 16:34:16 +00:00
|
|
|
{
|
|
|
|
this.state.error != null ?
|
|
|
|
<Alert bsStyle="danger">{this.state.error}</Alert>
|
|
|
|
: ''
|
|
|
|
}
|
2018-05-10 21:02:47 +00:00
|
|
|
{{#ifview stateMutability}}
|
|
|
|
<Button type="submit" bsStyle="primary" onClick={(e) => this.handleClick(e)}>Call</Button>
|
|
|
|
{
|
|
|
|
this.state.output != null ?
|
|
|
|
<React.Fragment>
|
|
|
|
<h4>Results</h4>
|
2018-05-11 13:26:27 +00:00
|
|
|
{{#iflengthgt outputs 1}}
|
2018-05-10 21:02:47 +00:00
|
|
|
<ul>
|
|
|
|
{{#each outputs}}
|
|
|
|
<li>{{emptyname name @index}}: { this.state.output.{{emptyname name @index}} }</li>
|
|
|
|
{{/each}}
|
|
|
|
</ul>
|
|
|
|
{{else}}
|
2018-05-11 13:26:27 +00:00
|
|
|
{this.state.output.toString()}
|
|
|
|
{{/iflengthgt}}
|
2018-05-10 21:02:47 +00:00
|
|
|
</React.Fragment>
|
|
|
|
: ''
|
|
|
|
}
|
2018-05-11 16:34:16 +00:00
|
|
|
{{else}}
|
|
|
|
<Button type="submit" bsStyle="primary" onClick={(e) => this.handleClick(e)}>Send</Button>
|
|
|
|
{
|
|
|
|
this.state.receipt != null ?
|
|
|
|
<Alert bsStyle={this.state.receipt.status == "0x1" ? 'success' : 'danger'}>{this.state.receipt.status == "0x1" ? 'Success' : 'Failure / Revert'} - Transaction Hash: {this.state.receipt.transactionHash}</Alert>
|
|
|
|
: ''
|
|
|
|
}
|
2018-05-10 21:02:47 +00:00
|
|
|
{{/ifview}}
|
|
|
|
</form>
|
|
|
|
</div>;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
{{/each}}
|
|
|
|
|
2018-05-10 16:16:13 +00:00
|
|
|
|
2018-05-10 16:31:10 +00:00
|
|
|
class {{contractName}}UI extends React.Component {
|
|
|
|
constructor (props) {
|
|
|
|
super(props);
|
|
|
|
this.state = {
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
render(){
|
2018-05-10 21:02:47 +00:00
|
|
|
return (<div>
|
|
|
|
{{#each functions}}
|
|
|
|
<{{capitalize name}}_{{@index}}_Form />
|
|
|
|
{{/each}}
|
|
|
|
</div>);
|
2018-05-10 16:31:10 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2018-05-10 16:16:13 +00:00
|
|
|
ReactDOM.render(<div>
|
2018-05-10 16:31:10 +00:00
|
|
|
<h1>{{title}}</h1>
|
|
|
|
<{{contractName}}UI />
|
2018-05-10 16:16:13 +00:00
|
|
|
</div>,
|
|
|
|
document.getElementById('app')
|
|
|
|
);
|