12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758 |
- import { Route } from './Route.js';
- import { Handler } from './_types.js';
- import './_version.js';
- export interface NavigationRouteMatchOptions {
- allowlist?: RegExp[];
- denylist?: RegExp[];
- }
- /**
- * NavigationRoute makes it easy to create a
- * [Route]{@link module:workbox-routing.Route} that matches for browser
- * [navigation requests]{@link https://developers.google.com/web/fundamentals/primers/service-workers/high-performance-loading#first_what_are_navigation_requests}.
- *
- * It will only match incoming Requests whose
- * [`mode`]{@link https://fetch.spec.whatwg.org/#concept-request-mode}
- * is set to `navigate`.
- *
- * You can optionally only apply this route to a subset of navigation requests
- * by using one or both of the `denylist` and `allowlist` parameters.
- *
- * @memberof module:workbox-routing
- * @extends module:workbox-routing.Route
- */
- declare class NavigationRoute extends Route {
- private readonly _allowlist;
- private readonly _denylist;
- /**
- * If both `denylist` and `allowlist` are provided, the `denylist` will
- * take precedence and the request will not match this route.
- *
- * The regular expressions in `allowlist` and `denylist`
- * are matched against the concatenated
- * [`pathname`]{@link https://developer.mozilla.org/en-US/docs/Web/API/HTMLHyperlinkElementUtils/pathname}
- * and [`search`]{@link https://developer.mozilla.org/en-US/docs/Web/API/HTMLHyperlinkElementUtils/search}
- * portions of the requested URL.
- *
- * @param {module:workbox-routing~handlerCallback} handler A callback
- * function that returns a Promise resulting in a Response.
- * @param {Object} options
- * @param {Array<RegExp>} [options.denylist] If any of these patterns match,
- * the route will not handle the request (even if a allowlist RegExp matches).
- * @param {Array<RegExp>} [options.allowlist=[/./]] If any of these patterns
- * match the URL's pathname and search parameter, the route will handle the
- * request (assuming the denylist doesn't match).
- */
- constructor(handler: Handler, { allowlist, denylist }?: NavigationRouteMatchOptions);
- /**
- * Routes match handler.
- *
- * @param {Object} options
- * @param {URL} options.url
- * @param {Request} options.request
- * @return {boolean}
- *
- * @private
- */
- private _match;
- }
- export { NavigationRoute };
|