diff --git a/packages/plugin/webpack/src/Config.ts b/packages/plugin/webpack/src/Config.ts index f0621176fc..e28281f987 100644 --- a/packages/plugin/webpack/src/Config.ts +++ b/packages/plugin/webpack/src/Config.ts @@ -1,6 +1,9 @@ -import { Configuration as RawWebpackConfiguration } from 'webpack'; +import { Configuration as RawWebpackConfiguration, WebpackPluginInstance } from 'webpack'; import WebpackDevServer from 'webpack-dev-server'; import { ConfigurationFactory as WebpackConfigurationFactory } from './WebpackConfig'; +import HtmlWebpackPlugin from 'html-webpack-plugin'; + +type ExtraHtmlPluginOptions = Omit<HtmlWebpackPlugin.Options, 'title' | 'template' | 'filename' | 'chunks'>; export interface WebpackPluginEntryPoint { /** @@ -48,6 +51,20 @@ export interface WebpackPluginEntryPoint { * for all entries. */ nodeIntegration?: boolean; + /** + * Custom options to merge into the configuration passed to `HtmlWebpackPlugin`. + */ + htmlOptions?: Partial<ExtraHtmlPluginOptions>; + /** + * Plugins to include before `HtmlWebpackPlugin`; typically, HTML plugin add-ons will + * need to be placed here. + */ + htmlPlugins?: WebpackPluginInstance[]; + /** + * Additional options to merge into the Webpack `output` configuration for this entry- + * point. + */ + output?: object; } export interface WebpackPreloadEntryPoint { diff --git a/packages/plugin/webpack/src/WebpackConfig.ts b/packages/plugin/webpack/src/WebpackConfig.ts index af481b11b0..bbe888c733 100644 --- a/packages/plugin/webpack/src/WebpackConfig.ts +++ b/packages/plugin/webpack/src/WebpackConfig.ts @@ -195,6 +195,7 @@ export default class WebpackConfigGenerator { devtool: this.rendererSourceMapOption, mode: this.mode, output: { + ...(entryPoint.output || {}), path: path.resolve(this.webpackDir, 'renderer'), filename: '[name]/index.js', globalObject: 'self', @@ -205,9 +206,11 @@ export default class WebpackConfigGenerator { __filename: false, }, plugins: [ + ...(entryPoint.htmlPlugins || []), ...(entryPoint.html ? [ new HtmlWebpackPlugin({ + ...(entryPoint.htmlOptions || {}), title: entryPoint.name, template: entryPoint.html, filename: `${entryPoint.name}/index.html`, diff --git a/packages/plugin/webpack/test/WebpackConfig_spec.ts b/packages/plugin/webpack/test/WebpackConfig_spec.ts index 95b9ce60fa..4c04dc12d0 100644 --- a/packages/plugin/webpack/test/WebpackConfig_spec.ts +++ b/packages/plugin/webpack/test/WebpackConfig_spec.ts @@ -643,6 +643,37 @@ describe('WebpackConfigGenerator', () => { await generator.getRendererConfig(config.renderer.entryPoints); expect(getInvokedCounter()).to.equal(2); }); + + it('honors custom entrypoint output options', async () => { + const { MyWebpackConfigGenerator } = makeSubclass(); + + const config = { + mainConfig: () => ({ + entry: 'main.js', + ...sampleWebpackConfig, + }), + renderer: { + config: { ...sampleWebpackConfig }, + entryPoints: [ + { + name: 'main', + js: 'rendererScript.js', + output: { + crossorigin: 'anonymous', + }, + }, + ], + }, + } as WebpackPluginConfig; + + const generator = new MyWebpackConfigGenerator(config, mockProjectDir, false, 3000); + + const rendererConfig = await generator.getRendererConfig(config.renderer.entryPoints); + // eslint-disable-next-line @typescript-eslint/no-explicit-any + const outputSettings = rendererConfig[0].output as any; + expect(outputSettings).not.to.be.undefined; + expect(outputSettings['crossorigin']).to.equal('anonymous'); + }); }); }); });