Modern.js provides engineering solutions such as Web App and Npm Module. By using the @modern-js/create tool, you can create initial project templates for engineering solutions. The initial project template provides a basic code development environment, simple example code, and configuration, etc.
The initial templates provided by Modern.js are generic and can meet some common project development needs.
When you use Modern.js deeply, you will inevitably find that each created project will make some specific similar changes for its own project, such as modifying example code, adding some configurations, enabling certain features, etc.
Generator plugin can help you to deposit these specific changes for individuals or teams. When running npx @modern-js/create@latest, you only need to simply add the --plugin parameter to avoid repetitive modification of the project after each project creation.
Generator plugin is based on the initial template projects provided by Modern.js, providing methods to add, delete, and modify templates, and modifying package.json, modernConfig configurations, and enabling features through a convenient way.
Use @modern-js/create to create a generator plugin project directly:
After creating, we can take a look at the directory structure of this project:
The project is based on the Npm module project, and the core files are as follows:
In addition to the normal fields of a module project, package.json provides a meta field to describe information about the generator plugin.
Generator plugin is divided into two categories: extension and custom. For specific classification definitions, please refer to Type.
This file is used to complete the content development of the generator plugin.
This file exports a function by default, and the function takes context as a parameter. The context object provides API methods supported by the generator plugin, which can be used to implement the logic of the generator plugin. The capabilities provided by context can be found in context.
The templates directory contains template files for the current customization method, supporting Handlebars and EJS formats. Different rendering engines will be used for rendering according to the template file suffix. If there is no suffix, the template file will be copied directly to the target directory.
If the template file is a js, ts, or json file, it is recommended to use the .handlebars or .ejs suffix directly to avoid project eslint errors and recognition issues in Monorepo projects.
The .gitignore and .npmrc files in the template will be automatically deleted when publishing the npm package, so it is necessary to use the .handlebars or .ejs suffix to keep them.