From c24e17530ae759de1541f9f96c765a82ab17ed41 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Ng=C3=B4=20=C4=90=E1=BB=A9c=20Anh?= <75556609+DuCanhGH@users.noreply.github.com> Date: Tue, 19 Sep 2023 19:09:30 +0700 Subject: [PATCH] feat: added `watchWorkersInDev`, added `.webm` to `defaultCache`'s `static-video-assets` (#90) [bump] --- .changeset/soft-schools-battle.md | 7 + .changeset/weak-tables-roll.md | 7 + .github/ISSUE_TEMPLATE/2-feature-request.yaml | 2 + docs/content/next-pwa/configuring.mdx | 2 + examples/custom-worker/shared/utils/index.ts | 4 +- examples/custom-worker/worker/index.ts | 4 +- packages/next-pwa/src/cache.ts | 2 +- packages/next-pwa/src/index.ts | 2 + .../next-pwa/src/resolve-workbox-plugin.ts | 12 +- packages/next-pwa/src/types.ts | 268 +++++++++--------- .../webpack-builders/build-custom-worker.ts | 30 +- .../webpack-builders/build-fallback-worker.ts | 13 +- .../webpack-builders/build-sw-entry-worker.ts | 11 +- .../next-pwa/src/webpack-builders/context.ts | 19 +- .../next-pwa/src/webpack-builders/utils.ts | 10 +- 15 files changed, 225 insertions(+), 168 deletions(-) create mode 100644 .changeset/soft-schools-battle.md create mode 100644 .changeset/weak-tables-roll.md diff --git a/.changeset/soft-schools-battle.md b/.changeset/soft-schools-battle.md new file mode 100644 index 00000000..52e6ae76 --- /dev/null +++ b/.changeset/soft-schools-battle.md @@ -0,0 +1,7 @@ +--- +"@ducanh2912/next-pwa": minor +--- + +feat: added `watchWorkersInDev` + +- Note that this feature is disabled by default, and can be enabled by setting `PluginOptions.watchWorkersInDev` to `true`. After a change is detected and `webpack` rebuilds the custom worker, you have to reload the page for it to take effect. diff --git a/.changeset/weak-tables-roll.md b/.changeset/weak-tables-roll.md new file mode 100644 index 00000000..883c5b29 --- /dev/null +++ b/.changeset/weak-tables-roll.md @@ -0,0 +1,7 @@ +--- +"@ducanh2912/next-pwa": minor +--- + +feat: added `.webm` to `defaultCache`'s `static-video-assets` + +- I think it'd be nice to support this extension as well, and this shouldn't cause a breaking change (if there is another entry that matches `.webm` files in `workboxOptions.runtimeCaching` and `extendDefaultRuntimeCaching`, then Workbox will still pick that entry). diff --git a/.github/ISSUE_TEMPLATE/2-feature-request.yaml b/.github/ISSUE_TEMPLATE/2-feature-request.yaml index e6896611..1161683c 100644 --- a/.github/ISSUE_TEMPLATE/2-feature-request.yaml +++ b/.github/ISSUE_TEMPLATE/2-feature-request.yaml @@ -2,6 +2,8 @@ name: Feature request description: Create a feature request title: "[Feature request]: " labels: ["feature-request", "triage"] +assignees: + - DuCanhGH body: - type: markdown attributes: diff --git a/docs/content/next-pwa/configuring.mdx b/docs/content/next-pwa/configuring.mdx index 72bf5696..bae523d6 100644 --- a/docs/content/next-pwa/configuring.mdx +++ b/docs/content/next-pwa/configuring.mdx @@ -95,6 +95,8 @@ export default withPWA({ - `reloadOnOnline` — Reload the app when it has gone back online. +- `watchWorkersInDev` — Watch certain workers for file changes in development mode. This currently includes the custom worker. + ## Other options `next-pwa` uses `workbox-webpack-plugin` under the hood, other options can be found in the documentation for [GenerateSW](https://developer.chrome.com/docs/workbox/modules/workbox-webpack-plugin/#generatesw-plugin) and diff --git a/examples/custom-worker/shared/utils/index.ts b/examples/custom-worker/shared/utils/index.ts index 3c0c1ef9..031cf0f6 100644 --- a/examples/custom-worker/shared/utils/index.ts +++ b/examples/custom-worker/shared/utils/index.ts @@ -1,5 +1,5 @@ -export function util(message: string) { - console.log("Hello from util."); +export function utils(message: string) { + console.log("Hello from utils."); console.log("es6+ syntax test:"); // eslint-disable-next-line prefer-const let foo = { message: message }; diff --git a/examples/custom-worker/worker/index.ts b/examples/custom-worker/worker/index.ts index eb91ac41..49d87dc4 100644 --- a/examples/custom-worker/worker/index.ts +++ b/examples/custom-worker/worker/index.ts @@ -1,5 +1,5 @@ import { message } from "@shared/constants.ts"; -import { util } from "@shared/utils/index.ts"; +import { utils } from "@shared/utils/index.ts"; declare const self: ServiceWorkerGlobalScope; @@ -8,7 +8,7 @@ declare const self: ServiceWorkerGlobalScope; // // self.__WB_DISABLE_DEV_LOGS = true -util(message); +utils(message); // listen to message event from window self.addEventListener("message", (event) => { diff --git a/packages/next-pwa/src/cache.ts b/packages/next-pwa/src/cache.ts index a5fe24eb..a4af8a99 100644 --- a/packages/next-pwa/src/cache.ts +++ b/packages/next-pwa/src/cache.ts @@ -81,7 +81,7 @@ const defaultCache: RuntimeCaching[] = [ }, }, { - urlPattern: /\.(?:mp4)$/i, + urlPattern: /\.(?:mp4|webm)$/i, handler: "CacheFirst", options: { rangeRequests: true, diff --git a/packages/next-pwa/src/index.ts b/packages/next-pwa/src/index.ts index 3f96c285..d2a9795d 100644 --- a/packages/next-pwa/src/index.ts +++ b/packages/next-pwa/src/index.ts @@ -87,6 +87,7 @@ const withPWAInit = ( extendDefaultRuntimeCaching = false, swcMinify = nextConfig.swcMinify ?? nextDefConfig?.swcMinify ?? false, browserslist = "chrome >= 56", + watchWorkersInDev = false, } = pluginOptions; if (typeof nextConfig.webpack === "function") { @@ -150,6 +151,7 @@ const withPWAInit = ( setDefaultContext("shouldMinify", !dev); setDefaultContext("useSwcMinify", swcMinify); setDefaultContext("browserslist", browserslist); + setDefaultContext("devWatchWorkers", watchWorkersInDev); const _dest = path.join(options.dir, dest); const _cwdest = path.join(options.dir, customWorkerDest); diff --git a/packages/next-pwa/src/resolve-workbox-plugin.ts b/packages/next-pwa/src/resolve-workbox-plugin.ts index a749e606..eea55f74 100644 --- a/packages/next-pwa/src/resolve-workbox-plugin.ts +++ b/packages/next-pwa/src/resolve-workbox-plugin.ts @@ -9,7 +9,7 @@ import { resolveRuntimeCaching } from "./resolve-runtime-caching.js"; import type { WorkboxCommon } from "./resolve-workbox-common.js"; import type { PluginOptions } from "./types.js"; import { isInjectManifestConfig, overrideAfterCalledMethod } from "./utils.js"; -import { NextPWAContext } from "./webpack-builders/context.js"; +import { nextPWAContext } from "./webpack-builders/context.js"; type PluginCompleteOptions = Required< Pick @@ -40,17 +40,17 @@ export const resolveWorkboxPlugin = ({ hasFallbacks: boolean; } & PluginCompleteOptions) => { if (!workboxOptions.babelPresetEnvTargets) { - switch (typeof NextPWAContext.browserslist) { + switch (typeof nextPWAContext.browserslist) { case "string": - workboxOptions.babelPresetEnvTargets = [NextPWAContext.browserslist]; + workboxOptions.babelPresetEnvTargets = [nextPWAContext.browserslist]; break; case "object": { - if (Array.isArray(NextPWAContext.browserslist)) { - workboxOptions.babelPresetEnvTargets = NextPWAContext.browserslist; + if (Array.isArray(nextPWAContext.browserslist)) { + workboxOptions.babelPresetEnvTargets = nextPWAContext.browserslist; } else { workboxOptions.babelPresetEnvTargets = []; for (const [browser, minimumVersion] of Object.entries( - NextPWAContext.browserslist + nextPWAContext.browserslist )) { workboxOptions.babelPresetEnvTargets.push( `${browser} >= ${minimumVersion}` diff --git a/packages/next-pwa/src/types.ts b/packages/next-pwa/src/types.ts index e8c8c055..c12e07c3 100644 --- a/packages/next-pwa/src/types.ts +++ b/packages/next-pwa/src/types.ts @@ -4,59 +4,66 @@ import type { BrowserslistOptions, WorkboxTypes } from "./private-types.js"; export interface PluginOptions { /** - * Whether `next-pwa` should be disabled. + * Cache every `` and `