This repository has been archived by the owner on Jul 19, 2021. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 363
Slate Configuration
Thomas Kelly edited this page Sep 14, 2018
·
3 revisions
Excluding connecting to your store, Slate should work out of the box without any additional configuration. For developers who want to customize the default configurations of Slate, they can do so via a slate.config.js
file found in the root of the theme.
A typical slate.config.js
could look something like below:
const path = require('path');
const newPostCssPlugin = require('newPostCssPlugin');
module.exports = {
// Configuration values can be set directly
'webpack.babel.enable': false,
// Or even computed when requested by Slate Config's .get() method. This allows
// configuration items to access other configuration items. The argument passed
// to the function is an instance of the SlateConfig() class.
'paths.theme.src': config => path.join(config.get('paths.theme'), 'src'),
// A function even has access to the default config value, allowing you to
// to extend configurations
'webpack.postcss.plugins': (config, defaultValue) => [
newPostCssPlugin,
...defaultValue
]
};
Sometimes you want a configuration to be different depending on if your running a production build (slate-tools build
) or development build (slate-tools start
). To do this, you can take advantage of the process.env.NODE_ENV
which Slate sets to 'production'
or 'development'
:
module.exports = {
'webpack.postcss.plugins': (config) => {
const plugins = [autoprefixer];
// We only want to minify our CSS if we're building for production
if (process.env.NODE_ENV === 'production') {
plugins.push(cssnano(config.get('webpack.cssnano.settings'))
}
return plugins;
},
}
Configurations are declared within Slate packages, across various schema files. The best way to learn about these configurations are to explore these files: