From a0438167508548c66e803f2eb0d279c87b2144d6 Mon Sep 17 00:00:00 2001 From: Richard Ramos Date: Fri, 11 May 2018 12:34:16 -0400 Subject: [PATCH] Base logic for invoking send functions and showin results --- .../scaffolding-react/templates/dapp.js.tpl | 75 ++++++++++++------- 1 file changed, 47 insertions(+), 28 deletions(-) diff --git a/lib/modules/scaffolding-react/templates/dapp.js.tpl b/lib/modules/scaffolding-react/templates/dapp.js.tpl index 6482b9ea..5a2554a9 100644 --- a/lib/modules/scaffolding-react/templates/dapp.js.tpl +++ b/lib/modules/scaffolding-react/templates/dapp.js.tpl @@ -21,7 +21,8 @@ class {{capitalize name}}_{{@index}}_Form extends React.Component { {{#ifview stateMutability}} output: null, {{/ifview}} - error: null + error: null, + mined: null }; } @@ -37,10 +38,10 @@ class {{capitalize name}}_{{@index}}_Form extends React.Component { async handleClick(e){ e.preventDefault(); - this.setState({output: null, error: null}); + this.setState({output: null, error: null, receipt: null}); - {{#ifview stateMutability}} try { + {{#ifview stateMutability}} {{../contractName}}.methods{{methodname ../functions name inputs}}({{#each inputs}}this.state.input.{{name}}{{#unless @last}}, {{/unless}}{{/each}}) .call() .then((result) => { @@ -57,44 +58,56 @@ class {{capitalize name}}_{{@index}}_Form extends React.Component { .catch((err) => { this.setState({error: err.message}); }); + {{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}} } catch(err) { this.setState({error: err.message}); } - - // TODO show on screen - {{/ifview}} - + // TODO validate } render(){ return

{{name}}

+
+ {{#if inputs.length}} + {{#each inputs}} + + {{name}} + {{#ifeq type 'bool'}} + this.handleCheckbox(e, '{{name}}')} + /> + {{else}} + this.handleChange(e, '{{name}}')} + /> + {{/ifeq}} + + {{/each}} + {{/if}} { this.state.error != null ? {this.state.error} : '' } - - {{#if inputs.length}} - {{#each inputs}} - - {{name}} - {{#ifeq type 'bool'}} - this.handleCheckbox(e, '{{name}}')} - /> - {{else}} - this.handleChange(e, '{{name}}')} - /> - {{/ifeq}} - - {{/each}} - {{/if}} {{#ifview stateMutability}} { @@ -113,7 +126,13 @@ class {{capitalize name}}_{{@index}}_Form extends React.Component { : '' } - + {{else}} + + { + this.state.receipt != null ? + {this.state.receipt.status == "0x1" ? 'Success' : 'Failure / Revert'} - Transaction Hash: {this.state.receipt.transactionHash} + : '' + } {{/ifview}}
;