mirror of
https://github.com/Mastermindzh/tidal-hifi.git
synced 2025-09-10 22:04:53 +02:00
Compare commits
9 Commits
Author | SHA1 | Date | |
---|---|---|---|
8fea5265e7 | |||
8d2e03ca6b | |||
1074de228b | |||
|
64d1aa4041 | ||
|
6608330ed3 | ||
aa562c4a30 | |||
d6f63ac560 | |||
cdc0f49789 | |||
2f290f83fd |
14
CHANGELOG.md
14
CHANGELOG.md
@@ -4,6 +4,20 @@ All notable changes to this project will be documented in this file.
|
|||||||
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/),
|
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/),
|
||||||
and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
|
and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
|
||||||
|
|
||||||
|
## 2.3.0
|
||||||
|
|
||||||
|
- Added a setting to minimize to tray on app close (off by default)
|
||||||
|
- Added the main menu to the trayicon
|
||||||
|
|
||||||
|
## 2.2.1
|
||||||
|
|
||||||
|
- artists is now gotten specifically from the footer. This fixes the [unknown artists bug](https://github.com/Mastermindzh/tidal-hifi/issues/45).
|
||||||
|
- the discord module will check whether the artists is empty and if so substitute it with a default message. This is to prevent sending an empty state to Discord (which it doesn't support). fixes [#45](https://github.com/Mastermindzh/tidal-hifi/issues/54)
|
||||||
|
|
||||||
|
### removed arch build details from source control
|
||||||
|
|
||||||
|
moved to: [https://github.com/Mastermindzh/tidal-hifi-aur](https://github.com/Mastermindzh/tidal-hifi-aur)
|
||||||
|
|
||||||
## 2.2.0
|
## 2.2.0
|
||||||
|
|
||||||
- The discord integration now adds a time remaining field based on the song duration
|
- The discord integration now adds a time remaining field based on the song duration
|
||||||
|
@@ -3,7 +3,7 @@ Tidal-hifi
|
|||||||
<img src = "./build/icon.png" height="40" align="right" />
|
<img src = "./build/icon.png" height="40" align="right" />
|
||||||
</h1>
|
</h1>
|
||||||
|
|
||||||
The web version of [listen.tidal.com](listen.tidal.com) running in electron with hifi support thanks to widevine.
|
The web version of [listen.tidal.com](https://listen.tidal.com) running in electron with hifi support thanks to widevine.
|
||||||
|
|
||||||

|

|
||||||
|
|
||||||
@@ -122,7 +122,7 @@ Sometimes it's just easier to start over, cover my own needs and then making it
|
|||||||
|
|
||||||
## Buy me a coffee? Please don't
|
## Buy me a coffee? Please don't
|
||||||
|
|
||||||
Instead spend some money on a charity I care for: [kwf.nl](secure.kwf.nl/donation).
|
Instead spend some money on a charity I care for: [kwf.nl](https://secure.kwf.nl/donation).
|
||||||
Inspired by [haydenjames' issue](https://github.com/Mastermindzh/tidal-hifi/issues/27#issuecomment-704198429)
|
Inspired by [haydenjames' issue](https://github.com/Mastermindzh/tidal-hifi/issues/27#issuecomment-704198429)
|
||||||
|
|
||||||
## Images
|
## Images
|
||||||
|
@@ -1,20 +0,0 @@
|
|||||||
pkgbase = tidal-hifi-git
|
|
||||||
pkgdesc = The web version of listen.tidal.com running in electron with hifi support thanks to widevine.
|
|
||||||
pkgver = 2.1.1
|
|
||||||
pkgrel = 1
|
|
||||||
url = https://github.com/Mastermindzh/tidal-hifi
|
|
||||||
arch = x86_64
|
|
||||||
license = custom:MIT
|
|
||||||
makedepends = npm
|
|
||||||
makedepends = git
|
|
||||||
depends = libxss
|
|
||||||
depends = nss
|
|
||||||
depends = gtk3
|
|
||||||
provides = tidal-hifi
|
|
||||||
source = https://github.com/Mastermindzh/tidal-hifi/archive/2.1.1.zip
|
|
||||||
source = tidal-hifi.desktop
|
|
||||||
sha512sums = 510c94d9db8573103ee900dcd75b0416ea06ea62af7ed21818d2a5a77ab009a2737c852e7e20b97f846e14b07754a9e5a36ac5b9d0cd0a2a8d0aff3bbc75e622
|
|
||||||
sha512sums = 35f38ac308b871c1822d7f6f760f2fb54c3748cf769822cb0f0dfb90f0f5754ba9316da5e903a0d2e9839de3a43ec76f238f3f2e44021956fa1da19142081349
|
|
||||||
|
|
||||||
pkgname = tidal-hifi-git
|
|
||||||
|
|
@@ -1,56 +0,0 @@
|
|||||||
# Maintainer: Rick van Lieshout <info@rickvanlieshout.com>
|
|
||||||
|
|
||||||
_pkgname=tidal-hifi
|
|
||||||
pkgname="$_pkgname-git"
|
|
||||||
pkgver=2.1.1
|
|
||||||
pkgrel=1
|
|
||||||
pkgdesc="The web version of listen.tidal.com running in electron with hifi support thanks to widevine."
|
|
||||||
arch=("x86_64")
|
|
||||||
url="https://github.com/Mastermindzh/tidal-hifi"
|
|
||||||
license=("custom:MIT")
|
|
||||||
|
|
||||||
depends=("libxss" "nss" "gtk3")
|
|
||||||
makedepends=("npm" "git")
|
|
||||||
provides=("$_pkgname")
|
|
||||||
|
|
||||||
source=("https://github.com/Mastermindzh/tidal-hifi/archive/$pkgver.zip"
|
|
||||||
"${_pkgname}.desktop")
|
|
||||||
sha512sums=('510c94d9db8573103ee900dcd75b0416ea06ea62af7ed21818d2a5a77ab009a2737c852e7e20b97f846e14b07754a9e5a36ac5b9d0cd0a2a8d0aff3bbc75e622'
|
|
||||||
'35f38ac308b871c1822d7f6f760f2fb54c3748cf769822cb0f0dfb90f0f5754ba9316da5e903a0d2e9839de3a43ec76f238f3f2e44021956fa1da19142081349')
|
|
||||||
|
|
||||||
cdToPkg(){
|
|
||||||
cd "tidal-hifi-$pkgver"
|
|
||||||
}
|
|
||||||
|
|
||||||
prepare() {
|
|
||||||
cdToPkg
|
|
||||||
|
|
||||||
# install build dependencies
|
|
||||||
npm install
|
|
||||||
}
|
|
||||||
|
|
||||||
build() {
|
|
||||||
cdToPkg
|
|
||||||
|
|
||||||
# We are not using the systems Electron as we need castlab's Electron.
|
|
||||||
npm run build-arch
|
|
||||||
}
|
|
||||||
|
|
||||||
package() {
|
|
||||||
cdToPkg
|
|
||||||
|
|
||||||
install -d "${pkgdir}/opt/${_pkgname}/" "${pkgdir}/usr/bin" "${pkgdir}/usr/share/doc" "${pkgdir}/usr/share/licenses"
|
|
||||||
|
|
||||||
cp -r dist/linux-unpacked/* "${pkgdir}/opt/${_pkgname}/"
|
|
||||||
chmod +x "${pkgdir}/opt/${_pkgname}/${_pkgname}"
|
|
||||||
|
|
||||||
ln -s "/opt/${_pkgname}/${_pkgname}" "${pkgdir}/usr/bin/${_pkgname}"
|
|
||||||
|
|
||||||
install -Dm 644 "build/icon.png" "${pkgdir}/usr/share/pixmaps/${_pkgname}.png"
|
|
||||||
install -Dm 644 "${srcdir}/${_pkgname}.desktop" "${pkgdir}/usr/share/applications/${_pkgname}.desktop"
|
|
||||||
|
|
||||||
install -Dm 644 "README.md" "${pkgdir}/usr/share/doc/${pkgname}/README.md"
|
|
||||||
install -Dm 644 "LICENSE" "${pkgdir}/usr/share/licenses/${pkgname}/LICENSE"
|
|
||||||
ln -s "/opt/${_pkgname}/LICENSE.electron.txt" "${pkgdir}/usr/share/licenses/${pkgname}/LICENSE.electron.txt"
|
|
||||||
ln -s "/opt/${_pkgname}/LICENSES.chromium.html" "${pkgdir}/usr/share/licenses/${pkgname}/LICENSES.chromium.html"
|
|
||||||
}
|
|
@@ -1,18 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
# Will generate a correctly formatted SRCINFO file
|
|
||||||
|
|
||||||
SCRIPT_DIST=".SRCINFO"
|
|
||||||
|
|
||||||
# generate SRCINFO
|
|
||||||
makepkg --printsrcinfo > $SCRIPT_DIST
|
|
||||||
|
|
||||||
# replace pkgbase with tidal-hifi-git
|
|
||||||
pkgName="tidal-hifi-git"
|
|
||||||
sed -i "1s/.*/pkgbase = $pkgName/" $SCRIPT_DIST
|
|
||||||
|
|
||||||
# replace pkgbase with tidal-hifi-git
|
|
||||||
sed -i '/^pkgname/ d' $SCRIPT_DIST
|
|
||||||
echo "pkgname = $pkgName" >> $SCRIPT_DIST
|
|
||||||
|
|
||||||
# remove double line breaks and replace with single line breaks
|
|
||||||
sed -i '/^$/N;/^\n$/D' $SCRIPT_DIST
|
|
@@ -1,13 +0,0 @@
|
|||||||
[Desktop Entry]
|
|
||||||
Encoding=UTF-8
|
|
||||||
Name=tidal-hifi
|
|
||||||
GenericName=tidal-hifi
|
|
||||||
Comment=The web version of listen.tidal.com running in electron with hifi support thanks to widevine.
|
|
||||||
Exec=tidal-hifi %u
|
|
||||||
Icon=tidal-hifi.png
|
|
||||||
StartupNotify=true
|
|
||||||
Terminal=false
|
|
||||||
Type=Application
|
|
||||||
Categories=Network;Application;Audio;Video
|
|
||||||
StartupWMClass=tidal-hifi
|
|
||||||
X-PulseAudio-Properties=media.role=music
|
|
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "tidal-hifi",
|
"name": "tidal-hifi",
|
||||||
"version": "2.2.0",
|
"version": "2.3.0",
|
||||||
"description": "Tidal on Electron with widevine(hifi) support",
|
"description": "Tidal on Electron with widevine(hifi) support",
|
||||||
"main": "src/main.js",
|
"main": "src/main.js",
|
||||||
"scripts": {
|
"scripts": {
|
||||||
|
@@ -26,6 +26,7 @@ const settings = {
|
|||||||
width: "windowBounds.width",
|
width: "windowBounds.width",
|
||||||
height: "windowBounds.height",
|
height: "windowBounds.height",
|
||||||
},
|
},
|
||||||
|
minimizeOnClose: "minimizeOnClose",
|
||||||
};
|
};
|
||||||
|
|
||||||
module.exports = settings;
|
module.exports = settings;
|
||||||
|
@@ -56,6 +56,14 @@ function createWindow(options = {}) {
|
|||||||
// run stuff after first load
|
// run stuff after first load
|
||||||
mainWindow.webContents.once("did-finish-load", () => {});
|
mainWindow.webContents.once("did-finish-load", () => {});
|
||||||
|
|
||||||
|
mainWindow.on("close", function (event) {
|
||||||
|
if (!app.isQuiting && store.get(settings.minimizeOnClose)) {
|
||||||
|
event.preventDefault();
|
||||||
|
mainWindow.hide();
|
||||||
|
refreshTray(mainWindow);
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
});
|
||||||
// Emitted when the window is closed.
|
// Emitted when the window is closed.
|
||||||
mainWindow.on("closed", function () {
|
mainWindow.on("closed", function () {
|
||||||
closeSettingsWindow();
|
closeSettingsWindow();
|
||||||
|
@@ -21,6 +21,7 @@ function refreshSettings() {
|
|||||||
mpris.checked = store.get(settings.mpris);
|
mpris.checked = store.get(settings.mpris);
|
||||||
enableCustomHotkeys.checked = store.get(settings.enableCustomHotkeys);
|
enableCustomHotkeys.checked = store.get(settings.enableCustomHotkeys);
|
||||||
enableDiscord.checked = store.get(settings.enableDiscord);
|
enableDiscord.checked = store.get(settings.enableDiscord);
|
||||||
|
minimizeOnClose.checked = store.get(settings.minimizeOnClose);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -80,6 +81,7 @@ window.addEventListener("DOMContentLoaded", () => {
|
|||||||
port = get("port");
|
port = get("port");
|
||||||
menuBar = get("menuBar");
|
menuBar = get("menuBar");
|
||||||
trayIcon = get("trayIcon");
|
trayIcon = get("trayIcon");
|
||||||
|
minimizeOnClose = get("minimizeOnClose");
|
||||||
mpris = get("mprisCheckbox");
|
mpris = get("mprisCheckbox");
|
||||||
enableCustomHotkeys = get("enableCustomHotkeys");
|
enableCustomHotkeys = get("enableCustomHotkeys");
|
||||||
enableDiscord = get("enableDiscord");
|
enableDiscord = get("enableDiscord");
|
||||||
@@ -95,4 +97,5 @@ window.addEventListener("DOMContentLoaded", () => {
|
|||||||
addInputListener(mpris, settings.mpris);
|
addInputListener(mpris, settings.mpris);
|
||||||
addInputListener(enableCustomHotkeys, settings.enableCustomHotkeys);
|
addInputListener(enableCustomHotkeys, settings.enableCustomHotkeys);
|
||||||
addInputListener(enableDiscord, settings.enableDiscord);
|
addInputListener(enableDiscord, settings.enableDiscord);
|
||||||
|
addInputListener(minimizeOnClose, settings.minimizeOnClose);
|
||||||
});
|
});
|
||||||
|
@@ -80,6 +80,16 @@
|
|||||||
<span class="slider round"></span>
|
<span class="slider round"></span>
|
||||||
</label>
|
</label>
|
||||||
</div>
|
</div>
|
||||||
|
<div class="option">
|
||||||
|
<h4>Minimize on Close</h4>
|
||||||
|
<p>
|
||||||
|
Minimize window on close instead <br />
|
||||||
|
</p>
|
||||||
|
<label class="switch">
|
||||||
|
<input id="minimizeOnClose" type="checkbox">
|
||||||
|
<span class="slider round"></span>
|
||||||
|
</label>
|
||||||
|
</div>
|
||||||
<div class="option">
|
<div class="option">
|
||||||
<h4>Hotkeys</h4>
|
<h4>Hotkeys</h4>
|
||||||
<p>
|
<p>
|
||||||
|
@@ -23,7 +23,7 @@ const elements = {
|
|||||||
next: '*[data-test="next"]',
|
next: '*[data-test="next"]',
|
||||||
previous: 'button[data-test="previous"]',
|
previous: 'button[data-test="previous"]',
|
||||||
title: '*[data-test^="footer-track-title"]',
|
title: '*[data-test^="footer-track-title"]',
|
||||||
artists: '*[class^="elemental__text elemental__text css-oxcos"]',
|
artists: '*[data-test^="grid-item-detail-text-title-artist"]',
|
||||||
home: '*[data-test="menu--home"]',
|
home: '*[data-test="menu--home"]',
|
||||||
back: '[class^="backwardButton"]',
|
back: '[class^="backwardButton"]',
|
||||||
forward: '[class^="forwardButton"]',
|
forward: '[class^="forwardButton"]',
|
||||||
@@ -38,6 +38,7 @@ const elements = {
|
|||||||
current: '*[data-test="current-time"]',
|
current: '*[data-test="current-time"]',
|
||||||
duration: '*[data-test="duration-time"]',
|
duration: '*[data-test="duration-time"]',
|
||||||
bar: '*[data-test="progress-bar"]',
|
bar: '*[data-test="progress-bar"]',
|
||||||
|
footer: "#footerPlayer",
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Get an element from the dom
|
* Get an element from the dom
|
||||||
@@ -63,6 +64,19 @@ const elements = {
|
|||||||
return "";
|
return "";
|
||||||
},
|
},
|
||||||
|
|
||||||
|
getArtists: function () {
|
||||||
|
const footer = this.get("footer");
|
||||||
|
|
||||||
|
if (footer) {
|
||||||
|
const artists = footer.querySelector(this["artists"]);
|
||||||
|
if (artists) {
|
||||||
|
return artists.innerText;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return "unknown artist(s)";
|
||||||
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Shorthand function to get the text of a dom element
|
* Shorthand function to get the text of a dom element
|
||||||
* @param {*} key key in elements object to fetch
|
* @param {*} key key in elements object to fetch
|
||||||
@@ -266,7 +280,7 @@ function updateURL() {
|
|||||||
*/
|
*/
|
||||||
setInterval(function () {
|
setInterval(function () {
|
||||||
const title = elements.getText("title");
|
const title = elements.getText("title");
|
||||||
const artists = elements.getText("artists");
|
const artists = elements.getArtists();
|
||||||
const current = elements.getText("current");
|
const current = elements.getText("current");
|
||||||
const duration = elements.getText("duration");
|
const duration = elements.getText("duration");
|
||||||
const progressBarcurrentTime = elements.get("bar").getAttribute("aria-valuenow");
|
const progressBarcurrentTime = elements.get("bar").getAttribute("aria-valuenow");
|
||||||
@@ -293,21 +307,21 @@ setInterval(function () {
|
|||||||
currentPlayStatus = currentStatus;
|
currentPlayStatus = currentStatus;
|
||||||
|
|
||||||
// check progress bar value and make sure current stays up to date after switch
|
// check progress bar value and make sure current stays up to date after switch
|
||||||
if(progressBarTime != progressBarcurrentTime && !titleOrArtistChanged) {
|
if (progressBarTime != progressBarcurrentTime && !titleOrArtistChanged) {
|
||||||
progressBarTime = progressBarcurrentTime;
|
progressBarTime = progressBarcurrentTime;
|
||||||
currentTime = options.current;
|
currentTime = options.current;
|
||||||
options.duration = duration;
|
options.duration = duration;
|
||||||
currentTimeChanged = true;
|
currentTimeChanged = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(currentTimeChanged) {
|
if (currentTimeChanged) {
|
||||||
if(options.current == currentTime && currentStatus != "paused") return;
|
if (options.current == currentTime && currentStatus != "paused") return;
|
||||||
currentTime = options.current;
|
currentTime = options.current;
|
||||||
currentTimeChanged = false;
|
currentTimeChanged = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
// make sure current is set to 0 if title changes
|
// make sure current is set to 0 if title changes
|
||||||
if(titleOrArtistChanged) {
|
if (titleOrArtistChanged) {
|
||||||
options.current = "0:00";
|
options.current = "0:00";
|
||||||
currentTime = options.current;
|
currentTime = options.current;
|
||||||
progressBarTime = progressBarcurrentTime;
|
progressBarTime = progressBarcurrentTime;
|
||||||
|
@@ -6,8 +6,8 @@ const mediaInfoModule = require("./mediaInfo");
|
|||||||
const discordModule = [];
|
const discordModule = [];
|
||||||
|
|
||||||
function timeToSeconds(timeArray) {
|
function timeToSeconds(timeArray) {
|
||||||
let minutes = (timeArray[0] * 1);
|
let minutes = timeArray[0] * 1;
|
||||||
let seconds = (minutes * 60) + (timeArray[1] * 1);
|
let seconds = minutes * 60 + timeArray[1] * 1;
|
||||||
return seconds;
|
return seconds;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -19,14 +19,16 @@ const observer = (event, arg) => {
|
|||||||
const currentSeconds = timeToSeconds(mediaInfoModule.mediaInfo.current.split(":"));
|
const currentSeconds = timeToSeconds(mediaInfoModule.mediaInfo.current.split(":"));
|
||||||
const durationSeconds = timeToSeconds(mediaInfoModule.mediaInfo.duration.split(":"));
|
const durationSeconds = timeToSeconds(mediaInfoModule.mediaInfo.duration.split(":"));
|
||||||
const date = new Date();
|
const date = new Date();
|
||||||
const now = date.getTime() / 1000 | 0;
|
const now = (date.getTime() / 1000) | 0;
|
||||||
const remaining = date.setSeconds(date.getSeconds() + (durationSeconds - currentSeconds));
|
const remaining = date.setSeconds(date.getSeconds() + (durationSeconds - currentSeconds));
|
||||||
if (mediaInfoModule.mediaInfo.url) {
|
if (mediaInfoModule.mediaInfo.url) {
|
||||||
rpc.setActivity({
|
rpc.setActivity({
|
||||||
...idleStatus,
|
...idleStatus,
|
||||||
...{
|
...{
|
||||||
details: `Listening to ${mediaInfoModule.mediaInfo.title}`,
|
details: `Listening to ${mediaInfoModule.mediaInfo.title}`,
|
||||||
state: mediaInfoModule.mediaInfo.artist,
|
state: mediaInfoModule.mediaInfo.artist
|
||||||
|
? mediaInfoModule.mediaInfo.artist
|
||||||
|
: "unknown artist(s)",
|
||||||
startTimestamp: parseInt(now),
|
startTimestamp: parseInt(now),
|
||||||
endTimestamp: parseInt(remaining),
|
endTimestamp: parseInt(remaining),
|
||||||
buttons: [{ label: "Play on Tidal", url: mediaInfoModule.mediaInfo.url }],
|
buttons: [{ label: "Play on Tidal", url: mediaInfoModule.mediaInfo.url }],
|
||||||
|
@@ -15,6 +15,7 @@ const store = new Store({
|
|||||||
port: 47836,
|
port: 47836,
|
||||||
},
|
},
|
||||||
trayIcon: true,
|
trayIcon: true,
|
||||||
|
minimizeOnClose : false,
|
||||||
mpris: false,
|
mpris: false,
|
||||||
enableCustomHotkeys: false,
|
enableCustomHotkeys: false,
|
||||||
enableDiscord: false,
|
enableDiscord: false,
|
||||||
|
@@ -1,5 +1,7 @@
|
|||||||
const { Tray } = require("electron");
|
const { Tray, app } = require("electron");
|
||||||
const { getMenu } = require("./menu");
|
const { Menu } = require("electron");
|
||||||
|
const { getMenu, mainMenu } = require("./menu");
|
||||||
|
const { store, settings } = require("./settings");
|
||||||
const trayModule = {};
|
const trayModule = {};
|
||||||
let tray;
|
let tray;
|
||||||
|
|
||||||
@@ -7,16 +9,41 @@ trayModule.addTray = function (options = { icon: "" }) {
|
|||||||
tray = new Tray(options.icon);
|
tray = new Tray(options.icon);
|
||||||
};
|
};
|
||||||
|
|
||||||
trayModule.refreshTray = function () {
|
trayModule.refreshTray = function (mainWindow) {
|
||||||
if (!tray) {
|
if (!tray) {
|
||||||
trayModule.addTray();
|
trayModule.addTray();
|
||||||
}
|
}
|
||||||
|
|
||||||
tray.on("click", function (e) {
|
tray.on("click", function (e) {
|
||||||
// do nothing on click
|
if (mainWindow) {
|
||||||
|
mainWindow.show();
|
||||||
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
tray.setToolTip("Tidal-hifi");
|
tray.setToolTip("Tidal-hifi");
|
||||||
tray.setContextMenu(getMenu());
|
|
||||||
|
if (mainWindow && store.get(settings.minimizeOnClose)) {
|
||||||
|
tray.setContextMenu(
|
||||||
|
Menu.buildFromTemplate([
|
||||||
|
{
|
||||||
|
label: "Toggle Window",
|
||||||
|
click: function () {
|
||||||
|
mainWindow.isVisible() ? mainWindow.hide() : mainWindow.show();
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
label: "Quit",
|
||||||
|
click: function () {
|
||||||
|
mainWindow.destroy();
|
||||||
|
app.quit();
|
||||||
|
},
|
||||||
|
},
|
||||||
|
...mainMenu, //we add menu items from the other context
|
||||||
|
])
|
||||||
|
);
|
||||||
|
} else {
|
||||||
|
tray.setContextMenu(getMenu());
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
module.exports = trayModule;
|
module.exports = trayModule;
|
||||||
|
Reference in New Issue
Block a user