eleventy-plugin-workbox
v1.4.0
Published
Plugin for creating service worker that caches built assets by Eleventy
Downloads
48
Readme
eleventy-plugin-workbox 💼
Cache your site to stay up in offline! ✊
Intention
This plugin aims to be as configurable as you want and has ability to inject service worker registration script into HTML.
Get started
Warning: plugin uses build events that are available in Eleventy from
0.11.1
version. So versions below are not supported!
Installation
At first do:
npm i -D eleventy-plugin-workbox
And then add plugin to eleventyConfig object in .eleventy.js
.
const { cache } = require('eleventy-plugin-workbox');
module.exports = (eleventyConfig) => {
eleventyConfig.addPlugin(cache, {
/* Options are optional. */
});
};
Options
Plugin can accept options:
interface EleventyPluginWorkboxOptions {
/**
* Options that will be passed to
* [`generateSW` function](https://developers.google.com/web/tools/workbox/reference-docs/latest/module-workbox-build#.generateSW).
*/
generateSWOptions?: GenerateSWConfig;
/**
* Directory inside _output_ folder to be used as place for
* service worker.
*/
publicDirectory?: string;
/**
* Scope for service worker.
* Default `/`.
*/
scope?: string;
/**
* Tells if plugin should generate service worker.
* Useful for situations when there is a need to test service worker,
* especially in development process.
*
* By default, it is enabled if `NODE_ENV === 'production'`.
*/
enabled?: boolean;
}
If your templates are generated into
index.html
files, then you can refer them with a directory name. In that case you should append/
to directory name. Without it service worker can not reachindex.html
files.
What's special?
This plugin uses
workbox
to cache assets.Assets is all HTML files, JavaScript, CSS, JSON, images and fonts. For detailed list of file extensions check
src/constants.ts
.It differentiates between static(images and fonts) and dynamic(JavaScript, CSS, HTML, JSON) assets. They are treated differently:
- for static assets plugin uses
StaleWhileRevalidate
due to assumption that such resources are changed rarely. - for dynamic assets plugin uses
NetworkFirst
strategy, because this resources may change frequently.
This is a default behavior and can be easily changed.
- for static assets plugin uses
It automatically injects service worker registration script into each generated HTML, so you must not do it manually. Perfect 😀!
Note: if you will also use
afterBuild
event to write some logic, be sure that your plugin is added before this plugin. Otherwise there may be inconsistencies in cached resources, if your plugin somehow changes them.
- It precaches URLs as absolute from root of site. It is very handy when Eleventy makes many directories for HTML files and you have only one place for each type of asset.
Word from author
Have fun! ✌️