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/cli.cjs +14 -22
- package/dist/client.d.ts +1 -1
- package/dist/client.js +136 -1
- package/dist/index.cjs +13 -21
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +9 -4
- package/dist/index.d.ts +9 -4
- package/dist/index.js +13 -21
- package/dist/index.js.map +1 -1
- package/dist/virtual-modules/background-entrypoint.js +2 -0
- package/dist/virtual-modules/background-entrypoint.js.map +1 -1
- package/dist/virtual-modules/content-script-entrypoint.js +2 -0
- package/dist/virtual-modules/content-script-entrypoint.js.map +1 -1
- package/dist/virtual-modules/reload-html.js +2 -0
- package/dist/virtual-modules/reload-html.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,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": ";AAEO,SAAS,oBACd,YACyB;AACzB,SAAO;AACT;;;ACAO,SAAS,iBACd,KAC6B;AAC7B,MAAI,OAAO,QAAQ;AAAY,WAAO,EAAE,MAAM,IAAI;AAClD,SAAO;AACT;;;ACXO,SAAS,uBAAuB;AACrC,QAAM,MAAM,uCAAuC;AACrD;;;ACFA,OAAO,qBAAiD;AAejD,IAAM,UAA4B;;;ACfzC,SAAS,MAAM,WAAqC,MAAa;AAC/D,MAAI,YAAY,IAAI,SAAS;AAAc;AAE3C,MAAI,OAAO,KAAK,CAAC,MAAM,UAAU;AAC/B,UAAM,UAAU,KAAK,MAAM;AAC3B,WAAO,SAAS,OAAO,IAAI,GAAG,IAAI;AAAA,EACpC,OAAO;AACL,WAAO,SAAS,GAAG,IAAI;AAAA,EACzB;AACF;AAKO,IAAM,SAAS;AAAA,EACpB,OAAO,IAAI,SAAgB,MAAM,QAAQ,OAAO,GAAG,IAAI;AAAA,EACvD,KAAK,IAAI,SAAgB,MAAM,QAAQ,KAAK,GAAG,IAAI;AAAA,EACnD,MAAM,IAAI,SAAgB,MAAM,QAAQ,MAAM,GAAG,IAAI;AAAA,EACrD,OAAO,IAAI,SAAgB,MAAM,QAAQ,OAAO,GAAG,IAAI;AACzD;;;ACTO,IAAM,uBAAN,MAAM,8BAA6B,gBAAgB;AAAA,EAKxD,YAA6B,mBAA2B;AACtD,UAAM;AADqB;AAG3B,QAAI,KAAK,aAAa;AACpB,WAAK,gBAAgB;AAAA,IACvB;AACA,SAAK,WAAW,MAAM;AAEpB,WAAK,uBAAuB;AAAA,IAC9B,CAAC;AAAA,EACH;AAAA,EAdA,OAAO,8BAA8B;AAAA,EAErC,cAAc,OAAO,SAAS,OAAO;AAAA,EAcrC,IAAI,YAAqB;AACvB,QAAI,QAAQ,QAAQ,MAAM,MAAM;AAC9B,WAAK,kBAAkB;AAAA,IACzB;AACA,WAAO,KAAK,OAAO;AAAA,EACrB;AAAA,EAEA,IAAI,UAAmB;AACrB,WAAO,CAAC,KAAK;AAAA,EACf;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAeA,cAAc,IAA4B;AACxC,SAAK,OAAO,iBAAiB,SAAS,EAAE;AACxC,WAAO,MAAM,KAAK,OAAO,oBAAoB,SAAS,EAAE;AAAA,EAC1D;AAAA;AAAA;AAAA;AAAA,EAKA,YAAY,SAAqB,SAA0B;AACzD,UAAM,KAAK,YAAY,MAAM;AAC3B,UAAI,KAAK;AAAS,gBAAQ;AAAA,IAC5B,GAAG,OAAO;AACV,SAAK,cAAc,MAAM,cAAc,EAAE,CAAC;AAC1C,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA,EAKA,WAAW,SAAqB,SAA0B;AACxD,UAAM,KAAK,WAAW,MAAM;AAC1B,UAAI,KAAK;AAAS,gBAAQ;AAAA,IAC5B,GAAG,OAAO;AACV,SAAK,cAAc,MAAM,aAAa,EAAE,CAAC;AACzC,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,sBAAsB,UAAwC;AAC5D,UAAM,KAAK,sBAAsB,IAAI,SAAS;AAC5C,UAAI,KAAK;AAAS,iBAAS,GAAG,IAAI;AAAA,IACpC,CAAC;AAED,SAAK,cAAc,MAAM,qBAAqB,EAAE,CAAC;AACjD,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA;AAAA,EAMA,oBACE,UACA,SACQ;AACR,UAAM,KAAK,oBAAoB,IAAI,SAAS;AAC1C,UAAI,CAAC,KAAK,OAAO;AAAS,iBAAS,GAAG,IAAI;AAAA,IAC5C,GAAG,OAAO;AAEV,SAAK,cAAc,MAAM,mBAAmB,EAAE,CAAC;AAC/C,WAAO;AAAA,EACT;AAAA;AAAA;AAAA;AAAA,EAKA,oBAAoB;AAClB,SAAK,MAAM,oCAAoC;AAC/C,WAAO;AAAA,MACL,mBAAmB,KAAK,iBAAiB;AAAA,IAC3C;AAAA,EACF;AAAA,EAEA,kBAAkB;AAEhB,WAAO,YAAY;AAAA,MACjB,OAAO,sBAAqB;AAAA,MAC5B,mBAAmB,KAAK;AAAA,IAC1B,CAAC;AAAA,EACH;AAAA,EAEA,yBAAyB;AACvB,UAAM,KAAK,CAAC,UAAwB;AAClC,UACE,MAAM,MAAM,SAAS,sBAAqB,+BAC1C,MAAM,MAAM,sBAAsB,KAAK,mBACvC;AACA,aAAK,kBAAkB;AAAA,MACzB;AAAA,IACF;AAEA,qBAAiB,WAAW,EAAE;AAC9B,SAAK,cAAc,MAAM,oBAAoB,WAAW,EAAE,CAAC;AAAA,EAC7D;AACF;",
  "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,13 +641,11 @@ 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";
|
|
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.
|
|
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
|
);
|