Skip to content

Commit

Permalink
feat: implement html minifier (#1015)
Browse files Browse the repository at this point in the history
  • Loading branch information
stefanfrede authored Sep 10, 2020
1 parent f44511b commit fa4190d
Show file tree
Hide file tree
Showing 3 changed files with 68 additions and 4 deletions.
32 changes: 32 additions & 0 deletions plugins/plugin-webpack/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@ npm install --save-dev @snowpack/plugin-webpack
- `outputPattern: {css: string, js: string, assets: string}` - Set the URL for your final bundled files. This is where they will be written to disk in the `build/` directory. See Webpack's [`output.filename`](https://webpack.js.org/configuration/output/#outputfilename) documentation for examples of valid values.
- `extendConfig: (config: WebpackConfig) => WebpackConfig` - extend your webpack config, see below.
- `manifest: boolean | string` - Enable generating a manifest file. The default value is `false`, the default file name is `./asset-manifest.json` if setting manifest to `true`. The relative path is resolved from the output directory.
- `htmlMinifierOptions: boolean | object` - [See below](#minify-html).

#### Extending The Default Webpack Config

Expand All @@ -50,3 +51,34 @@ module.exports = {
],
};
```

#### Minify HTML

With `htmlMinifierOptions` you can either disable the minification entirely or provide your own [options](https://github.com/kangax/html-minifier#options-quick-reference).

```js
// snowpack.config.js
module.exports = {
plugins: [
[
"@snowpack/plugin-webpack",
{
htmlMinifierOptions: false // disabled entirely,
},
],
],
};
```

The default options are:

```js
{
collapseWhitespace: true,
removeComments: true,
removeEmptyAttributes: true,
removeRedundantAttributes: true,
removeScriptTypeAttributes: true,
removeStyleLinkTypeAttributes: true,
}
```
1 change: 1 addition & 0 deletions plugins/plugin-webpack/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@
"css-loader": "^3.5.3",
"file-loader": "^6.0.0",
"glob": "^7.1.6",
"html-minifier": "^4.0.0",
"jsdom": "^16.2.2",
"mini-css-extract-plugin": "^0.9.0",
"optimize-css-assets-webpack-plugin": "^5.0.3",
Expand Down
39 changes: 35 additions & 4 deletions plugins/plugin-webpack/plugin.js
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ const ManifestPlugin = require('webpack-manifest-plugin');
const jsdom = require("jsdom");
const { JSDOM } = jsdom;
const cwd = process.cwd();
const minify = require('html-minifier').minify;

function insertBefore(newNode, existingNode) {
existingNode.parentNode.insertBefore(newNode, existingNode);
Expand Down Expand Up @@ -51,7 +52,13 @@ function parseHTMLFiles({ buildDirectory }) {
return { doms, jsEntries };
}

function emitHTMLFiles({ doms, jsEntries, stats, baseUrl, buildDirectory }) {
function emitHTMLFiles({
doms,
jsEntries,
stats, baseUrl,
buildDirectory,
htmlMinifierOptions,
}) {
const entrypoints = stats.toJson({ assets: false, hash: true }).entrypoints;

//Now that webpack is done, modify the html files to point to the newly compiled resources
Expand Down Expand Up @@ -87,7 +94,11 @@ function emitHTMLFiles({ doms, jsEntries, stats, baseUrl, buildDirectory }) {

//And write our modified html files out to the destination
for (const [htmlFile, dom] of Object.entries(doms)) {
fs.writeFileSync(path.join(buildDirectory, htmlFile), dom.serialize());
const html = htmlMinifierOptions
? minify(dom.serialize(), htmlMinifierOptions)
: dom.serialize();

fs.writeFileSync(path.join(buildDirectory, htmlFile), html);
}
}

Expand Down Expand Up @@ -161,7 +172,20 @@ module.exports = function plugin(config, args) {
if (!cssOutputPattern.endsWith(".css")) {
throw new Error("Output Pattern for CSS must end in .css");
}


// Default options for HTMLMinifier
// https://github.com/kangax/html-minifier#options-quick-reference
const defaultHtmlMinifierOptions = {
collapseWhitespace: true,
removeComments: true,
removeEmptyAttributes: true,
removeRedundantAttributes: true,
removeScriptTypeAttributes: true,
removeStyleLinkTypeAttributes: true,
};

const htmlMinifierOptions = args.htmlMinifierOptions === false ? false : Object.assign({}, defaultHtmlMinifierOptions, args.htmlMinifierOptions)

const manifest =
typeof args.manifest === 'string'
? args.manifest
Expand Down Expand Up @@ -355,7 +379,14 @@ module.exports = function plugin(config, args) {
);
}

emitHTMLFiles({ doms, jsEntries, stats, baseUrl, buildDirectory });
emitHTMLFiles({
doms,
jsEntries,
stats,
baseUrl,
buildDirectory,
htmlMinifierOptions,
});
},
};
};

0 comments on commit fa4190d

Please sign in to comment.