utils: use tray for desktop notification

This commit is contained in:
tobtoht 2023-03-29 10:46:53 +02:00
parent 6b065acdae
commit 37153356ee
No known key found for this signature in database
GPG key ID: E45B10DD027D2472
5 changed files with 21 additions and 36 deletions

View file

@ -432,7 +432,7 @@ void MainWindow::initWalletContext() {
connect(m_wallet, &Wallet::unconfirmedMoneyReceived, this, [this](const QString &txId, uint64_t amount){ connect(m_wallet, &Wallet::unconfirmedMoneyReceived, this, [this](const QString &txId, uint64_t amount){
if (m_wallet->isSynchronized()) { if (m_wallet->isSynchronized()) {
auto notify = QString("%1 XMR (pending)").arg(WalletManager::displayAmount(amount, false)); auto notify = QString("%1 XMR (pending)").arg(WalletManager::displayAmount(amount, false));
Utils::desktopNotify("Payment received", notify, 5000); m_windowManager->notify("Payment received", notify, 5000);
} }
}); });

View file

@ -579,6 +579,18 @@ void WindowManager::buildTrayMenu() {
menu->addAction("Exit Feather", this, &WindowManager::close); menu->addAction("Exit Feather", this, &WindowManager::close);
} }
void WindowManager::notify(const QString &title, const QString &message, int duration) {
if (!m_tray || !QSystemTrayIcon::supportsMessages()) {
return;
}
if (config()->get(Config::hideNotifications).toBool()) {
return;
}
m_tray->showMessage(title, message, icons()->icon("appicons/64x64.png"), duration);
}
// ######################## NETWORKING ######################## // ######################## NETWORKING ########################
void WindowManager::onInitialNetworkConfigured() { void WindowManager::onInitialNetworkConfigured() {

View file

@ -30,6 +30,8 @@ public:
void showSettings(Nodes *nodes, QWidget *parent, bool showProxyTab = false); void showSettings(Nodes *nodes, QWidget *parent, bool showProxyTab = false);
void notify(const QString &title, const QString &message, int duration);
EventFilter *eventFilter; EventFilter *eventFilter;
signals: signals:

View file

@ -465,7 +465,7 @@ QString blockExplorerLink(const QString &blockExplorer, NetworkType::Type nettyp
return QString("https://testnet.xmrchain.net/tx/%1").arg(txid); return QString("https://testnet.xmrchain.net/tx/%1").arg(txid);
} }
return QString(""); return {};
} }
void externalLinkWarning(QWidget *parent, const QString &url){ void externalLinkWarning(QWidget *parent, const QString &url){
@ -493,33 +493,6 @@ void externalLinkWarning(QWidget *parent, const QString &url){
} }
} }
void desktopNotify(const QString &title, const QString &message, int duration) {
if (config()->get(Config::hideNotifications).toBool()) {
return;
}
QStringList notify_send = QStringList() << title << message << "-t" << QString::number(duration);
QStringList kdialog = QStringList() << title << message;
QStringList macos = QStringList() << "-e" << QString(R"(display notification "%1" with title "%2")").arg(message).arg(title);
#if defined(Q_OS_LINUX)
QProcess process;
if (fileExists("/usr/bin/kdialog"))
process.start("/usr/bin/kdialog", kdialog);
else if (fileExists("/usr/bin/notify-send"))
process.start("/usr/bin/notify-send", notify_send);
process.waitForFinished(-1);
QString stdout = process.readAllStandardOutput();
QString stderr = process.readAllStandardError();
#elif defined(Q_OS_MACOS)
QProcess process;
// @TODO: need to escape special chars with "\"
process.start("osascript", macos);
process.waitForFinished(-1);
QString stdout = process.readAllStandardOutput();
QString stderr = process.readAllStandardError();
#endif
}
QString displayAddress(const QString& address, int sections, const QString& sep) { QString displayAddress(const QString& address, int sections, const QString& sep) {
QStringList list; QStringList list;
if (sections < 1) sections = 1; if (sections < 1) sections = 1;
@ -557,23 +530,23 @@ void applicationLogHandler(QtMsgType type, const QMessageLogContext &context, co
switch (type) { switch (type) {
case QtDebugMsg: case QtDebugMsg:
line = QString("[%1 D] %2(:%3) %4\n").arg(date).arg(fn).arg(context.line).arg(msg); line = QString("[%1 D] %2(:%3) %4\n").arg(date, fn, QString::number(context.line), msg);
fprintf(stderr, "%s", line.toLatin1().data()); fprintf(stderr, "%s", line.toLatin1().data());
break; break;
case QtInfoMsg: case QtInfoMsg:
line = QString("[%1 I] %2\n").arg(date).arg(msg); line = QString("[%1 I] %2\n").arg(date, msg);
fprintf(stdout, "%s", line.toLatin1().data()); fprintf(stdout, "%s", line.toLatin1().data());
break; break;
case QtWarningMsg: case QtWarningMsg:
line = QString("[%1 W] %2(:%3) %4\n").arg(date).arg(fn).arg(context.line).arg(msg); line = QString("[%1 W] %2(:%3) %4\n").arg(date, fn, QString::number(context.line), msg);
fprintf(stdout, "%s", line.toLatin1().data()); fprintf(stdout, "%s", line.toLatin1().data());
break; break;
case QtCriticalMsg: case QtCriticalMsg:
line = QString("[%1 C] %2(:%3) %4\n").arg(date).arg(fn).arg(context.line).arg(msg); line = QString("[%1 C] %2(:%3) %4\n").arg(date, fn, QString::number(context.line), msg);
fprintf(stderr, "%s", line.toLatin1().data()); fprintf(stderr, "%s", line.toLatin1().data());
break; break;
case QtFatalMsg: case QtFatalMsg:
line = QString("[%1 F] %2(:%3) %4\n").arg(date).arg(fn).arg(context.line).arg(msg); line = QString("[%1 F] %2(:%3) %4\n").arg(date, fn, QString::number(context.line), msg);
fprintf(stderr, "%s", line.toLatin1().data()); fprintf(stderr, "%s", line.toLatin1().data());
break; break;
} }

View file

@ -59,8 +59,6 @@ namespace Utils
QString blockExplorerLink(const QString &blockExplorer, NetworkType::Type nettype, const QString &txid); QString blockExplorerLink(const QString &blockExplorer, NetworkType::Type nettype, const QString &txid);
void externalLinkWarning(QWidget *parent, const QString &url); void externalLinkWarning(QWidget *parent, const QString &url);
void desktopNotify(const QString &title, const QString &message, int duration);
QString displayAddress(const QString& address, int sections = 3, const QString & sep = " "); QString displayAddress(const QString& address, int sections = 3, const QString & sep = " ");
QTextCharFormat addressTextFormat(const SubaddressIndex &index, quint64 amount); QTextCharFormat addressTextFormat(const SubaddressIndex &index, quint64 amount);