aboutsummaryrefslogtreecommitdiff
path: root/buildWeb.mjs
diff options
context:
space:
mode:
authorVendicated <vendicated@riseup.net>2022-10-04 00:52:42 +0200
committerVendicated <vendicated@riseup.net>2022-10-04 00:52:50 +0200
commitcc257533148419b1c94a1cd257e756d2688a403c (patch)
tree84affcf23ec84304efcb381626ac4d995db0ec95 /buildWeb.mjs
parenta9eae106c7cc6cccbb5c3f030130d3c7b6461c3e (diff)
downloadVencord-cc257533148419b1c94a1cd257e756d2688a403c.tar.gz
Vencord-cc257533148419b1c94a1cd257e756d2688a403c.tar.bz2
Vencord-cc257533148419b1c94a1cd257e756d2688a403c.zip
feat: Experimental browser support
Diffstat (limited to 'buildWeb.mjs')
-rw-r--r--buildWeb.mjs86
1 files changed, 86 insertions, 0 deletions
diff --git a/buildWeb.mjs b/buildWeb.mjs
new file mode 100644
index 0000000..9031d14
--- /dev/null
+++ b/buildWeb.mjs
@@ -0,0 +1,86 @@
+// TODO: Modularise these plugins since both build scripts use them
+
+import { execSync } from "child_process";
+import { createWriteStream, readdirSync } from "fs";
+import yazl from "yazl";
+import esbuild from "esbuild";
+
+/**
+ * @type {esbuild.Plugin}
+ */
+const globPlugins = {
+ name: "glob-plugins",
+ setup: build => {
+ build.onResolve({ filter: /^plugins$/ }, args => {
+ return {
+ namespace: "import-plugins",
+ path: args.path
+ };
+ });
+
+ build.onLoad({ filter: /^plugins$/, namespace: "import-plugins" }, () => {
+ const files = readdirSync("./src/plugins");
+ let code = "";
+ let obj = "";
+ for (let i = 0; i < files.length; i++) {
+ if (files[i] === "index.ts") {
+ continue;
+ }
+ const mod = `__pluginMod${i}`;
+ code += `import ${mod} from "./${files[i].replace(/.tsx?$/, "")}";\n`;
+ obj += `[${mod}.name]: ${mod},`;
+ }
+ code += `export default {${obj}}`;
+ return {
+ contents: code,
+ resolveDir: "./src/plugins"
+ };
+ });
+ }
+};
+
+const gitHash = execSync("git rev-parse --short HEAD", { encoding: "utf-8" }).trim();
+/**
+ * @type {esbuild.Plugin}
+ */
+const gitHashPlugin = {
+ name: "git-hash-plugin",
+ setup: build => {
+ const filter = /^git-hash$/;
+ build.onResolve({ filter }, args => ({
+ namespace: "git-hash", path: args.path
+ }));
+ build.onLoad({ filter, namespace: "git-hash" }, () => ({
+ contents: `export default "${gitHash}"`
+ }));
+ }
+};
+
+await esbuild.build({
+ logLevel: "info",
+ entryPoints: ["browser/Vencord.ts"],
+ outfile: "dist/browser.js",
+ format: "iife",
+ bundle: true,
+ globalName: "Vencord",
+ target: ["esnext"],
+ footer: { js: "//# sourceURL=VencordWeb" },
+ external: ["plugins", "git-hash"],
+ plugins: [
+ globPlugins,
+ gitHashPlugin
+ ],
+ sourcemap: false,
+ minify: true,
+});
+
+const zip = new yazl.ZipFile();
+zip.outputStream.pipe(createWriteStream("dist/extension.zip")).on("close", () => {
+ console.info("Extension written to dist/extension.zip");
+});
+
+zip.addFile("dist/browser.js", "dist/Vencord.js");
+["background.js", "content.js", "manifest.json"].forEach(f => {
+ zip.addFile(`browser/${f}`, `${f}`);
+});
+zip.end();