Unread badge and suggestions

Applied reviewer suggestions.

Unread Badge displays a `0`
This commit is contained in:
Kylie C 2024-06-21 20:59:45 -04:00
parent dd703eb969
commit dda7c7c958
2 changed files with 20 additions and 7 deletions

View file

@ -7,7 +7,7 @@
import { app, NativeImage, nativeImage } from "electron";
import { join } from "path";
import { BADGE_DIR } from "shared/paths";
import { exec } from "child_process";
import { execFile } from "child_process";
const imgCache = new Map<number, NativeImage>();
function loadBadge(index: number) {
@ -25,18 +25,31 @@ let lastIndex: null | number = -1;
export function setBadgeCount(count: number) {
switch (process.platform) {
case "linux":
if (count === -1) count = 0;
// app.setBadgeCount(count);
function emitDBusBadge(count: number, visible: boolean) {
const badgeCountCommand = `gdbus emit --session --object-path / --signal com.canonical.Unity.LauncherEntry.Update "application://vesktop.desktop" "{'count': <int64 ${count}>, 'count-visible': <${visible}>}"`;
exec(badgeCountCommand)
if (typeof count !== "number") { //sanitize
console.log("what the hel- *kaboom*")
break;
}
function emitDBusBadge(count: number, visible: boolean) {
execFile ("gdbus", [
"emit",
"--session",
"--object-path",
"/",
"--signal",
"com.canonical.Unity.LauncherEntry.Update",
"application://vesktop.desktop",
`{\'count\': <int64 ${count}>, \'count-visible\': <${visible}>}`
]);
}
if (count === 0) {
emitDBusBadge(count, false);
break;
}
if (count === -1) {
emitDBusBadge(0, true);
break;
}
emitDBusBadge(count, true);
break;
case "darwin":

View file

@ -446,7 +446,7 @@ function createMainWindow() {
if (Settings.store.staticTitle) win.on("page-title-updated", e => e.preventDefault());
else if (Settings.store.appBadge) mainWin.webContents.on('page-title-updated', (_, title) => {
let cleanedTitle = title.replace(/^\(\d+\)\s*/, '');
let cleanedTitle = title.replace(/^\(\d+\)\s*|•\s/, '');
mainWin.setTitle(cleanedTitle);
});