From c5e32d33b4cfa3ad2f6586947bd85c2cf47ad1c7 Mon Sep 17 00:00:00 2001 From: Jan Nicklas Date: Thu, 22 Mar 2018 18:08:37 +0100 Subject: [PATCH 1/2] feat: Allow to overwrite the templateParameter #830 --- README.md | 1 + index.js | 41 ++++++++++++++++++------- spec/BasicSpec.js | 55 +++++++++++++++++++++++++++++++++- spec/fixtures/templateParam.js | 2 +- 4 files changed, 87 insertions(+), 12 deletions(-) diff --git a/README.md b/README.md index ee2a7c4e..6bc8e347 100644 --- a/README.md +++ b/README.md @@ -110,6 +110,7 @@ Allowed values are as follows |**[`title`](#)**|`{String}`|``|The title to use for the generated HTML document| |**[`filename`](#)**|`{String}`|`'index.html'`|The file to write the HTML to. Defaults to `index.html`. You can specify a subdirectory here too (eg: `assets/admin.html`)| |**[`template`](#)**|`{String}`|``|`webpack` require path to the template. Please see the [docs](https://github.com/jantimon/html-webpack-plugin/blob/master/docs/template-option.md) for details| +|**[`templateParameters`](#)**|`{Boolean\|Object\|Function}`|``| Allows to overwrite the parameters used in the template | |**[`inject`](#)**|`{Boolean\|String}`|`true`|`true \|\| 'head' \|\| 'body' \|\| false` Inject all assets into the given `template` or `templateContent`. When passing `true` or `'body'` all javascript resources will be placed at the bottom of the body element. `'head'` will place the scripts in the head element| |**[`favicon`](#)**|`{String}`|``|Adds the given favicon path to the output HTML| |**[`minify`](#)**|`{Boolean\|Object}`|`true`|Pass [html-minifier](https://github.com/kangax/html-minifier#options-quick-reference)'s options as object to minify the output| diff --git a/index.js b/index.js index ae6026e5..d7844eaf 100644 --- a/index.js +++ b/index.js @@ -19,6 +19,7 @@ class HtmlWebpackPlugin { // Default options this.options = _.extend({ template: path.join(__dirname, 'default_index.ejs'), + templateParameters: templateParametersGenerator, filename: 'index.html', hash: false, inject: true, @@ -253,25 +254,29 @@ class HtmlWebpackPlugin { : Promise.reject('The loader "' + this.options.template + '" didn\'t return html.'); } + /** + * Generate the template parameters for the template function + */ + getTemplateParameters (compilation, assets) { + if (typeof this.options.templateParameters === 'function') { + return this.options.templateParameters(compilation, assets, this.options); + } + if (typeof this.options.templateParameters === 'object') { + return this.options.templateParameters; + } + return {}; + } + /** * Html post processing * * Returns a promise */ executeTemplate (templateFunction, chunks, assets, compilation) { - const self = this; return Promise.resolve() // Template processing .then(() => { - const templateParams = { - compilation: compilation, - webpack: compilation.getStats().toJson(), - webpackConfig: compilation.options, - htmlWebpackPlugin: { - files: assets, - options: self.options - } - }; + const templateParams = this.getTemplateParameters(compilation, assets); let html = ''; try { html = templateFunction(templateParams); @@ -684,4 +689,20 @@ function trainCaseToCamelCase (word) { return word.replace(/-([\w])/g, (match, p1) => p1.toUpperCase()); } +/** + * The default for options.templateParameter + * Generate the template parameters + */ +function templateParametersGenerator (compilation, assets, options) { + return { + compilation: compilation, + webpack: compilation.getStats().toJson(), + webpackConfig: compilation.options, + htmlWebpackPlugin: { + files: assets, + options: options + } + }; +} + module.exports = HtmlWebpackPlugin; diff --git a/spec/BasicSpec.js b/spec/BasicSpec.js index b70f2ea3..ca0d5158 100644 --- a/spec/BasicSpec.js +++ b/spec/BasicSpec.js @@ -1614,7 +1614,60 @@ describe('HtmlWebpackPlugin', function () { inject: false }) ] - }, ['templateParams.compilation exists: true'], null, done); + }, ['templateParams keys: "compilation,webpack,webpackConfig,htmlWebpackPlugin"'], null, done); + }); + + it('should allow to disable template parameters', function (done) { + testHtmlPlugin({ + entry: path.join(__dirname, 'fixtures/index.js'), + output: { + path: OUTPUT_DIR, + filename: 'index_bundle.js' + }, + plugins: [ + new HtmlWebpackPlugin({ + template: path.join(__dirname, 'fixtures/templateParam.js'), + inject: false, + templateParameters: false + }) + ] + }, ['templateParams keys: ""'], null, done); + }); + + it('should allow to set specific template parameters', function (done) { + testHtmlPlugin({ + entry: path.join(__dirname, 'fixtures/index.js'), + output: { + path: OUTPUT_DIR, + filename: 'index_bundle.js' + }, + plugins: [ + new HtmlWebpackPlugin({ + template: path.join(__dirname, 'fixtures/templateParam.js'), + inject: false, + templateParameters: { foo: 'bar' } + }) + ] + }, ['templateParams keys: "foo"'], null, done); + }); + + it('should allow to set specific template parameters using a function', function (done) { + testHtmlPlugin({ + entry: path.join(__dirname, 'fixtures/index.js'), + output: { + path: OUTPUT_DIR, + filename: 'index_bundle.js' + }, + plugins: [ + new HtmlWebpackPlugin({ + template: path.join(__dirname, 'fixtures/templateParam.js'), + inject: false, + templateParameters: function () { + return { 'foo': 'bar' }; + } + }) + ] + }, ['templateParams keys: "foo"'], null, done); }); it('should not treat templateContent set to an empty string as missing', function (done) { diff --git a/spec/fixtures/templateParam.js b/spec/fixtures/templateParam.js index 55741869..6580c457 100644 --- a/spec/fixtures/templateParam.js +++ b/spec/fixtures/templateParam.js @@ -1,3 +1,3 @@ module.exports = function (templateParams) { - return 'templateParams.compilation exists: ' + !!templateParams.compilation; + return 'templateParams keys: "' + Object.keys(templateParams).join(',') + '"'; }; From 07481a2781d606e705b834078590fbbdcaf7999a Mon Sep 17 00:00:00 2001 From: Jan Nicklas Date: Thu, 22 Mar 2018 18:40:25 +0100 Subject: [PATCH 2/2] chore(release): 3.1.0 --- CHANGELOG.md | 10 ++++++++++ package-lock.json | 2 +- package.json | 2 +- 3 files changed, 12 insertions(+), 2 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 60e7744b..5dbb6484 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -2,6 +2,16 @@ All notable changes to this project will be documented in this file. See [standard-version](https://github.com/conventional-changelog/standard-version) for commit guidelines. + +# [3.1.0](https://github.com/jantimon/html-webpack-plugin/compare/v3.0.8...v3.1.0) (2018-03-22) + + +### Features + +* Allow to overwrite the templateParameter [#830](https://github.com/jantimon/html-webpack-plugin/issues/830) ([c5e32d3](https://github.com/jantimon/html-webpack-plugin/commit/c5e32d3)) + + + ## [3.0.8](https://github.com/jantimon/html-webpack-plugin/compare/v3.0.7...v3.0.8) (2018-03-22) diff --git a/package-lock.json b/package-lock.json index d1fe0804..3eeda61c 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,6 +1,6 @@ { "name": "html-webpack-plugin", - "version": "3.0.8", + "version": "3.1.0", "lockfileVersion": 1, "requires": true, "dependencies": { diff --git a/package.json b/package.json index 01677816..2b6b680d 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "html-webpack-plugin", - "version": "3.0.8", + "version": "3.1.0", "license": "MIT", "description": "Simplifies creation of HTML files to serve your webpack bundles", "author": "Charles Blaxland (https://github.com/ampedandwired)",