From cdaa715c8c2672c9af63682dd26e2b5f52597011 Mon Sep 17 00:00:00 2001 From: vantezzen Date: Sat, 1 Feb 2020 11:33:41 +0100 Subject: getferdi/ferdi#319 Add fix for discord notifications --- discord.tar.gz | Bin 2839 -> 53477 bytes uncompressed/discord/index.js | 6 ++---- uncompressed/discord/webview.js | 25 ++++++++++++++++++++++--- 3 files changed, 24 insertions(+), 7 deletions(-) diff --git a/discord.tar.gz b/discord.tar.gz index 745ff47..d52cacb 100644 Binary files a/discord.tar.gz and b/discord.tar.gz differ diff --git a/uncompressed/discord/index.js b/uncompressed/discord/index.js index 629d7c7..dd2bcf2 100644 --- a/uncompressed/discord/index.js +++ b/uncompressed/discord/index.js @@ -1,10 +1,8 @@ -"use strict"; - module.exports = Franz => class Discord extends Franz { overrideUserAgent() { const useragent = window.navigator.userAgent; const parts = useragent.split('(KHTML, like Gecko)'); + return parts.join('(KHTML, like Gecko) discord/0.0.250').replace('Electron', 'Discord').replace('Franz', 'Discord'); } - -}; \ No newline at end of file +}; diff --git a/uncompressed/discord/webview.js b/uncompressed/discord/webview.js index 9a72420..f4a90b9 100644 --- a/uncompressed/discord/webview.js +++ b/uncompressed/discord/webview.js @@ -6,11 +6,30 @@ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { de module.exports = Franz => { const getMessages = function getMessages() { - const direct = document.querySelectorAll('[class^="guildsWrapper"] [class*="badge"]').length; - const indirect = document.querySelectorAll('[class^="guildsWrapper"] [class^="guild-"]+[class*="unread-"]').length; + // Get direct messages + const directElements = document.querySelectorAll('[class^="numberBadge-2s8kKX"]'); + var direct = 0; + + directElements.forEach(function(directElement) { + direct = direct + parseInt(directElement.innerHTML); + }); + + // Get indirect messages + const linkElements = document.getElementsByTagName('link'); + var indirect = 0; + + for (var i = 0; i < linkElements.length; i++) { + if(linkElements[i].getAttribute('rel') == 'icon') { + if(linkElements[i].getAttribute('href') == '') { + indirect = 1; + } + } + } + + // Set badge Franz.setBadge(direct, indirect); }; Franz.loop(getMessages); Franz.injectCSS(_path.default.join(__dirname, 'service.css')); -}; \ No newline at end of file +}; -- cgit v1.2.3-70-g09d2