aboutsummaryrefslogtreecommitdiffhomepage
path: root/webpack/webpack.manifest.js
diff options
context:
space:
mode:
authorMichael C <[email protected]>2022-06-30 21:39:28 -0400
committerMichael C <[email protected]>2022-06-30 21:39:28 -0400
commit4119fd843360f858891a7fbb1526a350f999e1f5 (patch)
treeef6ad8b69629608c4931025b74678c8a078e14e2 /webpack/webpack.manifest.js
parentcc7d7c0a0c03d552976b3291af85e3cec31a3c39 (diff)
downloadSponsorBlock-4119fd843360f858891a7fbb1526a350f999e1f5.tar.gz
SponsorBlock-4119fd843360f858891a7fbb1526a350f999e1f5.zip
revert module conversion
Diffstat (limited to 'webpack/webpack.manifest.js')
-rw-r--r--webpack/webpack.manifest.js86
1 files changed, 86 insertions, 0 deletions
diff --git a/webpack/webpack.manifest.js b/webpack/webpack.manifest.js
new file mode 100644
index 00000000..3e30ffc6
--- /dev/null
+++ b/webpack/webpack.manifest.js
@@ -0,0 +1,86 @@
+/* eslint-disable @typescript-eslint/no-var-requires */
+// eslint-disable-next-line @typescript-eslint/no-unused-vars
+const webpack = require("webpack");
+const path = require('path');
+const { validate } = require('schema-utils');
+
+const fs = require('fs');
+
+const manifest = require("../manifest/manifest.json");
+const firefoxManifestExtra = require("../manifest/firefox-manifest-extra.json");
+const chromeManifestExtra = require("../manifest/chrome-manifest-extra.json");
+const safariManifestExtra = require("../manifest/safari-manifest-extra.json");
+const betaManifestExtra = require("../manifest/beta-manifest-extra.json");
+const firefoxBetaManifestExtra = require("../manifest/firefox-beta-manifest-extra.json");
+
+// schema for options object
+const schema = {
+ type: 'object',
+ properties: {
+ browser: {
+ type: 'string'
+ },
+ pretty: {
+ type: 'boolean'
+ },
+ steam: {
+ type: 'string'
+ }
+ }
+};
+
+class BuildManifest {
+ constructor (options = {}) {
+ validate(schema, options, "Build Manifest Plugin");
+
+ this.options = options;
+ }
+
+ apply() {
+ const distFolder = path.resolve(__dirname, "../dist/");
+ const distManifestFile = path.resolve(distFolder, "manifest.json");
+
+ // Add missing manifest elements
+ if (this.options.browser.toLowerCase() === "firefox") {
+ mergeObjects(manifest, firefoxManifestExtra);
+ } else if (this.options.browser.toLowerCase() === "chrome"
+ || this.options.browser.toLowerCase() === "chromium"
+ || this.options.browser.toLowerCase() === "edge") {
+ mergeObjects(manifest, chromeManifestExtra);
+ } else if (this.options.browser.toLowerCase() === "safari") {
+ mergeObjects(manifest, safariManifestExtra);
+ }
+
+ if (this.options.stream === "beta") {
+ mergeObjects(manifest, betaManifestExtra);
+
+ if (this.options.browser.toLowerCase() === "firefox") {
+ mergeObjects(manifest, firefoxBetaManifestExtra);
+ }
+ }
+
+ let result = JSON.stringify(manifest);
+ if (this.options.pretty) result = JSON.stringify(manifest, null, 2);
+
+ fs.mkdirSync(distFolder, {recursive: true});
+ fs.writeFileSync(distManifestFile, result);
+ }
+}
+
+function mergeObjects(object1, object2) {
+ for (const key in object2) {
+ if (key in object1) {
+ if (Array.isArray(object1[key])) {
+ object1[key] = object1[key].concat(object2[key]);
+ } else if (typeof object1[key] == 'object') {
+ mergeObjects(object1[key], object2[key]);
+ } else {
+ object1[key] = object2[key];
+ }
+ } else {
+ object1[key] = object2[key];
+ }
+ }
+}
+
+module.exports = BuildManifest; \ No newline at end of file