mirror of
https://github.com/status-im/embark-area-51.git
synced 2025-01-22 21:29:14 +00:00
Adding base command logic for scaffolding generation
This commit is contained in:
parent
0948b04366
commit
fde198dece
24
lib/cmd.js
24
lib/cmd.js
@ -19,6 +19,7 @@ class Cmd {
|
||||
this.test();
|
||||
this.reset();
|
||||
this.graph();
|
||||
this.scaffold();
|
||||
this.upload();
|
||||
this.versionCmd();
|
||||
this.otherCommands();
|
||||
@ -194,6 +195,29 @@ class Cmd {
|
||||
});
|
||||
}
|
||||
|
||||
scaffold() {
|
||||
program
|
||||
.command('scaffold [contract] [environment]')
|
||||
.option('--framework', 'UI framework to use. (default: react)')
|
||||
.action(function(contract, env, options){
|
||||
let environment = env || 'development';
|
||||
|
||||
if(contract === undefined){
|
||||
console.log("contract name is required");
|
||||
process.exit(0);
|
||||
}
|
||||
|
||||
embark.initConfig(environment, {
|
||||
embarkConfig: 'embark.json', interceptLogs: false
|
||||
});
|
||||
|
||||
options.contract = contract;
|
||||
options.framework = options.framework || 'react';
|
||||
options.env = environment;
|
||||
embark.scaffold(options);
|
||||
});
|
||||
}
|
||||
|
||||
reset() {
|
||||
program
|
||||
.command('reset')
|
||||
|
@ -104,6 +104,10 @@ Plugin.prototype.registerPipeline = function(matcthingFiles, cb) {
|
||||
this.pluginTypes.push('pipeline');
|
||||
};
|
||||
|
||||
Plugin.prototype.registerCustomType = function(type){
|
||||
this.pluginTypes.push(type);
|
||||
}
|
||||
|
||||
Plugin.prototype.addFileToPipeline = function(file, intendedPath, options) {
|
||||
this.pipelineFiles.push({file: file, intendedPath: intendedPath, options: options});
|
||||
this.pluginTypes.push('pipelineFiles');
|
||||
|
36
lib/index.js
36
lib/index.js
@ -252,6 +252,42 @@ class Embark {
|
||||
resetCmd();
|
||||
}
|
||||
|
||||
scaffold(options) {
|
||||
// initialise embark engine
|
||||
let engine = new Engine({
|
||||
env: options.env,
|
||||
version: this.version,
|
||||
embarkConfig: options.embarkConfig || 'embark.json',
|
||||
logfile: options.logfile
|
||||
});
|
||||
engine.init();
|
||||
|
||||
// load plugins
|
||||
this.plugins.loadInternalPlugin('scaffolding', options);
|
||||
let scaffoldPlugin = this.plugins.plugins.filter(x => x.name == "scaffolding")[0].pluginModule;
|
||||
let self = this;
|
||||
|
||||
async.waterfall([
|
||||
function generateUI(callback){
|
||||
engine.events.on('outputDone', function () {
|
||||
let scaffold = new scaffoldPlugin(engine, options);
|
||||
let result = scaffold.generate(options.contract);
|
||||
engine.logger.info(result);
|
||||
callback();
|
||||
});
|
||||
self.build(options, engine, true);
|
||||
}
|
||||
], function (err, _result) {
|
||||
if (err) {
|
||||
engine.logger.error(err.message);
|
||||
engine.logger.debug(err.stack);
|
||||
} else {
|
||||
engine.logger.info("Finished generating ui");
|
||||
}
|
||||
process.exit();
|
||||
});
|
||||
}
|
||||
|
||||
upload(platform, options) {
|
||||
|
||||
options.buildDir = 'dist/';
|
||||
|
14
lib/modules/scaffolding-react/index.js
Normal file
14
lib/modules/scaffolding-react/index.js
Normal file
@ -0,0 +1,14 @@
|
||||
|
||||
class ScaffoldingReact {
|
||||
constructor(embark, options){
|
||||
this.embark = embark;
|
||||
this.options = options;
|
||||
}
|
||||
|
||||
build(contract){
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
module.exports = ScaffoldingReact;
|
61
lib/modules/scaffolding/index.js
Normal file
61
lib/modules/scaffolding/index.js
Normal file
@ -0,0 +1,61 @@
|
||||
const fs = require('fs');
|
||||
|
||||
const commandName = "generate-ui";
|
||||
|
||||
const formatReplyMsg = (message) => commandName + ": " + message;
|
||||
|
||||
class Scaffolding {
|
||||
constructor(embark, options){
|
||||
this.embark = embark;
|
||||
this.options = options;
|
||||
this.framework = options.framework;
|
||||
this.frameworkPlugin = null;
|
||||
}
|
||||
|
||||
createDirectories(contractName){
|
||||
const dir = './app/' + contractName;
|
||||
if (!fs.existsSync(dir)){
|
||||
fs.mkdirSync(dir);
|
||||
} else {
|
||||
throw formatReplyMsg("directory ./app/" + contractName + " already exists");
|
||||
}
|
||||
}
|
||||
|
||||
isContract(contractName){
|
||||
return this.embark.config.contractsConfig.contracts[contractName] !== undefined;
|
||||
}
|
||||
|
||||
generate(contractName){
|
||||
let frameworkPlugin;
|
||||
|
||||
if(this.framework == 'react'){
|
||||
this.embark.plugins.loadInternalPlugin('scaffolding-react', this.options);
|
||||
frameworkPlugin = this.embark.plugins.plugins.filter(x => x.name == "scaffolding-react")[0].pluginModule;
|
||||
} else {
|
||||
let plugins = this.embark.plugins.getPluginsFor(this.framework);
|
||||
if(plugins.length !== 1){
|
||||
return formatReplyMsg("Could not find plugin for framework '" + this.framework + "'");
|
||||
}
|
||||
frameworkPlugin = plugins[0].pluginModule;
|
||||
}
|
||||
|
||||
try {
|
||||
if(!this.isContract(contractName)){
|
||||
return formatReplyMsg("contract '" + contractName + "' does not exist");
|
||||
}
|
||||
|
||||
const contract = this.embark.config.contractsConfig.contracts[contractName];
|
||||
|
||||
this.createDirectories(contractName);
|
||||
let uiFramework = new frameworkPlugin(this.embark, this.options);
|
||||
uiFramework.build(contract);
|
||||
} catch(err){
|
||||
return err;
|
||||
}
|
||||
|
||||
return formatReplyMsg("done!");
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
module.exports = Scaffolding;
|
Loading…
x
Reference in New Issue
Block a user