2018-12-13 15:25:37 +00:00
|
|
|
/**
|
|
|
|
* External dependencies
|
|
|
|
*/
|
2019-10-15 15:35:03 +00:00
|
|
|
const { DefinePlugin } = require( 'webpack' );
|
2018-12-13 15:25:37 +00:00
|
|
|
const CopyWebpackPlugin = require( 'copy-webpack-plugin' );
|
2020-01-03 13:15:33 +00:00
|
|
|
const LiveReloadPlugin = require( 'webpack-livereload-plugin' );
|
2018-12-13 15:25:37 +00:00
|
|
|
const UglifyJS = require( 'uglify-js' );
|
2022-04-11 12:02:14 +00:00
|
|
|
const { join } = require( 'path' );
|
2018-12-13 15:25:37 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* WordPress dependencies
|
|
|
|
*/
|
2022-04-11 12:02:14 +00:00
|
|
|
const {
|
|
|
|
camelCaseDash,
|
|
|
|
} = require( '@wordpress/dependency-extraction-webpack-plugin/lib/util' );
|
2020-01-03 13:15:33 +00:00
|
|
|
const DependencyExtractionPlugin = require( '@wordpress/dependency-extraction-webpack-plugin' );
|
2018-12-13 15:25:37 +00:00
|
|
|
|
2019-09-19 15:17:39 +00:00
|
|
|
/**
|
|
|
|
* Internal dependencies
|
|
|
|
*/
|
2022-04-11 12:02:14 +00:00
|
|
|
const { stylesTransform, baseConfig, baseDir } = require( './shared' );
|
2019-09-19 15:17:39 +00:00
|
|
|
const { dependencies } = require( '../../package' );
|
|
|
|
|
2022-04-11 12:02:14 +00:00
|
|
|
const exportDefaultPackages = [
|
|
|
|
'api-fetch',
|
|
|
|
'deprecated',
|
|
|
|
'dom-ready',
|
|
|
|
'redux-routine',
|
|
|
|
'token-list',
|
|
|
|
'server-side-render',
|
|
|
|
'shortcode',
|
|
|
|
'warning',
|
|
|
|
];
|
2018-12-13 15:25:37 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Maps vendors to copy commands for the CopyWebpackPlugin.
|
|
|
|
*
|
2018-12-14 04:10:26 +00:00
|
|
|
* @param {Object} vendors Vendors to include in the vendor folder.
|
|
|
|
* @param {string} buildTarget The folder in which to build the packages.
|
2018-12-13 15:25:37 +00:00
|
|
|
*
|
|
|
|
* @return {Object[]} Copy object suitable for the CopyWebpackPlugin.
|
|
|
|
*/
|
2018-12-14 04:10:26 +00:00
|
|
|
function mapVendorCopies( vendors, buildTarget ) {
|
2018-12-13 15:25:37 +00:00
|
|
|
return Object.keys( vendors ).map( ( filename ) => ( {
|
|
|
|
from: join( baseDir, `node_modules/${ vendors[ filename ] }` ),
|
2018-12-14 04:10:26 +00:00
|
|
|
to: join( baseDir, `${ buildTarget }/js/dist/vendor/${ filename }` ),
|
2018-12-13 15:25:37 +00:00
|
|
|
} ) );
|
|
|
|
}
|
|
|
|
|
2018-12-24 13:28:22 +00:00
|
|
|
module.exports = function( env = { environment: 'production', watch: false, buildTarget: false } ) {
|
2018-12-13 15:25:37 +00:00
|
|
|
const mode = env.environment;
|
2018-12-14 04:10:26 +00:00
|
|
|
const suffix = mode === 'production' ? '.min' : '';
|
2018-12-24 13:28:22 +00:00
|
|
|
let buildTarget = env.buildTarget ? env.buildTarget : ( mode === 'production' ? 'build' : 'src' );
|
|
|
|
buildTarget = buildTarget + '/wp-includes';
|
2018-12-13 15:25:37 +00:00
|
|
|
|
2019-09-19 15:17:39 +00:00
|
|
|
const WORDPRESS_NAMESPACE = '@wordpress/';
|
2021-04-07 11:37:35 +00:00
|
|
|
const BUNDLED_PACKAGES = [ '@wordpress/icons', '@wordpress/interface' ];
|
2019-09-19 15:17:39 +00:00
|
|
|
const packages = Object.keys( dependencies )
|
2020-02-06 21:01:16 +00:00
|
|
|
.filter( ( packageName ) =>
|
|
|
|
! BUNDLED_PACKAGES.includes( packageName ) &&
|
|
|
|
packageName.startsWith( WORDPRESS_NAMESPACE )
|
|
|
|
)
|
2019-09-19 15:17:39 +00:00
|
|
|
.map( ( packageName ) => packageName.replace( WORDPRESS_NAMESPACE, '' ) );
|
2018-12-13 15:25:37 +00:00
|
|
|
|
|
|
|
const vendors = {
|
|
|
|
'lodash.js': 'lodash/lodash.js',
|
2021-06-14 23:16:27 +00:00
|
|
|
'wp-polyfill.js': '@wordpress/babel-preset-default/build/polyfill.js',
|
2018-12-13 15:25:37 +00:00
|
|
|
'wp-polyfill-fetch.js': 'whatwg-fetch/dist/fetch.umd.js',
|
|
|
|
'wp-polyfill-element-closest.js': 'element-closest/element-closest.js',
|
2021-03-30 14:47:04 +00:00
|
|
|
'wp-polyfill-node-contains.js': 'polyfill-library/polyfills/__dist/Node.prototype.contains/raw.js',
|
2020-03-03 16:53:32 +00:00
|
|
|
'wp-polyfill-url.js': 'core-js-url-browser/url.js',
|
2021-03-30 14:47:04 +00:00
|
|
|
'wp-polyfill-dom-rect.js': 'polyfill-library/polyfills/__dist/DOMRect/raw.js',
|
2018-12-13 15:25:37 +00:00
|
|
|
'wp-polyfill-formdata.js': 'formdata-polyfill/FormData.js',
|
2021-01-28 02:01:50 +00:00
|
|
|
'wp-polyfill-object-fit.js': 'objectFitPolyfill/src/objectFitPolyfill.js',
|
2018-12-13 15:25:37 +00:00
|
|
|
'moment.js': 'moment/moment.js',
|
|
|
|
'react.js': 'react/umd/react.development.js',
|
|
|
|
'react-dom.js': 'react-dom/umd/react-dom.development.js',
|
2021-06-23 00:04:47 +00:00
|
|
|
'regenerator-runtime.js': 'regenerator-runtime/runtime.js',
|
2018-12-13 15:25:37 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
const minifiedVendors = {
|
|
|
|
'lodash.min.js': 'lodash/lodash.min.js',
|
2021-06-14 23:16:27 +00:00
|
|
|
'wp-polyfill.min.js': '@wordpress/babel-preset-default/build/polyfill.min.js',
|
2018-12-13 15:25:37 +00:00
|
|
|
'wp-polyfill-formdata.min.js': 'formdata-polyfill/formdata.min.js',
|
2020-03-03 16:53:32 +00:00
|
|
|
'wp-polyfill-url.min.js': 'core-js-url-browser/url.min.js',
|
2021-01-28 02:01:50 +00:00
|
|
|
'wp-polyfill-object-fit.min.js': 'objectFitPolyfill/dist/objectFitPolyfill.min.js',
|
2018-12-13 15:25:37 +00:00
|
|
|
'moment.min.js': 'moment/min/moment.min.js',
|
|
|
|
'react.min.js': 'react/umd/react.production.min.js',
|
|
|
|
'react-dom.min.js': 'react-dom/umd/react-dom.production.min.js',
|
|
|
|
};
|
|
|
|
|
|
|
|
const minifyVendors = {
|
2021-06-23 00:04:47 +00:00
|
|
|
'regenerator-runtime.min.js': 'regenerator-runtime/runtime.js',
|
2018-12-13 15:25:37 +00:00
|
|
|
'wp-polyfill-fetch.min.js': 'whatwg-fetch/dist/fetch.umd.js',
|
|
|
|
'wp-polyfill-element-closest.min.js': 'element-closest/element-closest.js',
|
2021-03-30 14:47:04 +00:00
|
|
|
'wp-polyfill-node-contains.min.js': 'polyfill-library/polyfills/__dist/Node.prototype.contains/raw.js',
|
|
|
|
'wp-polyfill-dom-rect.min.js': 'polyfill-library/polyfills/__dist/DOMRect/raw.js',
|
2018-12-13 15:25:37 +00:00
|
|
|
};
|
|
|
|
|
2018-12-13 17:39:59 +00:00
|
|
|
const phpFiles = {
|
2018-12-17 04:50:48 +00:00
|
|
|
'block-serialization-default-parser/parser.php': 'wp-includes/class-wp-block-parser.php',
|
2018-12-13 17:39:59 +00:00
|
|
|
};
|
|
|
|
|
2018-12-14 04:10:26 +00:00
|
|
|
const developmentCopies = mapVendorCopies( vendors, buildTarget );
|
|
|
|
const minifiedCopies = mapVendorCopies( minifiedVendors, buildTarget );
|
|
|
|
const minifyCopies = mapVendorCopies( minifyVendors, buildTarget ).map( ( copyCommand ) => {
|
2018-12-13 15:25:37 +00:00
|
|
|
return {
|
|
|
|
...copyCommand,
|
|
|
|
transform: ( content ) => {
|
|
|
|
return UglifyJS.minify( content.toString() ).code;
|
|
|
|
},
|
|
|
|
};
|
|
|
|
} );
|
|
|
|
|
|
|
|
let vendorCopies = mode === "development" ? developmentCopies : [ ...minifiedCopies, ...minifyCopies ];
|
|
|
|
|
|
|
|
let cssCopies = packages.map( ( packageName ) => ( {
|
|
|
|
from: join( baseDir, `node_modules/@wordpress/${ packageName }/build-style/*.css` ),
|
2022-04-11 12:02:14 +00:00
|
|
|
to: join( baseDir, `${ buildTarget }/css/dist/${ packageName }/[name]${ suffix }.css` ),
|
|
|
|
transform: stylesTransform( mode ),
|
|
|
|
noErrorOnMissing: true,
|
2018-12-13 15:25:37 +00:00
|
|
|
} ) );
|
|
|
|
|
2018-12-13 17:39:59 +00:00
|
|
|
const phpCopies = Object.keys( phpFiles ).map( ( filename ) => ( {
|
|
|
|
from: join( baseDir, `node_modules/@wordpress/${ filename }` ),
|
|
|
|
to: join( baseDir, `src/${ phpFiles[ filename ] }` ),
|
|
|
|
} ) );
|
|
|
|
|
2018-12-13 15:25:37 +00:00
|
|
|
const config = {
|
2022-04-11 12:02:14 +00:00
|
|
|
...baseConfig( env ),
|
2018-12-13 15:25:37 +00:00
|
|
|
entry: packages.reduce( ( memo, packageName ) => {
|
2022-04-11 12:02:14 +00:00
|
|
|
memo[ packageName ] = {
|
|
|
|
import: join( baseDir, `node_modules/@wordpress/${ packageName }` ),
|
|
|
|
library: {
|
|
|
|
name: [ 'wp', camelCaseDash( packageName ) ],
|
|
|
|
type: 'window',
|
|
|
|
export: exportDefaultPackages.includes( packageName )
|
|
|
|
? 'default'
|
|
|
|
: undefined,
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
2018-12-13 15:25:37 +00:00
|
|
|
return memo;
|
|
|
|
}, {} ),
|
|
|
|
output: {
|
2019-09-17 17:26:38 +00:00
|
|
|
devtoolNamespace: 'wp',
|
2022-04-11 12:02:14 +00:00
|
|
|
filename: `[name]${ suffix }.js`,
|
2018-12-14 04:10:26 +00:00
|
|
|
path: join( baseDir, `${ buildTarget }/js/dist` ),
|
2021-05-20 12:18:43 +00:00
|
|
|
},
|
2018-12-13 15:25:37 +00:00
|
|
|
plugins: [
|
2019-10-15 15:35:03 +00:00
|
|
|
new DefinePlugin( {
|
2022-04-12 15:10:30 +00:00
|
|
|
// Inject the `IS_GUTENBERG_PLUGIN` global, used for feature flagging.
|
|
|
|
'process.env.IS_GUTENBERG_PLUGIN': false,
|
2020-07-07 16:06:43 +00:00
|
|
|
'process.env.FORCE_REDUCED_MOTION': JSON.stringify(
|
|
|
|
process.env.FORCE_REDUCED_MOTION
|
|
|
|
),
|
2019-10-15 15:35:03 +00:00
|
|
|
} ),
|
2020-01-03 13:15:33 +00:00
|
|
|
new DependencyExtractionPlugin( {
|
|
|
|
injectPolyfill: true,
|
2020-02-24 21:20:49 +00:00
|
|
|
combineAssets: true,
|
2020-03-18 04:48:19 +00:00
|
|
|
combinedOutputFile: '../../assets/script-loader-packages.php',
|
2020-01-03 13:15:33 +00:00
|
|
|
} ),
|
2022-04-11 12:02:14 +00:00
|
|
|
new CopyWebpackPlugin( {
|
|
|
|
patterns: [
|
2018-12-13 15:25:37 +00:00
|
|
|
...vendorCopies,
|
|
|
|
...cssCopies,
|
2018-12-13 17:39:59 +00:00
|
|
|
...phpCopies,
|
2018-12-13 15:25:37 +00:00
|
|
|
],
|
2022-04-11 12:02:14 +00:00
|
|
|
} ),
|
2018-12-13 15:25:37 +00:00
|
|
|
],
|
|
|
|
};
|
|
|
|
|
|
|
|
if ( config.mode === 'development' ) {
|
|
|
|
config.plugins.push( new LiveReloadPlugin( { port: process.env.WORDPRESS_LIVE_RELOAD_PORT || 35729 } ) );
|
|
|
|
}
|
|
|
|
|
|
|
|
return config;
|
|
|
|
};
|