A simple and small tool for quickly creating application components from templates by script.
npm install ebo --saveDev
or npm install ebo --global
./.ebo/questions.js
"use strict";
const questions = [
{
"type": "list",
"name": "scenario",
"message": "Scenario:",
"choices": ["Component", "Markup"]
},
{
"type": "list",
"name": "hierarchy",
"message": "Atomic hierarchy:",
"choices": ["Organism", "Group"],
"when": (e) => {
return e["scenario"] === "Component"
}
},
{
"type": "list",
"name": "type",
"message": "Markup type: ",
"choices": ["Page", "Popup"],
"when": (e) => {
return e["scenario"] === "Markup"
}
},
{
"type": "input",
"name": "name",
"message": "Name with spaces:"
}
];
module.exports = questions;
More information: https://www.npmjs.com/package/inquirer
./.ebo/scripts.json
[
{
"condition": "answers.scenario.given === 'Component'",
"action": "new",
"src": "./.ebo/component.js.twig",
"dest": "./example/component/{{answers.hierarchy.lower}}/{{answers.name.camel}}.js"
},
{
"condition": "answers.scenario.given === 'Markup'",
"action": "new",
"src": "./.ebo/markup.html.twig",
"dest": "./example/markup/{{answers.type.lower}}/{{answers.name.camel}}.html"
},
{
"condition": "answers.scenario.given === 'Component'",
"action": "inject",
"expression": "//@ebo inject {{answers.hierarchy.lower}}",
"place": "before",
"src": "const {{answers.hierarchy.lower}}{{answers.name.firstCamel}} = require('./component/{{answers.hierarchy.lower}}/{{answers.name.camel}}');\n",
"dest": "./example/main.js"
}
]
./.ebo/component.js.twig
"use strict";
console.log("{{answers.hierarchy.lower}}", "{{answers.name.camel}}");
More information: https://www.npmjs.com/package/twig
ebo