@serwist/next 8.4.3 → 9.0.0-preview.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (67) hide show
  1. package/dist/index.d.ts +5 -4
  2. package/dist/index.d.ts.map +1 -0
  3. package/dist/index.js +51 -43
  4. package/dist/index.worker.d.ts +5 -0
  5. package/dist/index.worker.d.ts.map +1 -0
  6. package/dist/{index.browser.cjs → index.worker.js} +57 -22
  7. package/dist/internal-types.d.ts +6 -0
  8. package/dist/internal-types.d.ts.map +1 -0
  9. package/dist/sw-entry-worker.d.ts +1 -0
  10. package/dist/sw-entry-worker.d.ts.map +1 -0
  11. package/dist/sw-entry.d.ts +1 -0
  12. package/dist/sw-entry.d.ts.map +1 -0
  13. package/dist/utils/find-first-truthy.d.ts +1 -0
  14. package/dist/utils/find-first-truthy.d.ts.map +1 -0
  15. package/dist/utils/get-content-hash.d.ts +1 -0
  16. package/dist/utils/get-content-hash.d.ts.map +1 -0
  17. package/dist/utils/get-file-hash.d.ts +1 -0
  18. package/dist/utils/get-file-hash.d.ts.map +1 -0
  19. package/dist/utils/get-package-version.d.ts +1 -0
  20. package/dist/utils/get-package-version.d.ts.map +1 -0
  21. package/dist/utils/index.d.ts +1 -0
  22. package/dist/utils/index.d.ts.map +1 -0
  23. package/dist/utils/load-tsconfig.d.ts +1 -0
  24. package/dist/utils/load-tsconfig.d.ts.map +1 -0
  25. package/dist/utils/logger.d.ts +1 -0
  26. package/dist/utils/logger.d.ts.map +1 -0
  27. package/dist/utils.d.ts +1 -0
  28. package/dist/utils.d.ts.map +1 -0
  29. package/dist/worker/defaultCache.d.ts +3 -0
  30. package/dist/worker/defaultCache.d.ts.map +1 -0
  31. package/dist/worker/definePageRuntimeCaching.d.ts +16 -0
  32. package/dist/worker/definePageRuntimeCaching.d.ts.map +1 -0
  33. package/package.json +47 -49
  34. package/src/index.ts +241 -0
  35. package/src/index.worker.ts +5 -0
  36. package/src/internal-types.ts +17 -0
  37. package/src/sw-entry-worker.ts +46 -0
  38. package/src/sw-entry.ts +64 -0
  39. package/src/utils/find-first-truthy.ts +15 -0
  40. package/src/utils/get-content-hash.ts +10 -0
  41. package/src/utils/get-file-hash.ts +4 -0
  42. package/src/utils/get-package-version.ts +16 -0
  43. package/src/utils/load-tsconfig.ts +27 -0
  44. package/src/utils/logger.ts +57 -0
  45. package/src/utils.ts +11 -0
  46. package/src/worker/defaultCache.ts +223 -0
  47. package/src/worker/definePageRuntimeCaching.ts +36 -0
  48. package/dist/index.browser.d.cts +0 -2
  49. package/dist/index.browser.d.ts +0 -2
  50. package/dist/index.browser.js +0 -208
  51. package/dist/index.cjs +0 -933
  52. package/dist/index.d.cts +0 -5
  53. package/dist/internal-types.d.cts +0 -9
  54. package/dist/sw-entry-worker.cjs +0 -35
  55. package/dist/sw-entry-worker.d.cts +0 -7
  56. package/dist/sw-entry.cjs +0 -43
  57. package/dist/sw-entry.d.cts +0 -6
  58. package/dist/types.d.cts +0 -81
  59. package/dist/types.d.ts +0 -81
  60. package/dist/utils/find-first-truthy.d.cts +0 -7
  61. package/dist/utils/get-content-hash.d.cts +0 -3
  62. package/dist/utils/get-file-hash.d.cts +0 -3
  63. package/dist/utils/get-package-version.d.cts +0 -6
  64. package/dist/utils/load-tsconfig.d.cts +0 -2
  65. package/dist/utils/logger.d.cts +0 -5
  66. package/dist/utils.d.cts +0 -0
  67. /package/{dist/utils/index.d.cts → src/utils/index.ts} +0 -0
package/dist/index.d.cts DELETED
@@ -1,5 +0,0 @@
1
- import type { NextConfig } from "next";
2
- import type { PluginOptions } from "./types.js";
3
- declare const withPWAInit: (pluginOptions: PluginOptions) => (nextConfig?: NextConfig) => NextConfig;
4
- export default withPWAInit;
5
- export * from "./types.js";
@@ -1,9 +0,0 @@
1
- export type SerwistNextOptionsKey = "self.__SERWIST_SW_ENTRY";
2
- export interface SerwistNextOptions {
3
- sw: string;
4
- scope: string;
5
- cacheOnFrontEndNav: boolean;
6
- register: boolean;
7
- reloadOnOnline: boolean;
8
- swEntryWorker: string | undefined;
9
- }
@@ -1,35 +0,0 @@
1
- 'use strict';
2
-
3
- self.onmessage = async (ev)=>{
4
- switch(ev.data.type){
5
- case "__START_URL_CACHE__":
6
- {
7
- const url = ev.data.url;
8
- const response = await fetch(url);
9
- if (!response.redirected) {
10
- const startUrlCache = await caches.open("start-url");
11
- return startUrlCache.put(url, response);
12
- }
13
- return Promise.resolve();
14
- }
15
- case "__FRONTEND_NAV_CACHE__":
16
- {
17
- const url = ev.data.url;
18
- const pagesCache = await caches.open("pages");
19
- const isPageCached = !!await pagesCache.match(url, {
20
- ignoreSearch: true
21
- });
22
- if (isPageCached) {
23
- return;
24
- }
25
- const page = await fetch(url);
26
- if (!page.ok) {
27
- return;
28
- }
29
- pagesCache.put(url, page.clone());
30
- return Promise.resolve();
31
- }
32
- default:
33
- return Promise.resolve();
34
- }
35
- };
@@ -1,7 +0,0 @@
1
- export type MessageType = {
2
- type: "__FRONTEND_NAV_CACHE__";
3
- url: URL | string;
4
- } | {
5
- type: "__START_URL_CACHE__";
6
- url: URL | string;
7
- };
package/dist/sw-entry.cjs DELETED
@@ -1,43 +0,0 @@
1
- 'use strict';
2
-
3
- var window$1 = require('@serwist/window');
4
-
5
- if (typeof window !== "undefined" && "serviceWorker" in navigator && typeof caches !== "undefined") {
6
- let swEntryWorker;
7
- if (self.__SERWIST_SW_ENTRY.swEntryWorker) {
8
- swEntryWorker = new Worker(self.__SERWIST_SW_ENTRY.swEntryWorker);
9
- }
10
- window.serwist = new window$1.Serwist(window.location.origin + self.__SERWIST_SW_ENTRY.sw, {
11
- scope: self.__SERWIST_SW_ENTRY.scope
12
- });
13
- if (self.__SERWIST_SW_ENTRY.register) {
14
- window.serwist.register();
15
- }
16
- if (self.__SERWIST_SW_ENTRY.cacheOnFrontEndNav) {
17
- const cacheOnFrontEndNav = async (url)=>{
18
- if (!window.navigator.onLine || !url) {
19
- return;
20
- }
21
- swEntryWorker?.postMessage({
22
- type: "__FRONTEND_NAV_CACHE__",
23
- url
24
- });
25
- };
26
- const pushState = history.pushState;
27
- history.pushState = (...args)=>{
28
- pushState.apply(history, args);
29
- cacheOnFrontEndNav(args[2]);
30
- };
31
- const replaceState = history.replaceState;
32
- history.replaceState = (...args)=>{
33
- replaceState.apply(history, args);
34
- cacheOnFrontEndNav(args[2]);
35
- };
36
- window.addEventListener("online", ()=>{
37
- cacheOnFrontEndNav(window.location.pathname);
38
- });
39
- }
40
- if (self.__SERWIST_SW_ENTRY.reloadOnOnline) {
41
- window.addEventListener("online", ()=>location.reload());
42
- }
43
- }
@@ -1,6 +0,0 @@
1
- import { Serwist } from "@serwist/window";
2
- declare global {
3
- interface Window {
4
- serwist: Serwist;
5
- }
6
- }
package/dist/types.d.cts DELETED
@@ -1,81 +0,0 @@
1
- import type { WebpackInjectManifestOptions } from "@serwist/build";
2
- type Require<T, U extends keyof T> = T & Required<Pick<T, U>>;
3
- export interface PluginOptions extends Require<WebpackInjectManifestOptions, "swDest"> {
4
- /**
5
- * Enable additional route caching when users navigate through pages with
6
- * `next/link`. This improves the user experience in some cases but it
7
- * also adds a bit of overhead due to additional network calls.
8
- * @default false
9
- */
10
- cacheOnFrontEndNav?: boolean;
11
- /**
12
- * Whether Serwist should be disabled.
13
- * @default false
14
- */
15
- disable?: boolean;
16
- /**
17
- * Whether `@serwist/next` should automatically register the service worker for you. If
18
- * you want to register the service worker yourself, set this to `false` and run
19
- * `window.serwist.register()` in `componentDidMount` or `useEffect`.
20
- * @example
21
- * ```tsx
22
- * // app/register-pwa.tsx
23
- * "use client";
24
- * import { useEffect } from "react";
25
- * import type { Serwist } from "@serwist/window";
26
- *
27
- * declare global {
28
- * interface Window {
29
- * serwist: Serwist;
30
- * }
31
- * }
32
- *
33
- * export default function RegisterPWA() {
34
- * useEffect(() => {
35
- * if ("serviceWorker" in navigator && window.serwist !== undefined) {
36
- * window.serwist.register();
37
- * }
38
- * }, []);
39
- * return <></>;
40
- * }
41
- *
42
- * // app/layout.tsx
43
- * import RegisterPWA from "./register-pwa";
44
- *
45
- * export default function RootLayout({
46
- * children,
47
- * }: {
48
- * children: React.ReactNode;
49
- * }) {
50
- * return (
51
- * <html lang="en">
52
- * <head />
53
- * <body>
54
- * <RegisterPWA />
55
- * {children}
56
- * </body>
57
- * </html>
58
- * );
59
- * }
60
- * ```
61
- * @default true
62
- */
63
- register?: boolean;
64
- /**
65
- * Whether Serwist should reload the app when it goes online.
66
- * @default true
67
- */
68
- reloadOnOnline?: boolean;
69
- /**
70
- * The service worker's URL scope. Set to `/foo/` so that paths under `/foo/` are under the service
71
- * worker's control while others are not.
72
- * @default nextConfig.basePath
73
- */
74
- scope?: string;
75
- /**
76
- * The URL to the service worker.
77
- * @default "/sw.js"
78
- */
79
- swUrl?: string;
80
- }
81
- export {};
package/dist/types.d.ts DELETED
@@ -1,81 +0,0 @@
1
- import type { WebpackInjectManifestOptions } from "@serwist/build";
2
- type Require<T, U extends keyof T> = T & Required<Pick<T, U>>;
3
- export interface PluginOptions extends Require<WebpackInjectManifestOptions, "swDest"> {
4
- /**
5
- * Enable additional route caching when users navigate through pages with
6
- * `next/link`. This improves the user experience in some cases but it
7
- * also adds a bit of overhead due to additional network calls.
8
- * @default false
9
- */
10
- cacheOnFrontEndNav?: boolean;
11
- /**
12
- * Whether Serwist should be disabled.
13
- * @default false
14
- */
15
- disable?: boolean;
16
- /**
17
- * Whether `@serwist/next` should automatically register the service worker for you. If
18
- * you want to register the service worker yourself, set this to `false` and run
19
- * `window.serwist.register()` in `componentDidMount` or `useEffect`.
20
- * @example
21
- * ```tsx
22
- * // app/register-pwa.tsx
23
- * "use client";
24
- * import { useEffect } from "react";
25
- * import type { Serwist } from "@serwist/window";
26
- *
27
- * declare global {
28
- * interface Window {
29
- * serwist: Serwist;
30
- * }
31
- * }
32
- *
33
- * export default function RegisterPWA() {
34
- * useEffect(() => {
35
- * if ("serviceWorker" in navigator && window.serwist !== undefined) {
36
- * window.serwist.register();
37
- * }
38
- * }, []);
39
- * return <></>;
40
- * }
41
- *
42
- * // app/layout.tsx
43
- * import RegisterPWA from "./register-pwa";
44
- *
45
- * export default function RootLayout({
46
- * children,
47
- * }: {
48
- * children: React.ReactNode;
49
- * }) {
50
- * return (
51
- * <html lang="en">
52
- * <head />
53
- * <body>
54
- * <RegisterPWA />
55
- * {children}
56
- * </body>
57
- * </html>
58
- * );
59
- * }
60
- * ```
61
- * @default true
62
- */
63
- register?: boolean;
64
- /**
65
- * Whether Serwist should reload the app when it goes online.
66
- * @default true
67
- */
68
- reloadOnOnline?: boolean;
69
- /**
70
- * The service worker's URL scope. Set to `/foo/` so that paths under `/foo/` are under the service
71
- * worker's control while others are not.
72
- * @default nextConfig.basePath
73
- */
74
- scope?: string;
75
- /**
76
- * The URL to the service worker.
77
- * @default "/sw.js"
78
- */
79
- swUrl?: string;
80
- }
81
- export {};
@@ -1,7 +0,0 @@
1
- /**
2
- * Find the first truthy value in an array.
3
- * @param arr
4
- * @param fn
5
- * @returns
6
- */
7
- export declare const findFirstTruthy: <T, U>(arr: T[], fn: (elm: T) => U) => NonNullable<U> | undefined;
@@ -1,3 +0,0 @@
1
- /// <reference types="node" resolution-mode="require"/>
2
- import type fs from "node:fs";
3
- export declare const getContentHash: (file: fs.PathOrFileDescriptor, isDev: boolean) => string;
@@ -1,3 +0,0 @@
1
- /// <reference types="node" resolution-mode="require"/>
2
- import fs from "node:fs";
3
- export declare const getFileHash: (file: fs.PathOrFileDescriptor) => string;
@@ -1,6 +0,0 @@
1
- /**
2
- * Get a package's version
3
- * @param packageName
4
- * @returns
5
- */
6
- export declare const getPackageVersion: (packageName: string) => string | undefined;
@@ -1,2 +0,0 @@
1
- import type { TsConfigJson as TSConfigJSON } from "type-fest";
2
- export declare const loadTSConfig: (baseDir: string, relativeTSConfigPath: string | undefined) => TSConfigJSON | undefined;
@@ -1,5 +0,0 @@
1
- export declare const wait: (...message: any[]) => void;
2
- export declare const error: (...message: any[]) => void;
3
- export declare const warn: (...message: any[]) => void;
4
- export declare const info: (...message: any[]) => void;
5
- export declare const event: (...message: any[]) => void;
package/dist/utils.d.cts DELETED
File without changes
File without changes