2018-05-09 21:02:17 +00:00
|
|
|
|
2018-05-10 15:25:31 +00:00
|
|
|
const Handlebars = require('handlebars');
|
|
|
|
const fs = require('../../core/fs');
|
2018-05-10 16:16:13 +00:00
|
|
|
|
2018-05-10 21:02:47 +00:00
|
|
|
Handlebars.registerHelper('capitalize', function(word) {
|
|
|
|
return word.charAt(0).toUpperCase() + word.slice(1);
|
|
|
|
});
|
|
|
|
|
|
|
|
Handlebars.registerHelper('ifview', function(stateMutability, options) {
|
|
|
|
let result = stateMutability == 'view' || stateMutability == 'pure' || stateMutability == 'constant';
|
|
|
|
if (result) {
|
|
|
|
return options.fn(this);
|
|
|
|
} else {
|
|
|
|
return options.inverse(this);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2018-05-11 13:26:27 +00:00
|
|
|
Handlebars.registerHelper('ifeq', function(elem, value, options){
|
|
|
|
if (elem == value) {
|
|
|
|
return options.fn(this);
|
|
|
|
} else {
|
|
|
|
return options.inverse(this);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
Handlebars.registerHelper('iflengthgt', function(arr, val, options) {
|
2018-05-10 21:02:47 +00:00
|
|
|
if (arr.length > val) {
|
|
|
|
return options.fn(this);
|
|
|
|
} else {
|
|
|
|
return options.inverse(this);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
Handlebars.registerHelper('emptyname', function(name, index) {
|
2018-05-11 13:26:27 +00:00
|
|
|
return name ? name : 'output' + index;
|
2018-05-10 21:02:47 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
|
|
|
|
Handlebars.registerHelper('methodname', function(abiDefinition, functionName, inputs){
|
|
|
|
let funCount = abiDefinition.filter(x => x.name == functionName).length;
|
|
|
|
if(funCount == 1){
|
|
|
|
return '.' + functionName;
|
|
|
|
} else {
|
|
|
|
return new Handlebars.SafeString(`['${functionName}(${inputs !== null ? inputs.map(input => input.type).join(',') : '' })']`);
|
|
|
|
}
|
|
|
|
});
|
2018-05-10 16:16:13 +00:00
|
|
|
|
2018-05-09 21:02:17 +00:00
|
|
|
class ScaffoldingReact {
|
|
|
|
constructor(embark, options){
|
|
|
|
this.embark = embark;
|
|
|
|
this.options = options;
|
2018-05-11 19:49:06 +00:00
|
|
|
|
|
|
|
this.embark.registerDappGenerator('react', this.build.bind(this));
|
2018-05-09 21:02:17 +00:00
|
|
|
}
|
|
|
|
|
2018-05-10 16:16:13 +00:00
|
|
|
_generateFile(contract, templateFilename, extension, data){
|
|
|
|
const filename = contract.className.toLowerCase() + '.' + extension;
|
2018-05-10 15:25:31 +00:00
|
|
|
const filePath = './app/' + filename;
|
|
|
|
if (fs.existsSync(filePath)){
|
2018-05-11 20:14:53 +00:00
|
|
|
throw new Error("file '" + filePath + "' already exists");
|
2018-05-10 15:25:31 +00:00
|
|
|
}
|
|
|
|
|
2018-05-10 16:16:13 +00:00
|
|
|
const templatePath = fs.embarkPath('lib/modules/scaffolding-react/templates/' + templateFilename);
|
2018-05-10 15:25:31 +00:00
|
|
|
const source = fs.readFileSync(templatePath).toString();
|
|
|
|
const template = Handlebars.compile(source);
|
2018-05-09 21:02:17 +00:00
|
|
|
|
2018-05-10 15:25:31 +00:00
|
|
|
// Write template
|
|
|
|
const result = template(data);
|
|
|
|
fs.writeFileSync(filePath, result);
|
2018-05-10 16:16:13 +00:00
|
|
|
}
|
|
|
|
|
2018-05-10 16:31:10 +00:00
|
|
|
_buildHTML(contract){
|
2018-05-10 16:16:13 +00:00
|
|
|
const filename = contract.className.toLowerCase();
|
|
|
|
this._generateFile(contract, 'index.html.tpl', 'html',
|
2018-05-10 16:31:10 +00:00
|
|
|
{
|
|
|
|
'title': contract.className,
|
|
|
|
'filename': filename
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
build(contract){
|
|
|
|
this._buildHTML(contract);
|
|
|
|
|
|
|
|
const filename = contract.className.toLowerCase();
|
2018-05-10 16:16:13 +00:00
|
|
|
|
2018-05-10 16:31:10 +00:00
|
|
|
this._generateFile(contract, 'dapp.js.tpl', 'js',
|
|
|
|
{
|
2018-05-11 13:26:27 +00:00
|
|
|
'title': contract.className,
|
2018-05-10 21:02:47 +00:00
|
|
|
'contractName': contract.className,
|
|
|
|
'functions': contract.abiDefinition.filter(x => x.type == 'function')
|
2018-05-10 16:31:10 +00:00
|
|
|
});
|
2018-05-10 16:16:13 +00:00
|
|
|
|
|
|
|
// 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';
|
2018-05-10 15:25:31 +00:00
|
|
|
|
2018-05-10 21:02:47 +00:00
|
|
|
fs.writeFileSync("./embark.json", JSON.stringify(embarkJson, null, 4));
|
2018-05-11 19:49:06 +00:00
|
|
|
|
|
|
|
return filename + ".html generated";
|
2018-05-09 21:02:17 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
module.exports = ScaffoldingReact;
|