extension-develop 2.0.0-alpha.8 → 2.0.0-beta.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.
Files changed (37) hide show
  1. package/dist/ensure-hmr-for-scripts.js +2 -2
  2. package/dist/extensions/chrome-manager-extension/manifest.json +3 -3
  3. package/dist/extensions/{chromium-manager-extension → chromium-based-manager-extension}/manifest.json +3 -3
  4. package/dist/extensions/chromium-based-manager-extension/pages/welcome.html +49 -0
  5. package/dist/extensions/edge-manager-extension/manifest.json +3 -3
  6. package/dist/extensions/edge-manager-extension/pages/welcome.html +1 -1
  7. package/dist/extensions/firefox-manager-extension/manifest.json +3 -3
  8. package/dist/extensions/firefox-manager-extension/pages/welcome.html +1 -1
  9. package/dist/extensions/gecko-based-manager-extension/background.js +57 -0
  10. package/dist/extensions/gecko-based-manager-extension/define-initial-tab.js +62 -0
  11. package/dist/extensions/gecko-based-manager-extension/images/logo.png +0 -0
  12. package/dist/extensions/gecko-based-manager-extension/manifest.json +16 -0
  13. package/dist/extensions/gecko-based-manager-extension/pages/sakura-dark.css +268 -0
  14. package/dist/extensions/gecko-based-manager-extension/pages/sakura.css +267 -0
  15. package/dist/extensions/{chromium-manager-extension → gecko-based-manager-extension}/pages/welcome.html +1 -1
  16. package/dist/extensions/gecko-based-manager-extension/pages/welcome.js +34 -0
  17. package/dist/extensions/gecko-based-manager-extension/reload-service.js +130 -0
  18. package/dist/inject-chromium-client-loader.js +2 -2
  19. package/dist/inject-content-css-during-dev.js +3 -3
  20. package/dist/inject-firefox-client-loader.js +9 -2
  21. package/dist/module.d.ts +33 -6
  22. package/dist/module.js +112 -127
  23. package/dist/resolver-loader.js +1 -1
  24. package/dist/resolver-module.mjs +1 -0
  25. package/package.json +21 -25
  26. package/dist/add-query-param-to-imported-css.js +0 -1
  27. package/dist/resolver-module.js +0 -1
  28. /package/dist/extensions/chrome-manager-extension/{public → images}/logo.png +0 -0
  29. /package/dist/extensions/{chromium-manager-extension → chromium-based-manager-extension}/background.js +0 -0
  30. /package/dist/extensions/{chromium-manager-extension → chromium-based-manager-extension}/define-initial-tab.js +0 -0
  31. /package/dist/extensions/{chromium-manager-extension/public → chromium-based-manager-extension/images}/logo.png +0 -0
  32. /package/dist/extensions/{chromium-manager-extension → chromium-based-manager-extension}/pages/sakura-dark.css +0 -0
  33. /package/dist/extensions/{chromium-manager-extension → chromium-based-manager-extension}/pages/sakura.css +0 -0
  34. /package/dist/extensions/{chromium-manager-extension → chromium-based-manager-extension}/pages/welcome.js +0 -0
  35. /package/dist/extensions/{chromium-manager-extension → chromium-based-manager-extension}/reload-service.js +0 -0
  36. /package/dist/extensions/edge-manager-extension/{public → images}/logo.png +0 -0
  37. /package/dist/extensions/firefox-manager-extension/{public → images}/logo.png +0 -0
package/dist/module.js CHANGED
@@ -1,187 +1,172 @@
1
- "use strict";var wp=Object.create;var Ge=Object.defineProperty;var xp=Object.getOwnPropertyDescriptor;var vp=Object.getOwnPropertyNames;var _p=Object.getPrototypeOf,Sp=Object.prototype.hasOwnProperty;var Pp=(t,e)=>()=>(e||t((e={exports:{}}).exports,e),e.exports),kp=(t,e)=>{for(var s in e)Ge(t,s,{get:e[s],enumerable:!0})},Or=(t,e,s,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let i of vp(e))!Sp.call(t,i)&&i!==s&&Ge(t,i,{get:()=>e[i],enumerable:!(r=xp(e,i))||r.enumerable});return t};var a=(t,e,s)=>(s=t!=null?wp(_p(t)):{},Or(e||!t||!t.__esModule?Ge(s,"default",{value:t,enumerable:!0}):s,t)),Ep=t=>Or(Ge({},"__esModule",{value:!0}),t);var qs=Pp((_l,$p)=>{$p.exports={license:"MIT",repository:{type:"git",url:"https://github.com/cezaraugusto/extension.git",directory:"programs/develop"},engines:{node:">=18"},name:"extension-develop",version:"2.0.0-alpha.8",description:"The develop step of Extension.js",main:"./dist/module.js",types:"./dist/module.d.ts",files:["dist"],author:{name:"Cezar Augusto",email:"boss@cezaraugusto.net",url:"https://cezaraugusto.com"},scripts:{clean:"rm -rf dist",watch:"tsup-node ./module.ts --format cjs --dts --target=node18 --watch",compile:"tsup-node ./module.ts --format cjs --dts --target=node18 --minify && bash install_scripts.sh",test:"jest --no-cache --testPathPattern='webpack/.*/__spec__/.*\\.spec\\.ts'","test:coverage":"jest --no-cache --testPathPattern='webpack/.*/__spec__/.*\\.spec\\.ts' --coverage","test:build":"jest ./build.spec.ts --no-cache"},dependencies:{"@colors/colors":"^1.6.0","@swc/core":"^1.7.3","@types/firefox-webext-browser":"^120.0.4",acorn:"^8.12.1","acorn-walk":"^8.3.3","adm-zip":"^0.5.12",ajv:"^8.17.1",astring:"^1.8.6",axios:"^1.6.8","browser-extension-manifest-fields":"^1.0.6","case-sensitive-paths-webpack-plugin":"^2.4.0",chokidar:"^3.6.0","chrome-location":"^1.2.1","content-security-policy-parser":"^0.6.0","css-loader":"^6.10.0","csv-loader":"^3.0.5","detect-package-manager":"^3.0.2","dotenv-webpack":"^8.0.1","edge-location":"^1.0.0","firefox-profile":"^4.6.0","fx-runner":"^1.4.0","go-git-it":"2.0.4",ignore:"^5.3.1","loader-utils":"^3.3.1",micromatch:"^4.0.7","mini-css-extract-plugin":"^2.8.1",parse5:"^7.1.2","parse5-utils":"^2.0.0",postcss:"^8.4.40",progress:"^2.0.3","schema-utils":"^4.2.0",slugify:"^1.6.6","style-loader":"^3.3.4","swc-loader":"^0.2.6","tiny-glob":"^0.2.9","vue-template-compiler":"^2.7.16","webextension-polyfill":"^0.12.0",webpack:"~5.92.0","webpack-dev-server":"^5.0.2","webpack-merge":"^6.0.1","webpack-target-webextension":"^1.1.2"},devDependencies:{"@types/adm-zip":"^0.5.5","@types/case-sensitive-paths-webpack-plugin":"^2.1.9","@types/chrome":"^0.0.268","@types/dotenv-webpack":"^7.0.7","@types/jest":"^29.5.12","@types/loader-utils":"^2.0.6","@types/node":"^20.14.12","@types/webextension-polyfill":"^0.10.7",jest:"^29.7.0","ts-jest":"^29.1.2",tsup:"^8.0.1",typescript:"5.3.3"},optionalDependencies:{"@babel/core":"^7.24.9","@pmmmwh/react-refresh-webpack-plugin":"^0.5.15","@prefresh/webpack":"^4.0.1","@vue/compiler-sfc":"^3.4.34","babel-loader":"^9.1.3","babel-preset-modern-browser-extension":"^0.7.0",less:"^4.2.0","less-loader":"^12.2.0","postcss-flexbugs-fixes":"^5.0.2","postcss-loader":"^8.1.1","postcss-normalize":"^10.0.1","postcss-preset-env":"^9.6.0","postcss-scss":"^4.0.9","react-refresh":"^0.14.2","react-refresh-typescript":"^2.0.9","resolve-url-loader":"^5.0.0",sass:"^1.77.8","sass-loader":"^16.0.0",stylelint:"^16.7.0","stylelint-config-standard-scss":"^13.1.0","stylelint-webpack-plugin":"^5.0.1",tailwindcss:"^3.4.7","vue-loader":"^17.4.2","vue-style-loader":"^4.1.3","vue-template-compiler":"^2.7.16"}}});var bl={};kp(bl,{extensionBuild:()=>ep,extensionDev:()=>cp,extensionPreview:()=>mp,extensionStart:()=>bp});module.exports=Ep(bl);var Zc=a(require("fs")),Yc=a(require("path")),Kc=a(require("webpack")),Qc=require("webpack-merge");var ze=a(require("path"));var mi=a(require("case-sensitive-paths-webpack-plugin"));var V=a(require("fs")),M=a(require("path")),ui=a(require("dotenv-webpack"));var Us=a(require("path")),u=require("@colors/colors/safe");var Ar=a(require("path")),Xe=Ar.default.join(process.cwd(),"node_modules/extension-develop/dist/certs"),Se=["chrome","edge"],jp=["firefox"],xl=[...Se,...jp];function w(t,e){return e==="error"?`${t} ${(0,u.red)("\u2716\uFE0E\u2716\uFE0E\u2716\uFE0E")}`:`${e==="warn"?(0,u.brightYellow)("\u25BA\u25BA\u25BA"):e==="info"?(0,u.cyan)("\u25BA\u25BA\u25BA"):(0,u.brightGreen)("\u25BA\u25BA\u25BA")} ${t}`}function Mr(t){return t.charAt(0).toUpperCase()+t.slice(1)}function Tr(t,e){if(!!1)return`${e.hasErrors()?(0,u.red)("\u2716\uFE0E\u2716\uFE0E\u2716\uFE0E"):(0,u.brightGreen)("\u25BA\u25BA\u25BA")} Extension.js compiled ${e.hasErrors()?(0,u.red)("with errors"):(0,u.brightGreen)("successfully")} in ${t} ms.`}function Rr(t,e,s){return`${w(t,"info")} ${(0,u.magenta)(e)} Integration Found
1
+ "use strict";var Ap=Object.create;var rt=Object.defineProperty;var Rp=Object.getOwnPropertyDescriptor;var Tp=Object.getOwnPropertyNames;var Np=Object.getPrototypeOf,Up=Object.prototype.hasOwnProperty;var qp=(t,e)=>()=>(e||t((e={exports:{}}).exports,e),e.exports),Wp=(t,e)=>{for(var r in e)rt(t,r,{get:e[r],enumerable:!0})},zs=(t,e,r,s)=>{if(e&&typeof e=="object"||typeof e=="function")for(let i of Tp(e))!Up.call(t,i)&&i!==r&&rt(t,i,{get:()=>e[i],enumerable:!(s=Rp(e,i))||s.enumerable});return t};var a=(t,e,r)=>(r=t!=null?Ap(Np(t)):{},zs(e||!t||!t.__esModule?rt(r,"default",{value:t,enumerable:!0}):r,t)),Bp=t=>zs(rt({},"__esModule",{value:!0}),t);var qr=qp((ql,Jp)=>{Jp.exports={license:"MIT",repository:{type:"git",url:"https://github.com/cezaraugusto/extension.git",directory:"programs/develop"},engines:{node:">=18"},name:"extension-develop",version:"2.0.0-beta.0",description:"The develop step of Extension.js",main:"./dist/module.js",types:"./dist/module.d.ts",files:["dist"],author:{name:"Cezar Augusto",email:"boss@cezaraugusto.net",url:"https://cezaraugusto.com"},scripts:{clean:"rm -rf dist",watch:"tsup-node ./module.ts --format cjs --dts --target=node18 --watch",compile:"tsup-node ./module.ts --format cjs --dts --target=node18 --minify && bash install_scripts.sh",test:"jest --no-cache --testPathPattern='webpack/.*/__spec__/.*\\.spec\\.*'","test:coverage":"jest --no-cache --testPathPattern='webpack/.*/__spec__/.*\\.spec\\.ts' --coverage","test:build":"jest ./build.spec.ts --no-cache"},dependencies:{"@colors/colors":"^1.6.0","@swc/core":"^1.7.3","@types/firefox-webext-browser":"^120.0.4",acorn:"^8.12.1","acorn-walk":"^8.3.3","adm-zip":"^0.5.12",ajv:"^8.17.1",astring:"^1.8.6",axios:"^1.6.8","case-sensitive-paths-webpack-plugin":"^2.4.0",chokidar:"^3.6.0","chrome-location":"^1.2.1","content-security-policy-parser":"^0.6.0","cross-spawn":"^7.0.3","css-loader":"^6.10.0","csv-loader":"^3.0.5",dotenv:"^16.4.5","dotenv-webpack":"^8.0.1","edge-location":"^1.0.0","firefox-profile":"^4.6.0","fx-runner":"^1.4.0","go-git-it":"2.0.4",ignore:"^5.3.1","loader-utils":"^3.3.1",micromatch:"^4.0.7","mini-css-extract-plugin":"^2.8.1","package-manager-detector":"^0.2.0",parse5:"^7.1.2","parse5-utils":"^2.0.0",postcss:"^8.4.45",progress:"^2.0.3","schema-utils":"^4.2.0",slugify:"^1.6.6","style-loader":"^3.3.4","swc-loader":"^0.2.6","tiny-glob":"^0.2.9","vue-template-compiler":"^2.7.16","webextension-polyfill":"^0.12.0",webpack:"~5.92.0","webpack-dev-server":"^5.0.2","webpack-merge":"^6.0.1","webpack-target-webextension":"^1.1.2",which:"^4.0.0",ws:"^8.18.0"},devDependencies:{"@types/adm-zip":"^0.5.5","@types/case-sensitive-paths-webpack-plugin":"^2.1.9","@types/chrome":"^0.0.270","@types/cross-spawn":"^6.0.6","@types/dotenv-webpack":"^7.0.7","@types/jest":"^29.5.12","@types/loader-utils":"^2.0.6","@types/node":"^22.5.3","@types/webextension-polyfill":"^0.10.7","@types/ws":"^8.5.12",jest:"^29.7.0","ts-jest":"^29.1.2",tsup:"^8.0.1",typescript:"5.3.3"},optionalDependencies:{"@pmmmwh/react-refresh-webpack-plugin":"^0.5.15","@prefresh/webpack":"^4.0.1","babel-loader":"^9.1.3","less-loader":"^12.2.0","postcss-flexbugs-fixes":"^5.0.2","postcss-loader":"^8.1.1","postcss-normalize":"^10.0.1","postcss-preset-env":"^9.6.0","postcss-scss":"^4.0.9","react-refresh":"^0.14.2","react-refresh-typescript":"^2.0.9","resolve-url-loader":"^5.0.0","sass-loader":"^16.0.0","vue-loader":"^17.4.2","vue-style-loader":"^4.1.3","vue-template-compiler":"^2.7.16"}}});var Rl={};Wp(Rl,{extensionBuild:()=>hp,extensionDev:()=>$p,extensionPreview:()=>Fp,extensionStart:()=>Mp});module.exports=Bp(Rl);var mp=a(require("fs")),Rs=a(require("path")),dp=a(require("webpack")),gp=require("webpack-merge");var et=a(require("path"));var Si=a(require("case-sensitive-paths-webpack-plugin"));var zr=a(require("fs")),nt=a(require("path")),oe=require("webpack"),Jr=a(require("dotenv"));var Wr=a(require("path")),f=require("@colors/colors/safe");var Js=a(require("path")),st=Js.default.join(process.cwd(),"node_modules/extension-develop/dist/certs"),Q=["chrome","edge"],zp=["firefox"],Nl=[...Q,...zp];var Hs=require("console");function x(t,e){return e==="error"?`${(0,f.bold)((0,f.red)("ERROR"))} in ${t} ${(0,f.red)("\u2716\uFE0E\u2716\uFE0E\u2716\uFE0E")}`:e==="warn"?`${t} ${(0,f.brightYellow)("\u2716\uFE0E\u2716\uFE0E\u2716\uFE0E")}`:`${e==="info"?(0,f.cyan)("\u25BA\u25BA\u25BA"):(0,f.brightGreen)("\u25BA\u25BA\u25BA")} ${(0,f.cyan)(t)}`}function Vs(t){return t.charAt(0).toUpperCase()+t.slice(1)}function Gs(t,e,r){if(!!1)return`${r.hasErrors()?(0,f.red)("\u2716\uFE0E\u2716\uFE0E\u2716\uFE0E"):(0,f.brightGreen)("\u25BA\u25BA\u25BA")} ${(0,f.cyan)(t)} compiled ${r.hasErrors()?(0,f.red)("with errors"):(0,f.brightGreen)("successfully")} in ${e} ms.`}function Xs(t,e){return`${(0,Hs.info)("\u25BA\u25BA\u25BA")} Using ${(0,f.magenta)(t)}. Installing required dependencies via ${(0,f.brightYellow)(e)}...`}function Zs(){return`${(0,f.cyan)("\u25BA\u25BA\u25BA")} ${(0,f.magenta)(".env")} file loaded ${(0,f.brightGreen)("successfully")}.`}function S(t){return`${(0,f.cyan)("\u25BA\u25BA\u25BA")} Using ${(0,f.magenta)(t)}...`}function D(t){return`${x(t,"success")} installation completed. Run the program again and happy hacking.`}function Ks(t){return`${x(t,"info")} dependencies are being installed. This only happens for core contributors...`}function Ys(t){return`${x(t,"success")} dependencies installed ${(0,f.brightGreen)("successfully")}.`}function Qs(t,e){return`${x("Integration","error")} ${t} Installation Error
2
2
 
3
- Installing required setup dependencies via ${(0,u.brightYellow)(s)}. This is a one time operation...`}function Nr(t){return`${w(t,"info")} loaded ${(0,u.brightYellow)("env")} file successfully.`}function v(t,e){return`${w(t,"info")} is using ${(0,u.magenta)(e)}.`}function k(t,e){return`${w(t,"success")} You Are All Set
3
+ Failed to detect package manager or install ${t} dependencies:
4
+ ${(0,f.red)(e?.toString()||"")}`}function ei(){return`${x("Firefox runner","error")} No Service Worker Support
4
5
 
5
- Run the program again to start hacking with ${(0,u.magenta)(e)} support.`}function qr(t,e){return`${w(t,"info")} Installing Root Dependencies
6
+ Firefox does not support the ${(0,f.brightYellow)("background.service_worker")} field yet.
7
+ Update your manifest.json file to use ${(0,f.brightYellow)("background.scripts")} instead.
8
+ If you really need to keep the ${(0,f.brightYellow)("service_worker")} field, prefix it with
9
+ ${(0,f.brightYellow)("chromium:")} so it can target only Chromium-based browsers.
6
10
 
7
- Installing ${(0,u.magenta)(e)} dependencies in Extension.js root. This only happens for authors and contributors.`}function Ur(t,e){return`${w(t,"success")} ${e} Dependencies Installed ${(0,u.brightGreen)("Successfully")}.`}function Wr(t,e,s){return`${w(t,"error")} ${(0,u.magenta)(e)} Installation Error
11
+ Mozilla bug: ${(0,f.underline)("https://bugzilla.mozilla.org/show_bug.cgi?id=1573659")}.`}function ti(){return`${x("content-security-policy","error")} Insecure Content-Security-Policy
8
12
 
9
- Failed to detect package manager or install ${(0,u.magenta)(e)} dependencies: ${(0,u.red)(s?.toString()||"")}`}function Br(t){return`${w(t,"error")} No Service Worker Support
13
+ Manifest includes insecure content-security-policy value ${(0,f.brightYellow)("'unsafe-eval'")} in directive ${(0,f.brightBlue)("'script-src'")}.`}function ri(){return`${x("_locales","error")} No Default Locale Specified
10
14
 
11
- Firefox does not support the ${(0,u.brightYellow)("background.service_worker")} field yet.
12
- Update your manifest.json file to use ${(0,u.brightYellow)("background.scripts")} instead.
15
+ Localization used, but ${(0,f.brightYellow)("default_locale")} wasn't specified in the manifest.`}function xe(t){return t==="chrome"?(0,f.underline)("https://developer.chrome.com/docs/extensions/reference/manifest"):(0,f.underline)("https://developer.mozilla.org/en-US/docs/Mozilla/Add-ons/WebExtensions/manifest.json")}function si(t){return`${x("manifest.json","error")} Wrong Manifest Field Type
13
16
 
14
- Read more: ${(0,u.underline)("https://bugzilla.mozilla.org/show_bug.cgi?id=1573659")}.`}function Jr(t){return`${w(t,"error")} Insecure Content-Security-Policy
17
+ Field ${(0,f.brightYellow)("web_accessible_resources")} must be a string array in Manifest version 2.
15
18
 
16
- Manifest includes insecure content-security-policy value ${(0,u.brightYellow)("'unsafe-eval'")} in directive ${(0,u.brightBlue)("'script-src'")}.`}function zr(t){return`${w(t,"error")} No Default Locale Specified
19
+ Read more: ${xe(t)}`}function ii(t){return`${x("manifest.json","error")} Wrong Manifest Field Type
17
20
 
18
- Localization used, but ${(0,u.brightYellow)("default_locale")} wasn't specified in the manifest.`}function Pe(t){return t==="chrome"?(0,u.underline)("https://developer.chrome.com/docs/extensions/reference/manifest"):(0,u.underline)("https://developer.mozilla.org/en-US/docs/Mozilla/Add-ons/WebExtensions/manifest.json")}function Hr(t,e){return`${w(t,"error")} Wrong Manifest Field Type
21
+ Field ${(0,f.brightYellow)("web_accessible_resources")} must be an array of objects in Manifest version 3.
19
22
 
20
- Field ${(0,u.brightYellow)("web_accessible_resources")} must be a string array in Manifest version 2.
23
+ Read more: ${xe(t)}`}function oi(t,e){let s=e?.schemaPath?.split("/"),i=s?.slice(s.length-2).shift();return`${x("manifest.json","error")} Deprecated Field
21
24
 
22
- Read more: ${Pe(e)}`}function Vr(t,e){return`${w(t,"error")} Wrong Manifest Field Type
25
+ Field ${(0,f.brightYellow)(i||"")} is deprecated in Manifest V3. Update your manifest.json file to run your extension.
23
26
 
24
- Field ${(0,u.brightYellow)("web_accessible_resources")} must be an array of objects in Manifest version 3.
27
+ Read more: ${xe(t)}`}function ni(t,e){let r=t?.instancePath.replaceAll("/",".").slice(1)||"",s=t?.params.type;return`${x("manifest.json","error")} Invalid Manifest Field
25
28
 
26
- Read more: ${Pe(e)}`}function Gr(t,e,s){let i=s?.schemaPath?.split("/"),n=i?.slice(i.length-2).shift();return`${w(t,"error")} Deprecated Field
29
+ Field ${(0,f.brightYellow)(r)} must be of type ${(0,f.brightBlue)(s)}.
27
30
 
28
- Field ${(0,u.brightYellow)(n||"")} is deprecated in Manifest V3. Update your manifest.json file to run your extension.
31
+ Read more: ${xe(e)}`}function ai(t,e){return`${x("manifest.json","error")} Missing Required Manifest Field
29
32
 
30
- Read more: ${Pe(e)}`}function Xr(t,e,s){let r=e?.instancePath.replaceAll("/",".").slice(1)||"",i=e?.params.type;return`${w(t,"error")} Invalid Manifest Field
33
+ Field ${(0,f.brightYellow)(e||"")} is required. Update your manifest.json file to run your extension.
31
34
 
32
- Field ${(0,u.brightYellow)(r)} must be of type ${(0,u.brightBlue)(i)}.
35
+ Read more: ${xe(t)}`}function ci(t,e){let r=e.split(".").pop(),s=`${x(t,"error")} Content Script Import
33
36
 
34
- Read more: ${Pe(s)}`}function Zr(t,e,s){return`${w(t,"error")} Missing Required Manifest Field
35
-
36
- Field ${(0,u.brightYellow)(s||"")} is required. Update your manifest.json file to run your extension.
37
-
38
- Read more: ${Pe(e)}`}function Yr(t,e){let s=e.split(".").pop(),r=`${w(t,"error")} Content Script Import
39
-
40
- One of your ${s?.toUpperCase()} imports is also a content_script CSS in manifest.json.
41
- Remove the duplicate entry and try again.`;if(e.startsWith("content_scripts"))return r}function Kr(t){return`${w(t,"error")} Top Level Await In Non-ECMAScript Module
37
+ One of your ${r?.toUpperCase()} imports is also a ${(0,f.brightYellow)("content_script")} CSS in manifest.json.
38
+ Remove the duplicate entry and try again.`;if(e.startsWith("content_scripts"))return s}function pi(t){return`${x(t,"error")} Top Level Await In Non-ECMAScript Module
42
39
 
43
40
  Top-level await is only supported in ECMAScript modules.
44
- To use it in your extension, make sure to set ${(0,u.brightYellow)('"type": "module"')}
45
- in your package.json or use the ${(0,u.brightYellow)(".mjs")} extension for your script files.`}function Ze(t,e,s){if(!e)throw new Error("This operation is impossible. Please report a bug.");switch(Us.default.extname(s)){case".js":case".ts":case".jsx":case".tsx":return Cp(t,e,s);case".css":case".scss":case".sass":case".less":return Dp(t,e,s);default:return Fp(t,e,s)}}function ae(t,e,s){let r=e.startsWith("content_scripts")?"content_scripts":e.replace("/","."),i=e.split("-")[1],n=e.startsWith("pages"),o=t.includes("content_scripts")?`(index ${i})
46
-
47
- `:r;return`${w(t,"error")} File Not Found
48
-
49
- ${n?`Check the ${(0,u.brightYellow)("pages")} folder in your project root directory.
50
-
51
- `:`Check the ${(0,u.brightYellow)(o)} field in your manifest.json file.
41
+ To use it in your extension, make sure to set ${(0,f.brightYellow)('"type": "module"')}
42
+ in your package.json or use the ${(0,f.brightYellow)(".mjs")} extension for your script files.`}function it(t,e){if(!t)throw new Error("This operation is impossible. Please report a bug.");switch(Wr.default.extname(e)){case".js":case".ts":case".jsx":case".tsx":return Hp(t,e);case".css":case".scss":case".sass":case".less":return Vp(t,e);default:return Gp(t,e)}}function ie(t,e,r){let s=e.startsWith("content_scripts")?"content_scripts":e.replace("/","."),i=e.split("-")[1],o=e.startsWith("pages"),n=t.includes("content_scripts")?`(index ${i})
52
43
 
53
- `}${(0,u.red)("NOT FOUND")} ${(0,u.underline)(s)}`}function Ye(t,e,s){return`${w(t,"error")} File Not Found
44
+ `:s;return`${x("manifest.json","error")} File Not Found
54
45
 
55
- Check the ${(0,u.brightYellow)(e)} field in your manifest.json file.
46
+ ${o?`Check the ${(0,f.brightYellow)("pages")} folder in your project root directory.
47
+ `:`Check the ${(0,f.brightYellow)(n)} field in your manifest.json file.
48
+ `}${(0,f.red)("NOT FOUND")} ${(0,f.underline)(r)}`}function ot(t,e){return`File Not Found
56
49
 
57
- ${(0,u.red)("NOT FOUND")} ${(0,u.underline)(s)}`}function Qr(t){return`${w(t,"error")} Manifest Not Found
50
+ Check the ${(0,f.brightYellow)(t)} field in your manifest.json file.
51
+ ${(0,f.red)("NOT FOUND")} ${(0,f.underline)(e)}`}function li(t,e){return`${x(t,"error")} Manifest Not Found
58
52
 
59
- Ensure you have a manifest.json file at the root directory of your project.`}function ei(t,e){return`${w(t,"error")} Invalid Manifest
53
+ Ensure you have a manifest.json file at the root directory of your project.
54
+ ${(0,f.red)("NOT FOUND")} ${(0,f.underline)(e)}`}function fi(t){return`${x("manifest.json","error")} Invalid Manifest
60
55
 
61
- Update your manifest.json file and try again. `+e}function ti(t,e){let s=e&&`${(0,u.gray)("PATH")} ${(0,u.red)("REMOVED")} ${(0,u.underline)(e)}
62
- `,r=t&&`${(0,u.gray)("PATH")} ${(0,u.brightGreen)("ADDED")} ${(0,u.underline)(t)}`;return`Manifest Entry Point Modification
56
+ Update your manifest.json file and try again. `+(0,f.red)(t.toString())}function ui(t,e){let r=e&&`${(0,f.gray)("PATH")} ${(0,f.red)("REMOVED")} ${(0,f.underline)(e)}
57
+ `,s=t&&`${(0,f.gray)("PATH")} ${(0,f.brightGreen)("ADDED")} ${(0,f.underline)(t)}`;return`$manifest.json ${(0,f.red)("\u2716\uFE0E\u2716\uFE0E\u2716\uFE0E")} Manifest Entry Point Modification
63
58
 
64
- Changing the path of ${(0,u.brightYellow)("<script>")} or ${(0,u.brightYellow)('<link rel="stylesheet">')} files after compilation requires a server restart.
59
+ Changing the path of ${(0,f.brightYellow)("HTML")} or ${(0,f.brightYellow)("script")} files in manifest.json after compilation requires a server restart.
60
+ `+r+s}function mi(t,e,r,s,i){let o=t.charAt(0).toUpperCase()+t.slice(1);return`${x("manifest.json","error")} Manifest Entry Point Modification
65
61
 
66
- `+s+r}function si(t,e,s,r,i){let n=t.charAt(0).toUpperCase()+t.slice(1);return`${w("manifest.json","error")} Manifest Entry Point Modification
67
-
68
- ${n} ${(0,u.brightYellow)(r)} in the ${(0,u.underline)(s+"/")} folder after compilation requires a server restart.
69
-
70
- ${(0,u.gray)("PATH")} ${(0,u.underline)(i)}`}function ri(t){return`${w(t,"warn")}`+v(t,"TypeScript").replace(".",`but no config file was found. Creating ${(0,u.brightYellow)("tsconfig.json")}...`)}function Ws(t,e,s){let r=t.name||"Extension.js",i;switch(e){case"chrome":i="chrome://extensions";break;case"edge":i="edge://extensions";break;case"firefox":i="about:debugging#/runtime/this-firefox";break;default:i=""}if(!s.data)return`
71
-
72
- ${(0,u.bold)((0,u.red)("ERROR"))} in ${w(r,"error")} No data received from the extension client.
62
+ ${o} ${(0,f.brightYellow)(s)} in the ${(0,f.underline)(r+"/")} folder after compilation requires a server restart.
63
+ ${(0,f.gray)("PATH")} ${(0,f.underline)(i)}`}function di(){return`${x("TypeScript","info")} is being used but no config file was found. Creating ${(0,f.brightYellow)("tsconfig.json")}...`}function Br(t,e,r){let s=t.name||"Extension.js",i;switch(e){case"chrome":i="chrome://extensions";break;case"edge":i="edge://extensions";break;case"firefox":i="about:debugging#/runtime/this-firefox";break;default:i=""}if(!r.data)return`${x(s,"error")} No Client Data Received
73
64
 
74
65
  This error happens when the program can't get the data from your extension.
75
66
  There are many reasons this might happen. To fix, ensure that:
76
67
 
77
- - Your extension is set as enabled in ${(0,u.underline)(i)}- No previous ${Mr(e)} browser instance is open
78
- If that is not the case, restart the both ${(0,u.cyan)(t.name||"")} the ${(0,u.brightYellow)("Manager Extension")} in ${(0,u.underline)(i)} and try again.
79
-
80
- If nothing helps and the issue persists, please report a bug:
81
-
82
- `+(0,u.underline)("https://github.com/extension-js/extension.js/issues");let{id:n,management:o}=s.data;if(!o&&process.env.EXTENSION_ENV==="development")return`${w(r,"error")} No management API info received from client. Investigate.`;let{name:c,version:p}=o,l=qs().version;return`
83
- \u{1F9E9} ${(0,u.brightGreen)("Extension.js")} ${(0,u.gray)(`${l}`)}
84
- Extension Name ${(0,u.gray)(c)}
85
- Extension Version ${(0,u.gray)(p)}
86
- Extension ID ${(0,u.gray)(n)}`}function ii(t){return`This is your first run using Extension.js via ${Mr(t)}. Welcome! \u{1F389}
87
-
88
- \u{1F9E9} Learn more at ${(0,u.underline)("https://extension.js.org")}`}function ni(t,e){return`${w(t,"error")} WebSocket: ${e}`}function oi(t,e,s){return`
68
+ - Your extension is set as enabled in ${(0,f.underline)(i)}
69
+ - No previous ${Vs(e)} browser instance is open
89
70
 
90
- ${(0,u.bold)((0,u.red)("ERROR"))} in ${w(t,"error")} File Not Found
71
+ If that is not the case, restart both the ${(0,f.cyan)(t.name||"")} and the
72
+ ${(0,f.brightYellow)("Manager Extension")} in ${(0,f.underline)(i)} and try again.
91
73
 
92
- Check the ${(0,u.brightYellow)(e.replace("/","."))} field in your manifest.json file.
74
+ If the issue still persists, please report a bug:
93
75
 
94
- ${(0,u.red)("NOT FOUND")} ${(0,u.underline)(s)}}`}function ai(t,e){return`${w(t,"error")} HTML Entry Point Modification
76
+ `+(0,f.underline)("https://github.com/extension-js/extension.js/issues");let{id:o,management:n}=r.data;if(!n&&process.env.EXTENSION_ENV==="development")return`${x(s,"error")} No management API info received from client. Investigate.`;let{name:c,version:p}=n,l=qr().version;return`
77
+ \u{1F9E9} ${(0,f.brightGreen)("Extension.js")} ${(0,f.gray)(`${l}`)}
78
+ Extension Name ${(0,f.gray)(c)}
79
+ Extension Version ${(0,f.gray)(p)}
80
+ Extension ID ${(0,f.gray)(o)}`}function gi(t){return`This is your first run using Extension.js via ${Vs(t)}. Welcome! \u{1F389}
95
81
 
96
- Changing the path of ${(0,u.brightYellow)("<script>")} or ${(0,u.brightYellow)('<link rel="stylesheet">')} files after compilation requires a server restart.
82
+ \u{1F9E9} Learn more at ${(0,f.underline)("https://extension.js.org")}`}function hi(t){return`${x("WebSocket","error")} General WebSocket Error:
83
+ ${(0,f.red)(t)}`}function yi(t,e){return`${x("manifest.json","error")} File Not Found
97
84
 
98
- ${(0,u.gray)("PATH")} ${e}`}function Cp(t,e,s){return`${w(t,"error")} File Not Found
85
+ Check the ${(0,f.brightYellow)(t.replace("/","."))} field in your manifest.json file.
86
+ ${(0,f.red)("NOT FOUND")} ${(0,f.underline)(e)}`}function bi(t){return`${x("HTML","error")} Entry Point Modification
99
87
 
100
- Check your ${(0,u.brightYellow)("<script>")} tags in ${(0,u.underline)(e)}.
88
+ Changing the path of ${(0,f.brightYellow)("<script>")} or ${(0,f.brightYellow)('<link rel="stylesheet">')} files after compilation requires a server restart.
89
+ ${(0,f.gray)("PATH")} ${(0,f.underline)(t)}`}function Hp(t,e){return`${x("HTML","error")} File Not Found
101
90
 
102
- ${(0,u.red)("NOT FOUND")} ${(0,u.underline)(s)}`}function Dp(t,e,s){return`${w(t,"error")} File Not Found
91
+ Check your ${(0,f.brightYellow)("<script>")} tags in ${(0,f.underline)(t)}.
92
+ ${(0,f.red)("NOT FOUND")} ${(0,f.underline)(e)}`}function Vp(t,e){return`${x("HTML","error")} File Not Found
103
93
 
104
- Check your ${(0,u.brightYellow)("<link>")} tags in ${(0,u.underline)(e)}.
94
+ Check your ${(0,f.brightYellow)("<link>")} tags in ${(0,f.underline)(t)}.
95
+ ${(0,f.red)("NOT FOUND")} ${(0,f.underline)(e)}`}function Gp(t,e){let r=Wr.default.extname(e);return`${x("HTML","warn")} File Not Found
105
96
 
106
- ${(0,u.red)("NOT FOUND")} ${(0,u.underline)(s)}`}function Fp(t,e,s){let r=Us.default.extname(s);return`${w(t,"error")} File Not Found
107
-
108
- Check your ${(0,u.brightYellow)("*"+r)} assets in ${(0,u.underline)(e)}.
109
-
110
- ${(0,u.red)("NOT FOUND")} ${(0,u.underline)(s)}`}function ci(){return`${(0,u.brightYellow)("Note")}: Firefox requires a secure certificate for localhost connections, needed for the reloader to work.
111
- By default, your ${(0,u.brightYellow)("manifest.json")} file is not being watched. To enable this feature, run:
97
+ Check your ${(0,f.brightYellow)("*"+r)} assets in ${(0,f.underline)(t)}.
98
+ ${(0,f.red)("NOT FOUND")} ${(0,f.underline)(e)}`}function wi(){return`${(0,f.brightYellow)("Note")}: Firefox requires a secure certificate for localhost connections, needed for the reloader to work.
99
+ By default, your manifest.json file is not being watched. To enable this feature, run:
112
100
 
113
101
  npx -y mkcert-cli \\
114
- ${(0,u.brightGreen)("--outDir")} ${(0,u.underline)(Xe)} \\
115
- ${(0,u.brightGreen)("--cert")} ${(0,u.brightYellow)("localhost.cert")} \\
116
- ${(0,u.brightGreen)("--key")} ${(0,u.brightYellow)("localhost.key")}
117
-
118
- This will enable the secure certificate needed for Firefox via ${(0,u.bold)("mkcert")}.
102
+ ${(0,f.brightGreen)("--outDir")} ${(0,f.underline)(st)} \\
103
+ ${(0,f.brightGreen)("--cert")} ${(0,f.brightYellow)("localhost.cert")} \\
104
+ ${(0,f.brightGreen)("--key")} ${(0,f.brightYellow)("localhost.key")}
119
105
 
120
- Learn more about ${(0,u.bold)("mkcert")}: ${(0,u.underline)("https://github.com/FiloSottile/mkcert")}`}function pi(t,e){return`${w(t,"error")} Default port ${e} in use, choose a new port. `}function li(t){return`${w(t,"error")} No Extension Id Specified
106
+ This will enable the secure certificate needed for Firefox via ${(0,f.bold)("mkcert")}.
121
107
 
122
- For MAIN world content scripts, you must specify an extension ID.
123
- Otherwise, the content script won't reload on changes.
124
- Add an ${(0,u.brightYellow)("id")} field to your manifest.json file and try again.`}var Ke=class{manifestPath;constructor(e){this.manifestPath=e.manifestPath}apply(e){let s=M.default.dirname(this.manifestPath),i=require(this.manifestPath).name||"Extension.js";(V.default.existsSync(M.default.join(s,".env"))||V.default.existsSync(M.default.join(s,".env.example"))||V.default.existsSync(M.default.join(s,".env.local"))||V.default.existsSync(M.default.join(s,".env.defaults")))&&(console.log(Nr(i)),new ui.default({path:V.default.existsSync(M.default.join(s,".env"))?M.default.join(s,".env"):V.default.existsSync(M.default.join(s,".env.local"))?M.default.join(s,".env.local"):M.default.join(s,".env.example"),allowEmptyValues:!0,defaults:V.default.existsSync(M.default.join(s,".env.defaults")),systemvars:!0}).apply(e))}};var Bs=a(require("fs")),fi=a(require("path")),Qe=class{apply(e){let s=fi.default.join(e.options.output.path||"","hot");Bs.default.existsSync(s)&&(Bs.default.rmSync(s,{recursive:!0,force:!0}),process.env.EXTENSION_ENV==="development"&&console.log("[CleanHotUpdatesPlugin] Removed old hot-update files before compilation."))}};var et=class{static name="plugin-compilation";manifestPath;constructor(e){this.manifestPath=e.manifestPath}apply(e){new mi.default().apply(e),new Ke({manifestPath:this.manifestPath}).apply(e),new Qe().apply(e),e.hooks.done.tap("develop:brand",s=>{s.compilation.name=void 0;let r=s.endTime-s.startTime;console.log(Tr(r,s))})}};var Oi=a(require("path")),Ai=a(require("mini-css-extract-plugin"));var Ci=a(require("mini-css-extract-plugin"));var ce=a(require("path")),Ee=a(require("fs"));var ke=a(require("path")),tt=a(require("fs")),Js=require("child_process"),di=require("detect-package-manager");function gi(t,e){return Object.values(e||{}).some(s=>s===t)}function g(t,e,s){let r=ke.default.extname(e),n=S(e,s)?ke.default.normalize(e):t;return[".js",".jsx",".tsx",".ts"].includes(r)&&(n=n.replace(r,".js")),[".html",".njk",".nunjucks"].includes(r)&&(n=n.replace(r,".html")),[".css",".scss",".sass",".less"].includes(r)&&(n=n.replace(r,".css")),zs(n||"")}function zs(t){return t.replace(/\\/g,"/")}function S(t,e={}){if(!e)return!1;let s=zs(t);return Object.values(e).some(i=>{if(typeof i!="string")return!1;let n=zs(i).replace(/\/$/,"");return s.includes(n)})}function G(t,e){if(t.getAsset("manifest.json")||t.assets["manifest.json"]){let s=t.assets["manifest.json"].source().toString();return JSON.parse(s||"{}")}return require(e)}async function _(t,e,s){try{let r=await(0,di.detect)();console.log(Rr(t,e,r));let i="";r==="yarn"?i=`yarn --silent add ${s.join(" ")} --cwd ${__dirname} --optional`:r==="npm"?i=`npm --silent install ${s.join(" ")} --prefix ${__dirname} --save-optional`:r==="pnpm"?i=`pnpm --silent add ${s.join(" ")} --prefix ${__dirname} --save-optional`:i=`${r} --silent install ${s.join(" ")} --cwd ${__dirname} --optional`,(0,Js.execSync)(i,{stdio:"inherit"}),await new Promise(n=>setTimeout(n,2e3)),process.env.EXTENSION_ENV==="development"&&(console.log(qr(t,e)),r==="yarn"?i="yarn install --silent > /dev/null 2>&1":r==="npm"?i="npm install --silent > /dev/null 2>&1":r==="pnpm"?i="pnpm install --silent > /dev/null 2>&1":i=`${r} install --silent > /dev/null 2>&1`,(0,Js.execSync)(i,{stdio:"inherit"})),console.log(Ur(t,e))}catch(r){console.error(Wr(t,e,r))}}function st(t){let e=ke.default.join(t,"package.json");if(!tt.default.existsSync(e))return!1;let s=JSON.parse(tt.default.readFileSync(e,"utf-8")),r=["react","vue","@angular/core","svelte","solid-js","preact"],i=s.dependencies||{},n=s.devDependencies||{};for(let o of r)if(i[o]||n[o])return!0;return!1}function hi(t){return!tt.default.existsSync(ke.default.resolve(__dirname,`run-${t}-profile`))}function yi(t){let e=t.name?.replace(/ /g,"-").toLowerCase();return{data:{id:`${e}@extension-js`,manifest:t,management:{id:`${e}@extension-js`,mayDisable:!0,optionsUrl:"",installType:"development",type:"extension",enabled:!0,name:t.name||"",description:t.description||"",version:t.version||"",hostPermissions:t.host_permissions||[],permissions:t.permissions||[],offlineEnabled:t.offline_enabled||!1,shortName:t.short_name||"",isApp:t.app&&t.app.background&&t.app.background.scripts}}}}function rt(t,e){return JSON.parse(JSON.stringify(t),function(i,n){let o=i.indexOf(":");if(o===-1)return n;let c=i.substring(0,o);(c===e||c==="chromium"&&Se.includes(e))&&(this[i.substring(o+1)]=n)})}var bi=!1;function it(t){let e=ce.default.join(t,"package.json"),s=ce.default.join(t,"manifest.json");if(!Ee.default.existsSync(e))return!1;let r=Lp(t),i=require(e),n=i.devDependencies&&i.devDependencies.tailwindcss,o=i.dependencies&&i.dependencies.tailwindcss,c=!!r&&!!(n||o);if(c&&!bi){let l=require(s).name||"Extension.js";process.env.EXTENSION_ENV==="development"&&console.log(v(l,"Tailwind")),bi=!0}return c}function Lp(t){let e=ce.default.join(t,"tailwind.config.mjs"),s=ce.default.join(t,"tailwind.config.cjs"),r=ce.default.join(t,"tailwind.config.js");if(Ee.default.existsSync(e))return e;if(Ee.default.existsSync(s))return s;if(Ee.default.existsSync(r))return r}var nt=a(require("path")),xi=a(require("fs"));var wi=!1;function je(t){let e=nt.default.join(t,"package.json"),s=nt.default.join(t,"manifest.json");if(!xi.default.existsSync(e))return!1;let r=require(e),i=r.devDependencies&&r.devDependencies.sass,n=r.dependencies&&r.dependencies.sass;if(i||n){if(!wi){let c=require(s).name||"Extension.js";process.env.EXTENSION_ENV==="development"&&console.log(v(c,"SASS")),wi=!0}return!0}return!1}async function vi(t,e){if(!je(t))return[];try{require.resolve("sass-loader")}catch{let r=["postcss-loader","postcss-scss","postcss-flexbugs-fixes","postcss-preset-env","postcss-normalize"],i=require(nt.default.join(t,"package.json")).name;await _(i,"PostCSS",r),await _(i,"SASS",["sass","sass-loader","resolve-url-loader"]),console.log(k(i,"SASS")),process.exit(0)}return[{test:/\.(s(a|c)ss)$/,exclude:/\.module\.(s(a|c)ss)$/,oneOf:[{resourceQuery:/is_content_css_import=true/,use:await A(t,{loader:"sass-loader",mode:e,useMiniCssExtractPlugin:!1})},{use:await A(t,{loader:"sass-loader",mode:e,useMiniCssExtractPlugin:e==="production"})}]},{test:/\.module\.(s(a|c)ss)$/,oneOf:[{resourceQuery:/is_content_css_import=true/,use:await A(t,{loader:"sass-loader",mode:e,useMiniCssExtractPlugin:!1})},{use:await A(t,{loader:"sass-loader",mode:e,useMiniCssExtractPlugin:!0})}]}]}var ot=a(require("path")),Si=a(require("fs"));var _i=!1;function $e(t){let e=ot.default.join(t,"package.json"),s=ot.default.join(t,"manifest.json"),i=require(s).name||"Extension.js";if(!Si.default.existsSync(e))return!1;let n=require(e),o=n.devDependencies&&n.devDependencies.less,c=n.dependencies&&n.dependencies.less;return o||c?(_i||(process.env.EXTENSION_ENV==="development"&&console.log(v(i,"LESS")),_i=!0),!0):!1}async function Pi(t,e){if(!$e(t))return[];try{require.resolve("less-loader")}catch{let r=require(ot.default.join(t,"package.json")).name;await _(r,"LESS",["less","less-loader","resolve-url-loader"]),console.log(k(r,"LESS")),process.exit(0)}return[{test:/\.less$/,oneOf:[{resourceQuery:/is_content_css_import=true/,use:await A(t,{loader:"less-loader",mode:e,useMiniCssExtractPlugin:!1})},{use:await A(t,{loader:"less-loader",mode:e,useMiniCssExtractPlugin:e==="production"})}]}]}var le=a(require("path")),at=a(require("fs"));var pe=!1;function Ip(t){let e=le.default.join(t,"package.json"),s=le.default.join(t,"manifest.json");if(!at.default.existsSync(e))return!1;let r=[".postcssrc",".postcssrc.json",".postcssrc.yaml",".postcssrc.yml",".postcssrc.js",".postcssrc.cjs","postcss.config.js","postcss.config.cjs"],n=require(s).name||"Extension.js";if(at.default.existsSync(e)){let o=require(e);if(o.dependencies&&o.dependencies.postcss||o.devDependencies&&o.devDependencies.postcss)return pe||(process.env.EXTENSION_ENV==="development"&&console.log(v(n,"PostCSS")),pe=!0),!0}for(let o of r)if(at.default.existsSync(le.default.join(t,o)))return pe||(process.env.EXTENSION_ENV==="development"&&console.log(v(n,"PostCSS")),pe=!0),!0;return it(t)?(pe||(process.env.EXTENSION_ENV==="development"&&console.log(v(n,"PostCSS")),pe=!0),!0):!1}async function ki(t,e){if(!Ip(t))return{};try{require.resolve("postcss-loader")}catch{let r=require(le.default.join(t,"package.json")).name;!je(t)&&!$e(t)&&await _(r,"PostCSS",["postcss","postcss-loader","postcss-scss","postcss-flexbugs-fixes","postcss-preset-env","postcss-normalize"]),console.log(k(r,"PostCSS")),process.exit(0)}return{loader:require.resolve("postcss-loader"),options:{postcssOptions:{parser:require.resolve("postcss-scss"),ident:"postcss",config:le.default.resolve(t,"postcss.config.js"),plugins:[require.resolve("postcss-flexbugs-fixes"),[require.resolve("postcss-preset-env"),{autoprefixer:{flexbox:"no-2009"},stage:3}].filter(Boolean),require.resolve("postcss-normalize")].filter(Boolean)},sourceMap:e.mode==="development"}}}var ct=a(require("path")),ji=a(require("fs"));var Ei=!1;function Ce(t){let e=ct.default.join(t,"package.json"),s=ct.default.join(t,"manifest.json");if(!ji.default.existsSync(e))return!1;let r=require(e),i=r.devDependencies&&r.devDependencies.vue,n=r.dependencies&&r.dependencies.vue;if((i||n)&&!Ei){let c=require(s).name||"Extension.js";process.env.EXTENSION_ENV==="development"&&console.log(v(c,"Vue")),Ei=!0}return!!i||!!n}async function $i(t){if(!Ce(t))return;try{require.resolve("vue-loader")}catch{let i=["typescript"],o=require(ct.default.join(t,"manifest.json")).name||"Extension.js";await _(o,"TypeScript",i),await _(o,"Vue",["vue-loader","@vue/compiler-sfc","vue-template-compiler","vue-style-loader"]),console.log(k(o,"Vue")),process.exit(0)}let e=[{test:/\.vue$/,loader:require.resolve("vue-loader"),include:t,exclude:/node_modules/}];return{plugins:[new(require("vue-loader")).VueLoaderPlugin],loaders:e,alias:void 0}}async function A(t,e){let s=Ci.default.loader,r=[e.useMiniCssExtractPlugin?s:Ce(t)?require.resolve("vue-style-loader"):require.resolve("style-loader"),{loader:require.resolve("css-loader"),options:{importLoaders:1}}].filter(Boolean);if(it(t)||je(t)||$e(t)){let i=await ki(t,e);i.loader&&r.push(i)}return e.loader&&r.push({loader:require.resolve("resolve-url-loader"),options:{sourceMap:e.mode==="development",root:t}},{loader:require.resolve(e.loader),options:{sourceMap:e.mode==="development"}}),r.filter(Boolean)}var C=a(require("path")),T=a(require("fs"));function Li(t){let e=C.default.join(t,"stylelint.config.json"),s=C.default.join(t,".stylelintrc.js file"),r=C.default.join(t,"stylelint.config.mjs"),i=C.default.join(t,".stylelintrc.mjs"),n=C.default.join(t,"stylelint.config.cjs"),o=C.default.join(t,".stylelintrc.cjs"),c=C.default.join(t,".stylelintrc.json"),p=C.default.join(t,".stylelintrc"),l=C.default.join(t,".stylelintrc.yml"),f=C.default.join(t,".stylelintrc.yaml");if(T.default.existsSync(e))return e;if(T.default.existsSync(s))return s;if(T.default.existsSync(r))return r;if(T.default.existsSync(i))return i;if(T.default.existsSync(n))return n;if(T.default.existsSync(o))return o;if(T.default.existsSync(c))return c;if(T.default.existsSync(p))return p;if(T.default.existsSync(l))return l;if(T.default.existsSync(f))return f}var Di=!1;function Fi(t){let e=C.default.join(t,"package.json"),s=C.default.join(t,"manifest.json");if(!T.default.existsSync(e))return!1;let i=!!Li(t);if(i&&!Di){let o=require(s).name||"Extension.js";process.env.EXTENSION_ENV==="development"&&console.log(v(o,"Stylelint")),Di=!0}return i}async function Ii(t){if(!Fi(t))return[];try{require.resolve("stylelint")}catch{let r=["stylelint","stylelint-webpack-plugin","stylelint-config-standard-scss"],i=require(C.default.join(t,"package.json")).name;await _(i,"Stylelint",r),console.log(k(i,"Stylelint")),process.exit(0)}let e=require("stylelint-webpack-plugin");return[new e({context:t,configFile:Fi(t)?Li(t):C.default.join(__dirname,"stylelint.config.json"),files:"**/*.{css,scss,sass,less}",exclude:["node_modules",C.default.join(t,"node_modules")]})]}var pt=class t{static name="plugin-css";manifestPath;mode;constructor(e){this.manifestPath=e.manifestPath,this.mode=e.mode}async configureOptions(e){let s=Oi.default.dirname(this.manifestPath),r=[new Ai.default];r.forEach(p=>p.apply(e));let i=await Ii(s);r.push(...i);let n=[{test:/\.css$/,exclude:/\.module\.css$/,oneOf:[{resourceQuery:/is_content_css_import=true/,use:await A(s,{mode:this.mode,useMiniCssExtractPlugin:!1})},{use:await A(s,{mode:this.mode,useMiniCssExtractPlugin:this.mode==="production"})}]},{test:/\.module\.css$/,oneOf:[{resourceQuery:/is_content_css_import=true/,use:await A(s,{mode:this.mode,useMiniCssExtractPlugin:!1})},{use:await A(s,{mode:this.mode,useMiniCssExtractPlugin:this.mode==="production"})}]}];e.options.plugins=[...e.options.plugins,...r].filter(Boolean);let o=await vi(s,this.mode),c=await Pi(s,this.mode);n.push(...o),n.push(...c),e.options.module.rules=[...e.options.module.rules,...n].filter(Boolean)}async apply(e){if(this.mode==="production"){e.hooks.beforeRun.tapPromise(t.name,async()=>await this.configureOptions(e));return}await this.configureOptions(e)}};var lt=class{static name="plugin-css";manifestPath;mode;constructor(e){this.manifestPath=e.manifestPath,this.mode=e.mode}async apply(e){let s={test:/\.svg$/i,type:"asset/resource",generator:{filename:"assets/[name][ext]"},parser:{dataUrlCondition:{maxSize:2048}}},i=[...e.options.module.rules.some(n=>n&&n.test instanceof RegExp&&n.test.test(".svg")&&n.use!==void 0)?[]:[s],{test:/\.(png|jpg|jpeg|gif|webp|avif|ico|bmp)$/i,type:"asset/resource",generator:{filename:"assets/[name][ext]"},parser:{dataUrlCondition:{maxSize:2*1024}}},{test:/\.(woff|woff2|eot|ttf|otf)$/i,type:"asset/resource",generator:{filename:"assets/[name][ext]"}},{test:/\.(txt|md|csv|tsv|xml|pdf|docx|doc|xls|xlsx|ppt|pptx|zip|gz|gzip|tgz)$/i,type:"asset/resource",generator:{filename:"assets/[name][ext]"},parser:{dataUrlCondition:{maxSize:2*1024}}},{test:/\.(csv|tsv)$/i,use:[require.resolve("csv-loader")],generator:{filename:"assets/[name][ext]"}}];e.options.module.rules=[...e.options.module.rules,...i].filter(Boolean)}};var Hs=a(require("path"));var fe=a(require("path")),mt=a(require("fs"));var ut=a(require("path")),Ti=a(require("fs"));var Mi=!1;function X(t){let e=ut.default.join(t,"package.json"),s=ut.default.join(t,"manifest.json");if(!Ti.default.existsSync(e))return!1;let r=require(e),i=r.devDependencies&&r.devDependencies.preact,n=r.dependencies&&r.dependencies.preact;if((i||n)&&!Mi){let c=require(s).name||"Extension.js";process.env.EXTENSION_ENV==="development"&&console.log(v(c,"Preact")),Mi=!0}return!!i||!!n}async function Ri(t){if(!X(t))return;try{require.resolve("@prefresh/webpack")}catch{let r=["@prefresh/webpack"],n=require(ut.default.join(t,"manifest.json")).name||"Extension.js";await _(n,"Preact",r),console.log(k(n,"Preact")),process.exit(0)}return{plugins:[new(require("@prefresh/webpack"))],loaders:void 0,alias:{react:"preact/compat","react-dom/test-utils":"preact/test-utils","react-dom":"preact/compat","react/jsx-runtime":"preact/jsx-runtime"}}}var ue=a(require("path")),ft=a(require("fs"));var Ni=!1;function R(t){let e=ue.default.join(t,"package.json");if(!ft.default.existsSync(e))return!1;let s=Ap(t),r=require(e),i=require(ue.default.join(t,"manifest.json")),n=i.name||"Extension.js",o=r.devDependencies&&r.devDependencies.typescript,c=r.dependencies&&r.dependencies.typescript;return Ni||((o||c)&&(s?process.env.EXTENSION_ENV==="development"&&console.log(v(n,"TypeScript")):(console.log(ri(i)),Mp(t))),Ni=!0),!!s&&!!(o||c)}function Op(t,e){return{compilerOptions:{allowJs:!0,allowSyntheticDefaultImports:!0,esModuleInterop:!0,forceConsistentCasingInFileNames:!0,jsx:st(t)?"react-jsx":"preserve",lib:["dom","dom.iterable","esnext"],moduleResolution:"node",module:"esnext",resolveJsonModule:!0,strict:!0,target:"esnext",isolatedModules:!1,skipLibCheck:!0},exclude:["node_modules","dist"]}}function Ap(t){let e=ue.default.join(t,"tsconfig.json");if(ft.default.existsSync(e))return e}function Mp(t){ft.default.writeFileSync(ue.default.join(t,"tsconfig.json"),JSON.stringify(Op(t,{mode:"development"}),null,2))}async function qi(t){if(!R(t))return!1;try{require.resolve("typescript")}catch{let s=["typescript"],i=require(ue.default.join(t,"manifest.json")).name||"Extension.js";await _(i,"TypeScript",s),console.log(k(i,"TypeScript")),process.exit(0)}return!0}var Ui=!1,Wi=[".babelrc",".babelrc.json",".babelrc.js",".babelrc.cjs","babel.config.json","babel.config.js","babel.config.cjs"];function Tp(t){let e=fe.default.join(t,"package.json"),s=fe.default.join(t,"manifest.json");if(!mt.default.existsSync(e))return!1;let r=require(e),i=r.devDependencies&&r.devDependencies["babel-core"],n=r.dependencies&&r.dependencies["babel-core"],o=Wi.some(c=>mt.default.existsSync(fe.default.join(t,c)))||!!i||!!n;if(o&&!Ui){let p=require(s).name||"Extension.js";process.env.EXTENSION_ENV==="development"&&process.env.EXTENSION_ENV==="development"&&console.log(v(p,"Babel")),Ui=!0}return o}function Rp(t){for(let e of Wi){let s=fe.default.join(t,e);if(mt.default.existsSync(s))return s}}function Np(t,e){let s=require("babel-preset-modern-browser-extension").default;return{cacheDirectory:!1,cacheCompression:!1,babelrc:!1,configFile:Rp(t),compact:e.mode==="production",overrides:[s(e).overrides],presets:[...s(e).presets],plugins:[...s(e).plugins,process.env.NODE_ENV!=="test"&&e.mode==="development"&&X(t)&&require.resolve("react-refresh/babel")].filter(Boolean)}}async function Bi(t,e){if(!Tp(e))return;try{require.resolve("babel-loader")}catch{let o=["@babel/core","babel-loader","babel-preset-modern-browser-extension"],p=require(fe.default.join(e,"manifest.json")).name||"Extension.js";await _(p,"Babel",o),console.log(k(p,"Babel")),process.exit(0)}let s=R(e)?/\.(js|mjs|jsx|mjsx|ts|mts|tsx|mtsx)$/:/\.(js|mjs|jsx|mjsx)$/,r=t.options.mode,i=await qi(e);return{plugins:void 0,loaders:[{test:s,include:e,exclude:/node_modules/,loader:require.resolve("babel-loader"),options:Np(e,{mode:r,typescript:i})}],alias:void 0}}var dt=a(require("path")),zi=a(require("fs"));var Ji=!1;function me(t){let e=dt.default.join(t,"package.json"),s=dt.default.join(t,"manifest.json");if(!zi.default.existsSync(e))return!1;let r=require(e),i=r.devDependencies&&r.devDependencies.react,n=r.dependencies&&r.dependencies.react;if((i||n)&&!Ji){let c=require(s).name||"Extension.js";process.env.EXTENSION_ENV==="development"&&console.log(v(c,"React")),Ji=!0}return!!i||!!n}async function Hi(t){if(!me(t))return;try{require.resolve("@pmmmwh/react-refresh-webpack-plugin")}catch{let r=["react-refresh","@pmmmwh/react-refresh-webpack-plugin","react-refresh-typescript"],n=require(dt.default.join(t,"manifest.json")).name||"Extension.js";await _(n,"React",r),console.log(k(n,"React")),process.exit(0)}return{plugins:[new(require("@pmmmwh/react-refresh-webpack-plugin"))({overlay:!1})],loaders:void 0,alias:void 0}}var gt=class t{static name="plugin-js-frameworks";manifestPath;mode;constructor(e){this.manifestPath=e.manifestPath,this.mode=e.mode}async configureOptions(e){let s=Hs.default.dirname(this.manifestPath),r=await Bi(e,s),i=await Hi(s),n=await Ri(s),o=await $i(s);e.options.resolve.alias={...r?.alias||{},...i?.alias||{},...n?.alias||{},...o?.alias||{},...e.options.resolve.alias},e.options.module.rules=[{test:/\.(js|mjs|jsx|mjsx|ts|mts|tsx|mtsx)$/,include:[Hs.default.dirname(this.manifestPath)],exclude:/node_modules/,use:{loader:require.resolve("swc-loader"),options:{sync:!0,module:{type:"es6"},minify:this.mode==="production",isModule:!0,jsc:{target:"es2016",parser:{syntax:R(s)?"typescript":"ecmascript",tsx:R(s)&&(me(s)||X(s)),jsx:!R(s)&&(me(s)||X(s)),dynamicImport:!0},transform:{react:{development:this.mode==="development",refresh:this.mode==="development",runtime:"automatic",importSource:"react"}}}}}},...r?.loaders||[],...i?.loaders||[],...n?.loaders||[],...o?.loaders||[],...e.options.module.rules].filter(Boolean),i?.plugins?.forEach(c=>c.apply(e)),n?.plugins?.forEach(c=>c.apply(e)),o?.plugins?.forEach(c=>c.apply(e))}async apply(e){if(this.mode==="production"){e.hooks.beforeRun.tapPromise(t.name,async()=>await this.configureOptions(e));return}await this.configureOptions(e)}};var Re=a(require("path"));var Ln=a(require("path"));var Vi=a(require("path"));function Gi(t,e){if(!e||!e.action||!e.action.default_popup)return;let s=e.action.default_popup;return Vi.default.join(t,s)}var Xi=a(require("path"));function Zi(t,e){if(!e||!e.browser_action||!e.browser_action.default_popup)return;let s=e.browser_action.default_popup;return Xi.default.join(t,s)}var ht=a(require("path"));function Yi(t,e){let s={newtab:void 0};if(!e||!e.chrome_url_overrides)return{"chrome_url_overrides/newtab":void 0};if(e.chrome_url_overrides.history){let r=e.chrome_url_overrides.history;s={"chrome_url_overrides/history":ht.default.join(t,r)}}if(e.chrome_url_overrides.newtab){let r=e.chrome_url_overrides.newtab;s={"chrome_url_overrides/newtab":ht.default.join(t,r)}}if(e.chrome_url_overrides.bookmarks){let r=e.chrome_url_overrides.bookmarks;s={"chrome_url_overrides/bookmarks":ht.default.join(t,r)}}return s}var Ki=a(require("path"));function Qi(t,e){if(!e||!e.devtools_page)return;let s=e.devtools_page;return Ki.default.join(t,s)}var Vs=a(require("path"));function en(t,e){if(e.options_page){let r=e.options_page;return Vs.default.join(t,r)}if(!e||!e.options_ui||!e.options_ui.page)return;let s=e.options_ui.page;return Vs.default.join(t,s)}var tn=a(require("path"));function sn(t,e){if(!e||!e.page_action||!e.page_action.default_popup)return;let s=e.page_action.default_popup;return tn.default.join(t,s)}var rn=a(require("path"));function nn(t,e){if(!e||!e.sandbox||!e.sandbox.pages)return{"sandbox/page-0":void 0};let s=e.sandbox.pages,r={};for(let[i,n]of s.entries())r[`sandbox/page-${i}`]=rn.default.join(t,n);return r}var on=a(require("path"));function an(t,e){if(!e||!e.side_panel||!e.side_panel.default_path)return;let s=e.side_panel.default_path;return on.default.join(t,s)}var cn=a(require("path"));function pn(t,e){if(!e||!e.sidebar_action||!e.sidebar_action.default_panel)return;let s=e.sidebar_action.default_panel;return cn.default.join(t,s)}function De(t,e){return{"action/default_popup":Gi(t,e),"browser_action/default_popup":Zi(t,e),...Yi(t,e),devtools_page:Qi(t,e),"options_ui/page":en(t,e),"page_action/default_popup":sn(t,e),...nn(t,e),"side_panel/default_path":an(t,e),"sidebar_action/default_panel":pn(t,e)}}var Gs=a(require("path"));function ln(t,e){if(!e||!e.action||!e.action.default_icon)return;if(typeof e.action.default_icon=="string")return Gs.default.join(t,e.action.default_icon);let s=[];for(let r in e.action.default_icon)s.push(Gs.default.join(t,e.action.default_icon[r]));return s}var Xs=a(require("path"));function un(t,e){if(!e||!e.browser_action||!e.browser_action.default_icon)return;let s=[];if(typeof e.browser_action.default_icon=="string")return Xs.default.join(t,e.browser_action.default_icon);for(let r in e.browser_action.default_icon){let i=e.browser_action.default_icon[r]=Xs.default.join(t,e.browser_action.default_icon[r]);s.push(i)}return s}var Zs=a(require("path"));function fn(t,e){if(!(!e||!e.browser_action||!e.browser_action.theme_icons)){for(let s of e.browser_action.theme_icons)s.light&&(s.light=Zs.default.join(t,s.light)),s.dark&&(s.dark=Zs.default.join(t,s.dark)),s.size&&delete s.size;return e.browser_action.theme_icons}}var mn=a(require("path"));function dn(t,e){if(!e||!e.icons)return;let s=[];for(let r in e.icons){let i=mn.default.join(t,e.icons[r]);s.push(i)}return s}var Ys=a(require("path"));function gn(t,e){if(!e||!e.page_action||!e.page_action.default_icon)return;if(typeof e.page_action.default_icon=="string")return Ys.default.join(t,e.page_action.default_icon);let s=[];for(let r in e.page_action.default_icon){let i=Ys.default.join(t,e.page_action.default_icon[r]);s.push(i)}return s}var hn=a(require("path"));function yn(t,e){return!e||!e.sidebar_action||!e.sidebar_action.default_icon?void 0:hn.default.join(t,e.sidebar_action.default_icon)}function bn(t,e){return{action:ln(t,e),browser_action:un(t,e),"browser_action/theme_icons":fn(t,e),icons:dn(t,e),page_action:gn(t,e),sidebar_action:yn(t,e)}}var wn=a(require("path"));function xn(t,e){let s={};return!e||!e.declarative_net_request||!e.declarative_net_request.rule_resources?{"declarative_net_request/rule_resources-0":void 0}:(e.declarative_net_request.rule_resources.forEach(i=>{s[`declarative_net_request/${i.id}`]=wn.default.join(t,i.path)}),s)}var vn=a(require("path"));function _n(t,e){if(!e||!e.storage||!e.storage.managed_schema)return;let s=e.storage.managed_schema;return vn.default.join(t,s)}function Sn(t,e){return{...xn(t,e),"storage/managed_schema":_n(t,e)}}var Pn=a(require("path"));function kn(t,e){if(!e||!e.background)return;let s=e.background.scripts;if(s)return s.map(r=>Pn.default.join(t,r))}var En=a(require("path"));function jn(t,e){if(!e||!e.background)return;let s=e.background.service_worker;if(s)return En.default.join(t,s)}var Ks=a(require("path"));function $n(t,e){if(!e||!e.content_scripts)return{"content_scripts/content-0":void 0};let s=n=>{if(n.js?.length!==0)return n.js?.map(o=>Ks.default.join(t,o))},r=n=>{if(n.css?.length!==0)return n.css?.map(o=>Ks.default.join(t,o))},i={};for(let[n,o]of e.content_scripts.entries()){let c=s(o),p=r(o);i[`content_scripts/content-${n}`]=[...(c||[]).filter(l=>l!=null),...(p||[]).filter(l=>l!=null)]}return i}var Cn=a(require("path"));function Dn(t,e){if(!e||!e.user_scripts||!e.user_scripts.api_script)return;let s=e.user_scripts.api_script;return Cn.default.join(t,s)}function Fe(t,e){return{"background/scripts":kn(t,e),"background/service_worker":jn(t,e),...$n(t,e),"user_scripts/api_script":Dn(t,e)}}function Fn(t){if(!(!t||!t.web_accessible_resources||!t.web_accessible_resources.length))return t.web_accessible_resources}function qp(t){function e(s){let r={};for(let i in s)if(s.hasOwnProperty(i)){let n=i.includes(":")?i.split(":")[1]:i;typeof s[i]=="object"&&!Array.isArray(s[i])?r[n]=e(s[i]):r[n]=s[i]}return r}return e(t)}function In({manifestPath:t}){let e=Ln.default.dirname(t),s=require(t),r=qp(s);return{html:De(e,r),icons:bn(e,r),json:Sn(e,r),scripts:Fe(e,r),web_accessible_resources:Fn(r)}}var de=a(require("path"));var yt=a(require("fs")),Le=a(require("path"));function bt(t,e){if(!yt.default.existsSync(t)||!yt.default.statSync(t).isDirectory())return[];let s=[];function r(i){let n=yt.default.readdirSync(i,{withFileTypes:!0});for(let o of n){let c=Le.default.join(i,o.name);o.isDirectory()?r(c):o.isFile()&&e(o.name)&&s.push(c)}}return r(t),s}function wt(t,e,s=""){return!e||!e.length?{}:e.reduce((r,i)=>{let n=Le.default.extname(i),o=Le.default.basename(i,n),c=s?`${s}/${o}`:Le.default.relative(t,i);return{...r,[c]:i}},{})}function On({manifestPath:t}){let e=de.default.dirname(t),s={public:de.default.join(e,"public"),pages:de.default.join(e,"pages"),scripts:de.default.join(e,"scripts")},r={public:bt(s.public,()=>!0),pages:bt(s.pages,n=>n.endsWith(".html")),scripts:bt(s.scripts,n=>[".js",".mjs",".jsx",".mjsx",".ts",".mts",".tsx",".mtsx"].includes(de.default.extname(n)))};return{public:wt(e,r.public),pages:wt(e,r.pages,"pages"),scripts:wt(e,r.scripts,"scripts")}}var xt=a(require("path")),An=a(require("webpack")),vt=class{manifestPath;includeList;excludeList;loaderOptions;constructor(e){this.manifestPath=e.manifestPath,this.includeList=e.includeList,this.excludeList=e.excludeList,this.loaderOptions=e.loaderOptions}apply(e){new An.default.ProvidePlugin({r:[xt.default.resolve(__dirname,"./resolver-module.js"),"default"]}).apply(e),e.options.module?.rules.push({test:/\.(js|mjs|jsx|mjsx|ts|mts|tsx|mtsx)$/,loader:require.resolve(xt.default.resolve(__dirname,"./resolver-loader.js")),include:[xt.default.dirname(this.manifestPath)],exclude:/node_modules/,options:{manifestPath:this.manifestPath,includeList:this.includeList,jsx:this.loaderOptions?this.loaderOptions.jsx:!1,typescript:this.loaderOptions?this.loaderOptions.typescript:!1,minify:this.loaderOptions?this.loaderOptions.minify:!1}})}};var Mn=a(require("fs")),St=a(require("webpack")),Tn=require("webpack");var _t=class{manifestPath;constructor(e){this.manifestPath=e.manifestPath}apply(e){e.hooks.compilation.tap("manifest:emit-manifest",s=>{s.hooks.processAssets.tap({name:"manifest:emit-manifest",stage:St.Compilation.PROCESS_ASSETS_STAGE_ADDITIONS},()=>{let r=this.manifestPath,i;try{let c=Mn.default.readFileSync(r,"utf-8");i=JSON.parse(c)}catch(c){let l=require(this.manifestPath).name||"Extension.js";s.errors.push(new St.default.WebpackError(ei(l,c)));return}let n=JSON.stringify(i,null,2);s.emitAsset("manifest.json",new Tn.sources.RawSource(n))})})}};var jt=require("webpack");function Rn(t,e){return t.background&&t.background.scripts&&{background:{...t.background,...t.background.scripts&&{scripts:[...t.background.scripts.map(s=>g("background/scripts.js",s,e))]}}}}var Nn=a(require("path"));var Pt=t=>Nn.default.basename(t);function qn(t,e){return t.browser_action&&{browser_action:{...t.browser_action,...t.browser_action.default_popup&&{default_popup:g("browser_action/default_popup.html",t.browser_action.default_popup,e)},...t.browser_action.default_icon&&{default_icon:typeof t.browser_action.default_icon=="string"?g(`icons/${Pt(t.browser_action.default_icon)}`,t.browser_action.default_icon,e):Object.fromEntries(Object.entries(t.browser_action.default_icon).map(([s,r])=>[s,g(`icons/${Pt(r)}`,r,e)]))},...t.browser_action.theme_icons&&{theme_icons:t.browser_action.theme_icons.map(s=>({...s,...s.light&&{light:g(`browser_action/${Pt(s.light)}`,s.light,e)},...s.dark&&{dark:g(`browser_action/${Pt(s.dark)}`,s.dark,e)}}))}}}}function Un(t,e){return t.declarative_net_request&&{declarative_net_request:{...t.declarative_net_request,rule_resources:t.declarative_net_request.rule_resources.map(s=>({...s,path:s.path&&g(`declarative_net_request/${s.id}.json`,s.path,e)}))}}}function Wn(t,e){return{...Rn(t,e),...qn(t,e),...Un(t,e)}}var Jn=a(require("path"));var Bn=t=>Jn.default.basename(t);function zn(t,e){return t.action&&{action:{...t.action,...t.action.default_popup&&{default_popup:g("action/default_popup.html",t.action.default_popup,e)},...t.action.default_icon&&{default_icon:typeof t.action.default_icon=="string"?g(`action/${Bn(t.action.default_icon)}`,t.action.default_icon,e):Object.fromEntries(Object.entries(t.action.default_icon).map(([s,r])=>[s,g(`action/${Bn(r)}`,r,e)]))}}}}function Hn(t,e){return t.background&&t.background.service_worker&&{background:{...t.background,...t.background.service_worker&&{service_worker:g("background/service_worker.js",t.background.service_worker,e)}}}}function kt(t,e){return t.side_panel&&{side_panel:{...t.side_panel.default_path&&{default_path:g("side_panel/default_path.html",t.side_panel.default_path,e)}}}}function Vn(t,e){return{...zn(t,e),...Hn(t,e),...kt(t,e)}}function Gn(t,e){return t.background&&t.background.page&&{background:{...t.background,...t.background.page&&{page:g("background/page.html",t.background.page,e)}}}}function Xn(t,e){return t.chrome_url_overrides&&{chrome_url_overrides:{...t.chrome_url_overrides.bookmarks&&{bookmarks:g("chrome_url_overrides/bookmarks.html",t.chrome_url_overrides.bookmarks,e)},...t.chrome_url_overrides.history&&{history:g("chrome_url_overrides/history.html",t.chrome_url_overrides.history,e)},...t.chrome_url_overrides.newtab&&{newtab:g("chrome_url_overrides/newtab.html",t.chrome_url_overrides.newtab,e)}}}}function Zn(t,e){return t.content_scripts&&{content_scripts:t.content_scripts.map((s,r)=>{let i=[...new Set(s.js)],n=[...new Set(s.css)];return{...s,js:[...i.map(o=>g(`content_scripts/content-${r}.js`,o,e))],css:[...n.map(o=>g(`content_scripts/content-${r}.css`,o,e))]}})}}function Yn(t,e){return t.devtools_page&&{devtools_page:g("devtools_page.html",t.devtools_page,e)}}var Kn=a(require("path"));var Up=t=>Kn.default.basename(t);function Qn(t,e){return t.icons&&{icons:Object.fromEntries(Object.entries(t.icons).map(([s,r])=>[s,g(`icons/${Up(r)}`,r,e)]))}}function eo(t,e){return t.options_page&&{options_page:g("options_ui/page.html",t.options_page,e)}}function to(t,e){return t.options_ui&&{options_ui:{...t.options_ui,...t.options_ui.page&&{page:g("options_ui/page.html",t.options_ui.page,e)}}}}var ro=a(require("path"));var so=t=>ro.default.basename(t);function io(t,e){return t.page_action&&{page_action:{...t.page_action,...t.page_action.default_popup&&{default_popup:g("page_action/default_popup.html",t.page_action.default_popup,e)},...t.page_action.default_icon&&{default_icon:typeof t.page_action.default_icon=="string"?g(`icons/${so(t.page_action.default_icon)}`,t.page_action.default_icon,e):Object.fromEntries(Object.entries(t.page_action.default_icon).map(([s,r])=>[s,g(`icons/${so(r)}`,r,e)]))}}}}function no(t,e){return t.sandbox&&{sandbox:{...t.sandbox,...t.sandbox.pages&&{pages:t.sandbox.pages.map((s,r)=>g(`sandbox/page-${r}.html`,s,e))}}}}var oo=a(require("path"));var Wp=t=>oo.default.basename(t);function ao(t,e){return t.sidebar_action&&{sidebar_action:{...t.sidebar_action,...t.sidebar_action.default_panel&&{default_panel:g("sidebar_action/default_panel.html",t.sidebar_action.default_panel,e)},...t.sidebar_action.default_icon&&{default_icon:g(`icons/${Wp(t.sidebar_action.default_icon)}`,t.sidebar_action.default_icon,e)}}}}function co(t,e){return t.storage&&{storage:{...t.storage.managed_schema&&{managed_schema:g("storage/managed_schema.json",t.storage.managed_schema,e)}}}}var po=a(require("path"));var Bp=t=>po.default.basename(t);function lo(t,e){return t.theme&&{theme:{...t.theme,...t.theme.images&&{images:{...t.theme.images,theme_frame:g(`theme/images/${Bp(t.theme.images.theme_frame)}`,t.theme.images.theme_frame,e)}}}}}function uo(t,e){return t.user_scripts&&{user_scripts:{...t.user_scripts,...t.user_scripts.api_script&&{api_script:g("user_scripts/api_script.js",t.user_scripts.api_script,e)}}}}function fo(t){return t.web_accessible_resources&&t.web_accessible_resources.length&&{web_accessible_resources:t.web_accessible_resources}}function mo(t,e){return{...Gn(t,e),...Xn(t,e),...Zn(t,e),...Yn(t,e),...Qn(t,e),...eo(t,e),...to(t,e),...io(t,e),...no(t,e),...kt(t,e),...ao(t,e),...co(t,e),...lo(t,e),...uo(t,e),...fo(t)}}function go(t,e,s){let r=e||require(t);return JSON.stringify({...r,...mo(r,s),...Wn(r,s),...Vn(r,s)},null,2)}var Et=class{manifestPath;excludeList;constructor(e){this.manifestPath=e.manifestPath,this.excludeList=e.excludeList}applyDevOverrides(e){return e.content_scripts?e.content_scripts.map((s,r)=>(s.css.length&&!s.js.length&&(s.js=[g(`content_scripts-${r}`,"dev.js",{})]),s)):{}}apply(e){e.hooks.thisCompilation.tap("manifest:update-manifest",s=>{s.hooks.processAssets.tap({name:"manifest:update-manifest",stage:jt.Compilation.PROCESS_ASSETS_STAGE_SUMMARIZE},()=>{if(s.errors.length>0)return;let r=G(s,this.manifestPath),i=go(this.manifestPath,r,this.excludeList||{}),n={...r,...JSON.parse(i)};e.options.mode!=="production"&&n.content_scripts&&(n.content_scripts=this.applyDevOverrides(n));let o=JSON.stringify(n,null,2),c=new jt.sources.RawSource(o);s.updateAsset("manifest.json",c)})})}};var ho=a(require("fs")),$t=class{dependencyList;constructor(e){this.dependencyList=e}apply(e){e.hooks.afterCompile.tap("ManifestPlugin (AddDependenciesPlugin)",s=>{if(s.errors?.length)return;let r=new Set(s.fileDependencies);this.dependencyList&&this.dependencyList.forEach(i=>{ho.default.existsSync(i)&&(r.has(i)||(r.add(i),s.fileDependencies.add(i)))})})}};var yo=a(require("fs")),bo=a(require("path")),Dt=a(require("webpack"));var Ct=class{manifestPath;includeList;excludeList;constructor(e){this.manifestPath=e.manifestPath,this.includeList=e.includeList,this.excludeList=e.excludeList}extractPaths(e){let s=Array.isArray(e)?e:[e];if(typeof s[0]=="string")return s;let r=[];if(typeof e=="object"&&!Array.isArray(e)){let i=e;i.light&&r.push(i.light),i.dark&&r.push(i.dark)}return r}handleErrors(e,s){let r=[".png",".jpg",".jpeg",".svg",".gif",".webp"],i=[".json"],n=[".js",".ts",".jsx",".tsx",".mjs",".cjs"],o=".html",c=Object.entries(this.includeList||{});for(let[p,l]of c)if(l){let f=this.extractPaths(l);for(let d of f){let h=bo.default.extname(d),$=require(this.manifestPath).name||"Extension.js",P=ae($,p,d);yo.default.existsSync(d)||(r.includes(h)?e.errors.push(new s(P)):i.includes(h)?e.errors.push(new s(P)):n.includes(h)?e.errors.push(new s(P)):h===o?e.errors.push(new s(P)):e.errors.push(new s(P)))}}}apply(e){e.hooks.compilation.tap("manifest:check-manifest-files",s=>{s.hooks.processAssets.tap({name:"compatibility:check-manifest-files",stage:Dt.Compilation.PROCESS_ASSETS_STAGE_OPTIMIZE_COUNT},()=>{let r=Dt.default.WebpackError;this.handleErrors(s,r)})})}};var wo=a(require("fs")),Lt=a(require("webpack"));var Ft=class{manifestPath;browser;includeList;constructor(e){this.manifestPath=e.manifestPath,this.browser=e.browser||"chrome",this.includeList=e.includeList}flattenAndSort(e){return e.flat(1/0).sort()}apply(e){e.hooks.watchRun.tapAsync("manifest:throw-if-recompile-is-needed",(s,r)=>{if((s.modifiedFiles||new Set).has(this.manifestPath)){let n=s.options.context||"",o=`${n}/package.json`;if(!wo.default.existsSync(o)){r();return}let c=require(this.manifestPath),p=rt(c,this.browser),l=this.flattenAndSort(Object.values(De(n,p))),f=this.flattenAndSort(Object.values(Fe(n,p)));s.hooks.thisCompilation.tap("manifest:throw-if-recompile-is-needed",d=>{d.hooks.processAssets.tap({name:"manifest:check-manifest-files",stage:Lt.Compilation.PROCESS_ASSETS_STAGE_OPTIMIZE_COMPATIBILITY},()=>{let y=d.getAsset("manifest.json")?.source.source().toString(),$=JSON.parse(y||"{}"),P=this.flattenAndSort(Object.values(De(n,$))),q=this.flattenAndSort(Object.values(Fe(n,$)));if(f.toString()!==q.toString()||l.toString()!==P.toString()){let U=l.filter(W=>!P.includes(W))[0],H=P.filter(W=>!l.includes(W))[0],_e=ti(H,U);d.errors.push(new Lt.default.WebpackError(_e))}})})}r()})}};var It=class{manifestPath;browser;includeList;excludeList;constructor(e){this.manifestPath=e.manifestPath,this.browser=e.browser||"chrome",this.includeList=e.includeList,this.excludeList=e.excludeList}apply(e){new _t({manifestPath:this.manifestPath}).apply(e),new Ct({manifestPath:this.manifestPath,includeList:this.includeList,excludeList:this.excludeList}).apply(e),new Et({manifestPath:this.manifestPath,excludeList:this.excludeList}).apply(e),new $t([this.manifestPath]).apply(e),new Ft({manifestPath:this.manifestPath,browser:this.browser,includeList:this.includeList}).apply(e)}};var rr=a(require("path"));var er=a(require("fs")),Mt=a(require("webpack")),Po=require("webpack");var xo=a(require("fs")),he=a(require("path")),vo=a(require("parse5-utils"));var ge=a(require("parse5-utils"));function Ot(t){try{return new URL(t),!0}catch{return!1}}function Ie(t,e){let{childNodes:s=[]}=t;for(let r of s)if(r.nodeName==="script"){let i=ge.default.getAttribute(r,"src");if(!i||Ot(i))continue;e({filePath:i,childNode:r,assetType:"script"})}else if(r.nodeName==="link"){let i=ge.default.getAttribute(r,"href"),n=ge.default.getAttribute(r,"rel");if(!i||Ot(i))continue;e(n==="dns-prefetch"||n==="icon"||n==="manifest"||n==="modulepreload"||n==="preconnect"||n==="prefetch"||n==="preload"||n==="prerender"?{filePath:i,childNode:r,assetType:"staticHref"}:{filePath:i,childNode:r,assetType:"css"})}else if(r.nodeName==="a"||r.nodeName==="area"){let i=ge.default.getAttribute(r,"href");if(!i||Ot(i))continue;e({filePath:i,childNode:r,assetType:"staticHref"})}else if(r.nodeName==="audio"||r.nodeName==="embed"||r.nodeName==="iframe"||r.nodeName==="img"||r.nodeName==="input"||r.nodeName==="source"||r.nodeName==="track"||r.nodeName==="video"){let i=ge.default.getAttribute(r,"src");if(!i||Ot(i))continue;e({filePath:i,childNode:r,assetType:"staticSrc"})}else Ie(r,e)}function D(t,e){let s={css:[],js:[],static:[]};if(!t)return s;let r=e||xo.default.readFileSync(t,{encoding:"utf8"}),i=vo.default.parse(r),n=(o,c)=>he.default.join(he.default.dirname(o),c.startsWith("/")?he.default.relative(he.default.dirname(o),c):c);for(let o of i.childNodes)if(o.nodeName==="html"){for(let c of o.childNodes)(c.nodeName==="head"||c.nodeName==="body")&&Ie(c,({filePath:p,assetType:l})=>{let f=n(t,p);switch(l){case"script":s.js?.push(f);break;case"css":s.css?.push(f);break;case"staticSrc":case"staticHref":if(p.startsWith("#"))break;s.static?.push(f);break;default:break}});return{css:s.css,js:s.js,static:s.static}}}function _o(t,e,s){let r=Object.keys(t).find(n=>{let o=t[n];return t[n]===e||D(o)?.js?.includes(e)||D(o)?.css?.includes(e)})||"",i=Qs(e);return r?`/${r.replace(i,"")}${s}`:`${e.replace(i,"")}${s}`}function Qs(t){switch(he.default.extname(t)){case".js":case".mjs":case".ts":case".tsx":return".js";case".css":case".scss":case".sass":case".less":return".css";case".html":return".html";default:return".js"}}function Z(t,e,s){return s?`/${t}${e}`:`${t}${e}`}function So(t,e){return Object.values(e||{}).some(s=>s===t)}var At=class{manifestPath;includeList;excludeList;constructor(e){this.manifestPath=e.manifestPath,this.includeList=e.includeList,this.excludeList=e.excludeList}apply(e){let r=require(this.manifestPath).name||"Extension.js";e.hooks.thisCompilation.tap("html:emit-html-file",i=>{i.hooks.processAssets.tap({name:"AddAssetsToCompilationPlugin",stage:Mt.Compilation.PROCESS_ASSETS_STAGE_ADDITIONAL},()=>{let n=Object.entries(this.includeList||{});for(let o of n){let[c,p]=o;if(p){if(!er.default.existsSync(p)){let f=ae(r,c,p);i.warnings.push(new Mt.default.WebpackError(f));return}let l=er.default.readFileSync(p,"utf8");if(!S(p,this.excludeList)){let f=new Po.sources.RawSource(l),d=Z(c,".html");i.emitAsset(d,f)}}}})})}};var Tt=a(require("fs")),ye=a(require("path")),ko=a(require("webpack")),Oe=require("webpack");var Rt=class{manifestPath;includeList;constructor(e){this.manifestPath=e.manifestPath,this.includeList=e.includeList}apply(e){e.hooks.thisCompilation.tap("html:add-assets-to-compilation",s=>{s.hooks.processAssets.tap({name:"html:add-assets-to-compilation",stage:Oe.Compilation.PROCESS_ASSETS_STAGE_ADDITIONAL},()=>{if(s.errors.length>0)return;let r=Object.entries(this.includeList||{});for(let i of r){let[n,o]=i,c=n+".html";if(o){let p=s.getAsset(c);if(p){let l=p.source.source().toString(),f=D(o,l)?.static,d=[...new Set(f)];for(let h of d)if(!h.includes("public/")){if(!Tt.default.existsSync(h)&&!So(h,this.includeList)&&!ye.default.basename(h).startsWith("#")){let U=Ze(require(this.manifestPath).name,o,h);s.warnings.push(new ko.default.WebpackError(U));return}let y=Tt.default.readFileSync(h),$=new Oe.sources.RawSource(y),P=ye.default.join("assets",ye.default.basename(h));if(!s.getAsset(P))if(h.endsWith(".html")){let q=D(h),U=[...q?.js||[],...q?.css||[],...q?.static||[]];s.emitAsset(P,$),U.forEach(H=>{let _e=Tt.default.readFileSync(H),W=new Oe.sources.RawSource(_e),Ir=ye.default.join("assets",ye.default.basename(H));s.getAsset(Ir)||s.emitAsset(Ir,W)})}else s.emitAsset(P,$)}}}}})})}};var Eo=a(require("path")),tr=a(require("fs"));var Nt=class{manifestPath;includeList;excludeList;constructor(e){this.manifestPath=e.manifestPath,this.includeList=e.includeList,this.excludeList=e.excludeList}apply(e){let s=this.includeList||{};for(let r of Object.entries(s)){let[i,n]=r;if(n){if(!tr.default.existsSync(n))return;let o=D(n),c=o?.js||[],p=o?.css||[],l=[...c,...p].filter(f=>!S(f,this.excludeList));if(e.options.mode==="development"){let f=Eo.default.resolve(__dirname,"minimum-script-file.mjs");l.push(f)}tr.default.existsSync(n)&&(S(n,this.excludeList)||(e.options.entry={...e.options.entry,[i]:{import:l}}))}}}};var Ut=require("webpack");var sr=a(require("fs")),Y=a(require("path")),F=a(require("parse5-utils"));function jo(t,e,s,r,i){let n=sr.default.readFileSync(s,{encoding:"utf8"}),o=F.default.parse(n),c=!!t.getAsset(e+".css"),p=!1;for(let l of o.childNodes)if(l.nodeName==="html"){for(let f of l.childNodes){if((f.nodeName==="head"||f.nodeName==="body")&&Ie(f,({filePath:d,childNode:h,assetType:y})=>{let $=Y.default.dirname(s),P=Y.default.resolve($,d),q=Qs(P),U=S(Y.default.resolve($,d),i),H=Y.default.join("/",Y.default.normalize(d)),_e=gi(P,r);switch(y){case"script":{U?l=F.default.setAttribute(h,"src",H):(l=F.default.remove(h),p=!0);break}case"css":{U?l=F.default.setAttribute(h,"href",H):(l=F.default.remove(h),c=!0);break}case"staticHref":case"staticSrc":{if(U)l=F.default.setAttribute(h,y==="staticSrc"?"src":"href",H);else if(_e){let W=_o(r,P,q);l=F.default.setAttribute(h,y==="staticSrc"?"src":"href",W)}else{let W=Y.default.join("assets",Y.default.basename(P,q));sr.default.existsSync(P)&&(l=F.default.setAttribute(h,y==="staticSrc"?"src":"href",Z(W,"",!0)))}break}default:break}}),f.nodeName==="head"&&c&&t.options.mode==="production"){let d=F.default.createNode("link");d.attrs=[{name:"rel",value:"stylesheet"},{name:"href",value:Z(e,".css",!0)}],F.default.append(f,d)}if(f.nodeName==="body"&&(p||t.options.mode!=="production")){let d=F.default.createNode("script");d.attrs=[{name:"src",value:Z(e,".js",!0)}],F.default.append(f,d)}}return F.default.serialize(o)}}var qt=class{manifestPath;includeList;excludeList;constructor(e){this.manifestPath=e.manifestPath,this.includeList=e.includeList,this.excludeList=e.excludeList}apply(e){e.hooks.thisCompilation.tap("html:update-html-file",s=>{s.hooks.processAssets.tap({name:"html:update-html-file",stage:Ut.Compilation.PROCESS_ASSETS_STAGE_DERIVED},()=>{if(s.errors.length>0)return;let r=this.includeList||{};for(let i of Object.entries(r)){let[n,o]=i;if(o){let c=jo(s,n,o,r,this.excludeList||{});if(!S(o,this.excludeList)&&c){let p=new Ut.sources.RawSource(c),l=Z(n,".html");s.updateAsset(l,p)}}}})})}};var $o=a(require("fs")),Co=require("webpack");var Wt=class{manifestPath;includeList;constructor(e){this.manifestPath=e.manifestPath,this.includeList=e.includeList}apply(e){e.hooks.thisCompilation.tap("html:add-to-file-dependencies",s=>{s.hooks.processAssets.tap({name:"html:add-to-file-dependencies",stage:Co.Compilation.PROCESS_ASSETS_STAGE_ADDITIONS},()=>{if(s.errors?.length)return;let r=this.includeList||{};for(let i of Object.entries(r)){let[,n]=i;if(n){let o=D(n),c=new Set(s.fileDependencies);if($o.default.existsSync(n)){let p=[n,...o?.static||[]];for(let l of p)c.has(l)||(c.add(l),l===n&&s.fileDependencies.add(l))}}}})})}};var Do=a(require("fs"));var Bt=class{manifestPath;includeList;initialHtmlAssets={};constructor(e){this.manifestPath=e.manifestPath,this.includeList=e.includeList}hasEntriesChanged(e,s){if(!s||!e||e.length!==s.length)return!0;for(let r=0;r<e.length;r++)if(e[r]!==s[r])return!0;return!1}storeInitialHtmlAssets(e){Object.entries(e).forEach(([s,r])=>{let i=r;if(i){if(!Do.default.existsSync(i)){let o=require(this.manifestPath).name||"Extension.js";console.error(ae(o,s,i)),process.exit(1)}this.initialHtmlAssets[i]={js:D(i)?.js||[],css:D(i)?.css||[]}}})}apply(e){let s=this.includeList||{};this.storeInitialHtmlAssets(s),e.hooks.make.tapAsync("html:throw-if-recompile-is-needed",(r,i)=>{let n=e.modifiedFiles||new Set,o=Array.from(n)[0];if(o&&this.initialHtmlAssets[o]){let c=D(o)?.js||[],p=D(o)?.css||[],{js:l,css:f}=this.initialHtmlAssets[o];if(this.hasEntriesChanged(p,f)||this.hasEntriesChanged(c,l)){let d=require(this.manifestPath).name;console.log(ai(d,o))}}i()})}};var Fo=a(require("fs")),Lo=require("webpack");function zp(t,e,s){let r="Module not found: Error: Can't resolve ",n=s.message.replace(r,"").split("'")[1];if(s.message.includes(r))for(let o of Object.entries(e)){let[,c]=o;if(c){if(!Fo.default.existsSync(c))return null;let p=D(c),l=p?.js||[],f=p?.css||[];if(l.includes(n)||f.includes(n)){let d=Ze(require(t).name,c,n);return new Lo.WebpackError(d)}}}return null}var Jt=class{manifestPath;includeList;constructor(e){this.manifestPath=e.manifestPath,this.includeList=e.includeList}apply(e){e.hooks.compilation.tap("html:handle-common-errors",s=>{s.hooks.afterSeal.tapPromise("html:handle-common-errors",async()=>{s.errors.forEach((r,i)=>{let n=zp(this.manifestPath,this.includeList||{},r);n&&(s.errors[i]=n)})})})}};var zt=class{manifestPath;includeList;excludeList;constructor(e){this.manifestPath=e.manifestPath,this.includeList=e.includeList,this.excludeList=e.excludeList}apply(e){new At({manifestPath:this.manifestPath,includeList:this.includeList,excludeList:this.excludeList}).apply(e),new Rt({manifestPath:this.manifestPath,includeList:this.includeList,excludeList:this.excludeList}).apply(e),new Nt({manifestPath:this.manifestPath,includeList:this.includeList,excludeList:this.excludeList}).apply(e),new qt({manifestPath:this.manifestPath,includeList:this.includeList,excludeList:this.excludeList}).apply(e),e.options.module.rules.push({test:/\.(js|mjs|jsx|mjsx|ts|mts|tsx|mtsx)$/,include:[rr.default.dirname(this.manifestPath)],exclude:/node_modules/,use:[{loader:require.resolve(rr.default.join(__dirname,"ensure-hmr-for-scripts.js")),options:{manifestPath:this.manifestPath,includeList:this.includeList,excludeList:this.excludeList}}]}),new Wt({manifestPath:this.manifestPath,includeList:this.includeList,excludeList:this.excludeList}).apply(e),new Bt({manifestPath:this.manifestPath,includeList:this.includeList,excludeList:this.excludeList}).apply(e),new Jt({manifestPath:this.manifestPath,includeList:this.includeList,excludeList:this.excludeList}).apply(e)}};var se=a(require("path"));var ir=a(require("fs")),Io=a(require("path"));function Oo(t,e){return(Array.isArray(t)?t||[]:t?[t]:[]).filter(i=>{let n=ir.default.existsSync(i)&&!S(i,e),o=Io.default.extname(i);return n&&(o===".js"||o===".mjs"||o===".jsx"||o===".ts"||o===".tsx")})}function Ao(t,e){return(Array.isArray(t)?t||[]:t?[t]:[]).filter(i=>ir.default.existsSync(i)&&!S(i,e)&&(i.endsWith(".css")||i.endsWith(".scss")||i.endsWith(".sass")||i.endsWith(".less")))}var Ht=class{manifestPath;includeList;excludeList;constructor(e){this.manifestPath=e.manifestPath,this.includeList=e.includeList||{},this.excludeList=e.excludeList||{}}apply(e){let s=this.includeList||{};for(let r of Object.entries(s)){let[i,n]=r,o=Oo(n,this.excludeList),c=Ao(n,this.excludeList),p=[...o];e.options.mode==="production"&&p.push(...c),(c.length||o.length)&&(e.options.entry={...e.options.entry,[i]:{import:p}})}}};var te=require("webpack"),Hp=['var isBrowser = !!(() => { try { return browser.runtime.getURL("/") } catch(e) {} })()','var isChrome = !!(() => { try { return chrome.runtime.getURL("/") } catch(e) {} })()'],Vp=[...Hp,`var runtime = isBrowser ? browser : isChrome ? chrome : (typeof self === 'object' && self.addEventListener) ? { get runtime() { throw new Error("No chrome or browser runtime found") } } : { runtime: { getURL: x => x } }`],Vt=class t{apply(e){let{RuntimeGlobals:s}=e.webpack;e.hooks.compilation.tap("PublicPathRuntimeModule",r=>{r.hooks.runtimeRequirementInTree.for(s.publicPath).tap(t.name,i=>{let n=Gp();return r.addRuntimeModule(i,n),!0})})}};function Gp(){class t extends te.RuntimeModule{constructor(){super("publicPath",te.RuntimeModule.STAGE_BASIC)}generate(){let s=this.compilation?.outputOptions.publicPath;return te.Template.asString([...Vp,`var path = ${JSON.stringify(this.compilation?.getPath(s||"",{hash:this.compilation.hash||"XXXX"}))}`,`${te.RuntimeGlobals.publicPath} = typeof importScripts === 'function' || !(isBrowser || isChrome) ? path : runtime.runtime.getURL(path);`])}}return new t}var Gt=class{manifestPath;browser;includeList;excludeList;constructor(e){this.manifestPath=e.manifestPath,this.browser=e.browser||"chrome",this.includeList=e.includeList||{},this.excludeList=e.excludeList||{}}apply(e){let s=require(this.manifestPath);if(s.content_scripts?.some(r=>r.world&&r.world.toLowerCase()==="main")){if(s.id||(console.error(li(s.name||"")),process.exit(1)),this.browser==="firefox"){e.options.output.publicPath=`moz-extension://${s.id}/`;return}e.options.output.publicPath=`${this.browser}-extension://${s.id}/`}}};var Xt=class{manifestPath;browser;includeList;excludeList;constructor(e){this.manifestPath=e.manifestPath,this.browser=e.browser||"chrome",this.includeList=e.includeList,this.excludeList=e.excludeList}apply(e){new Ht({manifestPath:this.manifestPath,includeList:this.includeList||{},excludeList:this.excludeList||{}}).apply(e),e.options.mode==="development"&&e.options.module.rules.push({test:/\.(js|mjs|jsx|mjsx|ts|mts|tsx|mtsx)$/,include:[se.default.dirname(this.manifestPath)],exclude:/node_modules/,use:[{loader:require.resolve(se.default.join(__dirname,"inject-content-css-during-dev.js")),options:{manifestPath:this.manifestPath,includeList:this.includeList||{},excludeList:this.excludeList||{}}}]}),e.options.mode==="development"&&e.options.module.rules.push({test:/\.(js|mjs|jsx|mjsx|ts|mts|tsx|mtsx)$/,include:[se.default.dirname(this.manifestPath)],exclude:/node_modules/,use:[{loader:require.resolve(se.default.join(__dirname,"add-hmr-accept-code.js")),options:{manifestPath:this.manifestPath,includeList:this.includeList||{},excludeList:this.excludeList||{}}}]}),e.options.mode==="production"&&new Vt().apply(e),new Gt({manifestPath:this.manifestPath,browser:this.browser||"chrome",includeList:this.includeList||{},excludeList:this.excludeList||{}}).apply(e),e.options.mode==="development"&&e.options.module.rules.push({test:/\.(js|mjs|jsx|mjsx|ts|mts|tsx|mtsx)$/,include:[se.default.dirname(this.manifestPath)],exclude:/node_modules/,use:[{loader:se.default.resolve(__dirname,"./add-query-param-to-imported-css.js"),options:{manifestPath:this.manifestPath,includeList:this.includeList||{},excludeList:this.excludeList||{}}}]})}};var or=a(require("path")),Ae=a(require("fs")),ar=a(require("webpack")),Me=require("webpack");var be=a(require("path")),Zt=a(require("fs"));function nr(t){let e=be.default.join(be.default.dirname(t),"_locales"),s=[];if(Zt.default.existsSync(e))for(let r of Zt.default.readdirSync(e)){let i=be.default.join(e,r);for(let n of Zt.default.readdirSync(i))s.push(be.default.join(be.default.dirname(t),"_locales",r,n))}return s}var Yt=class{manifestPath;includeList;excludeList;constructor(e){this.manifestPath=e.manifestPath,this.includeList=e.includeList,this.excludeList=e.excludeList}apply(e){e.hooks.thisCompilation.tap("locales:module",s=>{s.hooks.processAssets.tap({name:"locales:module",stage:Me.Compilation.PROCESS_ASSETS_STAGE_ADDITIONS},()=>{let i=require(this.manifestPath).name||"Extension.js";if(!Ae.default.existsSync(this.manifestPath)){s.errors.push(new ar.default.WebpackError(Qr(i)));return}if(s.errors.length>0)return;let n=nr(this.manifestPath);for(let o of Object.entries(n||[])){let[c,p]=o,l=p;if(l){if(!Ae.default.existsSync(l)){s.warnings.push(new ar.default.WebpackError(Ye(i,c,l)));return}let f=Ae.default.readFileSync(l),d=new Me.sources.RawSource(f),h=e.options.context||or.default.dirname(this.manifestPath);if(!S(l,this.excludeList)){let y=or.default.relative(h,l);s.emitAsset(y,d)}}}})}),e.hooks.thisCompilation.tap("locales:module",s=>{s.hooks.processAssets.tap({name:"locales:module",stage:Me.Compilation.PROCESS_ASSETS_STAGE_ADDITIONS},()=>{if(s.errors?.length)return;let r=nr(this.manifestPath);for(let i of Object.entries(r||[])){let[,n]=i;if(n){let o=new Set(s.fileDependencies),c=r||[];for(let p of c)Ae.default.existsSync(p)&&(o.has(p)||(o.add(p),s.fileDependencies.add(p)))}}})})}};var Kt=a(require("fs")),Mo=a(require("webpack")),Te=require("webpack");var Qt=class{manifestPath;includeList;excludeList;constructor(e){this.manifestPath=e.manifestPath,this.includeList=e.includeList,this.excludeList=e.excludeList}apply(e){e.hooks.thisCompilation.tap("json:module",s=>{s.hooks.processAssets.tap({name:"json:module",stage:Te.Compilation.PROCESS_ASSETS_STAGE_ADDITIONS},()=>{if(s.errors.length>0)return;let r=this.includeList||{};for(let i of Object.entries(r)){let[n,o]=i,c=Array.isArray(o)?o:[o];for(let p of c)if(p&&!S(p,this.excludeList)){if(!Kt.default.existsSync(p)){let h=require(this.manifestPath).name||"Extension.js";s.warnings.push(new Mo.default.WebpackError(Ye(h,n,p)));return}let l=Kt.default.readFileSync(p),f=new Te.sources.RawSource(l);s.emitAsset(n+".json",f)}}})}),e.hooks.thisCompilation.tap("json:module",s=>{s.hooks.processAssets.tap({name:"json:module",stage:Te.Compilation.PROCESS_ASSETS_STAGE_ADDITIONS},()=>{if(s.errors?.length)return;let r=this.includeList||{};for(let i of Object.entries(r)){let[,n]=i,o=Array.isArray(n)?n:[n];for(let c of o)if(c){let p=new Set(s.fileDependencies);S(c,this.excludeList)||Kt.default.existsSync(c)&&(p.has(c)||(p.add(c),s.fileDependencies.add(c)))}}})})}};var cr=a(require("fs")),To=a(require("path")),ts=require("webpack");var es=class{manifestPath;includeList;excludeList;constructor(e){this.manifestPath=e.manifestPath,this.includeList=e.includeList,this.excludeList=e.excludeList}apply(e){e.hooks.thisCompilation.tap("icons:emit-file",s=>{s.hooks.processAssets.tap({name:"icons:emit-file",stage:ts.Compilation.PROCESS_ASSETS_STAGE_OPTIMIZE_TRANSFER},()=>{if(s.errors.length>0)return;let r=this.includeList||{};for(let i of Object.entries(r)){let[n,o]=i;if(o===void 0)continue;let c=Array.isArray(o)?typeof o[0]=="string"?o:o.map(Object.values).flat():[o];for(let p of c)if(p){if(!cr.default.existsSync(p))continue;if(!S(p,this.excludeList)){let l=cr.default.readFileSync(p),f=new ts.sources.RawSource(l),d=To.default.basename(p),y=`${n.endsWith("theme_icons")?n.replace("theme_icons",""):n}/${d}`;s.emitAsset(y,f)}}}})})}};var Ro=a(require("fs")),No=require("webpack"),ss=class{manifestPath;includeList;excludeList;constructor(e){this.manifestPath=e.manifestPath,this.includeList=e.includeList,this.excludeList=e.excludeList}apply(e){e.hooks.thisCompilation.tap("icons:add-to-file-dependencies",s=>{s.hooks.processAssets.tap({name:"icons:add-to-file-dependencies",stage:No.Compilation.PROCESS_ASSETS_STAGE_ADDITIONS},()=>{if(s.errors?.length)return;let r=this.includeList||{};for(let i of Object.entries(r)){let[,n]=i,o=Array.isArray(n)?typeof n[0]=="string"?n:n.map(Object.values).flat():[n];for(let c of o)if(c){let p=new Set(s.fileDependencies);Ro.default.existsSync(c)&&(p.has(c)||(p.add(c),s.fileDependencies.add(c)))}}})})}};var rs=class{manifestPath;includeList;excludeList;constructor(e){this.manifestPath=e.manifestPath,this.includeList=e.includeList,this.excludeList=e.excludeList}apply(e){new es({manifestPath:this.manifestPath,includeList:this.includeList,excludeList:this.excludeList}).apply(e),new ss({manifestPath:this.manifestPath,includeList:this.includeList,excludeList:this.excludeList}).apply(e)}};var ns=require("webpack");var is=class{manifestPath;includeList;excludeList;constructor(e){this.manifestPath=e.manifestPath,this.includeList=e.includeList,this.excludeList=e.excludeList}generateManifestPatches(e,s){let r=G(e,this.manifestPath),i=r.web_accessible_resources||[],n=r.web_accessible_resources||[];for(let[p,l]of Object.entries(s)){let f=r.content_scripts?.find(d=>d.js&&d.js.some(h=>h.includes(p)));if(f){let d=f.matches||[];if(r.manifest_version===3){let h=i.find(y=>y.matches.some($=>d.includes($)));h?l.forEach(y=>{h.resources.includes(y)||h.resources.push(y)}):i.push({resources:l.filter(y=>!y.endsWith(".map")),matches:d})}else l.forEach(h=>{n.includes(h)||n.push(h)})}}r.manifest_version===3?r.web_accessible_resources=i:r.web_accessible_resources=Array.from(new Set(n));let o=JSON.stringify(r,null,2),c=new ns.sources.RawSource(o);e.getAsset("manifest.json")&&e.updateAsset("manifest.json",c)}apply(e){e.hooks.thisCompilation.tap("plugin-extension:feature-web-resources",s=>{s.hooks.processAssets.tap({name:"plugin-extension:feature-web-resources",stage:ns.Compilation.PROCESS_ASSETS_STAGE_ANALYSE},()=>{let r=[],i=Object.keys(this.includeList||{});for(let c of i.filter(Boolean))c.startsWith("content_scripts")&&(Array.isArray(c)?r.push(...c):typeof c=="string"&&r.push(c));let n=s.chunkGraph,o={};s.entrypoints.forEach((c,p)=>{if(r.includes(p)){let l=[];c.chunks.forEach(f=>{Array.from(n.getChunkModulesIterable(f)).forEach(h=>{n.getModuleChunks(h).forEach(y=>{y.auxiliaryFiles.forEach($=>{l.includes($)||l.push($)})})})}),o[p]=l}}),this.generateManifestPatches(s,o)})})}};var L=a(require("fs")),I=a(require("path")),qo=a(require("chokidar")),os=class{options;constructor(e){this.options=e}ensureDirectoryExistence(e){let s=I.default.dirname(e);if(L.default.existsSync(s))return!0;L.default.mkdirSync(s,{recursive:!0})}copyFile(e,s){this.ensureDirectoryExistence(s),L.default.copyFileSync(e,s)}copyFolder(e,s){L.default.existsSync(s)||L.default.mkdirSync(s,{recursive:!0}),L.default.readdirSync(e).forEach(i=>{let n=I.default.join(e,i),o=I.default.join(s,i);L.default.statSync(n).isDirectory()?this.copyFolder(n,o):this.copyFile(n,o)})}apply(e){let s=I.default.dirname(this.options.manifestPath),r=I.default.join(s,"public"),i=e.options.output?.path||"";L.default.existsSync(r)&&(e.hooks.afterEmit.tap("special-folders:copy-public-folder",()=>{let n=I.default.join(i,"public");L.default.existsSync(n)||L.default.mkdirSync(n,{recursive:!0}),L.default.existsSync(r)&&this.copyFolder(r,n)}),e.options.mode!=="production"&&e.hooks.afterPlugins.tap("special-folders:copy-public-folder",()=>{let n=I.default.join(s,"public"),o=qo.default.watch(n,{ignoreInitial:!0});o.on("add",c=>{let p=I.default.join(i,I.default.relative(s,c));this.copyFile(c,p)}),o.on("change",c=>{let p=I.default.join(i,I.default.relative(s,c));this.copyFile(c,p)}),o.on("unlink",c=>{let p=I.default.join(i,I.default.relative(s,c));L.default.existsSync(p)&&L.default.unlinkSync(p)}),e.hooks.watchClose.tap("special-folders:copy-public-folder",()=>{o.close().catch(console.error)})}))}};var N=a(require("path")),pr=a(require("chokidar"));var as=class{manifestPath;constructor(e){this.manifestPath=e}throwCompilationError(e,s,r){let i=N.relative(process.cwd(),s),p=si(r?"Adding":"Removing",r?"added":"removed",e,e==="pages"?"HTML pages":"script files",i);if(r){console.warn(p);return}console.error(p),process.exit(1)}apply(e){e.hooks.afterPlugins.tap("special-folders:warn-upon-folder-changes",()=>{let s=N.dirname(this.manifestPath),r=N.join(s,"pages"),i=N.join(s,"scripts"),n=pr.watch(r,{ignoreInitial:!0}),o=pr.watch(i,{ignoreInitial:!0}),c=e.options.resolve?.extensions;n.on("add",p=>{p.endsWith(".html")&&this.throwCompilationError("pages",p,!0)}),n.on("unlink",p=>{p.endsWith(".html")&&this.throwCompilationError("pages",p)}),o.on("add",p=>{c?.includes(N.extname(p))&&this.throwCompilationError("scripts",p,!0)}),o.on("unlink",p=>{c?.includes(N.extname(p))&&this.throwCompilationError("scripts",p)}),e.hooks.watchClose.tap("WarnUponFolderChanges",()=>{n.close().catch(console.error),o.close().catch(console.error)})})}};var cs=class{static name="plugin-special-folders";options;constructor(e){this.options=e}apply(e){let{manifestPath:s}=this.options;new os({manifestPath:s}).apply(e),e.options.mode==="development"&&e.options.watchOptions&&new as(s).apply(e)}};var ps=class{static name="plugin-extension";manifestPath;browser;mode;constructor(e){this.manifestPath=e.manifestPath,this.browser=e.browser||"chrome",this.mode=e.mode}apply(e){let s=this.manifestPath,r=In({manifestPath:s}),i=On({manifestPath:s});new vt({manifestPath:s,includeList:{...i?.pages||{},...i?.scripts||{}},excludeList:i.public,loaderOptions:{jsx:me(Re.default.dirname(this.manifestPath))||X(Re.default.dirname(this.manifestPath))||Ce(Re.default.dirname(this.manifestPath)),typescript:R(Re.default.dirname(this.manifestPath)),minify:this.mode==="production"}}).apply(e),new It({browser:this.browser,manifestPath:s,includeList:{...r.html,...r.icons,...r.json,...r.scripts},excludeList:i.public}).apply(e),new zt({manifestPath:s,includeList:{...r.html,...i.pages},excludeList:{...i.public,...i.scripts}}).apply(e),new Xt({manifestPath:s,browser:this.browser,includeList:{...r.scripts,...i.scripts},excludeList:{...i.public,...i.pages}}).apply(e),new Yt({manifestPath:s}).apply(e),new Qt({manifestPath:s,includeList:r.json,excludeList:i.public}).apply(e),new rs({manifestPath:s,includeList:r.icons,excludeList:i.public}).apply(e),new is({manifestPath:s,includeList:{...r.scripts,...i.scripts},excludeList:i.public}).apply(e),new cs({manifestPath:s}).apply(e)}};var Ue=a(require("path"));var Uo=a(require("path")),Wo=a(require("ws")),us=a(require("browser-extension-manifest-fields"));function ls(t,e){t.clients.forEach(s=>{s.readyState===Wo.default.OPEN&&s.send(JSON.stringify(e))})}function Bo(t,e,s){if(!s||!e)return;let r=(0,us.default)(e).locales,i=(0,us.default)(e).scripts,n=(0,us.default)(e).json;if(!t){process.env.EXTENSION_ENV==="development"&&console.error("WebSocket server is not running.");return}Uo.default.basename(s)==="manifest.json"&&ls(t,{changedFile:"manifest.json"}),r?.forEach(o=>{o.includes(s)&&ls(t,{changedFile:"_locales"})}),Object.entries(i).forEach(([o,c])=>{let p=Array.isArray(c)?c:[c];Object.values(p).flatMap(f=>f).includes(s)&&o==="background/service_worker"&&ls(t,{changedFile:"service_worker"})}),Object.entries(n).forEach(([o,c])=>{c?.includes(s)&&o==="declarative_net_request"&&ls(t,{changedFile:"declarative_net_request"})})}var ur=a(require("path")),Vo=a(require("fs")),qe=a(require("ws"));var Ne=a(require("path")),Xp=a(require("http")),zo=a(require("https")),lr=a(require("fs"));var Jo=t=>{if(!lr.default.existsSync(t))return;let e=Ne.default.basename(t);return lr.default.readFileSync(Ne.default.join(__dirname,"certs",e))};function Ho(t,e){let s={key:Jo(Ne.default.join(__dirname,"certs","localhost.key")),cert:Jo(Ne.default.join(__dirname,"certs","localhost.cert"))},r=zo.default.createServer(s,(i,n)=>{n.writeHead(200),n.end()});return r.on("error",i=>{throw console.error(pi(t,e)),new Error(i.message)}),{server:r,port:e}}function Zp(t,e,s){switch(s){case"chrome":return new qe.default.Server({host:"localhost",port:e});case"edge":return new qe.default.Server({host:"localhost",port:e+1});case"firefox":return new qe.default.Server({server:Ho(t,e+2).server});default:return new qe.default.Server({host:"localhost",port:8888})}}async function Go(t,e){let s=t.options.context||"",r=require(ur.default.join(s,"manifest.json")),i=r.name||"Extension.js",n=e.port||8e3,o=Zp(i,n,e.browser);if(o.on("connection",c=>{c.send(JSON.stringify({status:"serverReady"})),c.on("error",p=>{console.log(ni(i,p))}),c.on("message",p=>{let l=JSON.parse(p.toString());if(l.status==="clientReady"){let f=require(ur.default.join(s,"manifest.json"));setTimeout(()=>{console.log(Ws(f,e.browser,l)),console.log("")},2500),hi(e.browser)&&setTimeout(()=>{console.log(ii(e.browser))},5e3)}})}),e.browser==="firefox"&&!Vo.default.existsSync(Xe)){let c=yi(r);console.log(Ws(r,e.browser,c)),console.log(""),console.log(ci()),console.log("")}return o}var Xo=a(require("path")),fr=a(require("fs"));function Zo(t,e){let s=Xo.default.resolve(__dirname,`./extensions/${t}-manager-extension/reload-service.js`);try{let r=fr.default.readFileSync(s,"utf8"),i=r.replace(/__RELOAD_PORT__/g,e.toString());i!==r&&fr.default.writeFileSync(s,i,"utf8")}catch(r){console.error(`Error processing file: ${r.message}`)}}process.on("SIGINT",()=>{process.exit()});process.on("SIGTERM",()=>{process.exit()});var We=class{manifestPath;port;browser;stats;constructor(e){this.manifestPath=e.manifestPath,this.port=e.port||8e3,this.browser=e.browser||"chrome",this.stats=e.stats}async apply(e){if(!this.manifestPath)return;Zo(this.browser,this.port);let s=await Go(e,{...this,mode:e.options.mode,browser:this.browser,stats:this.stats,port:this.port});e.hooks.watchRun.tapAsync("reload:create-web-socket-server",(r,i)=>{let o=(r.modifiedFiles||new Set).values().next().value;if(!o){i();return}let c=Ue.default.relative(Ue.default.dirname(this.manifestPath),o),p=Ue.default.relative(process.cwd(),Ue.default.dirname(o));process.env.EXTENSION_ENV==="development"&&console.info(`\u25BA\u25BA Updated file \`${c}\` (relative to ${p})`),this.manifestPath&&Bo(s,this.manifestPath,o),i()})}};var mr=a(require("path"));function Yo(t,e,s){t.options.module.rules.push({test:/\.(js|mjs|jsx|mjsx|ts|mts|tsx|mtsx)$/,include:[mr.default.dirname(s)],exclude:/node_modules/,use:[{loader:mr.default.resolve(__dirname,"./inject-chromium-client-loader"),options:{manifestPath:s,browser:e}}]})}var dr=a(require("path"));function Ko(t,e,s){t.options.module.rules.push({test:/\.(js|mjs|jsx|mjsx|ts|mts|tsx|mtsx)$/,include:[dr.default.dirname(s)],exclude:/node_modules/,use:[{loader:dr.default.resolve(__dirname,"./inject-firefox-client-loader"),options:{manifestPath:s,browser:e}}]})}var ms=require("webpack");var gr=a(require("content-security-policy-parser"));function Qo(t){let e=t.content_security_policy;if(!e)return"script-src 'self' 'unsafe-eval' blob: filesystem:; object-src 'self' blob: filesystem:; ";let s=(0,gr.default)(e);e="",s.get("script-src")||s.set("script-src",["'self' 'unsafe-eval' blob: filesystem:"]),s.get("script-src")?.includes("'unsafe-eval'")||s.set("script-src",["unsafe-eval"]);for(let r in s)e+=`${r} ${s.get(r)?.join(" ")};`;return e}function ea(t){let e=t.content_security_policy;if(!e)return{extension_pages:"script-src 'self'; object-src 'self'; "};let s=(0,gr.default)(e.extension_pages||""),r="";for(let i in s)r+=`${i} ${s.get(i)?.join(" ")}; `;return{extension_pages:r.trim()}}function ta(t){let e=["/*.json","/*.js","/*.css"],s=t.web_accessible_resources;if(!s||s.length===0)return e;let r=new Set(s);for(let i of e)r.has(i)||r.add(i);return Array.from(r)}function sa(t){let e=["/*.json","/*.js","/*.css"];return[...t.web_accessible_resources||[],{resources:e,matches:["<all_urls>"]}]}function hr(t,e){return t.background?{background:{...t.background}}:e==="firefox"?{background:{...t.background||{},scripts:["background/script.js"]}}:t.manifest_version===2?{background:{...t.background||{},scripts:["background/script.js"]}}:{background:{...t.background||{},service_worker:"background/service_worker.js"}}}function yr(t){return t.externally_connectable&&!t.externally_connectable.ids?{externally_connectable:{...t.externally_connectable,ids:[...new Set(t.externally_connectable.ids||[]),"*"]}}:t.externally_connectable&&!t.externally_connectable.ids?{externally_connectable:{...t.externally_connectable,ids:["*"]}}:{}}var fs=class{manifestPath;browser;constructor(e){this.manifestPath=e.manifestPath,this.browser=e.browser||"chrome"}generateManifestPatches(e){let s=G(e,this.manifestPath),r={...s,content_security_policy:s.manifest_version===3?ea(s):Qo(s),...s.manifest_version===3?s.permissions?{permissions:[...new Set(["scripting",...s.permissions])]}:{permissions:["scripting"]}:{},...hr(s,this.browser),...yr(s),web_accessible_resources:s.manifest_version===3?sa(s):ta(s)},i=JSON.stringify(r,null,2),n=new ms.sources.RawSource(i);e.getAsset("manifest.json")&&e.updateAsset("manifest.json",n)}apply(e){e.hooks.thisCompilation.tap("run-chromium:apply-manifest-dev-defaults",s=>{s.hooks.processAssets.tap({name:"run-chromium:apply-manifest-dev-defaults",stage:ms.Compilation.PROCESS_ASSETS_STAGE_SUMMARIZE},r=>{if(!this.manifestPath){let i="No manifest.json found in your extension bundle. Unable to patch manifest.json.";s&&e.webpack.WebpackError&&s.errors.push(new e.webpack.WebpackError(`run-chromium: ${i}`));return}this.generateManifestPatches(s)})})}};var br=a(require("fs")),we=a(require("path")),ra=a(require("webpack-target-webextension"));var ds=class{manifestPath;browser;constructor(e){this.manifestPath=e.manifestPath,this.browser=e.browser||"chrome"}handleBackground(e,s,r){let i=we.default.resolve(__dirname,s==="firefox"?"minimum-firefox-file.mjs":"minimum-chromium-file.mjs"),n=we.default.dirname(this.manifestPath),o=r.background;if(s==="firefox"){o=r["gecko:background"]||r["firefox:background"]||o;let c=o?.scripts||o?.["gecko:scripts"]||o?.["firefox:scripts"];if(c&&c.length>0){let p=we.default.join(n,c[0]);this.ensureFileExists(p,"background.scripts")}else this.addDefaultEntry(e,"background/script",i)}else if(o=r["chromium:background"]||r["chrome:background"]||r["edge:background"]||o,r.manifest_version===3){let c=o?.service_worker||o?.["chromium:service_worker"]||o?.["chrome:service_worker"]||o?.["edge:service_worker"];if(c){let p=we.default.join(n,c);this.ensureFileExists(p,"background.service_worker")}else this.addDefaultEntry(e,"background/service_worker",i)}else if(r.manifest_version===2){let c=o?.scripts||o?.["chromium:scripts"]||o?.["chrome:scripts"]||o?.["edge:scripts"];if(c&&c.length>0){let p=we.default.join(n,c[0]);this.ensureFileExists(p,"background.scripts")}else this.addDefaultEntry(e,"background/script",i)}}ensureFileExists(e,s){if(!br.default.existsSync(e)&&this.manifestPath){let i=require(this.manifestPath).name||"Extension.js",n=oi(i,s,e);throw console.error(n),new Error(n)}}addDefaultEntry(e,s,r){e.options.entry={...e.options.entry,[s]:{import:[r]}}}getEntryName(e){if(e.background){if(e.manifest_version===3)return{serviceWorkerEntry:"background/service_worker"};if(e.manifest_version===2)return{pageEntry:"background/script"}}return{pageEntry:"background"}}apply(e){if(!this.manifestPath||!br.default.lstatSync(this.manifestPath).isFile())return;let s=require(this.manifestPath);this.handleBackground(e,this.browser,s),new ra.default({background:this.getEntryName(s),weakRuntimeCheck:!0}).apply(e)}};var wr=class{manifestPath;browser;constructor(e){this.manifestPath=e.manifestPath,this.browser=e.browser||"chrome"}apply(e){Se.includes(this.browser)&&Yo(e,this.browser,this.manifestPath),this.browser==="firefox"&&Ko(e,this.browser,this.manifestPath),new fs({manifestPath:this.manifestPath,browser:this.browser}).apply(e),new ds({manifestPath:this.manifestPath,browser:this.browser}).apply(e)}},ia=wr;var gs=class{static name="plugin-reload";manifestPath;browser;port;stats;autoReload;constructor(e){this.manifestPath=e.manifestPath,this.browser=e.browser||"chrome",this.port=e.port,this.stats=e.stats,this.autoReload=e.autoReload}apply(e){e.options.mode==="development"&&new We({manifestPath:this.manifestPath,browser:this.browser,port:this.port,stats:this.stats}).apply(e),e.options.mode==="development"&&new ia({manifestPath:this.manifestPath,browser:this.browser,autoReload:this.autoReload,stats:this.stats}).apply(e)}};var na=a(require("webpack")),hs=class{manifestPath;browser;constructor(e){this.manifestPath=e.manifestPath,this.browser=e.browser}apply(e){new na.default.ProvidePlugin({browser:require.resolve("webextension-polyfill")}).apply(e)}};var bs=require("webpack");var ys=class{browser;manifestPath;constructor(e){this.manifestPath=e.manifestPath,this.browser=e.browser||"chrome"}patchManifest(e){let s=rt(e,this.browser);return JSON.stringify(s,null,2)}apply(e){e.hooks.compilation.tap("compatibility:browser-fields",s=>{s.hooks.processAssets.tap({name:"compatibility:browser-fields",stage:bs.Compilation.PROCESS_ASSETS_STAGE_OPTIMIZE},()=>{let r=G(s,this.manifestPath),i=this.patchManifest(r),n=new bs.sources.RawSource(i);s.updateAsset("manifest.json",n)})})}};var ws=class{static name="plugin-compatibility";manifestPath;browser;polyfill;constructor(e){this.manifestPath=e.manifestPath,this.browser=e.browser||"chrome",this.polyfill=e.polyfill||!1}async apply(e){this.polyfill&&this.browser!=="firefox"&&new hs({manifestPath:this.manifestPath,browser:this.browser||"chrome"}).apply(e),new ys({manifestPath:this.manifestPath,browser:this.browser||"chrome"}).apply(e)}};var ha=a(require("fs"));var oa=a(require("webpack")),aa=a(require("content-security-policy-parser"));function ca(t){let e=t.content_security_policy,s=t.content_security_policy?.extension_pages,r=i=>{if(!i)return;let n=(0,aa.default)(i);if(n.get("script-src")&&n.get("script-src")?.includes("'unsafe-eval'")){let o=t.name||"Extension.js";return Jr(o)}};if(t.manifest_version===3){let i=e?r(s):void 0;if(i)return new oa.default.WebpackError(i)}return null}var xr=a(require("webpack"));function pa(t,e){let s=t.web_accessible_resources;if(s){let r=s.some(o=>typeof o=="string"),i=s.some(o=>typeof o=="object"||o.resources||o.matches),n=t.name||"Extension.js";if(t.manifest_version===2&&!r)return new xr.default.WebpackError(Hr(n,e));if(t.manifest_version===3&&!i)return new xr.default.WebpackError(Vr(n,e))}return null}var la=a(require("webpack"));function ua(t,e){if(e==="firefox"&&t.background?.service_worker){let s=t.name||"Extension.js";return new la.default.WebpackError(Br(s))}return null}var fa=a(require("path")),ma=a(require("fs")),da=a(require("webpack"));function ga(t,e){let s=fa.default.join(e.options.context||"","_locales"),r=t.name||"Extension.js";return ma.default.existsSync(s)&&!t.default_locale?new da.default.WebpackError(zr(r)):null}var xs=class{options;constructor(e){this.options=e}handleRuntimeErrors(e,s,r){let i=ca(s),n=pa(s,r),o=ua(s,r),c=ga(s,e);i&&e.errors.push(i),n&&e.errors.push(n),o&&e.options.mode==="production"&&e.errors.push(o),c&&e.errors.push(c)}apply(e){e.hooks.afterCompile.tapAsync("CompatPlugin (module)",(s,r)=>{let i=this.options.manifestPath,n=JSON.parse(ha.default.readFileSync(i,"utf-8")),o=this.options.browser||"chrome";this.handleRuntimeErrors(s,n,o),r()})}};var ja=a(require("fs")),$a=a(require("ajv"));var ya={$schema:"http://json-schema.org/draft-07/schema#",$id:"https://json.schemastore.org/chrome-manifest.json",additionalProperties:!0,definitions:{action_v2:{type:"object",properties:{default_title:{type:"string",description:"Tooltip for the main toolbar icon."},default_popup:{$ref:"#/definitions/uri",description:"The popup appears when the user clicks the icon."},default_icon:{anyOf:[{type:"string",description:"FIXME: String form is deprecated."},{type:"object",description:"Icon for the main toolbar.",properties:{"19":{$ref:"#/definitions/icon"},"38":{$ref:"#/definitions/icon"}}}]}},dependencies:{name:{not:{required:["name"]}},icons:{not:{required:["icons"]}},popup:{not:{required:["popup"]}}}},action_v3:{type:"object",properties:{default_title:{type:"string",description:"Tooltip for the main toolbar icon."},default_popup:{$ref:"#/definitions/uri",description:"The popup appears when the user clicks the icon."},default_icon:{type:"object",properties:{"16":{$ref:"#/definitions/icon"},"24":{$ref:"#/definitions/icon"},"32":{$ref:"#/definitions/icon"}}}},dependencies:{name:{not:{required:["name"]}},icons:{not:{required:["icons"]}},popup:{not:{required:["popup"]}}}},command:{type:"object",if:{$comment:"Global shortcuts change the acceptable pattern for the suggested_key.",properties:{global:{const:!0}},required:["global"]},then:{additionalProperties:!1,properties:{description:{type:"string"},global:{type:"boolean",description:"Whether this command should work while Chrome does not have focus. Keyboard shortcut suggestions for global commands are limited to Ctrl+Shift+[0..9]"},suggested_key:{type:"object",additionalProperties:!1,patternProperties:{"^(default|mac|windows|linux|chromeos)$":{type:"string",pattern:"^(Ctrl|Command|MacCtrl)\\+Shift\\+[0-9]"}}}}},else:{additionalProperties:!1,properties:{description:{type:"string"},global:{type:"boolean",description:"Whether this command should work while Chrome does not have focus. Keyboard shortcut suggestions for global commands are limited to Ctrl+Shift+[0..9]"},suggested_key:{type:"object",additionalProperties:!1,patternProperties:{"^(default|mac|windows|linux|chromeos)$":{type:"string",pattern:"^(Ctrl|Command|MacCtrl|Alt|Option)\\+(Shift\\+)?[A-Z]"}}}}}},content_security_policy:{type:"string",description:"This introduces some fairly strict policies that will make extensions more secure by default, and provides you with the ability to create and enforce rules governing the types of content that can be loaded and executed by your extensions and applications.",format:"content-security-policy",default:"script-src 'self'; object-src 'self'"},glob_pattern:{type:"string",format:"glob-pattern"},icon:{$ref:"#/definitions/uri"},match_pattern:{type:"string",format:"match-pattern",pattern:"^((\\*|http|https|file|ftp|chrome-extension):\\/\\/(\\*|\\*\\.[^\\/\\*]+|[^\\/\\*]+)?(\\/.*))|urn:(\\*|.*)|<all_urls>$"},mime_type:{type:"string",format:"mime-type",pattern:"^(?:application|audio|image|message|model|multipart|text|video)\\/[-+.\\w]+$"},page:{$ref:"#/definitions/uri"},permissions:{type:"array",uniqueItems:!0,items:{type:"string",format:"permission"}},scripts:{type:"array",minItems:1,uniqueItems:!0,items:{$ref:"#/definitions/uri"}},uri:{type:"string"},version_string:{type:"string",pattern:"^(?:\\d{1,5}\\.){0,3}\\d{1,5}$"},web_resource:{type:"object",required:["resources"],properties:{resources:{type:"array",description:`An array of resources to be exposed. Resources are specified as strings and may contain * for wildcard matches. For example, "/images/*" exposes everything in the extension's /images directory recursively while "*.png" exposes all PNG files.`,items:{$ref:"#/definitions/glob_pattern"}},matches:{type:"array",description:"A list of URL match patterns specifying which pages can access the resources. Only the origin is used to match URLs; subdomains patterns (*.google.com) and paths are ignored.",items:{$ref:"#/definitions/match_pattern"}},extension_ids:{type:"array",description:"A list of extension IDs, specifying which extensions can access the resources.",items:{type:"string"}},use_dynamic_url:{type:"boolean",description:"If true, only allow resources to be accessible through dynamic ID. The dynamic ID is generated per session. It's regenerated on browser restart or extension reload."}}}},dependencies:{content_scripts:{not:{required:["script_badge"]}},script_badge:{not:{required:["content_scripts"]}}},else:{properties:{background:{type:"object",description:"The background page is an HTML page that runs in the extension process. It exists for the lifetime of your extension, and only one instance of it at a time is active.",properties:{persistent:{type:"boolean",description:"When false, makes the background page an event page (loaded only when needed).",default:!0},page:{$ref:"#/definitions/page",description:"Specify the HTML of the background page.",default:"background.html"},scripts:{$ref:"#/definitions/scripts",description:"A background page will be generated by the extension system that includes each of the files listed in the scripts property.",default:["background.js"]}},dependencies:{page:{not:{required:["scripts"]}},scripts:{not:{required:["page"]}}}},browser_action:{$ref:"#/definitions/action_v2",description:"Use browser actions to put icons in the main Google Chrome toolbar, to the right of the address bar. In addition to its icon, a browser action can also have a tooltip, a badge, and a popup."},page_action:{$ref:"#/definitions/action_v2",description:"Use the chrome.pageAction API to put icons inside the address bar. Page actions represent actions that can be taken on the current page, but that aren't applicable to all pages."},content_security_policy:{$ref:"#/definitions/content_security_policy"},web_accessible_resources:{type:"array",description:"An array of strings specifying the paths (relative to the package root) of packaged resources that are expected to be usable in the context of a web page.",minItems:1,uniqueItems:!0,items:{$ref:"#/definitions/uri"}}},dependencies:{page_action:{not:{required:["browser_action"]}},browser_action:{not:{required:["page_action"]}}}},if:{properties:{manifest_version:{const:3}}},properties:{manifest_version:{type:"number",description:"One integer specifying the version of the manifest file format your package requires.",enum:[2,3]},name:{type:"string",description:"The name of the extension",maxLength:45},version:{$ref:"#/definitions/version_string",description:"One to four dot-separated integers identifying the version of this extension."},default_locale:{type:"string",description:"Specifies the subdirectory of _locales that contains the default strings for this extension.",default:"en"},description:{type:"string",description:"A plain text description of the extension",maxLength:132},icons:{type:"object",description:"One or more icons that represent the extension, app, or theme. Recommended format: PNG; also BMP, GIF, ICO, JPEG.",minProperties:1,properties:{"16":{$ref:"#/definitions/icon",description:"Used as the favicon for an extension's pages and infobar."},"48":{$ref:"#/definitions/icon",description:"Used on the extension management page (chrome://extensions)."},"128":{$ref:"#/definitions/icon",description:"Used during installation and in the Chrome Web Store."},"256":{$ref:"#/definitions/icon",description:"Used during installation and in the Chrome Web Store."}}},chrome_url_overrides:{type:"object",description:"Override pages are a way to substitute an HTML file from your extension for a page that Google Chrome normally provides.",additionalProperties:!1,maxProperties:1,properties:{bookmarks:{$ref:"#/definitions/page",description:"The page that appears when the user chooses the Bookmark Manager menu item from the Chrome menu or, on Mac, the Bookmark Manager item from the Bookmarks menu. You can also get to this page by entering the URL chrome://bookmarks.",default:"bookmarks.html"},history:{$ref:"#/definitions/page",description:"The page that appears when the user chooses the History menu item from the Chrome menu or, on Mac, the Show Full History item from the History menu. You can also get to this page by entering the URL chrome://history.",default:"history.html"},newtab:{$ref:"#/definitions/page",description:"The page that appears when the user creates a new tab or window. You can also get to this page by entering the URL chrome://newtab.",default:"newtab.html"}}},commands:{type:"object",description:"Use the commands API to add keyboard shortcuts that trigger actions in your extension, for example, an action to open the browser action or send a command to the extension.",patternProperties:{".*":{$ref:"#/definitions/command"},"^_execute_browser_action$":{$ref:"#/definitions/command"},"^_execute_page_action$":{$ref:"#/definitions/command"}}},content_scripts:{type:"array",description:"Content scripts are JavaScript files that run in the context of web pages.",minItems:1,uniqueItems:!0,items:{type:"object",required:["matches"],additionalProperties:!1,properties:{matches:{type:"array",description:"Specifies which pages this content script will be injected into.",minItems:1,uniqueItems:!0,items:{$ref:"#/definitions/match_pattern"}},exclude_matches:{type:"array",description:"Excludes pages that this content script would otherwise be injected into.",uniqueItems:!0,items:{$ref:"#/definitions/match_pattern"}},css:{type:"array",description:"The list of CSS files to be injected into matching pages. These are injected in the order they appear in this array, before any DOM is constructed or displayed for the page.",uniqueItems:!0,items:{$ref:"#/definitions/uri"}},js:{$ref:"#/definitions/scripts",description:"The list of JavaScript files to be injected into matching pages. These are injected in the order they appear in this array."},world:{type:"string",description:"The JavaScript world for a script to execute within.",enum:["ISOLATED","MAIN"],default:"ISOLATED"},run_at:{type:"string",description:"Controls when the files in js are injected.",enum:["document_start","document_end","document_idle"],default:"document_idle"},all_frames:{type:"boolean",description:"Controls whether the content script runs in all frames of the matching page, or only the top frame.",default:!1},include_globs:{type:"array",description:"Applied after matches to include only those URLs that also match this glob. Intended to emulate the @include Greasemonkey keyword.",uniqueItems:!0,items:{$ref:"#/definitions/glob_pattern"}},exclude_globs:{type:"array",description:"Applied after matches to exclude URLs that match this glob. Intended to emulate the @exclude Greasemonkey keyword.",uniqueItems:!0,items:{$ref:"#/definitions/glob_pattern"}},match_about_blank:{type:"boolean",description:"Whether to insert the content script on about:blank and about:srcdoc.",default:!1}}}},devtools_page:{$ref:"#/definitions/page",description:"A DevTools extension adds functionality to the Chrome DevTools. It can add new UI panels and sidebars, interact with the inspected page, get information about network requests, and more."},externally_connectable:{description:"Declares which extensions, apps, and web pages can connect to your extension via runtime.connect and runtime.sendMessage.",type:"object",additionalProperties:!1,properties:{ids:{type:"array",items:{type:"string",description:"The IDs of extensions or apps that are allowed to connect. If left empty or unspecified, no extensions or apps can connect."}},matches:{type:"array",items:{type:"string",description:"The URL patterns for web pages that are allowed to connect. This does not affect content scripts. If left empty or unspecified, no web pages can connect."}},accepts_tls_channel_id:{type:"boolean",default:!1,description:"Indicates that the extension would like to make use of the TLS channel ID of the web page connecting to it. The web page must also opt to send the TLS channel ID to the extension via setting includeTlsChannelId to true in runtime.connect's connectInfo or runtime.sendMessage's options."}}},file_browser_handlers:{type:"array",description:"You can use this API to enable users to upload files to your website.",minItems:1,items:{type:"object",required:["id","default_title","file_filters"],additionalProperties:!1,properties:{id:{type:"string",description:"Used by event handling code to differentiate between multiple file handlers"},default_title:{type:"string",description:"What the button will display."},file_filters:{type:"array",description:"Filetypes to match.",minItems:1,items:{type:"string"}}}}},homepage_url:{$ref:"#/definitions/uri",description:"The URL of the homepage for this extension."},incognito:{type:"string",description:"Specify how this extension will behave if allowed to run in incognito mode.",enum:["spanning","split","not_allowed"],default:"spanning"},input_components:{type:"array",description:"Allows your extension to handle keystrokes, set the composition, and manage the candidate window.",items:{type:"object",required:["name","type","id","description","language","layouts"],additionalProperties:!1,properties:{name:{type:"string"},type:{type:"string"},id:{type:"string"},description:{type:"string"},language:{type:"string"},layouts:{type:"array"}}}},key:{type:"string",description:"This value can be used to control the unique ID of an extension, app, or theme when it is loaded during development."},minimum_chrome_version:{$ref:"#/definitions/version_string",description:"The version of Chrome that your extension, app, or theme requires, if any."},nacl_modules:{type:"array",description:"One or more mappings from MIME types to the Native Client module that handles each type.",minItems:1,uniqueItems:!0,items:{type:"object",required:["path","mime_type"],additionalProperties:!1,properties:{path:{$ref:"#/definitions/uri",description:"The location of a Native Client manifest (a .nmf file) within the extension directory."},mime_type:{$ref:"#/definitions/mime_type",description:"The MIME type for which the Native Client module will be registered as content handler."}}}},oauth2:{type:"object",description:"Use the Chrome Identity API to authenticate users: the getAuthToken for users logged into their Google Account and the launchWebAuthFlow for users logged into a non-Google account.",required:["client_id","scopes"],additionalProperties:!1,properties:{client_id:{type:"string",description:"You need to register your app in the Google APIs Console to get the client ID."},scopes:{type:"array",minItems:1,items:{type:"string"}}}},offline_enabled:{type:"boolean",description:"Whether the app or extension is expected to work offline. When Chrome detects that it is offline, apps with this field set to true will be highlighted on the New Tab page."},omnibox:{type:"object",description:"The omnibox API allows you to register a keyword with Google Chrome's address bar, which is also known as the omnibox.",required:["keyword"],additionalProperties:!1,properties:{keyword:{type:"string",description:"The keyword that will trigger your extension."}}},optional_permissions:{$ref:"#/definitions/permissions",description:"Use the chrome.permissions API to request declared optional permissions at run time rather than install time, so users understand why the permissions are needed and grant only those that are necessary."},options_page:{$ref:"#/definitions/page",description:"To allow users to customize the behavior of your extension, you may wish to provide an options page. If you do, a link to it will be provided from the extensions management page at chrome://extensions. Clicking the Options link opens a new tab pointing at your options page.",default:"options.html"},options_ui:{type:"object",description:"To allow users to customize the behavior of your extension, you may wish to provide an options page. If you do, an Options link will be shown on the extensions management page at chrome://extensions which opens a dialogue containing your options page.",required:["page"],properties:{page:{type:"string",description:"The path to your options page, relative to your extension's root."},chrome_style:{type:"boolean",default:!0,description:"If true, a Chrome user agent stylesheet will be applied to your options page. The default value is false, but we recommend you enable it for a consistent UI with Chrome."},open_in_tab:{type:"boolean",default:!1,description:"If true, your extension's options page will be opened in a new tab rather than embedded in chrome://extensions. The default is false, and we recommend that you don't change it. This is only useful to delay the inevitable deprecation of the old options UI! It will be removed soon, so try not to use it. It will break."}}},permissions:{$ref:"#/definitions/permissions",description:"Permissions help to limit damage if your extension or app is compromised by malware. Some permissions are also displayed to users before installation, as detailed in Permission Warnings."},requirements:{type:"object",description:"Technologies required by the app or extension. Hosting sites such as the Chrome Web Store may use this list to dissuade users from installing apps or extensions that will not work on their computer.",additionalProperties:!1,properties:{plugins:{type:"object",description:"Indicates if an app or extension requires NPAPI to run. This requirement is enabled by default when the manifest includes the 'plugins' field.",required:["npapi"],additionalProperties:!1,properties:{npapi:{type:"boolean",default:!0}}},"3D":{type:"object",description:"The '3D' requirement denotes GPU hardware acceleration.",required:["features"],additionalProperties:!1,properties:{features:{type:"array",description:"List of the 3D-related features your app requires.",minItems:1,uniqueItems:!0,items:{type:"string",enum:["webgl"]}}}}}},sandbox:{type:"object",description:"Defines an collection of app or extension pages that are to be served in a sandboxed unique origin, and optionally a Content Security Policy to use with them.",required:["pages"],additionalProperties:!1,properties:{pages:{type:"array",minItems:1,uniqueItems:!0,items:{$ref:"#/definitions/page"}},content_security_policy:{$ref:"#/definitions/content_security_policy",default:"sandbox allow-scripts allow-forms"}}},short_name:{type:"string",description:"The short name is typically used where there is insufficient space to display the full name.",maxLength:12},update_url:{$ref:"#/definitions/uri",description:"If you publish using the Chrome Developer Dashboard, ignore this field. If you host your own extension or app: URL to an update manifest XML file."},tts_engine:{type:"object",description:"Register itself as a speech engine.",required:["voices"],additionalProperties:!1,properties:{voices:{type:"array",description:"Voices the extension can synthesize.",minItems:1,uniqueItems:!0,items:{type:"object",required:["voice_name","event_types"],additionalProperties:!1,properties:{voice_name:{type:"string",description:"Identifies the name of the voice and the engine used."},lang:{type:"string",description:"Almost always, a voice can synthesize speech in just a single language. When an engine supports more than one language, it can easily register a separate voice for each language."},gender:{type:"string",description:"If your voice corresponds to a male or female voice, you can use this parameter to help clients choose the most appropriate voice for their application."},event_types:{type:"array",description:"Events sent to update the client on the progress of speech synthesis.",minItems:1,uniqueItems:!0,items:{type:"string",description:"",enum:["start","word","sentence","marker","end","error"]}}}}}}},version_name:{type:"string",description:"In addition to the version field, which is used for update purposes, version_name can be set to a descriptive version string and will be used for display purposes if present."},chrome_settings_overrides:{},content_pack:{},current_locale:{},import:{},platforms:{},signature:{},spellcheck:{},storage:{},system_indicator:{}},required:["manifest_version","name","version"],then:{$comment:"browser_action and page_action are no longer present in v3",properties:{background:{type:"object",description:"The background page is an HTML page that runs in the extension process. It exists for the lifetime of your extension, and only one instance of it at a time is active.",properties:{service_worker:{type:"string",description:"The service worker js file."},type:{type:"string",enum:["module"]}},dependencies:{page:{not:{required:["scripts"]}},scripts:{not:{required:["page"]}}}},host_permissions:{$ref:"#/definitions/permissions"},action:{$ref:"#/definitions/action_v3",description:"Used to control the toolbar button for your extension in Chrome's UI."},content_security_policy:{type:"object",properties:{extension_pages:{$ref:"#/definitions/content_security_policy",description:"This policy covers pages in your extension, including html files and service workers."},sandbox:{$ref:"#/definitions/content_security_policy",description:"This policy covers any sandboxed extension pages that your extension uses."}}},web_accessible_resources:{type:"array",description:"An array of objects that declare resource access rules. Each object maps an array of extension resources to an array of URLs and/or extension IDs that can access those resources.",minItems:1,uniqueItems:!0,items:{$ref:"#/definitions/web_resource"}}},dependencies:{browser_action:{not:{required:["browser_action"]}},page_action:{not:{required:["page_action"]}}}},title:"JSON schema for Google Chrome extension manifest files",type:"object"};function ba(t){t.addFormat("permission",{type:"string",validate:e=>typeof e=="string"&&e.trim()!==""}),t.addFormat("content-security-policy",{type:"string",validate:e=>typeof e=="string"}),t.addFormat("glob-pattern",{type:"string",validate:e=>typeof e=="string"&&/[\*\?\[\]]/.test(e)}),t.addFormat("match-pattern",{type:"string",validate:e=>e==="<all_urls>"||e==="file:///"||e.startsWith("http://localhost")||e.startsWith("http:// ")||e.startsWith("http://*:*/*")?!0:typeof e=="string"&&/^(\*|http|https|file|ftp):\/\//.test(e)}),t.addFormat("uri",{type:"string",validate:e=>typeof e=="string"&&/^(\w+:)?\/\//.test(e)}),t.addFormat("mime-type",{type:"string",validate:e=>typeof e=="string"&&/^[a-z]+\/[a-z0-9\-\+]+$/.test(e)})}var wa=a(require("path")),xa=require("webpack");function va(t,e,s){let r=t.options.context||"",i=wa.default.join(r,"manifest.json"),o=require(i).name||"Extension.js",c=e?.params.missingProperty;t.errors.push(new xa.WebpackError(Zr(o,s,c)))}var _a=a(require("path")),Sa=require("webpack");function Pa(t,e,s){let r=t.options.context||"",i=_a.default.join(r,"manifest.json"),o=require(i).name||"Extension.js";t.warnings.push(new Sa.WebpackError(Xr(o,e,s)))}var ka=a(require("path")),Ea=require("webpack");function vr(t,e,s){let r=t.options.context||"",i=ka.default.join(r,"manifest.json"),o=require(i).name||"Extension.js";t.warnings.push(new Ea.WebpackError(Gr(o,s,e)))}var vs=class{options;constructor(e){this.options=e}handleSchemaErrors(e,s,r){let i=new $a.default;ba(i);let n={allOf:[ya]},o=i.compile(n),c=o(s),p=s.manifest_version===3;if(!c&&o.errors){let l=o.errors[0];if(l?.keyword==="required"){va(e,l,r);return}p&&(l?.keyword==="type"&&Pa(e,l,r),l?.keyword==="not"&&vr(e,l,r))}}apply(e){e.hooks.afterCompile.tapAsync("CompatPlugin (module)",(s,r)=>{let i=this.options.manifestPath,n=JSON.parse(ja.default.readFileSync(i,"utf-8")),o=this.options.browser||"chrome";this.handleSchemaErrors(s,n,o),r()})}};var Fa=a(require("fs")),Sr=a(require("path"));var _r=a(require("webpack"));function Ca(t,e){let s="Conflict: Multiple assets emit different content to the same filename ";if(e.message.includes(s)){let r=e.message.replace(s,"");if(r.startsWith("content_scripts"))return new _r.default.WebpackError(Yr(t,r))}return null}function Da(t,e){let s=require(t);return e.message.includes("Top-level-await is only supported in EcmaScript Modules")?new _r.default.WebpackError(Kr(s.name)):null}var _s=class{manifestPath;constructor(e){this.manifestPath=e.manifestPath}apply(e){let s=Sr.default.join(Sr.default.dirname(this.manifestPath),"package.json");if(!Fa.default.existsSync(s))return;let r=require(s).name;e.hooks.compilation.tap("develop:common-errors",i=>{i.hooks.afterSeal.tapAsync("develop:common-errors",n=>{i.errors.forEach((o,c)=>{let p=Ca(r,o),l=Da(r,o);p&&(i.errors[c]=p),l&&(i.errors[c]=l)}),n()})})}};var Ss=class{static name="plugin-errors";manifestPath;browser;constructor(e){this.manifestPath=e.manifestPath,this.browser=e.browser||"chrome"}apply(e){new xs({manifestPath:this.manifestPath,browser:this.browser||"chrome"}).apply(e),new vs({manifestPath:this.manifestPath,browser:this.browser||"chrome"}).apply(e),new _s({manifestPath:this.manifestPath}).apply(e)}};var yc=a(require("os")),kr=a(require("path"));var ec=a(require("fs")),tc=require("child_process");var re=a(require("path")),$s=a(require("fs"));var La={alternate_error_pages:{enabled:!1},autofill:{enabled:!1},browser:{check_default_browser:!1,default_browser_setting_enabled:!1},default_apps:"install",distribution:{alternate_shortcut_text:!1,auto_launch_chrome:!1,import_bookmarks:!1,import_history:!1,import_home_page:!1,import_search_engine:!1,suppress_first_run_bubble:!0,do_not_register_for_update_launch:!0,make_chrome_default:!1,make_chrome_default_for_user:!1,require_eula:!1,suppress_first_run_default_browser_prompt:!0},dns_prefetching:{enabled:!1},download:{default_directory:"/tmp/",directory_upgrade:!0,open_pdf_in_adobe_reader:!1,prompt_for_download:!0},enable_do_not_track:!0,extensions:{theme:{use_system:!1},toolbarsize:-1,ui:{developer_mode:!0}},plugins:{plugins_list:[{enabled:!1,name:"Java(TM)"}],show_details:!0},profile:{password_manager_enabled:!1},safebrowsing:{enabled:!1,safebrowsingextended_reporting_enabled:!1},savefile:{default_directory:"/tmp",type:0},search:{suggest_enabled:!1},session:{restore_on_startup:1},sync:{suppress_start:!0},sync_promo:{show_on_first_run_allowed:!1,show_ntp_bubble:!1},translate:{enabled:!1}},Ia={...La},Oa={...La};var x=require("@colors/colors/safe");function E(t,e){let s=e==="warn"?(0,x.brightYellow)("\u25BA\u25BA\u25BA"):e==="info"?(0,x.cyan)("\u25BA\u25BA\u25BA"):e==="error"?(0,x.red)("\u2716\uFE0E\u2716\uFE0E\u2716\uFE0E"):(0,x.brightGreen)("\u25BA\u25BA\u25BA");return`${(0,x.gray)("")}${s}`}function Be(t){return t.charAt(0).toUpperCase()+t.slice(1)}function Ps(t,e){let s=t==="firefox"?"Add-on":"Extension";return`${E(t,"success")} ${Be(t)} ${s} running in ${(0,x.cyan)(e||"unknown")} mode.`}function ks(t,e){let s=Be(t),r=e=="null"?`${s} browser is not installed.
108
+ Learn more about ${(0,f.bold)("mkcert")}: ${(0,f.underline)("https://github.com/FiloSottile/mkcert")}`}function xi(t){return`${x("Port","error")} Selected port ${(0,f.brightYellow)(t.toString())} in use. Choose a new port. `}function vi(){return`${x("manifest.json","error")} Extension ID Not Defined
125
109
 
126
- `:`Path to ${s} browser is not found.
110
+ For MAIN world content_scripts, the extension ID must be specified.
111
+ Ensure your extension have a fixed ID and that the ${(0,f.brightYellow)("publicPath")}
112
+ of your ${(0,f.brightYellow)("extension.config.js")} is defined as your extension URL.`}var at=class{manifestPath;browser;constructor(e){this.manifestPath=e.manifestPath,this.browser=e.browser||"chrome"}apply(e){let r=nt.default.dirname(this.manifestPath),s=e.options.mode||"development",i=[`.env.${this.browser}.${s}`,`.env.${this.browser}`,`.env.${s}`,".env.local",".env",".env.example"],o="";for(let d of i){let g=nt.default.join(r,d);if(zr.default.existsSync(g)){o=g;break}}if(!o)return;console.log(Zs());let n=Jr.default.config({path:o}).parsed||{},c=nt.default.join(r,".env.defaults"),l={...zr.default.existsSync(c)?Jr.default.config({path:c}).parsed||{}:{},...n,...process.env},u=Object.keys(l).filter(d=>d.startsWith("EXTENSION_PUBLIC_")).reduce((d,g)=>(d[`process.env.${g}`]=JSON.stringify(l[g]),d[`import.meta.env.${g}`]=JSON.stringify(l[g]),d),{});u["process.env.EXTENSION_PUBLIC_BROWSER"]=JSON.stringify(this.browser),u["import.meta.env.EXTENSION_PUBLIC_BROWSER"]=JSON.stringify(this.browser),u["process.env.EXTENSION_PUBLIC_ENV_MODE"]=JSON.stringify(s),u["import.meta.env.EXTENSION_PUBLIC_ENV_MODE"]=JSON.stringify(s),new oe.DefinePlugin(u).apply(e),e.hooks.thisCompilation.tap("manifest:update-manifest",d=>{d.hooks.processAssets.tap({name:"env:module",stage:oe.Compilation.PROCESS_ASSETS_STAGE_SUMMARIZE},g=>{Object.keys(g).forEach(_=>{if(_.endsWith(".json")||_.endsWith(".html")){let v=d.assets[_].source().toString();v=v.replace(/\$EXTENSION_PUBLIC_[A-Z_]+/g,M=>{let T=M.slice(1);return l[T]||M}),d.updateAsset(_,new oe.sources.RawSource(v))}})})})}};var Hr=a(require("fs")),_i=a(require("path")),ct=class{apply(e){let r=_i.default.join(e.options.output.path||"","hot");if(Hr.default.existsSync(r))try{Hr.default.rmSync(r,{recursive:!0,force:!0}),process.env.EXTENSION_ENV==="development"&&console.log("[CleanHotUpdatesPlugin] Removed old hot-update files before compilation.")}catch(s){console.error(`[CleanHotUpdatesPlugin] Failed to remove hot-update files: ${s.message}`)}}};var pt=class{static name="plugin-compilation";manifestPath;browser;constructor(e){this.manifestPath=e.manifestPath,this.browser=e.browser||"chrome"}apply(e){new Si.default().apply(e),new at({manifestPath:this.manifestPath,browser:this.browser}).apply(e),new ct().apply(e),e.hooks.done.tap("develop:brand",r=>{r.compilation.name=void 0;let s=r.endTime-r.startTime,i=require(this.manifestPath).name;console.log(Gs(i,s,r))})}};var Hi=a(require("path")),Vi=a(require("mini-css-extract-plugin"));var Bi=a(require("mini-css-extract-plugin"));var ve=a(require("path")),_e=a(require("fs"));var ne=a(require("path")),lt=a(require("fs")),Vr=require("child_process"),ki=require("package-manager-detector");function Ei(t,e){return Object.values(e||{}).some(r=>r===t)}function h(t,e,r){let s=ne.default.extname(e),o=k(e,r)?ne.default.normalize(e):t;return[".js",".jsx",".tsx",".ts"].includes(s)&&(o=o.replace(s,".js")),[".html",".njk",".nunjucks"].includes(s)&&(o=o.replace(s,".html")),[".css",".scss",".sass",".less"].includes(s)&&(o=o.replace(s,".css")),Gr(o||"")}function Gr(t){return t.replace(/\\/g,"/")}function k(t,e={}){if(!e)return!1;let r=ne.default.normalize(Gr(t));return Object.values(e).some(i=>typeof i!="string"?!1:Gr(i).includes(r))}function z(t,e){if(t.getAsset("manifest.json")||t.assets["manifest.json"]){let r=t.assets["manifest.json"].source().toString();return JSON.parse(r||"{}")}return require(e)}function ae(){return process.env.npm_config_user_agent&&process.env.npm_config_user_agent.includes("pnpm")?"pnpm":!1}function Pi(){return process.env.npm_execpath?"npm":!1}async function C(t,e){try{let r=await(0,ki.detect)();console.log(Xs(t,r?.name||"unknown"));let s="";r?.name==="yarn"?s=`yarn --silent add ${e.join(" ")} --cwd ${__dirname} --optional`:r?.name==="npm"||Pi()?s=`npm --silent install ${e.join(" ")} --prefix ${__dirname} --save-optional`:ae()?s=`pnpm --silent add ${e.join(" ")} --prefix ${__dirname} --save-optional`:s=`${r} --silent install ${e.join(" ")} --cwd ${__dirname} --optional`,(0,Vr.execSync)(s,{stdio:"inherit"}),await new Promise(i=>setTimeout(i,2e3)),process.env.EXTENSION_ENV==="development"&&(console.log(Ks(t)),r?.name==="yarn"?s="yarn install --silent > /dev/null 2>&1":r?.name==="npm"||Pi()?s="npm install --silent > /dev/null 2>&1":ae()?s="pnpm install --silent > /dev/null 2>&1":s=`${r} install --silent > /dev/null 2>&1`,(0,Vr.execSync)(s,{stdio:"inherit"})),console.log(Ys(t))}catch(r){console.error(Qs(t,r))}}function ft(t){let e=ne.default.join(t,"package.json");if(!lt.default.existsSync(e))return!1;let r=JSON.parse(lt.default.readFileSync(e,"utf-8")),s=["react","vue","@angular/core","svelte","solid-js","preact"],i=r.dependencies||{},o=r.devDependencies||{};for(let n of s)if(i[n]||o[n])return!0;return!1}function $i(t){return!lt.default.existsSync(ne.default.resolve(__dirname,`run-${t}-profile`))}function Ci(t){let e=t.name?.replace(/ /g,"-").toLowerCase();return{data:{id:`${e}@extension-js`,manifest:t,management:{id:`${e}@extension-js`,mayDisable:!0,optionsUrl:"",installType:"development",type:"extension",enabled:!0,name:t.name||"",description:t.description||"",version:t.version||"",hostPermissions:t.host_permissions||[],permissions:t.permissions||[],offlineEnabled:t.offline_enabled||!1,shortName:t.short_name||"",isApp:t.app&&t.app.background&&t.app.background.scripts}}}}function O(t,e){return JSON.parse(JSON.stringify(t),function(i,o){let n=i.indexOf(":");if(n===-1)return o;let c=i.substring(0,n);(c===e||c==="chromium"&&Q.includes(e))&&(this[i.substring(n+1)]=o)})}var ji=!1;function ut(t){let e=ve.default.join(t,"package.json");if(!_e.default.existsSync(e))return!1;let r=Xp(t),s=require(e),i=s.devDependencies&&s.devDependencies.tailwindcss,o=s.dependencies&&s.dependencies.tailwindcss,n=!!r&&!!(i||o);return n&&(ji||(process.env.EXTENSION_ENV==="development"&&console.log(S("Tailwind")),ji=!0)),n}function Xp(t){let e=ve.default.join(t,"tailwind.config.mjs"),r=ve.default.join(t,"tailwind.config.cjs"),s=ve.default.join(t,"tailwind.config.js");if(_e.default.existsSync(e))return e;if(_e.default.existsSync(r))return r;if(_e.default.existsSync(s))return s}var Fi=a(require("path")),Li=a(require("fs"));var Di=!1;function Se(t){let e=Fi.default.join(t,"package.json");if(!Li.default.existsSync(e))return!1;let r=require(e),s=r.devDependencies&&r.devDependencies.sass,i=r.dependencies&&r.dependencies.sass;return s||i?(Di||(process.env.EXTENSION_ENV==="development"&&console.log(S("SASS")),Di=!0),!0):!1}async function Ii(t,e){if(!Se(t))return[];try{require.resolve("sass-loader")}catch{await C("PostCSS",["postcss-loader","postcss-scss","postcss-flexbugs-fixes","postcss-preset-env","postcss-normalize"]),await C("SASS",["sass","sass-loader","resolve-url-loader"]),console.log(D("SASS")),process.exit(0)}return[{test:/\.(s(a|c)ss)$/,exclude:/\.module\.(s(a|c)ss)$/,oneOf:[{resourceQuery:/is_content_css_import=true/,use:await N(t,{loader:"sass-loader",mode:e,useMiniCssExtractPlugin:!1})},{use:await N(t,{loader:"sass-loader",mode:e,useMiniCssExtractPlugin:e==="production"})}]},{test:/\.module\.(s(a|c)ss)$/,oneOf:[{resourceQuery:/is_content_css_import=true/,use:await N(t,{loader:"sass-loader",mode:e,useMiniCssExtractPlugin:!1})},{use:await N(t,{loader:"sass-loader",mode:e,useMiniCssExtractPlugin:!0})}]}]}var Mi=a(require("path")),Ai=a(require("fs"));var Oi=!1;function Pe(t){let e=Mi.default.join(t,"package.json");if(!Ai.default.existsSync(e))return!1;let r=require(e),s=r.devDependencies&&r.devDependencies.less,i=r.dependencies&&r.dependencies.less;return s||i?(Oi||(process.env.EXTENSION_ENV==="development"&&console.log(S("LESS")),Oi=!0),!0):!1}async function Ri(t,e){if(!Pe(t))return[];try{require.resolve("less-loader")}catch{await C("LESS",["less","less-loader","resolve-url-loader"]),console.log(D("LESS")),process.exit(0)}return[{test:/\.less$/,oneOf:[{resourceQuery:/is_content_css_import=true/,use:await N(t,{loader:"less-loader",mode:e,useMiniCssExtractPlugin:!1})},{use:await N(t,{loader:"less-loader",mode:e,useMiniCssExtractPlugin:e==="production"})}]}]}var dt=a(require("path")),mt=a(require("fs"));var ce=!1;function Zp(t){let e=dt.default.join(t,"package.json");if(!mt.default.existsSync(e))return!1;let r=[".postcssrc",".postcssrc.json",".postcssrc.yaml",".postcssrc.yml",".postcssrc.js",".postcssrc.cjs","postcss.config.js","postcss.config.cjs"];if(mt.default.existsSync(e)){let s=require(e);if(s.dependencies&&s.dependencies.postcss||s.devDependencies&&s.devDependencies.postcss)return ce||(process.env.EXTENSION_ENV==="development"&&console.log(S("PostCSS")),ce=!0),!0}for(let s of r)if(mt.default.existsSync(dt.default.join(t,s)))return ce||(process.env.EXTENSION_ENV==="development"&&console.log(S("PostCSS")),ce=!0),!0;return ut(t)?(ce||(process.env.EXTENSION_ENV==="development"&&console.log(S("PostCSS")),ce=!0),!0):!1}async function Ti(t,e){if(!Zp(t))return{};try{require.resolve("postcss-loader")}catch{!Se(t)&&!Pe(t)&&await C("PostCSS",["postcss","postcss-loader","postcss-scss","postcss-flexbugs-fixes","postcss-preset-env","postcss-normalize"]),console.log(D("PostCSS")),process.exit(0)}return{loader:require.resolve("postcss-loader"),options:{postcssOptions:{parser:require.resolve("postcss-scss"),ident:"postcss",config:dt.default.resolve(t,"postcss.config.js"),plugins:[require.resolve("postcss-flexbugs-fixes"),[require.resolve("postcss-preset-env"),{autoprefixer:{flexbox:"no-2009"},stage:3}].filter(Boolean),require.resolve("postcss-normalize")].filter(Boolean)},sourceMap:e.mode==="development"}}}var Ui=a(require("path")),qi=a(require("fs"));var Ni=!1;function ke(t){let e=Ui.default.join(t,"package.json");if(!qi.default.existsSync(e))return!1;let r=require(e),s=r.devDependencies&&r.devDependencies.vue,i=r.dependencies&&r.dependencies.vue;return(s||i)&&(Ni||(process.env.EXTENSION_ENV==="development"&&console.log(S("Vue")),Ni=!0)),!!s||!!i}async function Wi(t){if(!ke(t))return;try{require.resolve("vue-loader")}catch{await C("TypeScript",["typescript"]),await C("Vue",["vue-loader","vue-template-compiler","vue-style-loader"]),console.log(D("Vue")),process.exit(0)}let e=[{test:/\.vue$/,loader:require.resolve("vue-loader"),include:t,exclude:/node_modules/}];return{plugins:[new(require("vue-loader")).VueLoaderPlugin],loaders:e,alias:void 0}}async function N(t,e){let r=Bi.default.loader,s=[e.useMiniCssExtractPlugin?r:ke(t)?require.resolve("vue-style-loader"):require.resolve("style-loader"),{loader:require.resolve("css-loader"),options:{sourceMap:e.mode==="development"}}].filter(Boolean);if(ut(t)||Se(t)||Pe(t)){let i=await Ti(t,e);i.loader&&s.push(i)}return e.loader&&s.push({loader:require.resolve("resolve-url-loader"),options:{sourceMap:e.mode==="development",root:t}},{loader:require.resolve(e.loader),options:{sourceMap:e.mode==="development"}}),s.filter(Boolean)}var A=a(require("path")),R=a(require("fs"));function Kp(t){let e=A.default.join(t,"stylelint.config.json"),r=A.default.join(t,".stylelintrc.js file"),s=A.default.join(t,"stylelint.config.mjs"),i=A.default.join(t,".stylelintrc.mjs"),o=A.default.join(t,"stylelint.config.cjs"),n=A.default.join(t,".stylelintrc.cjs"),c=A.default.join(t,".stylelintrc.json"),p=A.default.join(t,".stylelintrc"),l=A.default.join(t,".stylelintrc.yml"),u=A.default.join(t,".stylelintrc.yaml");if(R.default.existsSync(e))return e;if(R.default.existsSync(r))return r;if(R.default.existsSync(s))return s;if(R.default.existsSync(i))return i;if(R.default.existsSync(o))return o;if(R.default.existsSync(n))return n;if(R.default.existsSync(c))return c;if(R.default.existsSync(p))return p;if(R.default.existsSync(l))return l;if(R.default.existsSync(u))return u}var zi=!1;function Yp(t){let e=A.default.join(t,"package.json");if(!R.default.existsSync(e))return!1;let s=!!Kp(t);return s&&(zi||(process.env.EXTENSION_ENV==="development"&&console.log(S("Stylelint")),zi=!0)),s}async function Ji(t){return Yp(t),[]}var gt=class t{static name="plugin-css";manifestPath;constructor(e){this.manifestPath=e.manifestPath}async configureOptions(e){let r=e.options.mode||"development",s=Hi.default.dirname(this.manifestPath),i=[new Vi.default];i.forEach(l=>l.apply(e));let o=await Ji(s);i.push(...o);let n=[{test:/\.css$/,exclude:/\.module\.css$/,oneOf:[{use:await N(s,{mode:r,useMiniCssExtractPlugin:r==="production"})}]},{test:/\.module\.css$/,oneOf:[{use:await N(s,{mode:r,useMiniCssExtractPlugin:r==="production"})}]}];e.options.plugins=[...e.options.plugins,...i].filter(Boolean);let c=await Ii(s,r),p=await Ri(s,r);n.push(...c),n.push(...p),e.options.module.rules=[...e.options.module.rules,...n].filter(Boolean)}async apply(e){if((e.options.mode||"development")==="production"){e.hooks.beforeRun.tapPromise(t.name,async()=>await this.configureOptions(e));return}await this.configureOptions(e)}};var ht=class{static name="plugin-css";manifestPath;constructor(e){this.manifestPath=e.manifestPath}async apply(e){let r={test:/\.svg$/i,type:"asset/resource",generator:{filename:"assets/[name][ext]"},parser:{dataUrlCondition:{maxSize:2048}}},i=[...e.options.module.rules.some(o=>o&&o.test instanceof RegExp&&o.test.test(".svg")&&o.use!==void 0)?[]:[r],{test:/\.(png|jpg|jpeg|gif|webp|avif|ico|bmp)$/i,type:"asset/resource",generator:{filename:"assets/[name][ext]"},parser:{dataUrlCondition:{maxSize:2*1024}}},{test:/\.(woff|woff2|eot|ttf|otf)$/i,type:"asset/resource",generator:{filename:"assets/[name][ext]"}},{test:/\.(txt|md|csv|tsv|xml|pdf|docx|doc|xls|xlsx|ppt|pptx|zip|gz|gzip|tgz)$/i,type:"asset/resource",generator:{filename:"assets/[name][ext]"},parser:{dataUrlCondition:{maxSize:2*1024}}},{test:/\.(csv|tsv)$/i,use:[require.resolve("csv-loader")],generator:{filename:"assets/[name][ext]"}}];e.options.module.rules=[...e.options.module.rules,...i].filter(Boolean)}};var Kr=a(require("path"));var Xr=a(require("path")),Zr=a(require("fs"));var Gi=!1,Qp=[".babelrc",".babelrc.json",".babelrc.js",".babelrc.cjs","babel.config.json","babel.config.js","babel.config.cjs"];function el(t){let e=Xr.default.join(t,"package.json");if(!Zr.default.existsSync(e))return!1;let r=require(e),s=r.devDependencies&&r.devDependencies["babel-core"],i=r.dependencies&&r.dependencies["babel-core"],o=Qp.some(n=>Zr.default.existsSync(Xr.default.join(t,n)))||!!s||!!i;return o&&(Gi||(process.env.EXTENSION_ENV==="development"&&process.env.EXTENSION_ENV==="development"&&console.log(S("Babel")),Gi=!0)),o}async function Xi(t,e){el(e)}var Ki=a(require("path")),Yi=a(require("fs"));var Zi=!1;function pe(t){let e=Ki.default.join(t,"package.json");if(!Yi.default.existsSync(e))return!1;let r=require(e),s=r.devDependencies&&r.devDependencies.preact,i=r.dependencies&&r.dependencies.preact;return(s||i)&&(Zi||(process.env.EXTENSION_ENV==="development"&&console.log(S("Preact")),Zi=!0)),!!s||!!i}async function Qi(t){if(!pe(t))return;try{require.resolve("@prefresh/webpack")}catch{await C("Preact",["@prefresh/webpack"]),console.log(D("Preact")),process.exit(0)}return{plugins:[new(require("@prefresh/webpack"))],loaders:void 0,alias:{react:"preact/compat","react-dom/test-utils":"preact/test-utils","react-dom":"preact/compat","react/jsx-runtime":"preact/jsx-runtime"}}}var to=a(require("path")),ro=a(require("fs"));var eo=!1;function le(t){let e=to.default.join(t,"package.json");if(!ro.default.existsSync(e))return!1;let r=require(e),s=r.devDependencies&&r.devDependencies.react,i=r.dependencies&&r.dependencies.react;return(s||i)&&(eo||(process.env.EXTENSION_ENV==="development"&&console.log(S("React")),eo=!0)),!!s||!!i}async function so(t){if(!le(t))return;try{require.resolve("@pmmmwh/react-refresh-webpack-plugin")}catch{await C("React",["react-refresh","@pmmmwh/react-refresh-webpack-plugin","react-refresh-typescript"]),console.log(D("React")),process.exit(0)}return{plugins:[new(require("@pmmmwh/react-refresh-webpack-plugin"))({overlay:!1})],loaders:void 0,alias:void 0}}var yt=a(require("path")),bt=a(require("fs"));var io=!1;function V(t){let e=yt.default.join(t,"package.json");if(!bt.default.existsSync(e))return!1;let r=rl(t),s=require(e),i=s.devDependencies&&s.devDependencies.typescript,o=s.dependencies&&s.dependencies.typescript;return io||((i||o)&&(r?process.env.EXTENSION_ENV==="development"&&console.log(S("TypeScript")):(console.log(di()),sl(t))),io=!0),!!r&&!!(i||o)}function tl(t,e){return{compilerOptions:{allowJs:!0,allowSyntheticDefaultImports:!0,esModuleInterop:!0,forceConsistentCasingInFileNames:!0,jsx:ft(t)?"react-jsx":"preserve",lib:["dom","dom.iterable","esnext"],moduleResolution:"node",module:"esnext",resolveJsonModule:!0,strict:!0,target:"esnext",isolatedModules:!1,skipLibCheck:!0},exclude:["node_modules","dist"]}}function rl(t){let e=yt.default.join(t,"tsconfig.json");if(bt.default.existsSync(e))return e}function sl(t){bt.default.writeFileSync(yt.default.join(t,"tsconfig.json"),JSON.stringify(tl(t,{mode:"development"}),null,2))}var wt=class t{static name="plugin-js-frameworks";manifestPath;constructor(e){this.manifestPath=e.manifestPath}async configureOptions(e){let r=e.options.mode||"development",s=Kr.default.dirname(this.manifestPath),i=await Xi(e,s),o=await so(s),n=await Qi(s),c=await Wi(s);e.options.resolve.alias={...i?.alias||{},...o?.alias||{},...n?.alias||{},...c?.alias||{},...e.options.resolve.alias},e.options.module.rules=[{test:/\.(js|mjs|jsx|mjsx|ts|mts|tsx|mtsx)$/,include:[Kr.default.dirname(this.manifestPath)],exclude:/node_modules/,use:{loader:require.resolve("swc-loader"),options:{sync:!0,module:{type:"es6"},minify:r==="production",isModule:!0,jsc:{target:"es2016",parser:{syntax:V(s)?"typescript":"ecmascript",tsx:V(s)&&(le(s)||pe(s)),jsx:!V(s)&&(le(s)||pe(s)),dynamicImport:!0},transform:{react:{development:r==="development",refresh:r==="development",runtime:"automatic",importSource:"react"}}}}}},...i?.loaders||[],...o?.loaders||[],...n?.loaders||[],...c?.loaders||[],...e.options.module.rules].filter(Boolean),o?.plugins?.forEach(p=>p.apply(e)),n?.plugins?.forEach(p=>p.apply(e)),c?.plugins?.forEach(p=>p.apply(e))}async apply(e){if((e.options.mode||"development")==="production"){e.hooks.beforeRun.tapPromise(t.name,async()=>await this.configureOptions(e));return}await this.configureOptions(e)}};var Ue=a(require("path"));var Jo=a(require("path"));var oo=a(require("path"));function no(t,e){if(!e||!e.action||!e.action.default_popup)return;let r=e.action.default_popup;return oo.default.join(t,r)}var ao=a(require("path"));function co(t,e){if(!e||!e.browser_action||!e.browser_action.default_popup)return;let r=e.browser_action.default_popup;return ao.default.join(t,r)}var xt=a(require("path"));function po(t,e){let r={newtab:void 0};if(!e||!e.chrome_url_overrides)return{"chrome_url_overrides/newtab":void 0};if(e.chrome_url_overrides.history){let s=e.chrome_url_overrides.history;r={"chrome_url_overrides/history":xt.default.join(t,s)}}if(e.chrome_url_overrides.newtab){let s=e.chrome_url_overrides.newtab;r={"chrome_url_overrides/newtab":xt.default.join(t,s)}}if(e.chrome_url_overrides.bookmarks){let s=e.chrome_url_overrides.bookmarks;r={"chrome_url_overrides/bookmarks":xt.default.join(t,s)}}return r}var lo=a(require("path"));function fo(t,e){if(!e||!e.devtools_page)return;let r=e.devtools_page;return lo.default.join(t,r)}var Yr=a(require("path"));function uo(t,e){if(e.options_page){let s=e.options_page;return Yr.default.join(t,s)}if(!e||!e.options_ui||!e.options_ui.page)return;let r=e.options_ui.page;return Yr.default.join(t,r)}var mo=a(require("path"));function go(t,e){if(!e||!e.page_action||!e.page_action.default_popup)return;let r=e.page_action.default_popup;return mo.default.join(t,r)}var ho=a(require("path"));function yo(t,e){if(!e||!e.sandbox||!e.sandbox.pages)return{"sandbox/page-0":void 0};let r=e.sandbox.pages,s={};for(let[i,o]of r.entries())s[`sandbox/page-${i}`]=ho.default.join(t,o);return s}var bo=a(require("path"));function wo(t,e){if(!e||!e.side_panel||!e.side_panel.default_path)return;let r=e.side_panel.default_path;return bo.default.join(t,r)}var xo=a(require("path"));function vo(t,e){if(!e||!e.sidebar_action||!e.sidebar_action.default_panel)return;let r=e.sidebar_action.default_panel;return xo.default.join(t,r)}function Ee(t,e){return{"action/default_popup":no(t,e),"browser_action/default_popup":co(t,e),...po(t,e),devtools_page:fo(t,e),"options_ui/page":uo(t,e),"page_action/default_popup":go(t,e),...yo(t,e),"side_panel/default_path":wo(t,e),"sidebar_action/default_panel":vo(t,e)}}var Qr=a(require("path"));function _o(t,e){if(!e||!e.action||!e.action.default_icon)return;if(typeof e.action.default_icon=="string")return Qr.default.join(t,e.action.default_icon);let r=[];for(let s in e.action.default_icon)r.push(Qr.default.join(t,e.action.default_icon[s]));return r}var es=a(require("path"));function So(t,e){if(!e||!e.browser_action||!e.browser_action.default_icon)return;let r=[];if(typeof e.browser_action.default_icon=="string")return es.default.join(t,e.browser_action.default_icon);for(let s in e.browser_action.default_icon){let i=e.browser_action.default_icon[s]=es.default.join(t,e.browser_action.default_icon[s]);r.push(i)}return r}var ts=a(require("path"));function Po(t,e){if(!(!e||!e.browser_action||!e.browser_action.theme_icons)){for(let r of e.browser_action.theme_icons)r.light&&(r.light=ts.default.join(t,r.light)),r.dark&&(r.dark=ts.default.join(t,r.dark)),r.size&&delete r.size;return e.browser_action.theme_icons}}var ko=a(require("path"));function Eo(t,e){if(!e||!e.icons)return;let r=[];for(let s in e.icons){let i=ko.default.join(t,e.icons[s]);r.push(i)}return r}var rs=a(require("path"));function $o(t,e){if(!e||!e.page_action||!e.page_action.default_icon)return;if(typeof e.page_action.default_icon=="string")return rs.default.join(t,e.page_action.default_icon);let r=[];for(let s in e.page_action.default_icon){let i=rs.default.join(t,e.page_action.default_icon[s]);r.push(i)}return r}var Co=a(require("path"));function jo(t,e){return!e||!e.sidebar_action||!e.sidebar_action.default_icon?void 0:Co.default.join(t,e.sidebar_action.default_icon)}function Do(t,e){return{action:_o(t,e),browser_action:So(t,e),"browser_action/theme_icons":Po(t,e),icons:Eo(t,e),page_action:$o(t,e),sidebar_action:jo(t,e)}}var Fo=a(require("path"));function Lo(t,e){let r={};return!e||!e.declarative_net_request||!e.declarative_net_request.rule_resources?{"declarative_net_request/rule_resources-0":void 0}:(e.declarative_net_request.rule_resources.forEach(i=>{r[`declarative_net_request/${i.id}`]=Fo.default.join(t,i.path)}),r)}var Io=a(require("path"));function Oo(t,e){if(!e||!e.storage||!e.storage.managed_schema)return;let r=e.storage.managed_schema;return Io.default.join(t,r)}function Mo(t,e){return{...Lo(t,e),"storage/managed_schema":Oo(t,e)}}var $e=a(require("path")),Ce=a(require("fs"));function Ao(t,e){let r=$e.default.join($e.default.dirname(e),"_locales"),s=[];if(Ce.default.existsSync(r))for(let i of Ce.default.readdirSync(r)){let o=$e.default.join(r,i);if(o&&Ce.default.statSync(o).isDirectory())for(let n of Ce.default.readdirSync(o))s.push($e.default.join(t,"_locales",i,n))}return s}var Ro=a(require("path"));function To(t,e){if(!e||!e.background)return;let r=e.background.scripts;if(r)return r.map(s=>Ro.default.join(t,s))}var No=a(require("path"));function Uo(t,e){if(!e||!e.background)return;let r=e.background.service_worker;if(r)return No.default.join(t,r)}var ss=a(require("path"));function qo(t,e){if(!e||!e.content_scripts)return{"content_scripts/content-0":void 0};let r=o=>{if(o.js?.length!==0)return o.js?.map(n=>ss.default.join(t,n))},s=o=>{if(o.css?.length!==0)return o.css?.map(n=>ss.default.join(t,n))},i={};for(let[o,n]of e.content_scripts.entries()){let c=r(n),p=s(n);i[`content_scripts/content-${o}`]=[...(c||[]).filter(l=>l!=null),...(p||[]).filter(l=>l!=null)]}return i}var Wo=a(require("path"));function Bo(t,e){if(!e||!e.user_scripts||!e.user_scripts.api_script)return;let r=e.user_scripts.api_script;return Wo.default.join(t,r)}function je(t,e){return{"background/scripts":To(t,e),"background/service_worker":Uo(t,e),...qo(t,e),"user_scripts/api_script":Bo(t,e)}}function zo(t){if(!(!t||!t.web_accessible_resources||!t.web_accessible_resources.length))return t.web_accessible_resources}function fe({manifestPath:t,browser:e}){let r=Jo.default.dirname(t),s=require(t),i=O(s,e||"chrome");return{html:Ee(r,i),icons:Do(r,i),json:Mo(r,i),locales:Ao(r,t),scripts:je(r,i),web_accessible_resources:zo(i)}}var ue=a(require("path"));var vt=a(require("fs")),De=a(require("path"));function _t(t,e){if(!vt.default.existsSync(t)||!vt.default.statSync(t).isDirectory())return[];let r=[];function s(i){let o=vt.default.readdirSync(i,{withFileTypes:!0});for(let n of o){let c=De.default.join(i,n.name);n.isDirectory()?s(c):n.isFile()&&e(n.name)&&r.push(c)}}return s(t),r}function St(t,e,r=""){return!e||!e.length?{}:e.reduce((s,i)=>{let o=De.default.extname(i),n=De.default.basename(i,o),c=r?`${r}/${n}`:De.default.relative(t,i);return{...s,[c]:i}},{})}function Ho({manifestPath:t}){let e=ue.default.dirname(t),r={public:ue.default.join(e,"public"),pages:ue.default.join(e,"pages"),scripts:ue.default.join(e,"scripts")},s={public:_t(r.public,()=>!0),pages:_t(r.pages,o=>o.endsWith(".html")),scripts:_t(r.scripts,o=>[".js",".mjs",".jsx",".mjsx",".ts",".mts",".tsx",".mtsx"].includes(ue.default.extname(o)))};return{public:St(e,s.public),pages:St(e,s.pages,"pages"),scripts:St(e,s.scripts,"scripts")}}var Pt=a(require("path")),Vo=a(require("webpack")),kt=class{manifestPath;browser;includeList;excludeList;loaderOptions;constructor(e){this.manifestPath=e.manifestPath,this.browser=e.browser||"chrome",this.includeList=e.includeList,this.excludeList=e.excludeList,this.loaderOptions=e.loaderOptions}apply(e){new Vo.default.ProvidePlugin({r:[Pt.default.resolve(__dirname,"./resolver-module.mjs"),"default"]}).apply(e),e.options.module?.rules.push({test:/\.(js|mjs|jsx|mjsx|ts|mts|tsx|mtsx)$/,loader:require.resolve(Pt.default.resolve(__dirname,"./resolver-loader.js")),include:[Pt.default.dirname(this.manifestPath)],exclude:/node_modules/,options:{manifestPath:this.manifestPath,browser:this.browser,includeList:this.includeList,jsx:this.loaderOptions?this.loaderOptions.jsx:!1,typescript:this.loaderOptions?this.loaderOptions.typescript:!1,minify:this.loaderOptions?this.loaderOptions.minify:!1}})}};var Go=a(require("fs")),$t=a(require("webpack")),Xo=require("webpack");var Et=class{manifestPath;constructor(e){this.manifestPath=e.manifestPath}apply(e){e.hooks.compilation.tap("manifest:emit-manifest",r=>{r.hooks.processAssets.tap({name:"manifest:emit-manifest",stage:$t.Compilation.PROCESS_ASSETS_STAGE_ADDITIONS},()=>{let s=this.manifestPath,i;try{let c=Go.default.readFileSync(s,"utf-8");i=JSON.parse(c),"$schema"in i&&delete i.$schema}catch(c){r.errors.push(new $t.default.WebpackError(fi(c)));return}let o=JSON.stringify(i,null,2);r.emitAsset("manifest.json",new Xo.sources.RawSource(o))})})}};var $n=a(require("path")),Fe=require("webpack");function Zo(t,e){return t.background&&t.background.scripts&&{background:{...t.background,...t.background.scripts&&{scripts:[...t.background.scripts.map(r=>h("background/scripts.js",r,e))]}}}}var Ko=a(require("path"));var Ct=t=>Ko.default.basename(t);function Yo(t,e){return t.browser_action&&{browser_action:{...t.browser_action,...t.browser_action.default_popup&&{default_popup:h("browser_action/default_popup.html",t.browser_action.default_popup,e)},...t.browser_action.default_icon&&{default_icon:typeof t.browser_action.default_icon=="string"?h(`icons/${Ct(t.browser_action.default_icon)}`,t.browser_action.default_icon,e):Object.fromEntries(Object.entries(t.browser_action.default_icon).map(([r,s])=>[r,h(`icons/${Ct(s)}`,s,e)]))},...t.browser_action.theme_icons&&{theme_icons:t.browser_action.theme_icons.map(r=>({...r,...r.light&&{light:h(`browser_action/${Ct(r.light)}`,r.light,e)},...r.dark&&{dark:h(`browser_action/${Ct(r.dark)}`,r.dark,e)}}))}}}}function Qo(t,e){return t.declarative_net_request&&{declarative_net_request:{...t.declarative_net_request,rule_resources:t.declarative_net_request.rule_resources.map(r=>({...r,path:r.path&&h(`declarative_net_request/${r.id}.json`,r.path,e)}))}}}function en(t,e){return{...Zo(t,e),...Yo(t,e),...Qo(t,e)}}var rn=a(require("path"));var tn=t=>rn.default.basename(t);function sn(t,e){return t.action&&{action:{...t.action,...t.action.default_popup&&{default_popup:h("action/default_popup.html",t.action.default_popup,e)},...t.action.default_icon&&{default_icon:typeof t.action.default_icon=="string"?h(`action/${tn(t.action.default_icon)}`,t.action.default_icon,e):Object.fromEntries(Object.entries(t.action.default_icon).map(([r,s])=>[r,h(`action/${tn(s)}`,s,e)]))}}}}function on(t,e){return t.background&&t.background.service_worker&&{background:{...t.background,...t.background.service_worker&&{service_worker:h("background/service_worker.js",t.background.service_worker,e)}}}}function jt(t,e){return t.side_panel&&{side_panel:{...t.side_panel.default_path&&{default_path:h("side_panel/default_path.html",t.side_panel.default_path,e)}}}}function nn(t,e){return{...sn(t,e),...on(t,e),...jt(t,e)}}function an(t,e){return t.background&&t.background.page&&{background:{...t.background,...t.background.page&&{page:h("background/page.html",t.background.page,e)}}}}function cn(t,e){return t.chrome_url_overrides&&{chrome_url_overrides:{...t.chrome_url_overrides.bookmarks&&{bookmarks:h("chrome_url_overrides/bookmarks.html",t.chrome_url_overrides.bookmarks,e)},...t.chrome_url_overrides.history&&{history:h("chrome_url_overrides/history.html",t.chrome_url_overrides.history,e)},...t.chrome_url_overrides.newtab&&{newtab:h("chrome_url_overrides/newtab.html",t.chrome_url_overrides.newtab,e)}}}}function pn(t,e){return t.content_scripts&&{content_scripts:t.content_scripts.map((r,s)=>{let i=[...new Set(r.js)],o=[...new Set(r.css)];return{...r,js:[...i.map(n=>h(`content_scripts/content-${s}.js`,n,e))],css:[...o.map(n=>h(`content_scripts/content-${s}.css`,n,e))]}})}}function ln(t,e){return t.devtools_page&&{devtools_page:h("devtools_page.html",t.devtools_page,e)}}var fn=a(require("path"));var il=t=>fn.default.basename(t);function un(t,e){return t.icons&&{icons:Object.fromEntries(Object.entries(t.icons).map(([r,s])=>[r,h(`icons/${il(s)}`,s,e)]))}}function mn(t,e){return t.options_page&&{options_page:h("options_ui/page.html",t.options_page,e)}}function dn(t,e){return t.options_ui&&{options_ui:{...t.options_ui,...t.options_ui.page&&{page:h("options_ui/page.html",t.options_ui.page,e)}}}}var hn=a(require("path"));var gn=t=>hn.default.basename(t);function yn(t,e){return t.page_action&&{page_action:{...t.page_action,...t.page_action.default_popup&&{default_popup:h("page_action/default_popup.html",t.page_action.default_popup,e)},...t.page_action.default_icon&&{default_icon:typeof t.page_action.default_icon=="string"?h(`icons/${gn(t.page_action.default_icon)}`,t.page_action.default_icon,e):Object.fromEntries(Object.entries(t.page_action.default_icon).map(([r,s])=>[r,h(`icons/${gn(s)}`,s,e)]))}}}}function bn(t,e){return t.sandbox&&{sandbox:{...t.sandbox,...t.sandbox.pages&&{pages:t.sandbox.pages.map((r,s)=>h(`sandbox/page-${s}.html`,r,e))}}}}var wn=a(require("path"));var ol=t=>wn.default.basename(t);function xn(t,e){return t.sidebar_action&&{sidebar_action:{...t.sidebar_action,...t.sidebar_action.default_panel&&{default_panel:h("sidebar_action/default_panel.html",t.sidebar_action.default_panel,e)},...t.sidebar_action.default_icon&&{default_icon:h(`icons/${ol(t.sidebar_action.default_icon)}`,t.sidebar_action.default_icon,e)}}}}function vn(t,e){return t.storage&&{storage:{...t.storage.managed_schema&&{managed_schema:h("storage/managed_schema.json",t.storage.managed_schema,e)}}}}var _n=a(require("path"));var nl=t=>_n.default.basename(t);function Sn(t,e){return t.theme&&{theme:{...t.theme,...t.theme.images&&{images:{...t.theme.images,theme_frame:h(`theme/images/${nl(t.theme.images.theme_frame)}`,t.theme.images.theme_frame,e)}}}}}function Pn(t,e){return t.user_scripts&&{user_scripts:{...t.user_scripts,...t.user_scripts.api_script&&{api_script:h("user_scripts/api_script.js",t.user_scripts.api_script,e)}}}}function kn(t){return t.web_accessible_resources&&t.web_accessible_resources.length&&{web_accessible_resources:t.web_accessible_resources}}function En(t,e){return{...an(t,e),...cn(t,e),...pn(t,e),...ln(t,e),...un(t,e),...mn(t,e),...dn(t,e),...yn(t,e),...bn(t,e),...jt(t,e),...xn(t,e),...vn(t,e),...Sn(t,e),...Pn(t,e),...kn(t)}}function is(t,e,r){let s=e||require(t);return JSON.stringify({...s,...En(s,r),...en(s,r),...nn(s,r)},null,2)}var Dt=class{manifestPath;excludeList;constructor(e){this.manifestPath=e.manifestPath,this.excludeList=e.excludeList}applyDevOverrides(e){return e.content_scripts?e.content_scripts.map((r,s)=>(r.css.length&&!r.js.length&&(r.js=[h(`content_scripts-${s}`,"dev.js",{})]),r)):{}}applyProdOverrides(e,r){return r.content_scripts?r.content_scripts.map((s,i)=>{if(s.js.length&&!s.css.length){let o=e.options.output?.path||"";s.css=s.js.map(n=>{let c=$n.default.join(o,n.replace(".js",".css"));return h(`content_scripts/content-${i}.css`,c,{})})}return s}):{}}apply(e){e.hooks.thisCompilation.tap("manifest:update-manifest",r=>{r.hooks.processAssets.tap({name:"manifest:update-manifest",stage:Fe.Compilation.PROCESS_ASSETS_STAGE_SUMMARIZE},()=>{if(r.errors.length>0)return;let s=z(r,this.manifestPath),i=is(this.manifestPath,s,this.excludeList||{}),o={...s,...JSON.parse(i)};e.options.mode==="development"&&o.content_scripts&&(o.content_scripts=this.applyDevOverrides(o)),e.options.mode==="development"&&o.content_scripts&&(o.content_scripts=this.applyDevOverrides(o));let n=JSON.stringify(o,null,2),c=new Fe.sources.RawSource(n);r.updateAsset("manifest.json",c)}),e.options.mode==="production"&&r.hooks.afterProcessAssets.tap("manifest:update-manifest",()=>{if(r.errors.length>0)return;let s=z(r,this.manifestPath),i=is(this.manifestPath,s,this.excludeList||{}),o={...s,...JSON.parse(i)};o.content_scripts&&(o.content_scripts=this.applyProdOverrides(e,o));let n=JSON.stringify(o,null,2),c=new Fe.sources.RawSource(n);r.updateAsset("manifest.json",c)})})}};var Cn=a(require("fs")),Ft=class{dependencyList;constructor(e){this.dependencyList=e}apply(e){e.hooks.afterCompile.tap("ManifestPlugin (AddDependenciesPlugin)",r=>{if(r.errors?.length)return;let s=new Set(r.fileDependencies);this.dependencyList&&this.dependencyList.forEach(i=>{Cn.default.existsSync(i)&&(s.has(i)||(s.add(i),r.fileDependencies.add(i)))})})}};var jn=a(require("fs")),Dn=a(require("path")),It=a(require("webpack"));var Lt=class{manifestPath;includeList;excludeList;constructor(e){this.manifestPath=e.manifestPath,this.includeList=e.includeList,this.excludeList=e.excludeList}extractPaths(e){let r=Array.isArray(e)?e:[e];if(typeof r[0]=="string")return r;let s=[];if(typeof e=="object"&&!Array.isArray(e)){let i=e;i.light&&s.push(i.light),i.dark&&s.push(i.dark)}return s}handleErrors(e,r){let s=[".png",".jpg",".jpeg",".svg",".gif",".webp"],i=[".json"],o=[".js",".ts",".jsx",".tsx",".mjs",".cjs"],n=".html",c=Object.entries(this.includeList||{});for(let[p,l]of c)if(l){let u=this.extractPaths(l);for(let d of u){let g=Dn.default.extname(d),_=require(this.manifestPath).name||"Extension.js";if(!jn.default.existsSync(d)){if(d.startsWith("/"))return;let v=ie(_,p,d);s.includes(g)?e.errors.push(new r(v)):i.includes(g)?e.errors.push(new r(v)):o.includes(g)?e.errors.push(new r(v)):g===n?e.errors.push(new r(v)):e.errors.push(new r(v))}}}}apply(e){e.hooks.compilation.tap("manifest:check-manifest-files",r=>{r.hooks.processAssets.tap({name:"compatibility:check-manifest-files",stage:It.Compilation.PROCESS_ASSETS_STAGE_OPTIMIZE_COUNT},()=>{let s=It.default.WebpackError;this.handleErrors(r,s)})})}};var Fn=a(require("fs")),Mt=a(require("webpack"));var Ot=class{manifestPath;browser;includeList;constructor(e){this.manifestPath=e.manifestPath,this.browser=e.browser||"chrome",this.includeList=e.includeList}flattenAndSort(e){return e.flat(1/0).sort()}apply(e){e.hooks.watchRun.tapAsync("manifest:throw-if-recompile-is-needed",(r,s)=>{if((r.modifiedFiles||new Set).has(this.manifestPath)){let o=r.options.context||"",n=`${o}/package.json`;if(!Fn.default.existsSync(n)){s();return}let c=require(this.manifestPath),p=O(c,this.browser),l=this.flattenAndSort(Object.values(Ee(o,p))),u=this.flattenAndSort(Object.values(je(o,p)));r.hooks.thisCompilation.tap("manifest:throw-if-recompile-is-needed",d=>{d.hooks.processAssets.tap({name:"manifest:check-manifest-files",stage:Mt.Compilation.PROCESS_ASSETS_STAGE_OPTIMIZE_COMPATIBILITY},()=>{let y=d.getAsset("manifest.json")?.source.source().toString(),_=JSON.parse(y||"{}"),v=this.flattenAndSort(Object.values(Ee(o,_))),M=this.flattenAndSort(Object.values(je(o,_)));if(u.toString()!==M.toString()||l.toString()!==v.toString()){let T=l.filter(B=>!v.includes(B))[0],W=v.filter(B=>!l.includes(B))[0],we=ui(W,T);d.errors.push(new Mt.default.WebpackError(we))}})})}s()})}};var At=class{manifestPath;browser;includeList;excludeList;constructor(e){this.manifestPath=e.manifestPath,this.browser=e.browser||"chrome",this.includeList=e.includeList,this.excludeList=e.excludeList}apply(e){new Et({manifestPath:this.manifestPath}).apply(e),new Lt({manifestPath:this.manifestPath,includeList:this.includeList,excludeList:this.excludeList}).apply(e),new Dt({manifestPath:this.manifestPath,excludeList:this.excludeList}).apply(e),new Ft([this.manifestPath]).apply(e),new Ot({manifestPath:this.manifestPath,browser:this.browser,includeList:this.includeList}).apply(e)}};var ps=a(require("path"));var ns=a(require("fs")),Nt=a(require("webpack")),An=require("webpack");var Ln=a(require("fs")),de=a(require("path")),In=a(require("parse5-utils"));var me=a(require("parse5-utils"));function Rt(t){try{return new URL(t),!0}catch{return!1}}function Le(t,e){let{childNodes:r=[]}=t;for(let s of r)if(s.nodeName==="script"){let i=me.default.getAttribute(s,"src");if(!i||Rt(i))continue;e({filePath:i,childNode:s,assetType:"script"})}else if(s.nodeName==="link"){let i=me.default.getAttribute(s,"href"),o=me.default.getAttribute(s,"rel");if(!i||Rt(i))continue;e(o==="dns-prefetch"||o==="icon"||o==="manifest"||o==="modulepreload"||o==="preconnect"||o==="prefetch"||o==="preload"||o==="prerender"?{filePath:i,childNode:s,assetType:"staticHref"}:{filePath:i,childNode:s,assetType:"css"})}else if(s.nodeName==="a"||s.nodeName==="area"){let i=me.default.getAttribute(s,"href");if(!i||Rt(i))continue;e({filePath:i,childNode:s,assetType:"staticHref"})}else if(s.nodeName==="audio"||s.nodeName==="embed"||s.nodeName==="iframe"||s.nodeName==="img"||s.nodeName==="input"||s.nodeName==="source"||s.nodeName==="track"||s.nodeName==="video"){let i=me.default.getAttribute(s,"src");if(!i||Rt(i))continue;e({filePath:i,childNode:s,assetType:"staticSrc"})}else Le(s,e)}function j(t,e){let r={css:[],js:[],static:[]};if(!t)return r;let s=e||Ln.default.readFileSync(t,{encoding:"utf8"}),i=In.default.parse(s),o=(n,c)=>de.default.join(de.default.dirname(n),c.startsWith("/")?de.default.relative(de.default.dirname(n),c):c);for(let n of i.childNodes)if(n.nodeName==="html"){for(let c of n.childNodes)(c.nodeName==="head"||c.nodeName==="body")&&Le(c,({filePath:p,assetType:l})=>{let u=o(t,p);switch(l){case"script":r.js?.push(u);break;case"css":r.css?.push(u);break;case"staticSrc":case"staticHref":if(p.startsWith("#"))break;r.static?.push(u);break;default:break}});return{css:r.css,js:r.js,static:r.static}}}function On(t,e,r){let s=Object.keys(t).find(o=>{let n=t[o];return t[o]===e||j(n)?.js?.includes(e)||j(n)?.css?.includes(e)})||"",i=os(e);return s?`/${s.replace(i,"")}${r}`:`${e.replace(i,"")}${r}`}function os(t){switch(de.default.extname(t)){case".js":case".mjs":case".ts":case".tsx":return".js";case".css":case".scss":case".sass":case".less":return".css";case".html":return".html";default:return".js"}}function G(t,e,r){return r?`/${t}${e}`:`${t}${e}`}function Mn(t,e){return Object.values(e||{}).some(r=>r===t)}var Tt=class{manifestPath;includeList;excludeList;constructor(e){this.manifestPath=e.manifestPath,this.includeList=e.includeList,this.excludeList=e.excludeList}apply(e){let s=require(this.manifestPath).name||"Extension.js";e.hooks.thisCompilation.tap("html:emit-html-file",i=>{i.hooks.processAssets.tap({name:"AddAssetsToCompilationPlugin",stage:Nt.Compilation.PROCESS_ASSETS_STAGE_ADDITIONAL},()=>{let o=Object.entries(this.includeList||{});for(let n of o){let[c,p]=n;if(p){if(!ns.default.existsSync(p)){let u=ie(s,c,p);i.warnings.push(new Nt.default.WebpackError(u));return}let l=ns.default.readFileSync(p,"utf8");if(!k(p,this.excludeList)){let u=new An.sources.RawSource(l),d=G(c,".html");i.emitAsset(d,u)}}}})})}};var Ut=a(require("fs")),ge=a(require("path")),Rn=a(require("webpack")),Ie=require("webpack");var qt=class{manifestPath;includeList;constructor(e){this.manifestPath=e.manifestPath,this.includeList=e.includeList}apply(e){e.hooks.thisCompilation.tap("html:add-assets-to-compilation",r=>{r.hooks.processAssets.tap({name:"html:add-assets-to-compilation",stage:Ie.Compilation.PROCESS_ASSETS_STAGE_ADDITIONAL},()=>{if(r.errors.length>0)return;let s=Object.entries(this.includeList||{});for(let i of s){let[o,n]=i,c=o+".html";if(n){let p=r.getAsset(c);if(p){let l=p.source.source().toString(),u=j(n,l)?.static,d=[...new Set(u)];for(let g of d)if(!g.startsWith("/")){if(!Ut.default.existsSync(g)&&!Mn(g,this.includeList)&&!ge.default.basename(g).startsWith("#")){let T=it(n,g);g.startsWith("/")||r.warnings.push(new Rn.default.WebpackError(T));return}let y=Ut.default.readFileSync(g),_=new Ie.sources.RawSource(y),v=ge.default.join("assets",ge.default.basename(g));if(!r.getAsset(v))if(g.endsWith(".html")){let M=j(g),T=[...M?.js||[],...M?.css||[],...M?.static||[]];r.emitAsset(v,_),T.forEach(W=>{let we=Ut.default.readFileSync(W),B=new Ie.sources.RawSource(we),Bs=ge.default.join("assets",ge.default.basename(W));r.getAsset(Bs)||r.emitAsset(Bs,B)})}else r.emitAsset(v,_)}}}}})})}};var Tn=a(require("path")),as=a(require("fs"));var Wt=class{manifestPath;includeList;excludeList;constructor(e){this.manifestPath=e.manifestPath,this.includeList=e.includeList,this.excludeList=e.excludeList}apply(e){let r=this.includeList||{};for(let s of Object.entries(r)){let[i,o]=s;if(o){if(!as.default.existsSync(o))return;let n=j(o),c=n?.js||[],p=n?.css||[],l=[...c,...p].filter(u=>!k(u,this.excludeList));if(e.options.mode==="development"){let u=Tn.default.resolve(__dirname,"minimum-script-file.mjs");l.push(u)}as.default.existsSync(o)&&(k(o,this.excludeList)||(e.options.entry={...e.options.entry,[i]:{import:l}}))}}}};var zt=require("webpack");var cs=a(require("fs")),X=a(require("path")),F=a(require("parse5-utils"));function Nn(t,e,r,s,i){let o=cs.default.readFileSync(r,{encoding:"utf8"}),n=F.default.parse(o),c=!!t.getAsset(e+".css"),p=!1;for(let l of n.childNodes)if(l.nodeName==="html"){for(let u of l.childNodes){if((u.nodeName==="head"||u.nodeName==="body")&&Le(u,({filePath:d,childNode:g,assetType:y})=>{let _=X.default.dirname(r),v=X.default.resolve(_,d),M=os(v),T=k(X.default.resolve(_,d),i),W=X.default.join("/",X.default.normalize(d)),we=Ei(v,s);switch(y){case"script":{T?l=F.default.setAttribute(g,"src",W):(l=F.default.remove(g),p=!0);break}case"css":{T?l=F.default.setAttribute(g,"href",W):(l=F.default.remove(g),c=!0);break}case"staticHref":case"staticSrc":{if(T)l=F.default.setAttribute(g,y==="staticSrc"?"src":"href",W);else if(we){let B=On(s,v,M);l=F.default.setAttribute(g,y==="staticSrc"?"src":"href",B)}else{let B=X.default.join("assets",X.default.basename(v,M));cs.default.existsSync(v)&&(l=F.default.setAttribute(g,y==="staticSrc"?"src":"href",G(B,"",!0)))}break}default:break}}),u.nodeName==="head"&&c&&t.options.mode==="production"){let d=F.default.createNode("link");d.attrs=[{name:"rel",value:"stylesheet"},{name:"href",value:G(e,".css",!0)}],F.default.append(u,d)}if(u.nodeName==="body"&&(p||t.options.mode!=="production")){let d=F.default.createNode("script");d.attrs=[{name:"src",value:G(e,".js",!0)}],F.default.append(u,d)}}return F.default.serialize(n)}}var Bt=class{manifestPath;includeList;excludeList;constructor(e){this.manifestPath=e.manifestPath,this.includeList=e.includeList,this.excludeList=e.excludeList}apply(e){e.hooks.thisCompilation.tap("html:update-html-file",r=>{r.hooks.processAssets.tap({name:"html:update-html-file",stage:zt.Compilation.PROCESS_ASSETS_STAGE_DERIVED},()=>{if(r.errors.length>0)return;let s=this.includeList||{};for(let i of Object.entries(s)){let[o,n]=i;if(n){let c=Nn(r,o,n,s,this.excludeList||{});if(!k(n,this.excludeList)&&c){let p=new zt.sources.RawSource(c),l=G(o,".html");r.updateAsset(l,p)}}}})})}};var Un=a(require("fs")),qn=require("webpack");var Jt=class{manifestPath;includeList;constructor(e){this.manifestPath=e.manifestPath,this.includeList=e.includeList}apply(e){e.hooks.thisCompilation.tap("html:add-to-file-dependencies",r=>{r.hooks.processAssets.tap({name:"html:add-to-file-dependencies",stage:qn.Compilation.PROCESS_ASSETS_STAGE_ADDITIONS},()=>{if(r.errors?.length)return;let s=this.includeList||{};for(let i of Object.entries(s)){let[,o]=i;if(o){let n=j(o),c=new Set(r.fileDependencies);if(Un.default.existsSync(o)){let p=[o,...n?.static||[]];for(let l of p)c.has(l)||(c.add(l),l===o&&r.fileDependencies.add(l))}}}})})}};var Wn=a(require("fs"));var Ht=class{manifestPath;includeList;initialHtmlAssets={};constructor(e){this.manifestPath=e.manifestPath,this.includeList=e.includeList}hasEntriesChanged(e,r){if(!r||!e||e.length!==r.length)return!0;for(let s=0;s<e.length;s++)if(e[s]!==r[s])return!0;return!1}storeInitialHtmlAssets(e){Object.entries(e).forEach(([r,s])=>{let i=s;if(i){if(!Wn.default.existsSync(i)){let n=require(this.manifestPath).name||"Extension.js";console.error(ie(n,r,i)),process.exit(1)}this.initialHtmlAssets[i]={js:j(i)?.js||[],css:j(i)?.css||[]}}})}apply(e){let r=this.includeList||{};this.storeInitialHtmlAssets(r),e.hooks.make.tapAsync("html:throw-if-recompile-is-needed",(s,i)=>{let o=e.modifiedFiles||new Set,n=Array.from(o)[0];if(n&&this.initialHtmlAssets[n]){let c=j(n)?.js||[],p=j(n)?.css||[],{js:l,css:u}=this.initialHtmlAssets[n];(this.hasEntriesChanged(p,u)||this.hasEntriesChanged(c,l))&&console.log(bi(n))}i()})}};var Bn=a(require("fs")),zn=require("webpack");function cl(t,e){let r="Module not found: Error: Can't resolve ",i=e.message.replace(r,"").split("'")[1];if(e.message.includes(r))for(let o of Object.entries(t)){let[,n]=o;if(n){if(!Bn.default.existsSync(n))return null;let c=j(n),p=c?.js?.filter(u=>!u.startsWith("/"))||[],l=c?.css?.filter(u=>!u.startsWith("/"))||[];if(p.includes(i)||l.includes(i)){let u=it(n,i);return new zn.WebpackError(u)}}}return null}var Vt=class{manifestPath;includeList;constructor(e){this.manifestPath=e.manifestPath,this.includeList=e.includeList}apply(e){e.hooks.compilation.tap("html:handle-common-errors",r=>{r.hooks.afterSeal.tapPromise("html:handle-common-errors",async()=>{r.errors.forEach((s,i)=>{let o=cl(this.includeList||{},s);o&&(r.errors[i]=o)})})})}};var Gt=class{manifestPath;includeList;excludeList;constructor(e){this.manifestPath=e.manifestPath,this.includeList=e.includeList,this.excludeList=e.excludeList}apply(e){new Tt({manifestPath:this.manifestPath,includeList:this.includeList,excludeList:this.excludeList}).apply(e),new qt({manifestPath:this.manifestPath,includeList:this.includeList,excludeList:this.excludeList}).apply(e),new Wt({manifestPath:this.manifestPath,includeList:this.includeList,excludeList:this.excludeList}).apply(e),new Bt({manifestPath:this.manifestPath,includeList:this.includeList,excludeList:this.excludeList}).apply(e),e.options.module.rules.push({test:/\.(js|mjs|jsx|mjsx|ts|mts|tsx|mtsx)$/,include:[ps.default.dirname(this.manifestPath)],exclude:/node_modules/,use:[{loader:require.resolve(ps.default.join(__dirname,"ensure-hmr-for-scripts.js")),options:{manifestPath:this.manifestPath,includeList:this.includeList,excludeList:this.excludeList}}]}),new Jt({manifestPath:this.manifestPath,includeList:this.includeList,excludeList:this.excludeList}).apply(e),new Ht({manifestPath:this.manifestPath,includeList:this.includeList,excludeList:this.excludeList}).apply(e),new Vt({manifestPath:this.manifestPath,includeList:this.includeList,excludeList:this.excludeList}).apply(e)}};var Oe=a(require("path"));var ls=a(require("fs")),Jn=a(require("path"));function Hn(t,e){return(Array.isArray(t)?t||[]:t?[t]:[]).filter(i=>{let o=ls.default.existsSync(i)&&!k(i,e),n=Jn.default.extname(i);return o&&(n===".js"||n===".mjs"||n===".jsx"||n===".ts"||n===".tsx")})}function Vn(t,e){return(Array.isArray(t)?t||[]:t?[t]:[]).filter(i=>ls.default.existsSync(i)&&!k(i,e)&&(i.endsWith(".css")||i.endsWith(".scss")||i.endsWith(".sass")||i.endsWith(".less")))}var Xt=class{manifestPath;includeList;excludeList;constructor(e){this.manifestPath=e.manifestPath,this.includeList=e.includeList||{},this.excludeList=e.excludeList||{}}apply(e){let r=this.includeList||{},s={};for(let[i,o]of Object.entries(r)){let n=Hn(o,this.excludeList),c=Vn(o,this.excludeList),p=[...n];e.options.mode==="production"&&p.push(...c),(c.length||n.length)&&(s[i]={import:p})}e.options.entry={...e.options.entry,...s}}};var ee=require("webpack"),pl=['var isBrowser = !!(() => { try { return browser.runtime.getURL("/") } catch(e) {} })()','var isChrome = !!(() => { try { return chrome.runtime.getURL("/") } catch(e) {} })()'],ll=[...pl,`var runtime = isBrowser ? browser : isChrome ? chrome : (typeof self === 'object' && self.addEventListener) ? { get runtime() { throw new Error("No chrome or browser runtime found") } } : { runtime: { getURL: x => x } }`],Zt=class t{apply(e){let{RuntimeGlobals:r}=e.webpack;e.hooks.compilation.tap("PublicPathRuntimeModule",s=>{s.hooks.runtimeRequirementInTree.for(r.publicPath).tap(t.name,i=>{let o=fl();return s.addRuntimeModule(i,o),!0})})}};function fl(){class t extends ee.RuntimeModule{constructor(){super("publicPath",ee.RuntimeModule.STAGE_BASIC)}generate(){let r=this.compilation?.outputOptions.publicPath;return ee.Template.asString([...ll,`var path = ${JSON.stringify(this.compilation?.getPath(r||"",{hash:this.compilation.hash||"XXXX"}))}`,`${ee.RuntimeGlobals.publicPath} = typeof importScripts === 'function' || !(isBrowser || isChrome) ? path : runtime.runtime.getURL(path);`])}}return new t}var Kt=class{manifestPath;browser;includeList;excludeList;constructor(e){this.manifestPath=e.manifestPath,this.browser=e.browser||"chrome",this.includeList=e.includeList||{},this.excludeList=e.excludeList||{}}apply(e){let r=require(this.manifestPath);r.content_scripts?.some(s=>s.world&&s.world.toLowerCase()==="main")&&Q.includes(this.browser)&&!r.key&&(console.error(vi()),process.exit(1))}};var Yt=class{manifestPath;browser;includeList;excludeList;constructor(e){this.manifestPath=e.manifestPath,this.browser=e.browser||"chrome",this.includeList=e.includeList,this.excludeList=e.excludeList}apply(e){new Xt({manifestPath:this.manifestPath,includeList:this.includeList||{},excludeList:this.excludeList||{}}).apply(e),e.options.mode==="development"&&e.options.module.rules.push({test:/\.(js|mjs|jsx|mjsx|ts|mts|tsx|mtsx)$/,include:[Oe.default.dirname(this.manifestPath)],exclude:/node_modules/,use:[{loader:require.resolve(Oe.default.join(__dirname,"inject-content-css-during-dev.js")),options:{manifestPath:this.manifestPath,includeList:this.includeList||{},excludeList:this.excludeList||{}}}]}),e.options.mode==="development"&&e.options.module.rules.push({test:/\.(js|mjs|jsx|mjsx|ts|mts|tsx|mtsx)$/,include:[Oe.default.dirname(this.manifestPath)],exclude:/node_modules/,use:[{loader:require.resolve(Oe.default.join(__dirname,"add-hmr-accept-code.js")),options:{manifestPath:this.manifestPath,includeList:this.includeList||{},excludeList:this.excludeList||{}}}]}),e.options.mode==="production"&&new Zt().apply(e),new Kt({manifestPath:this.manifestPath,browser:this.browser||"chrome",includeList:this.includeList||{},excludeList:this.excludeList||{}}).apply(e)}};var Ae=a(require("path")),Re=a(require("fs")),us=a(require("webpack")),Te=require("webpack");var he=a(require("path")),Me=a(require("fs"));function fs(t){let e=he.default.join(he.default.dirname(t),"_locales"),r=[];if(Me.default.existsSync(e))for(let s of Me.default.readdirSync(e)){let i=he.default.join(e,s);if(i&&Me.default.statSync(i).isDirectory())for(let o of Me.default.readdirSync(i))r.push(he.default.join(he.default.dirname(t),"_locales",s,o))}return r}var Qt=class{manifestPath;includeList;excludeList;constructor(e){this.manifestPath=e.manifestPath,this.includeList=e.includeList,this.excludeList=e.excludeList}apply(e){e.hooks.thisCompilation.tap("locales:module",r=>{r.hooks.processAssets.tap({name:"locales:module",stage:Te.Compilation.PROCESS_ASSETS_STAGE_ADDITIONS},()=>{let i=require(this.manifestPath).name||"Extension.js";if(!Re.default.existsSync(this.manifestPath)){r.errors.push(new us.default.WebpackError(li(i,this.manifestPath)));return}if(r.errors.length>0)return;let o=fs(this.manifestPath);for(let n of Object.entries(o||[])){let[c,p]=n,l=p;if(l){if(Ae.default.extname(l)!==".json")continue;if(!Re.default.existsSync(l)){r.warnings.push(new us.default.WebpackError(ot(c,l)));return}let u=Re.default.readFileSync(l),d=new Te.sources.RawSource(u),g=e.options.context||Ae.default.dirname(this.manifestPath);if(!k(l,this.excludeList)){let y=Ae.default.relative(g,l);r.emitAsset(y,d)}}}})}),e.hooks.thisCompilation.tap("locales:module",r=>{r.hooks.processAssets.tap({name:"locales:module",stage:Te.Compilation.PROCESS_ASSETS_STAGE_ADDITIONS},()=>{if(r.errors?.length)return;let s=fs(this.manifestPath);for(let i of Object.entries(s||[])){let[,o]=i;if(o){let n=new Set(r.fileDependencies),c=s||[];for(let p of c)Re.default.existsSync(p)&&Ae.default.extname(p)===".json"&&(n.has(p)||(n.add(p),r.fileDependencies.add(p)))}}})})}};var er=a(require("fs")),Gn=a(require("webpack")),Ne=require("webpack");var tr=class{manifestPath;includeList;excludeList;constructor(e){this.manifestPath=e.manifestPath,this.includeList=e.includeList,this.excludeList=e.excludeList}apply(e){e.hooks.thisCompilation.tap("json:module",r=>{r.hooks.processAssets.tap({name:"json:module",stage:Ne.Compilation.PROCESS_ASSETS_STAGE_ADDITIONS},()=>{if(r.errors.length>0)return;let s=this.includeList||{};for(let i of Object.entries(s)){let[o,n]=i,c=Array.isArray(n)?n:[n];for(let p of c)if(p&&!k(p,this.excludeList)){if(!er.default.existsSync(p)){r.warnings.push(new Gn.default.WebpackError(ot(o,p)));return}let l=er.default.readFileSync(p),u=new Ne.sources.RawSource(l);r.emitAsset(o+".json",u)}}})}),e.hooks.thisCompilation.tap("json:module",r=>{r.hooks.processAssets.tap({name:"json:module",stage:Ne.Compilation.PROCESS_ASSETS_STAGE_ADDITIONS},()=>{if(r.errors?.length)return;let s=this.includeList||{};for(let i of Object.entries(s)){let[,o]=i,n=Array.isArray(o)?o:[o];for(let c of n)if(c){let p=new Set(r.fileDependencies);k(c,this.excludeList)||er.default.existsSync(c)&&(p.has(c)||(p.add(c),r.fileDependencies.add(c)))}}})})}};var ms=a(require("fs")),Xn=a(require("path")),sr=require("webpack");var rr=class{manifestPath;includeList;excludeList;constructor(e){this.manifestPath=e.manifestPath,this.includeList=e.includeList,this.excludeList=e.excludeList}apply(e){e.hooks.thisCompilation.tap("icons:emit-file",r=>{r.hooks.processAssets.tap({name:"icons:emit-file",stage:sr.Compilation.PROCESS_ASSETS_STAGE_OPTIMIZE_TRANSFER},()=>{if(r.errors.length>0)return;let s=this.includeList||{};for(let i of Object.entries(s)){let[o,n]=i;if(n===void 0)continue;let c=Array.isArray(n)?typeof n[0]=="string"?n:n.map(Object.values).flat():[n];for(let p of c)if(p){if(!ms.default.existsSync(p))continue;if(!k(p,this.excludeList)){let l=ms.default.readFileSync(p),u=new sr.sources.RawSource(l),d=Xn.default.basename(p),y=`${o.endsWith("theme_icons")?o.replace("theme_icons",""):o}/${d}`;r.emitAsset(y,u)}}}})})}};var Zn=a(require("fs")),Kn=require("webpack"),ir=class{manifestPath;includeList;excludeList;constructor(e){this.manifestPath=e.manifestPath,this.includeList=e.includeList,this.excludeList=e.excludeList}apply(e){e.hooks.thisCompilation.tap("icons:add-to-file-dependencies",r=>{r.hooks.processAssets.tap({name:"icons:add-to-file-dependencies",stage:Kn.Compilation.PROCESS_ASSETS_STAGE_ADDITIONS},()=>{if(r.errors?.length)return;let s=this.includeList||{};for(let i of Object.entries(s)){let[,o]=i,n=Array.isArray(o)?typeof o[0]=="string"?o:o.map(Object.values).flat():[o];for(let c of n)if(c){let p=new Set(r.fileDependencies);Zn.default.existsSync(c)&&(p.has(c)||(p.add(c),r.fileDependencies.add(c)))}}})})}};var or=class{manifestPath;includeList;excludeList;constructor(e){this.manifestPath=e.manifestPath,this.includeList=e.includeList,this.excludeList=e.excludeList}apply(e){new rr({manifestPath:this.manifestPath,includeList:this.includeList,excludeList:this.excludeList}).apply(e),new ir({manifestPath:this.manifestPath,includeList:this.includeList,excludeList:this.excludeList}).apply(e)}};var ar=require("webpack");function Yn(t){return t.map(e=>{try{let r=new URL(e.replace(/^\*:\/\//,"https://"));return e.endsWith(r.pathname)?`${e.substring(0,e.length-r.pathname.length)}/*`:r.pathname==="/"?`${e}/*`:e}catch{return e}})}var nr=class{manifestPath;includeList;excludeList;constructor(e){this.manifestPath=e.manifestPath,this.includeList=e.includeList,this.excludeList=e.excludeList}generateManifestPatches(e,r){let s=z(e,this.manifestPath),i=s.web_accessible_resources||[],o=s.web_accessible_resources||[];for(let[p,l]of Object.entries(r)){let u=s.content_scripts?.find(d=>d.js&&d.js.some(g=>g.includes(p)));if(u){let d=u.matches||[];if(s.manifest_version===3){let g=i.find(y=>y.matches.some(_=>d.includes(_)));g?l.forEach(y=>{!g.resources.includes(y)&&!y.endsWith(".map")&&g.resources.push(y)}):i.push({resources:l.filter(y=>!y.endsWith(".map")),matches:Yn(d)})}else l.forEach(g=>{o.includes(g)||o.push(g)})}}s.manifest_version===3?i.length>0&&(s.web_accessible_resources=i):o.length>0&&(s.web_accessible_resources=Array.from(new Set(o)));let n=JSON.stringify(s,null,2),c=new ar.sources.RawSource(n);e.getAsset("manifest.json")&&e.updateAsset("manifest.json",c)}apply(e){e.hooks.thisCompilation.tap("plugin-extension:feature-web-resources",r=>{r.hooks.processAssets.tap({name:"plugin-extension:feature-web-resources",stage:ar.Compilation.PROCESS_ASSETS_STAGE_ANALYSE},()=>{let s=[],i=Object.keys(this.includeList||{});for(let c of i.filter(Boolean))c.startsWith("content_scripts")&&(Array.isArray(c)?s.push(...c):typeof c=="string"&&s.push(c));let o=r.chunkGraph,n={};r.entrypoints.forEach((c,p)=>{if(s.includes(p)){let l=[];c.chunks.forEach(u=>{Array.from(o.getChunkModulesIterable(u)).forEach(g=>{o.getModuleChunks(g).forEach(y=>{y.auxiliaryFiles.forEach(_=>{l.includes(_)||l.push(_)})})})}),n[p]=l}}),this.generateManifestPatches(r,n)})})}};var L=a(require("fs")),I=a(require("path")),Qn=a(require("chokidar")),cr=class{options;constructor(e){this.options=e}ensureDirectoryExistence(e){let r=I.default.dirname(e);if(L.default.existsSync(r))return!0;L.default.mkdirSync(r,{recursive:!0})}copyFile(e,r){this.ensureDirectoryExistence(r),L.default.copyFileSync(e,r)}copyFolder(e,r){L.default.existsSync(r)||L.default.mkdirSync(r,{recursive:!0}),L.default.readdirSync(e).forEach(i=>{let o=I.default.join(e,i),n=I.default.join(r,i);L.default.statSync(o).isDirectory()?this.copyFolder(o,n):this.copyFile(o,n)})}apply(e){let r=I.default.dirname(this.options.manifestPath),s=I.default.join(r,"public"),i=e.options.output?.path||"";L.default.existsSync(s)&&(e.hooks.afterEmit.tap("special-folders:copy-public-folder",()=>{let o=I.default.join(i,"/");L.default.existsSync(o)||L.default.mkdirSync(o,{recursive:!0}),L.default.existsSync(s)&&this.copyFolder(s,o)}),e.options.mode!=="production"&&e.hooks.afterPlugins.tap("special-folders:copy-public-folder",()=>{let o=I.default.join(r,"public"),n=Qn.default.watch(o,{ignoreInitial:!0});n.on("add",c=>{let p=I.default.join(i,I.default.relative(r,c));this.copyFile(c,p)}),n.on("change",c=>{let p=I.default.join(i,I.default.relative(r,c));this.copyFile(c,p)}),n.on("unlink",c=>{let p=I.default.join(i,I.default.relative(r,c));L.default.existsSync(p)&&L.default.unlinkSync(p)}),e.hooks.watchClose.tap("special-folders:copy-public-folder",()=>{n.close().catch(console.error)})}))}};var U=a(require("path")),ds=a(require("chokidar"));var pr=class{manifestPath;constructor(e){this.manifestPath=e}throwCompilationError(e,r,s){let i=U.relative(process.cwd(),r),p=mi(s?"Adding":"Removing",s?"added":"removed",e,e==="pages"?"HTML pages":"script files",i);if(s){console.warn(p);return}console.error(p),process.exit(1)}apply(e){e.hooks.afterPlugins.tap("special-folders:warn-upon-folder-changes",()=>{let r=U.dirname(this.manifestPath),s=U.join(r,"pages"),i=U.join(r,"scripts"),o=ds.watch(s,{ignoreInitial:!0}),n=ds.watch(i,{ignoreInitial:!0}),c=e.options.resolve?.extensions;o.on("add",p=>{p.endsWith(".html")&&this.throwCompilationError("pages",p,!0)}),o.on("unlink",p=>{p.endsWith(".html")&&this.throwCompilationError("pages",p)}),n.on("add",p=>{c?.includes(U.extname(p))&&this.throwCompilationError("scripts",p,!0)}),n.on("unlink",p=>{c?.includes(U.extname(p))&&this.throwCompilationError("scripts",p)}),e.hooks.watchClose.tap("WarnUponFolderChanges",()=>{o.close().catch(console.error),n.close().catch(console.error)})})}};var lr=class{static name="plugin-special-folders";options;constructor(e){this.options=e}apply(e){let{manifestPath:r}=this.options;new cr({manifestPath:r}).apply(e),e.options.mode==="development"&&e.options.watchOptions&&new pr(r).apply(e)}};var fr=class{static name="plugin-extension";manifestPath;browser;constructor(e){this.manifestPath=e.manifestPath,this.browser=e.browser||"chrome"}apply(e){let r=this.manifestPath,s=fe({manifestPath:r,browser:this.browser}),i=Ho({manifestPath:r,browser:this.browser});process.env.EXPERIMENTAL_EXTENSION_RESOLVER_PLUGIN==="true"&&new kt({manifestPath:r,browser:this.browser,includeList:{...i?.pages||{},...i?.scripts||{}},excludeList:i.public,loaderOptions:{jsx:le(Ue.default.dirname(this.manifestPath))||pe(Ue.default.dirname(this.manifestPath))||ke(Ue.default.dirname(this.manifestPath)),typescript:V(Ue.default.dirname(this.manifestPath)),minify:e.options.mode==="production"}}).apply(e),new At({browser:this.browser,manifestPath:r,includeList:{...s.html,...s.icons,...s.json,...s.scripts},excludeList:i.public}).apply(e),new Gt({manifestPath:r,includeList:{...s.html,...i.pages},excludeList:{...i.public,...i.scripts}}).apply(e),new Yt({manifestPath:r,browser:this.browser,includeList:{...s.scripts,...i.scripts},excludeList:{...i.public,...i.pages}}).apply(e),new Qt({manifestPath:r}).apply(e),new tr({manifestPath:r,includeList:s.json,excludeList:i.public}).apply(e),new or({manifestPath:r,includeList:s.icons,excludeList:i.public}).apply(e),new nr({manifestPath:r,includeList:{...s.scripts,...i.scripts},excludeList:i.public}).apply(e),new lr({manifestPath:r}).apply(e)}};var Be=a(require("path"));var ea=a(require("path")),ta=a(require("ws"));function ur(t,e){t.clients.forEach(r=>{r.readyState===ta.default.OPEN&&r.send(JSON.stringify(e))})}function ra(t,e,r){if(!r||!e)return;let s=fe({manifestPath:e}).locales,i=fe({manifestPath:e}).scripts,o=fe({manifestPath:e}).json;if(!t){process.env.EXTENSION_ENV==="development"&&console.error("WebSocket server is not running.");return}ea.default.basename(r)==="manifest.json"&&ur(t,{changedFile:"manifest.json"}),s?.forEach(n=>{n.includes(r)&&ur(t,{changedFile:"_locales"})}),Object.entries(i).forEach(([n,c])=>{let p=Array.isArray(c)?c:[c];Object.values(p).flatMap(u=>u).includes(r)&&n==="background/service_worker"&&ur(t,{changedFile:"service_worker"})}),Object.entries(o).forEach(([n,c])=>{c?.includes(r)&&n==="declarative_net_request"&&ur(t,{changedFile:"declarative_net_request"})})}var hs=a(require("path")),na=a(require("fs")),We=a(require("ws"));var qe=a(require("path")),ul=a(require("http")),ia=a(require("https")),gs=a(require("fs"));var sa=t=>{if(!gs.default.existsSync(t))return;let e=qe.default.basename(t);return gs.default.readFileSync(qe.default.join(__dirname,"certs",e))};function oa(t){let e={key:sa(qe.default.join(__dirname,"certs","localhost.key")),cert:sa(qe.default.join(__dirname,"certs","localhost.cert"))},r=ia.default.createServer(e,(s,i)=>{i.writeHead(200),i.end()});return r.on("error",s=>{throw console.error(xi(t)),new Error(s.message)}),{server:r,port:t}}function ml(t,e){switch(e){case"chrome":return new We.default.Server({host:"localhost",port:t});case"edge":return new We.default.Server({host:"localhost",port:t+1});case"firefox":return new We.default.Server({server:oa(t+2).server});default:return new We.default.Server({host:"localhost",port:8888})}}async function aa(t,e){let r=t.options.context||"",s=require(hs.default.join(r,"manifest.json")),i=e.port||8e3,o=ml(i,e.browser);if(o.on("connection",n=>{n.send(JSON.stringify({status:"serverReady"})),n.on("error",c=>{console.log(hi(c))}),n.on("message",c=>{let p=JSON.parse(c.toString());if(p.status==="clientReady"){let l=require(hs.default.join(r,"manifest.json"));setTimeout(()=>{console.log(Br(l,e.browser,p)),console.log("")},2500),$i(e.browser)&&setTimeout(()=>{console.log(gi(e.browser))},5e3)}})}),e.browser==="firefox"||e.browser==="gecko-based"){let n=Ci(s);console.log(Br(s,e.browser,n)),console.log(""),na.default.existsSync(st)||(console.log(wi()),console.log(""))}return o}var ca=a(require("path")),ys=a(require("fs"));function pa(t,e){let r=ca.default.resolve(__dirname,`./extensions/${t}-manager-extension/reload-service.js`);try{let s=ys.default.readFileSync(r,"utf8"),i=s.replace(/__RELOAD_PORT__/g,e.toString());i!==s&&ys.default.writeFileSync(r,i,"utf8")}catch(s){console.error(`Error processing file: ${s.message}`)}}process.on("SIGINT",()=>{process.exit()});process.on("SIGTERM",()=>{process.exit()});var ze=class{manifestPath;port;browser;stats;constructor(e){this.manifestPath=e.manifestPath,this.port=e.port||8e3,this.browser=e.browser||"chrome",this.stats=e.stats}async apply(e){if(!this.manifestPath)return;pa(this.browser,this.port);let r=await aa(e,{...this,mode:e.options.mode,browser:this.browser,stats:this.stats,port:this.port});e.hooks.watchRun.tapAsync("reload:create-web-socket-server",(s,i)=>{let n=(s.modifiedFiles||new Set).values().next().value;if(!n){i();return}let c=Be.default.relative(Be.default.dirname(this.manifestPath),n),p=Be.default.relative(process.cwd(),Be.default.dirname(n));process.env.EXTENSION_ENV==="development"&&console.info(`\u25BA\u25BA Updated file \`${c}\` (relative to ${p})`),this.manifestPath&&ra(r,this.manifestPath,n),i()})}};var bs=a(require("path"));function la(t,e,r){t.options.module.rules.push({test:/\.(js|mjs|jsx|mjsx|ts|mts|tsx|mtsx)$/,include:[bs.default.dirname(r)],exclude:/node_modules/,use:[{loader:bs.default.resolve(__dirname,"./inject-chromium-client-loader"),options:{manifestPath:r,browser:e}}]})}var ws=a(require("path"));function fa(t,e,r){t.options.module.rules.push({test:/\.(js|mjs|jsx|mjsx|ts|mts|tsx|mtsx)$/,include:[ws.default.dirname(r)],exclude:/node_modules/,use:[{loader:ws.default.resolve(__dirname,"./inject-firefox-client-loader"),options:{manifestPath:r,browser:e}}]})}var dr=require("webpack");var xs=a(require("content-security-policy-parser"));function ua(t){let e="";for(let r in t)e+=`${r} ${t[r].join(" ")}; `;return e.trim()}function ma(t){let e=t.content_security_policy;if(!e)return"script-src 'self' 'unsafe-eval' blob: filesystem:; object-src 'self' blob: filesystem:; ";let r=(0,xs.default)(e);if(!r.get("script-src"))r.set("script-src",["'self'","'unsafe-eval'","blob:","filesystem:"]);else{let i=r.get("script-src")||[];i.includes("'unsafe-eval'")||i.push("'unsafe-eval'"),i.includes("blob:")||i.push("blob:"),i.includes("filesystem:")||i.push("filesystem:"),r.set("script-src",i)}r.get("object-src")||r.set("object-src",["'self'","blob:","filesystem:"]);let s=Object.fromEntries(r.entries());return ua(s)}function da(t){let e=t.content_security_policy;if(!e)return{extension_pages:"script-src 'self'; object-src 'self';"};let r=(0,xs.default)(e.extension_pages||""),s={};for(let n in s)r.get(n)||r.set(n,s[n]);let i=Object.fromEntries(r.entries());return{extension_pages:ua(i)}}function ga(t){let e=["/*.json","/*.js","/*.css"],r=t.web_accessible_resources;if(!r||r.length===0)return e;let s=new Set(r);for(let i of e)s.has(i)||s.add(i);return Array.from(s)}function ha(t){let e=["/*.json","/*.js","/*.css"];return[...t.web_accessible_resources||[],{resources:e,matches:["<all_urls>"]}]}function vs(t,e){return t.background?{background:{...t.background}}:e==="firefox"||e==="gecko-based"?{background:{...t.background||{},scripts:["background/script.js"]}}:t.manifest_version===2?{background:{...t.background||{},scripts:["background/script.js"]}}:{background:{...t.background||{},service_worker:"background/service_worker.js"}}}function _s(t){return t.externally_connectable&&!t.externally_connectable.ids?{externally_connectable:{...t.externally_connectable,ids:[...new Set(t.externally_connectable.ids||[]),"*"]}}:t.externally_connectable&&!t.externally_connectable.ids?{externally_connectable:{...t.externally_connectable,ids:["*"]}}:{}}var mr=class{manifestPath;browser;constructor(e){this.manifestPath=e.manifestPath,this.browser=e.browser||"chrome"}generateManifestPatches(e){let r=z(e,this.manifestPath),s={...r,content_security_policy:r.manifest_version===3?da(r):ma(r),...r.manifest_version===3?r.permissions?{permissions:[...new Set(["scripting",...r.permissions])]}:{permissions:["scripting"]}:{},...vs(r,this.browser),..._s(r),web_accessible_resources:r.manifest_version===3?ha(r):ga(r)},i=JSON.stringify(s,null,2),o=new dr.sources.RawSource(i);e.getAsset("manifest.json")&&e.updateAsset("manifest.json",o)}apply(e){e.hooks.thisCompilation.tap("run-chromium:apply-manifest-dev-defaults",r=>{r.hooks.processAssets.tap({name:"run-chromium:apply-manifest-dev-defaults",stage:dr.Compilation.PROCESS_ASSETS_STAGE_SUMMARIZE},s=>{if(!this.manifestPath){let i="No manifest.json found in your extension bundle. Unable to patch manifest.json.";r&&e.webpack.WebpackError&&r.errors.push(new e.webpack.WebpackError(`run-chromium: ${i}`));return}this.generateManifestPatches(r)})})}};var Ss=a(require("fs")),Je=a(require("path")),ya=a(require("webpack-target-webextension"));var gr=class{manifestPath;browser;constructor(e){this.manifestPath=e.manifestPath,this.browser=e.browser||"chrome"}handleBackground(e,r,s){let i=Je.default.resolve(__dirname,r==="firefox"||r==="gecko-based"?"minimum-firefox-file.mjs":"minimum-chromium-file.mjs"),o=O(s,r);if(r==="firefox"||r==="gecko-based"){o=s.background;let n=o?.scripts;n&&n.length>0?this.ensureFileExists(n[0]):this.addDefaultEntry(e,"background/script",i)}else{let n=Je.default.dirname(this.manifestPath);if(o=s.background,s.manifest_version===3){let c=o?.service_worker;if(c){let p=Je.default.join(n,c);this.ensureFileExists(p)}else this.addDefaultEntry(e,"background/service_worker",i)}else if(s.manifest_version===2){let c=o?.scripts;if(c&&c.length>0){let p=Je.default.join(n,c[0]);this.ensureFileExists(p)}else this.addDefaultEntry(e,"background/script",i)}}}ensureFileExists(e){if(!Ss.default.existsSync(e)&&this.manifestPath){let s=require(this.manifestPath).name||"Extension.js",i=yi(s,e);throw console.error(i),new Error(i)}}addDefaultEntry(e,r,s){e.options.entry={...e.options.entry,[r]:{import:[s]}}}getEntryName(e){if(e.background){if(e.manifest_version===3)return{serviceWorkerEntry:"background/service_worker"};if(e.manifest_version===2)return{pageEntry:"background/script"}}return{pageEntry:"background"}}apply(e){if(!this.manifestPath||!Ss.default.lstatSync(this.manifestPath).isFile())return;let r=require(this.manifestPath),s=O(r,this.browser);this.handleBackground(e,this.browser,s),new ya.default({background:this.getEntryName(s),weakRuntimeCheck:!0}).apply(e)}};var Ps=class{manifestPath;browser;constructor(e){this.manifestPath=e.manifestPath,this.browser=e.browser||"chrome"}apply(e){(Q.includes(this.browser)||this.browser==="chromium-based")&&la(e,this.browser,this.manifestPath),(this.browser==="firefox"||this.browser==="gecko-based")&&fa(e,this.browser,this.manifestPath),new mr({manifestPath:this.manifestPath,browser:this.browser}).apply(e),new gr({manifestPath:this.manifestPath,browser:this.browser}).apply(e)}},ba=Ps;var hr=class{static name="plugin-reload";manifestPath;browser;port;stats;autoReload;constructor(e){this.manifestPath=e.manifestPath,this.browser=e.browser||"chrome",this.port=e.port,this.stats=e.stats,this.autoReload=e.autoReload}apply(e){e.options.mode==="development"&&new ze({manifestPath:this.manifestPath,browser:this.browser,port:this.port,stats:this.stats}).apply(e),e.options.mode==="development"&&new ba({manifestPath:this.manifestPath,browser:this.browser,autoReload:this.autoReload,stats:this.stats}).apply(e)}};var wa=a(require("webpack")),yr=class{manifestPath;browser;constructor(e){this.manifestPath=e.manifestPath,this.browser=e.browser}apply(e){new wa.default.ProvidePlugin({browser:require.resolve("webextension-polyfill")}).apply(e)}};var wr=require("webpack");var br=class{browser;manifestPath;constructor(e){this.manifestPath=e.manifestPath,this.browser=e.browser||"chrome"}patchManifest(e){let r=O(e,this.browser);return JSON.stringify(r,null,2)}apply(e){e.hooks.compilation.tap("compatibility:browser-fields",r=>{r.hooks.processAssets.tap({name:"compatibility:browser-fields",stage:wr.Compilation.PROCESS_ASSETS_STAGE_OPTIMIZE},()=>{let s=z(r,this.manifestPath),i=this.patchManifest(s),o=new wr.sources.RawSource(i);r.updateAsset("manifest.json",o)})})}};var xr=class{static name="plugin-compatibility";manifestPath;browser;polyfill;constructor(e){this.manifestPath=e.manifestPath,this.browser=e.browser||"chrome",this.polyfill=e.polyfill||!1}async apply(e){this.polyfill&&this.browser!=="firefox"&&new yr({manifestPath:this.manifestPath,browser:this.browser||"chrome"}).apply(e),new br({manifestPath:this.manifestPath,browser:this.browser||"chrome"}).apply(e)}};var Da=a(require("fs"));var xa=a(require("webpack")),va=a(require("content-security-policy-parser"));function _a(t){let e=t.content_security_policy,r=t.content_security_policy?.extension_pages,s=i=>{if(!i)return;let o=(0,va.default)(i);if(o.get("script-src")&&o.get("script-src")?.includes("'unsafe-eval'"))return ti()};if(t.manifest_version===3){let i=e?s(r):void 0;if(i)return new xa.default.WebpackError(i)}return null}var ks=a(require("webpack"));function Sa(t,e){let r=t.web_accessible_resources;if(r){let s=r.some(o=>typeof o=="string"),i=r.some(o=>typeof o=="object"||o.resources||o.matches);if(t.manifest_version===2&&!s)return new ks.default.WebpackError(si(e));if(t.manifest_version===3&&!i)return new ks.default.WebpackError(ii(e))}return null}var Pa=a(require("webpack"));function ka(t,e){return(e==="firefox"||e==="gecko-based")&&t.background?.service_worker?new Pa.default.WebpackError(ei()):null}var Ea=a(require("path")),$a=a(require("fs")),Ca=a(require("webpack"));function ja(t,e){let r=Ea.default.join(e.options.context||"","_locales");return $a.default.existsSync(r)&&!t.default_locale?new Ca.default.WebpackError(ri()):null}var vr=class{options;constructor(e){this.options=e}handleRuntimeErrors(e,r,s){let i=_a(r),o=Sa(r,s),n=ka(r,s),c=ja(r,e);i&&e.errors.push(i),o&&e.errors.push(o),n&&e.options.mode==="production"&&e.errors.push(n),c&&e.errors.push(c)}apply(e){e.hooks.afterCompile.tapAsync("CompatPlugin (module)",(r,s)=>{let i=this.options.manifestPath,o=JSON.parse(Da.default.readFileSync(i,"utf-8")),n=this.options.browser||"chrome";this.handleRuntimeErrors(r,o,n),s()})}};var Ta=a(require("fs")),Na=a(require("ajv"));var Fa={$schema:"http://json-schema.org/draft-07/schema#",$id:"https://json.schemastore.org/chrome-manifest.json",additionalProperties:!0,definitions:{action_v2:{type:"object",properties:{default_title:{type:"string",description:"Tooltip for the main toolbar icon."},default_popup:{$ref:"#/definitions/uri",description:"The popup appears when the user clicks the icon."},default_icon:{anyOf:[{type:"string",description:"FIXME: String form is deprecated."},{type:"object",description:"Icon for the main toolbar.",properties:{"19":{$ref:"#/definitions/icon"},"38":{$ref:"#/definitions/icon"}}}]}},dependencies:{name:{not:{required:["name"]}},icons:{not:{required:["icons"]}},popup:{not:{required:["popup"]}}}},action_v3:{type:"object",properties:{default_title:{type:"string",description:"Tooltip for the main toolbar icon."},default_popup:{$ref:"#/definitions/uri",description:"The popup appears when the user clicks the icon."},default_icon:{type:"object",properties:{"16":{$ref:"#/definitions/icon"},"24":{$ref:"#/definitions/icon"},"32":{$ref:"#/definitions/icon"}}}},dependencies:{name:{not:{required:["name"]}},icons:{not:{required:["icons"]}},popup:{not:{required:["popup"]}}}},command:{type:"object",if:{$comment:"Global shortcuts change the acceptable pattern for the suggested_key.",properties:{global:{const:!0}},required:["global"]},then:{additionalProperties:!1,properties:{description:{type:"string"},global:{type:"boolean",description:"Whether this command should work while Chrome does not have focus. Keyboard shortcut suggestions for global commands are limited to Ctrl+Shift+[0..9]"},suggested_key:{type:"object",additionalProperties:!1,patternProperties:{"^(default|mac|windows|linux|chromeos)$":{type:"string",pattern:"^(Ctrl|Command|MacCtrl)\\+Shift\\+[0-9]"}}}}},else:{additionalProperties:!1,properties:{description:{type:"string"},global:{type:"boolean",description:"Whether this command should work while Chrome does not have focus. Keyboard shortcut suggestions for global commands are limited to Ctrl+Shift+[0..9]"},suggested_key:{type:"object",additionalProperties:!1,patternProperties:{"^(default|mac|windows|linux|chromeos)$":{type:"string",pattern:"^(Ctrl|Command|MacCtrl|Alt|Option)\\+(Shift\\+)?[A-Z]"}}}}}},content_security_policy:{type:"string",description:"This introduces some fairly strict policies that will make extensions more secure by default, and provides you with the ability to create and enforce rules governing the types of content that can be loaded and executed by your extensions and applications.",format:"content-security-policy",default:"script-src 'self'; object-src 'self'"},glob_pattern:{type:"string",format:"glob-pattern"},icon:{$ref:"#/definitions/uri"},match_pattern:{type:"string",format:"match-pattern",pattern:"^((\\*|http|https|file|ftp|chrome-extension):\\/\\/(\\*|\\*\\.[^\\/\\*]+|[^\\/\\*]+)?(\\/.*))|urn:(\\*|.*)|<all_urls>$"},mime_type:{type:"string",format:"mime-type",pattern:"^(?:application|audio|image|message|model|multipart|text|video)\\/[-+.\\w]+$"},page:{$ref:"#/definitions/uri"},permissions:{type:"array",uniqueItems:!0,items:{type:"string",format:"permission"}},scripts:{type:"array",minItems:1,uniqueItems:!0,items:{$ref:"#/definitions/uri"}},uri:{type:"string"},version_string:{type:"string",pattern:"^(?:\\d{1,5}\\.){0,3}\\d{1,5}$"},web_resource:{type:"object",required:["resources"],properties:{resources:{type:"array",description:`An array of resources to be exposed. Resources are specified as strings and may contain * for wildcard matches. For example, "/images/*" exposes everything in the extension's /images directory recursively while "*.png" exposes all PNG files.`,items:{$ref:"#/definitions/glob_pattern"}},matches:{type:"array",description:"A list of URL match patterns specifying which pages can access the resources. Only the origin is used to match URLs; subdomains patterns (*.google.com) and paths are ignored.",items:{$ref:"#/definitions/match_pattern"}},extension_ids:{type:"array",description:"A list of extension IDs, specifying which extensions can access the resources.",items:{type:"string"}},use_dynamic_url:{type:"boolean",description:"If true, only allow resources to be accessible through dynamic ID. The dynamic ID is generated per session. It's regenerated on browser restart or extension reload."}}}},dependencies:{content_scripts:{not:{required:["script_badge"]}},script_badge:{not:{required:["content_scripts"]}}},else:{properties:{background:{type:"object",description:"The background page is an HTML page that runs in the extension process. It exists for the lifetime of your extension, and only one instance of it at a time is active.",properties:{persistent:{type:"boolean",description:"When false, makes the background page an event page (loaded only when needed).",default:!0},page:{$ref:"#/definitions/page",description:"Specify the HTML of the background page.",default:"background.html"},scripts:{$ref:"#/definitions/scripts",description:"A background page will be generated by the extension system that includes each of the files listed in the scripts property.",default:["background.js"]}},dependencies:{page:{not:{required:["scripts"]}},scripts:{not:{required:["page"]}}}},browser_action:{$ref:"#/definitions/action_v2",description:"Use browser actions to put icons in the main Google Chrome toolbar, to the right of the address bar. In addition to its icon, a browser action can also have a tooltip, a badge, and a popup."},page_action:{$ref:"#/definitions/action_v2",description:"Use the chrome.pageAction API to put icons inside the address bar. Page actions represent actions that can be taken on the current page, but that aren't applicable to all pages."},content_security_policy:{$ref:"#/definitions/content_security_policy"},web_accessible_resources:{type:"array",description:"An array of strings specifying the paths (relative to the package root) of packaged resources that are expected to be usable in the context of a web page.",minItems:1,uniqueItems:!0,items:{$ref:"#/definitions/uri"}}},dependencies:{page_action:{not:{required:["browser_action"]}},browser_action:{not:{required:["page_action"]}}}},if:{properties:{manifest_version:{const:3}}},properties:{manifest_version:{type:"number",description:"One integer specifying the version of the manifest file format your package requires.",enum:[2,3]},name:{type:"string",description:"The name of the extension",maxLength:45},version:{$ref:"#/definitions/version_string",description:"One to four dot-separated integers identifying the version of this extension."},default_locale:{type:"string",description:"Specifies the subdirectory of _locales that contains the default strings for this extension.",default:"en"},description:{type:"string",description:"A plain text description of the extension",maxLength:132},icons:{type:"object",description:"One or more icons that represent the extension, app, or theme. Recommended format: PNG; also BMP, GIF, ICO, JPEG.",minProperties:1,properties:{"16":{$ref:"#/definitions/icon",description:"Used as the favicon for an extension's pages and infobar."},"48":{$ref:"#/definitions/icon",description:"Used on the extension management page (chrome://extensions)."},"128":{$ref:"#/definitions/icon",description:"Used during installation and in the Chrome Web Store."},"256":{$ref:"#/definitions/icon",description:"Used during installation and in the Chrome Web Store."}}},chrome_url_overrides:{type:"object",description:"Override pages are a way to substitute an HTML file from your extension for a page that Google Chrome normally provides.",additionalProperties:!1,maxProperties:1,properties:{bookmarks:{$ref:"#/definitions/page",description:"The page that appears when the user chooses the Bookmark Manager menu item from the Chrome menu or, on Mac, the Bookmark Manager item from the Bookmarks menu. You can also get to this page by entering the URL chrome://bookmarks.",default:"bookmarks.html"},history:{$ref:"#/definitions/page",description:"The page that appears when the user chooses the History menu item from the Chrome menu or, on Mac, the Show Full History item from the History menu. You can also get to this page by entering the URL chrome://history.",default:"history.html"},newtab:{$ref:"#/definitions/page",description:"The page that appears when the user creates a new tab or window. You can also get to this page by entering the URL chrome://newtab.",default:"newtab.html"}}},commands:{type:"object",description:"Use the commands API to add keyboard shortcuts that trigger actions in your extension, for example, an action to open the browser action or send a command to the extension.",patternProperties:{".*":{$ref:"#/definitions/command"},"^_execute_browser_action$":{$ref:"#/definitions/command"},"^_execute_page_action$":{$ref:"#/definitions/command"}}},content_scripts:{type:"array",description:"Content scripts are JavaScript files that run in the context of web pages.",minItems:1,uniqueItems:!0,items:{type:"object",required:["matches"],additionalProperties:!1,properties:{matches:{type:"array",description:"Specifies which pages this content script will be injected into.",minItems:1,uniqueItems:!0,items:{$ref:"#/definitions/match_pattern"}},exclude_matches:{type:"array",description:"Excludes pages that this content script would otherwise be injected into.",uniqueItems:!0,items:{$ref:"#/definitions/match_pattern"}},css:{type:"array",description:"The list of CSS files to be injected into matching pages. These are injected in the order they appear in this array, before any DOM is constructed or displayed for the page.",uniqueItems:!0,items:{$ref:"#/definitions/uri"}},js:{$ref:"#/definitions/scripts",description:"The list of JavaScript files to be injected into matching pages. These are injected in the order they appear in this array."},world:{type:"string",description:"The JavaScript world for a script to execute within.",enum:["ISOLATED","MAIN"],default:"ISOLATED"},run_at:{type:"string",description:"Controls when the files in js are injected.",enum:["document_start","document_end","document_idle"],default:"document_idle"},all_frames:{type:"boolean",description:"Controls whether the content script runs in all frames of the matching page, or only the top frame.",default:!1},include_globs:{type:"array",description:"Applied after matches to include only those URLs that also match this glob. Intended to emulate the @include Greasemonkey keyword.",uniqueItems:!0,items:{$ref:"#/definitions/glob_pattern"}},exclude_globs:{type:"array",description:"Applied after matches to exclude URLs that match this glob. Intended to emulate the @exclude Greasemonkey keyword.",uniqueItems:!0,items:{$ref:"#/definitions/glob_pattern"}},match_about_blank:{type:"boolean",description:"Whether to insert the content script on about:blank and about:srcdoc.",default:!1}}}},devtools_page:{$ref:"#/definitions/page",description:"A DevTools extension adds functionality to the Chrome DevTools. It can add new UI panels and sidebars, interact with the inspected page, get information about network requests, and more."},externally_connectable:{description:"Declares which extensions, apps, and web pages can connect to your extension via runtime.connect and runtime.sendMessage.",type:"object",additionalProperties:!1,properties:{ids:{type:"array",items:{type:"string",description:"The IDs of extensions or apps that are allowed to connect. If left empty or unspecified, no extensions or apps can connect."}},matches:{type:"array",items:{type:"string",description:"The URL patterns for web pages that are allowed to connect. This does not affect content scripts. If left empty or unspecified, no web pages can connect."}},accepts_tls_channel_id:{type:"boolean",default:!1,description:"Indicates that the extension would like to make use of the TLS channel ID of the web page connecting to it. The web page must also opt to send the TLS channel ID to the extension via setting includeTlsChannelId to true in runtime.connect's connectInfo or runtime.sendMessage's options."}}},file_browser_handlers:{type:"array",description:"You can use this API to enable users to upload files to your website.",minItems:1,items:{type:"object",required:["id","default_title","file_filters"],additionalProperties:!1,properties:{id:{type:"string",description:"Used by event handling code to differentiate between multiple file handlers"},default_title:{type:"string",description:"What the button will display."},file_filters:{type:"array",description:"Filetypes to match.",minItems:1,items:{type:"string"}}}}},homepage_url:{$ref:"#/definitions/uri",description:"The URL of the homepage for this extension."},incognito:{type:"string",description:"Specify how this extension will behave if allowed to run in incognito mode.",enum:["spanning","split","not_allowed"],default:"spanning"},input_components:{type:"array",description:"Allows your extension to handle keystrokes, set the composition, and manage the candidate window.",items:{type:"object",required:["name","type","id","description","language","layouts"],additionalProperties:!1,properties:{name:{type:"string"},type:{type:"string"},id:{type:"string"},description:{type:"string"},language:{type:"string"},layouts:{type:"array"}}}},key:{type:"string",description:"This value can be used to control the unique ID of an extension, app, or theme when it is loaded during development."},minimum_chrome_version:{$ref:"#/definitions/version_string",description:"The version of Chrome that your extension, app, or theme requires, if any."},nacl_modules:{type:"array",description:"One or more mappings from MIME types to the Native Client module that handles each type.",minItems:1,uniqueItems:!0,items:{type:"object",required:["path","mime_type"],additionalProperties:!1,properties:{path:{$ref:"#/definitions/uri",description:"The location of a Native Client manifest (a .nmf file) within the extension directory."},mime_type:{$ref:"#/definitions/mime_type",description:"The MIME type for which the Native Client module will be registered as content handler."}}}},oauth2:{type:"object",description:"Use the Chrome Identity API to authenticate users: the getAuthToken for users logged into their Google Account and the launchWebAuthFlow for users logged into a non-Google account.",required:["client_id","scopes"],additionalProperties:!1,properties:{client_id:{type:"string",description:"You need to register your app in the Google APIs Console to get the client ID."},scopes:{type:"array",minItems:1,items:{type:"string"}}}},offline_enabled:{type:"boolean",description:"Whether the app or extension is expected to work offline. When Chrome detects that it is offline, apps with this field set to true will be highlighted on the New Tab page."},omnibox:{type:"object",description:"The omnibox API allows you to register a keyword with Google Chrome's address bar, which is also known as the omnibox.",required:["keyword"],additionalProperties:!1,properties:{keyword:{type:"string",description:"The keyword that will trigger your extension."}}},optional_permissions:{$ref:"#/definitions/permissions",description:"Use the chrome.permissions API to request declared optional permissions at run time rather than install time, so users understand why the permissions are needed and grant only those that are necessary."},options_page:{$ref:"#/definitions/page",description:"To allow users to customize the behavior of your extension, you may wish to provide an options page. If you do, a link to it will be provided from the extensions management page at chrome://extensions. Clicking the Options link opens a new tab pointing at your options page.",default:"options.html"},options_ui:{type:"object",description:"To allow users to customize the behavior of your extension, you may wish to provide an options page. If you do, an Options link will be shown on the extensions management page at chrome://extensions which opens a dialogue containing your options page.",required:["page"],properties:{page:{type:"string",description:"The path to your options page, relative to your extension's root."},chrome_style:{type:"boolean",default:!0,description:"If true, a Chrome user agent stylesheet will be applied to your options page. The default value is false, but we recommend you enable it for a consistent UI with Chrome."},open_in_tab:{type:"boolean",default:!1,description:"If true, your extension's options page will be opened in a new tab rather than embedded in chrome://extensions. The default is false, and we recommend that you don't change it. This is only useful to delay the inevitable deprecation of the old options UI! It will be removed soon, so try not to use it. It will break."}}},permissions:{$ref:"#/definitions/permissions",description:"Permissions help to limit damage if your extension or app is compromised by malware. Some permissions are also displayed to users before installation, as detailed in Permission Warnings."},requirements:{type:"object",description:"Technologies required by the app or extension. Hosting sites such as the Chrome Web Store may use this list to dissuade users from installing apps or extensions that will not work on their computer.",additionalProperties:!1,properties:{plugins:{type:"object",description:"Indicates if an app or extension requires NPAPI to run. This requirement is enabled by default when the manifest includes the 'plugins' field.",required:["npapi"],additionalProperties:!1,properties:{npapi:{type:"boolean",default:!0}}},"3D":{type:"object",description:"The '3D' requirement denotes GPU hardware acceleration.",required:["features"],additionalProperties:!1,properties:{features:{type:"array",description:"List of the 3D-related features your app requires.",minItems:1,uniqueItems:!0,items:{type:"string",enum:["webgl"]}}}}}},sandbox:{type:"object",description:"Defines an collection of app or extension pages that are to be served in a sandboxed unique origin, and optionally a Content Security Policy to use with them.",required:["pages"],additionalProperties:!1,properties:{pages:{type:"array",minItems:1,uniqueItems:!0,items:{$ref:"#/definitions/page"}},content_security_policy:{$ref:"#/definitions/content_security_policy",default:"sandbox allow-scripts allow-forms"}}},short_name:{type:"string",description:"The short name is typically used where there is insufficient space to display the full name.",maxLength:12},update_url:{$ref:"#/definitions/uri",description:"If you publish using the Chrome Developer Dashboard, ignore this field. If you host your own extension or app: URL to an update manifest XML file."},tts_engine:{type:"object",description:"Register itself as a speech engine.",required:["voices"],additionalProperties:!1,properties:{voices:{type:"array",description:"Voices the extension can synthesize.",minItems:1,uniqueItems:!0,items:{type:"object",required:["voice_name","event_types"],additionalProperties:!1,properties:{voice_name:{type:"string",description:"Identifies the name of the voice and the engine used."},lang:{type:"string",description:"Almost always, a voice can synthesize speech in just a single language. When an engine supports more than one language, it can easily register a separate voice for each language."},gender:{type:"string",description:"If your voice corresponds to a male or female voice, you can use this parameter to help clients choose the most appropriate voice for their application."},event_types:{type:"array",description:"Events sent to update the client on the progress of speech synthesis.",minItems:1,uniqueItems:!0,items:{type:"string",description:"",enum:["start","word","sentence","marker","end","error"]}}}}}}},version_name:{type:"string",description:"In addition to the version field, which is used for update purposes, version_name can be set to a descriptive version string and will be used for display purposes if present."},chrome_settings_overrides:{},content_pack:{},current_locale:{},import:{},platforms:{},signature:{},spellcheck:{},storage:{},system_indicator:{}},required:["manifest_version","name","version"],then:{$comment:"browser_action and page_action are no longer present in v3",properties:{background:{type:"object",description:"The background page is an HTML page that runs in the extension process. It exists for the lifetime of your extension, and only one instance of it at a time is active.",properties:{service_worker:{type:"string",description:"The service worker js file."},type:{type:"string",enum:["module"]}},dependencies:{page:{not:{required:["scripts"]}},scripts:{not:{required:["page"]}}}},host_permissions:{$ref:"#/definitions/permissions"},action:{$ref:"#/definitions/action_v3",description:"Used to control the toolbar button for your extension in Chrome's UI."},content_security_policy:{type:"object",properties:{extension_pages:{$ref:"#/definitions/content_security_policy",description:"This policy covers pages in your extension, including html files and service workers."},sandbox:{$ref:"#/definitions/content_security_policy",description:"This policy covers any sandboxed extension pages that your extension uses."}}},web_accessible_resources:{type:"array",description:"An array of objects that declare resource access rules. Each object maps an array of extension resources to an array of URLs and/or extension IDs that can access those resources.",minItems:1,uniqueItems:!0,items:{$ref:"#/definitions/web_resource"}}},dependencies:{browser_action:{not:{required:["browser_action"]}},page_action:{not:{required:["page_action"]}}}},title:"JSON schema for Google Chrome extension manifest files",type:"object"};function La(t){t.addFormat("permission",{type:"string",validate:e=>typeof e=="string"&&e.trim()!==""}),t.addFormat("content-security-policy",{type:"string",validate:e=>typeof e=="string"}),t.addFormat("glob-pattern",{type:"string",validate:e=>typeof e=="string"&&/[\*\?\[\]]/.test(e)}),t.addFormat("match-pattern",{type:"string",validate:e=>e==="<all_urls>"||e==="file:///"||e.startsWith("http://localhost")||e.startsWith("http:// ")||e.startsWith("http://*:*/*")?!0:typeof e=="string"&&/^(\*|http|https|file|ftp):\/\//.test(e)}),t.addFormat("uri",{type:"string",validate:e=>typeof e=="string"&&/^(\w+:)?\/\//.test(e)}),t.addFormat("mime-type",{type:"string",validate:e=>typeof e=="string"&&/^[a-z]+\/[a-z0-9\-\+]+$/.test(e)})}var Ia=require("webpack");function Oa(t,e,r){let s=e?.params.missingProperty;t.errors.push(new Ia.WebpackError(ai(r,s)))}var Ma=require("webpack");function Aa(t,e,r){t.warnings.push(new Ma.WebpackError(ni(e,r)))}var Ra=require("webpack");function Es(t,e,r){t.warnings.push(new Ra.WebpackError(oi(r,e)))}var _r=class{options;constructor(e){this.options=e}handleSchemaErrors(e,r,s){let i=new Na.default;La(i);let o={allOf:[Fa]},n=i.compile(o),c=O(r,s),p=n(c),l=c.manifest_version===3;if(!p&&n.errors){let u=n.errors[0];if(u?.keyword==="required"){Oa(e,u,s);return}l&&(u?.keyword==="type"&&Aa(e,u,s),u?.keyword==="not"&&Es(e,u,s))}}apply(e){e.hooks.afterCompile.tapAsync("CompatPlugin (module)",(r,s)=>{let i=this.options.manifestPath,o=JSON.parse(Ta.default.readFileSync(i,"utf-8")),n=this.options.browser||"chrome";this.handleSchemaErrors(r,o,n),s()})}};var Wa=a(require("fs")),Cs=a(require("path"));var $s=a(require("webpack"));function Ua(t,e){let r="Conflict: Multiple assets emit different content to the same filename ";if(e.message.includes(r)){let s=e.message.replace(r,"");if(s.startsWith("content_scripts"))return new $s.default.WebpackError(ci(t,s))}return null}function qa(t,e){let r=require(t);return e.message.includes("Top-level-await is only supported in EcmaScript Modules")?new $s.default.WebpackError(pi(r.name)):null}var Sr=class{manifestPath;constructor(e){this.manifestPath=e.manifestPath}apply(e){let r=Cs.default.join(Cs.default.dirname(this.manifestPath),"package.json");if(!Wa.default.existsSync(r))return;let s=require(r).name;e.hooks.compilation.tap("develop:common-errors",i=>{i.hooks.afterSeal.tapAsync("develop:common-errors",o=>{i.errors.forEach((n,c)=>{let p=Ua(s,n),l=qa(s,n);p&&(i.errors[c]=p),l&&(i.errors[c]=l)}),o()})})}};var Pr=class{static name="plugin-errors";manifestPath;browser;constructor(e){this.manifestPath=e.manifestPath,this.browser=e.browser||"chrome"}apply(e){new vr({manifestPath:this.manifestPath,browser:this.browser||"chrome"}).apply(e),new _r({manifestPath:this.manifestPath,browser:this.browser||"chrome"}).apply(e),new Sr({manifestPath:this.manifestPath}).apply(e)}};var rp=a(require("os")),Os=a(require("path"));var fc=a(require("fs")),uc=a(require("path")),mc=require("child_process");var te=a(require("path")),Ge=a(require("fs"));var Ba={alternate_error_pages:{enabled:!1},autofill:{enabled:!1},browser:{check_default_browser:!1,default_browser_setting_enabled:!1},default_apps:"install",distribution:{alternate_shortcut_text:!1,auto_launch_chrome:!1,import_bookmarks:!1,import_history:!1,import_home_page:!1,import_search_engine:!1,suppress_first_run_bubble:!0,do_not_register_for_update_launch:!0,make_chrome_default:!1,make_chrome_default_for_user:!1,require_eula:!1,suppress_first_run_default_browser_prompt:!0},dns_prefetching:{enabled:!1},download:{default_directory:"/tmp/",directory_upgrade:!0,open_pdf_in_adobe_reader:!1,prompt_for_download:!0},enable_do_not_track:!0,extensions:{theme:{use_system:!1},toolbarsize:-1,ui:{developer_mode:!0}},plugins:{plugins_list:[{enabled:!1,name:"Java(TM)"}],show_details:!0},profile:{password_manager_enabled:!1},safebrowsing:{enabled:!1,safebrowsingextended_reporting_enabled:!1},savefile:{default_directory:"/tmp",type:0},search:{suggest_enabled:!1},session:{restore_on_startup:1},sync:{suppress_start:!0},sync_promo:{show_on_first_run_allowed:!1,show_ntp_bubble:!1},translate:{enabled:!1}},za={...Ba},Ja={...Ba};var b=require("@colors/colors/safe");function E(t,e){let r=e==="warn"?(0,b.brightYellow)("\u25BA\u25BA\u25BA"):e==="info"?(0,b.cyan)("\u25BA\u25BA\u25BA"):e==="error"?`${(0,b.bold)((0,b.red)("ERROR"))} in ${He(t)} ${(0,b.red)("\u2716\uFE0E\u2716\uFE0E\u2716\uFE0E")}`:(0,b.brightGreen)("\u25BA\u25BA\u25BA");return`${(0,b.gray)("")}${r}`}function He(t){return t.charAt(0).toUpperCase()+t.slice(1)}function kr(t){let e=He(t);return`${E(t,"info")} Creating new ${e} user profile...`}function Ha(t){return`${E(t,"success")} Instance already running.`}function Va(t){return`${E(t,"info")} Instance exited.`}function Er(t,e){let r=t==="firefox"||t==="gecko-based"?"Add-on":"Extension";return`${E(t,"success")} ${He(t)} ${r} running in ${(0,b.brightBlue)(e||"unknown")} mode.`}function Ve(t,e){let r=e=="null"?`Browser is not installed
127
113
 
128
- ${(0,x.red)("NOT FOUND")} ${(0,x.underline)(e)}
114
+ `:`Can't find the browser path
129
115
 
130
- `;return`${E(t,"error")} ${r}Either install the ${s} or choose a different browser via ${(0,x.brightYellow)("--browser")} flag.`}function Es(t){let e=Be(t);return`${E(t,"info")} Creating new ${e} user profile...`}function Aa(t){return`${E(t,"success")} Instance already running.`}function Ma(t){return`${E(t,"info")} Instance exited.`}function Ta(t){return`${E(t,"error")} No Service Worker Support
116
+ `;return`${E(t,"error")} ${r}Either install the missing browser or choose a different one via ${(0,b.brightYellow)("--browser")} flag.
117
+ ${(0,b.red)("NOT FOUND")} ${(0,b.underline)(e||He(t)+"BROWSER")}`}function Ga(t){return`${E(t,"error")} No Service Worker Support
131
118
 
132
- Firefox does not support the ${(0,x.brightYellow)("background.service_worker")} field yet.
133
- Update your manifest.json file to use ${(0,x.brightYellow)("background.scripts")} instead.
119
+ Firefox does not support the ${(0,b.brightYellow)("background.service_worker")} field yet.
120
+ Update your manifest.json file to use ${(0,b.brightYellow)("background.scripts")} instead.
134
121
 
135
- Read more: ${(0,x.underline)("https://bugzilla.mozilla.org/show_bug.cgi?id=1573659")}.`}function Ra(t,e){return`${E(t,"error")} Error launching ${Be(t)}. Error:
122
+ Read more: ${(0,b.underline)("https://bugzilla.mozilla.org/show_bug.cgi?id=1573659")}.`}function Xa(t,e){return`${E(t,"error")} Error launching browser:
123
+ ${(0,b.red)(e)}`}function Za(t,e){return`${E(t,"error")} ${(0,b.red)(e.stack)}`}function Ka(t){return`${E(t,"error")} Unable to connect to ${He(t)}. Too many retries.`}function Ya(t,e){return`${E(t,"error")} Error while installing temporary addon:
124
+ ${(0,b.red)(e)}`}function Qa(t,e){return`${E(t,"error")} Path is not directory
136
125
 
137
- ${(0,x.red)(e)}`}function Na(t,e){return`${E(t,"error")} ${(0,x.red)(e.stack)}`}function qa(t){return`${E(t,"error")} Unable to connect to ${Be(t)}. Too many retries.`}function Ua(t,e){return`${E(t,"error")} Error while installing temporary addon: ${(0,x.red)(e)}`}function Wa(t,e){return`${E(t,"error")} The path is not a directory.
126
+ Please provide a valid directory path and try again.
127
+ ${(0,b.red)("NOT DIRECTORY")} ${(0,b.underline)(e)}`}function ec(t){return`${E(t,"error")} Error parsing message length.`}function tc(t){return`${E(t,"error")} ${(0,b.magenta)("MessagingClient")} connection closed.`}function rc(t,e){return`${E(t,"error")} Unexpected ${(0,b.magenta)("MessagingClient")} request without target actor: ${(0,b.brightYellow)(e)}`}function sc(t){return`${E(t,"error")} ${(0,b.magenta)("MessagingClient")} connection closed.`}function ic(t,e){return`${E(t,"error")} Target actor ${(0,b.brightYellow)(e)} already has an active request.`}function oc(t,e){return`${E(t,"error")} Error parsing packet: ${(0,b.red)(e)}`}function nc(t,e){return`${E(t,"error")} Message received without a sender actor:
128
+ ${(0,b.brightYellow)(JSON.stringify(e))}`}function ac(t,e){return`${E(t,"error")} Received unexpected message:
129
+ ${(0,b.red)(e)}`}var cc=a(require("progress"));function $r(t,e){let s=new cc.default(`${t} [:bar] :percent :etas`,{complete:"=",incomplete:" ",width:50,total:131072}),i=setInterval(()=>{let o=Math.random()*10*1024;s.tick(o),s.complete&&(clearInterval(i),e())},50)}function pc(t,e,r){if(e&&Ge.default.existsSync(e))return e;if(Ge.default.existsSync(te.default.resolve(__dirname,`run-${t}-profile`)))return te.default.resolve(__dirname,`run-${t}-profile`);let i=JSON.stringify({...t==="chrome"?za:Ja,...r});return $r(kr(t),()=>{let o=te.default.resolve(__dirname,`run-${t}-profile`),n=te.default.join(o,"Default");Ge.default.mkdirSync(n,{recursive:!0});let c=te.default.join(n,"Preferences");Ge.default.writeFileSync(c,i,"utf8")}),te.default.resolve(__dirname,`run-${t}-profile`)}function lc(t){let e=Array.isArray(t.extension)?t.extension:[t.extension],r=pc(t.browser,t.profile,t.preferences);return[`--load-extension=${e.join()}`,`--user-data-dir=${r}`,"--no-first-run","--disable-client-side-phishing-detection","--disable-component-extensions-with-background-pages","--disable-default-apps","--disable-features=InterestFeedContentSuggestions","--disable-features=Translate","--hide-scrollbars","--mute-audio","--no-default-browser-check","--no-first-run","--ash-no-nudges","--disable-search-engine-choice-screen","--disable-features=MediaRoute","--use-mock-keychain","--disable-background-networking","--disable-breakpad","--disable-component-update","--disable-domain-reliability","--disable-features=AutofillServerCommunicatio","--disable-features=CertificateTransparencyComponentUpdate","--disable-sync","--disable-features=OptimizationHints","--disable-features=DialMediaRouteProvider","--no-pings","--enable-features=SidePanelUpdates",...t.browserFlags||[]]}process.on("SIGINT",()=>{process.exit()});process.on("SIGTERM",()=>{process.exit()});var Xe=class{extension;browser;browserFlags;userDataDir;profile;preferences;startingUrl;autoReload;stats;chromiumBinary;constructor(e){this.extension=e.extension,this.browser=e.browser,this.browserFlags=e.browserFlags||[],this.userDataDir=e.userDataDir,this.profile=e.profile||e.userDataDir,this.preferences=e.preferences,this.startingUrl=e.startingUrl,this.chromiumBinary=e.chromiumBinary}launchChromium(e){let r;switch(e){case"chrome":r=require(`${e}-location`);break;case"edge":r=require(`${e}-location`)();break;case"chromium-based":r=uc.default.normalize(this.chromiumBinary);break;default:r=require(`${e}`);break}fc.default.existsSync(r)||(console.error(Ve(e,r)),process.exit());let s=lc(this),i=this.startingUrl?[this.startingUrl,...s]:[...s],o=process.env.EXTENSION_ENV==="development"?"inherit":"ignore",n=(0,mc.spawn)(`${r}`,i,{stdio:o});process.env.EXTENSION_ENV==="development"&&(n.stdout?.pipe(process.stdout),n.stderr?.pipe(process.stderr))}apply(e){let r=!1;e.hooks.done.tapAsync("run-browsers:module",(s,i)=>{if(s.compilation.errors.length>0){i();return}if(r){i();return}this.launchChromium(this.browser),setTimeout(()=>{console.log(Er(this.browser,s.compilation.options.mode))},2e3),r=!0,i()})}};var ep=a(require("fs")),tp=a(require("path")),Is=require("child_process");var Ze=a(require("fs")),Cr=a(require("path")),dc=a(require("os")),gc=a(require("which")),hc=process.platform==="darwin",gl=process.platform==="win32",hl=!hc&&!gl;function yl(){if(hl)try{return gc.default.sync("firefox")}catch{return null}else if(hc){let t="/Applications/Firefox.app/Contents/MacOS/firefox",e=Cr.default.join(dc.default.homedir(),t.slice(1));return Ze.default.existsSync(t)?t:Ze.default.existsSync(e)?e:null}else{let t=Cr.default.join("Mozilla Firefox","firefox.exe"),e=[process.env.LOCALAPPDATA,process.env.PROGRAMFILES,process.env["PROGRAMFILES(X86)"]];for(let s of e)if(s){let i=Cr.default.join(s,t);if(Ze.default.existsSync(i))return i}let r=["C:\\Program Files\\Mozilla Firefox\\firefox.exe","C:\\Program Files (x86)\\Mozilla Firefox\\firefox.exe"];for(let s of r)if(Ze.default.existsSync(s))return s;return null}}var yc=yl();var Fs=a(require("path")),Ir=a(require("fs")),Ls=a(require("firefox-profile"));var bl={"app.update.enabled":!1,"browser.dom.window.dump.enabled":!0,"browser.formfill.enable":!1,"browser.link.open_newwindow":3,"browser.sessionstore.enabled":!1,"browser.shell.checkDefaultBrowser":!1,"browser.sync.enabled":!1,"browser.startup.page":0,"browser.startup.homepage_welcome_url":"about:blank","browser.startup.homepage_welcome_url_additional":"about:blank","browser.urlbar.suggest.bookmark":!1,"browser.urlbar.suggest.clipboard":!1,"browser.urlbar.suggest.history":!1,"browser.urlbar.suggest.openpage":!1,"browser.urlbar.suggest.remotetab":!1,"browser.urlbar.suggest.searches":!1,"browser.urlbar.suggest.topsites":!1,"browser.urlbar.suggest.engines":!1,"browser.urlbar.suggest.calculator":!1,"browser.urlbar.suggest.recentsearches":!1,"datareporting.policy.dataSubmissionEnabled":!1,"datareporting.policy.firstRunURL":"","devtools.browserconsole.contentMessages":!0,"devtools.chrome.enabled":!0,"devtools.debugger.prompt-connection":!1,"devtools.debugger.remote-enabled":!0,"devtools.errorconsole.enabled":!0,"extensions.installDistroAddons":!1,"extensions.autoDisableScopes":10,"extensions.chrome.enabled":!0,"extensions.logging.enabled":!1,"extensions.checkCompatibility.nightly":!1,"extensions.update.enabled":!1,"extensions.update.notifyUser":!1,"extensions.enabledScopes":5,"extensions.getAddons.cache.enabled":!1,"network.prefetch.next":!1,"network.speculative.preconnect.enabled":!1,"toolkit.telemetry.enabled":!1,"toolkit.telemetry.archive.enabled":!1,"toolkit.telemetry.newProfilePing.enabled":!1,"toolkit.recovery.enabled":!1,"urlclassifier.updateinterval":172800,"security.enterprise_roots.enabled":!0,"xpinstall.signatures.required":!1};function js(t){return{...bl,...t}}var Ye=a(require("fs")),Qe=a(require("path"));var Ke=a(require("path")),jr=a(require("fs")),m=require("@colors/colors/safe");function P(t){return`${t==="warn"?(0,m.brightYellow)("\u25BA\u25BA\u25BA"):t==="info"?(0,m.cyan)("\u25BA\u25BA\u25BA"):t==="error"?`${(0,m.bold)((0,m.red)("ERROR"))} in Extension.js ${(0,m.red)("\u2716\uFE0E\u2716\uFE0E\u2716\uFE0E")}`:(0,m.brightGreen)("\u25BA\u25BA\u25BA")}`}function Z(t){return`${P("error")} Manifest file not found.
138
130
 
139
- ${(0,x.gray)("PATH")} ${(0,x.underline)(e)}
140
-
141
- Please provide a valid directory path.`}function Ba(t){return`${E(t,"error")} Error parsing message length.`}function Ja(t){return`${E(t,"error")} MessagingClient connection closed.`}function za(t,e){return`${E(t,"error")} Unexpected MessagingClient request without target actor: ${(0,x.brightYellow)(e)}`}function Ha(t){return`${E(t,"error")} MessagingClient connection closed.`}function Va(t,e){return`${E(t,"error")} Target actor ${(0,x.brightYellow)(e)} already has an active request.`}function Ga(t,e){return`${E(t,"error")} Error parsing packet: ${(0,x.red)(e)}`}function Xa(t,e){return`${E(t,"error")} Message received without a sender actor: ${(0,x.brightYellow)(JSON.stringify(e))}`}function Za(t,e){return`${E(t,"error")} Received unexpected message: ${(0,x.red)(e)}`}var Ya=a(require("progress"));function js(t,e){let r=new Ya.default(`${t} [:bar] :percent :etas`,{complete:"=",incomplete:" ",width:50,total:131072}),i=setInterval(()=>{let n=Math.random()*10*1024;r.tick(n),r.complete&&(clearInterval(i),e())},50)}function Ka(t,e,s){if($s.default.existsSync(re.default.resolve(__dirname,`run-${t}-profile`)))return e||re.default.resolve(__dirname,`run-${t}-profile`);let i=JSON.stringify(t==="chrome"?Ia:Oa);return s||js(Es(t),()=>{let n=re.default.resolve(__dirname,`run-${t}-profile`),o=re.default.join(n,"Default");$s.default.mkdirSync(o,{recursive:!0});let c=re.default.join(o,"Preferences");$s.default.writeFileSync(c,i,"utf8")}),re.default.resolve(__dirname,`run-${t}-profile`)}function Qa(t){let e=Array.isArray(t.extension)?t.extension:[t.extension],s=Ka(t.browser,t.profile,!1);return[`--load-extension=${e.join()}`,`--user-data-dir=${s}`,"--no-first-run","--disable-client-side-phishing-detection","--disable-component-extensions-with-background-pages","--disable-default-apps","--disable-features=InterestFeedContentSuggestions","--disable-features=Translate","--hide-scrollbars","--mute-audio","--no-default-browser-check","--no-first-run","--ash-no-nudges","--disable-search-engine-choice-screen","--disable-features=MediaRoute","--use-mock-keychain","--disable-background-networking","--disable-breakpad","--disable-component-update","--disable-domain-reliability","--disable-features=AutofillServerCommunicatio","--disable-features=CertificateTransparencyComponentUpdate","--disable-sync","--disable-features=OptimizationHints","--disable-features=DialMediaRouteProvider","--no-pings","--enable-features=SidePanelUpdates",...t.browserFlags||[]]}process.on("SIGINT",()=>{process.exit()});process.on("SIGTERM",()=>{process.exit()});var ve=class{extension;browser;browserFlags;userDataDir;profile;preferences;startingUrl;autoReload;stats;constructor(e){this.extension=e.extension,this.browser=e.browser,this.browserFlags=e.browserFlags||[],this.userDataDir=e.userDataDir,this.profile=e.profile||e.userDataDir,this.preferences=e.preferences,this.startingUrl=e.startingUrl}launchChromium(e){let s;switch(e){case"chrome":s=require(`${e}-location`);break;case"edge":s=require(`${e}-location`)();break;default:s=require(`${e}`);break}ec.default.existsSync(s)||(console.error(ks(e,s)),process.exit());let r=Qa(this),i=this.startingUrl?[this.startingUrl,...r]:[...r],n=process.env.EXTENSION_ENV==="development"?"inherit":"ignore",o=(0,tc.spawn)(s,i,{stdio:n});process.env.EXTENSION_ENV==="development"&&(o.stdout?.pipe(process.stdout),o.stderr?.pipe(process.stderr))}apply(e){let s=!1;e.hooks.done.tapAsync("run-browsers:module",(r,i)=>{if(r.compilation.errors.length>0){i();return}if(s){i();return}this.launchChromium(this.browser),setTimeout(()=>{console.log(Ps(this.browser,r.compilation.options.mode))},2e3),s=!0,i()})}};var gc=a(require("fs")),hc=require("child_process");var Je=a(require("fs")),Cs=a(require("path")),sc=a(require("os")),rc=a(require("which")),ic=process.platform==="darwin",Kp=process.platform==="win32",Qp=!ic&&!Kp;function el(){if(Qp)try{return rc.default.sync("firefox")}catch{return null}else if(ic){let t="/Applications/Firefox.app/Contents/MacOS/firefox",e=Cs.default.join(sc.default.homedir(),t.slice(1));return Je.default.existsSync(t)?t:Je.default.existsSync(e)?e:null}else{let t=Cs.default.join("Mozilla Firefox","firefox.exe"),e=[process.env.LOCALAPPDATA,process.env.PROGRAMFILES,process.env["PROGRAMFILES(X86)"]];for(let r of e)if(r){let i=Cs.default.join(r,t);if(Je.default.existsSync(i))return i}let s=["C:\\Program Files\\Mozilla Firefox\\firefox.exe","C:\\Program Files (x86)\\Mozilla Firefox\\firefox.exe"];for(let r of s)if(Je.default.existsSync(r))return r;return null}}var Ds=el();var oc=a(require("path")),Fs=a(require("fs")),Pr=a(require("firefox-profile"));var tl={"app.update.enabled":!1,"browser.dom.window.dump.enabled":!0,"browser.formfill.enable":!1,"browser.link.open_newwindow":3,"browser.sessionstore.enabled":!1,"browser.shell.checkDefaultBrowser":!1,"browser.sync.enabled":!1,"browser.startup.page":0,"browser.startup.homepage_welcome_url":"about:blank","browser.startup.homepage_welcome_url_additional":"about:blank","browser.urlbar.suggest.bookmark":!1,"browser.urlbar.suggest.clipboard":!1,"browser.urlbar.suggest.history":!1,"browser.urlbar.suggest.openpage":!1,"browser.urlbar.suggest.remotetab":!1,"browser.urlbar.suggest.searches":!1,"browser.urlbar.suggest.topsites":!1,"browser.urlbar.suggest.engines":!1,"browser.urlbar.suggest.calculator":!1,"browser.urlbar.suggest.recentsearches":!1,"datareporting.policy.dataSubmissionEnabled":!1,"datareporting.policy.firstRunURL":"","devtools.browserconsole.contentMessages":!0,"devtools.chrome.enabled":!0,"devtools.debugger.prompt-connection":!1,"devtools.debugger.remote-enabled":!0,"devtools.errorconsole.enabled":!0,"extensions.installDistroAddons":!1,"extensions.autoDisableScopes":10,"extensions.chrome.enabled":!0,"extensions.logging.enabled":!1,"extensions.checkCompatibility.nightly":!1,"extensions.update.enabled":!1,"extensions.update.notifyUser":!1,"extensions.enabledScopes":5,"extensions.getAddons.cache.enabled":!1,"network.prefetch.next":!1,"network.speculative.preconnect.enabled":!1,"toolkit.telemetry.enabled":!1,"toolkit.telemetry.archive.enabled":!1,"toolkit.telemetry.newProfilePing.enabled":!1,"toolkit.recovery.enabled":!1,"urlclassifier.updateinterval":172800,"security.enterprise_roots.enabled":!0,"xpinstall.signatures.required":!1};function nc(t){return{...tl,...t}}function ac(t,e){let s=nc(e);Object.keys(s).forEach(n=>{t.setPreference(n,s[n])});let i=Object.keys(e);return i.length>0&&i.forEach(n=>{t.setPreference(n,e[n])}),t.updatePreferences(),t}function sl(t,e){let s=new Pr.default({destinationDirectory:t});return ac(s,e)}function rl(t,e,s){let r;if(Fs.default.statSync(e).isDirectory())r=e;else throw new Error(Wa(t,e));let n=new Pr.default({destinationDirectory:r});return ac(n,s)}function cc(t,e,s,r){let i,n=e||oc.default.resolve(__dirname,"run-firefox-data-dir");return Fs.default.existsSync(n)?i=rl(t,n,s||{}):(r||js(Es(t),()=>{}),Fs.default.mkdirSync(n,{recursive:!0}),i=sl(n,s||{})),i}async function pc(t,e){let{browser:s,startingUrl:r,preferences:i,userDataDir:n,browserConsole:o=!1,browserFlags:c=[]}=e,p=cc(s,n,i),l=[];r&&l.push(`--url "${r}"`),o&&l.push("--jsconsole"),c&&l.push(...c);let f=t.options.devServer?.port?t.options.devServer?.port+100:9222;return[`--binary-args "${c.join(" ")}"`,`--profile "${p.path()}"`,`--listen ${f}`,"--verbose"].join(" ")}var dc=a(require("path"));var lc=a(require("net")),uc=a(require("events"));function il(t,e){let s=e.toString(),r=s.indexOf(":");if(r<1)return{remainingData:e};let i=parseInt(s.substring(0,r),10);if(isNaN(i))return{remainingData:e,error:new Error(Ba(t)),fatal:!0};if(e.length-(r+1)<i)return{remainingData:e};let n=e.slice(r+1,r+1+i),o=e.slice(r+1+i);try{let c=JSON.parse(n.toString());return{remainingData:o,parsedMessage:c}}catch(c){return{remainingData:o,error:c,fatal:!1}}}var Ls=class extends uc.default{incomingData=Buffer.alloc(0);pendingRequests=[];activeRequests=new Map;connection;async connect(e){await new Promise((s,r)=>{try{let i={port:e,host:"127.0.0.1"},n=lc.default.createConnection(i,()=>{s()});this.connection=n,n.on("data",this.onData.bind(this)),n.on("error",r),n.on("end",this.onEnd.bind(this)),n.on("timeout",this.onTimeout.bind(this)),this.expectReply("root",{resolve:s,reject:r})}catch(i){r(i)}})}disconnect(){this.connection&&(this.connection.removeAllListeners(),this.connection.end(),this.rejectAllRequests(new Error(Ja("firefox"))))}rejectAllRequests(e){this.activeRequests.forEach(s=>{s.reject(e)}),this.activeRequests.clear(),this.pendingRequests.forEach(({deferred:s})=>{s.reject(e)}),this.pendingRequests=[]}async request(e){let s=typeof e=="string"?{to:"root",type:e}:e;if(!s.to)throw new Error(za("firefox",s.type));return await new Promise((r,i)=>{let n={resolve:r,reject:i};this.pendingRequests.push({request:s,deferred:n}),this.flushPendingRequests()})}flushPendingRequests(){this.pendingRequests=this.pendingRequests.filter(({request:e,deferred:s})=>{if(this.activeRequests.has(e.to))return!0;if(!this.connection)throw new Error(Ha("firefox"));try{let r=`${Buffer.from(JSON.stringify(e)).length}:${JSON.stringify(e)}`;this.connection.write(r),this.expectReply(e.to,s)}catch(r){s.reject(r)}return!1})}expectReply(e,s){if(this.activeRequests.has(e))throw new Error(Va("firefox",e));this.activeRequests.set(e,s)}onData(e){for(this.incomingData=Buffer.concat([this.incomingData,e]);this.readMessage(););}readMessage(){let{remainingData:e,parsedMessage:s,error:r,fatal:i}=il("firefox",this.incomingData);return this.incomingData=e,r?(this.emit("error",new Error(Ga("firefox",r))),i&&this.disconnect(),!i):s?(this.handleMessage(s),!0):!1}handleMessage(e){if(!e.from){this.emit("error",new Error(Xa("firefox",e)));return}let s=this.activeRequests.get(e.from);s?(this.activeRequests.delete(e.from),e.error?s.reject(e):s.resolve(e),this.flushPendingRequests()):this.emit("error",new Error(Za("firefox",JSON.stringify(e))))}onError(e){this.emit("error",e)}onEnd(){this.emit("end")}onTimeout(){this.emit("timeout")}};function fc(t){return t instanceof Error?String(t):`${t.error}: ${t.message}`}function mc(t,e){return Array.isArray(t)&&t.includes(e.code)?!0:e.code===t}var nl=150,ol=1e3,Is=class{options;constructor(e){this.options=e}async connectClient(e){let s;for(let r of Array.from({length:nl}))try{let i=new Ls;return await i.connect(e),i}catch(i){if(mc("ECONNREFUSED",i))await new Promise(n=>setTimeout(n,ol)),s=i;else throw console.error(Na(this.options.browser,i.stack)),i}throw console.error(qa(this.options.browser)),s}async installAddons(e){let{devtools:s}=this.options,r=Array.isArray(this.options.extension)?this.options.extension:[this.options.extension],i=e.options.devServer?.port,n=i?i+100:9222,o=await this.connectClient(n);for(let[c,p]of r.entries()){let l=dc.default.join(p.replace(/"/g,"")),f=c===0&&s;try{let d=await o.request({to:"root",type:"getRoot"});await o.request({to:d.addonsActor,type:"installTemporaryAddon",addonPath:l,openDevTools:f})}catch(d){let h=fc(d);throw new Error(Ua(this.options.browser,h))}}}};var ie=null;process.on("SIGINT",()=>{ie&&ie.kill("SIGINT"),process.exit()});process.on("SIGTERM",()=>{ie&&ie.kill("SIGTERM"),process.exit()});var Os=class{extension;browser;browserFlags;userDataDir;profile;preferences;startingUrl;autoReload;stats;constructor(e){this.extension=e.extension,this.browser=e.browser||"firefox",this.browserFlags=e.browserFlags||[],this.userDataDir=e.userDataDir,this.profile=e.profile,this.preferences=e.preferences,this.startingUrl=e.startingUrl}async launchFirefox(e){let s=`fx-runner start --binary "${Ds}" --foreground --no-remote`;gc.default.existsSync(Ds)||(console.error(ks(this.browser,Ds)),process.exit());let r=await pc(e,this),i=`${s} ${r}`;ie=(0,hc.exec)(i,(o,c,p)=>{if(o!=null)throw o;p.includes("Unable to move the cache")?console.log(Aa(this.browser)):(console.log(Ma(this.browser)),process.exit())}),process.env.EXTENSION_ENV==="development"&&(ie.stdout?.pipe(process.stdout),ie.stderr?.pipe(process.stderr));let n=new Is(this);try{await n.installAddons(e)}catch(o){o?.toString()?.includes("background.service_worker is currently disabled")&&(console.error(Ta(this.browser)),process.exit(1)),console.error(Ra(this.browser,o)),process.exit(1)}}apply(e){let s=!1;e.hooks.done.tapAsync("run-firefox:module",async(r,i)=>{if(r.compilation.errors.length>0){i();return}if(s){i();return}setTimeout(()=>{console.log(Ps(this.browser,r.compilation.options.mode))},2e3),await this.launchFirefox(e),s=!0,i()})}};var As=class{static name="plugin-browsers";extension;browser;browserFlags;userDataDir;profile;preferences;startingUrl;constructor(e){this.extension=[...e.extension,...e.browserFlags?.filter(s=>!s.startsWith("--load-extension="))||[]],this.browser=e.browser,this.browserFlags=e.browserFlags?.filter(s=>!s.startsWith("--load-extension="))||[],this.userDataDir=e.userDataDir,this.profile=e.profile||"",this.preferences=e.preferences||{},this.startingUrl=e.startingUrl||""}getProfilePath(e,s,r){return r||(e.options.mode==="production"?kr.default.join(yc.default.tmpdir(),"extension-js",s,"profile"):kr.default.resolve(__dirname,`run-${s}-profile`))}apply(e){let s={stats:!0,extension:this.extension,browser:this.browser,browserFlags:this.browserFlags||[],userDataDir:this.getProfilePath(e,this.browser,this.userDataDir||this.profile)};switch(this.browser){case"chrome":{new ve({...s,browser:"chrome"}).apply(e);break}case"edge":new ve({...s,browser:"edge"}).apply(e);break;case"firefox":new Os({...s,browser:"firefox"}).apply(e);break;default:{new ve({...s,browser:this.browser}).apply(e);break}}}};function B(t,e){let s=ze.default.join(t,"manifest.json"),r=ze.default.join(t,`dist/${e.browser}`),i=require(s);return{mode:e.mode||"development",entry:{},target:"web",context:t,devtool:i.manifest_version===3?"cheap-source-map":"eval-cheap-source-map",output:{clean:{keep(n){return!n.startsWith("hot/background")}},path:r,publicPath:"/",hotUpdateChunkFilename:"hot/[id].[fullhash].hot-update.js",hotUpdateMainFilename:"hot/[runtime].[fullhash].hot-update.json",environment:{bigIntLiteral:!0,dynamicImport:!0}},resolve:{modules:["node_modules",ze.default.join(t,"node_modules")],extensions:[".js",".mjs",".jsx",".ts",".mts",".tsx",".json",".wasm",".less",".css",".sass",".scss"]},watchOptions:{ignored:/node_modules|dist/},module:{rules:[]},plugins:[new et({manifestPath:s}),new lt({manifestPath:s,mode:e.mode}),new pt({manifestPath:s,mode:e.mode}),new gt({manifestPath:s,mode:e.mode}),process.env.EXTENSION_ENV==="development"&&new Ss({manifestPath:s,browser:e.browser}),new ws({manifestPath:s,browser:e.browser,polyfill:e.polyfill}),new ps({manifestPath:s,browser:e.browser,mode:e.mode}),new gs({manifestPath:s,browser:e.browser,stats:!0,port:e.port||8e3}),!e.noOpen&&new As({extension:[r,ze.default.join(__dirname,"extensions",`${e.browser}-manager-extension`)],browser:e.browser,startingUrl:e.startingUrl,profile:e.profile||e.userDataDir,preferences:e.preferences,browserFlags:e.browserFlags})].filter(Boolean),stats:{all:!1,errors:!0,warnings:!0},infrastructureLogging:{level:"none"},performance:{hints:!1,maxAssetSize:999e3,maxEntrypointSize:999e3},optimization:{minimize:e.mode==="production"},experiments:{asyncWebAssembly:!0}}}var oe=a(require("path")),Jc=a(require("go-git-it"));var He=a(require("path")),Ms=a(require("fs")),m=require("@colors/colors/safe");function j(t){return`${t==="warn"?(0,m.brightYellow)("\u25BA\u25BA\u25BA"):t==="info"?(0,m.magenta)("\u25BA\u25BA\u25BA"):t==="error"?(0,m.red)("\u2716\uFE0E\u2716\uFE0E\u2716\uFE0E"):(0,m.brightGreen)("\u25BA\u25BA\u25BA")}`}function K(){return`${j("error")} Manifest file not found. Ensure the path to your extension exists and try again.`}function Ts(t){let e=t==="firefox"?"Add-on":"Extension";return`${j("info")} Building ${ne(t)} ${e} package...`}function Rs(t,e){let s=He.default.join(t,"dist",e.browser||"chrome"),r=He.default.join(s,"manifest.json"),i=require(r),{name:n,version:o,hostPermissions:c,permissions:p}=i,l=bc(t,i).defaultLocale,f=bc(t,i).otherLocales.join(", "),d=`${l} ${f&&", "+f}`,h=c&&c.length,y=p&&p.length,$=qs().version;return`
142
- \u{1F9E9} ${(0,m.brightGreen)("Extension.js")} ${(0,m.gray)(`${$}`)}
143
- Extension Name ${(0,m.gray)(n)}
144
- Extension Version ${(0,m.gray)(o)}
131
+ Ensure the path to your extension exists and try again.
132
+ ${(0,m.red)("NOT FOUND")} ${(0,m.underline)(t)}`}function Dr(t){let e=t==="firefox"||t==="gecko-based"?"Add-on":"Extension";return`${P("info")} Building ${re(t)} ${e} package...`}function Fr(t,e){let r=Ke.default.join(t,"dist",e.browser||"chrome"),s=Ke.default.join(r,"manifest.json"),i=require(s),{name:o,version:n,hostPermissions:c,permissions:p}=i,l=bc(t,i).defaultLocale,u=bc(t,i).otherLocales.join(", "),d=`${l} ${u&&", "+u}`,g=c&&c.length,y=p&&p.length,_=qr().version;return`
133
+ \u{1F9E9} ${(0,m.brightGreen)("Extension.js")} ${(0,m.gray)(`${_}`)}
134
+ Extension Name ${(0,m.gray)(o)}
135
+ Extension Version ${(0,m.gray)(n)}
145
136
  Locales ${(0,m.gray)(d)}
146
- Host Permissions ${(0,m.gray)(h?c.join(", "):"Browser defaults")}
137
+ Host Permissions ${(0,m.gray)(g?c.join(", "):"Browser defaults")}
147
138
  Permissions ${(0,m.gray)(y?p.join(", "):"Browser defaults")}
148
- `}function wc(t,e){let s=t==="production"?m.magenta:m.magenta,r=e==="firefox"?"Add-on":"Extension";return`${j("success")} ${ne(e)} ${r} ready for ${s(t||"unknown")}.`}function xc(t,e,s){let r=e?.toJson(),i=He.default.join(t,"manifest.json"),n=JSON.parse(Ms.default.readFileSync(i,"utf8")),o=r?.assets,c=`${j("info")} Building ${(0,m.cyan)(n.name)} extension using ${ne(s)} defaults...
139
+ `}function wc(t,e){let r=t==="production"?m.brightBlue:m.brightBlue,s=e==="firefox"||e==="gecko-based"?"Add-on":"Extension";return`${P("success")} ${re(e)} ${s} ready for ${r(t||"unknown")}.`}function xc(t,e,r){let s=e?.toJson(),i=Ke.default.join(t,"manifest.json"),o=JSON.parse(jr.default.readFileSync(i,"utf8")),n=s?.assets,c=`${P("info")} Building ${(0,m.cyan)(o.name)} extension using ${re(r)} defaults...
149
140
 
150
141
  `,p=`
151
- Build completed in ${((r?.time||0)/1e3).toFixed(2)} seconds.
152
- `,l=`Build Target: ${(0,m.gray)(ne(s))}
153
- `,f=`Build Status: ${e?.hasErrors()?(0,m.red)("Failed"):(0,m.brightGreen)("Success")}
142
+ Build completed in ${((s?.time||0)/1e3).toFixed(2)} seconds.`,l=`Build Target: ${(0,m.gray)(re(r))}
143
+ `,u=`Build Status: ${e?.hasErrors()?(0,m.red)("Failed"):(0,m.brightGreen)("Success")}
154
144
  `,d=`
155
- Version: ${(0,m.gray)(n.version)}
156
- `,h=`Size: ${(0,m.gray)(al(o))}
157
- `,y="";return y+=c,y+=cl(o),y+=d,y+=h,y+=l,y+=f,y+=p,y}function vc(){return`${j("success")} No errors or warnings found. Your extension is ${(0,m.brightGreen)("ready for deployment")}.`}function _c(t,e){return`${j("success")} Fetching data...
158
-
159
- ${(0,m.gray)("URL")} ${(0,m.underline)(`https://github.com/${t}/${e}`)}`}function Sc(t){return`${j("success")} Downloading ${(0,m.cyan)(t)}...`}function Pc(t){return`
160
- ${j("success")} Creating a new browser extension...
161
-
162
- ${(0,m.gray)("PATH")} ${(0,m.underline)(`${process.cwd()}/${t}`)}`}function kc(t){return`${j("success")} No ${(0,m.brightYellow)(".gitignore")} found, zipping all the content inside path:
163
-
164
- ${(0,m.gray)("PATH")} ${(0,m.underline)(t)}`}function Ec(t){return`${j("success")} Packaging source files. Files in ${(0,m.brightYellow)(".gitignore")} will be excluded...
165
-
166
- ${(0,m.gray)("PATH")} ${(0,m.underline)(t)}.`}function jc(t){return`${j("success")} Packaging extension distribution files...
167
-
168
- ${(0,m.gray)("PATH")} ${(0,m.underline)(t)}`}function $c(t,e,s,r){return`\u{1F4E6} Package name: ${(0,m.brightYellow)(`${e}`)}, Target Browser: ${`${ne(t)}`}
169
- ${(0,m.gray)("\u2514\u2500")} ${(0,m.underline)(`${s}`)} (source)
170
- ${(0,m.gray)("\u2514\u2500")} ${(0,m.underline)(`${r}`)} (distribution)`}function Cc(t,e,s,r){return`\u{1F4E6} Package name: ${(0,m.brightYellow)(`${t}.${e}`)}, Target Browser: ${`${ne(s)}`}
171
- ${(0,m.gray)("\u2514\u2500")} ${(0,m.underline)(`${r}`)} (distribution)`}function Dc(t,e,s,r){return`\u{1F4E6} Package name: ${(0,m.brightYellow)(`${t}-source.${e}`)}, Target Browser: ${`${ne(s)}`}
172
- ${(0,m.gray)("\u2514\u2500")} ${(0,m.underline)(`${r}`)} (source)`}function Fc(t){return`${j("error")} Failed to compress extension package. ${t}`}function Lc(t){return`${j("info")} ${t.name} (v${t.version}) has no type definitions. Writing...`}function Ic(t){return`${j("error")} Failed to write the extension type definition. ${(0,m.red)(t)}`}function Oc(t){return`${j("success")} Downloading extension...
173
-
174
- ${(0,m.gray)("URL")} ${(0,m.underline)(t)}`}function Ac(t){return`${j("success")} Unpackaging browser extension...
175
-
176
- ${(0,m.gray)("PATH")} ${(0,m.underline)(t)}`}function Mc(){return`${j("success")} Browser extension unpackaged successfully. Compiling...`}function Tc(t){return`${j("error")} Failed to download or extract ZIP file. ${(0,m.red)(t)}`}function ne(t){return t.charAt(0).toUpperCase()+t.slice(1)}function bc(t,e){let s=e.default_locale,r=He.default.join(t,"_locales");if(!Ms.default.existsSync(r))return{defaultLocale:"Browser defaults",otherLocales:[]};let i=Ms.default.readdirSync(r).filter(n=>n!==s);return{defaultLocale:s,otherLocales:i}}function Rc(t){return`${(t/1024).toFixed(2)}KB`}function al(t){let e=0;return t?.forEach(s=>{e+=s.size}),Rc(e)}function Nc(t,e=""){let s="";return Object.keys(t).forEach((r,i,n)=>{let o=i===n.length-1,c=o?"\u2514\u2500":"\u251C\u2500",p=t[r].size?` (${Rc(t[r].size)})`:"";s+=`${(0,m.gray)(e)}${(0,m.gray)(c)} ${r}${(0,m.gray)(p)}
177
- `,typeof t[r]=="object"&&!t[r].size&&(s+=Nc(t[r],`${e}${o?" ":(0,m.gray)("\u2502 ")}`))}),s}function cl(t){let e={};return t?.forEach(s=>{let r=s.name.split("/"),i=e;r.forEach((n,o)=>{i[n]||(i[n]={}),o===r.length-1?i[n]={size:s.size}:i=i[n]})}),`.
178
- ${Nc(e)}`}function qc(t){return`${j("info")} is using ${(0,m.magenta)(t)}. ${(0,m.brightYellow)("This is very experimental")}.`}var Er=a(require("fs/promises")),jr=a(require("path")),Uc=a(require("axios")),Wc=a(require("adm-zip"));async function Bc(t,e){let s=t.split("?")[0];try{console.log(Oc(s));let r=await(0,Uc.default)({url:t,method:"GET",responseType:"arraybuffer"}),i=jr.default.basename(s),n=jr.default.join(e,`${i}.zip`);await Er.default.writeFile(n,r.data),console.log(Ac(n)),new Wc.default(n).extractAllTo(e,!0),await Er.default.unlink(n),console.log(Mc())}catch(r){throw console.error(Tc(r)),r}}var pl=t=>{try{return new URL(t),!0}catch{return!1}};async function ll(t,e){return await(0,Jc.default)(t,process.cwd(),e),oe.default.resolve(process.cwd(),oe.default.basename(t))}async function ul(t){return await Bc(t,process.cwd()),t=t.split("?")[0],oe.default.resolve(process.cwd(),oe.default.basename(t))}async function Q(t){if(!t)return process.cwd();if(pl(t)){let e=new URL(t);if(e.protocol.startsWith("http")){if(e.origin!=="https://github.com")return await ul(t);let s=e.pathname.split("/"),r=s.slice(1,3)[0],i=s.slice(1,3)[1];console.log(_c(r,i));let n=oe.default.basename(e.pathname),o=await ll(t,Sc(n));return console.log(Pc(n)),o}}return oe.default.resolve(process.cwd(),t)}var z=a(require("path")),zc=a(require("fs")),Hc=a(require("ignore")),Vc=a(require("tiny-glob")),$r=a(require("adm-zip")),Gc=a(require("slugify"));function fl(t){try{return zc.default.readFileSync(t,"utf8")}catch{return""}}function ml(t){return(0,Gc.default)(t,{replacement:"-",remove:/[^a-zA-Z0-9 ]/g,lower:!0})}function dl(t){switch(t){case"opera":return"crx";case"firefox":return"xpi";default:return"zip"}}function gl(t,e){let s=ml(e.zipFilename||t.name);return e.zipFilename?s:`${s}-${t.version}`}async function hl(t){let e=z.default.join(t,".gitignore"),s=fl(e),r=(0,Hc.default)();return s?r.add(s):console.log(kc(t)),(await(0,Vc.default)("**/*",{cwd:t,dot:!0})).filter(n=>!r.ignores(n))}async function Xc(t,{browser:e="chrome",...s}){try{let r=z.default.join(t,"dist"),i=z.default.join(r,e),n=s.zipSource?t:i,o=require(z.default.join(n,"manifest.json")),c=gl(o,s),p=dl(e),l=z.default.join(i,`${c}.${p}`),f=z.default.join(r,`${c}-source.${p}`);if(s.zipSource){console.log(""),console.log(Ec(e));let d=new $r.default;(await hl(t)).forEach(y=>{d.addLocalFile(z.default.join(t,y),z.default.dirname(y))}),d.writeZip(f)}if(s.zip){console.log(""),console.log(jc(l));let d=new $r.default;d.addLocalFolder(i),d.writeZip(l)}s.zip&&s.zipSource?(console.log(""),console.log($c(e,c,f,l))):s.zip?(console.log(""),console.log(Cc(c,p,e,l))):s.zipSource&&(console.log(""),console.log(Dc(c,p,e,f)))}catch(r){throw console.error(Fc(r)),r}}var Cr=a(require("fs")),Dr=a(require("path"));function ee(t){let e=Dr.default.join(t,"extension.config.js");if(Cr.default.existsSync(e)&&yl(t)){let s=require(e);if(s&&s!=null&&s&&typeof s.config=="function")return s.config}return s=>s}function yl(t){let e=Dr.default.join(t,"extension.config.js");return Cr.default.existsSync(e)?(console.log(qc("extension.config.js")),!0):!1}async function ep(t,e){let s=await Q(t);!t?.startsWith("http")&&!Zc.default.existsSync(Yc.default.join(s,"manifest.json"))&&(console.log(K()),process.exit(1));try{let r=e?.browser||"chrome",i=B(s,{...e,browser:r,mode:"production"}),n=i.plugins?.filter(f=>f?.constructor.name!=="plugin-browsers"&&f?.constructor.name!=="plugin-reload"),c=ee(s)({...i,plugins:n}),p=(0,Qc.merge)(c),l=(0,Kc.default)(p);await new Promise((f,d)=>{l.run(async(h,y)=>{if(h)return console.error(h.stack||h),d(h);console.log(xc(s,y,r)),(e?.zip||e?.zipSource)&&await Xc(s,{...e,browser:r}),y?.hasErrors()?(console.log(y.toString({colors:!0})),process.exit(1)):(console.log(vc()),f())})})}catch(r){process.env.EXTENSION_ENV==="development"&&console.error(r),process.exit(1)}}var op=a(require("fs")),ap=a(require("path"));var Lr=a(require("path")),tp=a(require("webpack")),sp=a(require("webpack-dev-server")),rp=require("webpack-merge");function Fr(t){t.stop().then(()=>{process.exit()}).catch(e=>{console.log(`Error in the Extension.js runner: ${e.stack||""}`)})}async function ip(t,{...e}){let s=B(t,{...e,mode:"development"}),i=ee(t)(s),n=(0,rp.merge)(i),o=(0,tp.default)(n),c={host:"127.0.0.1",allowedHosts:"all",static:Lr.default.join(t,"public"),compress:!1,devMiddleware:{writeToDisk:!0},watchFiles:st(t)?void 0:{paths:[Lr.default.join(t,"**/*.html")],options:{usePolling:!0,interval:1e3}},client:{logging:process.env.EXTENSION_ENV==="development"?"error":"none",progress:!1,overlay:!1},headers:{"Access-Control-Allow-Origin":"*"},port:"auto",hot:"only"},p=new sp.default(c,o);p.startCallback(l=>{l!=null&&console.log(`Error in the Extension.js runner: ${l.stack||""}`)}),process.on("ERROR",()=>{Fr(p)}),process.on("SIGINT",()=>{Fr(p)}),process.on("SIGTERM",()=>{Fr(p)})}var Ns=a(require("path")),Ve=a(require("fs/promises"));async function np(t){let e=Ns.default.join(t,"extension-env.d.ts"),s=process.env.EXTENSION_ENV==="development"?Ns.default.resolve(process.cwd(),"programs/cli/types"):"extension/dist/types",r=`// Required Extension.js types for TypeScript projects.
145
+ Version: ${(0,m.gray)(o.version)}
146
+ `,g=`Size: ${(0,m.gray)(wl(n))}
147
+ `,y="";return y+=c,y+=xl(n),y+=d,y+=g,y+=l,y+=u,y+=p,y}function vc(){return`${P("success")} No errors or warnings found. Your extension is ${(0,m.brightGreen)("ready for deployment")}.`}function _c(t,e){return`${P("info")} Fetching data...
148
+ ${(0,m.gray)("URL")} ${(0,m.underline)(`https://github.com/${t}/${e}`)}`}function Sc(t){return`${P("info")} Downloading ${(0,m.cyan)(t)}...`}function Pc(t){return`
149
+ ${P("info")} Creating a new browser extension...
150
+ ${(0,m.gray)("PATH")} ${(0,m.underline)(`${t}`)}`}function kc(t){return`${P("info")} No ${(0,m.brightYellow)(".gitignore")} found, zipping all the content inside path:
151
+ ${(0,m.gray)("PATH")} ${(0,m.underline)(t)}`}function Ec(t){return`${P("info")} Packaging source files. Files in ${(0,m.brightYellow)(".gitignore")} will be excluded...
152
+ ${(0,m.gray)("PATH")} ${(0,m.underline)(t)}.`}function $c(t){return`${P("info")} Packaging extension distribution files...
153
+ ${(0,m.gray)("PATH")} ${(0,m.underline)(t)}`}function Cc(t,e,r,s){return`\u{1F4E6} Package name: ${(0,m.brightYellow)(`${e}`)}, Target Browser: ${`${re(t)}`}
154
+ ${(0,m.gray)("\u2514\u2500")} ${(0,m.underline)(`${r}`)} (source)
155
+ ${(0,m.gray)("\u2514\u2500")} ${(0,m.underline)(`${s}`)} (distribution)`}function jc(t,e,r,s){return`\u{1F4E6} Package name: ${(0,m.brightYellow)(`${t}.${e}`)}, Target Browser: ${`${re(r)}`}
156
+ ${(0,m.gray)("\u2514\u2500")} ${(0,m.underline)(`${s}`)} ${(0,m.gray)("(distribution)")}`}function Dc(t,e,r,s){return`\u{1F4E6} Package name: ${(0,m.brightYellow)(`${t}-source.${e}`)}, Target Browser: ${`${re(r)}`}
157
+ ${(0,m.gray)("\u2514\u2500")} ${(0,m.underline)(`${s}`)} (source)`}function Fc(t){return`${P("error")} Failed to compress extension package.
158
+ ${(0,m.red)(t)}`}function Lc(t){return`${P("info")} Writing type definitions for ${(0,m.cyan)(t.name||"")}...`}function Ic(t){return`${P("error")} Failed to write the extension type definition.
159
+ ${(0,m.red)(t)}`}function Oc(t){return`${P("info")} Downloading extension...
160
+ ${(0,m.gray)("URL")} ${(0,m.underline)(t)}`}function Mc(t){return`${P("info")} Unpackaging browser extension...
161
+ ${(0,m.gray)("PATH")} ${(0,m.underline)(t)}`}function Ac(){return`${P("info")} Browser extension unpackaged ${(0,m.brightGreen)("successfully")}. Compiling...`}function Rc(t){return`${P("error")} Failed to download or extract ZIP file. ${(0,m.red)(t)}`}function re(t){return t.charAt(0).toUpperCase()+t.slice(1)}function bc(t,e){let r=e.default_locale,s=Ke.default.join(t,"_locales");if(!jr.default.existsSync(s))return{defaultLocale:"Browser defaults",otherLocales:[]};let i=jr.default.readdirSync(s).filter(o=>o!==r);return{defaultLocale:r,otherLocales:i}}function Tc(t){return`${(t/1024).toFixed(2)}KB`}function wl(t){let e=0;return t?.forEach(r=>{e+=r.size}),Tc(e)}function Nc(t,e=""){let r="";return Object.keys(t).forEach((s,i,o)=>{let n=i===o.length-1,c=n?"\u2514\u2500":"\u251C\u2500",p=t[s].size?` (${Tc(t[s].size)})`:"";r+=`${(0,m.gray)(e)}${(0,m.gray)(c)} ${s}${(0,m.gray)(p)}
162
+ `,typeof t[s]=="object"&&!t[s].size&&(r+=Nc(t[s],`${e}${n?" ":(0,m.gray)("\u2502 ")}`))}),r}function xl(t){let e={};return t?.forEach(r=>{let s=r.name.split("/"),i=e;s.forEach((o,n)=>{i[o]||(i[o]={}),n===s.length-1?i[o]={size:r.size}:i=i[o]})}),`.
163
+ ${Nc(e)}`}function Uc(t){return`${P("info")} Using ${(0,m.magenta)(t)}. ${(0,m.brightYellow)("This is very experimental")}.`}function qc(){return`${P("info")} Installing project dependencies...`}function Wc(t,e,r){return`${P("error")} Command ${t} ${e.join(" ")} failed with exit code ${r}`}function Bc(t){return`${P("error")} Can't install project dependencies. ${(0,m.red)(t.message||t.toString())}`}function K(t){let e=Qe.default.join(t,"extension.config.js");if(Ye.default.existsSync(e)&&Ds(t)){let r=require(e);if(r&&r!=null&&r&&typeof r.config=="function")return r.config}return r=>r}function Jc(t,e){let r=Qe.default.join(t,"extension.config.js");if(Ye.default.existsSync(r)&&Ds(t)){let s=require(r);if(s&&s!=null)return s[e]}return{}}function Lr(t,e){let r=Qe.default.join(t,"extension.config.js");if(Ye.default.existsSync(r)&&Ds(t)){let s=require(r);if(s&&s.browsers!=null)return s.browsers[e]}return{}}var zc=!1;function Ds(t){let e=Qe.default.join(t,"extension.config.js");return Ye.default.existsSync(e)?(zc||(console.log(Uc("extension.config.js")),zc=!0),!0):!1}function Hc(t,e){let r={...Lr(Fs.default.resolve(__dirname,"run-firefox"),"firefox"),...js(e)};Object.keys(r).forEach(o=>{t.setPreference(o,r[o])});let i=Object.keys(e);return i.length>0&&i.forEach(o=>{t.setPreference(o,e[o])}),t.updatePreferences(),t}function vl(t,e){let r=new Ls.default({destinationDirectory:t});return Hc(r,e)}function _l(t,e,r){let s;if(Ir.default.statSync(e).isDirectory())s=e;else throw new Error(Qa(t,e));let o=new Ls.default({destinationDirectory:s});return Hc(o,r)}function Vc(t,e,r){let s,i=e||Fs.default.resolve(__dirname,"run-firefox-data-dir"),c={...js(r||{}),...r};return Ir.default.existsSync(i)?s=_l(t,i,c):($r(kr(t),()=>{}),Ir.default.mkdirSync(i,{recursive:!0}),s=vl(i,c)),s}async function Gc(t,e){let{browser:r,startingUrl:s,preferences:i,userDataDir:o,browserFlags:n=[]}=e,c=Vc(r,o,i),p=[];s&&p.push(`--url=${s}`),n&&p.push(...n);let l=t.options.devServer?.port?t.options.devServer?.port+100:9222;return[`--binary-args="${p.join(" ")}"`,`--profile="${c.path()}"`,`--listen=${l}`,"--verbose"].join(" ")}var Qc=a(require("path"));var Xc=a(require("net")),Zc=a(require("events"));function Sl(t,e){let r=e.toString(),s=r.indexOf(":");if(s<1)return{remainingData:e};let i=parseInt(r.substring(0,s),10);if(isNaN(i))return{remainingData:e,error:new Error(ec(t)),fatal:!0};if(e.length-(s+1)<i)return{remainingData:e};let o=e.slice(s+1,s+1+i),n=e.slice(s+1+i);try{let c=JSON.parse(o.toString());return{remainingData:n,parsedMessage:c}}catch(c){return{remainingData:n,error:c,fatal:!1}}}var Or=class extends Zc.default{incomingData=Buffer.alloc(0);pendingRequests=[];activeRequests=new Map;connection;async connect(e){await new Promise((r,s)=>{try{let i={port:e,host:"127.0.0.1"},o=Xc.default.createConnection(i,()=>{r()});this.connection=o,o.on("data",this.onData.bind(this)),o.on("error",s),o.on("end",this.onEnd.bind(this)),o.on("timeout",this.onTimeout.bind(this)),this.expectReply("root",{resolve:r,reject:s})}catch(i){s(i)}})}disconnect(){this.connection&&(this.connection.removeAllListeners(),this.connection.end(),this.rejectAllRequests(new Error(tc("firefox"))))}rejectAllRequests(e){this.activeRequests.forEach(r=>{r.reject(e)}),this.activeRequests.clear(),this.pendingRequests.forEach(({deferred:r})=>{r.reject(e)}),this.pendingRequests=[]}async request(e){let r=typeof e=="string"?{to:"root",type:e}:e;if(!r.to)throw new Error(rc("firefox",r.type));return await new Promise((s,i)=>{let o={resolve:s,reject:i};this.pendingRequests.push({request:r,deferred:o}),this.flushPendingRequests()})}flushPendingRequests(){this.pendingRequests=this.pendingRequests.filter(({request:e,deferred:r})=>{if(this.activeRequests.has(e.to))return!0;if(!this.connection)throw new Error(sc("firefox"));try{let s=`${Buffer.from(JSON.stringify(e)).length}:${JSON.stringify(e)}`;this.connection.write(s),this.expectReply(e.to,r)}catch(s){r.reject(s)}return!1})}expectReply(e,r){if(this.activeRequests.has(e))throw new Error(ic("firefox",e));this.activeRequests.set(e,r)}onData(e){for(this.incomingData=Buffer.concat([this.incomingData,e]);this.readMessage(););}readMessage(){let{remainingData:e,parsedMessage:r,error:s,fatal:i}=Sl("firefox",this.incomingData);return this.incomingData=e,s?(this.emit("error",new Error(oc("firefox",s))),i&&this.disconnect(),!i):r?(this.handleMessage(r),!0):!1}handleMessage(e){if(!e.from){this.emit("error",new Error(nc("firefox",e)));return}let r=this.activeRequests.get(e.from);r?(this.activeRequests.delete(e.from),e.error?r.reject(e):r.resolve(e),this.flushPendingRequests()):this.emit("error",new Error(ac("firefox",JSON.stringify(e))))}onError(e){this.emit("error",e)}onEnd(){this.emit("end")}onTimeout(){this.emit("timeout")}};function Kc(t){return t instanceof Error?String(t):`${t.error}: ${t.message}`}function Yc(t,e){return Array.isArray(t)&&t.includes(e.code)?!0:e.code===t}var Pl=150,kl=1e3,Mr=class{options;constructor(e){this.options=e}async connectClient(e){let r;for(let s of Array.from({length:Pl}))try{let i=new Or;return await i.connect(e),i}catch(i){if(Yc("ECONNREFUSED",i))await new Promise(o=>setTimeout(o,kl)),r=i;else throw console.error(Za(this.options.browser,i.stack)),i}throw console.error(Ka(this.options.browser)),r}async installAddons(e){let{devtools:r}=this.options,s=Array.isArray(this.options.extension)?this.options.extension:[this.options.extension],i=e.options.devServer?.port,o=i?i+100:9222,n=await this.connectClient(o);for(let[c,p]of s.entries()){let l=Qc.default.join(p.replace(/"/g,"")),u=c===0&&r;try{let d=await n.request({to:"root",type:"getRoot"});await n.request({to:d.addonsActor,type:"installTemporaryAddon",addonPath:l,openDevTools:u})}catch(d){let g=Kc(d);throw new Error(Ya(this.options.browser,g))}}}};var se=null;process.on("SIGINT",()=>{se&&se.kill("SIGINT"),process.exit()});process.on("SIGTERM",()=>{se&&se.kill("SIGTERM"),process.exit()});var Ar=class{extension;browser;browserFlags;userDataDir;profile;preferences;startingUrl;autoReload;stats;geckoBinary;constructor(e){this.extension=e.extension,this.browser=e.browser||"firefox",this.browserFlags=e.browserFlags||[],this.userDataDir=e.userDataDir,this.profile=e.profile,this.preferences=e.preferences,this.startingUrl=e.startingUrl,this.geckoBinary=e.geckoBinary}async getFxRunnerCommand(){let e=ae()?"pnpm dlx fx-runner":"npm exec fx-runner";try{return await new Promise((r,s)=>{(0,Is.exec)(`${e} --version`,i=>{i?s(i):r(null)})}),e}catch{console.error(Ve("firefox",e)),process.exit(1)}}async launchFirefox(e,r){let s=await this.getFxRunnerCommand(),i;switch(r.browser){case"gecko-based":i=tp.default.normalize(this.geckoBinary);break;default:i=yc;break}let o=`${s} start --binary "${i}" --foreground --no-remote`;ep.default.existsSync(i||"")||(console.error(Ve(this.browser,i||"")),process.exit(1));let n=await Gc(e,r),c=`${o} ${n}`;se=(0,Is.exec)(c,(l,u,d)=>{if(l!=null)throw l;d.includes("Unable to move the cache")?console.log(Ha(this.browser)):(console.log(Va(this.browser)),process.exit())}),process.env.EXTENSION_ENV==="development"&&(se.stdout?.pipe(process.stdout),se.stderr?.pipe(process.stderr));let p=new Mr(this);try{await p.installAddons(e)}catch(l){l?.toString()?.includes("background.service_worker is currently disabled")&&(console.error(Ga(this.browser)),process.exit(1)),console.error(Xa(this.browser,l)),process.exit(1)}}apply(e){let r=!1;e.hooks.done.tapAsync("run-firefox:module",async(s,i)=>{if(s.compilation.errors.length>0){i();return}if(r){i();return}setTimeout(()=>{console.log(Er(this.browser,s.compilation.options.mode))},2e3),await this.launchFirefox(e,{browser:this.browser,browserFlags:this.browserFlags,userDataDir:this.userDataDir,profile:this.profile,preferences:this.preferences,startingUrl:this.startingUrl,mode:s.compilation.options.mode}),r=!0,i()})}};var Rr=class{static name="plugin-browsers";extension;browser;browserFlags;userDataDir;profile;preferences;startingUrl;chromiumBinary;geckoBinary;constructor(e){this.extension=[...e.extension,...e.browserFlags?.filter(r=>!r.startsWith("--load-extension="))||[]],this.browser=e.browser||"chrome",this.browserFlags=e.browserFlags?.filter(r=>!r.startsWith("--load-extension="))||[],this.userDataDir=e.userDataDir,this.profile=e.profile||"",this.preferences=e.preferences||{},this.startingUrl=e.startingUrl||"",this.chromiumBinary=e.chromiumBinary,this.geckoBinary=e.geckoBinary}getProfilePath(e,r,s){return s||(e.options.mode==="production"?Os.default.join(rp.default.tmpdir(),"extension-js",r,"profile"):Os.default.resolve(__dirname,`run-${r}-profile`))}apply(e){let s={...{stats:!0,extension:this.extension,browser:this.browser,browserFlags:this.browserFlags||[],userDataDir:this.getProfilePath(e,this.browser,this.userDataDir||this.profile),startingUrl:this.startingUrl,chromiumBinary:this.chromiumBinary,geckoBinary:this.geckoBinary},...Lr(e.context,this.browser)};switch(this.browser){case"chrome":case"edge":case"chromium-based":{new Xe(s).apply(e);break}case"firefox":case"gecko-based":new Ar(s).apply(e);break;default:{new Xe({...s,browser:"chrome"}).apply(e);break}}}};function J(t,e){let r=et.default.join(t,"manifest.json"),s=O(require(r),e.browser),i=et.default.join(t,`dist/${e.browser}`),o=e.chromiumBinary?"chromium-based":e.geckoBinary?"gecko-based":e.browser;return{mode:e.mode||"development",entry:{},target:"web",context:t,devtool:s.manifest_version===3?"cheap-source-map":"eval-cheap-source-map",output:{clean:{keep(n){return!n.startsWith("hot/background")}},path:i,publicPath:"/",hotUpdateChunkFilename:"hot/[id].[fullhash].hot-update.js",hotUpdateMainFilename:"hot/[runtime].[fullhash].hot-update.json",environment:{bigIntLiteral:!0,dynamicImport:!0}},resolve:{modules:["node_modules",et.default.join(t,"node_modules")],extensions:[".js",".mjs",".jsx",".ts",".mts",".tsx",".json",".wasm",".less",".css",".sass",".scss"]},watchOptions:{ignored:/node_modules|dist/},module:{rules:[]},plugins:[new pt({manifestPath:r,browser:o}),new ht({manifestPath:r}),new gt({manifestPath:r}),new wt({manifestPath:r}),process.env.EXPERIMENTAL_ERRORS_PLUGIN==="true"&&new Pr({manifestPath:r,browser:o}),new xr({manifestPath:r,browser:o,polyfill:e.polyfill}),new fr({manifestPath:r,browser:o}),new hr({manifestPath:r,browser:o,stats:!0,port:e.port||8e3}),!e.noOpen&&new Rr({extension:[i,et.default.join(__dirname,"extensions",`${o}-manager-extension`)],browser:o,startingUrl:e.startingUrl,profile:e.profile||e.userDataDir,preferences:e.preferences,browserFlags:e.browserFlags,chromiumBinary:e.chromiumBinary,geckoBinary:e.geckoBinary})].filter(Boolean),stats:{all:!1,errors:!0,warnings:!0},infrastructureLogging:{level:"none"},performance:{hints:!1,maxAssetSize:999e3,maxEntrypointSize:999e3},optimization:{minimize:e.mode==="production"},experiments:{asyncWebAssembly:!0}}}var tt=a(require("path")),ap=a(require("go-git-it"));var Tr=a(require("path")),sp=a(require("axios")),ip=a(require("adm-zip"));var Ms=a(require("stream")),op=require("util"),El=(0,op.promisify)(Ms.default.pipeline);async function np(t,e){let r=t.split("?")[0];try{console.log(Oc(r));let s=await(0,sp.default)({url:t,method:"GET",responseType:"stream"}),i=Tr.default.extname(r),o=Tr.default.basename(r,i),n=Tr.default.join(e,o);console.log(Mc(n));let c=[];await El(s.data,new Ms.default.Writable({write(u,d,g){c.push(u),g()}}));let p=Buffer.concat(c);return new ip.default(p).extractAllTo(n,!0),console.log(Ac()),n}catch(s){throw console.error(Rc(s)),s}}var $l=t=>{try{return new URL(t),!0}catch{return!1}};async function Cl(t,e){return await(0,ap.default)(t,process.cwd(),e),tt.default.resolve(process.cwd(),tt.default.basename(t))}async function jl(t){return await np(t,process.cwd())}async function Y(t){if(!t)return process.cwd();if($l(t)){let e=new URL(t);if(e.protocol.startsWith("http")){if(e.origin!=="https://github.com")return await jl(t);let r=e.pathname.split("/"),s=r.slice(1,3)[0],i=r.slice(1,3)[1];console.log(_c(s,i));let o=tt.default.basename(e.pathname),n=await Cl(t,Sc(o));return console.log(Pc(o)),n}}return tt.default.resolve(process.cwd(),t)}var H=a(require("path")),cp=a(require("fs")),pp=a(require("ignore")),lp=a(require("tiny-glob")),As=a(require("adm-zip")),fp=a(require("slugify"));function Dl(t){try{return cp.default.readFileSync(t,"utf8")}catch{return""}}function Fl(t){return(0,fp.default)(t,{replacement:"-",remove:/[^a-zA-Z0-9 ]/g,lower:!0})}function Ll(t){switch(t){case"opera":return"crx";case"firefox":return"xpi";default:return"zip"}}function Il(t,e){let r=Fl(e.zipFilename||t.name);return e.zipFilename?r:`${r}-${t.version}`}async function Ol(t){let e=H.default.join(t,".gitignore"),r=Dl(e),s=(0,pp.default)();return r?s.add(r):console.log(kc(t)),(await(0,lp.default)("**/*",{cwd:t,dot:!0})).filter(o=>!s.ignores(o))}async function up(t,{browser:e="chrome",...r}){try{let s=H.default.join(t,"dist"),i=H.default.join(s,e),o=r.zipSource?t:i,n=require(H.default.join(o,"manifest.json")),c=Il(n,r),p=Ll(e),l=H.default.join(i,`${c}.${p}`),u=H.default.join(s,`${c}-source.${p}`);if(r.zipSource){console.log(""),console.log(Ec(u));let d=new As.default;(await Ol(t)).forEach(y=>{d.addLocalFile(H.default.join(t,y),H.default.dirname(y))}),d.writeZip(u)}if(r.zip){console.log(""),console.log($c(l));let d=new As.default;d.addLocalFolder(i),d.writeZip(l)}r.zip&&r.zipSource?(console.log(""),console.log(Cc(e,c,u,l))):r.zip?(console.log(""),console.log(jc(c,p,e,l))):r.zipSource&&(console.log(""),console.log(Dc(c,p,e,u)))}catch(s){throw console.error(Fc(s)),s}}async function hp(t,e){let r=await Y(t);!t?.startsWith("http")&&!mp.default.existsSync(Rs.default.join(r,"manifest.json"))&&(console.log(Z(Rs.default.join(r,"manifest.json"))),process.exit(1));try{let s=e?.browser||"chrome",i=J(r,{...e,browser:s,mode:"production"}),o=i.plugins?.filter(u=>u?.constructor.name!=="plugin-browsers"&&u?.constructor.name!=="plugin-reload"),c=K(r)({...i,plugins:o}),p=(0,gp.merge)(c),l=(0,dp.default)(p);await new Promise((u,d)=>{l.run(async(g,y)=>{if(g)return console.error(g.stack||g),d(g);console.log(xc(r,y,s)),(e?.zip||e?.zipSource)&&await up(r,{...e,browser:s}),y?.hasErrors()?(console.log(y.toString({colors:!0})),process.exit(1)):(console.log(vc()),u())})})}catch(s){process.env.EXTENSION_ENV==="development"&&console.error(s),process.exit(1)}}var Us=a(require("fs")),Ur=a(require("path"));var Ns=a(require("path")),yp=a(require("webpack")),bp=a(require("webpack-dev-server")),wp=require("webpack-merge");function Ts(t){t.stop().then(()=>{process.exit()}).catch(e=>{console.log(`Error in the Extension.js runner: ${e.stack||""}`)})}async function xp(t,{...e}){let r=Jc(t,"dev"),s=J(t,{...e,...r,mode:"development"}),o=K(t)(s),n=(0,wp.merge)(o),c=(0,yp.default)(n),p={host:"127.0.0.1",allowedHosts:"all",static:Ns.default.join(t,"public"),compress:!1,devMiddleware:{writeToDisk:!0},watchFiles:ft(t)?void 0:{paths:[Ns.default.join(t,"**/*.html")],options:{usePolling:!0,interval:1e3}},client:{logging:process.env.EXTENSION_ENV==="development"?"error":"none",progress:!1,overlay:!1},headers:{"Access-Control-Allow-Origin":"*"},port:"auto",hot:"only"},l=new bp.default(p,c);l.startCallback(u=>{u!=null&&console.log(`Error in the Extension.js runner: ${u.stack||""}`)}),process.on("ERROR",()=>{Ts(l)}),process.on("SIGINT",()=>{Ts(l)}),process.on("SIGTERM",()=>{Ts(l)})}var Nr=a(require("path")),be=a(require("fs/promises"));async function vp(t){let e=Nr.default.join(t,"extension-env.d.ts"),r=process.env.EXTENSION_ENV==="development"?Nr.default.resolve(process.cwd(),"programs/cli/types"):"extension/dist/types",s=`// Required Extension.js types for TypeScript projects.
179
164
  // This file is auto-generated and should not be excluded.
180
165
  // If you need additional types, consider creating a new *.d.ts file and
181
166
  // referencing it in the "include" array of your tsconfig.json file.
182
167
  // See https://www.typescriptlang.org/tsconfig#include for more information.
183
- /// <reference types="${s}/index.d.ts" />
168
+ /// <reference types="${r}/index.d.ts" />
184
169
 
185
170
  // Polyfill types for browser.* APIs.
186
- /// <reference types="${s}/polyfill.d.ts" />
187
- `;try{await Ve.default.access(e),(await Ve.default.readFile(e,"utf8")).includes("develop/dist/types")&&await Ve.default.writeFile(e,r)}catch{let n=require(Ns.default.join(t,"manifest.json"));console.log(Lc(n));try{await Ve.default.writeFile(e,r)}catch(o){console.log(Ic(o))}}}async function cp(t,e){let s=await Q(t);!t?.startsWith("http")&&!op.default.existsSync(ap.default.join(s,"manifest.json"))&&(console.log(K()),process.exit(1));try{R(s)&&await np(s),await ip(s,{...e,mode:"development",browser:e.browser||"chrome"})}catch(r){process.env.EXTENSION_ENV==="development"&&console.error(r),process.exit(1)}}var pp=a(require("fs")),lp=a(require("path")),up=a(require("webpack")),fp=require("webpack-merge");async function mp(t,e){let s=await Q(t);!t?.startsWith("http")&&!pp.default.existsSync(lp.default.join(s,"manifest.json"))&&(console.log(K()),process.exit(1));try{let r=e.browser||"chrome",i=B(s,{...e,browser:r,mode:"production"}),n=i.plugins?.filter(f=>f?.constructor.name==="plugin-browsers");console.log(Ts(r));let c=ee(s)({...i,plugins:n}),p=(0,fp.merge)(c);(0,up.default)(p).run(async(f,d)=>{f&&(console.error(f.stack||f),process.exit(1)),d?.hasErrors()?(console.log(d.toString({colors:!0})),process.exit(1)):console.log(Rs(s,{browser:r,mode:"production"}))})}catch(r){process.env.EXTENSION_ENV==="development"&&console.error(r),process.exit(1)}}var dp=a(require("fs")),gp=a(require("path")),hp=a(require("webpack")),yp=require("webpack-merge");async function bp(t,e){let s=await Q(t);!t?.startsWith("http")&&!dp.default.existsSync(gp.default.join(s,"manifest.json"))&&(console.log(K()),process.exit(1));try{let r=e.browser||"chrome",i=B(s,{...e,browser:r,mode:"production"}),n=i.plugins?.filter(f=>f?.constructor.name!=="plugin-reload");console.log(Ts(r));let c=ee(s)({...i,plugins:n}),p=(0,yp.merge)(c);(0,hp.default)(p).run((f,d)=>{f&&(console.error(f.stack||f),process.exit(1)),d?.hasErrors()?(console.log(d.toString({colors:!0})),process.exit(1)):(console.log(Rs(s,e)),setTimeout(()=>{console.log(wc("production",r))},1500))})}catch(r){process.env.EXTENSION_ENV==="development"&&console.error(r),process.exit(1)}}0&&(module.exports={extensionBuild,extensionDev,extensionPreview,extensionStart});
171
+ /// <reference types="${r}/polyfill.d.ts" />
172
+ `;try{await be.default.access(e),(await be.default.readFile(e,"utf8")).includes("develop/dist/types")&&await be.default.writeFile(e,s),process.env.EXTENSION_ENV==="development"&&await be.default.writeFile(e,s)}catch{let o=require(Nr.default.join(t,"manifest.json"));console.log(Lc(o));try{await be.default.writeFile(e,s)}catch(n){console.log(Ic(n))}}}var _p=a(require("path")),Sp=require("cross-spawn"),Pp=a(require("fs")),kp=require("package-manager-detector");async function Ml(){let t=await(0,kp.detect)(),e="npm";if(ae())return"pnpm";switch(t?.name){case"yarn":e="yarn";break;case"pnpm":e="pnpm";break;default:e="npm"}return e}function Al(){return["install"]}async function Ep(t){let e=_p.default.join(t,"node_modules"),r=await Ml(),s=Al(),i=process.cwd();try{process.chdir(t),await Pp.default.promises.mkdir(e,{recursive:!0});let o=process.env.EXTENSION_ENV==="development"?"inherit":"ignore",n=(0,Sp.spawn)(r,s,{stdio:o});await new Promise((c,p)=>{n.on("close",l=>{l!==0?p(new Error(Wc(r,s,l))):c()}),n.on("error",l=>{p(l)})})}catch(o){console.error(Bc(o)),process.exit(1)}finally{process.chdir(i)}}async function $p(t,e){let r=await Y(t),s=Ur.default.join(r,"manifest.json");!t?.startsWith("http")&&!Us.default.existsSync(s)&&(console.log(Z(Ur.default.join(r,"manifest.json"))),process.exit(1));try{V(r)&&await vp(r);let i=Ur.default.join(r,"node_modules");Us.default.existsSync(i)||(console.log(qc()),await Ep(r)),setTimeout(async()=>{await xp(r,{...e,mode:"development",browser:e.browser||"chrome"})},50)}catch(i){process.env.EXTENSION_ENV==="development"&&console.error(i),process.exit(1)}}var Cp=a(require("fs")),qs=a(require("path")),jp=a(require("webpack")),Dp=require("webpack-merge");async function Fp(t,e){let r=await Y(t);!t?.startsWith("http")&&!Cp.default.existsSync(qs.default.join(r,"manifest.json"))&&(console.log(Z(qs.default.join(r,"manifest.json"))),process.exit(1));try{let s=e.browser||"chrome",i=J(r,{...e,browser:s,mode:"production"}),o=i.plugins?.filter(u=>u?.constructor.name==="plugin-browsers");console.log(Dr(s));let c=K(r)({...i,plugins:o}),p=(0,Dp.merge)(c);(0,jp.default)(p).run(async(u,d)=>{u&&(console.error(u.stack||u),process.exit(1)),d?.hasErrors()?(console.log(d.toString({colors:!0})),process.exit(1)):console.log(Fr(r,{browser:s,mode:"production"}))})}catch(s){process.env.EXTENSION_ENV==="development"&&console.error(s),process.exit(1)}}var Lp=a(require("fs")),Ws=a(require("path")),Ip=a(require("webpack")),Op=require("webpack-merge");async function Mp(t,e){let r=await Y(t);!t?.startsWith("http")&&!Lp.default.existsSync(Ws.default.join(r,"manifest.json"))&&(console.log(Z(Ws.default.join(r,"manifest.json"))),process.exit(1));try{let s=e.browser||"chrome",i=J(r,{...e,browser:s,mode:"production"}),o=i.plugins?.filter(u=>u?.constructor.name!=="plugin-reload");console.log(Dr(s));let c=K(r)({...i,plugins:o}),p=(0,Op.merge)(c);(0,Ip.default)(p).run((u,d)=>{u&&(console.error(u.stack||u),process.exit(1)),d?.hasErrors()?(console.log(d.toString({colors:!0})),process.exit(1)):(console.log(Fr(r,e)),setTimeout(()=>{console.log(wc("production",s))},1500))})}catch(s){process.env.EXTENSION_ENV==="development"&&console.error(s),process.exit(1)}}0&&(module.exports={extensionBuild,extensionDev,extensionPreview,extensionStart});