BetterDiscordAddons/Plugins/GameActivityToggle/GameActivityToggle.plugin.js

444 lines
17 KiB
JavaScript
Raw Normal View History

2021-03-20 14:31:24 +01:00
/**
* @name GameActivityToggle
* @author DevilBro
* @authorId 278543574059057154
2024-11-16 16:58:07 +01:00
* @version 1.2.8
2021-03-20 14:31:24 +01:00
* @description Adds a Quick-Toggle Game Activity Button
* @invite Jx3TjNS
* @donate https://www.paypal.me/MircoWittrien
* @patreon https://www.patreon.com/MircoWittrien
* @website https://mwittrien.github.io/
* @source https://github.com/mwittrien/BetterDiscordAddons/tree/master/Plugins/GameActivityToggle/
* @updateUrl https://mwittrien.github.io/BetterDiscordAddons/Plugins/GameActivityToggle/GameActivityToggle.plugin.js
*/
module.exports = (_ => {
2022-09-01 14:40:11 +02:00
const changeLog = {
2022-09-02 12:37:10 +02:00
2021-03-20 14:31:24 +01:00
};
2022-02-05 21:14:17 +01:00
return !window.BDFDB_Global || (!window.BDFDB_Global.loaded && !window.BDFDB_Global.started) ? class {
2022-09-01 14:55:22 +02:00
constructor (meta) {for (let key in meta) this[key] = meta[key];}
getName () {return this.name;}
getAuthor () {return this.author;}
getVersion () {return this.version;}
getDescription () {return `The Library Plugin needed for ${this.name} is missing. Open the Plugin Settings to download it. \n\n${this.description}`;}
2021-03-20 14:31:24 +01:00
downloadLibrary () {
2023-11-18 18:31:04 +01:00
BdApi.Net.fetch("https://mwittrien.github.io/BetterDiscordAddons/Library/0BDFDB.plugin.js").then(r => {
if (!r || r.status != 200) throw new Error();
else return r.text();
}).then(b => {
if (!b) throw new Error();
else return require("fs").writeFile(require("path").join(BdApi.Plugins.folder, "0BDFDB.plugin.js"), b, _ => BdApi.showToast("Finished downloading BDFDB Library", {type: "success"}));
}).catch(error => {
BdApi.alert("Error", "Could not download BDFDB Library Plugin. Try again later or download it manually from GitHub: https://mwittrien.github.io/downloader/?library");
2021-03-20 14:31:24 +01:00
});
}
load () {
if (!window.BDFDB_Global || !Array.isArray(window.BDFDB_Global.pluginQueue)) window.BDFDB_Global = Object.assign({}, window.BDFDB_Global, {pluginQueue: []});
if (!window.BDFDB_Global.downloadModal) {
window.BDFDB_Global.downloadModal = true;
2022-09-01 14:55:22 +02:00
BdApi.showConfirmationModal("Library Missing", `The Library Plugin needed for ${this.name} is missing. Please click "Download Now" to install it.`, {
2021-03-20 14:31:24 +01:00
confirmText: "Download Now",
cancelText: "Cancel",
onCancel: _ => {delete window.BDFDB_Global.downloadModal;},
onConfirm: _ => {
delete window.BDFDB_Global.downloadModal;
this.downloadLibrary();
}
});
}
2022-09-01 14:55:22 +02:00
if (!window.BDFDB_Global.pluginQueue.includes(this.name)) window.BDFDB_Global.pluginQueue.push(this.name);
2021-03-20 14:31:24 +01:00
}
start () {this.load();}
stop () {}
getSettingsPanel () {
let template = document.createElement("template");
2022-09-01 14:55:22 +02:00
template.innerHTML = `<div style="color: var(--header-primary); font-size: 16px; font-weight: 300; white-space: pre; line-height: 22px;">The Library Plugin needed for ${this.name} is missing.\nPlease click <a style="font-weight: 500;">Download Now</a> to install it.</div>`;
2021-03-20 14:31:24 +01:00
template.content.firstElementChild.querySelector("a").addEventListener("click", this.downloadLibrary);
return template.content.firstElementChild;
}
} : (([Plugin, BDFDB]) => {
var _this;
2024-11-11 21:46:17 +01:00
var toggleButton, toggleItem;
2021-03-20 14:31:24 +01:00
const ActivityToggleComponent = class ActivityToggle extends BdApi.React.Component {
componentDidMount() {
toggleButton = this;
}
render() {
2022-09-29 18:46:11 +02:00
const enabled = this.props.forceState != undefined ? this.props.forceState : BDFDB.DiscordUtils.getSetting("status", "showCurrentGame");
2021-12-31 14:28:01 +01:00
delete this.props.forceState;
2021-03-20 14:31:24 +01:00
return BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.PanelButton, Object.assign({}, this.props, {
2021-12-22 21:54:02 +01:00
tooltipText: enabled ? _this.labels.disable_activity : _this.labels.enable_activity,
2024-04-14 09:04:54 +02:00
icon: iconProps => BDFDB.ReactUtils.createElement("div", {
className: BDFDB.disCN.lottieicon,
style: {
"--__lottieIconColor": enabled ? "currentColor" : BDFDB.DiscordConstants.ColorsCSS.STATUS_DANGER,
"display": "flex",
"width": "20px",
"height": "20px"
},
children: BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SvgIcon, Object.assign({}, iconProps, {
nativeClass: true,
width: 20,
height: 20,
color: "var(--__lottieIconColor)",
name: enabled ? BDFDB.LibraryComponents.SvgIcon.Names.GAMEPAD : BDFDB.LibraryComponents.SvgIcon.Names.GAMEPAD_DISABLED
}))
}),
2024-11-11 21:46:17 +01:00
onClick: _ => {
_this.toggle();
if (toggleItem) BDFDB.ReactUtils.forceUpdate(toggleItem);
}
2021-03-20 14:31:24 +01:00
}));
}
};
2024-11-11 21:46:17 +01:00
const ActivityToggleItemComponent = class ActivityToggleItem extends BdApi.React.Component {
componentDidMount() {
toggleItem = this;
}
componentWillUnmount() {
toggleItem = null;
}
render() {
const enabled = this.props.forceState != undefined ? this.props.forceState : BDFDB.DiscordUtils.getSetting("status", "showCurrentGame");
delete this.props.forceState;
return BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.UserPopoutItem, {
label: BDFDB.LanguageUtils.LanguageStrings.ACTIVITY_STATUS,
id: BDFDB.ContextMenuUtils.createItemId(_this.name, "activity-toggle"),
icon: _ => BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SvgIcon, {
name: BDFDB.LibraryComponents.SvgIcon.Names.GAMEPAD,
width: 16,
height: 16
}),
2024-11-16 16:58:07 +01:00
onClick: _ => {
_this.toggle();
if (toggleButton) BDFDB.ReactUtils.forceUpdate(toggleButton);
},
2024-11-11 21:46:17 +01:00
hint: enabled ? BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SvgIcon, {
className: BDFDB.disCN.menucolordefault,
background: BDFDB.disCN.menucheckbox,
foreground: BDFDB.disCN.menucheck,
name: BDFDB.LibraryComponents.SvgIcon.Names.CHECKBOX,
2024-11-16 16:58:07 +01:00
style: {background: "unset"}
2024-11-11 21:46:17 +01:00
}) : BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SvgIcon, {
className: BDFDB.disCN.menucolordefault,
name: BDFDB.LibraryComponents.SvgIcon.Names.CHECKBOX_EMPTY,
2024-11-16 16:58:07 +01:00
style: {background: "unset"}
2024-11-11 21:46:17 +01:00
})
});
}
};
2022-04-20 20:49:39 +02:00
var sounds = [], keybind;
2021-03-20 14:31:24 +01:00
return class GameActivityToggle extends Plugin {
onLoad () {
_this = this;
this.defaults = {
general: {
2023-11-18 18:31:04 +01:00
showButton: {value: true, description: "Show Quick Toggle Button"},
showItem: {value: false, description: "Show Quick Toggle Item"},
playEnable: {value: true, description: "Play Enable Sound"},
playDisable: {value: true, description: "Play Disable Sound"}
2021-03-20 14:31:24 +01:00
},
selections: {
2023-11-18 18:31:04 +01:00
enableSound: {value: "stream_started", description: "Enable Sound"},
disableSound: {value: "stream_ended", description: "Disable Sound"}
2021-03-20 14:31:24 +01:00
}
};
2022-10-11 13:08:01 +02:00
this.modulePatches = {
after: [
2024-11-11 21:46:17 +01:00
"Account",
"AccountPopout"
2022-10-11 13:08:01 +02:00
]
2021-03-20 14:31:24 +01:00
};
2022-04-23 19:48:23 +02:00
this.css = `
2024-06-22 06:55:11 +02:00
${BDFDB.dotCNS._gameactivitytoggleadded + BDFDB.dotCN.accountinfoavatarwrapper} {
2022-04-24 11:05:56 +02:00
flex: 1;
min-width: 0;
2022-04-23 19:48:23 +02:00
}
`;
2021-03-20 14:31:24 +01:00
}
2021-07-30 13:20:04 +02:00
onStart () {
2022-12-07 11:11:41 +01:00
sounds = [BDFDB.LibraryModules.SoundParser && BDFDB.LibraryModules.SoundParser.keys()].flat(10).filter(n => n).map(s => s.replace("./", "").split(".")[0]).sort();
2021-07-30 13:20:04 +02:00
let cachedState = BDFDB.DataUtils.load(this, "cachedState");
2022-09-29 18:46:11 +02:00
let state = BDFDB.DiscordUtils.getSetting("status", "showCurrentGame");
2021-07-30 13:20:04 +02:00
if (!cachedState.date || (new Date() - cachedState.date) > 1000*60*60*24*3) {
2021-12-31 14:28:01 +01:00
cachedState.value = state;
2021-07-30 13:20:04 +02:00
cachedState.date = new Date();
BDFDB.DataUtils.save(cachedState, this, "cachedState");
}
2022-09-29 18:46:11 +02:00
else if (cachedState.value != null && cachedState.value != state) BDFDB.DiscordUtils.setSetting("status", "showCurrentGame", cachedState.value);
2021-07-30 13:20:04 +02:00
2022-09-29 18:46:11 +02:00
let SettingsStore = BDFDB.DiscordUtils.getSettingsStore();
if (SettingsStore) BDFDB.PatchUtils.patch(this, SettingsStore, "updateAsync", {after: e => {
2022-10-02 08:46:13 +02:00
if (e.methodArguments[0] != "status") return;
2022-09-29 18:58:06 +02:00
let newSettings = {value: undefined};
2022-09-29 18:46:11 +02:00
e.methodArguments[1](newSettings);
if (newSettings.showCurrentGame != undefined) {
if (toggleButton) toggleButton.props.forceState = newSettings.showCurrentGame.value;
BDFDB.ReactUtils.forceUpdate(toggleButton);
2024-11-11 21:46:17 +01:00
if (toggleItem) toggleItem.props.forceState = newSettings.showCurrentGame.value;
BDFDB.ReactUtils.forceUpdate(toggleItem);
2022-10-12 17:13:05 +02:00
BDFDB.DataUtils.save({date: new Date(), value: newSettings.showCurrentGame.value}, this, "cachedState");
2022-09-29 18:46:11 +02:00
}
2021-07-30 13:20:04 +02:00
}});
2021-03-20 14:31:24 +01:00
2022-04-20 20:49:39 +02:00
keybind = BDFDB.DataUtils.load(this, "keybind");
keybind = BDFDB.ArrayUtils.is(keybind) ? keybind : [];
this.activateKeybind();
2022-10-11 13:08:01 +02:00
BDFDB.DiscordUtils.rerenderAll();
2021-03-20 14:31:24 +01:00
}
onStop () {
2022-10-11 13:08:01 +02:00
BDFDB.DiscordUtils.rerenderAll();
2021-03-20 14:31:24 +01:00
}
getSettingsPanel (collapseStates = {}) {
let settingsPanel;
return settingsPanel = BDFDB.PluginUtils.createSettingsPanel(this, {
collapseStates: collapseStates,
children: _ => {
let settingsItems = [];
for (let key in this.defaults.general) settingsItems.push(BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SettingsSaveItem, {
type: "Switch",
plugin: this,
keys: ["general", key],
label: this.defaults.general[key].description,
value: this.settings.general[key]
}));
for (let key in this.defaults.selections) settingsItems.push(BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SettingsSaveItem, {
type: "Select",
plugin: this,
keys: ["selections", key],
label: this.defaults.selections[key].description,
basis: "50%",
2022-09-27 11:53:04 +02:00
options: sounds.map(o => ({value: o, label: o.split(/[-_]/g).map(BDFDB.StringUtils.upperCaseFirstChar).join(" ")})),
2021-03-20 16:11:35 +01:00
value: this.settings.selections[key],
2023-03-09 15:37:05 +01:00
onChange: value => BDFDB.LibraryModules.SoundUtils.playSound(value, .4)
2021-03-20 14:31:24 +01:00
}));
2022-04-20 20:49:39 +02:00
settingsItems.push(BDFDB.ReactUtils.createElement("div", {
className: BDFDB.disCN.settingsrowcontainer,
children: BDFDB.ReactUtils.createElement("div", {
className: BDFDB.disCN.settingsrowlabel,
children: [
BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.SettingsLabel, {
label: "Global Hotkey"
}),
BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.Flex.Child, {
className: BDFDB.disCNS.settingsrowcontrol + BDFDB.disCN.flexchild,
grow: 0,
wrap: true,
children: BDFDB.ReactUtils.createElement(BDFDB.LibraryComponents.KeybindRecorder, {
value: !keybind ? [] : keybind,
reset: true,
onChange: value => {
keybind = value;
2022-04-22 18:03:46 +02:00
BDFDB.DataUtils.save(keybind, this, "keybind")
2022-04-20 20:49:39 +02:00
this.activateKeybind();
}
})
})
].flat(10).filter(n => n)
})
}));
2021-03-20 14:31:24 +01:00
return settingsItems;
}
});
}
2024-11-11 21:46:17 +01:00
processAccountPopout (e) {
if (!this.settings.general.showItem) return;
let userpopoutMenus = BDFDB.ReactUtils.findChild(e.returnvalue, {props: [["className", BDFDB.disCN.userpopoutmenus]]});
if (!userpopoutMenus) return;
let [children, index] = BDFDB.ReactUtils.findParent(userpopoutMenus, {props: [["id", "set-status"]]});
if (index == -1) return;
children.splice(index, 0, BDFDB.ReactUtils.createElement(BDFDB.LibraryModules.React.Fragment, {
children: [
BDFDB.ReactUtils.createElement(ActivityToggleItemComponent, {}),
BDFDB.ReactUtils.createElement("div", {
className: BDFDB.disCN.userpopoutmenudivider
})
]
}));
2022-05-24 14:54:41 +02:00
}
2021-03-20 14:31:24 +01:00
processAccount (e) {
2022-05-24 14:54:41 +02:00
if (!this.settings.general.showButton) return;
2024-04-02 19:04:50 +02:00
let accountinfo = BDFDB.ReactUtils.findChild(e.returnvalue, {props: [["className", BDFDB.disCN.accountinfo]]});
let children = accountinfo && BDFDB.ObjectUtils.get(accountinfo, "props.children.1.props.children");
2024-03-19 17:47:11 +01:00
if (children && children.length && BDFDB.ArrayUtils.is(children)) {
2024-04-02 19:04:50 +02:00
accountinfo.props.className = BDFDB.DOMUtils.formatClassName(accountinfo.props.className, BDFDB.disCN._gameactivitytoggleadded);
2021-06-18 22:55:21 +02:00
children.unshift(BDFDB.ReactUtils.createElement(ActivityToggleComponent, {}));
}
2021-03-20 14:31:24 +01:00
}
2022-04-20 20:49:39 +02:00
activateKeybind () {
2022-10-24 09:41:24 +02:00
if (keybind && keybind.length) BDFDB.ListenerUtils.addGlobal(this, "GAMEACTIVITY_TOGGLE", keybind, _ => this.toggle());
else BDFDB.ListenerUtils.removeGlobal(this, "GAMEACTIVITY_TOGGLE");
2022-04-20 20:49:39 +02:00
}
toggle () {
2022-09-29 18:46:11 +02:00
const shouldEnable = !BDFDB.DiscordUtils.getSetting("status", "showCurrentGame");
2023-03-09 15:37:05 +01:00
this.settings.general[shouldEnable ? "playEnable" : "playDisable"] && BDFDB.LibraryModules.SoundUtils.playSound(this.settings.selections[shouldEnable ? "enableSound" : "disableSound"], .4);
2022-09-29 18:46:11 +02:00
BDFDB.DiscordUtils.setSetting("status", "showCurrentGame", shouldEnable);
2022-04-20 20:49:39 +02:00
}
2021-03-20 14:31:24 +01:00
setLabelsByLanguage () {
switch (BDFDB.LanguageUtils.getLanguage().id) {
case "bg": // Bulgarian
return {
disable_activity: "Деактивирайте активността в играта",
enable_activity: "Активирайте Game Activity"
};
case "da": // Danish
return {
disable_activity: "Deaktiver spilaktivitet",
enable_activity: "Aktivér spilaktivitet"
};
case "de": // German
return {
disable_activity: "Spieleaktivität deaktivieren",
enable_activity: "Spieleaktivität aktivieren"
};
case "el": // Greek
return {
disable_activity: "Απενεργοποίηση δραστηριότητας παιχνιδιού",
enable_activity: "Ενεργοποίηση δραστηριότητας παιχνιδιού"
};
case "es": // Spanish
return {
disable_activity: "Deshabilitar la actividad del juego",
enable_activity: "Habilitar la actividad del juego"
};
case "fi": // Finnish
return {
disable_activity: "Poista pelitoiminto käytöstä",
enable_activity: "Ota pelitoiminta käyttöön"
};
case "fr": // French
return {
disable_activity: "Désactiver l'activité de jeu",
enable_activity: "Activer l'activité de jeu"
};
case "hr": // Croatian
return {
disable_activity: "Onemogući aktivnost igre",
enable_activity: "Omogući aktivnost u igrama"
};
case "hu": // Hungarian
return {
disable_activity: "Tiltsa le a játéktevékenységet",
enable_activity: "Engedélyezze a játéktevékenységet"
};
case "it": // Italian
return {
disable_activity: "Disabilita l'attività di gioco",
enable_activity: "Abilita attività di gioco"
};
case "ja": // Japanese
return {
disable_activity: "ゲームアクティビティを無効にする",
enable_activity: "ゲームアクティビティを有効にする"
};
case "ko": // Korean
return {
disable_activity: "게임 활동 비활성화",
enable_activity: "게임 활동 활성화"
};
case "lt": // Lithuanian
return {
disable_activity: "Išjungti žaidimų veiklą",
enable_activity: "Įgalinti žaidimų veiklą"
};
case "nl": // Dutch
return {
disable_activity: "Schakel spelactiviteit uit",
enable_activity: "Schakel spelactiviteit in"
};
case "no": // Norwegian
return {
disable_activity: "Deaktiver spillaktivitet",
enable_activity: "Aktiver spillaktivitet"
};
case "pl": // Polish
return {
disable_activity: "Wyłącz aktywność w grach",
enable_activity: "Włącz aktywność w grach"
};
case "pt-BR": // Portuguese (Brazil)
return {
disable_activity: "Desativar atividade de jogo",
enable_activity: "Habilitar atividade de jogo"
};
case "ro": // Romanian
return {
disable_activity: "Dezactivați Activitatea jocului",
enable_activity: "Activați Activitatea jocului"
};
case "ru": // Russian
return {
disable_activity: "Отключить игровую активность",
enable_activity: "Включить игровую активность"
};
case "sv": // Swedish
return {
disable_activity: "Inaktivera spelaktivitet",
enable_activity: "Aktivera spelaktivitet"
};
case "th": // Thai
return {
disable_activity: "ปิดการใช้งานกิจกรรมของเกม",
enable_activity: "เปิดใช้งานกิจกรรมเกม"
};
case "tr": // Turkish
return {
disable_activity: "Oyun Etkinliğini Devre Dışı Bırak",
enable_activity: "Oyun Etkinliğini Etkinleştir"
};
case "uk": // Ukrainian
return {
disable_activity: "Вимкнути ігрову активність",
enable_activity: "Увімкнути ігрову активність"
};
case "vi": // Vietnamese
return {
disable_activity: "Tắt hoạt động trò chơi",
enable_activity: "Bật hoạt động trò chơi"
};
case "zh-CN": // Chinese (China)
return {
disable_activity: "禁用游戏活动",
enable_activity: "启用游戏活动"
};
case "zh-TW": // Chinese (Taiwan)
return {
disable_activity: "禁用遊戲活動",
enable_activity: "啟用遊戲活動"
};
default: // English
return {
disable_activity: "Disable Game Activity",
enable_activity: "Enable Game Activity"
};
}
}
};
2022-09-01 14:40:11 +02:00
})(window.BDFDB_Global.PluginUtils.buildPlugin(changeLog));
2021-06-18 22:55:21 +02:00
})();