extension-develop 2.0.0-alpha.28 → 2.0.0-alpha.29

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 (26) hide show
  1. package/dist/ensure-hmr-for-scripts.js +1 -1
  2. package/dist/extensions/gecko-based-manager-extension/background.js +57 -0
  3. package/dist/extensions/gecko-based-manager-extension/define-initial-tab.js +62 -0
  4. package/dist/extensions/gecko-based-manager-extension/manifest.json +16 -0
  5. package/dist/extensions/gecko-based-manager-extension/pages/sakura-dark.css +268 -0
  6. package/dist/extensions/gecko-based-manager-extension/pages/sakura.css +267 -0
  7. package/dist/extensions/gecko-based-manager-extension/pages/welcome.html +49 -0
  8. package/dist/extensions/gecko-based-manager-extension/pages/welcome.js +34 -0
  9. package/dist/extensions/gecko-based-manager-extension/public/logo.png +0 -0
  10. package/dist/extensions/gecko-based-manager-extension/reload-service.js +130 -0
  11. package/dist/inject-content-css-during-dev.js +2 -2
  12. package/dist/module.d.ts +14 -12
  13. package/dist/module.js +69 -69
  14. package/dist/resolver-loader.js +1 -1
  15. package/dist/resolver-module.mjs +1 -0
  16. package/package.json +3 -2
  17. package/dist/resolver-module.js +0 -1
  18. /package/dist/extensions/{chromium-manager-extension → chromium-based-manager-extension}/background.js +0 -0
  19. /package/dist/extensions/{chromium-manager-extension → chromium-based-manager-extension}/define-initial-tab.js +0 -0
  20. /package/dist/extensions/{chromium-manager-extension → chromium-based-manager-extension}/manifest.json +0 -0
  21. /package/dist/extensions/{chromium-manager-extension → chromium-based-manager-extension}/pages/sakura-dark.css +0 -0
  22. /package/dist/extensions/{chromium-manager-extension → chromium-based-manager-extension}/pages/sakura.css +0 -0
  23. /package/dist/extensions/{chromium-manager-extension → chromium-based-manager-extension}/pages/welcome.html +0 -0
  24. /package/dist/extensions/{chromium-manager-extension → chromium-based-manager-extension}/pages/welcome.js +0 -0
  25. /package/dist/extensions/{chromium-manager-extension → chromium-based-manager-extension}/public/logo.png +0 -0
  26. /package/dist/extensions/{chromium-manager-extension → chromium-based-manager-extension}/reload-service.js +0 -0
package/dist/module.js CHANGED
@@ -1,164 +1,164 @@
1
- "use strict";var Dp=Object.create;var et=Object.defineProperty;var Lp=Object.getOwnPropertyDescriptor;var Ip=Object.getOwnPropertyNames;var Op=Object.getPrototypeOf,Mp=Object.prototype.hasOwnProperty;var Ap=(t,e)=>()=>(e||t((e={exports:{}}).exports,e),e.exports),Rp=(t,e)=>{for(var s in e)et(t,s,{get:e[s],enumerable:!0})},zr=(t,e,s,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let n of Ip(e))!Mp.call(t,n)&&n!==s&&et(t,n,{get:()=>e[n],enumerable:!(r=Lp(e,n))||r.enumerable});return t};var a=(t,e,s)=>(s=t!=null?Dp(Op(t)):{},zr(e||!t||!t.__esModule?et(s,"default",{value:t,enumerable:!0}):s,t)),Np=t=>zr(et({},"__esModule",{value:!0}),t);var Js=Ap((Rl,qp)=>{qp.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.28",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","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","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"},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 Il={};Rp(Il,{extensionBuild:()=>fp,extensionDev:()=>_p,extensionPreview:()=>Ep,extensionStart:()=>Fp});module.exports=Np(Il);var cp=a(require("fs")),Nr=a(require("path")),pp=a(require("webpack")),lp=require("webpack-merge");var Ye=a(require("path"));var kn=a(require("case-sensitive-paths-webpack-plugin"));var V=a(require("fs")),M=a(require("path")),Sn=a(require("dotenv-webpack"));var zs=a(require("path")),f=require("@colors/colors/safe");var Hr=a(require("path")),tt=Hr.default.join(process.cwd(),"node_modules/extension-develop/dist/certs"),ee=["chrome","edge"],Tp=["firefox"],Ml=[...ee,...Tp];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"?(0,f.brightYellow)("\u25BA\u25BA\u25BA"):e==="info"?(0,f.cyan)("\u25BA\u25BA\u25BA"):(0,f.brightGreen)("\u25BA\u25BA\u25BA")} ${t}`}function Vr(t){return t.charAt(0).toUpperCase()+t.slice(1)}function Gr(t,e,s){if(!!1)return`${s.hasErrors()?(0,f.red)("\u2716\uFE0E\u2716\uFE0E\u2716\uFE0E"):(0,f.brightGreen)("\u25BA\u25BA\u25BA")} ${(0,f.cyan)(t)} compiled ${s.hasErrors()?(0,f.red)("with errors"):(0,f.brightGreen)("successfully")} in ${e} ms.`}function Xr(t,e,s){return`${x(e,"info")} is using ${e}. Installing required dependencies via ${(0,f.brightYellow)(s)}...`}function Zr(t){return`${x("env","success")} file loaded ${(0,f.brightGreen)("successfully")}.`}function v(t,e){return`${x(e,"info")}-based extension...`}function C(t,e){return`${x(e,"success")} installation completed. Run the program again and happy hacking.`}function Yr(t,e){return`${x(e,"info")} dependencies are being installed. This only happens for core contributors...`}function Kr(t,e){return`${x(e,"success")} dependencies installed ${(0,f.brightGreen)("successfully")}.`}function Qr(t,e,s){return`${x(t,"error")} ${e} Installation Error
1
+ "use strict";var Rp=Object.create;var tt=Object.defineProperty;var Np=Object.getOwnPropertyDescriptor;var Tp=Object.getOwnPropertyNames;var qp=Object.getPrototypeOf,Up=Object.prototype.hasOwnProperty;var Wp=(t,e)=>()=>(e||t((e={exports:{}}).exports,e),e.exports),Bp=(t,e)=>{for(var s in e)tt(t,s,{get:e[s],enumerable:!0})},Xr=(t,e,s,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let n of Tp(e))!Up.call(t,n)&&n!==s&&tt(t,n,{get:()=>e[n],enumerable:!(r=Np(e,n))||r.enumerable});return t};var a=(t,e,s)=>(s=t!=null?Rp(qp(t)):{},Xr(e||!t||!t.__esModule?tt(s,"default",{value:t,enumerable:!0}):s,t)),Jp=t=>Xr(tt({},"__esModule",{value:!0}),t);var Hs=Wp((Wl,Hp)=>{Hp.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.29",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","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"},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 Nl={};Bp(Nl,{extensionBuild:()=>yp,extensionDev:()=>$p,extensionPreview:()=>Lp,extensionStart:()=>Ap});module.exports=Jp(Nl);var dp=a(require("fs")),Wr=a(require("path")),gp=a(require("webpack")),hp=require("webpack-merge");var Qe=a(require("path"));var $n=a(require("case-sensitive-paths-webpack-plugin"));var Xs=a(require("fs")),it=a(require("path")),ie=require("webpack"),Zs=a(require("dotenv"));var Vs=a(require("path")),f=require("@colors/colors/safe");var Zr=a(require("path")),st=Zr.default.join(process.cwd(),"node_modules/extension-develop/dist/certs"),Q=["chrome","edge"],zp=["firefox"],ql=[...Q,...zp];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 Yr(t){return t.charAt(0).toUpperCase()+t.slice(1)}function Kr(t,e,s){if(!!1)return`${s.hasErrors()?(0,f.red)("\u2716\uFE0E\u2716\uFE0E\u2716\uFE0E"):(0,f.brightGreen)("\u25BA\u25BA\u25BA")} ${(0,f.cyan)(t)} compiled ${s.hasErrors()?(0,f.red)("with errors"):(0,f.brightGreen)("successfully")} in ${e} ms.`}function Qr(t,e,s){return`${x(e,"info")} is using ${e}. Installing required dependencies via ${(0,f.brightYellow)(s)}...`}function en(t){return`${x("env","success")} file loaded ${(0,f.brightGreen)("successfully")}.`}function _(t,e){return`${x(t,"info")} is an ${e}-based extension...`}function F(t,e){return`${x(e,"success")} installation completed. Run the program again and happy hacking.`}function tn(t,e){return`${x(e,"info")} dependencies are being installed. This only happens for core contributors...`}function sn(t,e){return`${x(e,"success")} dependencies installed ${(0,f.brightGreen)("successfully")}.`}function rn(t,e,s){return`${x(t,"error")} ${e} Installation Error
2
2
 
3
3
  Failed to detect package manager or install ${e} dependencies:
4
- ${(0,f.red)(s?.toString()||"")}`}function en(t){return`${x("Firefox runner","error")} No Service Worker Support
4
+ ${(0,f.red)(s?.toString()||"")}`}function nn(t){return`${x("Firefox runner","error")} No Service Worker Support
5
5
 
6
6
  Firefox does not support the ${(0,f.brightYellow)("background.service_worker")} field yet.
7
7
  Update your manifest.json file to use ${(0,f.brightYellow)("background.scripts")} instead.
8
8
 
9
- Read more: ${(0,f.underline)("https://bugzilla.mozilla.org/show_bug.cgi?id=1573659")}.`}function tn(t){return`${x("content-security-policy","error")} Insecure Content-Security-Policy
9
+ Read more: ${(0,f.underline)("https://bugzilla.mozilla.org/show_bug.cgi?id=1573659")}.`}function on(t){return`${x("content-security-policy","error")} Insecure Content-Security-Policy
10
10
 
11
- Manifest includes insecure content-security-policy value ${(0,f.brightYellow)("'unsafe-eval'")} in directive ${(0,f.brightBlue)("'script-src'")}.`}function sn(t){return`${x("_locales","error")} No Default Locale Specified
11
+ Manifest includes insecure content-security-policy value ${(0,f.brightYellow)("'unsafe-eval'")} in directive ${(0,f.brightBlue)("'script-src'")}.`}function an(t){return`${x("_locales","error")} No Default Locale Specified
12
12
 
13
- Localization used, but ${(0,f.brightYellow)("default_locale")} wasn't specified in the manifest.`}function ke(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 rn(t,e){return`${x("manifest.json","error")} Wrong Manifest Field Type
13
+ Localization used, but ${(0,f.brightYellow)("default_locale")} wasn't specified in the manifest.`}function Se(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 cn(t,e){return`${x("manifest.json","error")} Wrong Manifest Field Type
14
14
 
15
15
  Field ${(0,f.brightYellow)("web_accessible_resources")} must be a string array in Manifest version 2.
16
16
 
17
- Read more: ${ke(e)}`}function nn(t,e){return`${x("manifest.json","error")} Wrong Manifest Field Type
17
+ Read more: ${Se(e)}`}function pn(t,e){return`${x("manifest.json","error")} Wrong Manifest Field Type
18
18
 
19
19
  Field ${(0,f.brightYellow)("web_accessible_resources")} must be an array of objects in Manifest version 3.
20
20
 
21
- Read more: ${ke(e)}`}function on(t,e,s){let n=s?.schemaPath?.split("/"),i=n?.slice(n.length-2).shift();return`${x("manifest.json","error")} Deprecated Field
21
+ Read more: ${Se(e)}`}function ln(t,e,s){let n=s?.schemaPath?.split("/"),i=n?.slice(n.length-2).shift();return`${x("manifest.json","error")} Deprecated Field
22
22
 
23
23
  Field ${(0,f.brightYellow)(i||"")} is deprecated in Manifest V3. Update your manifest.json file to run your extension.
24
24
 
25
- Read more: ${ke(e)}`}function an(t,e,s){let r=e?.instancePath.replaceAll("/",".").slice(1)||"",n=e?.params.type;return`${x("manifest.json","error")} Invalid Manifest Field
25
+ Read more: ${Se(e)}`}function fn(t,e,s){let r=e?.instancePath.replaceAll("/",".").slice(1)||"",n=e?.params.type;return`${x("manifest.json","error")} Invalid Manifest Field
26
26
 
27
27
  Field ${(0,f.brightYellow)(r)} must be of type ${(0,f.brightBlue)(n)}.
28
28
 
29
- Read more: ${ke(s)}`}function cn(t,e,s){return`${x("manifest.json","error")} Missing Required Manifest Field
29
+ Read more: ${Se(s)}`}function un(t,e,s){return`${x("manifest.json","error")} Missing Required Manifest Field
30
30
 
31
31
  Field ${(0,f.brightYellow)(s||"")} is required. Update your manifest.json file to run your extension.
32
32
 
33
- Read more: ${ke(e)}`}function pn(t,e){let s=e.split(".").pop(),r=`${x(t,"error")} Content Script Import
33
+ Read more: ${Se(e)}`}function mn(t,e){let s=e.split(".").pop(),r=`${x(t,"error")} Content Script Import
34
34
 
35
35
  One of your ${s?.toUpperCase()} imports is also a ${(0,f.brightYellow)("content_script")} CSS in manifest.json.
36
- Remove the duplicate entry and try again.`;if(e.startsWith("content_scripts"))return r}function ln(t){return`${x(t,"error")} Top Level Await In Non-ECMAScript Module
36
+ Remove the duplicate entry and try again.`;if(e.startsWith("content_scripts"))return r}function dn(t){return`${x(t,"error")} Top Level Await In Non-ECMAScript Module
37
37
 
38
38
  Top-level await is only supported in ECMAScript modules.
39
39
  To use it in your extension, make sure to set ${(0,f.brightYellow)('"type": "module"')}
40
- in your package.json or use the ${(0,f.brightYellow)(".mjs")} extension for your script files.`}function st(t,e,s){if(!e)throw new Error("This operation is impossible. Please report a bug.");switch(zs.default.extname(s)){case".js":case".ts":case".jsx":case".tsx":return Up(t,e,s);case".css":case".scss":case".sass":case".less":return Wp(t,e,s);default:return Bp(t,e,s)}}function ie(t,e,s){let r=e.startsWith("content_scripts")?"content_scripts":e.replace("/","."),n=e.split("-")[1],i=e.startsWith("pages"),o=t.includes("content_scripts")?`(index ${n})
40
+ in your package.json or use the ${(0,f.brightYellow)(".mjs")} extension for your script files.`}function rt(t,e,s){if(!e)throw new Error("This operation is impossible. Please report a bug.");switch(Vs.default.extname(s)){case".js":case".ts":case".jsx":case".tsx":return Vp(t,e,s);case".css":case".scss":case".sass":case".less":return Gp(t,e,s);default:return Xp(t,e,s)}}function ne(t,e,s){let r=e.startsWith("content_scripts")?"content_scripts":e.replace("/","."),n=e.split("-")[1],i=e.startsWith("pages"),o=t.includes("content_scripts")?`(index ${n})
41
41
 
42
42
  `:r;return`${x("manifest.json","error")} File Not Found
43
43
 
44
44
  ${i?`Check the ${(0,f.brightYellow)("pages")} folder in your project root directory.
45
45
  `:`Check the ${(0,f.brightYellow)(o)} field in your manifest.json file.
46
- `}${(0,f.red)("NOT FOUND")} ${(0,f.underline)(s)}`}function rt(t,e,s){return`${x("manifest.json","error")} File Not Found
46
+ `}${(0,f.red)("NOT FOUND")} ${(0,f.underline)(s)}`}function nt(t,e,s){return`File Not Found
47
47
 
48
48
  Check the ${(0,f.brightYellow)(e)} field in your manifest.json file.
49
- ${(0,f.red)("NOT FOUND")} ${(0,f.underline)(s)}`}function fn(t,e){return`${x(t,"error")} Manifest Not Found
49
+ ${(0,f.red)("NOT FOUND")} ${(0,f.underline)(s)}`}function gn(t,e){return`${x(t,"error")} Manifest Not Found
50
50
 
51
51
  Ensure you have a manifest.json file at the root directory of your project.
52
- ${(0,f.red)("NOT FOUND")} ${(0,f.underline)(e)}`}function mn(t,e){return`${x("manifest.json","error")} Invalid Manifest
52
+ ${(0,f.red)("NOT FOUND")} ${(0,f.underline)(e)}`}function hn(t,e){return`${x("manifest.json","error")} Invalid Manifest
53
53
 
54
- Update your manifest.json file and try again. `+(0,f.red)(e.toString())}function un(t,e){let s=e&&`${(0,f.gray)("PATH")} ${(0,f.red)("REMOVED")} ${(0,f.underline)(e)}
54
+ Update your manifest.json file and try again. `+(0,f.red)(e.toString())}function yn(t,e){let s=e&&`${(0,f.gray)("PATH")} ${(0,f.red)("REMOVED")} ${(0,f.underline)(e)}
55
55
  `,r=t&&`${(0,f.gray)("PATH")} ${(0,f.brightGreen)("ADDED")} ${(0,f.underline)(t)}`;return`${x("manifest.json","error")} Manifest Entry Point Modification
56
56
 
57
57
  Changing the path of ${(0,f.brightYellow)("<script>")} or ${(0,f.brightYellow)('<link rel="stylesheet">')} files after compilation requires a server restart.
58
- `+s+r}function dn(t,e,s,r,n){let i=t.charAt(0).toUpperCase()+t.slice(1);return`${x("manifest.json","error")} Manifest Entry Point Modification
58
+ `+s+r}function bn(t,e,s,r,n){let i=t.charAt(0).toUpperCase()+t.slice(1);return`${x("manifest.json","error")} Manifest Entry Point Modification
59
59
 
60
60
  ${i} ${(0,f.brightYellow)(r)} in the ${(0,f.underline)(s+"/")} folder after compilation requires a server restart.
61
- ${(0,f.gray)("PATH")} ${(0,f.underline)(n)}`}function gn(t){return`${x("TypeScript","info")} is being used but no config file was found. Creating ${(0,f.brightYellow)("tsconfig.json")}...`}function Hs(t,e,s){let r=t.name||"Extension.js",n;switch(e){case"chrome":n="chrome://extensions";break;case"edge":n="edge://extensions";break;case"firefox":n="about:debugging#/runtime/this-firefox";break;default:n=""}if(!s.data)return`${x(r,"error")} No Client Data Received
61
+ ${(0,f.gray)("PATH")} ${(0,f.underline)(n)}`}function wn(t){return`${x("TypeScript","info")} is being used but no config file was found. Creating ${(0,f.brightYellow)("tsconfig.json")}...`}function Gs(t,e,s){let r=t.name||"Extension.js",n;switch(e){case"chrome":n="chrome://extensions";break;case"edge":n="edge://extensions";break;case"firefox":n="about:debugging#/runtime/this-firefox";break;default:n=""}if(!s.data)return`${x(r,"error")} No Client Data Received
62
62
 
63
63
  This error happens when the program can't get the data from your extension.
64
64
  There are many reasons this might happen. To fix, ensure that:
65
65
 
66
66
  - Your extension is set as enabled in ${(0,f.underline)(n)}
67
- - No previous ${Vr(e)} browser instance is open
67
+ - No previous ${Yr(e)} browser instance is open
68
68
 
69
69
  If that is not the case, restart both the ${(0,f.cyan)(t.name||"")} and the
70
70
  ${(0,f.brightYellow)("Manager Extension")} in ${(0,f.underline)(n)} and try again.
71
71
 
72
72
  If the issue still persists, please report a bug:
73
73
 
74
- `+(0,f.underline)("https://github.com/extension-js/extension.js/issues");let{id:i,management:o}=s.data;if(!o&&process.env.EXTENSION_ENV==="development")return`${x(r,"error")} No management API info received from client. Investigate.`;let{name:c,version:p}=o,l=Js().version;return`
74
+ `+(0,f.underline)("https://github.com/extension-js/extension.js/issues");let{id:i,management:o}=s.data;if(!o&&process.env.EXTENSION_ENV==="development")return`${x(r,"error")} No management API info received from client. Investigate.`;let{name:c,version:p}=o,l=Hs().version;return`
75
75
  \u{1F9E9} ${(0,f.brightGreen)("Extension.js")} ${(0,f.gray)(`${l}`)}
76
76
  Extension Name ${(0,f.gray)(c)}
77
77
  Extension Version ${(0,f.gray)(p)}
78
- Extension ID ${(0,f.gray)(i)}`}function hn(t){return`This is your first run using Extension.js via ${Vr(t)}. Welcome! \u{1F389}
78
+ Extension ID ${(0,f.gray)(i)}`}function xn(t){return`This is your first run using Extension.js via ${Yr(t)}. Welcome! \u{1F389}
79
79
 
80
- \u{1F9E9} Learn more at ${(0,f.underline)("https://extension.js.org")}`}function yn(t,e){return`${x("WebSocket","error")} General WebSocket Error:
81
- ${(0,f.red)(e)}`}function bn(t,e,s){return`${x("manifest.json","error")} File Not Found
80
+ \u{1F9E9} Learn more at ${(0,f.underline)("https://extension.js.org")}`}function vn(t,e){return`${x("WebSocket","error")} General WebSocket Error:
81
+ ${(0,f.red)(e)}`}function _n(t,e,s){return`${x("manifest.json","error")} File Not Found
82
82
 
83
83
  Check the ${(0,f.brightYellow)(e.replace("/","."))} field in your manifest.json file.
84
- ${(0,f.red)("NOT FOUND")} ${(0,f.underline)(s)}`}function wn(t,e){return`${x("HTML","error")} Entry Point Modification
84
+ ${(0,f.red)("NOT FOUND")} ${(0,f.underline)(s)}`}function Sn(t,e){return`${x("HTML","error")} Entry Point Modification
85
85
 
86
86
  Changing the path of ${(0,f.brightYellow)("<script>")} or ${(0,f.brightYellow)('<link rel="stylesheet">')} files after compilation requires a server restart.
87
- ${(0,f.gray)("PATH")} ${(0,f.underline)(e)}`}function Up(t,e,s){return`${x("HTML","error")} File Not Found
87
+ ${(0,f.gray)("PATH")} ${(0,f.underline)(e)}`}function Vp(t,e,s){return`${x("HTML","error")} File Not Found
88
88
 
89
89
  Check your ${(0,f.brightYellow)("<script>")} tags in ${(0,f.underline)(e)}.
90
- ${(0,f.red)("NOT FOUND")} ${(0,f.underline)(s)}`}function Wp(t,e,s){return`${x("HTML","error")} File Not Found
90
+ ${(0,f.red)("NOT FOUND")} ${(0,f.underline)(s)}`}function Gp(t,e,s){return`${x("HTML","error")} File Not Found
91
91
 
92
92
  Check your ${(0,f.brightYellow)("<link>")} tags in ${(0,f.underline)(e)}.
93
- ${(0,f.red)("NOT FOUND")} ${(0,f.underline)(s)}`}function Bp(t,e,s){let r=zs.default.extname(s);return`${x("HTML","error")} File Not Found
93
+ ${(0,f.red)("NOT FOUND")} ${(0,f.underline)(s)}`}function Xp(t,e,s){let r=Vs.default.extname(s);return`${x("HTML","warn")} File Not Found
94
94
 
95
95
  Check your ${(0,f.brightYellow)("*"+r)} assets in ${(0,f.underline)(e)}.
96
- ${(0,f.red)("NOT FOUND")} ${(0,f.underline)(s)}`}function xn(){return`${(0,f.brightYellow)("Note")}: Firefox requires a secure certificate for localhost connections, needed for the reloader to work.
96
+ ${(0,f.red)("NOT FOUND")} ${(0,f.underline)(s)}`}function Pn(){return`${(0,f.brightYellow)("Note")}: Firefox requires a secure certificate for localhost connections, needed for the reloader to work.
97
97
  By default, your manifest.json file is not being watched. To enable this feature, run:
98
98
 
99
99
  npx -y mkcert-cli \\
100
- ${(0,f.brightGreen)("--outDir")} ${(0,f.underline)(tt)} \\
100
+ ${(0,f.brightGreen)("--outDir")} ${(0,f.underline)(st)} \\
101
101
  ${(0,f.brightGreen)("--cert")} ${(0,f.brightYellow)("localhost.cert")} \\
102
102
  ${(0,f.brightGreen)("--key")} ${(0,f.brightYellow)("localhost.key")}
103
103
 
104
104
  This will enable the secure certificate needed for Firefox via ${(0,f.bold)("mkcert")}.
105
105
 
106
- Learn more about ${(0,f.bold)("mkcert")}: ${(0,f.underline)("https://github.com/FiloSottile/mkcert")}`}function vn(t,e){return`${x("Port","error")} Selected port ${(0,f.brightYellow)(e.toString())} in use. Choose a new port. `}function _n(t){return`${x("manifest.json","error")} Extension ID Not Defined
106
+ Learn more about ${(0,f.bold)("mkcert")}: ${(0,f.underline)("https://github.com/FiloSottile/mkcert")}`}function kn(t,e){return`${x("Port","error")} Selected port ${(0,f.brightYellow)(e.toString())} in use. Choose a new port. `}function En(t){return`${x("manifest.json","error")} Extension ID Not Defined
107
107
 
108
108
  For MAIN world content_scripts, the extension ID must be specified.
109
109
  Ensure your extension have a fixed ID and that the ${(0,f.brightYellow)("publicPath")}
110
- of your ${(0,f.brightYellow)("extension.config.js")} is defined as your extension URL.`}var nt=class{manifestPath;constructor(e){this.manifestPath=e.manifestPath}apply(e){let s=M.default.dirname(this.manifestPath),n=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(Zr(n)),new Sn.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 Vs=a(require("fs")),Pn=a(require("path")),it=class{apply(e){let s=Pn.default.join(e.options.output.path||"","hot");Vs.default.existsSync(s)&&(Vs.default.rmSync(s,{recursive:!0,force:!0}),process.env.EXTENSION_ENV==="development"&&console.log("[CleanHotUpdatesPlugin] Removed old hot-update files before compilation."))}};var ot=class{static name="plugin-compilation";manifestPath;constructor(e){this.manifestPath=e.manifestPath}apply(e){new kn.default().apply(e),new nt({manifestPath:this.manifestPath}).apply(e),new it().apply(e),e.hooks.done.tap("develop:brand",s=>{s.compilation.name=void 0;let r=s.endTime-s.startTime,n=require(this.manifestPath).name;console.log(Gr(n,r,s))})}};var zn=a(require("path")),Hn=a(require("mini-css-extract-plugin"));var Wn=a(require("mini-css-extract-plugin"));var pe=a(require("path")),Ee=a(require("fs"));var oe=a(require("path")),at=a(require("fs")),Gs=require("child_process"),jn=require("package-manager-detector");function $n(t,e){return Object.values(e||{}).some(s=>s===t)}function h(t,e,s){let r=oe.default.extname(e),i=S(e,s)?oe.default.normalize(e):t;return[".js",".jsx",".tsx",".ts"].includes(r)&&(i=i.replace(r,".js")),[".html",".njk",".nunjucks"].includes(r)&&(i=i.replace(r,".html")),[".css",".scss",".sass",".less"].includes(r)&&(i=i.replace(r,".css")),Xs(i||"")}function Xs(t){return t.replace(/\\/g,"/")}function S(t,e={}){if(!e)return!1;let s=oe.default.normalize(Xs(t));return Object.values(e).some(n=>typeof n!="string"?!1:Xs(n).includes(s))}function B(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)}function ae(){return process.env.npm_config_user_agent&&process.env.npm_config_user_agent.includes("pnpm")?"pnpm":!1}function En(){return process.env.npm_execpath?"npm":!1}async function j(t,e,s){try{let r=await(0,jn.detect)();console.log(Xr(t,e,r?.name||"unknown"));let n="";r?.name==="yarn"?n=`yarn --silent add ${s.join(" ")} --cwd ${__dirname} --optional`:r?.name==="npm"||En()?n=`npm --silent install ${s.join(" ")} --prefix ${__dirname} --save-optional`:ae()?n=`pnpm --silent add ${s.join(" ")} --prefix ${__dirname} --save-optional`:n=`${r} --silent install ${s.join(" ")} --cwd ${__dirname} --optional`,(0,Gs.execSync)(n,{stdio:"inherit"}),await new Promise(i=>setTimeout(i,2e3)),process.env.EXTENSION_ENV==="development"&&(console.log(Yr(t,e)),r?.name==="yarn"?n="yarn install --silent > /dev/null 2>&1":r?.name==="npm"||En()?n="npm install --silent > /dev/null 2>&1":ae()?n="pnpm install --silent > /dev/null 2>&1":n=`${r} install --silent > /dev/null 2>&1`,(0,Gs.execSync)(n,{stdio:"inherit"})),console.log(Kr(t,e))}catch(r){console.error(Qr(t,e,r))}}function ct(t){let e=oe.default.join(t,"package.json");if(!at.default.existsSync(e))return!1;let s=JSON.parse(at.default.readFileSync(e,"utf-8")),r=["react","vue","@angular/core","svelte","solid-js","preact"],n=s.dependencies||{},i=s.devDependencies||{};for(let o of r)if(n[o]||i[o])return!0;return!1}function Cn(t){return!at.default.existsSync(oe.default.resolve(__dirname,`run-${t}-profile`))}function Fn(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 ce(t,e){return JSON.parse(JSON.stringify(t),function(n,i){let o=n.indexOf(":");if(o===-1)return i;let c=n.substring(0,o);(c===e||c==="chromium"&&ee.includes(e))&&(this[n.substring(o+1)]=i)})}var Dn=!1;function pt(t){let e=pe.default.join(t,"package.json"),s=pe.default.join(t,"manifest.json");if(!Ee.default.existsSync(e))return!1;let r=Jp(t),n=require(e),i=n.devDependencies&&n.devDependencies.tailwindcss,o=n.dependencies&&n.dependencies.tailwindcss,c=!!r&&!!(i||o);if(c&&!Dn){let l=require(s).name||"Extension.js";process.env.EXTENSION_ENV==="development"&&console.log(v(l,"Tailwind")),Dn=!0}return c}function Jp(t){let e=pe.default.join(t,"tailwind.config.mjs"),s=pe.default.join(t,"tailwind.config.cjs"),r=pe.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 lt=a(require("path")),In=a(require("fs"));var Ln=!1;function je(t){let e=lt.default.join(t,"package.json"),s=lt.default.join(t,"manifest.json");if(!In.default.existsSync(e))return!1;let r=require(e),n=r.devDependencies&&r.devDependencies.sass,i=r.dependencies&&r.dependencies.sass;if(n||i){if(!Ln){let c=require(s).name||"Extension.js";process.env.EXTENSION_ENV==="development"&&console.log(v(c,"SASS")),Ln=!0}return!0}return!1}async function On(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"],n=require(lt.default.join(t,"package.json")).name;await j(n,"PostCSS",r),await j(n,"SASS",["sass","sass-loader","resolve-url-loader"]),console.log(C(n,"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 R(t,{loader:"sass-loader",mode:e,useMiniCssExtractPlugin:!1})},{use:await R(t,{loader:"sass-loader",mode:e,useMiniCssExtractPlugin:e==="production"})}]},{test:/\.module\.(s(a|c)ss)$/,oneOf:[{resourceQuery:/is_content_css_import=true/,use:await R(t,{loader:"sass-loader",mode:e,useMiniCssExtractPlugin:!1})},{use:await R(t,{loader:"sass-loader",mode:e,useMiniCssExtractPlugin:!0})}]}]}var ft=a(require("path")),An=a(require("fs"));var Mn=!1;function $e(t){let e=ft.default.join(t,"package.json"),s=ft.default.join(t,"manifest.json"),n=require(s).name||"Extension.js";if(!An.default.existsSync(e))return!1;let i=require(e),o=i.devDependencies&&i.devDependencies.less,c=i.dependencies&&i.dependencies.less;return o||c?(Mn||(process.env.EXTENSION_ENV==="development"&&console.log(v(n,"LESS")),Mn=!0),!0):!1}async function Rn(t,e){if(!$e(t))return[];try{require.resolve("less-loader")}catch{let r=require(ft.default.join(t,"package.json")).name;await j(r,"LESS",["less","less-loader","resolve-url-loader"]),console.log(C(r,"LESS")),process.exit(0)}return[{test:/\.less$/,oneOf:[{resourceQuery:/is_content_css_import=true/,use:await R(t,{loader:"less-loader",mode:e,useMiniCssExtractPlugin:!1})},{use:await R(t,{loader:"less-loader",mode:e,useMiniCssExtractPlugin:e==="production"})}]}]}var fe=a(require("path")),mt=a(require("fs"));var le=!1;function zp(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=[".postcssrc",".postcssrc.json",".postcssrc.yaml",".postcssrc.yml",".postcssrc.js",".postcssrc.cjs","postcss.config.js","postcss.config.cjs"],i=require(s).name||"Extension.js";if(mt.default.existsSync(e)){let o=require(e);if(o.dependencies&&o.dependencies.postcss||o.devDependencies&&o.devDependencies.postcss)return le||(process.env.EXTENSION_ENV==="development"&&console.log(v(i,"PostCSS")),le=!0),!0}for(let o of r)if(mt.default.existsSync(fe.default.join(t,o)))return le||(process.env.EXTENSION_ENV==="development"&&console.log(v(i,"PostCSS")),le=!0),!0;return pt(t)?(le||(process.env.EXTENSION_ENV==="development"&&console.log(v(i,"PostCSS")),le=!0),!0):!1}async function Nn(t,e){if(!zp(t))return{};try{require.resolve("postcss-loader")}catch{let r=require(fe.default.join(t,"package.json")).name;!je(t)&&!$e(t)&&await j(r,"PostCSS",["postcss","postcss-loader","postcss-scss","postcss-flexbugs-fixes","postcss-preset-env","postcss-normalize"]),console.log(C(r,"PostCSS")),process.exit(0)}return{loader:require.resolve("postcss-loader"),options:{postcssOptions:{parser:require.resolve("postcss-scss"),ident:"postcss",config:fe.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 ut=a(require("path")),qn=a(require("fs"));var Tn=!1;function Ce(t){let e=ut.default.join(t,"package.json"),s=ut.default.join(t,"manifest.json");if(!qn.default.existsSync(e))return!1;let r=require(e),n=r.devDependencies&&r.devDependencies.vue,i=r.dependencies&&r.dependencies.vue;if((n||i)&&!Tn){let c=require(s).name||"Extension.js";process.env.EXTENSION_ENV==="development"&&console.log(v(c,"Vue")),Tn=!0}return!!n||!!i}async function Un(t){if(!Ce(t))return;try{require.resolve("vue-loader")}catch{let n=["typescript"],o=require(ut.default.join(t,"manifest.json")).name||"Extension.js";await j(o,"TypeScript",n),await j(o,"Vue",["vue-loader","vue-template-compiler","vue-style-loader"]),console.log(C(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 R(t,e){let s=Wn.default.loader,r=[e.useMiniCssExtractPlugin?s:Ce(t)?require.resolve("vue-style-loader"):require.resolve("style-loader"),{loader:require.resolve("css-loader"),options:{sourceMap:e.mode==="development"}}].filter(Boolean);if(pt(t)||je(t)||$e(t)){let n=await Nn(t,e);n.loader&&r.push(n)}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 O=a(require("path")),A=a(require("fs"));function Hp(t){let e=O.default.join(t,"stylelint.config.json"),s=O.default.join(t,".stylelintrc.js file"),r=O.default.join(t,"stylelint.config.mjs"),n=O.default.join(t,".stylelintrc.mjs"),i=O.default.join(t,"stylelint.config.cjs"),o=O.default.join(t,".stylelintrc.cjs"),c=O.default.join(t,".stylelintrc.json"),p=O.default.join(t,".stylelintrc"),l=O.default.join(t,".stylelintrc.yml"),m=O.default.join(t,".stylelintrc.yaml");if(A.default.existsSync(e))return e;if(A.default.existsSync(s))return s;if(A.default.existsSync(r))return r;if(A.default.existsSync(n))return n;if(A.default.existsSync(i))return i;if(A.default.existsSync(o))return o;if(A.default.existsSync(c))return c;if(A.default.existsSync(p))return p;if(A.default.existsSync(l))return l;if(A.default.existsSync(m))return m}var Bn=!1;function Vp(t){let e=O.default.join(t,"package.json"),s=O.default.join(t,"manifest.json");if(!A.default.existsSync(e))return!1;let n=!!Hp(t);if(n&&!Bn){let o=require(s).name||"Extension.js";process.env.EXTENSION_ENV==="development"&&console.log(v(o,"Stylelint")),Bn=!0}return n}async function Jn(t){return Vp(t),[]}var dt=class t{static name="plugin-css";manifestPath;mode;constructor(e){this.manifestPath=e.manifestPath,this.mode=e.mode}async configureOptions(e){let s=zn.default.dirname(this.manifestPath),r=[new Hn.default];r.forEach(p=>p.apply(e));let n=await Jn(s);r.push(...n);let i=[{test:/\.css$/,exclude:/\.module\.css$/,oneOf:[{use:await R(s,{mode:this.mode,useMiniCssExtractPlugin:this.mode==="production"})}]},{test:/\.module\.css$/,oneOf:[{use:await R(s,{mode:this.mode,useMiniCssExtractPlugin:this.mode==="production"})}]}];e.options.plugins=[...e.options.plugins,...r].filter(Boolean);let o=await On(s,this.mode),c=await Rn(s,this.mode);i.push(...o),i.push(...c),e.options.module.rules=[...e.options.module.rules,...i].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 gt=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}}},n=[...e.options.module.rules.some(i=>i&&i.test instanceof RegExp&&i.test.test(".svg")&&i.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,...n].filter(Boolean)}};var Ys=a(require("path"));var ht=a(require("path")),Zs=a(require("fs"));var Vn=!1,Gp=[".babelrc",".babelrc.json",".babelrc.js",".babelrc.cjs","babel.config.json","babel.config.js","babel.config.cjs"];function Xp(t){let e=ht.default.join(t,"package.json"),s=ht.default.join(t,"manifest.json");if(!Zs.default.existsSync(e))return!1;let r=require(e),n=r.devDependencies&&r.devDependencies["babel-core"],i=r.dependencies&&r.dependencies["babel-core"],o=Gp.some(c=>Zs.default.existsSync(ht.default.join(t,c)))||!!n||!!i;if(o&&!Vn){let p=require(s).name||"Extension.js";process.env.EXTENSION_ENV==="development"&&process.env.EXTENSION_ENV==="development"&&console.log(v(p,"Babel")),Vn=!0}return o}async function Gn(t,e){Xp(e)}var yt=a(require("path")),Zn=a(require("fs"));var Xn=!1;function me(t){let e=yt.default.join(t,"package.json"),s=yt.default.join(t,"manifest.json");if(!Zn.default.existsSync(e))return!1;let r=require(e),n=r.devDependencies&&r.devDependencies.preact,i=r.dependencies&&r.dependencies.preact;if((n||i)&&!Xn){let c=require(s).name||"Extension.js";process.env.EXTENSION_ENV==="development"&&console.log(v(c,"Preact")),Xn=!0}return!!n||!!i}async function Yn(t){if(!me(t))return;try{require.resolve("@prefresh/webpack")}catch{let r=["@prefresh/webpack"],i=require(yt.default.join(t,"manifest.json")).name||"Extension.js";await j(i,"Preact",r),console.log(C(i,"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 bt=a(require("path")),Qn=a(require("fs"));var Kn=!1;function ue(t){let e=bt.default.join(t,"package.json"),s=bt.default.join(t,"manifest.json");if(!Qn.default.existsSync(e))return!1;let r=require(e),n=r.devDependencies&&r.devDependencies.react,i=r.dependencies&&r.dependencies.react;if((n||i)&&!Kn){let c=require(s).name||"Extension.js";process.env.EXTENSION_ENV==="development"&&console.log(v(c,"React")),Kn=!0}return!!n||!!i}async function ei(t){if(!ue(t))return;try{require.resolve("@pmmmwh/react-refresh-webpack-plugin")}catch{let r=["react-refresh","@pmmmwh/react-refresh-webpack-plugin","react-refresh-typescript"],i=require(bt.default.join(t,"manifest.json")).name||"Extension.js";await j(i,"React",r),console.log(C(i,"React")),process.exit(0)}return{plugins:[new(require("@pmmmwh/react-refresh-webpack-plugin"))({overlay:!1})],loaders:void 0,alias:void 0}}var Fe=a(require("path")),wt=a(require("fs"));var ti=!1;function G(t){let e=Fe.default.join(t,"package.json");if(!wt.default.existsSync(e))return!1;let s=Yp(t),r=require(e),n=require(Fe.default.join(t,"manifest.json")),i=n.name||"Extension.js",o=r.devDependencies&&r.devDependencies.typescript,c=r.dependencies&&r.dependencies.typescript;return ti||((o||c)&&(s?process.env.EXTENSION_ENV==="development"&&console.log(v(i,"TypeScript")):(console.log(gn(n)),Kp(t))),ti=!0),!!s&&!!(o||c)}function Zp(t,e){return{compilerOptions:{allowJs:!0,allowSyntheticDefaultImports:!0,esModuleInterop:!0,forceConsistentCasingInFileNames:!0,jsx:ct(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 Yp(t){let e=Fe.default.join(t,"tsconfig.json");if(wt.default.existsSync(e))return e}function Kp(t){wt.default.writeFileSync(Fe.default.join(t,"tsconfig.json"),JSON.stringify(Zp(t,{mode:"development"}),null,2))}var xt=class t{static name="plugin-js-frameworks";manifestPath;mode;constructor(e){this.manifestPath=e.manifestPath,this.mode=e.mode}async configureOptions(e){let s=Ys.default.dirname(this.manifestPath),r=await Gn(e,s),n=await ei(s),i=await Yn(s),o=await Un(s);e.options.resolve.alias={...r?.alias||{},...n?.alias||{},...i?.alias||{},...o?.alias||{},...e.options.resolve.alias},e.options.module.rules=[{test:/\.(js|mjs|jsx|mjsx|ts|mts|tsx|mtsx)$/,include:[Ys.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:G(s)?"typescript":"ecmascript",tsx:G(s)&&(ue(s)||me(s)),jsx:!G(s)&&(ue(s)||me(s)),dynamicImport:!0},transform:{react:{development:this.mode==="development",refresh:this.mode==="development",runtime:"automatic",importSource:"react"}}}}}},...r?.loaders||[],...n?.loaders||[],...i?.loaders||[],...o?.loaders||[],...e.options.module.rules].filter(Boolean),n?.plugins?.forEach(c=>c.apply(e)),i?.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 We=a(require("path"));var Ui=a(require("path"));var si=a(require("path"));function ri(t,e){if(!e||!e.action||!e.action.default_popup)return;let s=e.action.default_popup;return si.default.join(t,s)}var ni=a(require("path"));function ii(t,e){if(!e||!e.browser_action||!e.browser_action.default_popup)return;let s=e.browser_action.default_popup;return ni.default.join(t,s)}var vt=a(require("path"));function oi(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":vt.default.join(t,r)}}if(e.chrome_url_overrides.newtab){let r=e.chrome_url_overrides.newtab;s={"chrome_url_overrides/newtab":vt.default.join(t,r)}}if(e.chrome_url_overrides.bookmarks){let r=e.chrome_url_overrides.bookmarks;s={"chrome_url_overrides/bookmarks":vt.default.join(t,r)}}return s}var ai=a(require("path"));function ci(t,e){if(!e||!e.devtools_page)return;let s=e.devtools_page;return ai.default.join(t,s)}var Ks=a(require("path"));function pi(t,e){if(e.options_page){let r=e.options_page;return Ks.default.join(t,r)}if(!e||!e.options_ui||!e.options_ui.page)return;let s=e.options_ui.page;return Ks.default.join(t,s)}var li=a(require("path"));function fi(t,e){if(!e||!e.page_action||!e.page_action.default_popup)return;let s=e.page_action.default_popup;return li.default.join(t,s)}var mi=a(require("path"));function ui(t,e){if(!e||!e.sandbox||!e.sandbox.pages)return{"sandbox/page-0":void 0};let s=e.sandbox.pages,r={};for(let[n,i]of s.entries())r[`sandbox/page-${n}`]=mi.default.join(t,i);return r}var di=a(require("path"));function gi(t,e){if(!e||!e.side_panel||!e.side_panel.default_path)return;let s=e.side_panel.default_path;return di.default.join(t,s)}var hi=a(require("path"));function yi(t,e){if(!e||!e.sidebar_action||!e.sidebar_action.default_panel)return;let s=e.sidebar_action.default_panel;return hi.default.join(t,s)}function De(t,e){return{"action/default_popup":ri(t,e),"browser_action/default_popup":ii(t,e),...oi(t,e),devtools_page:ci(t,e),"options_ui/page":pi(t,e),"page_action/default_popup":fi(t,e),...ui(t,e),"side_panel/default_path":gi(t,e),"sidebar_action/default_panel":yi(t,e)}}var Qs=a(require("path"));function bi(t,e){if(!e||!e.action||!e.action.default_icon)return;if(typeof e.action.default_icon=="string")return Qs.default.join(t,e.action.default_icon);let s=[];for(let r in e.action.default_icon)s.push(Qs.default.join(t,e.action.default_icon[r]));return s}var er=a(require("path"));function wi(t,e){if(!e||!e.browser_action||!e.browser_action.default_icon)return;let s=[];if(typeof e.browser_action.default_icon=="string")return er.default.join(t,e.browser_action.default_icon);for(let r in e.browser_action.default_icon){let n=e.browser_action.default_icon[r]=er.default.join(t,e.browser_action.default_icon[r]);s.push(n)}return s}var tr=a(require("path"));function xi(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=tr.default.join(t,s.light)),s.dark&&(s.dark=tr.default.join(t,s.dark)),s.size&&delete s.size;return e.browser_action.theme_icons}}var vi=a(require("path"));function _i(t,e){if(!e||!e.icons)return;let s=[];for(let r in e.icons){let n=vi.default.join(t,e.icons[r]);s.push(n)}return s}var sr=a(require("path"));function Si(t,e){if(!e||!e.page_action||!e.page_action.default_icon)return;if(typeof e.page_action.default_icon=="string")return sr.default.join(t,e.page_action.default_icon);let s=[];for(let r in e.page_action.default_icon){let n=sr.default.join(t,e.page_action.default_icon[r]);s.push(n)}return s}var Pi=a(require("path"));function ki(t,e){return!e||!e.sidebar_action||!e.sidebar_action.default_icon?void 0:Pi.default.join(t,e.sidebar_action.default_icon)}function Ei(t,e){return{action:bi(t,e),browser_action:wi(t,e),"browser_action/theme_icons":xi(t,e),icons:_i(t,e),page_action:Si(t,e),sidebar_action:ki(t,e)}}var ji=a(require("path"));function $i(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(n=>{s[`declarative_net_request/${n.id}`]=ji.default.join(t,n.path)}),s)}var Ci=a(require("path"));function Fi(t,e){if(!e||!e.storage||!e.storage.managed_schema)return;let s=e.storage.managed_schema;return Ci.default.join(t,s)}function Di(t,e){return{...$i(t,e),"storage/managed_schema":Fi(t,e)}}var Le=a(require("path")),_t=a(require("fs"));function Li(t,e){let s=Le.default.join(Le.default.dirname(e),"_locales"),r=[];if(_t.default.existsSync(s))for(let n of _t.default.readdirSync(s)){let i=Le.default.join(s,n);for(let o of _t.default.readdirSync(i))r.push(Le.default.join(t,"_locales",n,o))}return r}var Ii=a(require("path"));function Oi(t,e){if(!e||!e.background)return;let s=e.background.scripts;if(s)return s.map(r=>Ii.default.join(t,r))}var Mi=a(require("path"));function Ai(t,e){if(!e||!e.background)return;let s=e.background.service_worker;if(s)return Mi.default.join(t,s)}var rr=a(require("path"));function Ri(t,e){if(!e||!e.content_scripts)return{"content_scripts/content-0":void 0};let s=i=>{if(i.js?.length!==0)return i.js?.map(o=>rr.default.join(t,o))},r=i=>{if(i.css?.length!==0)return i.css?.map(o=>rr.default.join(t,o))},n={};for(let[i,o]of e.content_scripts.entries()){let c=s(o),p=r(o);n[`content_scripts/content-${i}`]=[...(c||[]).filter(l=>l!=null),...(p||[]).filter(l=>l!=null)]}return n}var Ni=a(require("path"));function Ti(t,e){if(!e||!e.user_scripts||!e.user_scripts.api_script)return;let s=e.user_scripts.api_script;return Ni.default.join(t,s)}function Ie(t,e){return{"background/scripts":Oi(t,e),"background/service_worker":Ai(t,e),...Ri(t,e),"user_scripts/api_script":Ti(t,e)}}function qi(t){if(!(!t||!t.web_accessible_resources||!t.web_accessible_resources.length))return t.web_accessible_resources}function de({manifestPath:t,browser:e}){let s=Ui.default.dirname(t),r=require(t),n=ce(r,e||"chrome");return{html:De(s,n),icons:Ei(s,n),json:Di(s,n),locales:Li(s,t),scripts:Ie(s,n),web_accessible_resources:qi(n)}}var ge=a(require("path"));var St=a(require("fs")),Oe=a(require("path"));function Pt(t,e){if(!St.default.existsSync(t)||!St.default.statSync(t).isDirectory())return[];let s=[];function r(n){let i=St.default.readdirSync(n,{withFileTypes:!0});for(let o of i){let c=Oe.default.join(n,o.name);o.isDirectory()?r(c):o.isFile()&&e(o.name)&&s.push(c)}}return r(t),s}function kt(t,e,s=""){return!e||!e.length?{}:e.reduce((r,n)=>{let i=Oe.default.extname(n),o=Oe.default.basename(n,i),c=s?`${s}/${o}`:Oe.default.relative(t,n);return{...r,[c]:n}},{})}function Wi({manifestPath:t}){let e=ge.default.dirname(t),s={public:ge.default.join(e,"public"),pages:ge.default.join(e,"pages"),scripts:ge.default.join(e,"scripts")},r={public:Pt(s.public,()=>!0),pages:Pt(s.pages,i=>i.endsWith(".html")),scripts:Pt(s.scripts,i=>[".js",".mjs",".jsx",".mjsx",".ts",".mts",".tsx",".mtsx"].includes(ge.default.extname(i)))};return{public:kt(e,r.public),pages:kt(e,r.pages,"pages"),scripts:kt(e,r.scripts,"scripts")}}var Et=a(require("path")),Bi=a(require("webpack")),jt=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 Bi.default.ProvidePlugin({r:[Et.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(Et.default.resolve(__dirname,"./resolver-loader.js")),include:[Et.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 Ji=a(require("fs")),Ct=a(require("webpack")),zi=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:Ct.Compilation.PROCESS_ASSETS_STAGE_ADDITIONS},()=>{let r=this.manifestPath,n;try{let c=Ji.default.readFileSync(r,"utf-8");n=JSON.parse(c)}catch(c){let l=require(this.manifestPath).name||"Extension.js";s.errors.push(new Ct.default.WebpackError(mn(l,c)));return}let i=JSON.stringify(n,null,2);s.emitAsset("manifest.json",new zi.sources.RawSource(i))})})}};var So=a(require("path")),Me=require("webpack");function Hi(t,e){return t.background&&t.background.scripts&&{background:{...t.background,...t.background.scripts&&{scripts:[...t.background.scripts.map(s=>h("background/scripts.js",s,e))]}}}}var Vi=a(require("path"));var Ft=t=>Vi.default.basename(t);function Gi(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/${Ft(t.browser_action.default_icon)}`,t.browser_action.default_icon,e):Object.fromEntries(Object.entries(t.browser_action.default_icon).map(([s,r])=>[s,h(`icons/${Ft(r)}`,r,e)]))},...t.browser_action.theme_icons&&{theme_icons:t.browser_action.theme_icons.map(s=>({...s,...s.light&&{light:h(`browser_action/${Ft(s.light)}`,s.light,e)},...s.dark&&{dark:h(`browser_action/${Ft(s.dark)}`,s.dark,e)}}))}}}}function Xi(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&&h(`declarative_net_request/${s.id}.json`,s.path,e)}))}}}function Zi(t,e){return{...Hi(t,e),...Gi(t,e),...Xi(t,e)}}var Ki=a(require("path"));var Yi=t=>Ki.default.basename(t);function Qi(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/${Yi(t.action.default_icon)}`,t.action.default_icon,e):Object.fromEntries(Object.entries(t.action.default_icon).map(([s,r])=>[s,h(`action/${Yi(r)}`,r,e)]))}}}}function eo(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 Dt(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 to(t,e){return{...Qi(t,e),...eo(t,e),...Dt(t,e)}}function so(t,e){return t.background&&t.background.page&&{background:{...t.background,...t.background.page&&{page:h("background/page.html",t.background.page,e)}}}}function ro(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 no(t,e){return t.content_scripts&&{content_scripts:t.content_scripts.map((s,r)=>{let n=[...new Set(s.js)],i=[...new Set(s.css)];return{...s,js:[...n.map(o=>h(`content_scripts/content-${r}.js`,o,e))],css:[...i.map(o=>h(`content_scripts/content-${r}.css`,o,e))]}})}}function io(t,e){return t.devtools_page&&{devtools_page:h("devtools_page.html",t.devtools_page,e)}}var oo=a(require("path"));var Qp=t=>oo.default.basename(t);function ao(t,e){return t.icons&&{icons:Object.fromEntries(Object.entries(t.icons).map(([s,r])=>[s,h(`icons/${Qp(r)}`,r,e)]))}}function co(t,e){return t.options_page&&{options_page:h("options_ui/page.html",t.options_page,e)}}function po(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 fo=a(require("path"));var lo=t=>fo.default.basename(t);function mo(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/${lo(t.page_action.default_icon)}`,t.page_action.default_icon,e):Object.fromEntries(Object.entries(t.page_action.default_icon).map(([s,r])=>[s,h(`icons/${lo(r)}`,r,e)]))}}}}function uo(t,e){return t.sandbox&&{sandbox:{...t.sandbox,...t.sandbox.pages&&{pages:t.sandbox.pages.map((s,r)=>h(`sandbox/page-${r}.html`,s,e))}}}}var go=a(require("path"));var el=t=>go.default.basename(t);function ho(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/${el(t.sidebar_action.default_icon)}`,t.sidebar_action.default_icon,e)}}}}function yo(t,e){return t.storage&&{storage:{...t.storage.managed_schema&&{managed_schema:h("storage/managed_schema.json",t.storage.managed_schema,e)}}}}var bo=a(require("path"));var tl=t=>bo.default.basename(t);function wo(t,e){return t.theme&&{theme:{...t.theme,...t.theme.images&&{images:{...t.theme.images,theme_frame:h(`theme/images/${tl(t.theme.images.theme_frame)}`,t.theme.images.theme_frame,e)}}}}}function xo(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 vo(t){return t.web_accessible_resources&&t.web_accessible_resources.length&&{web_accessible_resources:t.web_accessible_resources}}function _o(t,e){return{...so(t,e),...ro(t,e),...no(t,e),...io(t,e),...ao(t,e),...co(t,e),...po(t,e),...mo(t,e),...uo(t,e),...Dt(t,e),...ho(t,e),...yo(t,e),...wo(t,e),...xo(t,e),...vo(t)}}function nr(t,e,s){let r=e||require(t);return JSON.stringify({...r,..._o(r,s),...Zi(r,s),...to(r,s)},null,2)}var Lt=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=[h(`content_scripts-${r}`,"dev.js",{})]),s)):{}}applyProdOverrides(e,s){return s.content_scripts?s.content_scripts.map((r,n)=>{if(r.js.length&&!r.css.length){let i=e.options.output?.path||"";r.css=r.js.map(o=>{let c=So.default.join(i,o.replace(".js",".css"));return h(`content_scripts/content-${n}.css`,c,{})})}return r}):{}}apply(e){e.hooks.thisCompilation.tap("manifest:update-manifest",s=>{s.hooks.processAssets.tap({name:"manifest:update-manifest",stage:Me.Compilation.PROCESS_ASSETS_STAGE_SUMMARIZE},()=>{if(s.errors.length>0)return;let r=B(s,this.manifestPath),n=nr(this.manifestPath,r,this.excludeList||{}),i={...r,...JSON.parse(n)};e.options.mode==="development"&&i.content_scripts&&(i.content_scripts=this.applyDevOverrides(i)),e.options.mode==="development"&&i.content_scripts&&(i.content_scripts=this.applyDevOverrides(i));let o=JSON.stringify(i,null,2),c=new Me.sources.RawSource(o);s.updateAsset("manifest.json",c)}),e.options.mode==="production"&&s.hooks.afterProcessAssets.tap("manifest:update-manifest",()=>{if(s.errors.length>0)return;let r=B(s,this.manifestPath),n=nr(this.manifestPath,r,this.excludeList||{}),i={...r,...JSON.parse(n)};i.content_scripts&&(i.content_scripts=this.applyProdOverrides(e,i));let o=JSON.stringify(i,null,2),c=new Me.sources.RawSource(o);s.updateAsset("manifest.json",c)})})}};var Po=a(require("fs")),It=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(n=>{Po.default.existsSync(n)&&(r.has(n)||(r.add(n),s.fileDependencies.add(n)))})})}};var ko=a(require("fs")),Eo=a(require("path")),Mt=a(require("webpack"));var Ot=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 n=e;n.light&&r.push(n.light),n.dark&&r.push(n.dark)}return r}handleErrors(e,s){let r=[".png",".jpg",".jpeg",".svg",".gif",".webp"],n=[".json"],i=[".js",".ts",".jsx",".tsx",".mjs",".cjs"],o=".html",c=Object.entries(this.includeList||{});for(let[p,l]of c)if(l){let m=this.extractPaths(l);for(let d of m){let g=Eo.default.extname(d),E=require(this.manifestPath).name||"Extension.js";if(!ko.default.existsSync(d)){let P=ie(E,p,d);r.includes(g)?e.errors.push(new s(P)):n.includes(g)?e.errors.push(new s(P)):i.includes(g)?e.errors.push(new s(P)):g===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:Mt.Compilation.PROCESS_ASSETS_STAGE_OPTIMIZE_COUNT},()=>{let r=Mt.default.WebpackError;this.handleErrors(s,r)})})}};var jo=a(require("fs")),Rt=a(require("webpack"));var At=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 i=s.options.context||"",o=`${i}/package.json`;if(!jo.default.existsSync(o)){r();return}let c=require(this.manifestPath),p=ce(c,this.browser),l=this.flattenAndSort(Object.values(De(i,p))),m=this.flattenAndSort(Object.values(Ie(i,p)));s.hooks.thisCompilation.tap("manifest:throw-if-recompile-is-needed",d=>{d.hooks.processAssets.tap({name:"manifest:check-manifest-files",stage:Rt.Compilation.PROCESS_ASSETS_STAGE_OPTIMIZE_COMPATIBILITY},()=>{let y=d.getAsset("manifest.json")?.source.source().toString(),E=JSON.parse(y||"{}"),P=this.flattenAndSort(Object.values(De(i,E))),q=this.flattenAndSort(Object.values(Ie(i,E)));if(m.toString()!==q.toString()||l.toString()!==P.toString()){let U=l.filter(W=>!P.includes(W))[0],H=P.filter(W=>!l.includes(W))[0],Pe=un(H,U);d.errors.push(new Rt.default.WebpackError(Pe))}})})}r()})}};var Nt=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 Ot({manifestPath:this.manifestPath,includeList:this.includeList,excludeList:this.excludeList}).apply(e),new Lt({manifestPath:this.manifestPath,excludeList:this.excludeList}).apply(e),new It([this.manifestPath]).apply(e),new At({manifestPath:this.manifestPath,browser:this.browser,includeList:this.includeList}).apply(e)}};var pr=a(require("path"));var or=a(require("fs")),Ut=a(require("webpack")),Lo=require("webpack");var $o=a(require("fs")),ye=a(require("path")),Co=a(require("parse5-utils"));var he=a(require("parse5-utils"));function Tt(t){try{return new URL(t),!0}catch{return!1}}function Ae(t,e){let{childNodes:s=[]}=t;for(let r of s)if(r.nodeName==="script"){let n=he.default.getAttribute(r,"src");if(!n||Tt(n))continue;e({filePath:n,childNode:r,assetType:"script"})}else if(r.nodeName==="link"){let n=he.default.getAttribute(r,"href"),i=he.default.getAttribute(r,"rel");if(!n||Tt(n))continue;e(i==="dns-prefetch"||i==="icon"||i==="manifest"||i==="modulepreload"||i==="preconnect"||i==="prefetch"||i==="preload"||i==="prerender"?{filePath:n,childNode:r,assetType:"staticHref"}:{filePath:n,childNode:r,assetType:"css"})}else if(r.nodeName==="a"||r.nodeName==="area"){let n=he.default.getAttribute(r,"href");if(!n||Tt(n))continue;e({filePath:n,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 n=he.default.getAttribute(r,"src");if(!n||Tt(n))continue;e({filePath:n,childNode:r,assetType:"staticSrc"})}else Ae(r,e)}function $(t,e){let s={css:[],js:[],static:[]};if(!t)return s;let r=e||$o.default.readFileSync(t,{encoding:"utf8"}),n=Co.default.parse(r),i=(o,c)=>ye.default.join(ye.default.dirname(o),c.startsWith("/")?ye.default.relative(ye.default.dirname(o),c):c);for(let o of n.childNodes)if(o.nodeName==="html"){for(let c of o.childNodes)(c.nodeName==="head"||c.nodeName==="body")&&Ae(c,({filePath:p,assetType:l})=>{let m=i(t,p);switch(l){case"script":s.js?.push(m);break;case"css":s.css?.push(m);break;case"staticSrc":case"staticHref":if(p.startsWith("#"))break;s.static?.push(m);break;default:break}});return{css:s.css,js:s.js,static:s.static}}}function Fo(t,e,s){let r=Object.keys(t).find(i=>{let o=t[i];return t[i]===e||$(o)?.js?.includes(e)||$(o)?.css?.includes(e)})||"",n=ir(e);return r?`/${r.replace(n,"")}${s}`:`${e.replace(n,"")}${s}`}function ir(t){switch(ye.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 X(t,e,s){return s?`/${t}${e}`:`${t}${e}`}function Do(t,e){return Object.values(e||{}).some(s=>s===t)}var qt=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",n=>{n.hooks.processAssets.tap({name:"AddAssetsToCompilationPlugin",stage:Ut.Compilation.PROCESS_ASSETS_STAGE_ADDITIONAL},()=>{let i=Object.entries(this.includeList||{});for(let o of i){let[c,p]=o;if(p){if(!or.default.existsSync(p)){let m=ie(r,c,p);n.warnings.push(new Ut.default.WebpackError(m));return}let l=or.default.readFileSync(p,"utf8");if(!S(p,this.excludeList)){let m=new Lo.sources.RawSource(l),d=X(c,".html");n.emitAsset(d,m)}}}})})}};var Wt=a(require("fs")),be=a(require("path")),Io=a(require("webpack")),Re=require("webpack");var Bt=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:Re.Compilation.PROCESS_ASSETS_STAGE_ADDITIONAL},()=>{if(s.errors.length>0)return;let r=Object.entries(this.includeList||{});for(let n of r){let[i,o]=n,c=i+".html";if(o){let p=s.getAsset(c);if(p){let l=p.source.source().toString(),m=$(o,l)?.static,d=[...new Set(m)];for(let g of d)if(!g.includes("public/")){if(!Wt.default.existsSync(g)&&!Do(g,this.includeList)&&!be.default.basename(g).startsWith("#")){let U=st(require(this.manifestPath).name,o,g);s.warnings.push(new Io.default.WebpackError(U));return}let y=Wt.default.readFileSync(g),E=new Re.sources.RawSource(y),P=be.default.join("assets",be.default.basename(g));if(!s.getAsset(P))if(g.endsWith(".html")){let q=$(g),U=[...q?.js||[],...q?.css||[],...q?.static||[]];s.emitAsset(P,E),U.forEach(H=>{let Pe=Wt.default.readFileSync(H),W=new Re.sources.RawSource(Pe),Jr=be.default.join("assets",be.default.basename(H));s.getAsset(Jr)||s.emitAsset(Jr,W)})}else s.emitAsset(P,E)}}}}})})}};var Oo=a(require("path")),ar=a(require("fs"));var Jt=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[n,i]=r;if(i){if(!ar.default.existsSync(i))return;let o=$(i),c=o?.js||[],p=o?.css||[],l=[...c,...p].filter(m=>!S(m,this.excludeList));if(e.options.mode==="development"){let m=Oo.default.resolve(__dirname,"minimum-script-file.mjs");l.push(m)}ar.default.existsSync(i)&&(S(i,this.excludeList)||(e.options.entry={...e.options.entry,[n]:{import:l}}))}}}};var Ht=require("webpack");var cr=a(require("fs")),Z=a(require("path")),D=a(require("parse5-utils"));function Mo(t,e,s,r,n){let i=cr.default.readFileSync(s,{encoding:"utf8"}),o=D.default.parse(i),c=!!t.getAsset(e+".css"),p=!1;for(let l of o.childNodes)if(l.nodeName==="html"){for(let m of l.childNodes){if((m.nodeName==="head"||m.nodeName==="body")&&Ae(m,({filePath:d,childNode:g,assetType:y})=>{let E=Z.default.dirname(s),P=Z.default.resolve(E,d),q=ir(P),U=S(Z.default.resolve(E,d),n),H=Z.default.join("/",Z.default.normalize(d)),Pe=$n(P,r);switch(y){case"script":{U?l=D.default.setAttribute(g,"src",H):(l=D.default.remove(g),p=!0);break}case"css":{U?l=D.default.setAttribute(g,"href",H):(l=D.default.remove(g),c=!0);break}case"staticHref":case"staticSrc":{if(U)l=D.default.setAttribute(g,y==="staticSrc"?"src":"href",H);else if(Pe){let W=Fo(r,P,q);l=D.default.setAttribute(g,y==="staticSrc"?"src":"href",W)}else{let W=Z.default.join("assets",Z.default.basename(P,q));cr.default.existsSync(P)&&(l=D.default.setAttribute(g,y==="staticSrc"?"src":"href",X(W,"",!0)))}break}default:break}}),m.nodeName==="head"&&c&&t.options.mode==="production"){let d=D.default.createNode("link");d.attrs=[{name:"rel",value:"stylesheet"},{name:"href",value:X(e,".css",!0)}],D.default.append(m,d)}if(m.nodeName==="body"&&(p||t.options.mode!=="production")){let d=D.default.createNode("script");d.attrs=[{name:"src",value:X(e,".js",!0)}],D.default.append(m,d)}}return D.default.serialize(o)}}var zt=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:Ht.Compilation.PROCESS_ASSETS_STAGE_DERIVED},()=>{if(s.errors.length>0)return;let r=this.includeList||{};for(let n of Object.entries(r)){let[i,o]=n;if(o){let c=Mo(s,i,o,r,this.excludeList||{});if(!S(o,this.excludeList)&&c){let p=new Ht.sources.RawSource(c),l=X(i,".html");s.updateAsset(l,p)}}}})})}};var Ao=a(require("fs")),Ro=require("webpack");var Vt=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:Ro.Compilation.PROCESS_ASSETS_STAGE_ADDITIONS},()=>{if(s.errors?.length)return;let r=this.includeList||{};for(let n of Object.entries(r)){let[,i]=n;if(i){let o=$(i),c=new Set(s.fileDependencies);if(Ao.default.existsSync(i)){let p=[i,...o?.static||[]];for(let l of p)c.has(l)||(c.add(l),l===i&&s.fileDependencies.add(l))}}}})})}};var No=a(require("fs"));var Gt=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 n=r;if(n){if(!No.default.existsSync(n)){let o=require(this.manifestPath).name||"Extension.js";console.error(ie(o,s,n)),process.exit(1)}this.initialHtmlAssets[n]={js:$(n)?.js||[],css:$(n)?.css||[]}}})}apply(e){let s=this.includeList||{};this.storeInitialHtmlAssets(s),e.hooks.make.tapAsync("html:throw-if-recompile-is-needed",(r,n)=>{let i=e.modifiedFiles||new Set,o=Array.from(i)[0];if(o&&this.initialHtmlAssets[o]){let c=$(o)?.js||[],p=$(o)?.css||[],{js:l,css:m}=this.initialHtmlAssets[o];if(this.hasEntriesChanged(p,m)||this.hasEntriesChanged(c,l)){let d=require(this.manifestPath).name;console.log(wn(d,o))}}n()})}};var To=a(require("fs")),qo=require("webpack");function rl(t,e,s){let r="Module not found: Error: Can't resolve ",i=s.message.replace(r,"").split("'")[1];if(s.message.includes(r))for(let o of Object.entries(e)){let[,c]=o;if(c){if(!To.default.existsSync(c))return null;let p=$(c),l=p?.js||[],m=p?.css||[];if(l.includes(i)||m.includes(i)){let d=st(require(t).name,c,i);return new qo.WebpackError(d)}}}return null}var Xt=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,n)=>{let i=rl(this.manifestPath,this.includeList||{},r);i&&(s.errors[n]=i)})})})}};var Zt=class{manifestPath;includeList;excludeList;constructor(e){this.manifestPath=e.manifestPath,this.includeList=e.includeList,this.excludeList=e.excludeList}apply(e){new qt({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),new zt({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:[pr.default.dirname(this.manifestPath)],exclude:/node_modules/,use:[{loader:require.resolve(pr.default.join(__dirname,"ensure-hmr-for-scripts.js")),options:{manifestPath:this.manifestPath,includeList:this.includeList,excludeList:this.excludeList}}]}),new Vt({manifestPath:this.manifestPath,includeList:this.includeList,excludeList:this.excludeList}).apply(e),new Gt({manifestPath:this.manifestPath,includeList:this.includeList,excludeList:this.excludeList}).apply(e),new Xt({manifestPath:this.manifestPath,includeList:this.includeList,excludeList:this.excludeList}).apply(e)}};var Ne=a(require("path"));var lr=a(require("fs")),Uo=a(require("path"));function Wo(t,e){return(Array.isArray(t)?t||[]:t?[t]:[]).filter(n=>{let i=lr.default.existsSync(n)&&!S(n,e),o=Uo.default.extname(n);return i&&(o===".js"||o===".mjs"||o===".jsx"||o===".ts"||o===".tsx")})}function Bo(t,e){return(Array.isArray(t)?t||[]:t?[t]:[]).filter(n=>lr.default.existsSync(n)&&!S(n,e)&&(n.endsWith(".css")||n.endsWith(".scss")||n.endsWith(".sass")||n.endsWith(".less")))}var Yt=class{manifestPath;includeList;excludeList;constructor(e){this.manifestPath=e.manifestPath,this.includeList=e.includeList||{},this.excludeList=e.excludeList||{}}apply(e){let s=this.includeList||{},r={};for(let[n,i]of Object.entries(s)){let o=Wo(i,this.excludeList),c=Bo(i,this.excludeList),p=[...o];e.options.mode==="production"&&p.push(...c),(c.length||o.length)&&(r[n]={import:p})}e.options.entry={...e.options.entry,...r}}};var te=require("webpack"),nl=['var isBrowser = !!(() => { try { return browser.runtime.getURL("/") } catch(e) {} })()','var isChrome = !!(() => { try { return chrome.runtime.getURL("/") } catch(e) {} })()'],il=[...nl,`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 } }`],Kt=class t{apply(e){let{RuntimeGlobals:s}=e.webpack;e.hooks.compilation.tap("PublicPathRuntimeModule",r=>{r.hooks.runtimeRequirementInTree.for(s.publicPath).tap(t.name,n=>{let i=ol();return r.addRuntimeModule(n,i),!0})})}};function ol(){class t extends te.RuntimeModule{constructor(){super("publicPath",te.RuntimeModule.STAGE_BASIC)}generate(){let s=this.compilation?.outputOptions.publicPath;return te.Template.asString([...il,`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 Qt=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);s.content_scripts?.some(r=>r.world&&r.world.toLowerCase()==="main")&&ee.includes(this.browser)&&!s.key&&(console.error(_n(s.name||"")),process.exit(1))}};var es=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 Yt({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:[Ne.default.dirname(this.manifestPath)],exclude:/node_modules/,use:[{loader:require.resolve(Ne.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:[Ne.default.dirname(this.manifestPath)],exclude:/node_modules/,use:[{loader:require.resolve(Ne.default.join(__dirname,"add-hmr-accept-code.js")),options:{manifestPath:this.manifestPath,includeList:this.includeList||{},excludeList:this.excludeList||{}}}]}),e.options.mode==="production"&&new Kt().apply(e),new Qt({manifestPath:this.manifestPath,browser:this.browser||"chrome",includeList:this.includeList||{},excludeList:this.excludeList||{}}).apply(e)}};var mr=a(require("path")),Te=a(require("fs")),ur=a(require("webpack")),qe=require("webpack");var we=a(require("path")),ts=a(require("fs"));function fr(t){let e=we.default.join(we.default.dirname(t),"_locales"),s=[];if(ts.default.existsSync(e))for(let r of ts.default.readdirSync(e)){let n=we.default.join(e,r);for(let i of ts.default.readdirSync(n))s.push(we.default.join(we.default.dirname(t),"_locales",r,i))}return s}var 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("locales:module",s=>{s.hooks.processAssets.tap({name:"locales:module",stage:qe.Compilation.PROCESS_ASSETS_STAGE_ADDITIONS},()=>{let n=require(this.manifestPath).name||"Extension.js";if(!Te.default.existsSync(this.manifestPath)){s.errors.push(new ur.default.WebpackError(fn(n,this.manifestPath)));return}if(s.errors.length>0)return;let i=fr(this.manifestPath);for(let o of Object.entries(i||[])){let[c,p]=o,l=p;if(l){if(!Te.default.existsSync(l)){s.warnings.push(new ur.default.WebpackError(rt(n,c,l)));return}let m=Te.default.readFileSync(l),d=new qe.sources.RawSource(m),g=e.options.context||mr.default.dirname(this.manifestPath);if(!S(l,this.excludeList)){let y=mr.default.relative(g,l);s.emitAsset(y,d)}}}})}),e.hooks.thisCompilation.tap("locales:module",s=>{s.hooks.processAssets.tap({name:"locales:module",stage:qe.Compilation.PROCESS_ASSETS_STAGE_ADDITIONS},()=>{if(s.errors?.length)return;let r=fr(this.manifestPath);for(let n of Object.entries(r||[])){let[,i]=n;if(i){let o=new Set(s.fileDependencies),c=r||[];for(let p of c)Te.default.existsSync(p)&&(o.has(p)||(o.add(p),s.fileDependencies.add(p)))}}})})}};var rs=a(require("fs")),Jo=a(require("webpack")),Ue=require("webpack");var ns=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:Ue.Compilation.PROCESS_ASSETS_STAGE_ADDITIONS},()=>{if(s.errors.length>0)return;let r=this.includeList||{};for(let n of Object.entries(r)){let[i,o]=n,c=Array.isArray(o)?o:[o];for(let p of c)if(p&&!S(p,this.excludeList)){if(!rs.default.existsSync(p)){let g=require(this.manifestPath).name||"Extension.js";s.warnings.push(new Jo.default.WebpackError(rt(g,i,p)));return}let l=rs.default.readFileSync(p),m=new Ue.sources.RawSource(l);s.emitAsset(i+".json",m)}}})}),e.hooks.thisCompilation.tap("json:module",s=>{s.hooks.processAssets.tap({name:"json:module",stage:Ue.Compilation.PROCESS_ASSETS_STAGE_ADDITIONS},()=>{if(s.errors?.length)return;let r=this.includeList||{};for(let n of Object.entries(r)){let[,i]=n,o=Array.isArray(i)?i:[i];for(let c of o)if(c){let p=new Set(s.fileDependencies);S(c,this.excludeList)||rs.default.existsSync(c)&&(p.has(c)||(p.add(c),s.fileDependencies.add(c)))}}})})}};var dr=a(require("fs")),zo=a(require("path")),os=require("webpack");var is=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:os.Compilation.PROCESS_ASSETS_STAGE_OPTIMIZE_TRANSFER},()=>{if(s.errors.length>0)return;let r=this.includeList||{};for(let n of Object.entries(r)){let[i,o]=n;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(!dr.default.existsSync(p))continue;if(!S(p,this.excludeList)){let l=dr.default.readFileSync(p),m=new os.sources.RawSource(l),d=zo.default.basename(p),y=`${i.endsWith("theme_icons")?i.replace("theme_icons",""):i}/${d}`;s.emitAsset(y,m)}}}})})}};var Ho=a(require("fs")),Vo=require("webpack"),as=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:Vo.Compilation.PROCESS_ASSETS_STAGE_ADDITIONS},()=>{if(s.errors?.length)return;let r=this.includeList||{};for(let n of Object.entries(r)){let[,i]=n,o=Array.isArray(i)?typeof i[0]=="string"?i:i.map(Object.values).flat():[i];for(let c of o)if(c){let p=new Set(s.fileDependencies);Ho.default.existsSync(c)&&(p.has(c)||(p.add(c),s.fileDependencies.add(c)))}}})})}};var cs=class{manifestPath;includeList;excludeList;constructor(e){this.manifestPath=e.manifestPath,this.includeList=e.includeList,this.excludeList=e.excludeList}apply(e){new is({manifestPath:this.manifestPath,includeList:this.includeList,excludeList:this.excludeList}).apply(e),new as({manifestPath:this.manifestPath,includeList:this.includeList,excludeList:this.excludeList}).apply(e)}};var ls=require("webpack");function Go(t){return t.map(e=>{try{let s=new URL(e.replace(/^\*:\/\//,"https://"));return e.endsWith(s.pathname)?`${e.substring(0,e.length-s.pathname.length)}/*`:s.pathname==="/"?`${e}/*`:e}catch{return e}})}var ps=class{manifestPath;includeList;excludeList;constructor(e){this.manifestPath=e.manifestPath,this.includeList=e.includeList,this.excludeList=e.excludeList}generateManifestPatches(e,s){let r=B(e,this.manifestPath),n=r.web_accessible_resources||[],i=r.web_accessible_resources||[];for(let[p,l]of Object.entries(s)){let m=r.content_scripts?.find(d=>d.js&&d.js.some(g=>g.includes(p)));if(m){let d=m.matches||[];if(r.manifest_version===3){let g=n.find(y=>y.matches.some(E=>d.includes(E)));g?l.forEach(y=>{g.resources.includes(y)||g.resources.push(y)}):n.push({resources:l.filter(y=>!y.endsWith(".map")),matches:Go(d)})}else l.forEach(g=>{i.includes(g)||i.push(g)})}}r.manifest_version===3?r.web_accessible_resources=n:r.web_accessible_resources=Array.from(new Set(i));let o=JSON.stringify(r,null,2),c=new ls.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:ls.Compilation.PROCESS_ASSETS_STAGE_ANALYSE},()=>{let r=[],n=Object.keys(this.includeList||{});for(let c of n.filter(Boolean))c.startsWith("content_scripts")&&(Array.isArray(c)?r.push(...c):typeof c=="string"&&r.push(c));let i=s.chunkGraph,o={};s.entrypoints.forEach((c,p)=>{if(r.includes(p)){let l=[];c.chunks.forEach(m=>{Array.from(i.getChunkModulesIterable(m)).forEach(g=>{i.getModuleChunks(g).forEach(y=>{y.auxiliaryFiles.forEach(E=>{l.includes(E)||l.push(E)})})})}),o[p]=l}}),this.generateManifestPatches(s,o)})})}};var L=a(require("fs")),I=a(require("path")),Xo=a(require("chokidar")),fs=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(n=>{let i=I.default.join(e,n),o=I.default.join(s,n);L.default.statSync(i).isDirectory()?this.copyFolder(i,o):this.copyFile(i,o)})}apply(e){let s=I.default.dirname(this.options.manifestPath),r=I.default.join(s,"public"),n=e.options.output?.path||"";L.default.existsSync(r)&&(e.hooks.afterEmit.tap("special-folders:copy-public-folder",()=>{let i=I.default.join(n,"public");L.default.existsSync(i)||L.default.mkdirSync(i,{recursive:!0}),L.default.existsSync(r)&&this.copyFolder(r,i)}),e.options.mode!=="production"&&e.hooks.afterPlugins.tap("special-folders:copy-public-folder",()=>{let i=I.default.join(s,"public"),o=Xo.default.watch(i,{ignoreInitial:!0});o.on("add",c=>{let p=I.default.join(n,I.default.relative(s,c));this.copyFile(c,p)}),o.on("change",c=>{let p=I.default.join(n,I.default.relative(s,c));this.copyFile(c,p)}),o.on("unlink",c=>{let p=I.default.join(n,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")),gr=a(require("chokidar"));var ms=class{manifestPath;constructor(e){this.manifestPath=e}throwCompilationError(e,s,r){let n=N.relative(process.cwd(),s),p=dn(r?"Adding":"Removing",r?"added":"removed",e,e==="pages"?"HTML pages":"script files",n);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"),n=N.join(s,"scripts"),i=gr.watch(r,{ignoreInitial:!0}),o=gr.watch(n,{ignoreInitial:!0}),c=e.options.resolve?.extensions;i.on("add",p=>{p.endsWith(".html")&&this.throwCompilationError("pages",p,!0)}),i.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",()=>{i.close().catch(console.error),o.close().catch(console.error)})})}};var us=class{static name="plugin-special-folders";options;constructor(e){this.options=e}apply(e){let{manifestPath:s}=this.options;new fs({manifestPath:s}).apply(e),e.options.mode==="development"&&e.options.watchOptions&&new ms(s).apply(e)}};var ds=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=de({manifestPath:s}),n=Wi({manifestPath:s});new jt({manifestPath:s,includeList:{...n?.pages||{},...n?.scripts||{}},excludeList:n.public,loaderOptions:{jsx:ue(We.default.dirname(this.manifestPath))||me(We.default.dirname(this.manifestPath))||Ce(We.default.dirname(this.manifestPath)),typescript:G(We.default.dirname(this.manifestPath)),minify:this.mode==="production"}}).apply(e),new Nt({browser:this.browser,manifestPath:s,includeList:{...r.html,...r.icons,...r.json,...r.scripts},excludeList:n.public}).apply(e),new Zt({manifestPath:s,includeList:{...r.html,...n.pages},excludeList:{...n.public,...n.scripts}}).apply(e),new es({manifestPath:s,browser:this.browser,includeList:{...r.scripts,...n.scripts},excludeList:{...n.public,...n.pages}}).apply(e),new ss({manifestPath:s}).apply(e),new ns({manifestPath:s,includeList:r.json,excludeList:n.public}).apply(e),new cs({manifestPath:s,includeList:r.icons,excludeList:n.public}).apply(e),new ps({manifestPath:s,includeList:{...r.scripts,...n.scripts},excludeList:n.public}).apply(e),new us({manifestPath:s}).apply(e)}};var ze=a(require("path"));var Zo=a(require("path")),Yo=a(require("ws"));function gs(t,e){t.clients.forEach(s=>{s.readyState===Yo.default.OPEN&&s.send(JSON.stringify(e))})}function Ko(t,e,s){if(!s||!e)return;let r=de({manifestPath:e}).locales,n=de({manifestPath:e}).scripts,i=de({manifestPath:e}).json;if(!t){process.env.EXTENSION_ENV==="development"&&console.error("WebSocket server is not running.");return}Zo.default.basename(s)==="manifest.json"&&gs(t,{changedFile:"manifest.json"}),r?.forEach(o=>{o.includes(s)&&gs(t,{changedFile:"_locales"})}),Object.entries(n).forEach(([o,c])=>{let p=Array.isArray(c)?c:[c];Object.values(p).flatMap(m=>m).includes(s)&&o==="background/service_worker"&&gs(t,{changedFile:"service_worker"})}),Object.entries(i).forEach(([o,c])=>{c?.includes(s)&&o==="declarative_net_request"&&gs(t,{changedFile:"declarative_net_request"})})}var yr=a(require("path")),sa=a(require("fs")),Je=a(require("ws"));var Be=a(require("path")),al=a(require("http")),ea=a(require("https")),hr=a(require("fs"));var Qo=t=>{if(!hr.default.existsSync(t))return;let e=Be.default.basename(t);return hr.default.readFileSync(Be.default.join(__dirname,"certs",e))};function ta(t,e){let s={key:Qo(Be.default.join(__dirname,"certs","localhost.key")),cert:Qo(Be.default.join(__dirname,"certs","localhost.cert"))},r=ea.default.createServer(s,(n,i)=>{i.writeHead(200),i.end()});return r.on("error",n=>{throw console.error(vn(t,e)),new Error(n.message)}),{server:r,port:e}}function cl(t,e,s){switch(s){case"chrome":return new Je.default.Server({host:"localhost",port:e});case"edge":return new Je.default.Server({host:"localhost",port:e+1});case"firefox":return new Je.default.Server({server:ta(t,e+2).server});default:return new Je.default.Server({host:"localhost",port:8888})}}async function ra(t,e){let s=t.options.context||"",r=require(yr.default.join(s,"manifest.json")),n=r.name||"Extension.js",i=e.port||8e3,o=cl(n,i,e.browser);if(o.on("connection",c=>{c.send(JSON.stringify({status:"serverReady"})),c.on("error",p=>{console.log(yn(n,p))}),c.on("message",p=>{let l=JSON.parse(p.toString());if(l.status==="clientReady"){let m=require(yr.default.join(s,"manifest.json"));setTimeout(()=>{console.log(Hs(m,e.browser,l)),console.log("")},2500),Cn(e.browser)&&setTimeout(()=>{console.log(hn(e.browser))},5e3)}})}),e.browser==="firefox"&&!sa.default.existsSync(tt)){let c=Fn(r);console.log(Hs(r,e.browser,c)),console.log(""),console.log(xn()),console.log("")}return o}var na=a(require("path")),br=a(require("fs"));function ia(t,e){let s=na.default.resolve(__dirname,`./extensions/${t}-manager-extension/reload-service.js`);try{let r=br.default.readFileSync(s,"utf8"),n=r.replace(/__RELOAD_PORT__/g,e.toString());n!==r&&br.default.writeFileSync(s,n,"utf8")}catch(r){console.error(`Error processing file: ${r.message}`)}}process.on("SIGINT",()=>{process.exit()});process.on("SIGTERM",()=>{process.exit()});var He=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;ia(this.browser,this.port);let s=await ra(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,n)=>{let o=(r.modifiedFiles||new Set).values().next().value;if(!o){n();return}let c=ze.default.relative(ze.default.dirname(this.manifestPath),o),p=ze.default.relative(process.cwd(),ze.default.dirname(o));process.env.EXTENSION_ENV==="development"&&console.info(`\u25BA\u25BA Updated file \`${c}\` (relative to ${p})`),this.manifestPath&&Ko(s,this.manifestPath,o),n()})}};var wr=a(require("path"));function oa(t,e,s){t.options.module.rules.push({test:/\.(js|mjs|jsx|mjsx|ts|mts|tsx|mtsx)$/,include:[wr.default.dirname(s)],exclude:/node_modules/,use:[{loader:wr.default.resolve(__dirname,"./inject-chromium-client-loader"),options:{manifestPath:s,browser:e}}]})}var xr=a(require("path"));function aa(t,e,s){t.options.module.rules.push({test:/\.(js|mjs|jsx|mjsx|ts|mts|tsx|mtsx)$/,include:[xr.default.dirname(s)],exclude:/node_modules/,use:[{loader:xr.default.resolve(__dirname,"./inject-firefox-client-loader"),options:{manifestPath:s,browser:e}}]})}var ys=require("webpack");var vr=a(require("content-security-policy-parser"));function ca(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,vr.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 pa(t){let e=t.content_security_policy;if(!e)return{extension_pages:"script-src 'self'; object-src 'self'; "};let s=(0,vr.default)(e.extension_pages||""),r="";for(let n in s)r+=`${n} ${s.get(n)?.join(" ")}; `;return{extension_pages:r.trim()}}function la(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 n of e)r.has(n)||r.add(n);return Array.from(r)}function fa(t){let e=["/*.json","/*.js","/*.css"];return[...t.web_accessible_resources||[],{resources:e,matches:["<all_urls>"]}]}function _r(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 Sr(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 hs=class{manifestPath;browser;constructor(e){this.manifestPath=e.manifestPath,this.browser=e.browser||"chrome"}generateManifestPatches(e){let s=B(e,this.manifestPath),r={...s,content_security_policy:s.manifest_version===3?pa(s):ca(s),...s.manifest_version===3?s.permissions?{permissions:[...new Set(["scripting",...s.permissions])]}:{permissions:["scripting"]}:{},..._r(s,this.browser),...Sr(s),web_accessible_resources:s.manifest_version===3?fa(s):la(s)},n=JSON.stringify(r,null,2),i=new ys.sources.RawSource(n);e.getAsset("manifest.json")&&e.updateAsset("manifest.json",i)}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:ys.Compilation.PROCESS_ASSETS_STAGE_SUMMARIZE},r=>{if(!this.manifestPath){let n="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: ${n}`));return}this.generateManifestPatches(s)})})}};var Pr=a(require("fs")),xe=a(require("path")),ma=a(require("webpack-target-webextension"));var bs=class{manifestPath;browser;constructor(e){this.manifestPath=e.manifestPath,this.browser=e.browser||"chrome"}handleBackground(e,s,r){let n=xe.default.resolve(__dirname,s==="firefox"?"minimum-firefox-file.mjs":"minimum-chromium-file.mjs"),i=xe.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=xe.default.join(i,c[0]);this.ensureFileExists(p,"background.scripts")}else this.addDefaultEntry(e,"background/script",n)}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=xe.default.join(i,c);this.ensureFileExists(p,"background.service_worker")}else this.addDefaultEntry(e,"background/service_worker",n)}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=xe.default.join(i,c[0]);this.ensureFileExists(p,"background.scripts")}else this.addDefaultEntry(e,"background/script",n)}}ensureFileExists(e,s){if(!Pr.default.existsSync(e)&&this.manifestPath){let n=require(this.manifestPath).name||"Extension.js",i=bn(n,s,e);throw console.error(i),new Error(i)}}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||!Pr.default.lstatSync(this.manifestPath).isFile())return;let s=require(this.manifestPath);this.handleBackground(e,this.browser,s),new ma.default({background:this.getEntryName(s),weakRuntimeCheck:!0}).apply(e)}};var kr=class{manifestPath;browser;constructor(e){this.manifestPath=e.manifestPath,this.browser=e.browser||"chrome"}apply(e){ee.includes(this.browser)&&oa(e,this.browser,this.manifestPath),this.browser==="firefox"&&aa(e,this.browser,this.manifestPath),new hs({manifestPath:this.manifestPath,browser:this.browser}).apply(e),new bs({manifestPath:this.manifestPath,browser:this.browser}).apply(e)}},ua=kr;var ws=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 He({manifestPath:this.manifestPath,browser:this.browser,port:this.port,stats:this.stats}).apply(e),e.options.mode==="development"&&new ua({manifestPath:this.manifestPath,browser:this.browser,autoReload:this.autoReload,stats:this.stats}).apply(e)}};var da=a(require("webpack")),xs=class{manifestPath;browser;constructor(e){this.manifestPath=e.manifestPath,this.browser=e.browser}apply(e){new da.default.ProvidePlugin({browser:require.resolve("webextension-polyfill")}).apply(e)}};var _s=require("webpack");var vs=class{browser;manifestPath;constructor(e){this.manifestPath=e.manifestPath,this.browser=e.browser||"chrome"}patchManifest(e){let s=ce(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:_s.Compilation.PROCESS_ASSETS_STAGE_OPTIMIZE},()=>{let r=B(s,this.manifestPath),n=this.patchManifest(r),i=new _s.sources.RawSource(n);s.updateAsset("manifest.json",i)})})}};var Ss=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 xs({manifestPath:this.manifestPath,browser:this.browser||"chrome"}).apply(e),new vs({manifestPath:this.manifestPath,browser:this.browser||"chrome"}).apply(e)}};var ka=a(require("fs"));var ga=a(require("webpack")),ha=a(require("content-security-policy-parser"));function ya(t){let e=t.content_security_policy,s=t.content_security_policy?.extension_pages,r=n=>{if(!n)return;let i=(0,ha.default)(n);if(i.get("script-src")&&i.get("script-src")?.includes("'unsafe-eval'")){let o=t.name||"Extension.js";return tn(o)}};if(t.manifest_version===3){let n=e?r(s):void 0;if(n)return new ga.default.WebpackError(n)}return null}var Er=a(require("webpack"));function ba(t,e){let s=t.web_accessible_resources;if(s){let r=s.some(o=>typeof o=="string"),n=s.some(o=>typeof o=="object"||o.resources||o.matches),i=t.name||"Extension.js";if(t.manifest_version===2&&!r)return new Er.default.WebpackError(rn(i,e));if(t.manifest_version===3&&!n)return new Er.default.WebpackError(nn(i,e))}return null}var wa=a(require("webpack"));function xa(t,e){if(e==="firefox"&&t.background?.service_worker){let s=t.name||"Extension.js";return new wa.default.WebpackError(en(s))}return null}var va=a(require("path")),_a=a(require("fs")),Sa=a(require("webpack"));function Pa(t,e){let s=va.default.join(e.options.context||"","_locales"),r=t.name||"Extension.js";return _a.default.existsSync(s)&&!t.default_locale?new Sa.default.WebpackError(sn(r)):null}var Ps=class{options;constructor(e){this.options=e}handleRuntimeErrors(e,s,r){let n=ya(s),i=ba(s,r),o=xa(s,r),c=Pa(s,e);n&&e.errors.push(n),i&&e.errors.push(i),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 n=this.options.manifestPath,i=JSON.parse(ka.default.readFileSync(n,"utf-8")),o=this.options.browser||"chrome";this.handleRuntimeErrors(s,i,o),r()})}};var Aa=a(require("fs")),Ra=a(require("ajv"));var Ea={$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 ja(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 $a=a(require("path")),Ca=require("webpack");function Fa(t,e,s){let r=t.options.context||"",n=$a.default.join(r,"manifest.json"),o=require(n).name||"Extension.js",c=e?.params.missingProperty;t.errors.push(new Ca.WebpackError(cn(o,s,c)))}var Da=a(require("path")),La=require("webpack");function Ia(t,e,s){let r=t.options.context||"",n=Da.default.join(r,"manifest.json"),o=require(n).name||"Extension.js";t.warnings.push(new La.WebpackError(an(o,e,s)))}var Oa=a(require("path")),Ma=require("webpack");function jr(t,e,s){let r=t.options.context||"",n=Oa.default.join(r,"manifest.json"),o=require(n).name||"Extension.js";t.warnings.push(new Ma.WebpackError(on(o,s,e)))}var ks=class{options;constructor(e){this.options=e}handleSchemaErrors(e,s,r){let n=new Ra.default;ja(n);let i={allOf:[Ea]},o=n.compile(i),c=o(s),p=s.manifest_version===3;if(!c&&o.errors){let l=o.errors[0];if(l?.keyword==="required"){Fa(e,l,r);return}p&&(l?.keyword==="type"&&Ia(e,l,r),l?.keyword==="not"&&jr(e,l,r))}}apply(e){e.hooks.afterCompile.tapAsync("CompatPlugin (module)",(s,r)=>{let n=this.options.manifestPath,i=JSON.parse(Aa.default.readFileSync(n,"utf-8")),o=this.options.browser||"chrome";this.handleSchemaErrors(s,i,o),r()})}};var qa=a(require("fs")),Cr=a(require("path"));var $r=a(require("webpack"));function Na(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(pn(t,r))}return null}function Ta(t,e){let s=require(t);return e.message.includes("Top-level-await is only supported in EcmaScript Modules")?new $r.default.WebpackError(ln(s.name)):null}var Es=class{manifestPath;constructor(e){this.manifestPath=e.manifestPath}apply(e){let s=Cr.default.join(Cr.default.dirname(this.manifestPath),"package.json");if(!qa.default.existsSync(s))return;let r=require(s).name;e.hooks.compilation.tap("develop:common-errors",n=>{n.hooks.afterSeal.tapAsync("develop:common-errors",i=>{n.errors.forEach((o,c)=>{let p=Na(r,o),l=Ta(r,o);p&&(n.errors[c]=p),l&&(n.errors[c]=l)}),i()})})}};var js=class{static name="plugin-errors";manifestPath;browser;constructor(e){this.manifestPath=e.manifestPath,this.browser=e.browser||"chrome"}apply(e){new Ps({manifestPath:this.manifestPath,browser:this.browser||"chrome"}).apply(e),new ks({manifestPath:this.manifestPath,browser:this.browser||"chrome"}).apply(e),new Es({manifestPath:this.manifestPath}).apply(e)}};var kc=a(require("os")),Ir=a(require("path"));var pc=a(require("fs")),lc=require("child_process");var se=a(require("path")),Xe=a(require("fs"));var Ua={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}},Wa={...Ua},Ba={...Ua};var b=require("@colors/colors/safe");function k(t,e){let s=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 ${Ve(t)} ${(0,b.red)("\u2716\uFE0E\u2716\uFE0E\u2716\uFE0E")}`:(0,b.brightGreen)("\u25BA\u25BA\u25BA");return`${(0,b.gray)("")}${s}`}function Ve(t){return t.charAt(0).toUpperCase()+t.slice(1)}function $s(t){let e=Ve(t);return`${k(t,"info")} Creating new ${e} user profile...`}function Ja(t){return`${k(t,"success")} Instance already running.`}function za(t){return`${k(t,"info")} Instance exited.`}function Cs(t,e){let s=t==="firefox"?"Add-on":"Extension";return`${k(t,"success")} ${Ve(t)} ${s} running in ${(0,b.brightBlue)(e||"unknown")} mode.`}function Ge(t,e){let s=e=="null"?`Browser is not installed
110
+ of your ${(0,f.brightYellow)("extension.config.js")} is defined as your extension URL.`}var ot=class{manifestPath;browser;constructor(e){this.manifestPath=e.manifestPath,this.browser=e.browser||"chrome"}apply(e){let s=it.default.dirname(this.manifestPath),n=require(this.manifestPath).name||"Extension.js",i=e.options.mode||"development",o=[`.env.${this.browser}.${i}`,`.env.${this.browser}`,`.env.${i}`,".env.local",".env",".env.example"],c="";for(let h of o){let v=it.default.join(s,h);if(Xs.default.existsSync(v)){c=v;break}}if(!c)return;console.log(en(n));let p=Zs.default.config({path:c}).parsed||{},l=it.default.join(s,".env.defaults"),d={...Xs.default.existsSync(l)?Zs.default.config({path:l}).parsed||{}:{},...p,...process.env},g=Object.keys(d).filter(h=>h.startsWith("EXTENSION_PUBLIC_")).reduce((h,v)=>(h[`process.env.${v}`]=JSON.stringify(d[v]),h[`import.meta.env.${v}`]=JSON.stringify(d[v]),h),{});new ie.DefinePlugin(g).apply(e),e.hooks.thisCompilation.tap("manifest:update-manifest",h=>{h.hooks.processAssets.tap({name:"env:module",stage:ie.Compilation.PROCESS_ASSETS_STAGE_SUMMARIZE},v=>{Object.keys(v).forEach(C=>{if(C.endsWith(".json")||C.endsWith(".html")){let M=h.assets[C].source().toString();M=M.replace(/\$EXTENSION_PUBLIC_[A-Z_]+/g,R=>{let K=R.slice(1),N=d[K]||R;return console.log(`Replacing ${R} with ${N}`),N}),h.updateAsset(C,new ie.sources.RawSource(M))}})})})}};var Ys=a(require("fs")),jn=a(require("path")),at=class{apply(e){let s=jn.default.join(e.options.output.path||"","hot");Ys.default.existsSync(s)&&(Ys.default.rmSync(s,{recursive:!0,force:!0}),process.env.EXTENSION_ENV==="development"&&console.log("[CleanHotUpdatesPlugin] Removed old hot-update files before compilation."))}};var ct=class{static name="plugin-compilation";manifestPath;browser;constructor(e){this.manifestPath=e.manifestPath,this.browser=e.browser||"chrome"}apply(e){new $n.default().apply(e),new ot({manifestPath:this.manifestPath,browser:this.browser}).apply(e),new at().apply(e),e.hooks.done.tap("develop:brand",s=>{s.compilation.name=void 0;let r=s.endTime-s.startTime,n=require(this.manifestPath).name;console.log(Kr(n,r,s))})}};var Gn=a(require("path")),Xn=a(require("mini-css-extract-plugin"));var zn=a(require("mini-css-extract-plugin"));var pe=a(require("path")),Pe=a(require("fs"));var oe=a(require("path")),pt=a(require("fs")),Ks=require("child_process"),Fn=require("package-manager-detector");function Dn(t,e){return Object.values(e||{}).some(s=>s===t)}function y(t,e,s){let r=oe.default.extname(e),i=k(e,s)?oe.default.normalize(e):t;return[".js",".jsx",".tsx",".ts"].includes(r)&&(i=i.replace(r,".js")),[".html",".njk",".nunjucks"].includes(r)&&(i=i.replace(r,".html")),[".css",".scss",".sass",".less"].includes(r)&&(i=i.replace(r,".css")),Qs(i||"")}function Qs(t){return t.replace(/\\/g,"/")}function k(t,e={}){if(!e)return!1;let s=oe.default.normalize(Qs(t));return Object.values(e).some(n=>typeof n!="string"?!1:Qs(n).includes(s))}function B(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)}function ae(){return process.env.npm_config_user_agent&&process.env.npm_config_user_agent.includes("pnpm")?"pnpm":!1}function Cn(){return process.env.npm_execpath?"npm":!1}async function j(t,e,s){try{let r=await(0,Fn.detect)();console.log(Qr(t,e,r?.name||"unknown"));let n="";r?.name==="yarn"?n=`yarn --silent add ${s.join(" ")} --cwd ${__dirname} --optional`:r?.name==="npm"||Cn()?n=`npm --silent install ${s.join(" ")} --prefix ${__dirname} --save-optional`:ae()?n=`pnpm --silent add ${s.join(" ")} --prefix ${__dirname} --save-optional`:n=`${r} --silent install ${s.join(" ")} --cwd ${__dirname} --optional`,(0,Ks.execSync)(n,{stdio:"inherit"}),await new Promise(i=>setTimeout(i,2e3)),process.env.EXTENSION_ENV==="development"&&(console.log(tn(t,e)),r?.name==="yarn"?n="yarn install --silent > /dev/null 2>&1":r?.name==="npm"||Cn()?n="npm install --silent > /dev/null 2>&1":ae()?n="pnpm install --silent > /dev/null 2>&1":n=`${r} install --silent > /dev/null 2>&1`,(0,Ks.execSync)(n,{stdio:"inherit"})),console.log(sn(t,e))}catch(r){console.error(rn(t,e,r))}}function lt(t){let e=oe.default.join(t,"package.json");if(!pt.default.existsSync(e))return!1;let s=JSON.parse(pt.default.readFileSync(e,"utf-8")),r=["react","vue","@angular/core","svelte","solid-js","preact"],n=s.dependencies||{},i=s.devDependencies||{};for(let o of r)if(n[o]||i[o])return!0;return!1}function Ln(t){return!pt.default.existsSync(oe.default.resolve(__dirname,`run-${t}-profile`))}function In(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 ce(t,e){return JSON.parse(JSON.stringify(t),function(n,i){let o=n.indexOf(":");if(o===-1)return i;let c=n.substring(0,o);(c===e||c==="chromium"&&Q.includes(e))&&(this[n.substring(o+1)]=i)})}var On=!1;function ft(t){let e=pe.default.join(t,"package.json"),s=pe.default.join(t,"manifest.json");if(!Pe.default.existsSync(e))return!1;let r=Zp(t),n=require(e),i=n.devDependencies&&n.devDependencies.tailwindcss,o=n.dependencies&&n.dependencies.tailwindcss,c=!!r&&!!(i||o);if(c&&!On){let l=require(s).name||"Extension.js";process.env.EXTENSION_ENV==="development"&&console.log(_(l,"Tailwind")),On=!0}return c}function Zp(t){let e=pe.default.join(t,"tailwind.config.mjs"),s=pe.default.join(t,"tailwind.config.cjs"),r=pe.default.join(t,"tailwind.config.js");if(Pe.default.existsSync(e))return e;if(Pe.default.existsSync(s))return s;if(Pe.default.existsSync(r))return r}var ut=a(require("path")),An=a(require("fs"));var Mn=!1;function ke(t){let e=ut.default.join(t,"package.json"),s=ut.default.join(t,"manifest.json");if(!An.default.existsSync(e))return!1;let r=require(e),n=r.devDependencies&&r.devDependencies.sass,i=r.dependencies&&r.dependencies.sass;if(n||i){if(!Mn){let c=require(s).name||"Extension.js";process.env.EXTENSION_ENV==="development"&&console.log(_(c,"SASS")),Mn=!0}return!0}return!1}async function Rn(t,e){if(!ke(t))return[];try{require.resolve("sass-loader")}catch{let r=["postcss-loader","postcss-scss","postcss-flexbugs-fixes","postcss-preset-env","postcss-normalize"],n=require(ut.default.join(t,"package.json")).name;await j(n,"PostCSS",r),await j(n,"SASS",["sass","sass-loader","resolve-url-loader"]),console.log(F(n,"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 q(t,{loader:"sass-loader",mode:e,useMiniCssExtractPlugin:!1})},{use:await q(t,{loader:"sass-loader",mode:e,useMiniCssExtractPlugin:e==="production"})}]},{test:/\.module\.(s(a|c)ss)$/,oneOf:[{resourceQuery:/is_content_css_import=true/,use:await q(t,{loader:"sass-loader",mode:e,useMiniCssExtractPlugin:!1})},{use:await q(t,{loader:"sass-loader",mode:e,useMiniCssExtractPlugin:!0})}]}]}var mt=a(require("path")),Tn=a(require("fs"));var Nn=!1;function Ee(t){let e=mt.default.join(t,"package.json"),s=mt.default.join(t,"manifest.json"),n=require(s).name||"Extension.js";if(!Tn.default.existsSync(e))return!1;let i=require(e),o=i.devDependencies&&i.devDependencies.less,c=i.dependencies&&i.dependencies.less;return o||c?(Nn||(process.env.EXTENSION_ENV==="development"&&console.log(_(n,"LESS")),Nn=!0),!0):!1}async function qn(t,e){if(!Ee(t))return[];try{require.resolve("less-loader")}catch{let r=require(mt.default.join(t,"package.json")).name;await j(r,"LESS",["less","less-loader","resolve-url-loader"]),console.log(F(r,"LESS")),process.exit(0)}return[{test:/\.less$/,oneOf:[{resourceQuery:/is_content_css_import=true/,use:await q(t,{loader:"less-loader",mode:e,useMiniCssExtractPlugin:!1})},{use:await q(t,{loader:"less-loader",mode:e,useMiniCssExtractPlugin:e==="production"})}]}]}var fe=a(require("path")),dt=a(require("fs"));var le=!1;function Yp(t){let e=fe.default.join(t,"package.json"),s=fe.default.join(t,"manifest.json");if(!dt.default.existsSync(e))return!1;let r=[".postcssrc",".postcssrc.json",".postcssrc.yaml",".postcssrc.yml",".postcssrc.js",".postcssrc.cjs","postcss.config.js","postcss.config.cjs"],i=require(s).name||"Extension.js";if(dt.default.existsSync(e)){let o=require(e);if(o.dependencies&&o.dependencies.postcss||o.devDependencies&&o.devDependencies.postcss)return le||(process.env.EXTENSION_ENV==="development"&&console.log(_(i,"PostCSS")),le=!0),!0}for(let o of r)if(dt.default.existsSync(fe.default.join(t,o)))return le||(process.env.EXTENSION_ENV==="development"&&console.log(_(i,"PostCSS")),le=!0),!0;return ft(t)?(le||(process.env.EXTENSION_ENV==="development"&&console.log(_(i,"PostCSS")),le=!0),!0):!1}async function Un(t,e){if(!Yp(t))return{};try{require.resolve("postcss-loader")}catch{let r=require(fe.default.join(t,"package.json")).name;!ke(t)&&!Ee(t)&&await j(r,"PostCSS",["postcss","postcss-loader","postcss-scss","postcss-flexbugs-fixes","postcss-preset-env","postcss-normalize"]),console.log(F(r,"PostCSS")),process.exit(0)}return{loader:require.resolve("postcss-loader"),options:{postcssOptions:{parser:require.resolve("postcss-scss"),ident:"postcss",config:fe.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 gt=a(require("path")),Bn=a(require("fs"));var Wn=!1;function je(t){let e=gt.default.join(t,"package.json"),s=gt.default.join(t,"manifest.json");if(!Bn.default.existsSync(e))return!1;let r=require(e),n=r.devDependencies&&r.devDependencies.vue,i=r.dependencies&&r.dependencies.vue;if((n||i)&&!Wn){let c=require(s).name||"Extension.js";process.env.EXTENSION_ENV==="development"&&console.log(_(c,"Vue")),Wn=!0}return!!n||!!i}async function Jn(t){if(!je(t))return;try{require.resolve("vue-loader")}catch{let n=["typescript"],o=require(gt.default.join(t,"manifest.json")).name||"Extension.js";await j(o,"TypeScript",n),await j(o,"Vue",["vue-loader","vue-template-compiler","vue-style-loader"]),console.log(F(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 q(t,e){let s=zn.default.loader,r=[e.useMiniCssExtractPlugin?s:je(t)?require.resolve("vue-style-loader"):require.resolve("style-loader"),{loader:require.resolve("css-loader"),options:{sourceMap:e.mode==="development"}}].filter(Boolean);if(ft(t)||ke(t)||Ee(t)){let n=await Un(t,e);n.loader&&r.push(n)}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 A=a(require("path")),T=a(require("fs"));function Kp(t){let e=A.default.join(t,"stylelint.config.json"),s=A.default.join(t,".stylelintrc.js file"),r=A.default.join(t,"stylelint.config.mjs"),n=A.default.join(t,".stylelintrc.mjs"),i=A.default.join(t,"stylelint.config.cjs"),o=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(T.default.existsSync(e))return e;if(T.default.existsSync(s))return s;if(T.default.existsSync(r))return r;if(T.default.existsSync(n))return n;if(T.default.existsSync(i))return i;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(u))return u}var Hn=!1;function Qp(t){let e=A.default.join(t,"package.json"),s=A.default.join(t,"manifest.json");if(!T.default.existsSync(e))return!1;let n=!!Kp(t);if(n&&!Hn){let o=require(s).name||"Extension.js";process.env.EXTENSION_ENV==="development"&&console.log(_(o,"Stylelint")),Hn=!0}return n}async function Vn(t){return Qp(t),[]}var ht=class t{static name="plugin-css";manifestPath;constructor(e){this.manifestPath=e.manifestPath}async configureOptions(e){let s=e.options.mode||"development",r=Gn.default.dirname(this.manifestPath),n=[new Xn.default];n.forEach(l=>l.apply(e));let i=await Vn(r);n.push(...i);let o=[{test:/\.css$/,exclude:/\.module\.css$/,oneOf:[{use:await q(r,{mode:s,useMiniCssExtractPlugin:s==="production"})}]},{test:/\.module\.css$/,oneOf:[{use:await q(r,{mode:s,useMiniCssExtractPlugin:s==="production"})}]}];e.options.plugins=[...e.options.plugins,...n].filter(Boolean);let c=await Rn(r,s),p=await qn(r,s);o.push(...c),o.push(...p),e.options.module.rules=[...e.options.module.rules,...o].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 yt=class{static name="plugin-css";manifestPath;constructor(e){this.manifestPath=e.manifestPath}async apply(e){let s={test:/\.svg$/i,type:"asset/resource",generator:{filename:"assets/[name][ext]"},parser:{dataUrlCondition:{maxSize:2048}}},n=[...e.options.module.rules.some(i=>i&&i.test instanceof RegExp&&i.test.test(".svg")&&i.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,...n].filter(Boolean)}};var tr=a(require("path"));var bt=a(require("path")),er=a(require("fs"));var Zn=!1,el=[".babelrc",".babelrc.json",".babelrc.js",".babelrc.cjs","babel.config.json","babel.config.js","babel.config.cjs"];function tl(t){let e=bt.default.join(t,"package.json"),s=bt.default.join(t,"manifest.json");if(!er.default.existsSync(e))return!1;let r=require(e),n=r.devDependencies&&r.devDependencies["babel-core"],i=r.dependencies&&r.dependencies["babel-core"],o=el.some(c=>er.default.existsSync(bt.default.join(t,c)))||!!n||!!i;if(o&&!Zn){let p=require(s).name||"Extension.js";process.env.EXTENSION_ENV==="development"&&process.env.EXTENSION_ENV==="development"&&console.log(_(p,"Babel")),Zn=!0}return o}async function Yn(t,e){tl(e)}var wt=a(require("path")),Qn=a(require("fs"));var Kn=!1;function ue(t){let e=wt.default.join(t,"package.json"),s=wt.default.join(t,"manifest.json");if(!Qn.default.existsSync(e))return!1;let r=require(e),n=r.devDependencies&&r.devDependencies.preact,i=r.dependencies&&r.dependencies.preact;if((n||i)&&!Kn){let c=require(s).name||"Extension.js";process.env.EXTENSION_ENV==="development"&&console.log(_(c,"Preact")),Kn=!0}return!!n||!!i}async function ei(t){if(!ue(t))return;try{require.resolve("@prefresh/webpack")}catch{let r=["@prefresh/webpack"],i=require(wt.default.join(t,"manifest.json")).name||"Extension.js";await j(i,"Preact",r),console.log(F(i,"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 xt=a(require("path")),si=a(require("fs"));var ti=!1;function me(t){let e=xt.default.join(t,"package.json"),s=xt.default.join(t,"manifest.json");if(!si.default.existsSync(e))return!1;let r=require(e),n=r.devDependencies&&r.devDependencies.react,i=r.dependencies&&r.dependencies.react;if((n||i)&&!ti){let c=require(s).name||"Extension.js";process.env.EXTENSION_ENV==="development"&&console.log(_(c,"React")),ti=!0}return!!n||!!i}async function ri(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"],i=require(xt.default.join(t,"manifest.json")).name||"Extension.js";await j(i,"React",r),console.log(F(i,"React")),process.exit(0)}return{plugins:[new(require("@pmmmwh/react-refresh-webpack-plugin"))({overlay:!1})],loaders:void 0,alias:void 0}}var $e=a(require("path")),vt=a(require("fs"));var ni=!1;function H(t){let e=$e.default.join(t,"package.json");if(!vt.default.existsSync(e))return!1;let s=rl(t),r=require(e),n=require($e.default.join(t,"manifest.json")),i=n.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(_(i,"TypeScript")):(console.log(wn(n)),nl(t))),ni=!0),!!s&&!!(o||c)}function sl(t,e){return{compilerOptions:{allowJs:!0,allowSyntheticDefaultImports:!0,esModuleInterop:!0,forceConsistentCasingInFileNames:!0,jsx:lt(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=$e.default.join(t,"tsconfig.json");if(vt.default.existsSync(e))return e}function nl(t){vt.default.writeFileSync($e.default.join(t,"tsconfig.json"),JSON.stringify(sl(t,{mode:"development"}),null,2))}var _t=class t{static name="plugin-js-frameworks";manifestPath;constructor(e){this.manifestPath=e.manifestPath}async configureOptions(e){let s=e.options.mode||"development",r=tr.default.dirname(this.manifestPath),n=await Yn(e,r),i=await ri(r),o=await ei(r),c=await Jn(r);e.options.resolve.alias={...n?.alias||{},...i?.alias||{},...o?.alias||{},...c?.alias||{},...e.options.resolve.alias},e.options.module.rules=[{test:/\.(js|mjs|jsx|mjsx|ts|mts|tsx|mtsx)$/,include:[tr.default.dirname(this.manifestPath)],exclude:/node_modules/,use:{loader:require.resolve("swc-loader"),options:{sync:!0,module:{type:"es6"},minify:s==="production",isModule:!0,jsc:{target:"es2016",parser:{syntax:H(r)?"typescript":"ecmascript",tsx:H(r)&&(me(r)||ue(r)),jsx:!H(r)&&(me(r)||ue(r)),dynamicImport:!0},transform:{react:{development:s==="development",refresh:s==="development",runtime:"automatic",importSource:"react"}}}}}},...n?.loaders||[],...i?.loaders||[],...o?.loaders||[],...c?.loaders||[],...e.options.module.rules].filter(Boolean),i?.plugins?.forEach(p=>p.apply(e)),o?.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 qe=a(require("path"));var Ji=a(require("path"));var ii=a(require("path"));function oi(t,e){if(!e||!e.action||!e.action.default_popup)return;let s=e.action.default_popup;return ii.default.join(t,s)}var ai=a(require("path"));function ci(t,e){if(!e||!e.browser_action||!e.browser_action.default_popup)return;let s=e.browser_action.default_popup;return ai.default.join(t,s)}var St=a(require("path"));function pi(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":St.default.join(t,r)}}if(e.chrome_url_overrides.newtab){let r=e.chrome_url_overrides.newtab;s={"chrome_url_overrides/newtab":St.default.join(t,r)}}if(e.chrome_url_overrides.bookmarks){let r=e.chrome_url_overrides.bookmarks;s={"chrome_url_overrides/bookmarks":St.default.join(t,r)}}return s}var li=a(require("path"));function fi(t,e){if(!e||!e.devtools_page)return;let s=e.devtools_page;return li.default.join(t,s)}var sr=a(require("path"));function ui(t,e){if(e.options_page){let r=e.options_page;return sr.default.join(t,r)}if(!e||!e.options_ui||!e.options_ui.page)return;let s=e.options_ui.page;return sr.default.join(t,s)}var mi=a(require("path"));function di(t,e){if(!e||!e.page_action||!e.page_action.default_popup)return;let s=e.page_action.default_popup;return mi.default.join(t,s)}var gi=a(require("path"));function hi(t,e){if(!e||!e.sandbox||!e.sandbox.pages)return{"sandbox/page-0":void 0};let s=e.sandbox.pages,r={};for(let[n,i]of s.entries())r[`sandbox/page-${n}`]=gi.default.join(t,i);return r}var yi=a(require("path"));function bi(t,e){if(!e||!e.side_panel||!e.side_panel.default_path)return;let s=e.side_panel.default_path;return yi.default.join(t,s)}var wi=a(require("path"));function xi(t,e){if(!e||!e.sidebar_action||!e.sidebar_action.default_panel)return;let s=e.sidebar_action.default_panel;return wi.default.join(t,s)}function Ce(t,e){return{"action/default_popup":oi(t,e),"browser_action/default_popup":ci(t,e),...pi(t,e),devtools_page:fi(t,e),"options_ui/page":ui(t,e),"page_action/default_popup":di(t,e),...hi(t,e),"side_panel/default_path":bi(t,e),"sidebar_action/default_panel":xi(t,e)}}var rr=a(require("path"));function vi(t,e){if(!e||!e.action||!e.action.default_icon)return;if(typeof e.action.default_icon=="string")return rr.default.join(t,e.action.default_icon);let s=[];for(let r in e.action.default_icon)s.push(rr.default.join(t,e.action.default_icon[r]));return s}var nr=a(require("path"));function _i(t,e){if(!e||!e.browser_action||!e.browser_action.default_icon)return;let s=[];if(typeof e.browser_action.default_icon=="string")return nr.default.join(t,e.browser_action.default_icon);for(let r in e.browser_action.default_icon){let n=e.browser_action.default_icon[r]=nr.default.join(t,e.browser_action.default_icon[r]);s.push(n)}return s}var ir=a(require("path"));function Si(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=ir.default.join(t,s.light)),s.dark&&(s.dark=ir.default.join(t,s.dark)),s.size&&delete s.size;return e.browser_action.theme_icons}}var Pi=a(require("path"));function ki(t,e){if(!e||!e.icons)return;let s=[];for(let r in e.icons){let n=Pi.default.join(t,e.icons[r]);s.push(n)}return s}var or=a(require("path"));function Ei(t,e){if(!e||!e.page_action||!e.page_action.default_icon)return;if(typeof e.page_action.default_icon=="string")return or.default.join(t,e.page_action.default_icon);let s=[];for(let r in e.page_action.default_icon){let n=or.default.join(t,e.page_action.default_icon[r]);s.push(n)}return s}var ji=a(require("path"));function $i(t,e){return!e||!e.sidebar_action||!e.sidebar_action.default_icon?void 0:ji.default.join(t,e.sidebar_action.default_icon)}function Ci(t,e){return{action:vi(t,e),browser_action:_i(t,e),"browser_action/theme_icons":Si(t,e),icons:ki(t,e),page_action:Ei(t,e),sidebar_action:$i(t,e)}}var Fi=a(require("path"));function Di(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(n=>{s[`declarative_net_request/${n.id}`]=Fi.default.join(t,n.path)}),s)}var Li=a(require("path"));function Ii(t,e){if(!e||!e.storage||!e.storage.managed_schema)return;let s=e.storage.managed_schema;return Li.default.join(t,s)}function Oi(t,e){return{...Di(t,e),"storage/managed_schema":Ii(t,e)}}var Fe=a(require("path")),Pt=a(require("fs"));function Mi(t,e){let s=Fe.default.join(Fe.default.dirname(e),"_locales"),r=[];if(Pt.default.existsSync(s))for(let n of Pt.default.readdirSync(s)){let i=Fe.default.join(s,n);for(let o of Pt.default.readdirSync(i))r.push(Fe.default.join(t,"_locales",n,o))}return r}var Ai=a(require("path"));function Ri(t,e){if(!e||!e.background)return;let s=e.background.scripts;if(s)return s.map(r=>Ai.default.join(t,r))}var Ni=a(require("path"));function Ti(t,e){if(!e||!e.background)return;let s=e.background.service_worker;if(s)return Ni.default.join(t,s)}var ar=a(require("path"));function qi(t,e){if(!e||!e.content_scripts)return{"content_scripts/content-0":void 0};let s=i=>{if(i.js?.length!==0)return i.js?.map(o=>ar.default.join(t,o))},r=i=>{if(i.css?.length!==0)return i.css?.map(o=>ar.default.join(t,o))},n={};for(let[i,o]of e.content_scripts.entries()){let c=s(o),p=r(o);n[`content_scripts/content-${i}`]=[...(c||[]).filter(l=>l!=null),...(p||[]).filter(l=>l!=null)]}return n}var Ui=a(require("path"));function Wi(t,e){if(!e||!e.user_scripts||!e.user_scripts.api_script)return;let s=e.user_scripts.api_script;return Ui.default.join(t,s)}function De(t,e){return{"background/scripts":Ri(t,e),"background/service_worker":Ti(t,e),...qi(t,e),"user_scripts/api_script":Wi(t,e)}}function Bi(t){if(!(!t||!t.web_accessible_resources||!t.web_accessible_resources.length))return t.web_accessible_resources}function de({manifestPath:t,browser:e}){let s=Ji.default.dirname(t),r=require(t),n=ce(r,e||"chrome");return{html:Ce(s,n),icons:Ci(s,n),json:Oi(s,n),locales:Mi(s,t),scripts:De(s,n),web_accessible_resources:Bi(n)}}var ge=a(require("path"));var kt=a(require("fs")),Le=a(require("path"));function Et(t,e){if(!kt.default.existsSync(t)||!kt.default.statSync(t).isDirectory())return[];let s=[];function r(n){let i=kt.default.readdirSync(n,{withFileTypes:!0});for(let o of i){let c=Le.default.join(n,o.name);o.isDirectory()?r(c):o.isFile()&&e(o.name)&&s.push(c)}}return r(t),s}function jt(t,e,s=""){return!e||!e.length?{}:e.reduce((r,n)=>{let i=Le.default.extname(n),o=Le.default.basename(n,i),c=s?`${s}/${o}`:Le.default.relative(t,n);return{...r,[c]:n}},{})}function zi({manifestPath:t}){let e=ge.default.dirname(t),s={public:ge.default.join(e,"public"),pages:ge.default.join(e,"pages"),scripts:ge.default.join(e,"scripts")},r={public:Et(s.public,()=>!0),pages:Et(s.pages,i=>i.endsWith(".html")),scripts:Et(s.scripts,i=>[".js",".mjs",".jsx",".mjsx",".ts",".mts",".tsx",".mtsx"].includes(ge.default.extname(i)))};return{public:jt(e,r.public),pages:jt(e,r.pages,"pages"),scripts:jt(e,r.scripts,"scripts")}}var $t=a(require("path")),Hi=a(require("webpack")),Ct=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 Hi.default.ProvidePlugin({r:[$t.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($t.default.resolve(__dirname,"./resolver-loader.js")),include:[$t.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 Vi=a(require("fs")),Dt=a(require("webpack")),Gi=require("webpack");var Ft=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:Dt.Compilation.PROCESS_ASSETS_STAGE_ADDITIONS},()=>{let r=this.manifestPath,n;try{let c=Vi.default.readFileSync(r,"utf-8");n=JSON.parse(c)}catch(c){let l=require(this.manifestPath).name||"Extension.js";s.errors.push(new Dt.default.WebpackError(hn(l,c)));return}let i=JSON.stringify(n,null,2);s.emitAsset("manifest.json",new Gi.sources.RawSource(i))})})}};var Eo=a(require("path")),Ie=require("webpack");function Xi(t,e){return t.background&&t.background.scripts&&{background:{...t.background,...t.background.scripts&&{scripts:[...t.background.scripts.map(s=>y("background/scripts.js",s,e))]}}}}var Zi=a(require("path"));var Lt=t=>Zi.default.basename(t);function Yi(t,e){return t.browser_action&&{browser_action:{...t.browser_action,...t.browser_action.default_popup&&{default_popup:y("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"?y(`icons/${Lt(t.browser_action.default_icon)}`,t.browser_action.default_icon,e):Object.fromEntries(Object.entries(t.browser_action.default_icon).map(([s,r])=>[s,y(`icons/${Lt(r)}`,r,e)]))},...t.browser_action.theme_icons&&{theme_icons:t.browser_action.theme_icons.map(s=>({...s,...s.light&&{light:y(`browser_action/${Lt(s.light)}`,s.light,e)},...s.dark&&{dark:y(`browser_action/${Lt(s.dark)}`,s.dark,e)}}))}}}}function Ki(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&&y(`declarative_net_request/${s.id}.json`,s.path,e)}))}}}function Qi(t,e){return{...Xi(t,e),...Yi(t,e),...Ki(t,e)}}var to=a(require("path"));var eo=t=>to.default.basename(t);function so(t,e){return t.action&&{action:{...t.action,...t.action.default_popup&&{default_popup:y("action/default_popup.html",t.action.default_popup,e)},...t.action.default_icon&&{default_icon:typeof t.action.default_icon=="string"?y(`action/${eo(t.action.default_icon)}`,t.action.default_icon,e):Object.fromEntries(Object.entries(t.action.default_icon).map(([s,r])=>[s,y(`action/${eo(r)}`,r,e)]))}}}}function ro(t,e){return t.background&&t.background.service_worker&&{background:{...t.background,...t.background.service_worker&&{service_worker:y("background/service_worker.js",t.background.service_worker,e)}}}}function It(t,e){return t.side_panel&&{side_panel:{...t.side_panel.default_path&&{default_path:y("side_panel/default_path.html",t.side_panel.default_path,e)}}}}function no(t,e){return{...so(t,e),...ro(t,e),...It(t,e)}}function io(t,e){return t.background&&t.background.page&&{background:{...t.background,...t.background.page&&{page:y("background/page.html",t.background.page,e)}}}}function oo(t,e){return t.chrome_url_overrides&&{chrome_url_overrides:{...t.chrome_url_overrides.bookmarks&&{bookmarks:y("chrome_url_overrides/bookmarks.html",t.chrome_url_overrides.bookmarks,e)},...t.chrome_url_overrides.history&&{history:y("chrome_url_overrides/history.html",t.chrome_url_overrides.history,e)},...t.chrome_url_overrides.newtab&&{newtab:y("chrome_url_overrides/newtab.html",t.chrome_url_overrides.newtab,e)}}}}function ao(t,e){return t.content_scripts&&{content_scripts:t.content_scripts.map((s,r)=>{let n=[...new Set(s.js)],i=[...new Set(s.css)];return{...s,js:[...n.map(o=>y(`content_scripts/content-${r}.js`,o,e))],css:[...i.map(o=>y(`content_scripts/content-${r}.css`,o,e))]}})}}function co(t,e){return t.devtools_page&&{devtools_page:y("devtools_page.html",t.devtools_page,e)}}var po=a(require("path"));var il=t=>po.default.basename(t);function lo(t,e){return t.icons&&{icons:Object.fromEntries(Object.entries(t.icons).map(([s,r])=>[s,y(`icons/${il(r)}`,r,e)]))}}function fo(t,e){return t.options_page&&{options_page:y("options_ui/page.html",t.options_page,e)}}function uo(t,e){return t.options_ui&&{options_ui:{...t.options_ui,...t.options_ui.page&&{page:y("options_ui/page.html",t.options_ui.page,e)}}}}var go=a(require("path"));var mo=t=>go.default.basename(t);function ho(t,e){return t.page_action&&{page_action:{...t.page_action,...t.page_action.default_popup&&{default_popup:y("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"?y(`icons/${mo(t.page_action.default_icon)}`,t.page_action.default_icon,e):Object.fromEntries(Object.entries(t.page_action.default_icon).map(([s,r])=>[s,y(`icons/${mo(r)}`,r,e)]))}}}}function yo(t,e){return t.sandbox&&{sandbox:{...t.sandbox,...t.sandbox.pages&&{pages:t.sandbox.pages.map((s,r)=>y(`sandbox/page-${r}.html`,s,e))}}}}var bo=a(require("path"));var ol=t=>bo.default.basename(t);function wo(t,e){return t.sidebar_action&&{sidebar_action:{...t.sidebar_action,...t.sidebar_action.default_panel&&{default_panel:y("sidebar_action/default_panel.html",t.sidebar_action.default_panel,e)},...t.sidebar_action.default_icon&&{default_icon:y(`icons/${ol(t.sidebar_action.default_icon)}`,t.sidebar_action.default_icon,e)}}}}function xo(t,e){return t.storage&&{storage:{...t.storage.managed_schema&&{managed_schema:y("storage/managed_schema.json",t.storage.managed_schema,e)}}}}var vo=a(require("path"));var al=t=>vo.default.basename(t);function _o(t,e){return t.theme&&{theme:{...t.theme,...t.theme.images&&{images:{...t.theme.images,theme_frame:y(`theme/images/${al(t.theme.images.theme_frame)}`,t.theme.images.theme_frame,e)}}}}}function So(t,e){return t.user_scripts&&{user_scripts:{...t.user_scripts,...t.user_scripts.api_script&&{api_script:y("user_scripts/api_script.js",t.user_scripts.api_script,e)}}}}function Po(t){return t.web_accessible_resources&&t.web_accessible_resources.length&&{web_accessible_resources:t.web_accessible_resources}}function ko(t,e){return{...io(t,e),...oo(t,e),...ao(t,e),...co(t,e),...lo(t,e),...fo(t,e),...uo(t,e),...ho(t,e),...yo(t,e),...It(t,e),...wo(t,e),...xo(t,e),..._o(t,e),...So(t,e),...Po(t)}}function cr(t,e,s){let r=e||require(t);return JSON.stringify({...r,...ko(r,s),...Qi(r,s),...no(r,s)},null,2)}var Ot=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=[y(`content_scripts-${r}`,"dev.js",{})]),s)):{}}applyProdOverrides(e,s){return s.content_scripts?s.content_scripts.map((r,n)=>{if(r.js.length&&!r.css.length){let i=e.options.output?.path||"";r.css=r.js.map(o=>{let c=Eo.default.join(i,o.replace(".js",".css"));return y(`content_scripts/content-${n}.css`,c,{})})}return r}):{}}apply(e){e.hooks.thisCompilation.tap("manifest:update-manifest",s=>{s.hooks.processAssets.tap({name:"manifest:update-manifest",stage:Ie.Compilation.PROCESS_ASSETS_STAGE_SUMMARIZE},()=>{if(s.errors.length>0)return;let r=B(s,this.manifestPath),n=cr(this.manifestPath,r,this.excludeList||{}),i={...r,...JSON.parse(n)};e.options.mode==="development"&&i.content_scripts&&(i.content_scripts=this.applyDevOverrides(i)),e.options.mode==="development"&&i.content_scripts&&(i.content_scripts=this.applyDevOverrides(i));let o=JSON.stringify(i,null,2),c=new Ie.sources.RawSource(o);s.updateAsset("manifest.json",c)}),e.options.mode==="production"&&s.hooks.afterProcessAssets.tap("manifest:update-manifest",()=>{if(s.errors.length>0)return;let r=B(s,this.manifestPath),n=cr(this.manifestPath,r,this.excludeList||{}),i={...r,...JSON.parse(n)};i.content_scripts&&(i.content_scripts=this.applyProdOverrides(e,i));let o=JSON.stringify(i,null,2),c=new Ie.sources.RawSource(o);s.updateAsset("manifest.json",c)})})}};var jo=a(require("fs")),Mt=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(n=>{jo.default.existsSync(n)&&(r.has(n)||(r.add(n),s.fileDependencies.add(n)))})})}};var $o=a(require("fs")),Co=a(require("path")),Rt=a(require("webpack"));var At=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 n=e;n.light&&r.push(n.light),n.dark&&r.push(n.dark)}return r}handleErrors(e,s){let r=[".png",".jpg",".jpeg",".svg",".gif",".webp"],n=[".json"],i=[".js",".ts",".jsx",".tsx",".mjs",".cjs"],o=".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=Co.default.extname(d),v=require(this.manifestPath).name||"Extension.js";if(!$o.default.existsSync(d)){let P=ne(v,p,d);r.includes(g)?e.errors.push(new s(P)):n.includes(g)?e.errors.push(new s(P)):i.includes(g)?e.errors.push(new s(P)):g===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:Rt.Compilation.PROCESS_ASSETS_STAGE_OPTIMIZE_COUNT},()=>{let r=Rt.default.WebpackError;this.handleErrors(s,r)})})}};var Fo=a(require("fs")),Tt=a(require("webpack"));var Nt=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 i=s.options.context||"",o=`${i}/package.json`;if(!Fo.default.existsSync(o)){r();return}let c=require(this.manifestPath),p=ce(c,this.browser),l=this.flattenAndSort(Object.values(Ce(i,p))),u=this.flattenAndSort(Object.values(De(i,p)));s.hooks.thisCompilation.tap("manifest:throw-if-recompile-is-needed",d=>{d.hooks.processAssets.tap({name:"manifest:check-manifest-files",stage:Tt.Compilation.PROCESS_ASSETS_STAGE_OPTIMIZE_COMPATIBILITY},()=>{let h=d.getAsset("manifest.json")?.source.source().toString(),v=JSON.parse(h||"{}"),P=this.flattenAndSort(Object.values(Ce(i,v))),C=this.flattenAndSort(Object.values(De(i,v)));if(u.toString()!==C.toString()||l.toString()!==P.toString()){let M=l.filter(N=>!P.includes(N))[0],R=P.filter(N=>!l.includes(N))[0],K=yn(R,M);d.errors.push(new Tt.default.WebpackError(K))}})})}r()})}};var qt=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 Ft({manifestPath:this.manifestPath}).apply(e),new At({manifestPath:this.manifestPath,includeList:this.includeList,excludeList:this.excludeList}).apply(e),new Ot({manifestPath:this.manifestPath,excludeList:this.excludeList}).apply(e),new Mt([this.manifestPath]).apply(e),new Nt({manifestPath:this.manifestPath,browser:this.browser,includeList:this.includeList}).apply(e)}};var mr=a(require("path"));var lr=a(require("fs")),Bt=a(require("webpack")),Mo=require("webpack");var Do=a(require("fs")),ye=a(require("path")),Lo=a(require("parse5-utils"));var he=a(require("parse5-utils"));function Ut(t){try{return new URL(t),!0}catch{return!1}}function Oe(t,e){let{childNodes:s=[]}=t;for(let r of s)if(r.nodeName==="script"){let n=he.default.getAttribute(r,"src");if(!n||Ut(n))continue;e({filePath:n,childNode:r,assetType:"script"})}else if(r.nodeName==="link"){let n=he.default.getAttribute(r,"href"),i=he.default.getAttribute(r,"rel");if(!n||Ut(n))continue;e(i==="dns-prefetch"||i==="icon"||i==="manifest"||i==="modulepreload"||i==="preconnect"||i==="prefetch"||i==="preload"||i==="prerender"?{filePath:n,childNode:r,assetType:"staticHref"}:{filePath:n,childNode:r,assetType:"css"})}else if(r.nodeName==="a"||r.nodeName==="area"){let n=he.default.getAttribute(r,"href");if(!n||Ut(n))continue;e({filePath:n,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 n=he.default.getAttribute(r,"src");if(!n||Ut(n))continue;e({filePath:n,childNode:r,assetType:"staticSrc"})}else Oe(r,e)}function $(t,e){let s={css:[],js:[],static:[]};if(!t)return s;let r=e||Do.default.readFileSync(t,{encoding:"utf8"}),n=Lo.default.parse(r),i=(o,c)=>ye.default.join(ye.default.dirname(o),c.startsWith("/")?ye.default.relative(ye.default.dirname(o),c):c);for(let o of n.childNodes)if(o.nodeName==="html"){for(let c of o.childNodes)(c.nodeName==="head"||c.nodeName==="body")&&Oe(c,({filePath:p,assetType:l})=>{let u=i(t,p);switch(l){case"script":s.js?.push(u);break;case"css":s.css?.push(u);break;case"staticSrc":case"staticHref":if(p.startsWith("#"))break;s.static?.push(u);break;default:break}});return{css:s.css,js:s.js,static:s.static}}}function Io(t,e,s){let r=Object.keys(t).find(i=>{let o=t[i];return t[i]===e||$(o)?.js?.includes(e)||$(o)?.css?.includes(e)})||"",n=pr(e);return r?`/${r.replace(n,"")}${s}`:`${e.replace(n,"")}${s}`}function pr(t){switch(ye.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 V(t,e,s){return s?`/${t}${e}`:`${t}${e}`}function Oo(t,e){return Object.values(e||{}).some(s=>s===t)}var Wt=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",n=>{n.hooks.processAssets.tap({name:"AddAssetsToCompilationPlugin",stage:Bt.Compilation.PROCESS_ASSETS_STAGE_ADDITIONAL},()=>{let i=Object.entries(this.includeList||{});for(let o of i){let[c,p]=o;if(p){if(!lr.default.existsSync(p)){let u=ne(r,c,p);n.warnings.push(new Bt.default.WebpackError(u));return}let l=lr.default.readFileSync(p,"utf8");if(!k(p,this.excludeList)){let u=new Mo.sources.RawSource(l),d=V(c,".html");n.emitAsset(d,u)}}}})})}};var Jt=a(require("fs")),be=a(require("path")),Ao=a(require("webpack")),Me=require("webpack");var zt=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:Me.Compilation.PROCESS_ASSETS_STAGE_ADDITIONAL},()=>{if(s.errors.length>0)return;let r=Object.entries(this.includeList||{});for(let n of r){let[i,o]=n,c=i+".html";if(o){let p=s.getAsset(c);if(p){let l=p.source.source().toString(),u=$(o,l)?.static,d=[...new Set(u)];for(let g of d)if(!g.includes("public/")){if(!Jt.default.existsSync(g)&&!Oo(g,this.includeList)&&!be.default.basename(g).startsWith("#")){let M=rt(require(this.manifestPath).name,o,g);s.warnings.push(new Ao.default.WebpackError(M));return}let h=Jt.default.readFileSync(g),v=new Me.sources.RawSource(h),P=be.default.join("assets",be.default.basename(g));if(!s.getAsset(P))if(g.endsWith(".html")){let C=$(g),M=[...C?.js||[],...C?.css||[],...C?.static||[]];s.emitAsset(P,v),M.forEach(R=>{let K=Jt.default.readFileSync(R),N=new Me.sources.RawSource(K),Gr=be.default.join("assets",be.default.basename(R));s.getAsset(Gr)||s.emitAsset(Gr,N)})}else s.emitAsset(P,v)}}}}})})}};var Ro=a(require("path")),fr=a(require("fs"));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[n,i]=r;if(i){if(!fr.default.existsSync(i))return;let o=$(i),c=o?.js||[],p=o?.css||[],l=[...c,...p].filter(u=>!k(u,this.excludeList));if(e.options.mode==="development"){let u=Ro.default.resolve(__dirname,"minimum-script-file.mjs");l.push(u)}fr.default.existsSync(i)&&(k(i,this.excludeList)||(e.options.entry={...e.options.entry,[n]:{import:l}}))}}}};var Gt=require("webpack");var ur=a(require("fs")),G=a(require("path")),L=a(require("parse5-utils"));function No(t,e,s,r,n){let i=ur.default.readFileSync(s,{encoding:"utf8"}),o=L.default.parse(i),c=!!t.getAsset(e+".css"),p=!1;for(let l of o.childNodes)if(l.nodeName==="html"){for(let u of l.childNodes){if((u.nodeName==="head"||u.nodeName==="body")&&Oe(u,({filePath:d,childNode:g,assetType:h})=>{let v=G.default.dirname(s),P=G.default.resolve(v,d),C=pr(P),M=k(G.default.resolve(v,d),n),R=G.default.join("/",G.default.normalize(d)),K=Dn(P,r);switch(h){case"script":{M?l=L.default.setAttribute(g,"src",R):(l=L.default.remove(g),p=!0);break}case"css":{M?l=L.default.setAttribute(g,"href",R):(l=L.default.remove(g),c=!0);break}case"staticHref":case"staticSrc":{if(M)l=L.default.setAttribute(g,h==="staticSrc"?"src":"href",R);else if(K){let N=Io(r,P,C);l=L.default.setAttribute(g,h==="staticSrc"?"src":"href",N)}else{let N=G.default.join("assets",G.default.basename(P,C));ur.default.existsSync(P)&&(l=L.default.setAttribute(g,h==="staticSrc"?"src":"href",V(N,"",!0)))}break}default:break}}),u.nodeName==="head"&&c&&t.options.mode==="production"){let d=L.default.createNode("link");d.attrs=[{name:"rel",value:"stylesheet"},{name:"href",value:V(e,".css",!0)}],L.default.append(u,d)}if(u.nodeName==="body"&&(p||t.options.mode!=="production")){let d=L.default.createNode("script");d.attrs=[{name:"src",value:V(e,".js",!0)}],L.default.append(u,d)}}return L.default.serialize(o)}}var Vt=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:Gt.Compilation.PROCESS_ASSETS_STAGE_DERIVED},()=>{if(s.errors.length>0)return;let r=this.includeList||{};for(let n of Object.entries(r)){let[i,o]=n;if(o){let c=No(s,i,o,r,this.excludeList||{});if(!k(o,this.excludeList)&&c){let p=new Gt.sources.RawSource(c),l=V(i,".html");s.updateAsset(l,p)}}}})})}};var To=a(require("fs")),qo=require("webpack");var Xt=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:qo.Compilation.PROCESS_ASSETS_STAGE_ADDITIONS},()=>{if(s.errors?.length)return;let r=this.includeList||{};for(let n of Object.entries(r)){let[,i]=n;if(i){let o=$(i),c=new Set(s.fileDependencies);if(To.default.existsSync(i)){let p=[i,...o?.static||[]];for(let l of p)c.has(l)||(c.add(l),l===i&&s.fileDependencies.add(l))}}}})})}};var Uo=a(require("fs"));var Zt=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 n=r;if(n){if(!Uo.default.existsSync(n)){let o=require(this.manifestPath).name||"Extension.js";console.error(ne(o,s,n)),process.exit(1)}this.initialHtmlAssets[n]={js:$(n)?.js||[],css:$(n)?.css||[]}}})}apply(e){let s=this.includeList||{};this.storeInitialHtmlAssets(s),e.hooks.make.tapAsync("html:throw-if-recompile-is-needed",(r,n)=>{let i=e.modifiedFiles||new Set,o=Array.from(i)[0];if(o&&this.initialHtmlAssets[o]){let c=$(o)?.js||[],p=$(o)?.css||[],{js:l,css:u}=this.initialHtmlAssets[o];if(this.hasEntriesChanged(p,u)||this.hasEntriesChanged(c,l)){let d=require(this.manifestPath).name;console.log(Sn(d,o))}}n()})}};var Wo=a(require("fs")),Bo=require("webpack");function pl(t,e,s){let r="Module not found: Error: Can't resolve ",i=s.message.replace(r,"").split("'")[1];if(s.message.includes(r))for(let o of Object.entries(e)){let[,c]=o;if(c){if(!Wo.default.existsSync(c))return null;let p=$(c),l=p?.js||[],u=p?.css||[];if(l.includes(i)||u.includes(i)){let d=rt(require(t).name,c,i);return new Bo.WebpackError(d)}}}return null}var Yt=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,n)=>{let i=pl(this.manifestPath,this.includeList||{},r);i&&(s.errors[n]=i)})})})}};var Kt=class{manifestPath;includeList;excludeList;constructor(e){this.manifestPath=e.manifestPath,this.includeList=e.includeList,this.excludeList=e.excludeList}apply(e){new Wt({manifestPath:this.manifestPath,includeList:this.includeList,excludeList:this.excludeList}).apply(e),new zt({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),e.options.module.rules.push({test:/\.(js|mjs|jsx|mjsx|ts|mts|tsx|mtsx)$/,include:[mr.default.dirname(this.manifestPath)],exclude:/node_modules/,use:[{loader:require.resolve(mr.default.join(__dirname,"ensure-hmr-for-scripts.js")),options:{manifestPath:this.manifestPath,includeList:this.includeList,excludeList:this.excludeList}}]}),new Xt({manifestPath:this.manifestPath,includeList:this.includeList,excludeList:this.excludeList}).apply(e),new Zt({manifestPath:this.manifestPath,includeList:this.includeList,excludeList:this.excludeList}).apply(e),new Yt({manifestPath:this.manifestPath,includeList:this.includeList,excludeList:this.excludeList}).apply(e)}};var Ae=a(require("path"));var dr=a(require("fs")),Jo=a(require("path"));function zo(t,e){return(Array.isArray(t)?t||[]:t?[t]:[]).filter(n=>{let i=dr.default.existsSync(n)&&!k(n,e),o=Jo.default.extname(n);return i&&(o===".js"||o===".mjs"||o===".jsx"||o===".ts"||o===".tsx")})}function Ho(t,e){return(Array.isArray(t)?t||[]:t?[t]:[]).filter(n=>dr.default.existsSync(n)&&!k(n,e)&&(n.endsWith(".css")||n.endsWith(".scss")||n.endsWith(".sass")||n.endsWith(".less")))}var Qt=class{manifestPath;includeList;excludeList;constructor(e){this.manifestPath=e.manifestPath,this.includeList=e.includeList||{},this.excludeList=e.excludeList||{}}apply(e){let s=this.includeList||{},r={};for(let[n,i]of Object.entries(s)){let o=zo(i,this.excludeList),c=Ho(i,this.excludeList),p=[...o];e.options.mode==="production"&&p.push(...c),(c.length||o.length)&&(r[n]={import:p})}e.options.entry={...e.options.entry,...r}}};var ee=require("webpack"),ll=['var isBrowser = !!(() => { try { return browser.runtime.getURL("/") } catch(e) {} })()','var isChrome = !!(() => { try { return chrome.runtime.getURL("/") } catch(e) {} })()'],fl=[...ll,`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 } }`],es=class t{apply(e){let{RuntimeGlobals:s}=e.webpack;e.hooks.compilation.tap("PublicPathRuntimeModule",r=>{r.hooks.runtimeRequirementInTree.for(s.publicPath).tap(t.name,n=>{let i=ul();return r.addRuntimeModule(n,i),!0})})}};function ul(){class t extends ee.RuntimeModule{constructor(){super("publicPath",ee.RuntimeModule.STAGE_BASIC)}generate(){let s=this.compilation?.outputOptions.publicPath;return ee.Template.asString([...fl,`var path = ${JSON.stringify(this.compilation?.getPath(s||"",{hash:this.compilation.hash||"XXXX"}))}`,`${ee.RuntimeGlobals.publicPath} = typeof importScripts === 'function' || !(isBrowser || isChrome) ? path : runtime.runtime.getURL(path);`])}}return new t}var ts=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);s.content_scripts?.some(r=>r.world&&r.world.toLowerCase()==="main")&&Q.includes(this.browser)&&!s.key&&(console.error(En(s.name||"")),process.exit(1))}};var ss=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 Qt({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:[Ae.default.dirname(this.manifestPath)],exclude:/node_modules/,use:[{loader:require.resolve(Ae.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:[Ae.default.dirname(this.manifestPath)],exclude:/node_modules/,use:[{loader:require.resolve(Ae.default.join(__dirname,"add-hmr-accept-code.js")),options:{manifestPath:this.manifestPath,includeList:this.includeList||{},excludeList:this.excludeList||{}}}]}),e.options.mode==="production"&&new es().apply(e),new ts({manifestPath:this.manifestPath,browser:this.browser||"chrome",includeList:this.includeList||{},excludeList:this.excludeList||{}}).apply(e)}};var hr=a(require("path")),Re=a(require("fs")),yr=a(require("webpack")),Ne=require("webpack");var we=a(require("path")),rs=a(require("fs"));function gr(t){let e=we.default.join(we.default.dirname(t),"_locales"),s=[];if(rs.default.existsSync(e))for(let r of rs.default.readdirSync(e)){let n=we.default.join(e,r);for(let i of rs.default.readdirSync(n))s.push(we.default.join(we.default.dirname(t),"_locales",r,i))}return s}var ns=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:Ne.Compilation.PROCESS_ASSETS_STAGE_ADDITIONS},()=>{let n=require(this.manifestPath).name||"Extension.js";if(!Re.default.existsSync(this.manifestPath)){s.errors.push(new yr.default.WebpackError(gn(n,this.manifestPath)));return}if(s.errors.length>0)return;let i=gr(this.manifestPath);for(let o of Object.entries(i||[])){let[c,p]=o,l=p;if(l){if(!Re.default.existsSync(l)){s.warnings.push(new yr.default.WebpackError(nt(n,c,l)));return}let u=Re.default.readFileSync(l),d=new Ne.sources.RawSource(u),g=e.options.context||hr.default.dirname(this.manifestPath);if(!k(l,this.excludeList)){let h=hr.default.relative(g,l);s.emitAsset(h,d)}}}})}),e.hooks.thisCompilation.tap("locales:module",s=>{s.hooks.processAssets.tap({name:"locales:module",stage:Ne.Compilation.PROCESS_ASSETS_STAGE_ADDITIONS},()=>{if(s.errors?.length)return;let r=gr(this.manifestPath);for(let n of Object.entries(r||[])){let[,i]=n;if(i){let o=new Set(s.fileDependencies),c=r||[];for(let p of c)Re.default.existsSync(p)&&(o.has(p)||(o.add(p),s.fileDependencies.add(p)))}}})})}};var is=a(require("fs")),Vo=a(require("webpack")),Te=require("webpack");var os=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 n of Object.entries(r)){let[i,o]=n,c=Array.isArray(o)?o:[o];for(let p of c)if(p&&!k(p,this.excludeList)){if(!is.default.existsSync(p)){let g=require(this.manifestPath).name||"Extension.js";s.warnings.push(new Vo.default.WebpackError(nt(g,i,p)));return}let l=is.default.readFileSync(p),u=new Te.sources.RawSource(l);s.emitAsset(i+".json",u)}}})}),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 n of Object.entries(r)){let[,i]=n,o=Array.isArray(i)?i:[i];for(let c of o)if(c){let p=new Set(s.fileDependencies);k(c,this.excludeList)||is.default.existsSync(c)&&(p.has(c)||(p.add(c),s.fileDependencies.add(c)))}}})})}};var br=a(require("fs")),Go=a(require("path")),cs=require("webpack");var as=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:cs.Compilation.PROCESS_ASSETS_STAGE_OPTIMIZE_TRANSFER},()=>{if(s.errors.length>0)return;let r=this.includeList||{};for(let n of Object.entries(r)){let[i,o]=n;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(!br.default.existsSync(p))continue;if(!k(p,this.excludeList)){let l=br.default.readFileSync(p),u=new cs.sources.RawSource(l),d=Go.default.basename(p),h=`${i.endsWith("theme_icons")?i.replace("theme_icons",""):i}/${d}`;s.emitAsset(h,u)}}}})})}};var Xo=a(require("fs")),Zo=require("webpack"),ps=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:Zo.Compilation.PROCESS_ASSETS_STAGE_ADDITIONS},()=>{if(s.errors?.length)return;let r=this.includeList||{};for(let n of Object.entries(r)){let[,i]=n,o=Array.isArray(i)?typeof i[0]=="string"?i:i.map(Object.values).flat():[i];for(let c of o)if(c){let p=new Set(s.fileDependencies);Xo.default.existsSync(c)&&(p.has(c)||(p.add(c),s.fileDependencies.add(c)))}}})})}};var ls=class{manifestPath;includeList;excludeList;constructor(e){this.manifestPath=e.manifestPath,this.includeList=e.includeList,this.excludeList=e.excludeList}apply(e){new as({manifestPath:this.manifestPath,includeList:this.includeList,excludeList:this.excludeList}).apply(e),new ps({manifestPath:this.manifestPath,includeList:this.includeList,excludeList:this.excludeList}).apply(e)}};var us=require("webpack");function Yo(t){return t.map(e=>{try{let s=new URL(e.replace(/^\*:\/\//,"https://"));return e.endsWith(s.pathname)?`${e.substring(0,e.length-s.pathname.length)}/*`:s.pathname==="/"?`${e}/*`:e}catch{return e}})}var fs=class{manifestPath;includeList;excludeList;constructor(e){this.manifestPath=e.manifestPath,this.includeList=e.includeList,this.excludeList=e.excludeList}generateManifestPatches(e,s){let r=B(e,this.manifestPath),n=r.web_accessible_resources||[],i=r.web_accessible_resources||[];for(let[p,l]of Object.entries(s)){let u=r.content_scripts?.find(d=>d.js&&d.js.some(g=>g.includes(p)));if(u){let d=u.matches||[];if(r.manifest_version===3){let g=n.find(h=>h.matches.some(v=>d.includes(v)));g?l.forEach(h=>{!g.resources.includes(h)&&!h.endsWith(".map")&&g.resources.push(h)}):n.push({resources:l.filter(h=>!h.endsWith(".map")),matches:Yo(d)})}else l.forEach(g=>{i.includes(g)||i.push(g)})}}r.manifest_version===3?n.length>0&&(r.web_accessible_resources=n):i.length>0&&(r.web_accessible_resources=Array.from(new Set(i)));let o=JSON.stringify(r,null,2),c=new us.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:us.Compilation.PROCESS_ASSETS_STAGE_ANALYSE},()=>{let r=[],n=Object.keys(this.includeList||{});for(let c of n.filter(Boolean))c.startsWith("content_scripts")&&(Array.isArray(c)?r.push(...c):typeof c=="string"&&r.push(c));let i=s.chunkGraph,o={};s.entrypoints.forEach((c,p)=>{if(r.includes(p)){let l=[];c.chunks.forEach(u=>{Array.from(i.getChunkModulesIterable(u)).forEach(g=>{i.getModuleChunks(g).forEach(h=>{h.auxiliaryFiles.forEach(v=>{l.includes(v)||l.push(v)})})})}),o[p]=l}}),this.generateManifestPatches(s,o)})})}};var I=a(require("fs")),O=a(require("path")),Ko=a(require("chokidar")),ms=class{options;constructor(e){this.options=e}ensureDirectoryExistence(e){let s=O.default.dirname(e);if(I.default.existsSync(s))return!0;I.default.mkdirSync(s,{recursive:!0})}copyFile(e,s){this.ensureDirectoryExistence(s),I.default.copyFileSync(e,s)}copyFolder(e,s){I.default.existsSync(s)||I.default.mkdirSync(s,{recursive:!0}),I.default.readdirSync(e).forEach(n=>{let i=O.default.join(e,n),o=O.default.join(s,n);I.default.statSync(i).isDirectory()?this.copyFolder(i,o):this.copyFile(i,o)})}apply(e){let s=O.default.dirname(this.options.manifestPath),r=O.default.join(s,"public"),n=e.options.output?.path||"";I.default.existsSync(r)&&(e.hooks.afterEmit.tap("special-folders:copy-public-folder",()=>{let i=O.default.join(n,"public");I.default.existsSync(i)||I.default.mkdirSync(i,{recursive:!0}),I.default.existsSync(r)&&this.copyFolder(r,i)}),e.options.mode!=="production"&&e.hooks.afterPlugins.tap("special-folders:copy-public-folder",()=>{let i=O.default.join(s,"public"),o=Ko.default.watch(i,{ignoreInitial:!0});o.on("add",c=>{let p=O.default.join(n,O.default.relative(s,c));this.copyFile(c,p)}),o.on("change",c=>{let p=O.default.join(n,O.default.relative(s,c));this.copyFile(c,p)}),o.on("unlink",c=>{let p=O.default.join(n,O.default.relative(s,c));I.default.existsSync(p)&&I.default.unlinkSync(p)}),e.hooks.watchClose.tap("special-folders:copy-public-folder",()=>{o.close().catch(console.error)})}))}};var U=a(require("path")),wr=a(require("chokidar"));var ds=class{manifestPath;constructor(e){this.manifestPath=e}throwCompilationError(e,s,r){let n=U.relative(process.cwd(),s),p=bn(r?"Adding":"Removing",r?"added":"removed",e,e==="pages"?"HTML pages":"script files",n);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=U.dirname(this.manifestPath),r=U.join(s,"pages"),n=U.join(s,"scripts"),i=wr.watch(r,{ignoreInitial:!0}),o=wr.watch(n,{ignoreInitial:!0}),c=e.options.resolve?.extensions;i.on("add",p=>{p.endsWith(".html")&&this.throwCompilationError("pages",p,!0)}),i.on("unlink",p=>{p.endsWith(".html")&&this.throwCompilationError("pages",p)}),o.on("add",p=>{c?.includes(U.extname(p))&&this.throwCompilationError("scripts",p,!0)}),o.on("unlink",p=>{c?.includes(U.extname(p))&&this.throwCompilationError("scripts",p)}),e.hooks.watchClose.tap("WarnUponFolderChanges",()=>{i.close().catch(console.error),o.close().catch(console.error)})})}};var gs=class{static name="plugin-special-folders";options;constructor(e){this.options=e}apply(e){let{manifestPath:s}=this.options;new ms({manifestPath:s}).apply(e),e.options.mode==="development"&&e.options.watchOptions&&new ds(s).apply(e)}};var hs=class{static name="plugin-extension";manifestPath;browser;constructor(e){this.manifestPath=e.manifestPath,this.browser=e.browser||"chrome"}apply(e){let s=this.manifestPath,r=de({manifestPath:s}),n=zi({manifestPath:s});process.env.EXPERIMENTAL_EXTENSION_RESOLVER_PLUGIN&&new Ct({manifestPath:s,includeList:{...n?.pages||{},...n?.scripts||{}},excludeList:n.public,loaderOptions:{jsx:me(qe.default.dirname(this.manifestPath))||ue(qe.default.dirname(this.manifestPath))||je(qe.default.dirname(this.manifestPath)),typescript:H(qe.default.dirname(this.manifestPath)),minify:e.options.mode==="production"}}).apply(e),new qt({browser:this.browser,manifestPath:s,includeList:{...r.html,...r.icons,...r.json,...r.scripts},excludeList:n.public}).apply(e),new Kt({manifestPath:s,includeList:{...r.html,...n.pages},excludeList:{...n.public,...n.scripts}}).apply(e),new ss({manifestPath:s,browser:this.browser,includeList:{...r.scripts,...n.scripts},excludeList:{...n.public,...n.pages}}).apply(e),new ns({manifestPath:s}).apply(e),new os({manifestPath:s,includeList:r.json,excludeList:n.public}).apply(e),new ls({manifestPath:s,includeList:r.icons,excludeList:n.public}).apply(e),new fs({manifestPath:s,includeList:{...r.scripts,...n.scripts},excludeList:n.public}).apply(e),new gs({manifestPath:s}).apply(e)}};var Be=a(require("path"));var Qo=a(require("path")),ea=a(require("ws"));function ys(t,e){t.clients.forEach(s=>{s.readyState===ea.default.OPEN&&s.send(JSON.stringify(e))})}function ta(t,e,s){if(!s||!e)return;let r=de({manifestPath:e}).locales,n=de({manifestPath:e}).scripts,i=de({manifestPath:e}).json;if(!t){process.env.EXTENSION_ENV==="development"&&console.error("WebSocket server is not running.");return}Qo.default.basename(s)==="manifest.json"&&ys(t,{changedFile:"manifest.json"}),r?.forEach(o=>{o.includes(s)&&ys(t,{changedFile:"_locales"})}),Object.entries(n).forEach(([o,c])=>{let p=Array.isArray(c)?c:[c];Object.values(p).flatMap(u=>u).includes(s)&&o==="background/service_worker"&&ys(t,{changedFile:"service_worker"})}),Object.entries(i).forEach(([o,c])=>{c?.includes(s)&&o==="declarative_net_request"&&ys(t,{changedFile:"declarative_net_request"})})}var vr=a(require("path")),ia=a(require("fs")),We=a(require("ws"));var Ue=a(require("path")),ml=a(require("http")),ra=a(require("https")),xr=a(require("fs"));var sa=t=>{if(!xr.default.existsSync(t))return;let e=Ue.default.basename(t);return xr.default.readFileSync(Ue.default.join(__dirname,"certs",e))};function na(t,e){let s={key:sa(Ue.default.join(__dirname,"certs","localhost.key")),cert:sa(Ue.default.join(__dirname,"certs","localhost.cert"))},r=ra.default.createServer(s,(n,i)=>{i.writeHead(200),i.end()});return r.on("error",n=>{throw console.error(kn(t,e)),new Error(n.message)}),{server:r,port:e}}function dl(t,e,s){switch(s){case"chrome":return new We.default.Server({host:"localhost",port:e});case"edge":return new We.default.Server({host:"localhost",port:e+1});case"firefox":return new We.default.Server({server:na(t,e+2).server});default:return new We.default.Server({host:"localhost",port:8888})}}async function oa(t,e){let s=t.options.context||"",r=require(vr.default.join(s,"manifest.json")),n=r.name||"Extension.js",o=dl(n,8e3,e.browser);if(o.on("connection",c=>{c.send(JSON.stringify({status:"serverReady"})),c.on("error",p=>{console.log(vn(n,p))}),c.on("message",p=>{let l=JSON.parse(p.toString());if(l.status==="clientReady"){let u=require(vr.default.join(s,"manifest.json"));setTimeout(()=>{console.log(Gs(u,e.browser,l)),console.log("")},2500),Ln(e.browser)&&setTimeout(()=>{console.log(xn(e.browser))},5e3)}})}),(e.browser==="firefox"||e.browser==="gecko-based")&&!ia.default.existsSync(st)){let c=In(r);console.log(Gs(r,e.browser,c)),console.log(""),console.log(Pn()),console.log("")}return o}var aa=a(require("path")),_r=a(require("fs"));function ca(t,e){let s=aa.default.resolve(__dirname,`./extensions/${t}-manager-extension/reload-service.js`);try{let r=_r.default.readFileSync(s,"utf8"),n=r.replace(/__RELOAD_PORT__/g,e.toString());n!==r&&_r.default.writeFileSync(s,n,"utf8")}catch(r){console.error(`Error processing file: ${r.message}`)}}process.on("SIGINT",()=>{process.exit()});process.on("SIGTERM",()=>{process.exit()});var Je=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;ca(this.browser,this.port);let s=await oa(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,n)=>{let o=(r.modifiedFiles||new Set).values().next().value;if(!o){n();return}let c=Be.default.relative(Be.default.dirname(this.manifestPath),o),p=Be.default.relative(process.cwd(),Be.default.dirname(o));process.env.EXTENSION_ENV==="development"&&console.info(`\u25BA\u25BA Updated file \`${c}\` (relative to ${p})`),this.manifestPath&&ta(s,this.manifestPath,o),n()})}};var Sr=a(require("path"));function pa(t,e,s){t.options.module.rules.push({test:/\.(js|mjs|jsx|mjsx|ts|mts|tsx|mtsx)$/,include:[Sr.default.dirname(s)],exclude:/node_modules/,use:[{loader:Sr.default.resolve(__dirname,"./inject-chromium-client-loader"),options:{manifestPath:s,browser:e}}]})}var Pr=a(require("path"));function la(t,e,s){t.options.module.rules.push({test:/\.(js|mjs|jsx|mjsx|ts|mts|tsx|mtsx)$/,include:[Pr.default.dirname(s)],exclude:/node_modules/,use:[{loader:Pr.default.resolve(__dirname,"./inject-firefox-client-loader"),options:{manifestPath:s,browser:e}}]})}var ws=require("webpack");var kr=a(require("content-security-policy-parser"));function fa(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,kr.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 ua(t){let e=t.content_security_policy;if(!e)return{extension_pages:"script-src 'self'; object-src 'self'; "};let s=(0,kr.default)(e.extension_pages||""),r="";for(let n in s)r+=`${n} ${s.get(n)?.join(" ")}; `;return{extension_pages:r.trim()}}function ma(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 n of e)r.has(n)||r.add(n);return Array.from(r)}function da(t){let e=["/*.json","/*.js","/*.css"];return[...t.web_accessible_resources||[],{resources:e,matches:["<all_urls>"]}]}function Er(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 jr(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 bs=class{manifestPath;browser;constructor(e){this.manifestPath=e.manifestPath,this.browser=e.browser||"chrome"}generateManifestPatches(e){let s=B(e,this.manifestPath),r={...s,content_security_policy:s.manifest_version===3?ua(s):fa(s),...s.manifest_version===3?s.permissions?{permissions:[...new Set(["scripting",...s.permissions])]}:{permissions:["scripting"]}:{},...Er(s,this.browser),...jr(s),web_accessible_resources:s.manifest_version===3?da(s):ma(s)},n=JSON.stringify(r,null,2),i=new ws.sources.RawSource(n);e.getAsset("manifest.json")&&e.updateAsset("manifest.json",i)}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:ws.Compilation.PROCESS_ASSETS_STAGE_SUMMARIZE},r=>{if(!this.manifestPath){let n="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: ${n}`));return}this.generateManifestPatches(s)})})}};var $r=a(require("fs")),xe=a(require("path")),ga=a(require("webpack-target-webextension"));var xs=class{manifestPath;browser;constructor(e){this.manifestPath=e.manifestPath,this.browser=e.browser||"chrome"}handleBackground(e,s,r){let n=xe.default.resolve(__dirname,s==="firefox"||s==="gecko-based"?"minimum-firefox-file.mjs":"minimum-chromium-file.mjs"),i=xe.default.dirname(this.manifestPath),o=r.background;if(s==="firefox"||s==="gecko-based"){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=xe.default.join(i,c[0]);this.ensureFileExists(p,"background.scripts")}else this.addDefaultEntry(e,"background/script",n)}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=xe.default.join(i,c);this.ensureFileExists(p,"background.service_worker")}else this.addDefaultEntry(e,"background/service_worker",n)}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=xe.default.join(i,c[0]);this.ensureFileExists(p,"background.scripts")}else this.addDefaultEntry(e,"background/script",n)}}ensureFileExists(e,s){if(!$r.default.existsSync(e)&&this.manifestPath){let n=require(this.manifestPath).name||"Extension.js",i=_n(n,s,e);throw console.error(i),new Error(i)}}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||!$r.default.lstatSync(this.manifestPath).isFile())return;let s=require(this.manifestPath);this.handleBackground(e,this.browser,s),new ga.default({background:this.getEntryName(s),weakRuntimeCheck:!0}).apply(e)}};var Cr=class{manifestPath;browser;constructor(e){this.manifestPath=e.manifestPath,this.browser=e.browser||"chrome"}apply(e){(Q.includes(this.browser)||this.browser==="chromium-based")&&pa(e,this.browser,this.manifestPath),(this.browser==="firefox"||this.browser==="gecko-based")&&la(e,this.browser,this.manifestPath),new bs({manifestPath:this.manifestPath,browser:this.browser}).apply(e),new xs({manifestPath:this.manifestPath,browser:this.browser}).apply(e)}},ha=Cr;var vs=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 Je({manifestPath:this.manifestPath,browser:this.browser,port:this.port,stats:this.stats}).apply(e),e.options.mode==="development"&&new ha({manifestPath:this.manifestPath,browser:this.browser,autoReload:this.autoReload,stats:this.stats}).apply(e)}};var ya=a(require("webpack")),_s=class{manifestPath;browser;constructor(e){this.manifestPath=e.manifestPath,this.browser=e.browser}apply(e){new ya.default.ProvidePlugin({browser:require.resolve("webextension-polyfill")}).apply(e)}};var Ps=require("webpack");var Ss=class{browser;manifestPath;constructor(e){this.manifestPath=e.manifestPath,this.browser=e.browser||"chrome"}patchManifest(e){let s=ce(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:Ps.Compilation.PROCESS_ASSETS_STAGE_OPTIMIZE},()=>{let r=B(s,this.manifestPath),n=this.patchManifest(r),i=new Ps.sources.RawSource(n);s.updateAsset("manifest.json",i)})})}};var ks=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 _s({manifestPath:this.manifestPath,browser:this.browser||"chrome"}).apply(e),new Ss({manifestPath:this.manifestPath,browser:this.browser||"chrome"}).apply(e)}};var $a=a(require("fs"));var ba=a(require("webpack")),wa=a(require("content-security-policy-parser"));function xa(t){let e=t.content_security_policy,s=t.content_security_policy?.extension_pages,r=n=>{if(!n)return;let i=(0,wa.default)(n);if(i.get("script-src")&&i.get("script-src")?.includes("'unsafe-eval'")){let o=t.name||"Extension.js";return on(o)}};if(t.manifest_version===3){let n=e?r(s):void 0;if(n)return new ba.default.WebpackError(n)}return null}var Fr=a(require("webpack"));function va(t,e){let s=t.web_accessible_resources;if(s){let r=s.some(o=>typeof o=="string"),n=s.some(o=>typeof o=="object"||o.resources||o.matches),i=t.name||"Extension.js";if(t.manifest_version===2&&!r)return new Fr.default.WebpackError(cn(i,e));if(t.manifest_version===3&&!n)return new Fr.default.WebpackError(pn(i,e))}return null}var _a=a(require("webpack"));function Sa(t,e){if((e==="firefox"||e==="gecko-based")&&t.background?.service_worker){let s=t.name||"Extension.js";return new _a.default.WebpackError(nn(s))}return null}var Pa=a(require("path")),ka=a(require("fs")),Ea=a(require("webpack"));function ja(t,e){let s=Pa.default.join(e.options.context||"","_locales"),r=t.name||"Extension.js";return ka.default.existsSync(s)&&!t.default_locale?new Ea.default.WebpackError(an(r)):null}var Es=class{options;constructor(e){this.options=e}handleRuntimeErrors(e,s,r){let n=xa(s),i=va(s,r),o=Sa(s,r),c=ja(s,e);n&&e.errors.push(n),i&&e.errors.push(i),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 n=this.options.manifestPath,i=JSON.parse($a.default.readFileSync(n,"utf-8")),o=this.options.browser||"chrome";this.handleRuntimeErrors(s,i,o),r()})}};var Ta=a(require("fs")),qa=a(require("ajv"));var Ca={$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 Fa(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 Da=a(require("path")),La=require("webpack");function Ia(t,e,s){let r=t.options.context||"",n=Da.default.join(r,"manifest.json"),o=require(n).name||"Extension.js",c=e?.params.missingProperty;t.errors.push(new La.WebpackError(un(o,s,c)))}var Oa=a(require("path")),Ma=require("webpack");function Aa(t,e,s){let r=t.options.context||"",n=Oa.default.join(r,"manifest.json"),o=require(n).name||"Extension.js";t.warnings.push(new Ma.WebpackError(fn(o,e,s)))}var Ra=a(require("path")),Na=require("webpack");function Dr(t,e,s){let r=t.options.context||"",n=Ra.default.join(r,"manifest.json"),o=require(n).name||"Extension.js";t.warnings.push(new Na.WebpackError(ln(o,s,e)))}var js=class{options;constructor(e){this.options=e}handleSchemaErrors(e,s,r){let n=new qa.default;Fa(n);let i={allOf:[Ca]},o=n.compile(i),c=o(s),p=s.manifest_version===3;if(!c&&o.errors){let l=o.errors[0];if(l?.keyword==="required"){Ia(e,l,r);return}p&&(l?.keyword==="type"&&Aa(e,l,r),l?.keyword==="not"&&Dr(e,l,r))}}apply(e){e.hooks.afterCompile.tapAsync("CompatPlugin (module)",(s,r)=>{let n=this.options.manifestPath,i=JSON.parse(Ta.default.readFileSync(n,"utf-8")),o=this.options.browser||"chrome";this.handleSchemaErrors(s,i,o),r()})}};var Ba=a(require("fs")),Ir=a(require("path"));var Lr=a(require("webpack"));function Ua(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 Lr.default.WebpackError(mn(t,r))}return null}function Wa(t,e){let s=require(t);return e.message.includes("Top-level-await is only supported in EcmaScript Modules")?new Lr.default.WebpackError(dn(s.name)):null}var $s=class{manifestPath;constructor(e){this.manifestPath=e.manifestPath}apply(e){let s=Ir.default.join(Ir.default.dirname(this.manifestPath),"package.json");if(!Ba.default.existsSync(s))return;let r=require(s).name;e.hooks.compilation.tap("develop:common-errors",n=>{n.hooks.afterSeal.tapAsync("develop:common-errors",i=>{n.errors.forEach((o,c)=>{let p=Ua(r,o),l=Wa(r,o);p&&(n.errors[c]=p),l&&(n.errors[c]=l)}),i()})})}};var Cs=class{static name="plugin-errors";manifestPath;browser;constructor(e){this.manifestPath=e.manifestPath,this.browser=e.browser||"chrome"}apply(e){new Es({manifestPath:this.manifestPath,browser:this.browser||"chrome"}).apply(e),new js({manifestPath:this.manifestPath,browser:this.browser||"chrome"}).apply(e),new $s({manifestPath:this.manifestPath}).apply(e)}};var rp=a(require("os")),Tr=a(require("path"));var uc=a(require("fs")),mc=a(require("path")),dc=require("child_process");var te=a(require("path")),Ve=a(require("fs"));var Ja={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={...Ja},Ha={...Ja};var b=require("@colors/colors/safe");function E(t,e){let s=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 ${ze(t)} ${(0,b.red)("\u2716\uFE0E\u2716\uFE0E\u2716\uFE0E")}`:(0,b.brightGreen)("\u25BA\u25BA\u25BA");return`${(0,b.gray)("")}${s}`}function ze(t){return t.charAt(0).toUpperCase()+t.slice(1)}function Fs(t){let e=ze(t);return`${E(t,"info")} Creating new ${e} user profile...`}function Va(t){return`${E(t,"success")} Instance already running.`}function Ga(t){return`${E(t,"info")} Instance exited.`}function Ds(t,e){let s=t==="firefox"||t==="gecko-based"?"Add-on":"Extension";return`${E(t,"success")} ${ze(t)} ${s} running in ${(0,b.brightBlue)(e||"unknown")} mode.`}function He(t,e){let s=e=="null"?`Browser is not installed
111
111
 
112
112
  `:`Can't find the browser path
113
113
 
114
- `;return`${k(t,"error")} ${s}Either install the missing browser or choose a different one via ${(0,b.brightYellow)("--browser")} flag.
115
- ${(0,b.red)("NOT FOUND")} ${(0,b.underline)(e||Ve(t)+"BROWSER")}`}function Ha(t){return`${k(t,"error")} No Service Worker Support
114
+ `;return`${E(t,"error")} ${s}Either install the missing browser or choose a different one via ${(0,b.brightYellow)("--browser")} flag.
115
+ ${(0,b.red)("NOT FOUND")} ${(0,b.underline)(e||ze(t)+"BROWSER")}`}function Xa(t){return`${E(t,"error")} No Service Worker Support
116
116
 
117
117
  Firefox does not support the ${(0,b.brightYellow)("background.service_worker")} field yet.
118
118
  Update your manifest.json file to use ${(0,b.brightYellow)("background.scripts")} instead.
119
119
 
120
- Read more: ${(0,b.underline)("https://bugzilla.mozilla.org/show_bug.cgi?id=1573659")}.`}function Va(t,e){return`${k(t,"error")} Error launching browser:
121
- ${(0,b.red)(e)}`}function Ga(t,e){return`${k(t,"error")} ${(0,b.red)(e.stack)}`}function Xa(t){return`${k(t,"error")} Unable to connect to ${Ve(t)}. Too many retries.`}function Za(t,e){return`${k(t,"error")} Error while installing temporary addon:
122
- ${(0,b.red)(e)}`}function Ya(t,e){return`${k(t,"error")} Path is not directory
120
+ Read more: ${(0,b.underline)("https://bugzilla.mozilla.org/show_bug.cgi?id=1573659")}.`}function Za(t,e){return`${E(t,"error")} Error launching browser:
121
+ ${(0,b.red)(e)}`}function Ya(t,e){return`${E(t,"error")} ${(0,b.red)(e.stack)}`}function Ka(t){return`${E(t,"error")} Unable to connect to ${ze(t)}. Too many retries.`}function Qa(t,e){return`${E(t,"error")} Error while installing temporary addon:
122
+ ${(0,b.red)(e)}`}function ec(t,e){return`${E(t,"error")} Path is not directory
123
123
 
124
124
  Please provide a valid directory path and try again.
125
- ${(0,b.red)("NOT DIRECTORY")} ${(0,b.underline)(e)}`}function Ka(t){return`${k(t,"error")} Error parsing message length.`}function Qa(t){return`${k(t,"error")} ${(0,b.magenta)("MessagingClient")} connection closed.`}function ec(t,e){return`${k(t,"error")} Unexpected ${(0,b.magenta)("MessagingClient")} request without target actor: ${(0,b.brightYellow)(e)}`}function tc(t){return`${k(t,"error")} ${(0,b.magenta)("MessagingClient")} connection closed.`}function sc(t,e){return`${k(t,"error")} Target actor ${(0,b.brightYellow)(e)} already has an active request.`}function rc(t,e){return`${k(t,"error")} Error parsing packet: ${(0,b.red)(e)}`}function nc(t,e){return`${k(t,"error")} Message received without a sender actor:
126
- ${(0,b.brightYellow)(JSON.stringify(e))}`}function ic(t,e){return`${k(t,"error")} Received unexpected message:
127
- ${(0,b.red)(e)}`}var oc=a(require("progress"));function Fs(t,e){let r=new oc.default(`${t} [:bar] :percent :etas`,{complete:"=",incomplete:" ",width:50,total:131072}),n=setInterval(()=>{let i=Math.random()*10*1024;r.tick(i),r.complete&&(clearInterval(n),e())},50)}function ac(t,e,s){if(e&&Xe.default.existsSync(e))return e;if(Xe.default.existsSync(se.default.resolve(__dirname,`run-${t}-profile`)))return se.default.resolve(__dirname,`run-${t}-profile`);let n=JSON.stringify(t==="chrome"?Wa:Ba);return s||Fs($s(t),()=>{let i=se.default.resolve(__dirname,`run-${t}-profile`),o=se.default.join(i,"Default");Xe.default.mkdirSync(o,{recursive:!0});let c=se.default.join(o,"Preferences");Xe.default.writeFileSync(c,n,"utf8")}),se.default.resolve(__dirname,`run-${t}-profile`)}function cc(t){let e=Array.isArray(t.extension)?t.extension:[t.extension],s=ac(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 _e=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}pc.default.existsSync(s)||(console.error(Ge(e,s)),process.exit());let r=cc(this),n=this.startingUrl?[this.startingUrl,...r]:[...r],i=process.env.EXTENSION_ENV==="development"?"inherit":"ignore",o=(0,lc.spawn)(s,n,{stdio:i});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,n)=>{if(r.compilation.errors.length>0){n();return}if(s){n();return}this.launchChromium(this.browser),setTimeout(()=>{console.log(Cs(this.browser,r.compilation.options.mode))},2e3),s=!0,n()})}};var Dr=a(require("fs")),Pc=a(require("path")),Lr=require("child_process");var Ze=a(require("fs")),Ds=a(require("path")),fc=a(require("os")),mc=a(require("which")),uc=process.platform==="darwin",ll=process.platform==="win32",fl=!uc&&!ll;function ml(){if(fl)try{return mc.default.sync("firefox")}catch{return null}else if(uc){let t="/Applications/Firefox.app/Contents/MacOS/firefox",e=Ds.default.join(fc.default.homedir(),t.slice(1));return Ze.default.existsSync(t)?t:Ze.default.existsSync(e)?e:null}else{let t=Ds.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 n=Ds.default.join(r,t);if(Ze.default.existsSync(n))return n}let s=["C:\\Program Files\\Mozilla Firefox\\firefox.exe","C:\\Program Files (x86)\\Mozilla Firefox\\firefox.exe"];for(let r of s)if(Ze.default.existsSync(r))return r;return null}}var Ls=ml();var gc=a(require("path")),Is=a(require("fs")),Fr=a(require("firefox-profile"));var ul={"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 dc(t){return{...ul,...t}}function hc(t,e){let s=dc(e);Object.keys(s).forEach(i=>{t.setPreference(i,s[i])});let n=Object.keys(e);return n.length>0&&n.forEach(i=>{t.setPreference(i,e[i])}),t.updatePreferences(),t}function dl(t,e){let s=new Fr.default({destinationDirectory:t});return hc(s,e)}function gl(t,e,s){let r;if(Is.default.statSync(e).isDirectory())r=e;else throw new Error(Ya(t,e));let i=new Fr.default({destinationDirectory:r});return hc(i,s)}function yc(t,e,s,r){let n,i=e||gc.default.resolve(__dirname,"run-firefox-data-dir");return Is.default.existsSync(i)?n=gl(t,i,s||{}):(r||Fs($s(t),()=>{}),Is.default.mkdirSync(i,{recursive:!0}),n=dl(i,s||{})),n}async function bc(t,e){let{browser:s,startingUrl:r,preferences:n,userDataDir:i,browserConsole:o=!1,browserFlags:c=[]}=e,p=yc(s,i,n),l=[];r&&l.push(`--url "${r}"`),o&&l.push("--jsconsole"),c&&l.push(...c);let m=t.options.devServer?.port?t.options.devServer?.port+100:9222;return[`--binary-args "${c.join(" ")}"`,`--profile "${p.path()}"`,`--listen ${m}`,"--verbose"].join(" ")}var Sc=a(require("path"));var wc=a(require("net")),xc=a(require("events"));function hl(t,e){let s=e.toString(),r=s.indexOf(":");if(r<1)return{remainingData:e};let n=parseInt(s.substring(0,r),10);if(isNaN(n))return{remainingData:e,error:new Error(Ka(t)),fatal:!0};if(e.length-(r+1)<n)return{remainingData:e};let i=e.slice(r+1,r+1+n),o=e.slice(r+1+n);try{let c=JSON.parse(i.toString());return{remainingData:o,parsedMessage:c}}catch(c){return{remainingData:o,error:c,fatal:!1}}}var Os=class extends xc.default{incomingData=Buffer.alloc(0);pendingRequests=[];activeRequests=new Map;connection;async connect(e){await new Promise((s,r)=>{try{let n={port:e,host:"127.0.0.1"},i=wc.default.createConnection(n,()=>{s()});this.connection=i,i.on("data",this.onData.bind(this)),i.on("error",r),i.on("end",this.onEnd.bind(this)),i.on("timeout",this.onTimeout.bind(this)),this.expectReply("root",{resolve:s,reject:r})}catch(n){r(n)}})}disconnect(){this.connection&&(this.connection.removeAllListeners(),this.connection.end(),this.rejectAllRequests(new Error(Qa("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(ec("firefox",s.type));return await new Promise((r,n)=>{let i={resolve:r,reject:n};this.pendingRequests.push({request:s,deferred:i}),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(tc("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(sc("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:n}=hl("firefox",this.incomingData);return this.incomingData=e,r?(this.emit("error",new Error(rc("firefox",r))),n&&this.disconnect(),!n):s?(this.handleMessage(s),!0):!1}handleMessage(e){if(!e.from){this.emit("error",new Error(nc("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(ic("firefox",JSON.stringify(e))))}onError(e){this.emit("error",e)}onEnd(){this.emit("end")}onTimeout(){this.emit("timeout")}};function vc(t){return t instanceof Error?String(t):`${t.error}: ${t.message}`}function _c(t,e){return Array.isArray(t)&&t.includes(e.code)?!0:e.code===t}var yl=150,bl=1e3,Ms=class{options;constructor(e){this.options=e}async connectClient(e){let s;for(let r of Array.from({length:yl}))try{let n=new Os;return await n.connect(e),n}catch(n){if(_c("ECONNREFUSED",n))await new Promise(i=>setTimeout(i,bl)),s=n;else throw console.error(Ga(this.options.browser,n.stack)),n}throw console.error(Xa(this.options.browser)),s}async installAddons(e){let{devtools:s}=this.options,r=Array.isArray(this.options.extension)?this.options.extension:[this.options.extension],n=e.options.devServer?.port,i=n?n+100:9222,o=await this.connectClient(i);for(let[c,p]of r.entries()){let l=Sc.default.join(p.replace(/"/g,"")),m=c===0&&s;try{let d=await o.request({to:"root",type:"getRoot"});await o.request({to:d.addonsActor,type:"installTemporaryAddon",addonPath:l,openDevTools:m})}catch(d){let g=vc(d);throw new Error(Za(this.options.browser,g))}}}};var re=null;process.on("SIGINT",()=>{re&&re.kill("SIGINT"),process.exit()});process.on("SIGTERM",()=>{re&&re.kill("SIGTERM"),process.exit()});var As=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 getFxRunnerCommand(){let e=Pc.default.join(process.cwd(),"node_modules",".bin","fx-runner"),s=ae()?"pnpm dlx -y fx-runner":"npx -y fx-runner";if(Dr.default.existsSync(e))return e;try{return await new Promise((r,n)=>{(0,Lr.exec)(`${s} --version`,i=>{i?n(i):r(null)})}),s}catch{console.error(Ge("firefox",e)),process.exit(1)}}async launchFirefox(e){let r=`${await this.getFxRunnerCommand()} start --binary "${Ls}" --foreground --no-remote`;Dr.default.existsSync(Ls||"")||(console.error(Ge(this.browser,Ls||"")),process.exit(1));let n=await bc(e,this),i=`${r} ${n}`;re=(0,Lr.exec)(i,(c,p,l)=>{if(c!=null)throw c;l.includes("Unable to move the cache")?console.log(Ja(this.browser)):(console.log(za(this.browser)),process.exit())}),process.env.EXTENSION_ENV==="development"&&(re.stdout?.pipe(process.stdout),re.stderr?.pipe(process.stderr));let o=new Ms(this);try{await o.installAddons(e)}catch(c){c?.toString()?.includes("background.service_worker is currently disabled")&&(console.error(Ha(this.browser)),process.exit(1)),console.error(Va(this.browser,c)),process.exit(1)}}apply(e){let s=!1;e.hooks.done.tapAsync("run-firefox:module",async(r,n)=>{if(r.compilation.errors.length>0){n();return}if(s){n();return}setTimeout(()=>{console.log(Cs(this.browser,r.compilation.options.mode))},2e3),await this.launchFirefox(e),s=!0,n()})}};var Rs=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"?Ir.default.join(kc.default.tmpdir(),"extension-js",s,"profile"):Ir.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 _e({...s,browser:"chrome"}).apply(e);break}case"edge":new _e({...s,browser:"edge"}).apply(e);break;case"firefox":new As({...s,browser:"firefox"}).apply(e);break;default:{new _e({...s,browser:this.browser}).apply(e);break}}}};function J(t,e){let s=Ye.default.join(t,"manifest.json"),r=Ye.default.join(t,`dist/${e.browser}`),n=require(s);return{mode:e.mode||"development",entry:{},target:"web",context:t,devtool:n.manifest_version===3?"cheap-source-map":"eval-cheap-source-map",output:{clean:{keep(i){return!i.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",Ye.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 ot({manifestPath:s}),new gt({manifestPath:s,mode:e.mode}),new dt({manifestPath:s,mode:e.mode}),new xt({manifestPath:s,mode:e.mode}),process.env.EXTENSION_ENV==="development"&&new js({manifestPath:s,browser:e.browser}),new Ss({manifestPath:s,browser:e.browser,polyfill:e.polyfill}),new ds({manifestPath:s,browser:e.browser,mode:e.mode}),new ws({manifestPath:s,browser:e.browser,stats:!0,port:e.port||8e3}),!e.noOpen&&new Rs({extension:[r,Ye.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 Qe=a(require("path")),sp=a(require("go-git-it"));var Ke=a(require("path")),Ns=a(require("fs")),u=require("@colors/colors/safe");function _(t){return`${t==="warn"?(0,u.brightYellow)("\u25BA\u25BA\u25BA"):t==="info"?(0,u.cyan)("\u25BA\u25BA\u25BA"):t==="error"?`${(0,u.bold)((0,u.red)("ERROR"))} in Extension.js ${(0,u.red)("\u2716\uFE0E\u2716\uFE0E\u2716\uFE0E")}`:(0,u.brightGreen)("\u25BA\u25BA\u25BA")}`}function Y(t){return`${_("error")} Manifest file not found.
125
+ ${(0,b.red)("NOT DIRECTORY")} ${(0,b.underline)(e)}`}function tc(t){return`${E(t,"error")} Error parsing message length.`}function sc(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 nc(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 ac(t,e){return`${E(t,"error")} Message received without a sender actor:
126
+ ${(0,b.brightYellow)(JSON.stringify(e))}`}function cc(t,e){return`${E(t,"error")} Received unexpected message:
127
+ ${(0,b.red)(e)}`}var pc=a(require("progress"));function Ls(t,e){let r=new pc.default(`${t} [:bar] :percent :etas`,{complete:"=",incomplete:" ",width:50,total:131072}),n=setInterval(()=>{let i=Math.random()*10*1024;r.tick(i),r.complete&&(clearInterval(n),e())},50)}function lc(t,e,s){if(e&&Ve.default.existsSync(e))return e;if(Ve.default.existsSync(te.default.resolve(__dirname,`run-${t}-profile`)))return te.default.resolve(__dirname,`run-${t}-profile`);let n=JSON.stringify({...t==="chrome"?za:Ha,...s});return Ls(Fs(t),()=>{let i=te.default.resolve(__dirname,`run-${t}-profile`),o=te.default.join(i,"Default");Ve.default.mkdirSync(o,{recursive:!0});let c=te.default.join(o,"Preferences");Ve.default.writeFileSync(c,n,"utf8")}),te.default.resolve(__dirname,`run-${t}-profile`)}function fc(t){let e=Array.isArray(t.extension)?t.extension:[t.extension],s=lc(t.browser,t.profile,t.preferences);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 Ge=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 s;switch(e){case"chrome":s=require(`${e}-location`);break;case"edge":s=require(`${e}-location`)();break;case"chromium-based":s=mc.default.normalize(this.chromiumBinary);break;default:s=require(`${e}`);break}uc.default.existsSync(s)||(console.error(He(e,s)),process.exit());let r=fc(this);console.log("asdlasdlasdaldjsalds",this.startingUrl);let n=this.startingUrl?[this.startingUrl,...r]:[...r],i=process.env.EXTENSION_ENV==="development"?"inherit":"ignore",o=(0,dc.spawn)(`${s}`,n,{stdio:i});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,n)=>{if(r.compilation.errors.length>0){n();return}if(s){n();return}this.launchChromium(this.browser),setTimeout(()=>{console.log(Ds(this.browser,r.compilation.options.mode))},2e3),s=!0,n()})}};var tp=a(require("fs")),sp=a(require("path")),Nr=require("child_process");var Xe=a(require("fs")),Is=a(require("path")),gc=a(require("os")),hc=a(require("which")),yc=process.platform==="darwin",hl=process.platform==="win32",yl=!yc&&!hl;function bl(){if(yl)try{return hc.default.sync("firefox")}catch{return null}else if(yc){let t="/Applications/Firefox.app/Contents/MacOS/firefox",e=Is.default.join(gc.default.homedir(),t.slice(1));return Xe.default.existsSync(t)?t:Xe.default.existsSync(e)?e:null}else{let t=Is.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 n=Is.default.join(r,t);if(Xe.default.existsSync(n))return n}let s=["C:\\Program Files\\Mozilla Firefox\\firefox.exe","C:\\Program Files (x86)\\Mozilla Firefox\\firefox.exe"];for(let r of s)if(Xe.default.existsSync(r))return r;return null}}var bc=bl();var Ar=a(require("path")),Ns=a(require("fs")),Rr=a(require("firefox-profile"));var wl={"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 Or(t){return{...wl,...t}}var Ye=a(require("fs")),Ke=a(require("path"));var Ze=a(require("path")),Os=a(require("fs")),m=require("@colors/colors/safe");function S(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 X(t){return`${S("error")} Manifest file not found.
128
128
 
129
129
  Ensure the path to your extension exists and try again.
130
- ${(0,u.red)("NOT FOUND")} ${(0,u.underline)(t)}`}function Ts(t){let e=t==="firefox"?"Add-on":"Extension";return`${_("info")} Building ${ne(t)} ${e} package...`}function qs(t,e){let s=Ke.default.join(t,"dist",e.browser||"chrome"),r=Ke.default.join(s,"manifest.json"),n=require(r),{name:i,version:o,hostPermissions:c,permissions:p}=n,l=Ec(t,n).defaultLocale,m=Ec(t,n).otherLocales.join(", "),d=`${l} ${m&&", "+m}`,g=c&&c.length,y=p&&p.length,E=Js().version;return`
131
- \u{1F9E9} ${(0,u.brightGreen)("Extension.js")} ${(0,u.gray)(`${E}`)}
132
- Extension Name ${(0,u.gray)(i)}
133
- Extension Version ${(0,u.gray)(o)}
134
- Locales ${(0,u.gray)(d)}
135
- Host Permissions ${(0,u.gray)(g?c.join(", "):"Browser defaults")}
136
- Permissions ${(0,u.gray)(y?p.join(", "):"Browser defaults")}
137
- `}function jc(t,e){let s=t==="production"?u.brightBlue:u.brightBlue,r=e==="firefox"?"Add-on":"Extension";return`${_("success")} ${ne(e)} ${r} ready for ${s(t||"unknown")}.`}function $c(t,e,s){let r=e?.toJson(),n=Ke.default.join(t,"manifest.json"),i=JSON.parse(Ns.default.readFileSync(n,"utf8")),o=r?.assets,c=`${_("info")} Building ${(0,u.cyan)(i.name)} extension using ${ne(s)} defaults...
130
+ ${(0,m.red)("NOT FOUND")} ${(0,m.underline)(t)}`}function Ms(t){let e=t==="firefox"||t==="gecko-based"?"Add-on":"Extension";return`${S("info")} Building ${se(t)} ${e} package...`}function As(t,e){let s=Ze.default.join(t,"dist",e.browser||"chrome"),r=Ze.default.join(s,"manifest.json"),n=require(r),{name:i,version:o,hostPermissions:c,permissions:p}=n,l=wc(t,n).defaultLocale,u=wc(t,n).otherLocales.join(", "),d=`${l} ${u&&", "+u}`,g=c&&c.length,h=p&&p.length,v=Hs().version;return`
131
+ \u{1F9E9} ${(0,m.brightGreen)("Extension.js")} ${(0,m.gray)(`${v}`)}
132
+ Extension Name ${(0,m.gray)(i)}
133
+ Extension Version ${(0,m.gray)(o)}
134
+ Locales ${(0,m.gray)(d)}
135
+ Host Permissions ${(0,m.gray)(g?c.join(", "):"Browser defaults")}
136
+ Permissions ${(0,m.gray)(h?p.join(", "):"Browser defaults")}
137
+ `}function xc(t,e){let s=t==="production"?m.brightBlue:m.brightBlue,r=e==="firefox"||e==="gecko-based"?"Add-on":"Extension";return`${S("success")} ${se(e)} ${r} ready for ${s(t||"unknown")}.`}function vc(t,e,s){let r=e?.toJson(),n=Ze.default.join(t,"manifest.json"),i=JSON.parse(Os.default.readFileSync(n,"utf8")),o=r?.assets,c=`${S("info")} Building ${(0,m.cyan)(i.name)} extension using ${se(s)} defaults...
138
138
 
139
139
  `,p=`
140
- Build completed in ${((r?.time||0)/1e3).toFixed(2)} seconds.`,l=`Build Target: ${(0,u.gray)(ne(s))}
141
- `,m=`Build Status: ${e?.hasErrors()?(0,u.red)("Failed"):(0,u.brightGreen)("Success")}
140
+ Build completed in ${((r?.time||0)/1e3).toFixed(2)} seconds.`,l=`Build Target: ${(0,m.gray)(se(s))}
141
+ `,u=`Build Status: ${e?.hasErrors()?(0,m.red)("Failed"):(0,m.brightGreen)("Success")}
142
142
  `,d=`
143
- Version: ${(0,u.gray)(i.version)}
144
- `,g=`Size: ${(0,u.gray)(wl(o))}
145
- `,y="";return y+=c,y+=xl(o),y+=d,y+=g,y+=l,y+=m,y+=p,y}function Cc(){return`${_("success")} No errors or warnings found. Your extension is ${(0,u.brightGreen)("ready for deployment")}.`}function Fc(t,e){return`${_("info")} Fetching data...
146
- ${(0,u.gray)("URL")} ${(0,u.underline)(`https://github.com/${t}/${e}`)}`}function Dc(t){return`${_("info")} Downloading ${(0,u.cyan)(t)}...`}function Lc(t){return`
147
- ${_("info")} Creating a new browser extension...
148
- ${(0,u.gray)("PATH")} ${(0,u.underline)(`${t}`)}`}function Ic(t){return`${_("info")} No ${(0,u.brightYellow)(".gitignore")} found, zipping all the content inside path:
149
- ${(0,u.gray)("PATH")} ${(0,u.underline)(t)}`}function Oc(t){return`${_("info")} Packaging source files. Files in ${(0,u.brightYellow)(".gitignore")} will be excluded...
150
- ${(0,u.gray)("PATH")} ${(0,u.underline)(t)}.`}function Mc(t){return`${_("info")} Packaging extension distribution files...
151
- ${(0,u.gray)("PATH")} ${(0,u.underline)(t)}`}function Ac(t,e,s,r){return`\u{1F4E6} Package name: ${(0,u.brightYellow)(`${e}`)}, Target Browser: ${`${ne(t)}`}
152
- ${(0,u.gray)("\u2514\u2500")} ${(0,u.underline)(`${s}`)} (source)
153
- ${(0,u.gray)("\u2514\u2500")} ${(0,u.underline)(`${r}`)} (distribution)`}function Rc(t,e,s,r){return`\u{1F4E6} Package name: ${(0,u.brightYellow)(`${t}.${e}`)}, Target Browser: ${`${ne(s)}`}
154
- ${(0,u.gray)("\u2514\u2500")} ${(0,u.underline)(`${r}`)} ${(0,u.gray)("(distribution)")}`}function Nc(t,e,s,r){return`\u{1F4E6} Package name: ${(0,u.brightYellow)(`${t}-source.${e}`)}, Target Browser: ${`${ne(s)}`}
155
- ${(0,u.gray)("\u2514\u2500")} ${(0,u.underline)(`${r}`)} (source)`}function Tc(t){return`${_("error")} Failed to compress extension package.
156
- ${(0,u.red)(t)}`}function qc(t){return`${_("info")} Writing type definitions for ${(0,u.cyan)(t.name||"")}...`}function Uc(t){return`${_("error")} Failed to write the extension type definition.
157
- ${(0,u.red)(t)}`}function Wc(t){return`${_("info")} Downloading extension...
158
- ${(0,u.gray)("URL")} ${(0,u.underline)(t)}`}function Bc(t){return`${_("info")} Unpackaging browser extension...
159
- ${(0,u.gray)("PATH")} ${(0,u.underline)(t)}`}function Jc(){return`${_("info")} Browser extension unpackaged ${(0,u.brightGreen)("successfully")}. Compiling...`}function zc(t){return`${_("error")} Failed to download or extract ZIP file. ${(0,u.red)(t)}`}function ne(t){return t.charAt(0).toUpperCase()+t.slice(1)}function Ec(t,e){let s=e.default_locale,r=Ke.default.join(t,"_locales");if(!Ns.default.existsSync(r))return{defaultLocale:"Browser defaults",otherLocales:[]};let n=Ns.default.readdirSync(r).filter(i=>i!==s);return{defaultLocale:s,otherLocales:n}}function Hc(t){return`${(t/1024).toFixed(2)}KB`}function wl(t){let e=0;return t?.forEach(s=>{e+=s.size}),Hc(e)}function Vc(t,e=""){let s="";return Object.keys(t).forEach((r,n,i)=>{let o=n===i.length-1,c=o?"\u2514\u2500":"\u251C\u2500",p=t[r].size?` (${Hc(t[r].size)})`:"";s+=`${(0,u.gray)(e)}${(0,u.gray)(c)} ${r}${(0,u.gray)(p)}
160
- `,typeof t[r]=="object"&&!t[r].size&&(s+=Vc(t[r],`${e}${o?" ":(0,u.gray)("\u2502 ")}`))}),s}function xl(t){let e={};return t?.forEach(s=>{let r=s.name.split("/"),n=e;r.forEach((i,o)=>{n[i]||(n[i]={}),o===r.length-1?n[i]={size:s.size}:n=n[i]})}),`.
161
- ${Vc(e)}`}function Gc(t){return`${_("info")} Using ${(0,u.brightYellow)(t)}. ${(0,u.magenta)("This is very experimental")}.`}function Xc(t){return`${_("info")} Installing ${(0,u.cyan)(t)} dependencies...`}function Zc(t,e,s){return`${_("error")} Command ${t} ${e.join(" ")} failed with exit code ${s}`}function Yc(t){return`${_("error")} Can't install project dependencies. ${(0,u.red)(t.message||t.toString())}`}var Us=a(require("path")),Kc=a(require("axios")),Qc=a(require("adm-zip"));var Or=a(require("stream")),ep=require("util"),vl=(0,ep.promisify)(Or.default.pipeline);async function tp(t,e){let s=t.split("?")[0];try{console.log(Wc(s));let r=await(0,Kc.default)({url:t,method:"GET",responseType:"stream"}),n=Us.default.extname(s),i=Us.default.basename(s,n),o=Us.default.join(e,i);console.log(Bc(o));let c=[];await vl(r.data,new Or.default.Writable({write(m,d,g){c.push(m),g()}}));let p=Buffer.concat(c);return new Qc.default(p).extractAllTo(o,!0),console.log(Jc()),o}catch(r){throw console.error(zc(r)),r}}var _l=t=>{try{return new URL(t),!0}catch{return!1}};async function Sl(t,e){return await(0,sp.default)(t,process.cwd(),e),Qe.default.resolve(process.cwd(),Qe.default.basename(t))}async function Pl(t){return await tp(t,process.cwd())}async function K(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 Pl(t);let s=e.pathname.split("/"),r=s.slice(1,3)[0],n=s.slice(1,3)[1];console.log(Fc(r,n));let i=Qe.default.basename(e.pathname),o=await Sl(t,Dc(i));return console.log(Lc(i)),o}}return Qe.default.resolve(process.cwd(),t)}var z=a(require("path")),rp=a(require("fs")),np=a(require("ignore")),ip=a(require("tiny-glob")),Mr=a(require("adm-zip")),op=a(require("slugify"));function kl(t){try{return rp.default.readFileSync(t,"utf8")}catch{return""}}function El(t){return(0,op.default)(t,{replacement:"-",remove:/[^a-zA-Z0-9 ]/g,lower:!0})}function jl(t){switch(t){case"opera":return"crx";case"firefox":return"xpi";default:return"zip"}}function $l(t,e){let s=El(e.zipFilename||t.name);return e.zipFilename?s:`${s}-${t.version}`}async function Cl(t){let e=z.default.join(t,".gitignore"),s=kl(e),r=(0,np.default)();return s?r.add(s):console.log(Ic(t)),(await(0,ip.default)("**/*",{cwd:t,dot:!0})).filter(i=>!r.ignores(i))}async function ap(t,{browser:e="chrome",...s}){try{let r=z.default.join(t,"dist"),n=z.default.join(r,e),i=s.zipSource?t:n,o=require(z.default.join(i,"manifest.json")),c=$l(o,s),p=jl(e),l=z.default.join(n,`${c}.${p}`),m=z.default.join(r,`${c}-source.${p}`);if(s.zipSource){console.log(""),console.log(Oc(m));let d=new Mr.default;(await Cl(t)).forEach(y=>{d.addLocalFile(z.default.join(t,y),z.default.dirname(y))}),d.writeZip(m)}if(s.zip){console.log(""),console.log(Mc(l));let d=new Mr.default;d.addLocalFolder(n),d.writeZip(l)}s.zip&&s.zipSource?(console.log(""),console.log(Ac(e,c,m,l))):s.zip?(console.log(""),console.log(Rc(c,p,e,l))):s.zipSource&&(console.log(""),console.log(Nc(c,p,e,m)))}catch(r){throw console.error(Tc(r)),r}}var Ar=a(require("fs")),Rr=a(require("path"));function Q(t){let e=Rr.default.join(t,"extension.config.js");if(Ar.default.existsSync(e)&&Fl(t)){let s=require(e);if(s&&s!=null&&s&&typeof s.config=="function")return s.config}return s=>s}function Fl(t){let e=Rr.default.join(t,"extension.config.js");return Ar.default.existsSync(e)?(console.log(Gc("extension.config.js")),!0):!1}async function fp(t,e){let s=await K(t);!t?.startsWith("http")&&!cp.default.existsSync(Nr.default.join(s,"manifest.json"))&&(console.log(Y(Nr.default.join(s,"manifest.json"))),process.exit(1));try{let r=e?.browser||"chrome",n=J(s,{...e,browser:r,mode:"production"}),i=n.plugins?.filter(m=>m?.constructor.name!=="plugin-browsers"&&m?.constructor.name!=="plugin-reload"),c=Q(s)({...n,plugins:i}),p=(0,lp.merge)(c),l=(0,pp.default)(p);await new Promise((m,d)=>{l.run(async(g,y)=>{if(g)return console.error(g.stack||g),d(g);console.log($c(s,y,r)),(e?.zip||e?.zipSource)&&await ap(s,{...e,browser:r}),y?.hasErrors()?(console.log(y.toString({colors:!0})),process.exit(1)):(console.log(Cc()),m())})})}catch(r){process.env.EXTENSION_ENV==="development"&&console.error(r),process.exit(1)}}var Ur=a(require("fs")),Bs=a(require("path"));var qr=a(require("path")),mp=a(require("webpack")),up=a(require("webpack-dev-server")),dp=require("webpack-merge");function Tr(t){t.stop().then(()=>{process.exit()}).catch(e=>{console.log(`Error in the Extension.js runner: ${e.stack||""}`)})}async function gp(t,{...e}){let s=J(t,{...e,mode:"development"}),n=Q(t)(s),i=(0,dp.merge)(n),o=(0,mp.default)(i),c={host:"127.0.0.1",allowedHosts:"all",static:qr.default.join(t,"public"),compress:!1,devMiddleware:{writeToDisk:!0},watchFiles:ct(t)?void 0:{paths:[qr.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 up.default(c,o);p.startCallback(l=>{l!=null&&console.log(`Error in the Extension.js runner: ${l.stack||""}`)}),process.on("ERROR",()=>{Tr(p)}),process.on("SIGINT",()=>{Tr(p)}),process.on("SIGTERM",()=>{Tr(p)})}var Ws=a(require("path")),Se=a(require("fs/promises"));async function hp(t){let e=Ws.default.join(t,"extension-env.d.ts"),s=process.env.EXTENSION_ENV==="development"?Ws.default.resolve(process.cwd(),"programs/cli/types"):"extension/dist/types",r=`// Required Extension.js types for TypeScript projects.
143
+ Version: ${(0,m.gray)(i.version)}
144
+ `,g=`Size: ${(0,m.gray)(xl(o))}
145
+ `,h="";return h+=c,h+=vl(o),h+=d,h+=g,h+=l,h+=u,h+=p,h}function _c(){return`${S("success")} No errors or warnings found. Your extension is ${(0,m.brightGreen)("ready for deployment")}.`}function Sc(t,e){return`${S("info")} Fetching data...
146
+ ${(0,m.gray)("URL")} ${(0,m.underline)(`https://github.com/${t}/${e}`)}`}function Pc(t){return`${S("info")} Downloading ${(0,m.cyan)(t)}...`}function kc(t){return`
147
+ ${S("info")} Creating a new browser extension...
148
+ ${(0,m.gray)("PATH")} ${(0,m.underline)(`${t}`)}`}function Ec(t){return`${S("info")} No ${(0,m.brightYellow)(".gitignore")} found, zipping all the content inside path:
149
+ ${(0,m.gray)("PATH")} ${(0,m.underline)(t)}`}function jc(t){return`${S("info")} Packaging source files. Files in ${(0,m.brightYellow)(".gitignore")} will be excluded...
150
+ ${(0,m.gray)("PATH")} ${(0,m.underline)(t)}.`}function $c(t){return`${S("info")} Packaging extension distribution files...
151
+ ${(0,m.gray)("PATH")} ${(0,m.underline)(t)}`}function Cc(t,e,s,r){return`\u{1F4E6} Package name: ${(0,m.brightYellow)(`${e}`)}, Target Browser: ${`${se(t)}`}
152
+ ${(0,m.gray)("\u2514\u2500")} ${(0,m.underline)(`${s}`)} (source)
153
+ ${(0,m.gray)("\u2514\u2500")} ${(0,m.underline)(`${r}`)} (distribution)`}function Fc(t,e,s,r){return`\u{1F4E6} Package name: ${(0,m.brightYellow)(`${t}.${e}`)}, Target Browser: ${`${se(s)}`}
154
+ ${(0,m.gray)("\u2514\u2500")} ${(0,m.underline)(`${r}`)} ${(0,m.gray)("(distribution)")}`}function Dc(t,e,s,r){return`\u{1F4E6} Package name: ${(0,m.brightYellow)(`${t}-source.${e}`)}, Target Browser: ${`${se(s)}`}
155
+ ${(0,m.gray)("\u2514\u2500")} ${(0,m.underline)(`${r}`)} (source)`}function Lc(t){return`${S("error")} Failed to compress extension package.
156
+ ${(0,m.red)(t)}`}function Ic(t){return`${S("info")} Writing type definitions for ${(0,m.cyan)(t.name||"")}...`}function Oc(t){return`${S("error")} Failed to write the extension type definition.
157
+ ${(0,m.red)(t)}`}function Mc(t){return`${S("info")} Downloading extension...
158
+ ${(0,m.gray)("URL")} ${(0,m.underline)(t)}`}function Ac(t){return`${S("info")} Unpackaging browser extension...
159
+ ${(0,m.gray)("PATH")} ${(0,m.underline)(t)}`}function Rc(){return`${S("info")} Browser extension unpackaged ${(0,m.brightGreen)("successfully")}. Compiling...`}function Nc(t){return`${S("error")} Failed to download or extract ZIP file. ${(0,m.red)(t)}`}function se(t){return t.charAt(0).toUpperCase()+t.slice(1)}function wc(t,e){let s=e.default_locale,r=Ze.default.join(t,"_locales");if(!Os.default.existsSync(r))return{defaultLocale:"Browser defaults",otherLocales:[]};let n=Os.default.readdirSync(r).filter(i=>i!==s);return{defaultLocale:s,otherLocales:n}}function Tc(t){return`${(t/1024).toFixed(2)}KB`}function xl(t){let e=0;return t?.forEach(s=>{e+=s.size}),Tc(e)}function qc(t,e=""){let s="";return Object.keys(t).forEach((r,n,i)=>{let o=n===i.length-1,c=o?"\u2514\u2500":"\u251C\u2500",p=t[r].size?` (${Tc(t[r].size)})`:"";s+=`${(0,m.gray)(e)}${(0,m.gray)(c)} ${r}${(0,m.gray)(p)}
160
+ `,typeof t[r]=="object"&&!t[r].size&&(s+=qc(t[r],`${e}${o?" ":(0,m.gray)("\u2502 ")}`))}),s}function vl(t){let e={};return t?.forEach(s=>{let r=s.name.split("/"),n=e;r.forEach((i,o)=>{n[i]||(n[i]={}),o===r.length-1?n[i]={size:s.size}:n=n[i]})}),`.
161
+ ${qc(e)}`}function Uc(t){return`${S("info")} Using ${(0,m.brightYellow)(t)}. ${(0,m.magenta)("This is very experimental")}.`}function Wc(t){return`${S("info")} Installing ${(0,m.cyan)(t)} dependencies...`}function Bc(t,e,s){return`${S("error")} Command ${t} ${e.join(" ")} failed with exit code ${s}`}function Jc(t){return`${S("error")} Can't install project dependencies. ${(0,m.red)(t.message||t.toString())}`}function Z(t){let e=Ke.default.join(t,"extension.config.js");if(Ye.default.existsSync(e)&&Mr(t)){let s=require(e);if(s&&s!=null&&s&&typeof s.config=="function")return s.config}return s=>s}function Hc(t,e){let s=Ke.default.join(t,"extension.config.js");if(Ye.default.existsSync(s)&&Mr(t)){let r=require(s);if(r&&r!=null)return r[e]}return{}}function Rs(t,e){let s=Ke.default.join(t,"extension.config.js");if(Ye.default.existsSync(s)&&Mr(t)){let r=require(s);if(r&&r!=null)return r.browsers[e]}return{}}var zc=!1;function Mr(t){let e=Ke.default.join(t,"extension.config.js");return Ye.default.existsSync(e)?(zc||(console.log(Uc("extension.config.js")),zc=!0),!0):!1}function Vc(t,e){let s={...Rs(Ar.default.resolve(__dirname,"run-firefox"),"firefox"),...Or(e)};Object.keys(s).forEach(i=>{t.setPreference(i,s[i])});let n=Object.keys(e);return n.length>0&&n.forEach(i=>{t.setPreference(i,e[i])}),t.updatePreferences(),t}function _l(t,e){let s=new Rr.default({destinationDirectory:t}),r=Vc(s,e);return console.log({profileConfigured:r}),r}function Sl(t,e,s){let r;if(Ns.default.statSync(e).isDirectory())r=e;else throw new Error(ec(t,e));let i=new Rr.default({destinationDirectory:r});return Vc(i,s)}function Gc(t,e,s){let r,n=e||Ar.default.resolve(__dirname,"run-firefox-data-dir"),c={...Or(s||{}),...s};return Ns.default.existsSync(n)?r=Sl(t,n,c):(Ls(Fs(t),()=>{}),Ns.default.mkdirSync(n,{recursive:!0}),r=_l(n,c)),r}async function Xc(t,e){let{browser:s,startingUrl:r,preferences:n,userDataDir:i,browserFlags:o=[]}=e,c=Gc(s,i,n),p=[];r&&p.push(`--url=${r}`),o&&p.push(...o);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 ep=a(require("path"));var Zc=a(require("net")),Yc=a(require("events"));function Pl(t,e){let s=e.toString(),r=s.indexOf(":");if(r<1)return{remainingData:e};let n=parseInt(s.substring(0,r),10);if(isNaN(n))return{remainingData:e,error:new Error(tc(t)),fatal:!0};if(e.length-(r+1)<n)return{remainingData:e};let i=e.slice(r+1,r+1+n),o=e.slice(r+1+n);try{let c=JSON.parse(i.toString());return{remainingData:o,parsedMessage:c}}catch(c){return{remainingData:o,error:c,fatal:!1}}}var Ts=class extends Yc.default{incomingData=Buffer.alloc(0);pendingRequests=[];activeRequests=new Map;connection;async connect(e){await new Promise((s,r)=>{try{let n={port:e,host:"127.0.0.1"},i=Zc.default.createConnection(n,()=>{s()});this.connection=i,i.on("data",this.onData.bind(this)),i.on("error",r),i.on("end",this.onEnd.bind(this)),i.on("timeout",this.onTimeout.bind(this)),this.expectReply("root",{resolve:s,reject:r})}catch(n){r(n)}})}disconnect(){this.connection&&(this.connection.removeAllListeners(),this.connection.end(),this.rejectAllRequests(new Error(sc("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(rc("firefox",s.type));return await new Promise((r,n)=>{let i={resolve:r,reject:n};this.pendingRequests.push({request:s,deferred:i}),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(nc("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(ic("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:n}=Pl("firefox",this.incomingData);return this.incomingData=e,r?(this.emit("error",new Error(oc("firefox",r))),n&&this.disconnect(),!n):s?(this.handleMessage(s),!0):!1}handleMessage(e){if(!e.from){this.emit("error",new Error(ac("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(cc("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 Qc(t,e){return Array.isArray(t)&&t.includes(e.code)?!0:e.code===t}var kl=150,El=1e3,qs=class{options;constructor(e){this.options=e}async connectClient(e){let s;for(let r of Array.from({length:kl}))try{let n=new Ts;return await n.connect(e),n}catch(n){if(Qc("ECONNREFUSED",n))await new Promise(i=>setTimeout(i,El)),s=n;else throw console.error(Ya(this.options.browser,n.stack)),n}throw console.error(Ka(this.options.browser)),s}async installAddons(e){let{devtools:s}=this.options,r=Array.isArray(this.options.extension)?this.options.extension:[this.options.extension],n=e.options.devServer?.port,i=n?n+100:9222,o=await this.connectClient(i);for(let[c,p]of r.entries()){let l=ep.default.join(p.replace(/"/g,"")),u=c===0&&s;try{let d=await o.request({to:"root",type:"getRoot"});await o.request({to:d.addonsActor,type:"installTemporaryAddon",addonPath:l,openDevTools:u})}catch(d){let g=Kc(d);throw new Error(Qa(this.options.browser,g))}}}};var re=null;process.on("SIGINT",()=>{re&&re.kill("SIGINT"),process.exit()});process.on("SIGTERM",()=>{re&&re.kill("SIGTERM"),process.exit()});var Us=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((s,r)=>{(0,Nr.exec)(`${e} --version`,n=>{n?r(n):s(null)})}),e}catch{console.error(He("firefox",e)),process.exit(1)}}async launchFirefox(e,s){let r=await this.getFxRunnerCommand(),n;switch(s.browser){case"gecko-based":n=sp.default.normalize(this.geckoBinary);break;default:n=bc;break}let i=`${r} start --binary "${n}" --foreground --no-remote`;tp.default.existsSync(n||"")||(console.error(He(this.browser,n||"")),process.exit(1));let o=await Xc(e,s),c=`${i} ${o}`;re=(0,Nr.exec)(c,(l,u,d)=>{if(l!=null)throw l;d.includes("Unable to move the cache")?console.log(Va(this.browser)):(console.log(Ga(this.browser)),process.exit())}),process.env.EXTENSION_ENV==="development"&&(re.stdout?.pipe(process.stdout),re.stderr?.pipe(process.stderr));let p=new qs(this);try{await p.installAddons(e)}catch(l){l?.toString()?.includes("background.service_worker is currently disabled")&&(console.error(Xa(this.browser)),process.exit(1)),console.error(Za(this.browser,l)),process.exit(1)}}apply(e){let s=!1;e.hooks.done.tapAsync("run-firefox:module",async(r,n)=>{if(r.compilation.errors.length>0){n();return}if(s){n();return}setTimeout(()=>{console.log(Ds(this.browser,r.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:r.compilation.options.mode}),s=!0,n()})}};var Ws=class{static name="plugin-browsers";extension;browser;browserFlags;userDataDir;profile;preferences;startingUrl;chromiumBinary;geckoBinary;constructor(e){this.extension=[...e.extension,...e.browserFlags?.filter(s=>!s.startsWith("--load-extension="))||[]],this.browser=e.browser||"chrome",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||"",this.chromiumBinary=e.chromiumBinary,this.geckoBinary=e.geckoBinary}getProfilePath(e,s,r){return r||(e.options.mode==="production"?Tr.default.join(rp.default.tmpdir(),"extension-js",s,"profile"):Tr.default.resolve(__dirname,`run-${s}-profile`))}apply(e){let r={...{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},...Rs(e.context,this.browser)};switch(this.browser){case"chrome":case"edge":case"chromium-based":{new Ge(r).apply(e);break}case"firefox":case"gecko-based":new Us(r).apply(e);break;default:{new Ge({...r,browser:"chrome"}).apply(e);break}}}};function J(t,e){let s=Qe.default.join(t,"manifest.json"),r=Qe.default.join(t,`dist/${e.browser}`),n=require(s),i=e.chromiumBinary?"chromium-based":e.geckoBinary?"gecko-based":e.browser;return{mode:e.mode||"development",entry:{},target:"web",context:t,devtool:n.manifest_version===3?"cheap-source-map":"eval-cheap-source-map",output:{clean:{keep(o){return!o.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",Qe.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 ct({manifestPath:s,browser:i}),new yt({manifestPath:s}),new ht({manifestPath:s}),new _t({manifestPath:s}),process.env.EXPERIMENTAL_ERRORS_PLUGIN&&new Cs({manifestPath:s,browser:i}),new ks({manifestPath:s,browser:i,polyfill:e.polyfill}),new hs({manifestPath:s,browser:i}),new vs({manifestPath:s,browser:i,stats:!0,port:8e3}),!e.noOpen&&new Ws({extension:[r,Qe.default.join(__dirname,"extensions",`${i}-manager-extension`)],browser:i,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 et=a(require("path")),cp=a(require("go-git-it"));var Bs=a(require("path")),np=a(require("axios")),ip=a(require("adm-zip"));var qr=a(require("stream")),op=require("util"),jl=(0,op.promisify)(qr.default.pipeline);async function ap(t,e){let s=t.split("?")[0];try{console.log(Mc(s));let r=await(0,np.default)({url:t,method:"GET",responseType:"stream"}),n=Bs.default.extname(s),i=Bs.default.basename(s,n),o=Bs.default.join(e,i);console.log(Ac(o));let c=[];await jl(r.data,new qr.default.Writable({write(u,d,g){c.push(u),g()}}));let p=Buffer.concat(c);return new ip.default(p).extractAllTo(o,!0),console.log(Rc()),o}catch(r){throw console.error(Nc(r)),r}}var $l=t=>{try{return new URL(t),!0}catch{return!1}};async function Cl(t,e){return await(0,cp.default)(t,process.cwd(),e),et.default.resolve(process.cwd(),et.default.basename(t))}async function Fl(t){return await ap(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 Fl(t);let s=e.pathname.split("/"),r=s.slice(1,3)[0],n=s.slice(1,3)[1];console.log(Sc(r,n));let i=et.default.basename(e.pathname),o=await Cl(t,Pc(i));return console.log(kc(i)),o}}return et.default.resolve(process.cwd(),t)}var z=a(require("path")),pp=a(require("fs")),lp=a(require("ignore")),fp=a(require("tiny-glob")),Ur=a(require("adm-zip")),up=a(require("slugify"));function Dl(t){try{return pp.default.readFileSync(t,"utf8")}catch{return""}}function Ll(t){return(0,up.default)(t,{replacement:"-",remove:/[^a-zA-Z0-9 ]/g,lower:!0})}function Il(t){switch(t){case"opera":return"crx";case"firefox":return"xpi";default:return"zip"}}function Ol(t,e){let s=Ll(e.zipFilename||t.name);return e.zipFilename?s:`${s}-${t.version}`}async function Ml(t){let e=z.default.join(t,".gitignore"),s=Dl(e),r=(0,lp.default)();return s?r.add(s):console.log(Ec(t)),(await(0,fp.default)("**/*",{cwd:t,dot:!0})).filter(i=>!r.ignores(i))}async function mp(t,{browser:e="chrome",...s}){try{let r=z.default.join(t,"dist"),n=z.default.join(r,e),i=s.zipSource?t:n,o=require(z.default.join(i,"manifest.json")),c=Ol(o,s),p=Il(e),l=z.default.join(n,`${c}.${p}`),u=z.default.join(r,`${c}-source.${p}`);if(s.zipSource){console.log(""),console.log(jc(u));let d=new Ur.default;(await Ml(t)).forEach(h=>{d.addLocalFile(z.default.join(t,h),z.default.dirname(h))}),d.writeZip(u)}if(s.zip){console.log(""),console.log($c(l));let d=new Ur.default;d.addLocalFolder(n),d.writeZip(l)}s.zip&&s.zipSource?(console.log(""),console.log(Cc(e,c,u,l))):s.zip?(console.log(""),console.log(Fc(c,p,e,l))):s.zipSource&&(console.log(""),console.log(Dc(c,p,e,u)))}catch(r){throw console.error(Lc(r)),r}}async function yp(t,e){let s=await Y(t);!t?.startsWith("http")&&!dp.default.existsSync(Wr.default.join(s,"manifest.json"))&&(console.log(X(Wr.default.join(s,"manifest.json"))),process.exit(1));try{let r=e?.browser||"chrome",n=J(s,{...e,browser:r,mode:"production"}),i=n.plugins?.filter(u=>u?.constructor.name!=="plugin-browsers"&&u?.constructor.name!=="plugin-reload"),c=Z(s)({...n,plugins:i}),p=(0,hp.merge)(c),l=(0,gp.default)(p);await new Promise((u,d)=>{l.run(async(g,h)=>{if(g)return console.error(g.stack||g),d(g);console.log(vc(s,h,r)),(e?.zip||e?.zipSource)&&await mp(s,{...e,browser:r}),h?.hasErrors()?(console.log(h.toString({colors:!0})),process.exit(1)):(console.log(_c()),u())})})}catch(r){process.env.EXTENSION_ENV==="development"&&console.error(r),process.exit(1)}}var zr=a(require("fs")),zs=a(require("path"));var Jr=a(require("path")),bp=a(require("webpack")),wp=a(require("webpack-dev-server")),xp=require("webpack-merge");function Br(t){t.stop().then(()=>{process.exit()}).catch(e=>{console.log(`Error in the Extension.js runner: ${e.stack||""}`)})}async function vp(t,{...e}){let s=Hc(t,"dev"),r=J(t,{...e,...s,mode:"development"}),i=Z(t)(r),o=(0,xp.merge)(i),c=(0,bp.default)(o),p={host:"127.0.0.1",allowedHosts:"all",static:Jr.default.join(t,"public"),compress:!1,devMiddleware:{writeToDisk:!0},watchFiles:lt(t)?void 0:{paths:[Jr.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 wp.default(p,c);l.startCallback(u=>{u!=null&&console.log(`Error in the Extension.js runner: ${u.stack||""}`)}),process.on("ERROR",()=>{Br(l)}),process.on("SIGINT",()=>{Br(l)}),process.on("SIGTERM",()=>{Br(l)})}var Js=a(require("path")),_e=a(require("fs/promises"));async function _p(t){let e=Js.default.join(t,"extension-env.d.ts"),s=process.env.EXTENSION_ENV==="development"?Js.default.resolve(process.cwd(),"programs/cli/types"):"extension/dist/types",r=`// Required Extension.js types for TypeScript projects.
162
162
  // This file is auto-generated and should not be excluded.
163
163
  // If you need additional types, consider creating a new *.d.ts file and
164
164
  // referencing it in the "include" array of your tsconfig.json file.
@@ -167,4 +167,4 @@ ${Vc(e)}`}function Gc(t){return`${_("info")} Using ${(0,u.brightYellow)(t)}. ${(
167
167
 
168
168
  // Polyfill types for browser.* APIs.
169
169
  /// <reference types="${s}/polyfill.d.ts" />
170
- `;try{await Se.default.access(e),(await Se.default.readFile(e,"utf8")).includes("develop/dist/types")&&await Se.default.writeFile(e,r),process.env.EXTENSION_ENV==="development"&&await Se.default.writeFile(e,r)}catch{let i=require(Ws.default.join(t,"manifest.json"));console.log(qc(i));try{await Se.default.writeFile(e,r)}catch(o){console.log(Uc(o))}}}var yp=a(require("path")),bp=require("cross-spawn"),wp=a(require("fs")),xp=require("package-manager-detector");async function Dl(){let t=await(0,xp.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 Ll(){return["install"]}async function vp(t){let e=yp.default.join(t,"node_modules"),s=await Dl(),r=Ll(),n=process.cwd();try{process.chdir(t),await wp.default.promises.mkdir(e,{recursive:!0});let i=process.env.EXTENSION_ENV==="development"?"inherit":"ignore",o=(0,bp.spawn)(s,r,{stdio:i});await new Promise((c,p)=>{o.on("close",l=>{l!==0?p(new Error(Zc(s,r,l))):c()}),o.on("error",l=>{p(l)})})}catch(i){console.error(Yc(i)),process.exit(1)}finally{process.chdir(n)}}async function _p(t,e){let s=await K(t),r=Bs.default.join(s,"manifest.json");!t?.startsWith("http")&&!Ur.default.existsSync(r)&&(console.log(Y(Bs.default.join(s,"manifest.json"))),process.exit(1));try{G(s)&&await hp(s);let n=Bs.default.join(s,"node_modules");if(!Ur.default.existsSync(n)){let i=require(r).name;console.log(Xc(i)),await vp(s)}setTimeout(async()=>{await gp(s,{...e,mode:"development",browser:e.browser||"chrome"})},50)}catch(n){process.env.EXTENSION_ENV==="development"&&console.error(n),process.exit(1)}}var Sp=a(require("fs")),Wr=a(require("path")),Pp=a(require("webpack")),kp=require("webpack-merge");async function Ep(t,e){let s=await K(t);!t?.startsWith("http")&&!Sp.default.existsSync(Wr.default.join(s,"manifest.json"))&&(console.log(Y(Wr.default.join(s,"manifest.json"))),process.exit(1));try{let r=e.browser||"chrome",n=J(s,{...e,browser:r,mode:"production"}),i=n.plugins?.filter(m=>m?.constructor.name==="plugin-browsers");console.log(Ts(r));let c=Q(s)({...n,plugins:i}),p=(0,kp.merge)(c);(0,Pp.default)(p).run(async(m,d)=>{m&&(console.error(m.stack||m),process.exit(1)),d?.hasErrors()?(console.log(d.toString({colors:!0})),process.exit(1)):console.log(qs(s,{browser:r,mode:"production"}))})}catch(r){process.env.EXTENSION_ENV==="development"&&console.error(r),process.exit(1)}}var jp=a(require("fs")),Br=a(require("path")),$p=a(require("webpack")),Cp=require("webpack-merge");async function Fp(t,e){let s=await K(t);!t?.startsWith("http")&&!jp.default.existsSync(Br.default.join(s,"manifest.json"))&&(console.log(Y(Br.default.join(s,"manifest.json"))),process.exit(1));try{let r=e.browser||"chrome",n=J(s,{...e,browser:r,mode:"production"}),i=n.plugins?.filter(m=>m?.constructor.name!=="plugin-reload");console.log(Ts(r));let c=Q(s)({...n,plugins:i}),p=(0,Cp.merge)(c);(0,$p.default)(p).run((m,d)=>{m&&(console.error(m.stack||m),process.exit(1)),d?.hasErrors()?(console.log(d.toString({colors:!0})),process.exit(1)):(console.log(qs(s,e)),setTimeout(()=>{console.log(jc("production",r))},1500))})}catch(r){process.env.EXTENSION_ENV==="development"&&console.error(r),process.exit(1)}}0&&(module.exports={extensionBuild,extensionDev,extensionPreview,extensionStart});
170
+ `;try{await _e.default.access(e),(await _e.default.readFile(e,"utf8")).includes("develop/dist/types")&&await _e.default.writeFile(e,r),process.env.EXTENSION_ENV==="development"&&await _e.default.writeFile(e,r)}catch{let i=require(Js.default.join(t,"manifest.json"));console.log(Ic(i));try{await _e.default.writeFile(e,r)}catch(o){console.log(Oc(o))}}}var Sp=a(require("path")),Pp=require("cross-spawn"),kp=a(require("fs")),Ep=require("package-manager-detector");async function Al(){let t=await(0,Ep.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 Rl(){return["install"]}async function jp(t){let e=Sp.default.join(t,"node_modules"),s=await Al(),r=Rl(),n=process.cwd();try{process.chdir(t),await kp.default.promises.mkdir(e,{recursive:!0});let i=process.env.EXTENSION_ENV==="development"?"inherit":"ignore",o=(0,Pp.spawn)(s,r,{stdio:i});await new Promise((c,p)=>{o.on("close",l=>{l!==0?p(new Error(Bc(s,r,l))):c()}),o.on("error",l=>{p(l)})})}catch(i){console.error(Jc(i)),process.exit(1)}finally{process.chdir(n)}}async function $p(t,e){let s=await Y(t),r=zs.default.join(s,"manifest.json");!t?.startsWith("http")&&!zr.default.existsSync(r)&&(console.log(X(zs.default.join(s,"manifest.json"))),process.exit(1));try{H(s)&&await _p(s);let n=zs.default.join(s,"node_modules");if(!zr.default.existsSync(n)){let i=require(r).name;console.log(Wc(i)),await jp(s)}setTimeout(async()=>{await vp(s,{...e,mode:"development",browser:e.browser||"chrome"})},50)}catch(n){process.env.EXTENSION_ENV==="development"&&console.error(n),process.exit(1)}}var Cp=a(require("fs")),Hr=a(require("path")),Fp=a(require("webpack")),Dp=require("webpack-merge");async function Lp(t,e){let s=await Y(t);!t?.startsWith("http")&&!Cp.default.existsSync(Hr.default.join(s,"manifest.json"))&&(console.log(X(Hr.default.join(s,"manifest.json"))),process.exit(1));try{let r=e.browser||"chrome",n=J(s,{...e,browser:r,mode:"production"}),i=n.plugins?.filter(u=>u?.constructor.name==="plugin-browsers");console.log(Ms(r));let c=Z(s)({...n,plugins:i}),p=(0,Dp.merge)(c);(0,Fp.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(As(s,{browser:r,mode:"production"}))})}catch(r){process.env.EXTENSION_ENV==="development"&&console.error(r),process.exit(1)}}var Ip=a(require("fs")),Vr=a(require("path")),Op=a(require("webpack")),Mp=require("webpack-merge");async function Ap(t,e){let s=await Y(t);!t?.startsWith("http")&&!Ip.default.existsSync(Vr.default.join(s,"manifest.json"))&&(console.log(X(Vr.default.join(s,"manifest.json"))),process.exit(1));try{let r=e.browser||"chrome",n=J(s,{...e,browser:r,mode:"production"}),i=n.plugins?.filter(u=>u?.constructor.name!=="plugin-reload");console.log(Ms(r));let c=Z(s)({...n,plugins:i}),p=(0,Mp.merge)(c);(0,Op.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(As(s,e)),setTimeout(()=>{console.log(xc("production",r))},1500))})}catch(r){process.env.EXTENSION_ENV==="development"&&console.error(r),process.exit(1)}}0&&(module.exports={extensionBuild,extensionDev,extensionPreview,extensionStart});