mirror of
https://github.com/arcan1s/awesome-widgets.git
synced 2025-05-05 04:33:55 +00:00
Compare commits
1 Commits
f1a01fbb32
...
ce93664f5b
Author | SHA1 | Date | |
---|---|---|---|
ce93664f5b |
@ -9,9 +9,6 @@ endif ()
|
|||||||
if (POLICY CMP0071)
|
if (POLICY CMP0071)
|
||||||
cmake_policy(SET CMP0071 NEW)
|
cmake_policy(SET CMP0071 NEW)
|
||||||
endif ()
|
endif ()
|
||||||
if (POLICY CMP0160)
|
|
||||||
cmake_policy(SET CMP0160 OLD)
|
|
||||||
endif ()
|
|
||||||
|
|
||||||
project(awesomewidgets)
|
project(awesomewidgets)
|
||||||
set(PROJECT_AUTHOR "Evgeniy Alekseev")
|
set(PROJECT_AUTHOR "Evgeniy Alekseev")
|
||||||
|
@ -88,6 +88,20 @@ void AWActions::showReadme()
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void AWActions::showLegacyInfo()
|
||||||
|
{
|
||||||
|
auto msgBox = new QMessageBox(nullptr);
|
||||||
|
msgBox->setAttribute(Qt::WA_DeleteOnClose);
|
||||||
|
msgBox->setModal(false);
|
||||||
|
msgBox->setWindowTitle(i18n("Not supported"));
|
||||||
|
msgBox->setText(i18n("You are using mammoth's Qt version, try to update it first"));
|
||||||
|
msgBox->setStandardButtons(QMessageBox::Ok);
|
||||||
|
msgBox->setIcon(QMessageBox::Information);
|
||||||
|
|
||||||
|
msgBox->open();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
// HACK: this method uses variables from version.h
|
// HACK: this method uses variables from version.h
|
||||||
QString AWActions::getAboutText(const QString &_type)
|
QString AWActions::getAboutText(const QString &_type)
|
||||||
{
|
{
|
||||||
@ -121,6 +135,7 @@ void AWActions::sendNotification(const QString &_eventId, const QString &_messag
|
|||||||
{
|
{
|
||||||
qCDebug(LOG_AW) << "Event" << _eventId << "with message" << _message;
|
qCDebug(LOG_AW) << "Event" << _eventId << "with message" << _message;
|
||||||
|
|
||||||
auto *event = KNotification::event(_eventId, QString("Awesome Widget ::: %1").arg(_eventId), _message);
|
KNotification *notification
|
||||||
event->setComponentName("plasma-applet-org.kde.plasma.awesome-widget");
|
= KNotification::event(_eventId, QString("Awesome Widget ::: %1").arg(_eventId), _message);
|
||||||
|
notification->setComponentName("plasma-applet-org.kde.plasma.awesome-widget");
|
||||||
}
|
}
|
||||||
|
@ -33,6 +33,7 @@ public:
|
|||||||
Q_INVOKABLE void checkUpdates(bool _showAnyway = false);
|
Q_INVOKABLE void checkUpdates(bool _showAnyway = false);
|
||||||
Q_INVOKABLE static QString getFileContent(const QString &_path);
|
Q_INVOKABLE static QString getFileContent(const QString &_path);
|
||||||
Q_INVOKABLE static bool runCmd(const QString &_cmd, const QStringList &_args);
|
Q_INVOKABLE static bool runCmd(const QString &_cmd, const QStringList &_args);
|
||||||
|
Q_INVOKABLE static void showLegacyInfo();
|
||||||
Q_INVOKABLE static void showReadme();
|
Q_INVOKABLE static void showReadme();
|
||||||
// configuration slots
|
// configuration slots
|
||||||
Q_INVOKABLE static QString getAboutText(const QString &_type);
|
Q_INVOKABLE static QString getAboutText(const QString &_type);
|
||||||
|
@ -18,7 +18,6 @@
|
|||||||
#include "awbugreporter.h"
|
#include "awbugreporter.h"
|
||||||
|
|
||||||
#include <KI18n/KLocalizedString>
|
#include <KI18n/KLocalizedString>
|
||||||
#include <KNotifications/KNotification>
|
|
||||||
|
|
||||||
#include <QDesktopServices>
|
#include <QDesktopServices>
|
||||||
#include <QJsonDocument>
|
#include <QJsonDocument>
|
||||||
@ -115,12 +114,6 @@ void AWBugReporter::issueReplyReceived(QNetworkReply *_reply)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void AWBugReporter::openBugReport()
|
|
||||||
{
|
|
||||||
QDesktopServices::openUrl(m_lastBugUrl);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void AWBugReporter::showInformation(const int _number, const QString &_url)
|
void AWBugReporter::showInformation(const int _number, const QString &_url)
|
||||||
{
|
{
|
||||||
qCDebug(LOG_AW) << "Created issue with number" << _number << "and url" << _url;
|
qCDebug(LOG_AW) << "Created issue with number" << _number << "and url" << _url;
|
||||||
@ -128,9 +121,29 @@ void AWBugReporter::showInformation(const int _number, const QString &_url)
|
|||||||
// cache url first
|
// cache url first
|
||||||
m_lastBugUrl = _url;
|
m_lastBugUrl = _url;
|
||||||
|
|
||||||
auto event = KNotification::event("system", i18n("Issue created"), i18n("Issue %1 has been created", _number));
|
auto msgBox = new QMessageBox(nullptr);
|
||||||
event->setComponentName("plasma-applet-org.kde.plasma.awesome-widget");
|
msgBox->setAttribute(Qt::WA_DeleteOnClose);
|
||||||
|
msgBox->setModal(false);
|
||||||
|
msgBox->setWindowTitle(i18n("Issue created"));
|
||||||
|
msgBox->setText(i18n("Issue %1 has been created", _number));
|
||||||
|
msgBox->setStandardButtons(QMessageBox::Open | QMessageBox::Close);
|
||||||
|
msgBox->setIcon(QMessageBox::Information);
|
||||||
|
|
||||||
auto action = event->addAction(i18n("Details"));
|
msgBox->open(this, SLOT(userReplyOnBugReport(QAbstractButton *)));
|
||||||
connect(action, &KNotificationAction::activated, this, &AWBugReporter::openBugReport);
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void AWBugReporter::userReplyOnBugReport(QAbstractButton *_button)
|
||||||
|
{
|
||||||
|
auto ret = dynamic_cast<QMessageBox *>(sender())->buttonRole(_button);
|
||||||
|
qCInfo(LOG_AW) << "User select" << ret;
|
||||||
|
|
||||||
|
switch (ret) {
|
||||||
|
case QMessageBox::AcceptRole:
|
||||||
|
QDesktopServices::openUrl(m_lastBugUrl);
|
||||||
|
break;
|
||||||
|
case QMessageBox::RejectRole:
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -40,8 +40,8 @@ signals:
|
|||||||
|
|
||||||
private slots:
|
private slots:
|
||||||
void issueReplyReceived(QNetworkReply *_reply);
|
void issueReplyReceived(QNetworkReply *_reply);
|
||||||
void openBugReport();
|
|
||||||
void showInformation(int _number, const QString &_url);
|
void showInformation(int _number, const QString &_url);
|
||||||
|
void userReplyOnBugReport(QAbstractButton *_button);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
QString m_lastBugUrl;
|
QString m_lastBugUrl;
|
||||||
|
@ -21,7 +21,7 @@
|
|||||||
#include <QDBusError>
|
#include <QDBusError>
|
||||||
#include <QThread>
|
#include <QThread>
|
||||||
#include <QTimer>
|
#include <QTimer>
|
||||||
#include <QtConcurrent>
|
#include <QtConcurrent/QtConcurrent>
|
||||||
|
|
||||||
#include "awdataaggregator.h"
|
#include "awdataaggregator.h"
|
||||||
#include "awdataengineaggregator.h"
|
#include "awdataengineaggregator.h"
|
||||||
@ -189,8 +189,7 @@ void AWKeys::dataUpdated(const QHash<QString, KSysGuard::SensorInfo> &_sensors,
|
|||||||
if (!_sensors.contains(data.sensorProperty))
|
if (!_sensors.contains(data.sensorProperty))
|
||||||
continue;
|
continue;
|
||||||
auto sensor = _sensors[data.sensorProperty];
|
auto sensor = _sensors[data.sensorProperty];
|
||||||
std::ignore = QtConcurrent::run(m_threadPool, &AWKeys::setDataBySource, this, data.sensorProperty, sensor,
|
std::ignore = QtConcurrent::run(m_threadPool, &AWKeys::setDataBySource, this, data.sensorProperty, sensor, data.payload);
|
||||||
data.payload);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -18,7 +18,6 @@
|
|||||||
#include "awupdatehelper.h"
|
#include "awupdatehelper.h"
|
||||||
|
|
||||||
#include <KI18n/KLocalizedString>
|
#include <KI18n/KLocalizedString>
|
||||||
#include <KNotifications/KNotification>
|
|
||||||
|
|
||||||
#include <QDesktopServices>
|
#include <QDesktopServices>
|
||||||
#include <QJsonDocument>
|
#include <QJsonDocument>
|
||||||
@ -71,7 +70,8 @@ bool AWUpdateHelper::checkVersion()
|
|||||||
qCInfo(LOG_AW) << "Found version" << version << "actual one is" << m_foundVersion;
|
qCInfo(LOG_AW) << "Found version" << version << "actual one is" << m_foundVersion;
|
||||||
|
|
||||||
if ((version != m_foundVersion) && (!QString(CHANGELOG).isEmpty())) {
|
if ((version != m_foundVersion) && (!QString(CHANGELOG).isEmpty())) {
|
||||||
sendNotification(i18nc("Changelog of %1", VERSION), QString(CHANGELOG).replace('@', '\n'));
|
genMessageBox(i18nc("Changelog of %1", VERSION), QString(CHANGELOG).replace('@', '\n'), QMessageBox::Ok)
|
||||||
|
->open();
|
||||||
return true;
|
return true;
|
||||||
} else if (version != m_foundVersion) {
|
} else if (version != m_foundVersion) {
|
||||||
qCWarning(LOG_AW) << "No changelog information provided";
|
qCWarning(LOG_AW) << "No changelog information provided";
|
||||||
@ -84,12 +84,6 @@ bool AWUpdateHelper::checkVersion()
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void AWUpdateHelper::openReleasesPage()
|
|
||||||
{
|
|
||||||
QDesktopServices::openUrl(QString(RELEASES) + m_foundVersion.toString());
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void AWUpdateHelper::showInfo(const QVersionNumber &_version)
|
void AWUpdateHelper::showInfo(const QVersionNumber &_version)
|
||||||
{
|
{
|
||||||
qCDebug(LOG_AW) << "Version" << _version;
|
qCDebug(LOG_AW) << "Version" << _version;
|
||||||
@ -97,7 +91,7 @@ void AWUpdateHelper::showInfo(const QVersionNumber &_version)
|
|||||||
auto text = i18n("You are using the actual version %1", _version.toString());
|
auto text = i18n("You are using the actual version %1", _version.toString());
|
||||||
if (!QString(COMMIT_SHA).isEmpty())
|
if (!QString(COMMIT_SHA).isEmpty())
|
||||||
text += QString(" (%1)").arg(QString(COMMIT_SHA));
|
text += QString(" (%1)").arg(QString(COMMIT_SHA));
|
||||||
sendNotification(i18n("No new version found"), text);
|
return genMessageBox(i18n("No new version found"), text, QMessageBox::Ok)->open();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -111,9 +105,24 @@ void AWUpdateHelper::showUpdates(const QVersionNumber &_version)
|
|||||||
text += i18n("New version : %1", _version.toString()) + "\n\n";
|
text += i18n("New version : %1", _version.toString()) + "\n\n";
|
||||||
text += i18n("Click \"Ok\" to download");
|
text += i18n("Click \"Ok\" to download");
|
||||||
|
|
||||||
auto event = sendNotification(i18n("There are updates"), text);
|
genMessageBox(i18n("There are updates"), text, QMessageBox::Ok | QMessageBox::Cancel)
|
||||||
auto action = event->addAction(i18n("Details"));
|
->open(this, SLOT(userReplyOnUpdates(QAbstractButton *)));
|
||||||
connect(action, &KNotificationAction::activated, this, &AWUpdateHelper::openReleasesPage);
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void AWUpdateHelper::userReplyOnUpdates(QAbstractButton *_button)
|
||||||
|
{
|
||||||
|
auto ret = dynamic_cast<QMessageBox *>(sender())->buttonRole(_button);
|
||||||
|
qCInfo(LOG_AW) << "User select" << ret;
|
||||||
|
|
||||||
|
switch (ret) {
|
||||||
|
case QMessageBox::AcceptRole:
|
||||||
|
QDesktopServices::openUrl(QString(RELEASES) + m_foundVersion.toString());
|
||||||
|
break;
|
||||||
|
case QMessageBox::RejectRole:
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -149,12 +158,18 @@ void AWUpdateHelper::versionReplyReceived(QNetworkReply *_reply, const bool _sho
|
|||||||
|
|
||||||
|
|
||||||
// additional method which is used to show message box which does not block UI
|
// additional method which is used to show message box which does not block UI
|
||||||
KNotification *AWUpdateHelper::sendNotification(const QString &_title, const QString &_body)
|
QMessageBox *AWUpdateHelper::genMessageBox(const QString &_title, const QString &_body,
|
||||||
|
const QMessageBox::StandardButtons _buttons)
|
||||||
{
|
{
|
||||||
qCDebug(LOG_AW) << "Construct message box with title" << _title << "and body" << _body;
|
qCDebug(LOG_AW) << "Construct message box with title" << _title << "and body" << _body;
|
||||||
|
|
||||||
auto event = KNotification::event("system", _title, _body);
|
auto msgBox = new QMessageBox(nullptr);
|
||||||
event->setComponentName("plasma-applet-org.kde.plasma.awesome-widget");
|
msgBox->setAttribute(Qt::WA_DeleteOnClose);
|
||||||
|
msgBox->setModal(false);
|
||||||
|
msgBox->setWindowTitle(_title);
|
||||||
|
msgBox->setText(_body);
|
||||||
|
msgBox->setStandardButtons(_buttons);
|
||||||
|
msgBox->setIcon(QMessageBox::Information);
|
||||||
|
|
||||||
return event;
|
return msgBox;
|
||||||
}
|
}
|
||||||
|
@ -17,11 +17,11 @@
|
|||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
|
#include <QMessageBox>
|
||||||
#include <QObject>
|
#include <QObject>
|
||||||
#include <QVersionNumber>
|
#include <QVersionNumber>
|
||||||
|
|
||||||
|
|
||||||
class KNotification;
|
|
||||||
class QNetworkReply;
|
class QNetworkReply;
|
||||||
|
|
||||||
class AWUpdateHelper : public QObject
|
class AWUpdateHelper : public QObject
|
||||||
@ -35,13 +35,14 @@ public:
|
|||||||
bool checkVersion();
|
bool checkVersion();
|
||||||
|
|
||||||
private slots:
|
private slots:
|
||||||
void openReleasesPage();
|
|
||||||
static void showInfo(const QVersionNumber &_version);
|
static void showInfo(const QVersionNumber &_version);
|
||||||
void showUpdates(const QVersionNumber &_version);
|
void showUpdates(const QVersionNumber &_version);
|
||||||
|
void userReplyOnUpdates(QAbstractButton *_button);
|
||||||
void versionReplyReceived(QNetworkReply *_reply, bool _showAnyway);
|
void versionReplyReceived(QNetworkReply *_reply, bool _showAnyway);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
static KNotification *sendNotification(const QString &_title, const QString &_body);
|
static QMessageBox *genMessageBox(const QString &_title, const QString &_body,
|
||||||
|
QMessageBox::StandardButtons _buttons);
|
||||||
QVersionNumber m_foundVersion;
|
QVersionNumber m_foundVersion;
|
||||||
QString m_genericConfig;
|
QString m_genericConfig;
|
||||||
};
|
};
|
||||||
|
@ -8,7 +8,7 @@ add_definitions(
|
|||||||
${Qt6Qml_DEFINITIONS} ${Qt6Widgets_DEFINITIONS}
|
${Qt6Qml_DEFINITIONS} ${Qt6Widgets_DEFINITIONS}
|
||||||
)
|
)
|
||||||
set(Qt_INCLUDE
|
set(Qt_INCLUDE
|
||||||
${Qt6Core_INCLUDE_DIRS} ${Qt6Concurrent_INCLUDE_DIRS} ${Qt6DBus_INCLUDE_DIRS} ${Qt6Network_INCLUDE_DIRS}
|
${Qt6Core_INCLUDE_DIRS} ${Qt6DBus_INCLUDE_DIRS} ${Qt6Network_INCLUDE_DIRS}
|
||||||
${Qt6Qml_INCLUDE_DIRS} ${Qt6Widgets_INCLUDE_DIRS}
|
${Qt6Qml_INCLUDE_DIRS} ${Qt6Widgets_INCLUDE_DIRS}
|
||||||
)
|
)
|
||||||
set(Qt_LIBRARIES
|
set(Qt_LIBRARIES
|
||||||
|
Loading…
x
Reference in New Issue
Block a user