-
Notifications
You must be signed in to change notification settings - Fork 330
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Support configuration of style rules, not just rule and loader options #223
Comments
Making Style Rules ConfigurableWebpack style processing rules created by nwb chain together These are configured appropriately for development serving and for builds (using CurrentBy default, one rule is created for CSS in your app ( These are configurable using a naming convention in e.g. NextFor nwb v0.16 we would like to make it possible to configure your own style rule setup and provide configuration for the individual loaders chained by the rule at the same time. Example use case: use CSS modules for CSS from a particular directory but use global CSS for everything else. Example use case: providing the specific rule setup a dependency from Backwards CompatibilityOption 1: Same by default. If you don't define Option 2: Break, with new defaults. If you don't define You should also be able to configure something like Style Rule ConfigWhat should the object configuring a single style rule look like? We need the following values to create rules: // Style processing configuration object format
// One of these maps to creation of a single Webpack rule
let styleConfig = {
// Either 'css' or the the id of a style preprocessing plugin
// e.g. 'sass' if you're using nwb-sass
type: 'css',
// Loaders chained in the style rule can have their configuration tweaked
// using an object under a prop matching their name.
loaders: {
style: { /*...*/ }
css: { /*...*/ }
postcss: { /*...*/ }
// When using a preprocessor, its loader can also be configured
// sass: configure sass-loader, including plugins (type: 'sass', using nwb-sass)
// less: configure less-loader, including plugins (type: 'less', using nwb-less)
// stylus: configure stylus-loader, including plugins (type: 'stylus', using nwb-stylus)
sass: { /*...*/ }
},
// For convenience, we will take 'style', 'css', 'postcss' and preprocessor
// loader config and move it into the `loaders` format above when processing
// user config if a `loaders` prop doesn't exist.
// Example of configuring css-loader to use CSS modules
css: {
modules: true,
localIdentName: (
process.env.NODE_ENV === 'production'
? '[path][name]-[local]-[hash:base64:5]'
: '[hash:base64:5]'
)
}
// All other properties passed will be added to the Webpack rule, so
// all top-level rule config can be provided here - see module.rules in
// https://webpack.js.org/configuration/ for all possibilities.
include: path.resolve('src/components'),
// Support for custom rules? Maybe next release.
// What if a use: prop could be used to configure additional loaders?
// Passing the names of loaders managed by nwb could be detected to allow
// mixing them with custom loaders, similar to what we do for reusing Karma
// plugins managed by nwb when creating Karma config.
} Speculative Example ConfigsCSS modules for one directory, global CSS everywhere else module.exports = {
webpack: {
styles: [
{
type: 'css',
include: path.resolve('src/components'),
css: {
modules: true,
localIdentName: (
process.env.NODE_ENV === 'production'
? '[path][name]-[local]-[hash:base64:5]'
: '[hash:base64:5]'
)
}
},
{
type: 'css',
exclude: path.resolve('src/components')
}
]
}
} Variant: an object is provided and its properties are the module.exports = {
webpack: {
styles: {
css: [
{
include: path.resolve('src/components'),
css: {
modules: true,
localIdentName: (
process.env.NODE_ENV === 'production'
? '[path][name]-[local]-[hash:base64:5]'
: '[hash:base64:5]'
)
}
},
{
exclude: path.resolve('src/components')
}
]
]
}
} TODO: react-toolbox example |
It's really focused on styling, but how would I configure the loaders used for JavaScript? Or SVG? I'm not a huge fan of the custom schema, I'd prefer to stay as close to the Webpack schema as possible. |
Implemented in v0.16.0 |
The default style rule configured to handle an app's own stylesheets applies to everything by excluding
node_modules/
- it's not possible, for example, to use CSS modules for some stylesheets (e.g. just those insrc/components/
) and global CSS for everything else.By default we also create a separate a
vendor-
version of each style rule which handles all imports fromnode_modules/
the same way.Equivalents of these two rules are also created for each style preprocessor plugin you use, using the plugin's id (e.g.
sass
) instead of `css.We should provide a way to configure this.
Having configurable style rules would also allow you to set up special snowflakes for dependencies which want you do to preprocessing in a specific way.
A way to represent the current setup might be the following -
createRules()
increateWebpackConfig.js
is effectively doing an unrolled version of this for CSS and for any style preprocessors being used:What might it look like for a dependency which wants you to use a preprocessor with a specific config?
The purpose of using a prefix is to ensure every loader has unique id associated with it to allow configuration via
webpack.rules[id]
- what if this configuration allowed you to provide loader option overrides by loader (in the chain) id?e.g. enabling CSS modules for a specific path:
TBC
The text was updated successfully, but these errors were encountered: