wxt 0.5.6 → 0.6.0-alpha1
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/cli.cjs +13 -22
- package/dist/client.d.ts +1 -1
- package/dist/client.js +134 -1
- package/dist/index.cjs +12 -21
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +6 -4
- package/dist/index.d.ts +6 -4
- package/dist/index.js +12 -21
- package/dist/index.js.map +1 -1
- package/package.json +1 -1
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,142 @@ 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 (typeof args[0] === "string") {
|
|
25
|
+
const message = args.shift();
|
|
26
|
+
method(`[wxt] ${message}`, ...args);
|
|
27
|
+
} else {
|
|
28
|
+
method("[wxt]", ...args);
|
|
29
|
+
}
|
|
30
|
+
}
|
|
31
|
+
var logger = {
|
|
32
|
+
debug: (...args) => print(console.debug, ...args),
|
|
33
|
+
log: (...args) => print(console.log, ...args),
|
|
34
|
+
warn: (...args) => print(console.warn, ...args),
|
|
35
|
+
error: (...args) => print(console.error, ...args)
|
|
36
|
+
};
|
|
37
|
+
|
|
38
|
+
// src/client/utils/ContentScriptContext.ts
|
|
39
|
+
var ContentScriptContext = class _ContentScriptContext extends AbortController {
|
|
40
|
+
constructor(contentScriptName) {
|
|
41
|
+
super();
|
|
42
|
+
this.contentScriptName = contentScriptName;
|
|
43
|
+
if (this.#isTopFrame) {
|
|
44
|
+
this.#stopOldScripts();
|
|
45
|
+
}
|
|
46
|
+
this.setTimeout(() => {
|
|
47
|
+
this.#listenForNewerScripts();
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
static SCRIPT_STARTED_MESSAGE_TYPE = "wxt:content-script-started";
|
|
51
|
+
#isTopFrame = window.self === window.top;
|
|
52
|
+
get isInvalid() {
|
|
53
|
+
if (browser.runtime.id == null) {
|
|
54
|
+
this.notifyInvalidated();
|
|
55
|
+
}
|
|
56
|
+
return this.signal.aborted;
|
|
57
|
+
}
|
|
58
|
+
get isValid() {
|
|
59
|
+
return !this.isInvalid;
|
|
60
|
+
}
|
|
61
|
+
/**
|
|
62
|
+
* Add a listener that is called when the content script's context is invalidated.
|
|
63
|
+
*
|
|
64
|
+
* @returns A function to remove the listener.
|
|
65
|
+
*
|
|
66
|
+
* @example
|
|
67
|
+
* browser.runtime.onMessage.addListener(cb);
|
|
68
|
+
* const removeInvalidatedListener = ctx.onInvalidated(() => {
|
|
69
|
+
* browser.runtime.onMessage.removeListener(cb);
|
|
70
|
+
* })
|
|
71
|
+
* // ...
|
|
72
|
+
* removeInvalidatedListener();
|
|
73
|
+
*/
|
|
74
|
+
onInvalidated(cb) {
|
|
75
|
+
this.signal.addEventListener("abort", cb);
|
|
76
|
+
return () => this.signal.removeEventListener("abort", cb);
|
|
77
|
+
}
|
|
78
|
+
/**
|
|
79
|
+
* Wrapper around `window.setInterval` that automatically clears the interval when invalidated.
|
|
80
|
+
*/
|
|
81
|
+
setInterval(handler, timeout) {
|
|
82
|
+
const id = setInterval(() => {
|
|
83
|
+
if (this.isValid)
|
|
84
|
+
handler();
|
|
85
|
+
}, timeout);
|
|
86
|
+
this.onInvalidated(() => clearInterval(id));
|
|
87
|
+
return id;
|
|
88
|
+
}
|
|
89
|
+
/**
|
|
90
|
+
* Wrapper around `window.setTimeout` that automatically clears the interval when invalidated.
|
|
91
|
+
*/
|
|
92
|
+
setTimeout(handler, timeout) {
|
|
93
|
+
const id = setTimeout(() => {
|
|
94
|
+
if (this.isValid)
|
|
95
|
+
handler();
|
|
96
|
+
}, timeout);
|
|
97
|
+
this.onInvalidated(() => clearTimeout(id));
|
|
98
|
+
return id;
|
|
99
|
+
}
|
|
100
|
+
/**
|
|
101
|
+
* Wrapper around `window.requestAnimationFrame` that automatically cancels the request when
|
|
102
|
+
* invalidated.
|
|
103
|
+
*/
|
|
104
|
+
requestAnimationFrame(callback) {
|
|
105
|
+
const id = requestAnimationFrame((...args) => {
|
|
106
|
+
if (this.isValid)
|
|
107
|
+
callback(...args);
|
|
108
|
+
});
|
|
109
|
+
this.onInvalidated(() => cancelAnimationFrame(id));
|
|
110
|
+
return id;
|
|
111
|
+
}
|
|
112
|
+
/**
|
|
113
|
+
* Wrapper around `window.requestIdleCallback` that automatically cancels the request when
|
|
114
|
+
* invalidated.
|
|
115
|
+
*/
|
|
116
|
+
requestIdleCallback(callback, options) {
|
|
117
|
+
const id = requestIdleCallback((...args) => {
|
|
118
|
+
if (!this.signal.aborted)
|
|
119
|
+
callback(...args);
|
|
120
|
+
}, options);
|
|
121
|
+
this.onInvalidated(() => cancelIdleCallback(id));
|
|
122
|
+
return id;
|
|
123
|
+
}
|
|
124
|
+
/**
|
|
125
|
+
* Abort the abort controller and execute all `onInvalidated` listeners.
|
|
126
|
+
*/
|
|
127
|
+
notifyInvalidated() {
|
|
128
|
+
this.abort("Content script context invalidated");
|
|
129
|
+
logger.debug(
|
|
130
|
+
`Content script "${this.contentScriptName}" context invalidated`
|
|
131
|
+
);
|
|
132
|
+
}
|
|
133
|
+
#stopOldScripts() {
|
|
134
|
+
window.postMessage({
|
|
135
|
+
event: _ContentScriptContext.SCRIPT_STARTED_MESSAGE_TYPE,
|
|
136
|
+
contentScriptName: this.contentScriptName
|
|
137
|
+
});
|
|
138
|
+
}
|
|
139
|
+
#listenForNewerScripts() {
|
|
140
|
+
const cb = (event) => {
|
|
141
|
+
if (event.data?.type === _ContentScriptContext.SCRIPT_STARTED_MESSAGE_TYPE && event.data?.contentScriptName === this.contentScriptName) {
|
|
142
|
+
this.notifyInvalidated();
|
|
143
|
+
}
|
|
144
|
+
};
|
|
145
|
+
addEventListener("message", cb);
|
|
146
|
+
this.onInvalidated(() => removeEventListener("message", cb));
|
|
147
|
+
}
|
|
148
|
+
};
|
|
17
149
|
export {
|
|
150
|
+
ContentScriptContext,
|
|
18
151
|
defineBackground,
|
|
19
152
|
defineContentScript,
|
|
20
153
|
mountContentScriptUi
|
|
21
154
|
};
|
|
22
|
-
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vc3JjL2NsaWVudC9kZWZpbmVDb250ZW50U2NyaXB0LnRzIiwgIi4uL3NyYy9jbGllbnQvZGVmaW5lQmFja2dyb3VuZC50cyIsICIuLi9zcmMvY2xpZW50L21vdW50Q29udGVudFNjcmlwdFVpLnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyJpbXBvcnQgeyBDb250ZW50U2NyaXB0RGVmaW5pdGlvbiB9IGZyb20gJy4uL2NvcmUvdHlwZXMnO1xuXG5leHBvcnQgZnVuY3Rpb24gZGVmaW5lQ29udGVudFNjcmlwdChcbiAgZGVmaW5pdGlvbjogQ29udGVudFNjcmlwdERlZmluaXRpb24sXG4pOiBDb250ZW50U2NyaXB0RGVmaW5pdGlvbiB7XG4gIHJldHVybiBkZWZpbml0aW9uO1xufVxuIiwgImltcG9ydCB7IEJhY2tncm91bmRTY3JpcHREZWZpbnRpdGlvbiB9IGZyb20gJy4uJztcblxuZXhwb3J0IGZ1bmN0aW9uIGRlZmluZUJhY2tncm91bmQobWFpbjogKCkgPT4gdm9pZCk6IEJhY2tncm91bmRTY3JpcHREZWZpbnRpdGlvbjtcbmV4cG9ydCBmdW5jdGlvbiBkZWZpbmVCYWNrZ3JvdW5kKFxuICBkZWZpbml0aW9uOiBCYWNrZ3JvdW5kU2NyaXB0RGVmaW50aXRpb24sXG4pOiBCYWNrZ3JvdW5kU2NyaXB0RGVmaW50aXRpb247XG5leHBvcnQgZnVuY3Rpb24gZGVmaW5lQmFja2dyb3VuZChcbiAgYXJnOiAoKCkgPT4gdm9pZCkgfCBCYWNrZ3JvdW5kU2NyaXB0RGVmaW50aXRpb24sXG4pOiBCYWNrZ3JvdW5kU2NyaXB0RGVmaW50aXRpb24ge1xuICBpZiAodHlwZW9mIGFyZyA9PT0gJ2Z1bmN0aW9uJykgcmV0dXJuIHsgbWFpbjogYXJnIH07XG4gIHJldHVybiBhcmc7XG59XG4iLCAiZXhwb3J0IGZ1bmN0aW9uIG1vdW50Q29udGVudFNjcmlwdFVpKCkge1xuICB0aHJvdyBFcnJvcignTm90IGltcGxlbWVudGVkOiBtb3VudENvbnRlbnRTY3JpcHRVaScpO1xufVxuIl0sCiAgIm1hcHBpbmdzIjogIjtBQUVPLFNBQVMsb0JBQ2QsWUFDeUI7QUFDekIsU0FBTztBQUNUOzs7QUNBTyxTQUFTLGlCQUNkLEtBQzZCO0FBQzdCLE1BQUksT0FBTyxRQUFRO0FBQVksV0FBTyxFQUFFLE1BQU0sSUFBSTtBQUNsRCxTQUFPO0FBQ1Q7OztBQ1hPLFNBQVMsdUJBQXVCO0FBQ3JDLFFBQU0sTUFBTSx1Q0FBdUM7QUFDckQ7IiwKICAibmFtZXMiOiBbXQp9Cg==
|
|
155
|
+
//# 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 (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 =
|
|
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
|
|
597
|
-
const inline = await
|
|
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,10 +641,7 @@ function resolveInternalZipConfig(root, mergedConfig) {
|
|
|
647
641
|
};
|
|
648
642
|
}
|
|
649
643
|
async function resolveInternalViteConfig(env, mergedConfig, finalConfig) {
|
|
650
|
-
const internalVite = await
|
|
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";
|
|
@@ -865,7 +856,7 @@ async function buildSingleEntrypoint(entrypoint, config) {
|
|
|
865
856
|
}
|
|
866
857
|
const entryConfig = vite3.mergeConfig(
|
|
867
858
|
libMode,
|
|
868
|
-
config.vite
|
|
859
|
+
await config.vite(config.env)
|
|
869
860
|
);
|
|
870
861
|
const result = await vite3.build(entryConfig);
|
|
871
862
|
return {
|
|
@@ -899,7 +890,7 @@ async function buildMultipleEntrypoints(entrypoints, config) {
|
|
|
899
890
|
}
|
|
900
891
|
const entryConfig = vite3.mergeConfig(
|
|
901
892
|
multiPage,
|
|
902
|
-
config.vite
|
|
893
|
+
await config.vite(config.env)
|
|
903
894
|
);
|
|
904
895
|
const result = await vite3.build(entryConfig);
|
|
905
896
|
return {
|
|
@@ -2202,7 +2193,7 @@ async function getServerInfo() {
|
|
|
2202
2193
|
async function setupServer(serverInfo, config) {
|
|
2203
2194
|
const runner = createWebExtRunner();
|
|
2204
2195
|
const viteServer = await vite5.createServer(
|
|
2205
|
-
vite5.mergeConfig(serverInfo, config.vite)
|
|
2196
|
+
vite5.mergeConfig(serverInfo, await config.vite(config.env))
|
|
2206
2197
|
);
|
|
2207
2198
|
const start = async () => {
|
|
2208
2199
|
await viteServer.listen(server.port);
|
|
@@ -2303,7 +2294,7 @@ async function clean(root = process.cwd()) {
|
|
|
2303
2294
|
}
|
|
2304
2295
|
|
|
2305
2296
|
// package.json
|
|
2306
|
-
var version2 = "0.
|
|
2297
|
+
var version2 = "0.6.0-alpha1";
|
|
2307
2298
|
|
|
2308
2299
|
// src/core/utils/defineConfig.ts
|
|
2309
2300
|
function defineConfig(config) {
|
|
@@ -2326,7 +2317,7 @@ async function createServer2(config) {
|
|
|
2326
2317
|
return getInternalConfig(
|
|
2327
2318
|
{
|
|
2328
2319
|
...config,
|
|
2329
|
-
vite: serverInfo.viteServerConfig
|
|
2320
|
+
vite: () => serverInfo.viteServerConfig
|
|
2330
2321
|
},
|
|
2331
2322
|
"serve"
|
|
2332
2323
|
);
|