diff --git a/cmd/cmd_controller.js b/cmd/cmd_controller.js index 4ab2ce088..9a1e7367b 100644 --- a/cmd/cmd_controller.js +++ b/cmd/cmd_controller.js @@ -463,7 +463,6 @@ class EmbarkController { engine.startService("pipeline"); engine.startService("deployment", {onlyCompile: true}); engine.startService("web3"); - engine.startService("codeGenerator"); engine.events.request('deploy:contracts', callback); } @@ -474,7 +473,6 @@ class EmbarkController { } else { let scaffold = new Scaffolding(engine, options); scaffold.generate(options.contract, options.overwrite); - process.exit(); } }); } diff --git a/lib/cmds/scaffolding.js b/lib/cmds/scaffolding.js index d92e34a15..a2ca765f9 100644 --- a/lib/cmds/scaffolding.js +++ b/lib/cmds/scaffolding.js @@ -39,8 +39,10 @@ class Scaffolding { const contract = contractsList.find(x => x.className === contractName); try { - build(contract, overwrite); - this.engine.logger.info(__("finished generating the UI").underline); + build(contract, overwrite, () => { + this.engine.logger.info(__("finished generating the UI").underline); + process.exit(); + }); } catch(err){ this.engine.logger.error(err.message); } diff --git a/lib/modules/scaffolding-react/index.js b/lib/modules/scaffolding-react/index.js index c11d744ef..73db137d4 100644 --- a/lib/modules/scaffolding-react/index.js +++ b/lib/modules/scaffolding-react/index.js @@ -1,6 +1,8 @@ const Handlebars = require('handlebars'); const fs = require('../../core/fs'); +let utils = require('../../utils/utils.js'); + Handlebars.registerHelper('capitalize', function(word) { return word.charAt(0).toUpperCase() + word.slice(1); @@ -64,34 +66,42 @@ class ScaffoldingReact { fs.writeFileSync(filePath, result); } - build(contract, overwrite){ - const filename = contract.className.toLowerCase(); + build(contract, overwrite, cb){ + const packageInstallCmd = 'npm install react react-bootstrap react-dom'; + utils.runCmd(packageInstallCmd, null, (err) => { + if (err) { + this.embark.logger.error(err.message); + process.exit(1); + } - this._generateFile(contract, 'index.html.tpl', 'html', - { - 'title': contract.className, - filename - }, overwrite); + const filename = contract.className.toLowerCase(); - this._generateFile(contract, 'dapp.js.tpl', 'js', - { - 'title': contract.className, - 'contractName': contract.className, - 'functions': contract.abiDefinition.filter(x => x.type === 'function') - }, overwrite); - - - // Update config - const contents = fs.readFileSync("./embark.json"); - let embarkJson = JSON.parse(contents); - embarkJson.app["js/" + filename + ".js"] = "app/" + filename + '.js'; - embarkJson.app[filename + ".html"] = "app/" + filename + '.html'; - - fs.writeFileSync("./embark.json", JSON.stringify(embarkJson, null, 4)); - - this.embark.logger.info(filename + ".html generated"); - this.embark.logger.info(filename + ".js generated"); + this._generateFile(contract, 'index.html.tpl', 'html', + { + 'title': contract.className, + filename + }, overwrite); + + this._generateFile(contract, 'dapp.js.tpl', 'js', + { + 'title': contract.className, + 'contractName': contract.className, + 'functions': contract.abiDefinition.filter(x => x.type === 'function') + }, overwrite); + + // Update config + const contents = fs.readFileSync("./embark.json"); + let embarkJson = JSON.parse(contents); + embarkJson.app["js/" + filename + ".js"] = "app/" + filename + '.js'; + embarkJson.app[filename + ".html"] = "app/" + filename + '.html'; + + fs.writeFileSync("./embark.json", JSON.stringify(embarkJson, null, 4)); + + this.embark.logger.info(filename + ".html generated"); + this.embark.logger.info(filename + ".js generated"); + cb(); + }); } } diff --git a/lib/modules/scaffolding-react/templates/dapp.js.tpl b/lib/modules/scaffolding-react/templates/dapp.js.tpl index ff9fcd2d2..2ff2c2858 100644 --- a/lib/modules/scaffolding-react/templates/dapp.js.tpl +++ b/lib/modules/scaffolding-react/templates/dapp.js.tpl @@ -160,21 +160,13 @@ class {{capitalize name}}Form{{@index}} extends Component { {{/each}} -class {{contractName}}UI extends Component { - constructor (props) { - super(props); - this.state = { - }; - } - - render(){ - return (
+function {{contractName}}UI(props) { + return (

{{title}}

{{#each functions}} <{{capitalize name}}Form{{@index}} /> {{/each}}
); - } }