A simple tool to create boilerplate generator.
npx enerate path/to/new-project --template examples/vue-project
The template consists of two parts: the config.js
configuration file (optional) and the template
folder which contains files which will become the base for new projects.
Template files can contain special tags, which will be replaced during project creation by values entered by the user.
For example it may contain file index.html
:
<!DOCTYPE html>
<html>
<head>
<title><%= PROJECT_NAME %></title>
</head>
<body>
<script src="<%= ENTRY_PATH %>"></script>
</body>
</html>
It uses mustache.js under the hood. I recommend reading the it's documentation for more info.
Template variables may come from two sources:
- prompts (user input)
- context
See Configuration file section for more details.
Configuration file, among other things, allows you to define what questions will be asked during project creation.
Example configuration file:
// config.js
export default {
prompts: [
{
type: 'text',
name: 'PROJECT_NAME',
message: 'Project name',
initial: 'My project',
},
{
type: 'select',
name: 'LANGUAGE',
message: 'Page language',
choices: [
{ title: 'English', value: 'en' },
{ title: 'Polish', value: 'pl' },
],
initial: 0
}
]
}
Configuration file can export object or function (async functions are supported).
Example configuration file that exports function:
// config.js
export default (context) => ({
prompts: [
{
type: 'text',
name: 'PROJECT_NAME',
message: 'Project name',
initial: context.output.split('/').slice(-1)[0],
},
]
})
Configuration context
object type:
type ConfigContext = {
template: string; // template directory path
output: string; // output directory path
}
Default: []
Provided questions will be asked while generating project. All answers will be accessible as variables in the template based on name
attribute.
If output
directory already exists user will be asked if it should be overwritten.
See prompts
for details.
Default: {}
All properties of provided object will be accessible as variables in the template.
Example:
// config.js
export default () => ({
context: {
TIMESTAMP: Date.now()
},
// ...
})
// template/index.js
export const appVersion = <%= TIMESTAMP %>
Default: ['**/*.{html,json,vue,js,ts,jsx,tsx}', '**/.env', '**/.env.*']
Glob or array of globs defining which files should be rendered. Unmatched files from template
directory will be just copied without change.
Default: ['<%=', '%>']
onBeforeCreate?: (renderContext: Record<string, any>) => void | Promise<void>
onBeforeRender?: (renderContext: Record<string, any>) => void | Promise<void>
onAfterCreate?: (renderContext: Record<string, any>) => void | Promise<void>