wxt 0.8.4 → 0.8.6
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/README.md +3 -2
- package/dist/browser.js +3 -4
- package/dist/chunk-FNTE2L27.js +7 -0
- package/dist/chunk-VFZ5667B.js +2410 -0
- package/dist/chunk-YUG22S6W.js +38 -0
- package/dist/cli.cjs +3941 -3775
- package/dist/cli.d.cts +2 -0
- package/dist/client.d.ts +5 -171
- package/dist/client.js +128 -131
- package/dist/execa-WKZHVHC5.js +2043 -0
- package/dist/external-9107db91.d.ts +176 -0
- package/dist/external-cb0967d6.d.ts +572 -0
- package/dist/index.cjs +2727 -2355
- package/dist/index.d.cts +36 -583
- package/dist/index.d.ts +36 -583
- package/dist/index.js +330 -4484
- package/dist/sandbox.d.ts +2 -23
- package/dist/sandbox.js +1 -2
- package/dist/testing.cjs +161 -35
- package/dist/testing.d.cts +7 -273
- package/dist/testing.d.ts +7 -273
- package/dist/testing.js +12 -676
- package/dist/{virtual-modules → virtual}/background-entrypoint.js +6 -7
- package/dist/{virtual-modules → virtual}/content-script-entrypoint.js +4 -5
- package/dist/virtual/mock-browser.js +152 -0
- package/dist/{virtual-modules → virtual}/reload-html.js +2 -3
- package/dist/{virtual-modules → virtual}/unlisted-script-entrypoint.js +2 -3
- package/package.json +6 -5
- package/dist/index.cjs.map +0 -1
- package/dist/index.js.map +0 -1
- package/dist/virtual-modules/background-entrypoint.js.map +0 -1
- package/dist/virtual-modules/content-script-entrypoint.js.map +0 -1
- package/dist/virtual-modules/fake-browser.cjs +0 -31
- package/dist/virtual-modules/fake-browser.js +0 -8
- package/dist/virtual-modules/reload-html.js.map +0 -1
- package/dist/virtual-modules/unlisted-script-entrypoint.js.map +0 -1
package/dist/sandbox.d.ts
CHANGED
|
@@ -1,26 +1,5 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
/**
|
|
4
|
-
* Main function executed when the unlisted script is ran.
|
|
5
|
-
*/
|
|
6
|
-
main(): void | Promise<void>;
|
|
7
|
-
}
|
|
8
|
-
interface ExcludableEntrypoint {
|
|
9
|
-
/**
|
|
10
|
-
* List of target browsers to include this entrypoint in. Defaults to being included in all
|
|
11
|
-
* builds. Cannot be used with `exclude`. You must choose one of the two options.
|
|
12
|
-
*
|
|
13
|
-
* @default undefined
|
|
14
|
-
*/
|
|
15
|
-
include?: TargetBrowser[];
|
|
16
|
-
/**
|
|
17
|
-
* List of target browsers to exclude this entrypoint from. Cannot be used with `include`. You
|
|
18
|
-
* must choose one of the two options.
|
|
19
|
-
*
|
|
20
|
-
* @default undefined
|
|
21
|
-
*/
|
|
22
|
-
exclude?: TargetBrowser[];
|
|
23
|
-
}
|
|
1
|
+
import { U as UnlistedScriptDefinition } from './external-9107db91.js';
|
|
2
|
+
import 'webextension-polyfill';
|
|
24
3
|
|
|
25
4
|
declare function defineUnlistedScript(main: () => void): UnlistedScriptDefinition;
|
|
26
5
|
declare function defineUnlistedScript(definition: UnlistedScriptDefinition): UnlistedScriptDefinition;
|
package/dist/sandbox.js
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
// src/
|
|
1
|
+
// src/sandbox/define-unlisted-script.ts
|
|
2
2
|
function defineUnlistedScript(arg) {
|
|
3
3
|
if (typeof arg === "function")
|
|
4
4
|
return { main: arg };
|
|
@@ -7,4 +7,3 @@ function defineUnlistedScript(arg) {
|
|
|
7
7
|
export {
|
|
8
8
|
defineUnlistedScript
|
|
9
9
|
};
|
|
10
|
-
//# sourceMappingURL=data:application/json;base64,ewogICJ2ZXJzaW9uIjogMywKICAic291cmNlcyI6IFsiLi4vc3JjL2NsaWVudC9zYW5kYm94L2RlZmluZVVubGlzdGVkU2NyaXB0LnRzIl0sCiAgInNvdXJjZXNDb250ZW50IjogWyJpbXBvcnQgeyBVbmxpc3RlZFNjcmlwdERlZmluaXRpb24gfSBmcm9tICcuLi8uLi9jb3JlL3R5cGVzJztcblxuZXhwb3J0IGZ1bmN0aW9uIGRlZmluZVVubGlzdGVkU2NyaXB0KFxuICBtYWluOiAoKSA9PiB2b2lkLFxuKTogVW5saXN0ZWRTY3JpcHREZWZpbml0aW9uO1xuZXhwb3J0IGZ1bmN0aW9uIGRlZmluZVVubGlzdGVkU2NyaXB0KFxuICBkZWZpbml0aW9uOiBVbmxpc3RlZFNjcmlwdERlZmluaXRpb24sXG4pOiBVbmxpc3RlZFNjcmlwdERlZmluaXRpb247XG5leHBvcnQgZnVuY3Rpb24gZGVmaW5lVW5saXN0ZWRTY3JpcHQoXG4gIGFyZzogKCgpID0+IHZvaWQpIHwgVW5saXN0ZWRTY3JpcHREZWZpbml0aW9uLFxuKTogVW5saXN0ZWRTY3JpcHREZWZpbml0aW9uIHtcbiAgaWYgKHR5cGVvZiBhcmcgPT09ICdmdW5jdGlvbicpIHJldHVybiB7IG1haW46IGFyZyB9O1xuICByZXR1cm4gYXJnO1xufVxuIl0sCiAgIm1hcHBpbmdzIjogIjtBQVFPLFNBQVMscUJBQ2QsS0FDMEI7QUFDMUIsTUFBSSxPQUFPLFFBQVE7QUFBWSxXQUFPLEVBQUUsTUFBTSxJQUFJO0FBQ2xELFNBQU87QUFDVDsiLAogICJuYW1lcyI6IFtdCn0K
|
package/dist/testing.cjs
CHANGED
|
@@ -44,8 +44,8 @@ var import_node_path2 = __toESM(require("path"), 1);
|
|
|
44
44
|
// src/core/utils/paths.ts
|
|
45
45
|
var import_node_path = __toESM(require("path"), 1);
|
|
46
46
|
var vite = __toESM(require("vite"), 1);
|
|
47
|
-
function normalizePath2(
|
|
48
|
-
return vite.normalizePath(
|
|
47
|
+
function normalizePath2(path7) {
|
|
48
|
+
return vite.normalizePath(path7);
|
|
49
49
|
}
|
|
50
50
|
var CSS_EXTENSIONS = ["css", "scss", "sass", "less", "styl", "stylus"];
|
|
51
51
|
var CSS_EXTENSIONS_PATTERN = `+(${CSS_EXTENSIONS.join("|")})`;
|
|
@@ -65,7 +65,7 @@ function devHtmlPrerender(config) {
|
|
|
65
65
|
const htmlReloadId = "@wxt/reload-html";
|
|
66
66
|
const resolvedHtmlReloadId = (0, import_path.resolve)(
|
|
67
67
|
config.root,
|
|
68
|
-
"node_modules/wxt/dist/virtual
|
|
68
|
+
"node_modules/wxt/dist/virtual/reload-html.js"
|
|
69
69
|
);
|
|
70
70
|
const virtualReactRefreshId = "@wxt/virtual-react-refresh";
|
|
71
71
|
const resolvedVirtualReactRefreshId = "\0" + virtualReactRefreshId;
|
|
@@ -198,7 +198,7 @@ function devServerGlobals(internalConfig) {
|
|
|
198
198
|
// src/core/utils/network.ts
|
|
199
199
|
var import_node_dns = __toESM(require("dns"), 1);
|
|
200
200
|
|
|
201
|
-
// src/core/utils/
|
|
201
|
+
// src/core/utils/time.ts
|
|
202
202
|
function withTimeout(promise, duration) {
|
|
203
203
|
return new Promise((res, rej) => {
|
|
204
204
|
const timeout = setTimeout(() => {
|
|
@@ -271,7 +271,7 @@ var import_fs_extra = __toESM(require("fs-extra"), 1);
|
|
|
271
271
|
// src/core/vite-plugins/unimport.ts
|
|
272
272
|
var import_unimport = require("unimport");
|
|
273
273
|
|
|
274
|
-
// src/core/utils/
|
|
274
|
+
// src/core/utils/unimport.ts
|
|
275
275
|
var import_vite = require("vite");
|
|
276
276
|
function getUnimportOptions(config) {
|
|
277
277
|
if (config.imports === false)
|
|
@@ -346,7 +346,7 @@ function virtualEntrypoint(type, config) {
|
|
|
346
346
|
const template = await import_fs_extra2.default.readFile(
|
|
347
347
|
(0, import_path3.resolve)(
|
|
348
348
|
config.root,
|
|
349
|
-
`node_modules/wxt/dist/virtual
|
|
349
|
+
`node_modules/wxt/dist/virtual/${type}-entrypoint.js`
|
|
350
350
|
),
|
|
351
351
|
"utf-8"
|
|
352
352
|
);
|
|
@@ -481,7 +481,7 @@ function webextensionPolyfillAlias(config) {
|
|
|
481
481
|
alias: {
|
|
482
482
|
"webextension-polyfill": import_node_path4.default.resolve(
|
|
483
483
|
config.root,
|
|
484
|
-
"node_modules/wxt/dist/virtual
|
|
484
|
+
"node_modules/wxt/dist/virtual/mock-browser"
|
|
485
485
|
)
|
|
486
486
|
}
|
|
487
487
|
}
|
|
@@ -490,17 +490,32 @@ function webextensionPolyfillAlias(config) {
|
|
|
490
490
|
};
|
|
491
491
|
}
|
|
492
492
|
|
|
493
|
-
// src/core/
|
|
494
|
-
|
|
495
|
-
|
|
496
|
-
|
|
493
|
+
// src/core/vite-plugins/webextensionPolyfillInlineDeps.ts
|
|
494
|
+
function webextensionPolyfillInlineDeps() {
|
|
495
|
+
return {
|
|
496
|
+
name: "wxt:testing-inline-deps",
|
|
497
|
+
config() {
|
|
498
|
+
const wxtModules = ["wxt/browser", "wxt/client"];
|
|
499
|
+
return {
|
|
500
|
+
test: {
|
|
501
|
+
server: {
|
|
502
|
+
deps: {
|
|
503
|
+
inline: [...wxtModules]
|
|
504
|
+
}
|
|
505
|
+
}
|
|
506
|
+
}
|
|
507
|
+
};
|
|
508
|
+
}
|
|
509
|
+
};
|
|
510
|
+
}
|
|
497
511
|
|
|
498
|
-
// src/core/utils/
|
|
499
|
-
var
|
|
500
|
-
var import_path4 = require("path");
|
|
512
|
+
// src/core/utils/building/build-entrypoints.ts
|
|
513
|
+
var vite2 = __toESM(require("vite"), 1);
|
|
501
514
|
|
|
502
515
|
// src/core/utils/fs.ts
|
|
503
516
|
var import_fs_extra3 = __toESM(require("fs-extra"), 1);
|
|
517
|
+
var import_fast_glob = __toESM(require("fast-glob"), 1);
|
|
518
|
+
var import_node_path5 = __toESM(require("path"), 1);
|
|
504
519
|
async function writeFileIfDifferent(file, newContents) {
|
|
505
520
|
const existingContents = await import_fs_extra3.default.readFile(file, "utf-8").catch(() => void 0);
|
|
506
521
|
if (existingContents !== newContents) {
|
|
@@ -508,19 +523,83 @@ async function writeFileIfDifferent(file, newContents) {
|
|
|
508
523
|
}
|
|
509
524
|
}
|
|
510
525
|
|
|
511
|
-
// src/core/utils/
|
|
526
|
+
// src/core/utils/building/build-entrypoints.ts
|
|
527
|
+
var import_fs_extra4 = __toESM(require("fs-extra"), 1);
|
|
528
|
+
var import_picocolors = __toESM(require("picocolors"), 1);
|
|
529
|
+
|
|
530
|
+
// src/core/utils/building/find-entrypoints.ts
|
|
531
|
+
var import_fs_extra5 = __toESM(require("fs-extra"), 1);
|
|
532
|
+
var import_minimatch = require("minimatch");
|
|
533
|
+
var import_linkedom2 = require("linkedom");
|
|
534
|
+
var import_json5 = __toESM(require("json5"), 1);
|
|
535
|
+
var import_fast_glob2 = __toESM(require("fast-glob"), 1);
|
|
536
|
+
var PATH_GLOB_TO_TYPE_MAP = {
|
|
537
|
+
"sandbox.html": "sandbox",
|
|
538
|
+
"sandbox/index.html": "sandbox",
|
|
539
|
+
"*.sandbox.html": "sandbox",
|
|
540
|
+
"*.sandbox/index.html": "sandbox",
|
|
541
|
+
"bookmarks.html": "bookmarks",
|
|
542
|
+
"bookmarks/index.html": "bookmarks",
|
|
543
|
+
"history.html": "history",
|
|
544
|
+
"history/index.html": "history",
|
|
545
|
+
"newtab.html": "newtab",
|
|
546
|
+
"newtab/index.html": "newtab",
|
|
547
|
+
"sidepanel.html": "sidepanel",
|
|
548
|
+
"sidepanel/index.html": "sidepanel",
|
|
549
|
+
"*.sidepanel.html": "sidepanel",
|
|
550
|
+
"*.sidepanel/index.html": "sidepanel",
|
|
551
|
+
"devtools.html": "devtools",
|
|
552
|
+
"devtools/index.html": "devtools",
|
|
553
|
+
"background.[jt]s": "background",
|
|
554
|
+
"background/index.[jt]s": "background",
|
|
555
|
+
[VIRTUAL_NOOP_BACKGROUND_MODULE_ID]: "background",
|
|
556
|
+
"content.[jt]s?(x)": "content-script",
|
|
557
|
+
"content/index.[jt]s?(x)": "content-script",
|
|
558
|
+
"*.content.[jt]s?(x)": "content-script",
|
|
559
|
+
"*.content/index.[jt]s?(x)": "content-script",
|
|
560
|
+
[`content.${CSS_EXTENSIONS_PATTERN}`]: "content-script-style",
|
|
561
|
+
[`*.content.${CSS_EXTENSIONS_PATTERN}`]: "content-script-style",
|
|
562
|
+
[`content/index.${CSS_EXTENSIONS_PATTERN}`]: "content-script-style",
|
|
563
|
+
[`*.content/index.${CSS_EXTENSIONS_PATTERN}`]: "content-script-style",
|
|
564
|
+
"popup.html": "popup",
|
|
565
|
+
"popup/index.html": "popup",
|
|
566
|
+
"options.html": "options",
|
|
567
|
+
"options/index.html": "options",
|
|
568
|
+
"*.html": "unlisted-page",
|
|
569
|
+
"*/index.html": "unlisted-page",
|
|
570
|
+
"*.[jt]s": "unlisted-script",
|
|
571
|
+
"*/index.ts": "unlisted-script",
|
|
572
|
+
[`*.${CSS_EXTENSIONS_PATTERN}`]: "unlisted-style",
|
|
573
|
+
[`*/index.${CSS_EXTENSIONS_PATTERN}`]: "unlisted-style",
|
|
574
|
+
// Don't warn about any files in subdirectories, like CSS or JS entrypoints for HTML files or tests
|
|
575
|
+
"*/**": "ignored"
|
|
576
|
+
};
|
|
577
|
+
|
|
578
|
+
// src/core/utils/building/generate-wxt-dir.ts
|
|
579
|
+
var import_unimport3 = require("unimport");
|
|
580
|
+
var import_fs_extra6 = __toESM(require("fs-extra"), 1);
|
|
581
|
+
var import_node_path6 = __toESM(require("path"), 1);
|
|
582
|
+
|
|
583
|
+
// src/core/utils/building/get-internal-config.ts
|
|
584
|
+
var import_c12 = require("c12");
|
|
585
|
+
var import_node_path7 = __toESM(require("path"), 1);
|
|
586
|
+
var vite3 = __toESM(require("vite"), 1);
|
|
587
|
+
|
|
588
|
+
// src/core/utils/cache.ts
|
|
589
|
+
var import_fs_extra7 = __toESM(require("fs-extra"), 1);
|
|
590
|
+
var import_path4 = require("path");
|
|
512
591
|
function createFsCache(wxtDir) {
|
|
513
592
|
const getPath = (key) => (0, import_path4.resolve)(wxtDir, "cache", encodeURIComponent(key));
|
|
514
593
|
return {
|
|
515
594
|
async set(key, value) {
|
|
516
|
-
const
|
|
517
|
-
await (0,
|
|
518
|
-
await writeFileIfDifferent(
|
|
595
|
+
const path7 = getPath(key);
|
|
596
|
+
await (0, import_fs_extra7.ensureDir)((0, import_path4.dirname)(path7));
|
|
597
|
+
await writeFileIfDifferent(path7, value);
|
|
519
598
|
},
|
|
520
599
|
async get(key) {
|
|
521
|
-
const
|
|
600
|
+
const path7 = getPath(key);
|
|
522
601
|
try {
|
|
523
|
-
return await
|
|
602
|
+
return await import_fs_extra7.default.readFile(path7, "utf-8");
|
|
524
603
|
} catch {
|
|
525
604
|
return void 0;
|
|
526
605
|
}
|
|
@@ -528,7 +607,7 @@ function createFsCache(wxtDir) {
|
|
|
528
607
|
};
|
|
529
608
|
}
|
|
530
609
|
|
|
531
|
-
// src/core/utils/
|
|
610
|
+
// src/core/utils/building/get-internal-config.ts
|
|
532
611
|
var import_consola = __toESM(require("consola"), 1);
|
|
533
612
|
async function getInternalConfig(inlineConfig, command) {
|
|
534
613
|
let userConfig = {};
|
|
@@ -551,19 +630,19 @@ async function getInternalConfig(inlineConfig, command) {
|
|
|
551
630
|
const manifestVersion = mergedConfig.manifestVersion ?? (browser === "firefox" || browser === "safari" ? 2 : 3);
|
|
552
631
|
const mode = mergedConfig.mode ?? (command === "build" ? "production" : "development");
|
|
553
632
|
const env = { browser, command, manifestVersion, mode };
|
|
554
|
-
const root =
|
|
633
|
+
const root = import_node_path7.default.resolve(
|
|
555
634
|
inlineConfig.root ?? userConfig.root ?? process.cwd()
|
|
556
635
|
);
|
|
557
|
-
const wxtDir =
|
|
558
|
-
const srcDir =
|
|
559
|
-
const entrypointsDir =
|
|
636
|
+
const wxtDir = import_node_path7.default.resolve(root, ".wxt");
|
|
637
|
+
const srcDir = import_node_path7.default.resolve(root, mergedConfig.srcDir ?? root);
|
|
638
|
+
const entrypointsDir = import_node_path7.default.resolve(
|
|
560
639
|
srcDir,
|
|
561
640
|
mergedConfig.entrypointsDir ?? "entrypoints"
|
|
562
641
|
);
|
|
563
|
-
const publicDir =
|
|
564
|
-
const typesDir =
|
|
565
|
-
const outBaseDir =
|
|
566
|
-
const outDir =
|
|
642
|
+
const publicDir = import_node_path7.default.resolve(srcDir, mergedConfig.publicDir ?? "public");
|
|
643
|
+
const typesDir = import_node_path7.default.resolve(wxtDir, "types");
|
|
644
|
+
const outBaseDir = import_node_path7.default.resolve(root, ".output");
|
|
645
|
+
const outDir = import_node_path7.default.resolve(outBaseDir, `${browser}-mv${manifestVersion}`);
|
|
567
646
|
const runnerConfig = await (0, import_c12.loadConfig)({
|
|
568
647
|
name: "web-ext",
|
|
569
648
|
cwd: root,
|
|
@@ -618,7 +697,7 @@ function mergeInlineConfig(inlineConfig, userConfig) {
|
|
|
618
697
|
} else if (userConfig.imports == null && inlineConfig.imports == null) {
|
|
619
698
|
imports = void 0;
|
|
620
699
|
} else {
|
|
621
|
-
imports =
|
|
700
|
+
imports = vite3.mergeConfig(
|
|
622
701
|
userConfig.imports ?? {},
|
|
623
702
|
inlineConfig.imports ?? {}
|
|
624
703
|
);
|
|
@@ -626,18 +705,18 @@ function mergeInlineConfig(inlineConfig, userConfig) {
|
|
|
626
705
|
const manifest = async (env) => {
|
|
627
706
|
const user = await resolveManifestConfig(env, userConfig.manifest);
|
|
628
707
|
const inline = await resolveManifestConfig(env, inlineConfig.manifest);
|
|
629
|
-
return
|
|
708
|
+
return vite3.mergeConfig(user, inline);
|
|
630
709
|
};
|
|
631
710
|
const viteConfig = async (env) => {
|
|
632
711
|
const user = await userConfig.vite?.(env);
|
|
633
712
|
const inline = await inlineConfig.vite?.(env);
|
|
634
|
-
return
|
|
713
|
+
return vite3.mergeConfig(user ?? {}, inline ?? {});
|
|
635
714
|
};
|
|
636
|
-
const runner =
|
|
715
|
+
const runner = vite3.mergeConfig(
|
|
637
716
|
userConfig.runner ?? {},
|
|
638
717
|
inlineConfig.runner ?? {}
|
|
639
718
|
);
|
|
640
|
-
const zip =
|
|
719
|
+
const zip = vite3.mergeConfig(
|
|
641
720
|
userConfig.zip ?? {},
|
|
642
721
|
inlineConfig.zip ?? {}
|
|
643
722
|
);
|
|
@@ -715,10 +794,58 @@ async function resolveInternalViteConfig(env, mergedConfig, finalConfig) {
|
|
|
715
794
|
return internalVite;
|
|
716
795
|
}
|
|
717
796
|
|
|
797
|
+
// src/core/utils/building/import-entrypoint.ts
|
|
798
|
+
var import_jiti = __toESM(require("jiti"), 1);
|
|
799
|
+
var import_unimport5 = require("unimport");
|
|
800
|
+
var import_fs_extra8 = __toESM(require("fs-extra"), 1);
|
|
801
|
+
var import_esbuild = require("esbuild");
|
|
802
|
+
|
|
803
|
+
// src/core/utils/building/internal-build.ts
|
|
804
|
+
var import_picocolors4 = __toESM(require("picocolors"), 1);
|
|
805
|
+
var vite5 = __toESM(require("vite"), 1);
|
|
806
|
+
var import_fs_extra12 = __toESM(require("fs-extra"), 1);
|
|
807
|
+
|
|
808
|
+
// src/core/utils/log/printFileList.ts
|
|
809
|
+
var import_node_path8 = __toESM(require("path"), 1);
|
|
810
|
+
var import_picocolors2 = __toESM(require("picocolors"), 1);
|
|
811
|
+
var import_fs_extra9 = __toESM(require("fs-extra"), 1);
|
|
812
|
+
var import_filesize = require("filesize");
|
|
813
|
+
var DEFAULT_COLOR = import_picocolors2.default.blue;
|
|
814
|
+
var CHUNK_COLORS = {
|
|
815
|
+
".js.map": import_picocolors2.default.gray,
|
|
816
|
+
".cjs.map": import_picocolors2.default.gray,
|
|
817
|
+
".mjs.map": import_picocolors2.default.gray,
|
|
818
|
+
".html": import_picocolors2.default.green,
|
|
819
|
+
".css": import_picocolors2.default.magenta,
|
|
820
|
+
".js": import_picocolors2.default.cyan,
|
|
821
|
+
".cjs": import_picocolors2.default.cyan,
|
|
822
|
+
".mjs": import_picocolors2.default.cyan,
|
|
823
|
+
".zip": import_picocolors2.default.yellow
|
|
824
|
+
};
|
|
825
|
+
|
|
826
|
+
// src/core/utils/log/printHeader.ts
|
|
827
|
+
var import_picocolors3 = __toESM(require("picocolors"), 1);
|
|
828
|
+
var import_consola2 = require("consola");
|
|
829
|
+
|
|
830
|
+
// src/core/utils/building/internal-build.ts
|
|
831
|
+
var import_fast_glob3 = __toESM(require("fast-glob"), 1);
|
|
832
|
+
|
|
833
|
+
// src/core/utils/manifest.ts
|
|
834
|
+
var import_fs_extra11 = __toESM(require("fs-extra"), 1);
|
|
835
|
+
|
|
836
|
+
// src/core/utils/package.ts
|
|
837
|
+
var import_node_path9 = require("path");
|
|
838
|
+
var import_fs_extra10 = __toESM(require("fs-extra"), 1);
|
|
839
|
+
|
|
840
|
+
// src/core/utils/manifest.ts
|
|
841
|
+
var import_immer = require("immer");
|
|
842
|
+
var vite4 = __toESM(require("vite"), 1);
|
|
843
|
+
|
|
718
844
|
// src/testing/wxt-vitest-plugin.ts
|
|
719
845
|
function WxtVitest(inlineConfig) {
|
|
720
846
|
return getInternalConfig(inlineConfig ?? {}, "serve").then((config) => [
|
|
721
847
|
webextensionPolyfillAlias(config),
|
|
848
|
+
webextensionPolyfillInlineDeps(),
|
|
722
849
|
unimport(config),
|
|
723
850
|
globals(config),
|
|
724
851
|
download(config),
|
|
@@ -730,4 +857,3 @@ function WxtVitest(inlineConfig) {
|
|
|
730
857
|
WxtVitest,
|
|
731
858
|
fakeBrowser
|
|
732
859
|
});
|
|
733
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../src/testing/index.ts", "../src/testing/fake-browser.ts", "../src/core/utils/entrypoints.ts", "../src/core/utils/paths.ts", "../src/core/vite-plugins/devHtmlPrerender.ts", "../src/core/vite-plugins/devServerGlobals.ts", "../src/core/utils/network.ts", "../src/core/utils/promises.ts", "../src/core/vite-plugins/download.ts", "../src/core/vite-plugins/multipageMove.ts", "../src/core/vite-plugins/unimport.ts", "../src/core/utils/auto-imports.ts", "../src/core/vite-plugins/virtualEntrypoint.ts", "../src/core/vite-plugins/tsconfigPaths.ts", "../src/core/vite-plugins/noopBackground.ts", "../src/core/vite-plugins/bundleAnalysis.ts", "../src/core/utils/globals.ts", "../src/core/vite-plugins/globals.ts", "../src/core/vite-plugins/webextensionPolyfillAlias.ts", "../src/core/utils/getInternalConfig.ts", "../src/core/utils/createFsCache.ts", "../src/core/utils/fs.ts", "../src/testing/wxt-vitest-plugin.ts"],
  "sourcesContent": ["/**\n * @module wxt/testing\n */\nexport * from './fake-browser';\nexport * from './wxt-vitest-plugin';\n", "export { fakeBrowser, type FakeBrowser } from '@webext-core/fake-browser';\n", "import { Entrypoint, PerBrowserOption, TargetBrowser } from '../types';\nimport path, { relative, resolve } from 'node:path';\nimport { normalizePath } from './paths';\n\nexport function getEntrypointName(\n  entrypointsDir: string,\n  inputPath: string,\n  // type: Entrypoint['type'],\n): string {\n  const relativePath = path.relative(entrypointsDir, inputPath);\n  // Grab the string up to the first . or / or \\\\\n  const name = relativePath.split(/[\\.\\/\\\\]/, 2)[0];\n\n  return name;\n}\n\nexport function getEntrypointOutputFile(\n  entrypoint: Entrypoint,\n  ext: string,\n): string {\n  return resolve(entrypoint.outputDir, `${entrypoint.name}${ext}`);\n}\n\n/**\n * Return's the entrypoint's output path relative to the output directory. Used for paths in the\n * manifest and rollup's bundle.\n */\nexport function getEntrypointBundlePath(\n  entrypoint: Entrypoint,\n  outDir: string,\n  ext: string,\n): string {\n  return normalizePath(\n    relative(outDir, getEntrypointOutputFile(entrypoint, ext)),\n  );\n}\n\n/**\n * Given an entrypoint option, resolve it's value based on a target browser.\n */\nexport function resolvePerBrowserOption<T>(\n  option: PerBrowserOption<T>,\n  browser: TargetBrowser,\n): T {\n  if (typeof option === 'object' && !Array.isArray(option))\n    return (option as any)[browser];\n  return option;\n}\n", "import nodePath from 'node:path';\nimport * as vite from 'vite';\n\n/**\n * Converts system paths to normalized bundler path. On windows and unix, this returns paths with /\n * instead of \\.\n */\nexport function normalizePath(path: string): string {\n  return vite.normalizePath(path);\n}\n\n/**\n * Given a normalized path, convert it to the system path style. On Windows, switch to \\, otherwise use /.\n */\nexport function unnormalizePath(path: string): string {\n  return nodePath.normalize(path);\n}\n\nexport const CSS_EXTENSIONS = ['css', 'scss', 'sass', 'less', 'styl', 'stylus'];\n\n// .module.css files are not supported because these are global CSS files, so using CSS modules doesn't make sense.\nexport const CSS_EXTENSIONS_PATTERN = `+(${CSS_EXTENSIONS.join('|')})`;\n", "import * as vite from 'vite';\nimport { InternalConfig } from '../types';\nimport { getEntrypointName } from '../utils/entrypoints';\nimport { parseHTML } from 'linkedom';\nimport { dirname, isAbsolute, relative, resolve } from 'path';\n\n// Cache the preamble script for all devHtmlPrerender plugins, not just one\nlet reactRefreshPreamble = '';\n\n/**\n * Pre-renders the HTML entrypoints when building the extension to connect to the dev server.\n */\nexport function devHtmlPrerender(config: InternalConfig): vite.PluginOption {\n  const htmlReloadId = '@wxt/reload-html';\n  const resolvedHtmlReloadId = resolve(\n    config.root,\n    'node_modules/wxt/dist/virtual-modules/reload-html.js',\n  );\n  const virtualReactRefreshId = '@wxt/virtual-react-refresh';\n  const resolvedVirtualReactRefreshId = '\\0' + virtualReactRefreshId;\n\n  return [\n    {\n      apply: 'build',\n      name: 'wxt:dev-html-prerender',\n      config() {\n        return {\n          resolve: {\n            alias: {\n              [htmlReloadId]: resolvedHtmlReloadId,\n            },\n          },\n        };\n      },\n      // Convert scripts like src=\"./main.tsx\" -> src=\"http://localhost:3000/entrypoints/popup/main.tsx\"\n      // before the paths are replaced with their bundled path\n      transform(code, id) {\n        const server = config.server;\n        if (\n          config.command !== 'serve' ||\n          server == null ||\n          !id.endsWith('.html')\n        )\n          return;\n\n        const { document } = parseHTML(code);\n\n        const pointToDevServer = (\n          querySelector: string,\n          attr: string,\n        ): void => {\n          document.querySelectorAll(querySelector).forEach((element) => {\n            const src = element.getAttribute(attr);\n            if (!src) return;\n\n            if (isAbsolute(src)) {\n              element.setAttribute(attr, server.origin + src);\n            } else if (src.startsWith('.')) {\n              const abs = resolve(dirname(id), src);\n              const pathname = relative(config.root, abs);\n              element.setAttribute(attr, `${server.origin}/${pathname}`);\n            }\n          });\n        };\n        pointToDevServer('script[type=module]', 'src');\n        pointToDevServer('link[rel=stylesheet]', 'href');\n\n        // Add a script to add page reloading\n        const reloader = document.createElement('script');\n        reloader.src = htmlReloadId;\n        reloader.type = 'module';\n        document.head.appendChild(reloader);\n\n        const newHtml = document.toString();\n        config.logger.debug('transform ' + id);\n        config.logger.debug('Old HTML:\\n' + code);\n        config.logger.debug('New HTML:\\n' + newHtml);\n        return newHtml;\n      },\n\n      // Pass the HTML through the dev server to add dev-mode specific code\n      async transformIndexHtml(html, ctx) {\n        const server = config.server;\n        if (config.command !== 'serve' || server == null) return;\n\n        const originalUrl = `${server.origin}${ctx.path}`;\n        const name = getEntrypointName(config.entrypointsDir, ctx.filename);\n        const url = `${server.origin}/${name}.html`;\n        const serverHtml = await server.transformIndexHtml(\n          url,\n          html,\n          originalUrl,\n        );\n        const { document } = parseHTML(serverHtml);\n\n        // React pages include a preamble as an unsafe-inline type=\"module\" script to enable fast refresh, as shown here:\n        // https://github.com/wxt-dev/wxt/issues/157#issuecomment-1756497616\n        // Since unsafe-inline scripts are blocked by MV3 CSPs, we need to virtualize it.\n        const reactRefreshScript = Array.from(\n          document.querySelectorAll('script[type=module]'),\n        ).find((script) => script.innerHTML.includes('@react-refresh'));\n        if (reactRefreshScript) {\n          // Save preamble to serve from server\n          reactRefreshPreamble = reactRefreshScript.innerHTML;\n\n          // Replace unsafe inline script\n          const virtualScript = document.createElement('script');\n          virtualScript.type = 'module';\n          virtualScript.src = `${server.origin}/${virtualReactRefreshId}`;\n          reactRefreshScript.replaceWith(virtualScript);\n        }\n\n        // Change /@vite/client -> http://localhost:3000/@vite/client\n        const viteClientScript = document.querySelector<HTMLScriptElement>(\n          \"script[src='/@vite/client']\",\n        );\n        if (viteClientScript) {\n          viteClientScript.src = `${server.origin}${viteClientScript.src}`;\n        }\n\n        const newHtml = document.toString();\n        config.logger.debug('transformIndexHtml ' + ctx.filename);\n        config.logger.debug('Old HTML:\\n' + html);\n        config.logger.debug('New HTML:\\n' + newHtml);\n        return newHtml;\n      },\n    },\n    {\n      name: 'wxt:virtualize-react-refresh',\n      apply: 'serve',\n      resolveId(id) {\n        if (id === `/${virtualReactRefreshId}`) {\n          return resolvedVirtualReactRefreshId;\n        }\n        // Ignore chunk contents when pre-rendering\n        if (id.startsWith('/chunks/')) {\n          return '\\0noop';\n        }\n      },\n      load(id) {\n        if (id === resolvedVirtualReactRefreshId) {\n          return reactRefreshPreamble;\n        }\n        if (id === '\\0noop') {\n          return '';\n        }\n      },\n    },\n  ];\n}\n", "import { Plugin } from 'vite';\nimport { InternalConfig } from '../types';\n\n/**\n * Defines global constants about the dev server. Helps scripts connect to the server's web socket.\n */\nexport function devServerGlobals(internalConfig: InternalConfig): Plugin {\n  return {\n    name: 'wxt:dev-server-globals',\n    config() {\n      if (internalConfig.server == null || internalConfig.command == 'build')\n        return;\n\n      return {\n        define: {\n          __DEV_SERVER_PROTOCOL__: JSON.stringify('ws:'),\n          __DEV_SERVER_HOSTNAME__: JSON.stringify(\n            internalConfig.server.hostname,\n          ),\n          __DEV_SERVER_PORT__: JSON.stringify(internalConfig.server.port),\n        },\n      };\n    },\n  };\n}\n", "import dns from 'node:dns';\nimport { withTimeout } from './promises';\nimport { InternalConfig } from '../types';\n\nfunction isOffline(): Promise<boolean> {\n  const isOffline = new Promise<boolean>((res) => {\n    dns.resolve('google.com', (err) => {\n      if (err == null) {\n        res(false);\n      } else {\n        res(true);\n      }\n    });\n  });\n  return withTimeout(isOffline, 1e3).catch(() => true);\n}\n\nexport async function isOnline(): Promise<boolean> {\n  const offline = await isOffline();\n  return !offline;\n}\n\n/**\n * Fetches a URL with a simple GET request. Grabs it from cache if it doesn't exist, or throws an\n * error if it can't be resolved via the network or cache.\n */\nexport async function fetchCached(\n  url: string,\n  config: InternalConfig,\n): Promise<string> {\n  let content: string = '';\n\n  if (await isOnline()) {\n    const res = await fetch(url);\n    if (res.status < 300) {\n      content = await res.text();\n      await config.fsCache.set(url, content);\n    } else {\n      config.logger.debug(\n        `Failed to download \"${url}\", falling back to cache...`,\n      );\n    }\n  }\n\n  if (!content) content = (await config.fsCache.get(url)) ?? '';\n  if (!content)\n    throw Error(\n      `Offline and \"${url}\" has not been cached. Try again when online.`,\n    );\n\n  return content;\n}\n", "/**\n * Add a timeout to a promise.\n */\nexport function withTimeout<T>(\n  promise: Promise<T>,\n  duration: number,\n): Promise<T> {\n  return new Promise((res, rej) => {\n    const timeout = setTimeout(() => {\n      rej(`Promise timed out after ${duration}ms`);\n    }, duration);\n    promise\n      .then(res)\n      .catch(rej)\n      .finally(() => clearTimeout(timeout));\n  });\n}\n\n/**\n * @deprecated Don't use in production, just for testing and slowing things down.\n */\nexport function sleep(ms: number): Promise<void> {\n  return new Promise((res) => setTimeout(res, ms));\n}\n", "import { Plugin } from 'vite';\nimport { InternalConfig } from '../types';\nimport { fetchCached } from '../utils/network';\n\n/**\n * Downloads any URL imports, like Google Analytics, into virtual modules so they are bundled with\n * the extension instead of depending on remote code at runtime.\n *\n * @example\n * import \"url:https://google-tagmanager.com/gtag?id=XYZ\";\n */\nexport function download(config: InternalConfig): Plugin {\n  return {\n    name: 'wxt:download',\n    resolveId(id) {\n      if (id.startsWith('url:')) return '\\0' + id;\n    },\n    async load(id) {\n      if (!id.startsWith('\\0url:')) return;\n\n      // Load file from network or cache\n      const url = id.replace('\\0url:', '');\n      return await fetchCached(url, config);\n    },\n  };\n}\n", "import * as vite from 'vite';\nimport { Entrypoint, InternalConfig } from '../types';\nimport { dirname, extname, resolve } from 'node:path';\nimport { getEntrypointBundlePath } from '../utils/entrypoints';\nimport fs, { ensureDir } from 'fs-extra';\nimport { normalizePath } from '../utils/paths';\n\n/**\n * Ensures the HTML files output by a multipage build are in the correct location. This does two\n * things:\n *\n * 1. Moves the HMTL files to their final location at `<outDir>/<entrypoint.name>.html`.\n * 2. Updates the bundle so it summarizes the files correctly in the returned build output.\n *\n * Assets (JS and CSS) are output to the `<outDir>/assets` directory, and don't need to be modified.\n * HTML files access them via absolute URLs, so we don't need to update any import paths in the HTML\n * files either.\n *\n * THIS PLUGIN SHOULD ONLY BE APPLIED TO MULTIPAGE BUILDS. It should not be added to every build.\n */\nexport function multipageMove(\n  entrypoints: Entrypoint[],\n  config: InternalConfig,\n): vite.Plugin {\n  return {\n    name: 'wxt:multipage-move',\n    async writeBundle(_, bundle) {\n      for (const oldBundlePath in bundle) {\n        // oldBundlePath = 'entrypoints/popup.html' or 'entrypoints/options/index.html'\n\n        // Find a matching entrypoint - oldBundlePath is the same as end end of the input path.\n        const entrypoint = entrypoints.find(\n          (entry) => !!normalizePath(entry.inputPath).endsWith(oldBundlePath),\n        );\n        if (entrypoint == null) {\n          config.logger.debug(\n            `No entrypoint found for ${oldBundlePath}, leaving in chunks directory`,\n          );\n          continue;\n        }\n\n        // Get the new bundle path\n        const newBundlePath = getEntrypointBundlePath(\n          entrypoint,\n          config.outDir,\n          extname(oldBundlePath),\n        );\n        if (newBundlePath === oldBundlePath) {\n          config.logger.debug(\n            'HTML file is already in the correct location',\n            oldBundlePath,\n          );\n          continue;\n        }\n\n        // Move file and update bundle\n        // Do this inside a mutex lock so it only runs one at a time for concurrent multipage builds\n        const oldAbsPath = resolve(config.outDir, oldBundlePath);\n        const newAbsPath = resolve(config.outDir, newBundlePath);\n        await ensureDir(dirname(newAbsPath));\n        await fs.move(oldAbsPath, newAbsPath, { overwrite: true });\n\n        const renamedChunk = {\n          ...bundle[oldBundlePath],\n          fileName: newBundlePath,\n        };\n        delete bundle[oldBundlePath];\n        bundle[newBundlePath] = renamedChunk;\n      }\n    },\n  };\n}\n", "import { createUnimport } from 'unimport';\nimport { InternalConfig } from '../types';\nimport { getUnimportOptions } from '../utils/auto-imports';\nimport * as vite from 'vite';\nimport { extname } from 'path';\n\nconst ENABLED_EXTENSIONS: Record<string, boolean | undefined> = {\n  '.js': true,\n  '.jsx': true,\n  '.ts': true,\n  '.tsx': true,\n  '.vue': true,\n  '.svelte': true,\n};\n\n/**\n * Inject any global imports defined by unimport\n */\nexport function unimport(config: InternalConfig): vite.PluginOption {\n  const options = getUnimportOptions(config);\n  if (options === false) return [];\n\n  const unimport = createUnimport(options);\n\n  return {\n    name: 'wxt:unimport',\n    async config() {\n      await unimport.scanImportsFromDir(undefined, { cwd: config.srcDir });\n    },\n    async transform(code, id) {\n      const ext = extname(id);\n      if (ENABLED_EXTENSIONS[ext]) return unimport.injectImports(code, id);\n    },\n  };\n}\n", "import { UnimportOptions } from 'unimport';\nimport { InternalConfig } from '../types';\nimport { mergeConfig } from 'vite';\n\nexport function getUnimportOptions(\n  config: InternalConfig,\n): Partial<UnimportOptions | false> {\n  if (config.imports === false) return false;\n\n  const defaultOptions: Partial<UnimportOptions> = {\n    debugLog: config.logger.debug,\n    imports: [\n      { name: 'defineConfig', from: 'wxt' },\n      { name: 'fakeBrowser', from: 'wxt/testing' },\n    ],\n    presets: [\n      { package: 'wxt/client' },\n      { package: 'wxt/browser' },\n      { package: 'wxt/sandbox' },\n    ],\n    warn: config.logger.warn,\n    dirs: ['components', 'composables', 'hooks', 'utils'],\n  };\n\n  return mergeConfig(\n    defaultOptions,\n    config.imports,\n  ) as Partial<UnimportOptions>;\n}\n", "import { Plugin } from 'vite';\nimport { Entrypoint, InternalConfig } from '../types';\nimport fs from 'fs-extra';\nimport { resolve } from 'path';\nimport { normalizePath } from '../utils/paths';\n\n/**\n * Wraps a user's entrypoint with a vitual version with additional logic.\n */\nexport function virtualEntrypoint(\n  type: Entrypoint['type'],\n  config: InternalConfig,\n): Plugin {\n  const virtualId = `virtual:wxt-${type}?`;\n  const resolvedVirtualId = `\\0${virtualId}`;\n\n  return {\n    name: `wxt:virtual-entrypoint`,\n    resolveId(id) {\n      // Id doesn't start with prefix, it looks like this:\n      // /path/to/project/virtual:background?/path/to/project/entrypoints/background.ts\n      const index = id.indexOf(virtualId);\n      if (index === -1) return;\n\n      const inputPath = normalizePath(id.substring(index + virtualId.length));\n      return resolvedVirtualId + inputPath;\n    },\n    async load(id) {\n      if (!id.startsWith(resolvedVirtualId)) return;\n\n      const inputPath = id.replace(resolvedVirtualId, '');\n      const template = await fs.readFile(\n        resolve(\n          config.root,\n          `node_modules/wxt/dist/virtual-modules/${type}-entrypoint.js`,\n        ),\n        'utf-8',\n      );\n      return template.replace(`virtual:user-${type}`, inputPath);\n    },\n  };\n}\n", "import { InternalConfig } from '../types';\nimport * as vite from 'vite';\n\nexport function tsconfigPaths(config: InternalConfig): vite.Plugin {\n  return {\n    name: 'wxt:aliases',\n    async config() {\n      return {\n        resolve: {\n          alias: {\n            '@@': config.root,\n            '~~': config.root,\n            '@': config.srcDir,\n            '~': config.srcDir,\n          },\n        },\n      };\n    },\n  };\n}\n", "import { Plugin } from 'vite';\n\n/**\n * In dev mode, if there's not a background script listed, we need to add one.\n *\n * This define's a virtual module that is basically just a noop.\n */\nexport function noopBackground(): Plugin {\n  const virtualModuleId = VIRTUAL_NOOP_BACKGROUND_MODULE_ID;\n  const resolvedVirtualModuleId = '\\0' + virtualModuleId;\n  return {\n    name: 'wxt:noop-background',\n    resolveId(id) {\n      if (id === virtualModuleId) return resolvedVirtualModuleId;\n    },\n    load(id) {\n      if (id === resolvedVirtualModuleId) {\n        return `import { defineBackground } from 'wxt/client';\\nexport default defineBackground(() => void 0)`;\n      }\n    },\n  };\n}\n\nexport const VIRTUAL_NOOP_BACKGROUND_MODULE_ID = 'virtual:user-background';\n", "import * as vite from 'vite';\nimport { visualizer } from 'rollup-plugin-visualizer';\n\nlet increment = 0;\n\nexport function bundleAnalysis(): vite.Plugin {\n  return visualizer({\n    emitFile: true,\n    template: 'raw-data',\n    filename: `stats-${increment++}.json`,\n  }) as vite.Plugin;\n}\n", "import { InternalConfig } from '../types';\n\nexport function getGlobals(\n  config: InternalConfig,\n): Array<{ name: string; value: any; type: string }> {\n  return [\n    {\n      name: surroundInUnderscore('MANIFEST_VERSION'),\n      value: config.manifestVersion,\n      type: `2 | 3`,\n    },\n    {\n      name: surroundInUnderscore('BROWSER'),\n      value: config.browser,\n      type: `string`,\n    },\n    {\n      name: surroundInUnderscore('IS_CHROME'),\n      value: config.browser === 'chrome',\n      type: `boolean`,\n    },\n    {\n      name: surroundInUnderscore('IS_FIREFOX'),\n      value: config.browser === 'firefox',\n      type: `boolean`,\n    },\n    {\n      name: surroundInUnderscore('IS_SAFARI'),\n      value: config.browser === 'safari',\n      type: `boolean`,\n    },\n    {\n      name: surroundInUnderscore('IS_EDGE'),\n      value: config.browser === 'edge',\n      type: `boolean`,\n    },\n    {\n      name: surroundInUnderscore('IS_OPERA'),\n      value: config.browser === 'opera',\n      type: `boolean`,\n    },\n    {\n      name: surroundInUnderscore('COMMAND'),\n      value: config.command,\n      type: `\"build\" | \"serve\"`,\n    },\n  ];\n}\n\nexport function getEntrypointGlobals(\n  config: InternalConfig,\n  entrypointName: string,\n) {\n  return [\n    {\n      name: surroundInUnderscore('ENTRYPOINT'),\n      value: entrypointName,\n      type: `string`,\n    },\n  ];\n}\n\n/**\n * Don't hardcode the complete name so that the string litterals in this file aren't replaced during\n * tests (which causes syntax errors), only during builds.\n */\nfunction surroundInUnderscore(name: string): string {\n  return `__${name}__`;\n}\n", "import * as vite from 'vite';\nimport { InternalConfig } from '../types';\nimport { getGlobals } from '../utils/globals';\n\nexport function globals(config: InternalConfig): vite.PluginOption {\n  return {\n    name: 'wxt:globals',\n    config() {\n      const define: vite.InlineConfig['define'] = {};\n      for (const global of getGlobals(config)) {\n        define[global.name] = JSON.stringify(global.value);\n      }\n      return {\n        define,\n      };\n    },\n  };\n}\n", "import path from 'node:path';\nimport * as vite from 'vite';\nimport { InternalConfig } from '../types';\n\n/**\n * Creates an alias to redirect \"webextension-polyfill\" imports to WXT's `fakeBrowser`.\n *\n * This should only be used during tests.\n */\nexport function webextensionPolyfillAlias(\n  config: InternalConfig,\n): vite.PluginOption {\n  return {\n    name: 'wxt:webextension-polyfill-test-alias',\n    config() {\n      return {\n        resolve: {\n          alias: {\n            'webextension-polyfill': path.resolve(\n              config.root,\n              'node_modules/wxt/dist/virtual-modules/fake-browser',\n            ),\n          },\n        },\n      };\n    },\n  };\n}\n", "import { loadConfig } from 'c12';\nimport {\n  InlineConfig,\n  InternalConfig,\n  UserConfig,\n  ConfigEnv,\n  UserManifestFn,\n  UserManifest,\n  WxtViteConfig,\n  ExtensionRunnerConfig,\n} from '../types';\nimport path from 'node:path';\nimport * as vite from 'vite';\nimport { createFsCache } from './createFsCache';\nimport consola, { LogLevels } from 'consola';\nimport * as plugins from '../vite-plugins';\n\n/**\n * Given an inline config, discover the config file if necessary, merge the results, resolve any\n * relative paths, and apply any defaults.\n *\n * Inline config always has priority over user config. Cli flags are passed as inline config if set.\n * If unset, undefined is passed in, letting this function decide default values.\n */\nexport async function getInternalConfig(\n  inlineConfig: InlineConfig,\n  command: 'build' | 'serve',\n): Promise<InternalConfig> {\n  // Load user config\n\n  let userConfig: UserConfig = {};\n  let userConfigMetadata: InternalConfig['userConfigMetadata'] | undefined;\n  if (inlineConfig.configFile !== false) {\n    const { config: loadedConfig, ...metadata } = await loadConfig<UserConfig>({\n      name: 'wxt',\n      cwd: inlineConfig.root ?? process.cwd(),\n      rcFile: false,\n    });\n    userConfig = loadedConfig ?? {};\n    userConfigMetadata = metadata;\n  }\n\n  // Merge it into the inline config\n\n  const mergedConfig = mergeInlineConfig(inlineConfig, userConfig);\n\n  // Apply defaults to make internal config.\n\n  const debug = mergedConfig.debug ?? false;\n  const logger = mergedConfig.logger ?? consola;\n  if (debug) logger.level = LogLevels.debug;\n\n  const browser = mergedConfig.browser ?? 'chrome';\n  const manifestVersion =\n    mergedConfig.manifestVersion ??\n    (browser === 'firefox' || browser === 'safari' ? 2 : 3);\n  const mode =\n    mergedConfig.mode ?? (command === 'build' ? 'production' : 'development');\n  const env: ConfigEnv = { browser, command, manifestVersion, mode };\n\n  const root = path.resolve(\n    inlineConfig.root ?? userConfig.root ?? process.cwd(),\n  );\n  const wxtDir = path.resolve(root, '.wxt');\n  const srcDir = path.resolve(root, mergedConfig.srcDir ?? root);\n  const entrypointsDir = path.resolve(\n    srcDir,\n    mergedConfig.entrypointsDir ?? 'entrypoints',\n  );\n  const publicDir = path.resolve(srcDir, mergedConfig.publicDir ?? 'public');\n  const typesDir = path.resolve(wxtDir, 'types');\n  const outBaseDir = path.resolve(root, '.output');\n  const outDir = path.resolve(outBaseDir, `${browser}-mv${manifestVersion}`);\n\n  const runnerConfig = await loadConfig<ExtensionRunnerConfig>({\n    name: 'web-ext',\n    cwd: root,\n    globalRc: true,\n    rcFile: '.webextrc',\n    overrides: inlineConfig.runner,\n    defaults: userConfig.runner,\n  });\n\n  const finalConfig: InternalConfig = {\n    browser,\n    command,\n    debug,\n    entrypointsDir,\n    env,\n    fsCache: createFsCache(wxtDir),\n    imports: mergedConfig.imports ?? {},\n    logger,\n    manifest: await resolveManifestConfig(env, mergedConfig.manifest),\n    manifestVersion,\n    mode,\n    outBaseDir,\n    outDir,\n    publicDir,\n    root,\n    runnerConfig,\n    srcDir,\n    typesDir,\n    vite: () => ({}), // Real value added after this object is initialized.\n    wxtDir,\n    zip: resolveInternalZipConfig(root, mergedConfig),\n    transformManifest(manifest) {\n      userConfig.transformManifest?.(manifest);\n      inlineConfig.transformManifest?.(manifest);\n    },\n    analysis: {\n      enabled: mergedConfig.analysis?.enabled ?? false,\n      template: mergedConfig.analysis?.template ?? 'treemap',\n    },\n    userConfigMetadata: userConfigMetadata ?? {},\n  };\n\n  finalConfig.vite = (env) =>\n    resolveInternalViteConfig(env, mergedConfig, finalConfig);\n\n  return finalConfig;\n}\n\nasync function resolveManifestConfig(\n  env: ConfigEnv,\n  manifest: UserManifest | Promise<UserManifest> | UserManifestFn | undefined,\n): Promise<UserManifest> {\n  return await (typeof manifest === 'function'\n    ? manifest(env)\n    : manifest ?? {});\n}\n\n/**\n * Merge the inline config and user config. Inline config is given priority. Defaults are not applied here.\n */\nfunction mergeInlineConfig(\n  inlineConfig: InlineConfig,\n  userConfig: UserConfig,\n): InlineConfig {\n  let imports: InlineConfig['imports'];\n  if (inlineConfig.imports === false || userConfig.imports === false) {\n    imports = false;\n  } else if (userConfig.imports == null && inlineConfig.imports == null) {\n    imports = undefined;\n  } else {\n    imports = vite.mergeConfig(\n      userConfig.imports ?? {},\n      inlineConfig.imports ?? {},\n    );\n  }\n  const manifest: UserManifestFn = async (env) => {\n    const user = await resolveManifestConfig(env, userConfig.manifest);\n    const inline = await resolveManifestConfig(env, inlineConfig.manifest);\n    return vite.mergeConfig(user, inline);\n  };\n  const viteConfig = async (env: ConfigEnv): Promise<WxtViteConfig> => {\n    const user = await userConfig.vite?.(env);\n    const inline = await inlineConfig.vite?.(env);\n    return vite.mergeConfig(user ?? {}, inline ?? {});\n  };\n  const runner: InlineConfig['runner'] = vite.mergeConfig(\n    userConfig.runner ?? {},\n    inlineConfig.runner ?? {},\n  );\n  const zip: InlineConfig['zip'] = vite.mergeConfig(\n    userConfig.zip ?? {},\n    inlineConfig.zip ?? {},\n  );\n\n  return {\n    root: inlineConfig.root ?? userConfig.root,\n    browser: inlineConfig.browser ?? userConfig.browser,\n    manifestVersion: inlineConfig.manifestVersion ?? userConfig.manifestVersion,\n    configFile: inlineConfig.configFile,\n    debug: inlineConfig.debug ?? userConfig.debug,\n    entrypointsDir: inlineConfig.entrypointsDir ?? userConfig.entrypointsDir,\n    imports,\n    logger: inlineConfig.logger ?? userConfig.logger,\n    manifest,\n    mode: inlineConfig.mode ?? userConfig.mode,\n    publicDir: inlineConfig.publicDir ?? userConfig.publicDir,\n    runner,\n    srcDir: inlineConfig.srcDir ?? userConfig.srcDir,\n    vite: viteConfig,\n    zip,\n    analysis: {\n      enabled: inlineConfig.analysis?.enabled ?? userConfig.analysis?.enabled,\n      template:\n        inlineConfig.analysis?.template ?? userConfig.analysis?.template,\n    },\n  };\n}\n\nfunction resolveInternalZipConfig(\n  root: string,\n  mergedConfig: InlineConfig,\n): InternalConfig['zip'] {\n  return {\n    sourcesTemplate: '{{name}}-{{version}}-sources.zip',\n    artifactTemplate: '{{name}}-{{version}}-{{browser}}.zip',\n    sourcesRoot: root,\n    ...mergedConfig.zip,\n    ignoredSources: [\n      '**/node_modules',\n      // WXT files\n      '**/web-ext.config.ts',\n      // Hidden files\n      '**/.*',\n      // Tests\n      '**/__tests__/**',\n      '**/*.+(test|spec).?(c|m)+(j|t)s?(x)',\n      // From user\n      ...(mergedConfig.zip?.ignoredSources ?? []),\n    ],\n  };\n}\n\nasync function resolveInternalViteConfig(\n  env: ConfigEnv,\n  mergedConfig: InlineConfig,\n  finalConfig: InternalConfig,\n) {\n  const internalVite: vite.InlineConfig =\n    (await mergedConfig.vite?.(env)) ?? {};\n\n  internalVite.root = finalConfig.root;\n  internalVite.configFile = false;\n  internalVite.logLevel = 'warn';\n  internalVite.mode = env.mode;\n\n  internalVite.build ??= {};\n  internalVite.build.outDir = finalConfig.outDir;\n  internalVite.build.emptyOutDir = false;\n\n  internalVite.plugins ??= [];\n  internalVite.plugins.push(plugins.download(finalConfig));\n  internalVite.plugins.push(plugins.devHtmlPrerender(finalConfig));\n  internalVite.plugins.push(plugins.unimport(finalConfig));\n  internalVite.plugins.push(\n    plugins.virtualEntrypoint('background', finalConfig),\n  );\n  internalVite.plugins.push(\n    plugins.virtualEntrypoint('content-script', finalConfig),\n  );\n  internalVite.plugins.push(\n    plugins.virtualEntrypoint('unlisted-script', finalConfig),\n  );\n  internalVite.plugins.push(plugins.devServerGlobals(finalConfig));\n  internalVite.plugins.push(plugins.tsconfigPaths(finalConfig));\n  internalVite.plugins.push(plugins.noopBackground());\n  if (finalConfig.analysis.enabled) {\n    internalVite.plugins.push(plugins.bundleAnalysis());\n  }\n  internalVite.plugins.push(plugins.globals(finalConfig));\n\n  return internalVite;\n}\n", "import fs, { ensureDir } from 'fs-extra';\nimport { FsCache } from '../types';\nimport { dirname, resolve } from 'path';\nimport { writeFileIfDifferent } from './fs';\n\n/**\n * A basic file system cache stored at `<srcDir>/.wxt/cache/<key>`. Just caches a string in a\n * file for the given key.\n *\n * @param srcDir Absolute path to source directory. See `InternalConfig.srcDir`\n */\nexport function createFsCache(wxtDir: string): FsCache {\n  const getPath = (key: string) =>\n    resolve(wxtDir, 'cache', encodeURIComponent(key));\n\n  return {\n    async set(key: string, value: string): Promise<void> {\n      const path = getPath(key);\n      await ensureDir(dirname(path));\n      await writeFileIfDifferent(path, value);\n    },\n    async get(key: string): Promise<string | undefined> {\n      const path = getPath(key);\n      try {\n        return await fs.readFile(path, 'utf-8');\n      } catch {\n        return undefined;\n      }\n    },\n  };\n}\n", "import fs from 'fs-extra';\n\n/**\n * Only write the contents to a file if it results in a change. This prevents unnecessary file\n * watchers from being triggered, like WXT's dev server or the TS language server in editors.\n *\n * @param file The file to write to.\n * @param newContents The new text content to write.\n */\nexport async function writeFileIfDifferent(\n  file: string,\n  newContents: string,\n): Promise<void> {\n  const existingContents = await fs\n    .readFile(file, 'utf-8')\n    .catch(() => undefined);\n\n  if (existingContents !== newContents) {\n    await fs.writeFile(file, newContents);\n  }\n}\n", "import * as vite from 'vite';\nimport {\n  unimport,\n  download,\n  tsconfigPaths,\n  globals,\n  webextensionPolyfillAlias,\n} from '../core/vite-plugins';\nimport { getInternalConfig } from '../core/utils/getInternalConfig';\nimport { InlineConfig } from '../core/types';\n\n/**\n * Vite plugin that configures Vitest with everything required to test a WXT extension, based on the `<root>/wxt.config.ts`\n *\n * ```ts\n * // vitest.config.ts\n * import { defineConfig } from 'vitest/config';\n * import { AutoImport } from 'wxt/testing';\n *\n * export default defineConfig({\n *   plugins: [AutoImport()],\n * });\n * ```\n *\n * @param inlineConfig Customize WXT's config for testing. Any config specified here overrides the config from your `wxt.config.ts` file.\n */\nexport function WxtVitest(inlineConfig?: InlineConfig): vite.PluginOption {\n  return getInternalConfig(inlineConfig ?? {}, 'serve').then((config) => [\n    webextensionPolyfillAlias(config),\n    unimport(config),\n    globals(config),\n    download(config),\n    tsconfigPaths(config),\n  ]);\n}\n"],
  "mappings": "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",
  "names": ["import_node_path", "normalizePath", "path", "path", "isOffline", "dns", "import_node_path", "import_path", "unimport", "import_fs_extra", "import_path", "normalizePath", "fs", "import_node_path", "path", "import_node_path", "vite", "import_fs_extra", "import_path", "import_fs_extra", "fs", "path", "fs", "consola", "path", "env"]
}

|