Skip to content

Latest commit

 

History

History
96 lines (65 loc) · 3.97 KB

SCAFFOLDING.md

File metadata and controls

96 lines (65 loc) · 3.97 KB

Introduction

Setting up webpack for the first time is hard. Writing advanced configurations to optimize performance is even harder. The init feature is designed to support people that want to create their own configuration or initializing other projects people create.

Writing a good scaffold

Before writing a webpack-cli scaffold, think about what you're trying to achieve. Do you want a "general" scaffold that could be used by any project or type of app? Do you want something very focused - like a scaffold that writes both your webpack.config.js and your framework code? It's also useful to think about the user experience for your scaffold.

webpack-cli offers an experience that is interactive and you can prompt users for questions (like, "What is your entry point?") to help customize the output accordingly.

webpack-scaffold

webpack-scaffold is a utility suite for creating addons. It contains functions that could be of use for creating an addon yourself.

webpack-scaffold-yourpackage

In order for webpack-cli to compile your package, it must be available on npm or on your local filesystem. If you are curious about how you can create your very own scaffold, please read How do I compose a webpack-addon?.

If the package is on npm, its name must have a prefix of webpack-scaffold.

If the package is on your local filesystem, it can be named whatever you want. Pass the path to the package.

API

To create an addon, you must create a yeoman-generator. Because of that, you can optionally extend your generator to include methods from the Yeoman API. Its worth noting that we support all the properties of a regular webpack configuration. In order for us to do this, there's a thing you need to remember.

Objects are made using strings, while strings are made using double strings. This means that in order for you to create an string, you have to wrap it inside another string for us to validate it correctly.

opts.env.configuration(required)

Initialized inside the constructor of your generator in order for the CLI to work.

constructor(args, opts) {
		super(args, opts);
		opts.env.configuration = {};
	}

opts.env.configuration.myObj (required)

myObj is your scaffold. This is where you will add options for the CLI to transform into a configuration. You can name it anything, and you can also add more objects, that could represent a dev.config or prod.config.

constructor(args, opts) {
		super(args, opts);
		opts.env.configuration = {
			dev: {},
			prod: {}
		};
	}

myObj.webpackOptions (required)

As with a regular webpack configuration, this property behaves the same. Inside webpackOptions you can declare the properties you want to scaffold. You can for instance, scaffold entry, output and context.

(Inside a yeoman method)

this.options.env.configuration.dev.webpackOptions = {
entry: '\'app.js\'',
output: {....},
merge: 'myConfig'
};

If you want to use webpack-merge, you can supply webpackOptions with the merge property, and the configuration you want to merge it with.

myObj.topScope(optional)

The topScope property is a way for the authors to add special behaviours, like functions that could be called inside a configuration, or variable initializations and module imports.

this.options.env.configuration.dev.topScope = [
'var webpack = require(\'webpack\');'
'var path = require(\'path\');'
];

myObj.configName(optional)

If you want to name your webpack.config.js something special, you can do that.

this.options.env.configuration.dev.configName = 'base';

writing (required)

For the scaffolding instance to run, you need to write your configuration to a .yo-rc.json file. This could be done using one of the lifecycles in the yeoman generator, such as the writing method.

writing() {
	this.config.set('configuration', myObj)
}