mirror of
https://github.com/th-ch/youtube-music.git
synced 2026-01-10 10:11:46 +00:00
113 lines
2.9 KiB
JavaScript
113 lines
2.9 KiB
JavaScript
const { ipcRenderer, ipcMain } = require("electron");
|
|
|
|
const defaultConfig = require("./defaults");
|
|
const { getOptions, setOptions, setMenuOptions } = require("./plugins");
|
|
|
|
/**
|
|
* This class is used to create a dynamic synced config for plugins.
|
|
*
|
|
* [!IMPORTANT!]
|
|
* The methods are **sync** in the main process and **async** in the renderer process.
|
|
*
|
|
* @param {string} name - The name of the plugin.
|
|
* @param {boolean} [options.enableFront] - Whether the config should be available in front.js. Default: false.
|
|
* @param {object} [options.initialOptions] - The initial options for the plugin. Default: loaded from store.
|
|
*
|
|
* @example
|
|
* const { PluginConfig } = require("../../config/dynamic");
|
|
* const config = new PluginConfig("plugin-name", { enableFront: true });
|
|
* module.exports = { ...config };
|
|
*
|
|
* // or
|
|
*
|
|
* module.exports = (win, options) => {
|
|
* const config = new PluginConfig("plugin-name", {
|
|
* enableFront: true,
|
|
* initialOptions: options,
|
|
* });
|
|
* setupMyPlugin(win, config);
|
|
* };
|
|
*/
|
|
module.exports.PluginConfig = class PluginConfig {
|
|
#name;
|
|
#config;
|
|
#defaultConfig;
|
|
#enableFront;
|
|
|
|
constructor(name, { enableFront = false, initialOptions = undefined } = {}) {
|
|
const pluginDefaultConfig = defaultConfig.plugins[name] || {};
|
|
const pluginConfig = initialOptions || getOptions(name) || {};
|
|
|
|
this.#name = name;
|
|
this.#enableFront = enableFront;
|
|
this.#defaultConfig = pluginDefaultConfig;
|
|
this.#config = { ...pluginDefaultConfig, ...pluginConfig };
|
|
|
|
if (this.#enableFront) {
|
|
this.#setupFront();
|
|
}
|
|
}
|
|
|
|
get = (option) => {
|
|
return this.#config[option];
|
|
};
|
|
|
|
set = (option, value) => {
|
|
this.#config[option] = value;
|
|
this.#save();
|
|
};
|
|
|
|
toggle = (option) => {
|
|
this.#config[option] = !this.#config[option];
|
|
this.#save();
|
|
};
|
|
|
|
getAll = () => {
|
|
return { ...this.#config };
|
|
};
|
|
|
|
setAll = (options) => {
|
|
this.#config = { ...this.#config, ...options };
|
|
this.#save();
|
|
};
|
|
|
|
getDefaultConfig = () => {
|
|
return this.#defaultConfig;
|
|
};
|
|
|
|
/**
|
|
* Use this method to set an option and restart the app if `appConfig.restartOnConfigChange === true`
|
|
*
|
|
* Used for options that require a restart to take effect.
|
|
*/
|
|
setAndMaybeRestart = (option, value) => {
|
|
this.#config[option] = value;
|
|
setMenuOptions(this.#name, this.#config);
|
|
};
|
|
|
|
#save() {
|
|
setOptions(this.#name, this.#config);
|
|
}
|
|
|
|
#setupFront() {
|
|
if (process.type === "renderer") {
|
|
for (const [fnName, fn] of Object.entries(this)) {
|
|
if (typeof fn !== "function") return;
|
|
this[fnName] = async (...args) => {
|
|
return await ipcRenderer.invoke(
|
|
`${this.name}-config-${fnName}`,
|
|
...args,
|
|
);
|
|
};
|
|
}
|
|
} else if (process.type === "browser") {
|
|
for (const [fnName, fn] of Object.entries(this)) {
|
|
if (typeof fn !== "function") return;
|
|
ipcMain.handle(`${this.name}-config-${fnName}`, (_, ...args) => {
|
|
return fn(...args);
|
|
});
|
|
}
|
|
}
|
|
}
|
|
};
|