48 lines
1.8 KiB
JavaScript
48 lines
1.8 KiB
JavaScript
/*
|
|
Copyright 2020 Google LLC
|
|
|
|
Use of this source code is governed by an MIT-style
|
|
license that can be found in the LICENSE file or at
|
|
https://opensource.org/licenses/MIT.
|
|
*/
|
|
import { getOrCreatePrecacheController } from './utils/getOrCreatePrecacheController.js';
|
|
import './_version.js';
|
|
/**
|
|
* `PrecacheFallbackPlugin` allows you to specify an "offline fallback"
|
|
* response to be used when a given strategy is unable to generate a response.
|
|
*
|
|
* It does this by intercepting the `handlerDidError` plugin callback
|
|
* and returning a precached response, taking the expected revision parameter
|
|
* into account automatically.
|
|
*
|
|
* Unless you explicitly pass in a `PrecacheController` instance to the
|
|
* constructor, the default instance will be used. Generally speaking, most
|
|
* developers will end up using the default.
|
|
*
|
|
* @memberof workbox-precaching
|
|
*/
|
|
class PrecacheFallbackPlugin {
|
|
/**
|
|
* Constructs a new PrecacheFallbackPlugin with the associated fallbackURL.
|
|
*
|
|
* @param {Object} config
|
|
* @param {string} config.fallbackURL A precached URL to use as the fallback
|
|
* if the associated strategy can't generate a response.
|
|
* @param {PrecacheController} [config.precacheController] An optional
|
|
* PrecacheController instance. If not provided, the default
|
|
* PrecacheController will be used.
|
|
*/
|
|
constructor({ fallbackURL, precacheController, }) {
|
|
/**
|
|
* @return {Promise<Response>} The precache response for the fallback URL.
|
|
*
|
|
* @private
|
|
*/
|
|
this.handlerDidError = () => this._precacheController.matchPrecache(this._fallbackURL);
|
|
this._fallbackURL = fallbackURL;
|
|
this._precacheController =
|
|
precacheController || getOrCreatePrecacheController();
|
|
}
|
|
}
|
|
export { PrecacheFallbackPlugin };
|