diff options
author | Michael C <[email protected]> | 2022-06-30 21:39:28 -0400 |
---|---|---|
committer | Michael C <[email protected]> | 2022-06-30 21:39:28 -0400 |
commit | 4119fd843360f858891a7fbb1526a350f999e1f5 (patch) | |
tree | ef6ad8b69629608c4931025b74678c8a078e14e2 /webpack/webpack.manifest.js | |
parent | cc7d7c0a0c03d552976b3291af85e3cec31a3c39 (diff) | |
download | SponsorBlock-4119fd843360f858891a7fbb1526a350f999e1f5.tar.gz SponsorBlock-4119fd843360f858891a7fbb1526a350f999e1f5.zip |
revert module conversion
Diffstat (limited to 'webpack/webpack.manifest.js')
-rw-r--r-- | webpack/webpack.manifest.js | 86 |
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 |