wxt 0.5.6 → 0.6.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.
package/dist/client.d.ts CHANGED
@@ -128,4 +128,4 @@ declare function defineBackground(definition: BackgroundScriptDefintition): Back
128
128
 
129
129
  declare function mountContentScriptUi(): void;
130
130
 
131
- export { defineBackground, defineContentScript, mountContentScriptUi };
131
+ export { ContentScriptContext, defineBackground, defineContentScript, mountContentScriptUi };
package/dist/client.js CHANGED
@@ -14,9 +14,144 @@ function defineBackground(arg) {
14
14
  function mountContentScriptUi() {
15
15
  throw Error("Not implemented: mountContentScriptUi");
16
16
  }
17
+
18
+ // src/client/browser.ts
19
+ import originalBrowser from "webextension-polyfill";
20
+ var browser = originalBrowser;
21
+
22
+ // src/client/utils/logger.ts
23
+ function print(method, ...args) {
24
+ if (import.meta.env.MODE === "production")
25
+ return;
26
+ if (typeof args[0] === "string") {
27
+ const message = args.shift();
28
+ method(`[wxt] ${message}`, ...args);
29
+ } else {
30
+ method("[wxt]", ...args);
31
+ }
32
+ }
33
+ var logger = {
34
+ debug: (...args) => print(console.debug, ...args),
35
+ log: (...args) => print(console.log, ...args),
36
+ warn: (...args) => print(console.warn, ...args),
37
+ error: (...args) => print(console.error, ...args)
38
+ };
39
+
40
+ // src/client/utils/ContentScriptContext.ts
41
+ var ContentScriptContext = class _ContentScriptContext extends AbortController {
42
+ constructor(contentScriptName) {
43
+ super();
44
+ this.contentScriptName = contentScriptName;
45
+ if (this.#isTopFrame) {
46
+ this.#stopOldScripts();
47
+ }
48
+ this.setTimeout(() => {
49
+ this.#listenForNewerScripts();
50
+ });
51
+ }
52
+ static SCRIPT_STARTED_MESSAGE_TYPE = "wxt:content-script-started";
53
+ #isTopFrame = window.self === window.top;
54
+ get isInvalid() {
55
+ if (browser.runtime.id == null) {
56
+ this.notifyInvalidated();
57
+ }
58
+ return this.signal.aborted;
59
+ }
60
+ get isValid() {
61
+ return !this.isInvalid;
62
+ }
63
+ /**
64
+ * Add a listener that is called when the content script's context is invalidated.
65
+ *
66
+ * @returns A function to remove the listener.
67
+ *
68
+ * @example
69
+ * browser.runtime.onMessage.addListener(cb);
70
+ * const removeInvalidatedListener = ctx.onInvalidated(() => {
71
+ * browser.runtime.onMessage.removeListener(cb);
72
+ * })
73
+ * // ...
74
+ * removeInvalidatedListener();
75
+ */
76
+ onInvalidated(cb) {
77
+ this.signal.addEventListener("abort", cb);
78
+ return () => this.signal.removeEventListener("abort", cb);
79
+ }
80
+ /**
81
+ * Wrapper around `window.setInterval` that automatically clears the interval when invalidated.
82
+ */
83
+ setInterval(handler, timeout) {
84
+ const id = setInterval(() => {
85
+ if (this.isValid)
86
+ handler();
87
+ }, timeout);
88
+ this.onInvalidated(() => clearInterval(id));
89
+ return id;
90
+ }
91
+ /**
92
+ * Wrapper around `window.setTimeout` that automatically clears the interval when invalidated.
93
+ */
94
+ setTimeout(handler, timeout) {
95
+ const id = setTimeout(() => {
96
+ if (this.isValid)
97
+ handler();
98
+ }, timeout);
99
+ this.onInvalidated(() => clearTimeout(id));
100
+ return id;
101
+ }
102
+ /**
103
+ * Wrapper around `window.requestAnimationFrame` that automatically cancels the request when
104
+ * invalidated.
105
+ */
106
+ requestAnimationFrame(callback) {
107
+ const id = requestAnimationFrame((...args) => {
108
+ if (this.isValid)
109
+ callback(...args);
110
+ });
111
+ this.onInvalidated(() => cancelAnimationFrame(id));
112
+ return id;
113
+ }
114
+ /**
115
+ * Wrapper around `window.requestIdleCallback` that automatically cancels the request when
116
+ * invalidated.
117
+ */
118
+ requestIdleCallback(callback, options) {
119
+ const id = requestIdleCallback((...args) => {
120
+ if (!this.signal.aborted)
121
+ callback(...args);
122
+ }, options);
123
+ this.onInvalidated(() => cancelIdleCallback(id));
124
+ return id;
125
+ }
126
+ /**
127
+ * Abort the abort controller and execute all `onInvalidated` listeners.
128
+ */
129
+ notifyInvalidated() {
130
+ this.abort("Content script context invalidated");
131
+ logger.debug(
132
+ `Content script "${this.contentScriptName}" context invalidated`
133
+ );
134
+ }
135
+ #stopOldScripts() {
136
+ window.postMessage({
137
+ event: _ContentScriptContext.SCRIPT_STARTED_MESSAGE_TYPE,
138
+ contentScriptName: this.contentScriptName
139
+ });
140
+ }
141
+ #listenForNewerScripts() {
142
+ const cb = (event) => {
143
+ if (event.data?.type === _ContentScriptContext.SCRIPT_STARTED_MESSAGE_TYPE && event.data?.contentScriptName === this.contentScriptName) {
144
+ this.notifyInvalidated();
145
+ }
146
+ };
147
+ addEventListener("message", cb);
148
+ this.onInvalidated(() => removeEventListener("message", cb));
149
+ }
150
+ };
17
151
  export {
152
+ ContentScriptContext,
18
153
  defineBackground,
19
154
  defineContentScript,
20
155
  mountContentScriptUi
21
156
  };
22
- //# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vc3JjL2NsaWVudC9kZWZpbmVDb250ZW50U2NyaXB0LnRzIiwgIi4uL3NyYy9jbGllbnQvZGVmaW5lQmFja2dyb3VuZC50cyIsICIuLi9zcmMvY2xpZW50L21vdW50Q29udGVudFNjcmlwdFVpLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyJpbXBvcnQgeyBDb250ZW50U2NyaXB0RGVmaW5pdGlvbiB9IGZyb20gJy4uL2NvcmUvdHlwZXMnO1xuXG5leHBvcnQgZnVuY3Rpb24gZGVmaW5lQ29udGVudFNjcmlwdChcbiAgZGVmaW5pdGlvbjogQ29udGVudFNjcmlwdERlZmluaXRpb24sXG4pOiBDb250ZW50U2NyaXB0RGVmaW5pdGlvbiB7XG4gIHJldHVybiBkZWZpbml0aW9uO1xufVxuIiwgImltcG9ydCB7IEJhY2tncm91bmRTY3JpcHREZWZpbnRpdGlvbiB9IGZyb20gJy4uJztcblxuZXhwb3J0IGZ1bmN0aW9uIGRlZmluZUJhY2tncm91bmQobWFpbjogKCkgPT4gdm9pZCk6IEJhY2tncm91bmRTY3JpcHREZWZpbnRpdGlvbjtcbmV4cG9ydCBmdW5jdGlvbiBkZWZpbmVCYWNrZ3JvdW5kKFxuICBkZWZpbml0aW9uOiBCYWNrZ3JvdW5kU2NyaXB0RGVmaW50aXRpb24sXG4pOiBCYWNrZ3JvdW5kU2NyaXB0RGVmaW50aXRpb247XG5leHBvcnQgZnVuY3Rpb24gZGVmaW5lQmFja2dyb3VuZChcbiAgYXJnOiAoKCkgPT4gdm9pZCkgfCBCYWNrZ3JvdW5kU2NyaXB0RGVmaW50aXRpb24sXG4pOiBCYWNrZ3JvdW5kU2NyaXB0RGVmaW50aXRpb24ge1xuICBpZiAodHlwZW9mIGFyZyA9PT0gJ2Z1bmN0aW9uJykgcmV0dXJuIHsgbWFpbjogYXJnIH07XG4gIHJldHVybiBhcmc7XG59XG4iLCAiZXhwb3J0IGZ1bmN0aW9uIG1vdW50Q29udGVudFNjcmlwdFVpKCkge1xuICB0aHJvdyBFcnJvcignTm90IGltcGxlbWVudGVkOiBtb3VudENvbnRlbnRTY3JpcHRVaScpO1xufVxuIl0sCiAgIm1hcHBpbmdzIjogIjtBQUVPLFNBQVMsb0JBQ2QsWUFDeUI7QUFDekIsU0FBTztBQUNUOzs7QUNBTyxTQUFTLGlCQUNkLEtBQzZCO0FBQzdCLE1BQUksT0FBTyxRQUFRO0FBQVksV0FBTyxFQUFFLE1BQU0sSUFBSTtBQUNsRCxTQUFPO0FBQ1Q7OztBQ1hPLFNBQVMsdUJBQXVCO0FBQ3JDLFFBQU0sTUFBTSx1Q0FBdUM7QUFDckQ7IiwKICAibmFtZXMiOiBbXQp9Cg==
157
+ //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/client/defineContentScript.ts", "../src/client/defineBackground.ts", "../src/client/mountContentScriptUi.ts", "../src/client/browser.ts", "../src/client/utils/logger.ts", "../src/client/utils/ContentScriptContext.ts"],
  "sourcesContent": ["import { ContentScriptDefinition } from '../core/types';\n\nexport function defineContentScript(\n  definition: ContentScriptDefinition,\n): ContentScriptDefinition {\n  return definition;\n}\n", "import { BackgroundScriptDefintition } from '..';\n\nexport function defineBackground(main: () => void): BackgroundScriptDefintition;\nexport function defineBackground(\n  definition: BackgroundScriptDefintition,\n): BackgroundScriptDefintition;\nexport function defineBackground(\n  arg: (() => void) | BackgroundScriptDefintition,\n): BackgroundScriptDefintition {\n  if (typeof arg === 'function') return { main: arg };\n  return arg;\n}\n", "export function mountContentScriptUi() {\n  throw Error('Not implemented: mountContentScriptUi');\n}\n", "import originalBrowser, { Browser, Runtime, I18n } from 'webextension-polyfill';\n\nexport interface AugmentedBrowser extends Browser {\n  runtime: WxtRuntime;\n  i18n: WxtI18n;\n}\n\nexport interface WxtRuntime extends Runtime.Static {\n  // Overriden per-project\n}\n\nexport interface WxtI18n extends I18n.Static {\n  // Overriden per-project\n}\n\nexport const browser: AugmentedBrowser = originalBrowser;\n", "function print(method: (...args: any[]) => void, ...args: any[]) {\n  if (import.meta.env.MODE === 'production') return;\n\n  if (typeof args[0] === 'string') {\n    const message = args.shift();\n    method(`[wxt] ${message}`, ...args);\n  } else {\n    method('[wxt]', ...args);\n  }\n}\n\n/**\n * Wrapper around `console` with a \"[wxt]\" prefix\n */\nexport const logger = {\n  debug: (...args: any[]) => print(console.debug, ...args),\n  log: (...args: any[]) => print(console.log, ...args),\n  warn: (...args: any[]) => print(console.warn, ...args),\n  error: (...args: any[]) => print(console.error, ...args),\n};\n", "import { browser } from '../browser';\nimport { logger } from './logger';\n\n/**\n * Extends [`AbortController`](https://developer.mozilla.org/en-US/docs/Web/API/AbortController).\n * Used to detect and stop content script code when the script is invalidated.\n *\n * It also provides several utilities like `ctx.setTimeout` and `ctx.setInterval` that should be used in\n * content scripts instead of `window.setTimeout` or `window.setInterval`.\n */\nexport class ContentScriptContext extends AbortController {\n  static SCRIPT_STARTED_MESSAGE_TYPE = 'wxt:content-script-started';\n\n  #isTopFrame = window.self === window.top;\n\n  constructor(private readonly contentScriptName: string) {\n    super();\n\n    if (this.#isTopFrame) {\n      this.#stopOldScripts();\n    }\n    this.setTimeout(() => {\n      // Run on next tick so the listener it adds isn't triggered by stopOldScript\n      this.#listenForNewerScripts();\n    });\n  }\n\n  get isInvalid(): boolean {\n    if (browser.runtime.id == null) {\n      this.notifyInvalidated(); // Sets `signal.aborted` to true\n    }\n    return this.signal.aborted;\n  }\n\n  get isValid(): boolean {\n    return !this.isInvalid;\n  }\n\n  /**\n   * Add a listener that is called when the content script's context is invalidated.\n   *\n   * @returns A function to remove the listener.\n   *\n   * @example\n   * browser.runtime.onMessage.addListener(cb);\n   * const removeInvalidatedListener = ctx.onInvalidated(() => {\n   *   browser.runtime.onMessage.removeListener(cb);\n   * })\n   * // ...\n   * removeInvalidatedListener();\n   */\n  onInvalidated(cb: () => void): () => void {\n    this.signal.addEventListener('abort', cb);\n    return () => this.signal.removeEventListener('abort', cb);\n  }\n\n  /**\n   * Wrapper around `window.setInterval` that automatically clears the interval when invalidated.\n   */\n  setInterval(handler: () => void, timeout?: number): number {\n    const id = setInterval(() => {\n      if (this.isValid) handler();\n    }, timeout) as unknown as number;\n    this.onInvalidated(() => clearInterval(id));\n    return id;\n  }\n\n  /**\n   * Wrapper around `window.setTimeout` that automatically clears the interval when invalidated.\n   */\n  setTimeout(handler: () => void, timeout?: number): number {\n    const id = setTimeout(() => {\n      if (this.isValid) handler();\n    }, timeout) as unknown as number;\n    this.onInvalidated(() => clearTimeout(id));\n    return id;\n  }\n\n  /**\n   * Wrapper around `window.requestAnimationFrame` that automatically cancels the request when\n   * invalidated.\n   */\n  requestAnimationFrame(callback: FrameRequestCallback): number {\n    const id = requestAnimationFrame((...args) => {\n      if (this.isValid) callback(...args);\n    });\n\n    this.onInvalidated(() => cancelAnimationFrame(id));\n    return id;\n  }\n\n  /**\n   * Wrapper around `window.requestIdleCallback` that automatically cancels the request when\n   * invalidated.\n   */\n  requestIdleCallback(\n    callback: IdleRequestCallback,\n    options?: IdleRequestOptions,\n  ): number {\n    const id = requestIdleCallback((...args) => {\n      if (!this.signal.aborted) callback(...args);\n    }, options);\n\n    this.onInvalidated(() => cancelIdleCallback(id));\n    return id;\n  }\n\n  /**\n   * Abort the abort controller and execute all `onInvalidated` listeners.\n   */\n  notifyInvalidated() {\n    this.abort('Content script context invalidated');\n    logger.debug(\n      `Content script \"${this.contentScriptName}\" context invalidated`,\n    );\n  }\n\n  #stopOldScripts() {\n    // Use postMessage so it get's sent to all the frames of the page.\n    window.postMessage({\n      event: ContentScriptContext.SCRIPT_STARTED_MESSAGE_TYPE,\n      contentScriptName: this.contentScriptName,\n    });\n  }\n\n  #listenForNewerScripts() {\n    const cb = (event: MessageEvent) => {\n      if (\n        event.data?.type === ContentScriptContext.SCRIPT_STARTED_MESSAGE_TYPE &&\n        event.data?.contentScriptName === this.contentScriptName\n      ) {\n        this.notifyInvalidated();\n      }\n    };\n\n    addEventListener('message', cb);\n    this.onInvalidated(() => removeEventListener('message', cb));\n  }\n}\n"],
  "mappings": "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",
  "names": []
}

package/dist/index.cjs CHANGED
@@ -547,6 +547,7 @@ async function getInternalConfig(inlineConfig, command) {
547
547
  command,
548
548
  debug,
549
549
  entrypointsDir,
550
+ env,
550
551
  fsCache: createFsCache(wxtDir),
551
552
  imports: mergedConfig.imports ?? {},
552
553
  logger,
@@ -560,16 +561,12 @@ async function getInternalConfig(inlineConfig, command) {
560
561
  runnerConfig,
561
562
  srcDir,
562
563
  typesDir,
563
- vite: {},
564
+ vite: () => ({}),
564
565
  // Real value added after this object is initialized.
565
566
  wxtDir,
566
567
  zip: resolveInternalZipConfig(root, mergedConfig)
567
568
  };
568
- finalConfig.vite = await resolveInternalViteConfig(
569
- env,
570
- mergedConfig,
571
- finalConfig
572
- );
569
+ finalConfig.vite = (env2) => resolveInternalViteConfig(env2, mergedConfig, finalConfig);
573
570
  return finalConfig;
574
571
  }
575
572
  async function resolveManifestConfig(env, manifest) {
@@ -593,9 +590,9 @@ function mergeInlineConfig(inlineConfig, userConfig) {
593
590
  return vite2.mergeConfig(user, inline);
594
591
  };
595
592
  const viteConfig = async (env) => {
596
- const user = await resolveViteConfig(env, userConfig.vite);
597
- const inline = await resolveViteConfig(env, inlineConfig.vite);
598
- return vite2.mergeConfig(user, inline);
593
+ const user = await userConfig.vite?.(env);
594
+ const inline = await inlineConfig.vite?.(env);
595
+ return vite2.mergeConfig(user ?? {}, inline ?? {});
599
596
  };
600
597
  const runner = vite2.mergeConfig(
601
598
  userConfig.runner ?? {},
@@ -623,9 +620,6 @@ function mergeInlineConfig(inlineConfig, userConfig) {
623
620
  zip
624
621
  };
625
622
  }
626
- async function resolveViteConfig(env, vite6) {
627
- return await (typeof vite6 === "function" ? vite6(env) : vite6 ?? {});
628
- }
629
623
  function resolveInternalZipConfig(root, mergedConfig) {
630
624
  return {
631
625
  sourcesTemplate: "{{name}}-{{version}}-sources.zip",
@@ -647,13 +641,11 @@ function resolveInternalZipConfig(root, mergedConfig) {
647
641
  };
648
642
  }
649
643
  async function resolveInternalViteConfig(env, mergedConfig, finalConfig) {
650
- const internalVite = await resolveViteConfig(
651
- env,
652
- mergedConfig.vite
653
- );
644
+ const internalVite = await mergedConfig.vite?.(env) ?? {};
654
645
  internalVite.root = finalConfig.root;
655
646
  internalVite.configFile = false;
656
647
  internalVite.logLevel = "warn";
648
+ internalVite.mode = env.mode;
657
649
  internalVite.build ??= {};
658
650
  internalVite.build.outDir = finalConfig.outDir;
659
651
  internalVite.build.emptyOutDir = false;
@@ -865,7 +857,7 @@ async function buildSingleEntrypoint(entrypoint, config) {
865
857
  }
866
858
  const entryConfig = vite3.mergeConfig(
867
859
  libMode,
868
- config.vite
860
+ await config.vite(config.env)
869
861
  );
870
862
  const result = await vite3.build(entryConfig);
871
863
  return {
@@ -899,7 +891,7 @@ async function buildMultipleEntrypoints(entrypoints, config) {
899
891
  }
900
892
  const entryConfig = vite3.mergeConfig(
901
893
  multiPage,
902
- config.vite
894
+ await config.vite(config.env)
903
895
  );
904
896
  const result = await vite3.build(entryConfig);
905
897
  return {
@@ -2202,7 +2194,7 @@ async function getServerInfo() {
2202
2194
  async function setupServer(serverInfo, config) {
2203
2195
  const runner = createWebExtRunner();
2204
2196
  const viteServer = await vite5.createServer(
2205
- vite5.mergeConfig(serverInfo, config.vite)
2197
+ vite5.mergeConfig(serverInfo, await config.vite(config.env))
2206
2198
  );
2207
2199
  const start = async () => {
2208
2200
  await viteServer.listen(server.port);
@@ -2303,7 +2295,7 @@ async function clean(root = process.cwd()) {
2303
2295
  }
2304
2296
 
2305
2297
  // package.json
2306
- var version2 = "0.5.6";
2298
+ var version2 = "0.6.0";
2307
2299
 
2308
2300
  // src/core/utils/defineConfig.ts
2309
2301
  function defineConfig(config) {
@@ -2326,7 +2318,7 @@ async function createServer2(config) {
2326
2318
  return getInternalConfig(
2327
2319
  {
2328
2320
  ...config,
2329
- vite: serverInfo.viteServerConfig
2321
+ vite: () => serverInfo.viteServerConfig
2330
2322
  },
2331
2323
  "serve"
2332
2324
  );