Skip to content

Commit

Permalink
Add webpack changes to build also view files prefixed with view
Browse files Browse the repository at this point in the history
  • Loading branch information
gziolo committed Mar 16, 2022
1 parent 10b4501 commit 8e5fc20
Show file tree
Hide file tree
Showing 2 changed files with 15 additions and 11 deletions.
2 changes: 1 addition & 1 deletion packages/block-library/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ _This package assumes that your code will run in an **ES2015+** environment. If

## Building JavaScript for the browser

If a `view.js` file is present in the block's directory, this file will be built along other assets, making it available to load from the browser.
If a `view.js` file (or a file prefixed with `view`, e.g. `view-example.js`) is present in the block's directory, this file will be built along other assets, making it available to load from the browser.

This enables us to, for instance, load this file when the block is present on the page in two ways:

Expand Down
24 changes: 14 additions & 10 deletions tools/webpack/blocks.js
Original file line number Diff line number Diff line change
Expand Up @@ -17,10 +17,11 @@ const DependencyExtractionWebpackPlugin = require( '@wordpress/dependency-extrac
const { baseConfig, plugins, stylesTransform } = require( './shared' );

/*
* Matches a block's name in paths in the form
* build-module/<blockName>/view.js
* Matches a block's filepaths in the form build-module/<filename>.js
*/
const blockNameRegex = new RegExp( /(?<=build-module\/).*(?=(\/view))/g );
const blockViewRegex = new RegExp(
/build-module\/(?<filename>.*\/view.*).js$/
);

/**
* We need to automatically rename some functions when they are called inside block files,
Expand All @@ -31,26 +32,29 @@ const prefixFunctions = [ 'build_query_vars_from_query_block' ];

const createEntrypoints = () => {
/*
* Returns an array of paths to view.js files within the `@wordpress/block-library` package.
* These paths can be matched by the regex `blockNameRegex` in order to extract
* the block's name.
* Returns an array of paths to block view files within the `@wordpress/block-library` package.
* These paths can be matched by the regex `blockViewRegex` in order to extract
* the block's filename.
*
* Returns an empty array if no files were found.
*/
const blockViewScriptPaths = fastGlob.sync(
'./packages/block-library/build-module/**/view.js'
'./packages/block-library/build-module/**/view*.js'
);

/*
* Go through the paths found above, in order to define webpack entry points for
* each block's view.js file.
*/
return blockViewScriptPaths.reduce( ( entries, scriptPath ) => {
const [ blockName ] = scriptPath.match( blockNameRegex );
const result = scriptPath.match( blockViewRegex );
if ( ! result?.groups?.filename ) {
return entries;
}

return {
...entries,
[ 'blocks/' + blockName ]: scriptPath,
[ result.groups.filename ]: scriptPath,
};
}, {} );
};
Expand All @@ -61,7 +65,7 @@ module.exports = {
entry: createEntrypoints(),
output: {
devtoolNamespace: 'wp',
filename: './build/block-library/[name]/view.min.js',
filename: './build/block-library/blocks/[name].min.js',
path: join( __dirname, '..', '..' ),
},
plugins: [
Expand Down

0 comments on commit 8e5fc20

Please sign in to comment.