Skip to main content

Webpack

docs-source

At its core, webpack is a static module bundler for modern JavaScript applications. When webpack processes your application, it internally builds a dependency graph which maps every module your project needs and generates one or more bundles. Learn more about webpack here.

Look at how the config is set up on Eightshift Boilerplate repo.

In order to use this library, you'll need to have a webpack.config.js file in the root of your project.

This file holds basic configuration that will build your assets correctly and provide browsersync functionality.

webpack.config.js is a main entrypoint for webpack config and looks like this:

/* eslint-disable import/no-dynamic-require, global-require */

module.exports = (env, argv) => {

const projectConfig = {
config: {
projectDir: __dirname, // Current project directory absolute path.
projectUrl: 'local-url.test', // Used for providing browsersync functionality.
projectPath: 'wp-content/themes/your-theme-name', // Project path relative to project root.
assetsPath: 'src/blocks/assets', // Assets path after projectPath location. (add this key only to override the default value.)
blocksAssetsPathConfig: 'src/blocks/assets', // Blocks assets path after projectPath location. (add this key only to override the default value.)
outputPath: 'public', // Public output path after projectPath location. (add this key only to override the default value.)
},
};

// Generate webpack config for this project using options object.
const project = require('./node_modules/@eightshift/frontend-libs/webpack')(argv.mode, projectConfig);

return {
...project,
};
};

Override built-in functionality

To remove built-in functionality, add a new array to the config called overrides. If you provide any of the overrides keys, it will remove that config from the build. Here is a list of all the features that we use and how to remove them.


const projectConfig = {
config: {
...
},
overrides: [
'application',
'applicationAdmin',
'applicationBlocks',
'applicationBlocksEditor',
'filename',
'cleanWebpackPlugin',
'terserPlugin',
'browserSyncPlugin',
'providePlugin',
'manifestPlugin',
'miniCssExtractPlugin',
'copyWebpackPlugin',
'optimizeCSSAssetsPlugin',
'js',
'scss',
'images',
'fonts',
'runtimeChunk',
],
}

Add Custom build

If you want to add something custom to your build, you can simply use all the native webpack features by providing it like in the example:

/* eslint-disable import/no-dynamic-require, global-require */

const HtmlWebpackPlugin = require('html-webpack-plugin');

module.exports = (env, argv) => {

...

return {
...project,
plugins: [
...project.plugins,
new HtmlWebpackPlugin(),
],
};
};

If you want to override the defaults from the libs, first put it in the overrides array, then provide your own config as described above.