mirror of
				https://github.com/arcan1s/awesome-widgets.git
				synced 2025-10-24 18:33:43 +00:00 
			
		
		
		
	Replace yahoo finance to stooq (#131)
Old code is dropped to separated provider
This commit is contained in:
		| @ -21,7 +21,7 @@ BreakBeforeBinaryOperators: All | |||||||
| BreakBeforeBraces: Linux | BreakBeforeBraces: Linux | ||||||
| BreakBeforeTernaryOperators: true | BreakBeforeTernaryOperators: true | ||||||
| BreakConstructorInitializersBeforeComma: true | BreakConstructorInitializersBeforeComma: true | ||||||
| ColumnLimit:     80 | ColumnLimit:     100 | ||||||
| CommentPragmas:  '^ IWYU pragma:' | CommentPragmas:  '^ IWYU pragma:' | ||||||
| ConstructorInitializerAllOnOneLineOrOnePerLine: false | ConstructorInitializerAllOnOneLineOrOnePerLine: false | ||||||
| ConstructorInitializerIndentWidth: 4 | ConstructorInitializerIndentWidth: 4 | ||||||
|  | |||||||
| @ -6,6 +6,9 @@ cmake_policy(SET CMP0015 NEW) | |||||||
| if (POLICY CMP0063) | if (POLICY CMP0063) | ||||||
|     cmake_policy(SET CMP0063 OLD) |     cmake_policy(SET CMP0063 OLD) | ||||||
| endif () | endif () | ||||||
|  | if (POLICY CMP0071) | ||||||
|  |     cmake_policy(SET CMP0071 NEW) | ||||||
|  | endif () | ||||||
|  |  | ||||||
| project(awesomewidgets) | project(awesomewidgets) | ||||||
| set(PROJECT_AUTHOR "Evgeniy Alekseev") | set(PROJECT_AUTHOR "Evgeniy Alekseev") | ||||||
|  | |||||||
| @ -21,16 +21,12 @@ | |||||||
| #include "awdebug.h" | #include "awdebug.h" | ||||||
|  |  | ||||||
|  |  | ||||||
| Q_LOGGING_CATEGORY(LOG_AW, "org.kde.plasma.awesomewidget", | Q_LOGGING_CATEGORY(LOG_AW, "org.kde.plasma.awesomewidget", QtMsgType::QtWarningMsg) | ||||||
|                    QtMsgType::QtWarningMsg) |  | ||||||
| Q_LOGGING_CATEGORY(LOG_DBUS, "org.kde.plasma.awdbus", QtMsgType::QtWarningMsg) | Q_LOGGING_CATEGORY(LOG_DBUS, "org.kde.plasma.awdbus", QtMsgType::QtWarningMsg) | ||||||
| Q_LOGGING_CATEGORY(LOG_DP, "org.kde.plasma.desktoppanel", | Q_LOGGING_CATEGORY(LOG_DP, "org.kde.plasma.desktoppanel", QtMsgType::QtWarningMsg) | ||||||
|                    QtMsgType::QtWarningMsg) |  | ||||||
| Q_LOGGING_CATEGORY(LOG_ESM, "org.kde.plasma.extsysmon", QtMsgType::QtWarningMsg) | Q_LOGGING_CATEGORY(LOG_ESM, "org.kde.plasma.extsysmon", QtMsgType::QtWarningMsg) | ||||||
| Q_LOGGING_CATEGORY(LOG_ESS, "org.kde.plasma.extsysmonsources", | Q_LOGGING_CATEGORY(LOG_ESS, "org.kde.plasma.extsysmonsources", QtMsgType::QtWarningMsg) | ||||||
|                    QtMsgType::QtWarningMsg) | Q_LOGGING_CATEGORY(LOG_LIB, "org.kde.plasma.awesomewidgets", QtMsgType::QtWarningMsg) | ||||||
| Q_LOGGING_CATEGORY(LOG_LIB, "org.kde.plasma.awesomewidgets", |  | ||||||
|                    QtMsgType::QtWarningMsg) |  | ||||||
|  |  | ||||||
|  |  | ||||||
| QString AWDebug::getAboutText(const QString &_type) | QString AWDebug::getAboutText(const QString &_type) | ||||||
| @ -46,15 +42,9 @@ QString AWDebug::getAboutText(const QString &_type) | |||||||
|         text = i18n("A set of minimalistic plasmoid widgets"); |         text = i18n("A set of minimalistic plasmoid widgets"); | ||||||
|     } else if (_type == "links") { |     } else if (_type == "links") { | ||||||
|         text = i18n("Links:") + "<ul>" |         text = i18n("Links:") + "<ul>" | ||||||
|                + QString("<li><a href=\"%1\">%2</a></li>") |                + QString("<li><a href=\"%1\">%2</a></li>").arg(HOMEPAGE).arg(i18n("Homepage")) | ||||||
|                      .arg(HOMEPAGE) |                + QString("<li><a href=\"%1\">%2</a></li>").arg(REPOSITORY).arg(i18n("Repository")) | ||||||
|                      .arg(i18n("Homepage")) |                + QString("<li><a href=\"%1\">%2</a></li>").arg(BUGTRACKER).arg(i18n("Bugtracker")) | ||||||
|                + QString("<li><a href=\"%1\">%2</a></li>") |  | ||||||
|                      .arg(REPOSITORY) |  | ||||||
|                      .arg(i18n("Repository")) |  | ||||||
|                + QString("<li><a href=\"%1\">%2</a></li>") |  | ||||||
|                      .arg(BUGTRACKER) |  | ||||||
|                      .arg(i18n("Bugtracker")) |  | ||||||
|                + QString("<li><a href=\"%1\">%2</a></li>") |                + QString("<li><a href=\"%1\">%2</a></li>") | ||||||
|                      .arg(TRANSLATION) |                      .arg(TRANSLATION) | ||||||
|                      .arg(i18n("Translation issue")) |                      .arg(i18n("Translation issue")) | ||||||
| @ -70,28 +60,22 @@ QString AWDebug::getAboutText(const QString &_type) | |||||||
|                    .arg(DATE) |                    .arg(DATE) | ||||||
|                    .arg(EMAIL) |                    .arg(EMAIL) | ||||||
|                    .arg(AUTHOR) |                    .arg(AUTHOR) | ||||||
|                + i18n("This software is licensed under %1", LICENSE) |                + i18n("This software is licensed under %1", LICENSE) + "</small>"; | ||||||
|                + "</small>"; |  | ||||||
|     } else if (_type == "translators") { |     } else if (_type == "translators") { | ||||||
|         QStringList translatorList = QString(TRANSLATORS).split(','); |         QStringList translatorList = QString(TRANSLATORS).split(','); | ||||||
|         for (auto &translator : translatorList) |         for (auto &translator : translatorList) | ||||||
|             translator = QString("<li>%1</li>").arg(translator); |             translator = QString("<li>%1</li>").arg(translator); | ||||||
|         text |         text = i18n("Translators:") + "<ul>" + translatorList.join("") + "</ul>"; | ||||||
|             = i18n("Translators:") + "<ul>" + translatorList.join("") + "</ul>"; |  | ||||||
|     } else if (_type == "3rdparty") { |     } else if (_type == "3rdparty") { | ||||||
|         QStringList trdPartyList |         QStringList trdPartyList = QString(TRDPARTY_LICENSE).split(';', QString::SkipEmptyParts); | ||||||
|             = QString(TRDPARTY_LICENSE).split(';', QString::SkipEmptyParts); |  | ||||||
|         for (int i = 0; i < trdPartyList.count(); i++) |         for (int i = 0; i < trdPartyList.count(); i++) | ||||||
|             trdPartyList[i] |             trdPartyList[i] = QString("<li><a href=\"%3\">%1</a> (%2 license)</li>") | ||||||
|                 = QString("<li><a href=\"%3\">%1</a> (%2 license)</li>") |  | ||||||
|                                   .arg(trdPartyList.at(i).split(',')[0]) |                                   .arg(trdPartyList.at(i).split(',')[0]) | ||||||
|                                   .arg(trdPartyList.at(i).split(',')[1]) |                                   .arg(trdPartyList.at(i).split(',')[1]) | ||||||
|                                   .arg(trdPartyList.at(i).split(',')[2]); |                                   .arg(trdPartyList.at(i).split(',')[2]); | ||||||
|         text = i18n("This software uses:") + "<ul>" + trdPartyList.join("") |         text = i18n("This software uses:") + "<ul>" + trdPartyList.join("") + "</ul>"; | ||||||
|                + "</ul>"; |  | ||||||
|     } else if (_type == "thanks") { |     } else if (_type == "thanks") { | ||||||
|         QStringList thanks |         QStringList thanks = QString(SPECIAL_THANKS).split(';', QString::SkipEmptyParts); | ||||||
|             = QString(SPECIAL_THANKS).split(';', QString::SkipEmptyParts); |  | ||||||
|         for (int i = 0; i < thanks.count(); i++) |         for (int i = 0; i < thanks.count(); i++) | ||||||
|             thanks[i] = QString("<li><a href=\"%2\">%1</a></li>") |             thanks[i] = QString("<li><a href=\"%2\">%1</a></li>") | ||||||
|                             .arg(thanks.at(i).split(',')[0]) |                             .arg(thanks.at(i).split(',')[0]) | ||||||
| @ -117,10 +101,8 @@ QStringList AWDebug::getBuildData() | |||||||
|     metadata.append(QString("    AW_GRAPHITEM_API: %1").arg(AW_GRAPHITEM_API)); |     metadata.append(QString("    AW_GRAPHITEM_API: %1").arg(AW_GRAPHITEM_API)); | ||||||
|     metadata.append(QString("    AW_EXTQUOTES_API: %1").arg(AW_EXTQUOTES_API)); |     metadata.append(QString("    AW_EXTQUOTES_API: %1").arg(AW_EXTQUOTES_API)); | ||||||
|     metadata.append(QString("    AW_EXTSCRIPT_API: %1").arg(AW_EXTSCRIPT_API)); |     metadata.append(QString("    AW_EXTSCRIPT_API: %1").arg(AW_EXTSCRIPT_API)); | ||||||
|     metadata.append( |     metadata.append(QString("    AW_EXTUPGRADE_API: %1").arg(AW_EXTUPGRADE_API)); | ||||||
|         QString("    AW_EXTUPGRADE_API: %1").arg(AW_EXTUPGRADE_API)); |     metadata.append(QString("    AW_EXTWEATHER_API: %1").arg(AW_EXTWEATHER_API)); | ||||||
|     metadata.append( |  | ||||||
|         QString("    AW_EXTWEATHER_API: %1").arg(AW_EXTWEATHER_API)); |  | ||||||
|     metadata.append(QString("    AW_FORMATTER_API: %1").arg(AW_FORMATTER_API)); |     metadata.append(QString("    AW_FORMATTER_API: %1").arg(AW_FORMATTER_API)); | ||||||
|     metadata.append(QString("    REQUEST_TIMEOUT: %1").arg(REQUEST_TIMEOUT)); |     metadata.append(QString("    REQUEST_TIMEOUT: %1").arg(REQUEST_TIMEOUT)); | ||||||
|     metadata.append(QString("    TIME_KEYS: %1").arg(TIME_KEYS)); |     metadata.append(QString("    TIME_KEYS: %1").arg(TIME_KEYS)); | ||||||
| @ -128,41 +110,28 @@ QStringList AWDebug::getBuildData() | |||||||
|     // cmake properties |     // cmake properties | ||||||
|     metadata.append("cmake properties:"); |     metadata.append("cmake properties:"); | ||||||
|     metadata.append(QString("    CMAKE_BUILD_TYPE: %1").arg(CMAKE_BUILD_TYPE)); |     metadata.append(QString("    CMAKE_BUILD_TYPE: %1").arg(CMAKE_BUILD_TYPE)); | ||||||
|     metadata.append( |     metadata.append(QString("    CMAKE_CXX_COMPILER: %1").arg(CMAKE_CXX_COMPILER)); | ||||||
|         QString("    CMAKE_CXX_COMPILER: %1").arg(CMAKE_CXX_COMPILER)); |  | ||||||
|     metadata.append(QString("    CMAKE_CXX_FLAGS: %1").arg(CMAKE_CXX_FLAGS)); |     metadata.append(QString("    CMAKE_CXX_FLAGS: %1").arg(CMAKE_CXX_FLAGS)); | ||||||
|  |     metadata.append(QString("    CMAKE_CXX_FLAGS_DEBUG: %1").arg(CMAKE_CXX_FLAGS_DEBUG)); | ||||||
|  |     metadata.append(QString("    CMAKE_CXX_FLAGS_RELEASE: %1").arg(CMAKE_CXX_FLAGS_RELEASE)); | ||||||
|     metadata.append( |     metadata.append( | ||||||
|         QString("    CMAKE_CXX_FLAGS_DEBUG: %1").arg(CMAKE_CXX_FLAGS_DEBUG)); |         QString("    CMAKE_CXX_FLAGS_OPTIMIZATION: %1").arg(CMAKE_CXX_FLAGS_OPTIMIZATION)); | ||||||
|     metadata.append(QString("    CMAKE_CXX_FLAGS_RELEASE: %1") |     metadata.append(QString("    CMAKE_DEFINITIONS: %1").arg(CMAKE_DEFINITIONS)); | ||||||
|                         .arg(CMAKE_CXX_FLAGS_RELEASE)); |     metadata.append(QString("    CMAKE_INSTALL_PREFIX: %1").arg(CMAKE_INSTALL_PREFIX)); | ||||||
|     metadata.append(QString("    CMAKE_CXX_FLAGS_OPTIMIZATION: %1") |     metadata.append(QString("    CMAKE_MODULE_LINKER_FLAGS: %1").arg(CMAKE_MODULE_LINKER_FLAGS)); | ||||||
|                         .arg(CMAKE_CXX_FLAGS_OPTIMIZATION)); |     metadata.append(QString("    CMAKE_SHARED_LINKER_FLAGS: %1").arg(CMAKE_SHARED_LINKER_FLAGS)); | ||||||
|     metadata.append( |  | ||||||
|         QString("    CMAKE_DEFINITIONS: %1").arg(CMAKE_DEFINITIONS)); |  | ||||||
|     metadata.append( |  | ||||||
|         QString("    CMAKE_INSTALL_PREFIX: %1").arg(CMAKE_INSTALL_PREFIX)); |  | ||||||
|     metadata.append(QString("    CMAKE_MODULE_LINKER_FLAGS: %1") |  | ||||||
|                         .arg(CMAKE_MODULE_LINKER_FLAGS)); |  | ||||||
|     metadata.append(QString("    CMAKE_SHARED_LINKER_FLAGS: %1") |  | ||||||
|                         .arg(CMAKE_SHARED_LINKER_FLAGS)); |  | ||||||
|     // components |     // components | ||||||
|     metadata.append("Components data:"); |     metadata.append("Components data:"); | ||||||
|     metadata.append(QString("    BUILD_PLASMOIDS: %1").arg(BUILD_PLASMOIDS)); |     metadata.append(QString("    BUILD_PLASMOIDS: %1").arg(BUILD_PLASMOIDS)); | ||||||
|     metadata.append( |     metadata.append(QString("    BUILD_DEB_PACKAGE: %1").arg(BUILD_DEB_PACKAGE)); | ||||||
|         QString("    BUILD_DEB_PACKAGE: %1").arg(BUILD_DEB_PACKAGE)); |     metadata.append(QString("    BUILD_RPM_PACKAGE: %1").arg(BUILD_RPM_PACKAGE)); | ||||||
|     metadata.append( |     metadata.append(QString("    CLANGFORMAT_EXECUTABLE: %1").arg(CLANGFORMAT_EXECUTABLE)); | ||||||
|         QString("    BUILD_RPM_PACKAGE: %1").arg(BUILD_RPM_PACKAGE)); |  | ||||||
|     metadata.append( |  | ||||||
|         QString("    CLANGFORMAT_EXECUTABLE: %1").arg(CLANGFORMAT_EXECUTABLE)); |  | ||||||
|     metadata.append(QString("    COVERITY_COMMENT: %1").arg(COVERITY_COMMENT)); |     metadata.append(QString("    COVERITY_COMMENT: %1").arg(COVERITY_COMMENT)); | ||||||
|     metadata.append( |     metadata.append(QString("    COVERITY_DIRECTORY: %1").arg(COVERITY_DIRECTORY)); | ||||||
|         QString("    COVERITY_DIRECTORY: %1").arg(COVERITY_DIRECTORY)); |  | ||||||
|     metadata.append(QString("    COVERITY_EMAIL: %1").arg(COVERITY_EMAIL)); |     metadata.append(QString("    COVERITY_EMAIL: %1").arg(COVERITY_EMAIL)); | ||||||
|     metadata.append( |     metadata.append(QString("    COVERITY_EXECUTABLE: %1").arg(COVERITY_EXECUTABLE)); | ||||||
|         QString("    COVERITY_EXECUTABLE: %1").arg(COVERITY_EXECUTABLE)); |  | ||||||
|     metadata.append(QString("    COVERITY_URL: %1").arg(COVERITY_URL)); |     metadata.append(QString("    COVERITY_URL: %1").arg(COVERITY_URL)); | ||||||
|     metadata.append( |     metadata.append(QString("    CPPCHECK_EXECUTABLE: %1").arg(CPPCHECK_EXECUTABLE)); | ||||||
|         QString("    CPPCHECK_EXECUTABLE: %1").arg(CPPCHECK_EXECUTABLE)); |  | ||||||
|     // additional functions |     // additional functions | ||||||
|     metadata.append(QString("    PROP_FUTURE: %1").arg(PROP_FUTURE)); |     metadata.append(QString("    PROP_FUTURE: %1").arg(PROP_FUTURE)); | ||||||
|     metadata.append(QString("    PROP_LOAD: %1").arg(PROP_LOAD)); |     metadata.append(QString("    PROP_LOAD: %1").arg(PROP_LOAD)); | ||||||
|  | |||||||
| @ -26,8 +26,7 @@ | |||||||
| #include "awdebug.h" | #include "awdebug.h" | ||||||
|  |  | ||||||
|  |  | ||||||
| AWAbstractPairConfig::AWAbstractPairConfig(QWidget *_parent, | AWAbstractPairConfig::AWAbstractPairConfig(QWidget *_parent, const bool _hasEdit, | ||||||
|                                            const bool _hasEdit, |  | ||||||
|                                            const QStringList &_keys) |                                            const QStringList &_keys) | ||||||
|     : QDialog(_parent) |     : QDialog(_parent) | ||||||
|     , ui(new Ui::AWAbstractPairConfig) |     , ui(new Ui::AWAbstractPairConfig) | ||||||
| @ -43,8 +42,7 @@ AWAbstractPairConfig::AWAbstractPairConfig(QWidget *_parent, | |||||||
|  |  | ||||||
|     // edit feature |     // edit feature | ||||||
|     if (m_hasEdit) { |     if (m_hasEdit) { | ||||||
|         m_editButton = ui->buttonBox->addButton(i18n("Edit"), |         m_editButton = ui->buttonBox->addButton(i18n("Edit"), QDialogButtonBox::ActionRole); | ||||||
|                                                 QDialogButtonBox::ActionRole); |  | ||||||
|         connect(m_editButton, SIGNAL(clicked(bool)), this, SLOT(edit())); |         connect(m_editButton, SIGNAL(clicked(bool)), this, SLOT(edit())); | ||||||
|     } |     } | ||||||
| } | } | ||||||
| @ -86,10 +84,8 @@ void AWAbstractPairConfig::edit() | |||||||
|  |  | ||||||
| void AWAbstractPairConfig::updateUi() | void AWAbstractPairConfig::updateUi() | ||||||
| { | { | ||||||
|     QPair<QString, QString> current |     QPair<QString, QString> current = static_cast<AWAbstractSelector *>(sender())->current(); | ||||||
|         = static_cast<AWAbstractSelector *>(sender())->current(); |     int index = m_selectors.indexOf(static_cast<AWAbstractSelector *>(sender())); | ||||||
|     int index |  | ||||||
|         = m_selectors.indexOf(static_cast<AWAbstractSelector *>(sender())); |  | ||||||
|  |  | ||||||
|     if ((current.first.isEmpty()) && (current.second.isEmpty())) { |     if ((current.first.isEmpty()) && (current.second.isEmpty())) { | ||||||
|         // remove current selector if it is empty and does not last |         // remove current selector if it is empty and does not last | ||||||
| @ -108,15 +104,13 @@ void AWAbstractPairConfig::updateUi() | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| void AWAbstractPairConfig::addSelector(const QStringList &_keys, | void AWAbstractPairConfig::addSelector(const QStringList &_keys, const QStringList &_values, | ||||||
|                                        const QStringList &_values, |  | ||||||
|                                        const QPair<QString, QString> &_current) |                                        const QPair<QString, QString> &_current) | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Add selector with keys" << _keys << "values" << _values |     qCDebug(LOG_AW) << "Add selector with keys" << _keys << "values" << _values | ||||||
|                     << "and current ones" << _current; |                     << "and current ones" << _current; | ||||||
|  |  | ||||||
|     AWAbstractSelector *selector |     AWAbstractSelector *selector = new AWAbstractSelector(ui->scrollAreaWidgetContents, m_editable); | ||||||
|         = new AWAbstractSelector(ui->scrollAreaWidgetContents, m_editable); |  | ||||||
|     selector->init(_keys, _values, _current); |     selector->init(_keys, _values, _current); | ||||||
|     ui->verticalLayout->insertWidget(ui->verticalLayout->count() - 1, selector); |     ui->verticalLayout->insertWidget(ui->verticalLayout->count() - 1, selector); | ||||||
|     connect(selector, SIGNAL(selectionChanged()), this, SLOT(updateUi())); |     connect(selector, SIGNAL(selectionChanged()), this, SLOT(updateUi())); | ||||||
| @ -127,8 +121,7 @@ void AWAbstractPairConfig::addSelector(const QStringList &_keys, | |||||||
| void AWAbstractPairConfig::clearSelectors() | void AWAbstractPairConfig::clearSelectors() | ||||||
| { | { | ||||||
|     for (auto &selector : m_selectors) { |     for (auto &selector : m_selectors) { | ||||||
|         disconnect(selector, SIGNAL(selectionChanged()), this, |         disconnect(selector, SIGNAL(selectionChanged()), this, SLOT(updateUi())); | ||||||
|                    SLOT(updateUi())); |  | ||||||
|         ui->verticalLayout->removeWidget(selector); |         ui->verticalLayout->removeWidget(selector); | ||||||
|         selector->deleteLater(); |         selector->deleteLater(); | ||||||
|     } |     } | ||||||
| @ -167,8 +160,7 @@ QPair<QStringList, QStringList> AWAbstractPairConfig::initKeys() const | |||||||
|     left.append(m_helper->leftKeys().isEmpty() ? m_keys : m_helper->leftKeys()); |     left.append(m_helper->leftKeys().isEmpty() ? m_keys : m_helper->leftKeys()); | ||||||
|     left.sort(); |     left.sort(); | ||||||
|     QStringList right = {""}; |     QStringList right = {""}; | ||||||
|     right.append(m_helper->rightKeys().isEmpty() ? m_keys |     right.append(m_helper->rightKeys().isEmpty() ? m_keys : m_helper->rightKeys()); | ||||||
|                                                  : m_helper->rightKeys()); |  | ||||||
|     right.sort(); |     right.sort(); | ||||||
|  |  | ||||||
|     return QPair<QStringList, QStringList>(left, right); |     return QPair<QStringList, QStringList>(left, right); | ||||||
| @ -182,8 +174,7 @@ void AWAbstractPairConfig::updateDialog() | |||||||
|     auto keys = initKeys(); |     auto keys = initKeys(); | ||||||
|  |  | ||||||
|     for (auto &key : m_helper->keys()) |     for (auto &key : m_helper->keys()) | ||||||
|         addSelector(keys.first, keys.second, |         addSelector(keys.first, keys.second, QPair<QString, QString>(key, m_helper->pairs()[key])); | ||||||
|                     QPair<QString, QString>(key, m_helper->pairs()[key])); |  | ||||||
|     // empty one |     // empty one | ||||||
|     addSelector(keys.first, keys.second, QPair<QString, QString>()); |     addSelector(keys.first, keys.second, QPair<QString, QString>()); | ||||||
| } | } | ||||||
|  | |||||||
| @ -35,8 +35,7 @@ class AWAbstractPairConfig : public QDialog | |||||||
|     Q_OBJECT |     Q_OBJECT | ||||||
|  |  | ||||||
| public: | public: | ||||||
|     explicit AWAbstractPairConfig(QWidget *_parent = nullptr, |     explicit AWAbstractPairConfig(QWidget *_parent = nullptr, const bool _hasEdit = false, | ||||||
|                                   const bool _hasEdit = false, |  | ||||||
|                                   const QStringList &_keys = QStringList()); |                                   const QStringList &_keys = QStringList()); | ||||||
|     virtual ~AWAbstractPairConfig(); |     virtual ~AWAbstractPairConfig(); | ||||||
|     template <class T> void initHelper() |     template <class T> void initHelper() | ||||||
|  | |||||||
| @ -23,8 +23,7 @@ | |||||||
| #include "awdebug.h" | #include "awdebug.h" | ||||||
|  |  | ||||||
|  |  | ||||||
| AWAbstractPairHelper::AWAbstractPairHelper(const QString &_filePath, | AWAbstractPairHelper::AWAbstractPairHelper(const QString &_filePath, const QString &_section) | ||||||
|                                            const QString &_section) |  | ||||||
|     : m_filePath(_filePath) |     : m_filePath(_filePath) | ||||||
|     , m_section(_section) |     , m_section(_section) | ||||||
| { | { | ||||||
| @ -62,8 +61,8 @@ void AWAbstractPairHelper::initItems() | |||||||
| { | { | ||||||
|     m_pairs.clear(); |     m_pairs.clear(); | ||||||
|  |  | ||||||
|     QStringList configs = QStandardPaths::locateAll( |     QStringList configs | ||||||
|         QStandardPaths::GenericDataLocation, m_filePath); |         = QStandardPaths::locateAll(QStandardPaths::GenericDataLocation, m_filePath); | ||||||
|  |  | ||||||
|     for (auto &fileName : configs) { |     for (auto &fileName : configs) { | ||||||
|         QSettings settings(fileName, QSettings::IniFormat); |         QSettings settings(fileName, QSettings::IniFormat); | ||||||
| @ -86,14 +85,13 @@ void AWAbstractPairHelper::initItems() | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| bool AWAbstractPairHelper::writeItems( | bool AWAbstractPairHelper::writeItems(const QHash<QString, QString> &_configuration) const | ||||||
|     const QHash<QString, QString> &_configuration) const |  | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Write configuration" << _configuration; |     qCDebug(LOG_AW) << "Write configuration" << _configuration; | ||||||
|  |  | ||||||
|     QString fileName = QString("%1/%2") |     QString fileName | ||||||
|                            .arg(QStandardPaths::writableLocation( |         = QString("%1/%2") | ||||||
|                                QStandardPaths::GenericDataLocation)) |               .arg(QStandardPaths::writableLocation(QStandardPaths::GenericDataLocation)) | ||||||
|               .arg(m_filePath); |               .arg(m_filePath); | ||||||
|     QSettings settings(fileName, QSettings::IniFormat); |     QSettings settings(fileName, QSettings::IniFormat); | ||||||
|     qCInfo(LOG_AW) << "Configuration file" << fileName; |     qCInfo(LOG_AW) << "Configuration file" << fileName; | ||||||
| @ -113,9 +111,9 @@ bool AWAbstractPairHelper::removeUnusedKeys(const QStringList &_keys) const | |||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Remove keys" << _keys; |     qCDebug(LOG_AW) << "Remove keys" << _keys; | ||||||
|  |  | ||||||
|     QString fileName = QString("%1/%2") |     QString fileName | ||||||
|                            .arg(QStandardPaths::writableLocation( |         = QString("%1/%2") | ||||||
|                                QStandardPaths::GenericDataLocation)) |               .arg(QStandardPaths::writableLocation(QStandardPaths::GenericDataLocation)) | ||||||
|               .arg(m_filePath); |               .arg(m_filePath); | ||||||
|     QSettings settings(fileName, QSettings::IniFormat); |     QSettings settings(fileName, QSettings::IniFormat); | ||||||
|     qCInfo(LOG_AW) << "Configuration file" << fileName; |     qCInfo(LOG_AW) << "Configuration file" << fileName; | ||||||
|  | |||||||
| @ -25,16 +25,14 @@ | |||||||
| class AWAbstractPairHelper | class AWAbstractPairHelper | ||||||
| { | { | ||||||
| public: | public: | ||||||
|     explicit AWAbstractPairHelper(const QString &_filePath = "", |     explicit AWAbstractPairHelper(const QString &_filePath = "", const QString &_section = ""); | ||||||
|                                   const QString &_section = ""); |  | ||||||
|     virtual ~AWAbstractPairHelper(); |     virtual ~AWAbstractPairHelper(); | ||||||
|     QStringList keys() const; |     QStringList keys() const; | ||||||
|     QHash<QString, QString> pairs() const; |     QHash<QString, QString> pairs() const; | ||||||
|     QStringList values() const; |     QStringList values() const; | ||||||
|     // read-write methods |     // read-write methods | ||||||
|     virtual void initItems(); |     virtual void initItems(); | ||||||
|     virtual bool |     virtual bool writeItems(const QHash<QString, QString> &_configuration) const; | ||||||
|     writeItems(const QHash<QString, QString> &_configuration) const; |  | ||||||
|     virtual bool removeUnusedKeys(const QStringList &_keys) const; |     virtual bool removeUnusedKeys(const QStringList &_keys) const; | ||||||
|     // configuration related |     // configuration related | ||||||
|     virtual void editPairs() = 0; |     virtual void editPairs() = 0; | ||||||
|  | |||||||
| @ -21,8 +21,7 @@ | |||||||
| #include "awdebug.h" | #include "awdebug.h" | ||||||
|  |  | ||||||
|  |  | ||||||
| AWAbstractSelector::AWAbstractSelector(QWidget *_parent, | AWAbstractSelector::AWAbstractSelector(QWidget *_parent, const QPair<bool, bool> &_editable) | ||||||
|                                        const QPair<bool, bool> &_editable) |  | ||||||
|     : QWidget(_parent) |     : QWidget(_parent) | ||||||
|     , ui(new Ui::AWAbstractSelector) |     , ui(new Ui::AWAbstractSelector) | ||||||
| { | { | ||||||
| @ -32,10 +31,8 @@ AWAbstractSelector::AWAbstractSelector(QWidget *_parent, | |||||||
|     ui->comboBox_key->setEditable(_editable.first); |     ui->comboBox_key->setEditable(_editable.first); | ||||||
|     ui->comboBox_value->setEditable(_editable.second); |     ui->comboBox_value->setEditable(_editable.second); | ||||||
|  |  | ||||||
|     connect(ui->comboBox_key, SIGNAL(currentIndexChanged(int)), this, |     connect(ui->comboBox_key, SIGNAL(currentIndexChanged(int)), this, SIGNAL(selectionChanged())); | ||||||
|             SIGNAL(selectionChanged())); |     connect(ui->comboBox_value, SIGNAL(currentIndexChanged(int)), this, SIGNAL(selectionChanged())); | ||||||
|     connect(ui->comboBox_value, SIGNAL(currentIndexChanged(int)), this, |  | ||||||
|             SIGNAL(selectionChanged())); |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -56,18 +53,15 @@ QPair<QString, QString> AWAbstractSelector::current() const | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| void AWAbstractSelector::init(const QStringList &_keys, | void AWAbstractSelector::init(const QStringList &_keys, const QStringList &_values, | ||||||
|                               const QStringList &_values, |  | ||||||
|                               const QPair<QString, QString> &_current) |                               const QPair<QString, QString> &_current) | ||||||
| { | { | ||||||
|     if ((!_keys.contains(_current.first)) |     if ((!_keys.contains(_current.first)) || (!_values.contains(_current.second))) { | ||||||
|         || (!_values.contains(_current.second))) { |         qCWarning(LOG_AW) << "Invalid current value" << _current << "not found in default ones"; | ||||||
|         qCWarning(LOG_AW) << "Invalid current value" << _current |  | ||||||
|                           << "not found in default ones"; |  | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|     qCDebug(LOG_AW) << "Init selector with keys" << _keys << "and values" |     qCDebug(LOG_AW) << "Init selector with keys" << _keys << "and values" << _values | ||||||
|                     << _values << "and current ones are" << _current; |                     << "and current ones are" << _current; | ||||||
|  |  | ||||||
|     // set data |     // set data | ||||||
|     ui->comboBox_key->clear(); |     ui->comboBox_key->clear(); | ||||||
|  | |||||||
| @ -33,8 +33,7 @@ class AWAbstractSelector : public QWidget | |||||||
|  |  | ||||||
| public: | public: | ||||||
|     explicit AWAbstractSelector(QWidget *_parent = nullptr, |     explicit AWAbstractSelector(QWidget *_parent = nullptr, | ||||||
|                                 const QPair<bool, bool> &_editable |                                 const QPair<bool, bool> &_editable = {false, false}); | ||||||
|                                 = {false, false}); |  | ||||||
|     virtual ~AWAbstractSelector(); |     virtual ~AWAbstractSelector(); | ||||||
|     QPair<QString, QString> current() const; |     QPair<QString, QString> current() const; | ||||||
|     void init(const QStringList &_keys, const QStringList &_values, |     void init(const QStringList &_keys, const QStringList &_values, | ||||||
|  | |||||||
| @ -61,8 +61,7 @@ QString AWActions::getFileContent(const QString &_path) const | |||||||
|  |  | ||||||
|     QFile inputFile(_path); |     QFile inputFile(_path); | ||||||
|     if (!inputFile.open(QIODevice::ReadOnly | QIODevice::Text)) { |     if (!inputFile.open(QIODevice::ReadOnly | QIODevice::Text)) { | ||||||
|         qCWarning(LOG_AW) << "Could not open file as text" |         qCWarning(LOG_AW) << "Could not open file as text" << inputFile.fileName(); | ||||||
|                           << inputFile.fileName(); |  | ||||||
|         return ""; |         return ""; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @ -102,8 +101,7 @@ void AWActions::showLegacyInfo() const | |||||||
|     msgBox->setAttribute(Qt::WA_DeleteOnClose); |     msgBox->setAttribute(Qt::WA_DeleteOnClose); | ||||||
|     msgBox->setModal(false); |     msgBox->setModal(false); | ||||||
|     msgBox->setWindowTitle(i18n("Not supported")); |     msgBox->setWindowTitle(i18n("Not supported")); | ||||||
|     msgBox->setText( |     msgBox->setText(i18n("You are using mammoth's Qt version, try to update it first")); | ||||||
|         i18n("You are using mammoth's Qt version, try to update it first")); |  | ||||||
|     msgBox->setStandardButtons(QMessageBox::Ok); |     msgBox->setStandardButtons(QMessageBox::Ok); | ||||||
|     msgBox->setIcon(QMessageBox::Information); |     msgBox->setIcon(QMessageBox::Information); | ||||||
|  |  | ||||||
| @ -126,11 +124,9 @@ QVariantMap AWActions::getFont(const QVariantMap &_defaultFont) const | |||||||
|  |  | ||||||
|     QVariantMap fontMap; |     QVariantMap fontMap; | ||||||
|     int ret = 0; |     int ret = 0; | ||||||
|     CFont defaultCFont |     CFont defaultCFont = CFont(_defaultFont["family"].toString(), _defaultFont["size"].toInt(), 400, | ||||||
|         = CFont(_defaultFont["family"].toString(), _defaultFont["size"].toInt(), |                                false, _defaultFont["color"].toString()); | ||||||
|                 400, false, _defaultFont["color"].toString()); |     CFont font = CFontDialog::getFont(i18n("Select font"), defaultCFont, false, false, &ret); | ||||||
|     CFont font = CFontDialog::getFont(i18n("Select font"), defaultCFont, false, |  | ||||||
|                                       false, &ret); |  | ||||||
|  |  | ||||||
|     fontMap["applied"] = ret; |     fontMap["applied"] = ret; | ||||||
|     fontMap["color"] = font.color().name(); |     fontMap["color"] = font.color().name(); | ||||||
| @ -142,13 +138,11 @@ QVariantMap AWActions::getFont(const QVariantMap &_defaultFont) const | |||||||
|  |  | ||||||
|  |  | ||||||
| // to avoid additional object definition this method is static | // to avoid additional object definition this method is static | ||||||
| void AWActions::sendNotification(const QString &_eventId, | void AWActions::sendNotification(const QString &_eventId, const QString &_message) | ||||||
|                                  const QString &_message) |  | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Event" << _eventId << "with message" << _message; |     qCDebug(LOG_AW) << "Event" << _eventId << "with message" << _message; | ||||||
|  |  | ||||||
|     KNotification *notification = KNotification::event( |     KNotification *notification | ||||||
|         _eventId, QString("Awesome Widget ::: %1").arg(_eventId), _message); |         = KNotification::event(_eventId, QString("Awesome Widget ::: %1").arg(_eventId), _message); | ||||||
|     notification->setComponentName( |     notification->setComponentName("plasma-applet-org.kde.plasma.awesome-widget"); | ||||||
|         "plasma-applet-org.kde.plasma.awesome-widget"); |  | ||||||
| } | } | ||||||
|  | |||||||
| @ -43,8 +43,7 @@ public: | |||||||
|     Q_INVOKABLE QVariantMap getFont(const QVariantMap &_defaultFont) const; |     Q_INVOKABLE QVariantMap getFont(const QVariantMap &_defaultFont) const; | ||||||
|  |  | ||||||
| public slots: | public slots: | ||||||
|     Q_INVOKABLE static void sendNotification(const QString &_eventId, |     Q_INVOKABLE static void sendNotification(const QString &_eventId, const QString &_message); | ||||||
|                                              const QString &_message); |  | ||||||
|  |  | ||||||
| private: | private: | ||||||
|     AWUpdateHelper *m_updateHelper = nullptr; |     AWUpdateHelper *m_updateHelper = nullptr; | ||||||
|  | |||||||
| @ -49,22 +49,18 @@ void AWBugReporter::doConnect() | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| QString AWBugReporter::generateText(const QString &_description, | QString AWBugReporter::generateText(const QString &_description, const QString &_reproduce, | ||||||
|                                     const QString &_reproduce, |                                     const QString &_expected, const QString &_logs) const | ||||||
|                                     const QString &_expected, |  | ||||||
|                                     const QString &_logs) const |  | ||||||
| { | { | ||||||
|     // do not log _logs here, it may have quite large size |     // do not log _logs here, it may have quite large size | ||||||
|     qCDebug(LOG_AW) << "Generate text with description" << _description |     qCDebug(LOG_AW) << "Generate text with description" << _description << "steps" << _reproduce | ||||||
|                     << "steps" << _reproduce << "and expected result" |                     << "and expected result" << _expected; | ||||||
|                     << _expected; |  | ||||||
|  |  | ||||||
|     QString output; |     QString output; | ||||||
|     output += QString("**Description**\n\n%1\n\n").arg(_description); |     output += QString("**Description**\n\n%1\n\n").arg(_description); | ||||||
|     output += QString("**Step to _reproduce**\n\n%1\n\n").arg(_reproduce); |     output += QString("**Step to _reproduce**\n\n%1\n\n").arg(_reproduce); | ||||||
|     output += QString("**Expected result**\n\n%1\n\n").arg(_expected); |     output += QString("**Expected result**\n\n%1\n\n").arg(_expected); | ||||||
|     output += QString("**Version**\n\n%1\n\n") |     output += QString("**Version**\n\n%1\n\n").arg(AWDebug::getBuildData().join(QString("\n"))); | ||||||
|                   .arg(AWDebug::getBuildData().join(QString("\n"))); |  | ||||||
|     // append _logs |     // append _logs | ||||||
|     output += QString("**Logs**\n\n%1").arg(_logs); |     output += QString("**Logs**\n\n%1").arg(_logs); | ||||||
|  |  | ||||||
| @ -74,8 +70,7 @@ QString AWBugReporter::generateText(const QString &_description, | |||||||
|  |  | ||||||
| void AWBugReporter::sendBugReport(const QString &_title, const QString &_body) | void AWBugReporter::sendBugReport(const QString &_title, const QString &_body) | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Send bug report with title" << _title << "and body" |     qCDebug(LOG_AW) << "Send bug report with title" << _title << "and body" << _body; | ||||||
|                     << _body; |  | ||||||
|  |  | ||||||
|     QNetworkAccessManager *manager = new QNetworkAccessManager(nullptr); |     QNetworkAccessManager *manager = new QNetworkAccessManager(nullptr); | ||||||
|     connect(manager, SIGNAL(finished(QNetworkReply *)), this, |     connect(manager, SIGNAL(finished(QNetworkReply *)), this, | ||||||
| @ -90,10 +85,8 @@ void AWBugReporter::sendBugReport(const QString &_title, const QString &_body) | |||||||
|     payload["body"] = _body; |     payload["body"] = _body; | ||||||
|     payload["labels"] = QStringList() << "from application"; |     payload["labels"] = QStringList() << "from application"; | ||||||
|     // convert to QByteArray to send request |     // convert to QByteArray to send request | ||||||
|     QByteArray data |     QByteArray data = QJsonDocument::fromVariant(payload).toJson(QJsonDocument::Compact); | ||||||
|         = QJsonDocument::fromVariant(payload).toJson(QJsonDocument::Compact); |     qCInfo(LOG_AW) << "Send request with _body" << data.data() << "and size" << data.size(); | ||||||
|     qCInfo(LOG_AW) << "Send request with _body" << data.data() << "and size" |  | ||||||
|                    << data.size(); |  | ||||||
|  |  | ||||||
|     manager->post(request, data); |     manager->post(request, data); | ||||||
| } | } | ||||||
| @ -102,8 +95,8 @@ void AWBugReporter::sendBugReport(const QString &_title, const QString &_body) | |||||||
| void AWBugReporter::issueReplyRecieved(QNetworkReply *_reply) | void AWBugReporter::issueReplyRecieved(QNetworkReply *_reply) | ||||||
| { | { | ||||||
|     if (_reply->error() != QNetworkReply::NoError) { |     if (_reply->error() != QNetworkReply::NoError) { | ||||||
|         qCWarning(LOG_AW) << "An error occurs" << _reply->error() |         qCWarning(LOG_AW) << "An error occurs" << _reply->error() << "with message" | ||||||
|                           << "with message" << _reply->errorString(); |                           << _reply->errorString(); | ||||||
|         return emit(replyReceived(0, "")); |         return emit(replyReceived(0, "")); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @ -126,8 +119,7 @@ void AWBugReporter::issueReplyRecieved(QNetworkReply *_reply) | |||||||
|  |  | ||||||
| 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" |     qCDebug(LOG_AW) << "Created issue with number" << _number << "and url" << _url; | ||||||
|                     << _url; |  | ||||||
|  |  | ||||||
|     // cache url first |     // cache url first | ||||||
|     m_lastBugUrl = _url; |     m_lastBugUrl = _url; | ||||||
| @ -146,8 +138,7 @@ void AWBugReporter::showInformation(const int _number, const QString &_url) | |||||||
|  |  | ||||||
| void AWBugReporter::userReplyOnBugReport(QAbstractButton *_button) | void AWBugReporter::userReplyOnBugReport(QAbstractButton *_button) | ||||||
| { | { | ||||||
|     QMessageBox::ButtonRole ret |     QMessageBox::ButtonRole ret = static_cast<QMessageBox *>(sender())->buttonRole(_button); | ||||||
|         = static_cast<QMessageBox *>(sender())->buttonRole(_button); |  | ||||||
|     qCInfo(LOG_AW) << "User select" << ret; |     qCInfo(LOG_AW) << "User select" << ret; | ||||||
|  |  | ||||||
|     switch (ret) { |     switch (ret) { | ||||||
|  | |||||||
| @ -33,10 +33,8 @@ public: | |||||||
|     explicit AWBugReporter(QObject *_parent = nullptr); |     explicit AWBugReporter(QObject *_parent = nullptr); | ||||||
|     virtual ~AWBugReporter(); |     virtual ~AWBugReporter(); | ||||||
|     Q_INVOKABLE void doConnect(); |     Q_INVOKABLE void doConnect(); | ||||||
|     Q_INVOKABLE QString generateText(const QString &_description, |     Q_INVOKABLE QString generateText(const QString &_description, const QString &_reproduce, | ||||||
|                                      const QString &_reproduce, |                                      const QString &_expected, const QString &_logs) const; | ||||||
|                                      const QString &_expected, |  | ||||||
|                                      const QString &_logs) const; |  | ||||||
|     Q_INVOKABLE void sendBugReport(const QString &_title, const QString &_body); |     Q_INVOKABLE void sendBugReport(const QString &_title, const QString &_body); | ||||||
|  |  | ||||||
| signals: | signals: | ||||||
|  | |||||||
| @ -34,8 +34,7 @@ AWConfigHelper::AWConfigHelper(QObject *_parent) | |||||||
|     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; |     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; | ||||||
|  |  | ||||||
|     m_baseDir = QString("%1/awesomewidgets") |     m_baseDir = QString("%1/awesomewidgets") | ||||||
|                     .arg(QStandardPaths::writableLocation( |                     .arg(QStandardPaths::writableLocation(QStandardPaths::GenericDataLocation)); | ||||||
|                         QStandardPaths::GenericDataLocation)); |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -48,14 +47,13 @@ AWConfigHelper::~AWConfigHelper() | |||||||
| QString AWConfigHelper::configurationDirectory() const | QString AWConfigHelper::configurationDirectory() const | ||||||
| { | { | ||||||
|     // get readable directory |     // get readable directory | ||||||
|     QString localDir = QString("%1/awesomewidgets/configs") |     QString localDir | ||||||
|                            .arg(QStandardPaths::writableLocation( |         = QString("%1/awesomewidgets/configs") | ||||||
|                                QStandardPaths::GenericDataLocation)); |               .arg(QStandardPaths::writableLocation(QStandardPaths::GenericDataLocation)); | ||||||
|  |  | ||||||
|     // create directory and copy files from default settings |     // create directory and copy files from default settings | ||||||
|     QDir localDirectory; |     QDir localDirectory; | ||||||
|     if ((!localDirectory.exists(localDir)) |     if ((!localDirectory.exists(localDir)) && (localDirectory.mkpath(localDir))) { | ||||||
|         && (localDirectory.mkpath(localDir))) { |  | ||||||
|         qCInfo(LOG_AW) << "Created directory" << localDir; |         qCInfo(LOG_AW) << "Created directory" << localDir; | ||||||
|         copyConfigs(localDir); |         copyConfigs(localDir); | ||||||
|     } |     } | ||||||
| @ -66,23 +64,21 @@ QString AWConfigHelper::configurationDirectory() const | |||||||
|  |  | ||||||
| bool AWConfigHelper::dropCache() const | bool AWConfigHelper::dropCache() const | ||||||
| { | { | ||||||
|     QString fileName = QString("%1/awesomewidgets.ndx") |     QString fileName | ||||||
|                            .arg(QStandardPaths::writableLocation( |         = QString("%1/awesomewidgets.ndx") | ||||||
|                                QStandardPaths::GenericCacheLocation)); |               .arg(QStandardPaths::writableLocation(QStandardPaths::GenericCacheLocation)); | ||||||
|  |  | ||||||
|     return QFile(fileName).remove(); |     return QFile(fileName).remove(); | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| bool AWConfigHelper::exportConfiguration(QObject *_nativeConfig, | bool AWConfigHelper::exportConfiguration(QObject *_nativeConfig, const QString &_fileName) const | ||||||
|                                          const QString &_fileName) const |  | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Selected filename" << _fileName; |     qCDebug(LOG_AW) << "Selected filename" << _fileName; | ||||||
|  |  | ||||||
|     QSettings settings(_fileName, QSettings::IniFormat); |     QSettings settings(_fileName, QSettings::IniFormat); | ||||||
|     // plasmoid configuration |     // plasmoid configuration | ||||||
|     const QQmlPropertyMap *configuration |     const QQmlPropertyMap *configuration = static_cast<const QQmlPropertyMap *>(_nativeConfig); | ||||||
|         = static_cast<const QQmlPropertyMap *>(_nativeConfig); |  | ||||||
|     settings.beginGroup("plasmoid"); |     settings.beginGroup("plasmoid"); | ||||||
|     for (auto &key : configuration->keys()) { |     for (auto &key : configuration->keys()) { | ||||||
|         QVariant value = configuration->value(key); |         QVariant value = configuration->value(key); | ||||||
| @ -94,8 +90,7 @@ bool AWConfigHelper::exportConfiguration(QObject *_nativeConfig, | |||||||
|  |  | ||||||
|     // extensions |     // extensions | ||||||
|     for (auto &item : m_dirs) { |     for (auto &item : m_dirs) { | ||||||
|         QStringList items |         QStringList items = QDir(QString("%1/%2").arg(m_baseDir).arg(item)) | ||||||
|             = QDir(QString("%1/%2").arg(m_baseDir).arg(item)) |  | ||||||
|                                 .entryList(QStringList() << "*.desktop", QDir::Files); |                                 .entryList(QStringList() << "*.desktop", QDir::Files); | ||||||
|         settings.beginGroup(item); |         settings.beginGroup(item); | ||||||
|         for (auto &it : items) |         for (auto &it : items) | ||||||
| @ -107,18 +102,15 @@ bool AWConfigHelper::exportConfiguration(QObject *_nativeConfig, | |||||||
|     settings.beginGroup("json"); |     settings.beginGroup("json"); | ||||||
|     // script filters |     // script filters | ||||||
|     readFile(settings, "filters", |     readFile(settings, "filters", | ||||||
|              QString("%1/scripts/awesomewidgets-extscripts-filters.json") |              QString("%1/scripts/awesomewidgets-extscripts-filters.json").arg(m_baseDir)); | ||||||
|                  .arg(m_baseDir)); |  | ||||||
|     // weather icon settings |     // weather icon settings | ||||||
|     readFile(settings, "weathers", |     readFile(settings, "weathers", | ||||||
|              QString("%1/weather/awesomewidgets-extweather-ids.json") |              QString("%1/weather/awesomewidgets-extweather-ids.json").arg(m_baseDir)); | ||||||
|                  .arg(m_baseDir)); |  | ||||||
|     settings.endGroup(); |     settings.endGroup(); | ||||||
|  |  | ||||||
|     settings.beginGroup("ini"); |     settings.beginGroup("ini"); | ||||||
|     // formatter settings |     // formatter settings | ||||||
|     readFile(settings, "formatters", |     readFile(settings, "formatters", QString("%1/formatters/formatters.ini").arg(m_baseDir)); | ||||||
|              QString("%1/formatters/formatters.ini").arg(m_baseDir)); |  | ||||||
|     // custom keys settings |     // custom keys settings | ||||||
|     readFile(settings, "custom", QString("%1/custom.ini").arg(m_baseDir)); |     readFile(settings, "custom", QString("%1/custom.ini").arg(m_baseDir)); | ||||||
|     settings.endGroup(); |     settings.endGroup(); | ||||||
| @ -155,18 +147,15 @@ QVariantMap AWConfigHelper::importConfiguration(const QString &_fileName, | |||||||
|         settings.beginGroup("json"); |         settings.beginGroup("json"); | ||||||
|         // script filters |         // script filters | ||||||
|         writeFile(settings, "filters", |         writeFile(settings, "filters", | ||||||
|                   QString("%1/scripts/awesomewidgets-extscripts-filters.json") |                   QString("%1/scripts/awesomewidgets-extscripts-filters.json").arg(m_baseDir)); | ||||||
|                       .arg(m_baseDir)); |  | ||||||
|         // weather icon settings |         // weather icon settings | ||||||
|         writeFile(settings, "weathers", |         writeFile(settings, "weathers", | ||||||
|                   QString("%1/weather/awesomewidgets-extweather-ids.json") |                   QString("%1/weather/awesomewidgets-extweather-ids.json").arg(m_baseDir)); | ||||||
|                       .arg(m_baseDir)); |  | ||||||
|         settings.endGroup(); |         settings.endGroup(); | ||||||
|  |  | ||||||
|         settings.beginGroup("ini"); |         settings.beginGroup("ini"); | ||||||
|         // formatter settings |         // formatter settings | ||||||
|         writeFile(settings, "formatters", |         writeFile(settings, "formatters", QString("%1/formatters/formatters.ini").arg(m_baseDir)); | ||||||
|                   QString("%1/formatters/formatters.ini").arg(m_baseDir)); |  | ||||||
|         // custom keys settings |         // custom keys settings | ||||||
|         writeFile(settings, "custom", QString("%1/custom.ini").arg(m_baseDir)); |         writeFile(settings, "custom", QString("%1/custom.ini").arg(m_baseDir)); | ||||||
|         settings.endGroup(); |         settings.endGroup(); | ||||||
| @ -186,19 +175,17 @@ QVariantMap AWConfigHelper::importConfiguration(const QString &_fileName, | |||||||
|  |  | ||||||
| QVariantMap AWConfigHelper::readDataEngineConfiguration() const | QVariantMap AWConfigHelper::readDataEngineConfiguration() const | ||||||
| { | { | ||||||
|     QString fileName = QStandardPaths::locate( |     QString fileName = QStandardPaths::locate(QStandardPaths::ConfigLocation, | ||||||
|         QStandardPaths::ConfigLocation, "plasma-dataengine-extsysmon.conf"); |                                               "plasma-dataengine-extsysmon.conf"); | ||||||
|     qCInfo(LOG_AW) << "Configuration file" << fileName; |     qCInfo(LOG_AW) << "Configuration file" << fileName; | ||||||
|     QSettings settings(fileName, QSettings::IniFormat); |     QSettings settings(fileName, QSettings::IniFormat); | ||||||
|     QVariantMap configuration; |     QVariantMap configuration; | ||||||
|  |  | ||||||
|     settings.beginGroup("Configuration"); |     settings.beginGroup("Configuration"); | ||||||
|     configuration["ACPIPATH"] |     configuration["ACPIPATH"] = settings.value("ACPIPATH", "/sys/class/power_supply/"); | ||||||
|         = settings.value("ACPIPATH", "/sys/class/power_supply/"); |  | ||||||
|     configuration["GPUDEV"] = settings.value("GPUDEV", "auto"); |     configuration["GPUDEV"] = settings.value("GPUDEV", "auto"); | ||||||
|     configuration["HDDDEV"] = settings.value("HDDDEV", "all"); |     configuration["HDDDEV"] = settings.value("HDDDEV", "all"); | ||||||
|     configuration["HDDTEMPCMD"] |     configuration["HDDTEMPCMD"] = settings.value("HDDTEMPCMD", "sudo smartctl -a"); | ||||||
|         = settings.value("HDDTEMPCMD", "sudo smartctl -a"); |  | ||||||
|     configuration["MPDADDRESS"] = settings.value("MPDADDRESS", "localhost"); |     configuration["MPDADDRESS"] = settings.value("MPDADDRESS", "localhost"); | ||||||
|     configuration["MPDPORT"] = settings.value("MPDPORT", "6600"); |     configuration["MPDPORT"] = settings.value("MPDPORT", "6600"); | ||||||
|     configuration["MPRIS"] = settings.value("MPRIS", "auto"); |     configuration["MPRIS"] = settings.value("MPRIS", "auto"); | ||||||
| @ -212,14 +199,12 @@ QVariantMap AWConfigHelper::readDataEngineConfiguration() const | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| bool AWConfigHelper::writeDataEngineConfiguration( | bool AWConfigHelper::writeDataEngineConfiguration(const QVariantMap &_configuration) const | ||||||
|     const QVariantMap &_configuration) const |  | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Configuration" << _configuration; |     qCDebug(LOG_AW) << "Configuration" << _configuration; | ||||||
|  |  | ||||||
|     QString fileName = QString("%1/plasma-dataengine-extsysmon.conf") |     QString fileName = QString("%1/plasma-dataengine-extsysmon.conf") | ||||||
|                            .arg(QStandardPaths::writableLocation( |                            .arg(QStandardPaths::writableLocation(QStandardPaths::ConfigLocation)); | ||||||
|                                QStandardPaths::ConfigLocation)); |  | ||||||
|     QSettings settings(fileName, QSettings::IniFormat); |     QSettings settings(fileName, QSettings::IniFormat); | ||||||
|     qCInfo(LOG_AW) << "Configuration file" << settings.fileName(); |     qCInfo(LOG_AW) << "Configuration file" << settings.fileName(); | ||||||
|  |  | ||||||
| @ -245,8 +230,8 @@ void AWConfigHelper::copyConfigs(const QString &_localDir) const | |||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Local directory" << _localDir; |     qCDebug(LOG_AW) << "Local directory" << _localDir; | ||||||
|  |  | ||||||
|     QStringList dirs = QStandardPaths::locateAll( |     QStringList dirs | ||||||
|         QStandardPaths::GenericDataLocation, "awesomewidgets/configs", |         = QStandardPaths::locateAll(QStandardPaths::GenericDataLocation, "awesomewidgets/configs", | ||||||
|                                     QStandardPaths::LocateDirectory); |                                     QStandardPaths::LocateDirectory); | ||||||
|     for (auto &dir : dirs) { |     for (auto &dir : dirs) { | ||||||
|         if (dir == _localDir) |         if (dir == _localDir) | ||||||
| @ -254,25 +239,21 @@ void AWConfigHelper::copyConfigs(const QString &_localDir) const | |||||||
|         QStringList files = QDir(dir).entryList(QDir::Files); |         QStringList files = QDir(dir).entryList(QDir::Files); | ||||||
|         for (auto &source : files) { |         for (auto &source : files) { | ||||||
|             QString destination = QString("%1/%2").arg(_localDir).arg(source); |             QString destination = QString("%1/%2").arg(_localDir).arg(source); | ||||||
|             bool status = QFile::copy(QString("%1/%2").arg(dir).arg(source), |             bool status = QFile::copy(QString("%1/%2").arg(dir).arg(source), destination); | ||||||
|                                       destination); |             qCInfo(LOG_AW) << "File" << source << "has been copied to" << destination | ||||||
|             qCInfo(LOG_AW) << "File" << source << "has been copied to" |                            << "with status" << status; | ||||||
|                            << destination << "with status" << status; |  | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| void AWConfigHelper::copyExtensions(const QString &_item, const QString &_type, | void AWConfigHelper::copyExtensions(const QString &_item, const QString &_type, | ||||||
|                                     QSettings &_settings, |                                     QSettings &_settings, const bool _inverse) const | ||||||
|                                     const bool _inverse) const |  | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Extension" << _item << "has type" << _type |     qCDebug(LOG_AW) << "Extension" << _item << "has type" << _type << "inverse copying" << _inverse; | ||||||
|                     << "inverse copying" << _inverse; |  | ||||||
|  |  | ||||||
|     _settings.beginGroup(_item); |     _settings.beginGroup(_item); | ||||||
|     QSettings itemSettings( |     QSettings itemSettings(QString("%1/%2/%3").arg(m_baseDir).arg(_type).arg(_item), | ||||||
|         QString("%1/%2/%3").arg(m_baseDir).arg(_type).arg(_item), |  | ||||||
|                            QSettings::IniFormat); |                            QSettings::IniFormat); | ||||||
|     itemSettings.beginGroup("Desktop Entry"); |     itemSettings.beginGroup("Desktop Entry"); | ||||||
|     if (_inverse) |     if (_inverse) | ||||||
|  | |||||||
| @ -34,31 +34,26 @@ public: | |||||||
|     virtual ~AWConfigHelper(); |     virtual ~AWConfigHelper(); | ||||||
|     Q_INVOKABLE QString configurationDirectory() const; |     Q_INVOKABLE QString configurationDirectory() const; | ||||||
|     Q_INVOKABLE bool dropCache() const; |     Q_INVOKABLE bool dropCache() const; | ||||||
|     Q_INVOKABLE bool exportConfiguration(QObject *_nativeConfig, |     Q_INVOKABLE bool exportConfiguration(QObject *_nativeConfig, const QString &_fileName) const; | ||||||
|                                          const QString &_fileName) const; |  | ||||||
|     Q_INVOKABLE QVariantMap importConfiguration(const QString &_fileName, |     Q_INVOKABLE QVariantMap importConfiguration(const QString &_fileName, | ||||||
|                                                 const bool _importPlasmoid, |                                                 const bool _importPlasmoid, | ||||||
|                                                 const bool _importExtensions, |                                                 const bool _importExtensions, | ||||||
|                                                 const bool _importAdds) const; |                                                 const bool _importAdds) const; | ||||||
|     // dataengine |     // dataengine | ||||||
|     Q_INVOKABLE QVariantMap readDataEngineConfiguration() const; |     Q_INVOKABLE QVariantMap readDataEngineConfiguration() const; | ||||||
|     Q_INVOKABLE bool |     Q_INVOKABLE bool writeDataEngineConfiguration(const QVariantMap &_configuration) const; | ||||||
|     writeDataEngineConfiguration(const QVariantMap &_configuration) const; |  | ||||||
|  |  | ||||||
| private: | private: | ||||||
|     // methods |     // methods | ||||||
|     void copyConfigs(const QString &_localDir) const; |     void copyConfigs(const QString &_localDir) const; | ||||||
|     void copyExtensions(const QString &_item, const QString &_type, |     void copyExtensions(const QString &_item, const QString &_type, QSettings &_settings, | ||||||
|                         QSettings &_settings, const bool _inverse) const; |                         const bool _inverse) const; | ||||||
|     void copySettings(QSettings &_from, QSettings &_to) const; |     void copySettings(QSettings &_from, QSettings &_to) const; | ||||||
|     void readFile(QSettings &_settings, const QString &_key, |     void readFile(QSettings &_settings, const QString &_key, const QString &_fileName) const; | ||||||
|                   const QString &_fileName) const; |     void writeFile(QSettings &_settings, const QString &_key, const QString &_fileName) const; | ||||||
|     void writeFile(QSettings &_settings, const QString &_key, |  | ||||||
|                    const QString &_fileName) const; |  | ||||||
|     // properties |     // properties | ||||||
|     QString m_baseDir; |     QString m_baseDir; | ||||||
|     QStringList m_dirs |     QStringList m_dirs = {"desktops", "quotes", "scripts", "upgrade", "weather", "formatters"}; | ||||||
|         = {"desktops", "quotes", "scripts", "upgrade", "weather", "formatters"}; |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | |||||||
| @ -21,8 +21,7 @@ | |||||||
| #include "awdebug.h" | #include "awdebug.h" | ||||||
|  |  | ||||||
|  |  | ||||||
| AWCustomKeysConfig::AWCustomKeysConfig(QWidget *_parent, | AWCustomKeysConfig::AWCustomKeysConfig(QWidget *_parent, const QStringList &_keys) | ||||||
|                                        const QStringList &_keys) |  | ||||||
|     : AWAbstractPairConfig(_parent, false, _keys) |     : AWAbstractPairConfig(_parent, false, _keys) | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; |     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; | ||||||
|  | |||||||
| @ -60,8 +60,7 @@ QString AWDataAggregator::htmlImage(const QPixmap &_source) const | |||||||
|     QBuffer buffer(&byteArray); |     QBuffer buffer(&byteArray); | ||||||
|     _source.save(&buffer, "PNG"); |     _source.save(&buffer, "PNG"); | ||||||
|  |  | ||||||
|     return byteArray.isEmpty() |     return byteArray.isEmpty() ? "" | ||||||
|                ? "" |  | ||||||
|                                : QString("<img src=\"data:image/png;base64,%1\"/>") |                                : QString("<img src=\"data:image/png;base64,%1\"/>") | ||||||
|                                      .arg(QString(byteArray.toBase64())); |                                      .arg(QString(byteArray.toBase64())); | ||||||
| } | } | ||||||
| @ -125,8 +124,7 @@ QPixmap AWDataAggregator::tooltipImage() | |||||||
|             shift -= 100.0; |             shift -= 100.0; | ||||||
|         // apply pen color |         // apply pen color | ||||||
|         if (key != "batTooltip") |         if (key != "batTooltip") | ||||||
|             pen.setColor(QColor( |             pen.setColor(QColor(m_configuration[QString("%1Color").arg(key)].toString())); | ||||||
|                 m_configuration[QString("%1Color").arg(key)].toString())); |  | ||||||
|         // paint data inside frame |         // paint data inside frame | ||||||
|         for (int j = 0; j < m_values[key].count() - 1; j++) { |         for (int j = 0; j < m_values[key].count() - 1; j++) { | ||||||
|             // some magic here |             // some magic here | ||||||
| @ -136,11 +134,9 @@ QPixmap AWDataAggregator::tooltipImage() | |||||||
|             float y2 = -std::fabs(m_values[key].at(j + 1)) * normY + 5.0f; |             float y2 = -std::fabs(m_values[key].at(j + 1)) * normY + 5.0f; | ||||||
|             if (key == "batTooltip") { |             if (key == "batTooltip") { | ||||||
|                 if (m_values[key].at(j + 1) > 0) |                 if (m_values[key].at(j + 1) > 0) | ||||||
|                     pen.setColor( |                     pen.setColor(QColor(m_configuration["batTooltipColor"].toString())); | ||||||
|                         QColor(m_configuration["batTooltipColor"].toString())); |  | ||||||
|                 else |                 else | ||||||
|                     pen.setColor(QColor( |                     pen.setColor(QColor(m_configuration["batInTooltipColor"].toString())); | ||||||
|                         m_configuration["batInTooltipColor"].toString())); |  | ||||||
|             } |             } | ||||||
|             m_toolTipScene->addLine(x1, y1, x2, y2, pen); |             m_toolTipScene->addLine(x1, y1, x2, y2, pen); | ||||||
|         } |         } | ||||||
| @ -163,33 +159,27 @@ void AWDataAggregator::dataUpdate(const QVariantHash &_values) | |||||||
| void AWDataAggregator::checkValue(const QString &_source, const float _value, | void AWDataAggregator::checkValue(const QString &_source, const float _value, | ||||||
|                                   const float _extremum) const |                                   const float _extremum) const | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Notification source" << _source << "with value" |     qCDebug(LOG_AW) << "Notification source" << _source << "with value" << _value | ||||||
|                     << _value << "called with extremum" << _extremum; |                     << "called with extremum" << _extremum; | ||||||
|  |  | ||||||
|     if (_value >= 0.0) { |     if (_value >= 0.0) { | ||||||
|         if ((m_enablePopup) && (_value > _extremum) |         if ((m_enablePopup) && (_value > _extremum) && (m_values[_source].last() < _extremum)) | ||||||
|             && (m_values[_source].last() < _extremum)) |             return AWActions::sendNotification("event", notificationText(_source, _value)); | ||||||
|             return AWActions::sendNotification( |  | ||||||
|                 "event", notificationText(_source, _value)); |  | ||||||
|     } else { |     } else { | ||||||
|         if ((m_enablePopup) && (_value < _extremum) |         if ((m_enablePopup) && (_value < _extremum) && (m_values[_source].last() > _extremum)) | ||||||
|             && (m_values[_source].last() > _extremum)) |             return AWActions::sendNotification("event", notificationText(_source, _value)); | ||||||
|             return AWActions::sendNotification( |  | ||||||
|                 "event", notificationText(_source, _value)); |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| void AWDataAggregator::checkValue(const QString &_source, | void AWDataAggregator::checkValue(const QString &_source, const QString &_current, | ||||||
|                                   const QString &_current, |  | ||||||
|                                   const QString &_received) const |                                   const QString &_received) const | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Notification source" << _source << "with current value" |     qCDebug(LOG_AW) << "Notification source" << _source << "with current value" << _current | ||||||
|                     << _current << "and received one" << _received; |                     << "and received one" << _received; | ||||||
|  |  | ||||||
|     if ((m_enablePopup) && (_current != _received) && (!_received.isEmpty())) |     if ((m_enablePopup) && (_current != _received) && (!_received.isEmpty())) | ||||||
|         return AWActions::sendNotification( |         return AWActions::sendNotification("event", notificationText(_source, _received)); | ||||||
|             "event", notificationText(_source, _received)); |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -205,11 +195,9 @@ void AWDataAggregator::initScene() | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| QString AWDataAggregator::notificationText(const QString &_source, | QString AWDataAggregator::notificationText(const QString &_source, const float _value) const | ||||||
|                                            const float _value) const |  | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Notification source" << _source << "with value" |     qCDebug(LOG_AW) << "Notification source" << _source << "with value" << _value; | ||||||
|                     << _value; |  | ||||||
|  |  | ||||||
|     QString output; |     QString output; | ||||||
|     if (_source == "batTooltip") |     if (_source == "batTooltip") | ||||||
| @ -227,11 +215,9 @@ QString AWDataAggregator::notificationText(const QString &_source, | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| QString AWDataAggregator::notificationText(const QString &_source, | QString AWDataAggregator::notificationText(const QString &_source, const QString &_value) const | ||||||
|                                            const QString &_value) const |  | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Notification source" << _source << "with value" |     qCDebug(LOG_AW) << "Notification source" << _source << "with value" << _value; | ||||||
|                     << _value; |  | ||||||
|  |  | ||||||
|     QString output; |     QString output; | ||||||
|     if (_source == "netdev") |     if (_source == "netdev") | ||||||
| @ -245,8 +231,8 @@ void AWDataAggregator::setData(const QVariantHash &_values) | |||||||
| { | { | ||||||
|     // do not log these arguments |     // do not log these arguments | ||||||
|     // battery update requires info is AC online or not |     // battery update requires info is AC online or not | ||||||
|     setData(_values["ac"].toString() == m_configuration["acOnline"], |     setData(_values["ac"].toString() == m_configuration["acOnline"], "batTooltip", | ||||||
|             "batTooltip", _values["bat"].toFloat()); |             _values["bat"].toFloat()); | ||||||
|     // usual case |     // usual case | ||||||
|     setData("cpuTooltip", _values["cpu"].toFloat(), 90.0); |     setData("cpuTooltip", _values["cpu"].toFloat(), 90.0); | ||||||
|     setData("cpuclTooltip", _values["cpucl"].toFloat()); |     setData("cpuclTooltip", _values["cpucl"].toFloat()); | ||||||
| @ -267,16 +253,13 @@ void AWDataAggregator::setData(const QVariantHash &_values) | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| void AWDataAggregator::setData(const QString &_source, float _value, | void AWDataAggregator::setData(const QString &_source, float _value, const float _extremum) | ||||||
|                                const float _extremum) |  | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Source" << _source << "to value" << _value |     qCDebug(LOG_AW) << "Source" << _source << "to value" << _value << "with extremum" << _extremum; | ||||||
|                     << "with extremum" << _extremum; |  | ||||||
|  |  | ||||||
|     if (m_values[_source].count() == 0) |     if (m_values[_source].count() == 0) | ||||||
|         m_values[_source].append(0.0); |         m_values[_source].append(0.0); | ||||||
|     else if (m_values[_source].count() |     else if (m_values[_source].count() > m_configuration["tooltipNumber"].toInt()) | ||||||
|              > m_configuration["tooltipNumber"].toInt()) |  | ||||||
|         m_values[_source].removeFirst(); |         m_values[_source].removeFirst(); | ||||||
|     if (std::isnan(_value)) |     if (std::isnan(_value)) | ||||||
|         _value = 0.0; |         _value = 0.0; | ||||||
| @ -286,8 +269,7 @@ void AWDataAggregator::setData(const QString &_source, float _value, | |||||||
|  |  | ||||||
|     m_values[_source].append(_value); |     m_values[_source].append(_value); | ||||||
|     if (_source == "downkbTooltip") { |     if (_source == "downkbTooltip") { | ||||||
|         QList<float> netValues |         QList<float> netValues = m_values["downkbTooltip"] + m_values["upkbTooltip"]; | ||||||
|             = m_values["downkbTooltip"] + m_values["upkbTooltip"]; |  | ||||||
|         // to avoid inf value of normY |         // to avoid inf value of normY | ||||||
|         netValues << 1.0; |         netValues << 1.0; | ||||||
|         m_boundaries["downkbTooltip"] |         m_boundaries["downkbTooltip"] | ||||||
| @ -297,11 +279,10 @@ void AWDataAggregator::setData(const QString &_source, float _value, | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| void AWDataAggregator::setData(const bool _dontInvert, const QString &_source, | void AWDataAggregator::setData(const bool _dontInvert, const QString &_source, float _value) | ||||||
|                                float _value) |  | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Do not invert" << _dontInvert << "value" << _value |     qCDebug(LOG_AW) << "Do not invert" << _dontInvert << "value" << _value << "for source" | ||||||
|                     << "for source" << _source; |                     << _source; | ||||||
|  |  | ||||||
|     // invert values for different battery colours |     // invert values for different battery colours | ||||||
|     _value = _dontInvert ? _value : -_value; |     _value = _dontInvert ? _value : -_value; | ||||||
|  | |||||||
| @ -49,18 +49,15 @@ private: | |||||||
|     // ui |     // ui | ||||||
|     QGraphicsScene *m_toolTipScene = nullptr; |     QGraphicsScene *m_toolTipScene = nullptr; | ||||||
|     QGraphicsView *m_toolTipView = nullptr; |     QGraphicsView *m_toolTipView = nullptr; | ||||||
|     void checkValue(const QString &_source, const float _value, |     void checkValue(const QString &_source, const float _value, const float _extremum) const; | ||||||
|                     const float _extremum) const; |  | ||||||
|     void checkValue(const QString &_source, const QString &_current, |     void checkValue(const QString &_source, const QString &_current, | ||||||
|                     const QString &_received) const; |                     const QString &_received) const; | ||||||
|     void initScene(); |     void initScene(); | ||||||
|     QString notificationText(const QString &_source, const float _value) const; |     QString notificationText(const QString &_source, const float _value) const; | ||||||
|     QString notificationText(const QString &_source, |     QString notificationText(const QString &_source, const QString &_value) const; | ||||||
|                              const QString &_value) const; |  | ||||||
|     // main method |     // main method | ||||||
|     void setData(const QVariantHash &_values); |     void setData(const QVariantHash &_values); | ||||||
|     void setData(const QString &_source, float _value, |     void setData(const QString &_source, float _value, const float _extremum = -1.0f); | ||||||
|                  const float _extremum = -1.0f); |  | ||||||
|     // different signature for battery device |     // different signature for battery device | ||||||
|     void setData(const bool _dontInvert, const QString &_source, float _value); |     void setData(const bool _dontInvert, const QString &_source, float _value); | ||||||
|     // variables |     // variables | ||||||
|  | |||||||
| @ -34,12 +34,11 @@ AWDataEngineAggregator::AWDataEngineAggregator(QObject *_parent) | |||||||
|     m_dataEngines["time"] = m_consumer->dataEngine("time"); |     m_dataEngines["time"] = m_consumer->dataEngine("time"); | ||||||
|  |  | ||||||
|     // additional method required by systemmonitor structure |     // additional method required by systemmonitor structure | ||||||
|     m_newSourceConnection = connect( |     m_newSourceConnection | ||||||
|         m_dataEngines["systemmonitor"], &Plasma::DataEngine::sourceAdded, |         = connect(m_dataEngines["systemmonitor"], &Plasma::DataEngine::sourceAdded, | ||||||
|                   [this](const QString source) { |                   [this](const QString source) { | ||||||
|                       emit(deviceAdded(source)); |                       emit(deviceAdded(source)); | ||||||
|             m_dataEngines["systemmonitor"]->connectSource(source, parent(), |                       m_dataEngines["systemmonitor"]->connectSource(source, parent(), 1000); | ||||||
|                                                           1000); |  | ||||||
|                   }); |                   }); | ||||||
|  |  | ||||||
|     // required to define Qt::QueuedConnection for signal-slot connection |     // required to define Qt::QueuedConnection for signal-slot connection | ||||||
| @ -74,12 +73,11 @@ void AWDataEngineAggregator::reconnectSources(const int _interval) | |||||||
|     m_dataEngines["extsysmon"]->connectAllSources(parent(), _interval); |     m_dataEngines["extsysmon"]->connectAllSources(parent(), _interval); | ||||||
|     m_dataEngines["time"]->connectSource("Local", parent(), 1000); |     m_dataEngines["time"]->connectSource("Local", parent(), 1000); | ||||||
|  |  | ||||||
|     m_newSourceConnection = connect( |     m_newSourceConnection | ||||||
|         m_dataEngines["systemmonitor"], &Plasma::DataEngine::sourceAdded, |         = connect(m_dataEngines["systemmonitor"], &Plasma::DataEngine::sourceAdded, | ||||||
|                   [this, _interval](const QString source) { |                   [this, _interval](const QString source) { | ||||||
|                       emit(deviceAdded(source)); |                       emit(deviceAdded(source)); | ||||||
|             m_dataEngines["systemmonitor"]->connectSource(source, parent(), |                       m_dataEngines["systemmonitor"]->connectSource(source, parent(), _interval); | ||||||
|                                                           _interval); |  | ||||||
|                   }); |                   }); | ||||||
|  |  | ||||||
| #ifdef BUILD_FUTURE | #ifdef BUILD_FUTURE | ||||||
| @ -105,24 +103,18 @@ void AWDataEngineAggregator::createQueuedConnection() | |||||||
|     // for more details refer to plasma-framework source code |     // for more details refer to plasma-framework source code | ||||||
|     for (auto &dataEngine : m_dataEngines.keys()) { |     for (auto &dataEngine : m_dataEngines.keys()) { | ||||||
|         // different source set for different engines |         // different source set for different engines | ||||||
|         QStringList sources = dataEngine == "time" |         QStringList sources = dataEngine == "time" ? QStringList() << "Local" | ||||||
|                                   ? QStringList() << "Local" |  | ||||||
|                                                    : m_dataEngines[dataEngine]->sources(); |                                                    : m_dataEngines[dataEngine]->sources(); | ||||||
|         // reconnect sources |         // reconnect sources | ||||||
|         for (auto &source : sources) { |         for (auto &source : sources) { | ||||||
|             Plasma::DataContainer *container |             Plasma::DataContainer *container | ||||||
|                 = m_dataEngines[dataEngine]->containerForSource(source); |                 = m_dataEngines[dataEngine]->containerForSource(source); | ||||||
|             // disconnect old connections first |             // disconnect old connections first | ||||||
|             disconnect(container, |             disconnect(container, SIGNAL(dataUpdated(QString, Plasma::DataEngine::Data)), parent(), | ||||||
|                        SIGNAL(dataUpdated(QString, Plasma::DataEngine::Data)), |  | ||||||
|                        parent(), |  | ||||||
|                        SLOT(dataUpdated(QString, Plasma::DataEngine::Data))); |                        SLOT(dataUpdated(QString, Plasma::DataEngine::Data))); | ||||||
|             // and now reconnect with Qt::QueuedConnection type |             // and now reconnect with Qt::QueuedConnection type | ||||||
|             connect(container, |             connect(container, SIGNAL(dataUpdated(QString, Plasma::DataEngine::Data)), parent(), | ||||||
|                     SIGNAL(dataUpdated(QString, Plasma::DataEngine::Data)), |                     SLOT(dataUpdated(QString, Plasma::DataEngine::Data)), Qt::QueuedConnection); | ||||||
|                     parent(), |  | ||||||
|                     SLOT(dataUpdated(QString, Plasma::DataEngine::Data)), |  | ||||||
|                     Qt::QueuedConnection); |  | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
| @ -23,8 +23,7 @@ | |||||||
| #include "awformatterhelper.h" | #include "awformatterhelper.h" | ||||||
|  |  | ||||||
|  |  | ||||||
| AWDataEngineMapper::AWDataEngineMapper(QObject *_parent, | AWDataEngineMapper::AWDataEngineMapper(QObject *_parent, AWFormatterHelper *_custom) | ||||||
|                                        AWFormatterHelper *_custom) |  | ||||||
|     : QObject(_parent) |     : QObject(_parent) | ||||||
|     , m_customFormatters(_custom) |     , m_customFormatters(_custom) | ||||||
| { | { | ||||||
| @ -59,8 +58,7 @@ AWDataEngineMapper::~AWDataEngineMapper() | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| AWKeysAggregator::FormatterType | AWKeysAggregator::FormatterType AWDataEngineMapper::formatter(const QString &_key) const | ||||||
| AWDataEngineMapper::formatter(const QString &_key) const |  | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Get formatter for key" << _key; |     qCDebug(LOG_AW) << "Get formatter for key" << _key; | ||||||
|  |  | ||||||
| @ -78,8 +76,7 @@ QStringList AWDataEngineMapper::keysFromSource(const QString &_source) const | |||||||
|  |  | ||||||
| // HACK units required to define should the value be calculated as temperature | // HACK units required to define should the value be calculated as temperature | ||||||
| // or fan data | // or fan data | ||||||
| QStringList AWDataEngineMapper::registerSource(const QString &_source, | QStringList AWDataEngineMapper::registerSource(const QString &_source, const QString &_units, | ||||||
|                                                const QString &_units, |  | ||||||
|                                                const QStringList &_keys) |                                                const QStringList &_keys) | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Source" << _source << "with units" << _units; |     qCDebug(LOG_AW) << "Source" << _source << "with units" << _units; | ||||||
| @ -92,10 +89,8 @@ QStringList AWDataEngineMapper::registerSource(const QString &_source, | |||||||
|     QRegExp mountFillRegExp = QRegExp("partitions/.*/filllevel"); |     QRegExp mountFillRegExp = QRegExp("partitions/.*/filllevel"); | ||||||
|     QRegExp mountFreeRegExp = QRegExp("partitions/.*/freespace"); |     QRegExp mountFreeRegExp = QRegExp("partitions/.*/freespace"); | ||||||
|     QRegExp mountUsedRegExp = QRegExp("partitions/.*/usedspace"); |     QRegExp mountUsedRegExp = QRegExp("partitions/.*/usedspace"); | ||||||
|     QRegExp netRegExp |     QRegExp netRegExp = QRegExp("network/interfaces/.*/(receiver|transmitter)/data$"); | ||||||
|         = QRegExp("network/interfaces/.*/(receiver|transmitter)/data$"); |     QRegExp netTotalRegExp = QRegExp("network/interfaces/.*/(receiver|transmitter)/dataTotal$"); | ||||||
|     QRegExp netTotalRegExp |  | ||||||
|         = QRegExp("network/interfaces/.*/(receiver|transmitter)/dataTotal$"); |  | ||||||
|  |  | ||||||
|     if (_source == "battery/ac") { |     if (_source == "battery/ac") { | ||||||
|         // AC |         // AC | ||||||
| @ -106,8 +101,7 @@ QStringList AWDataEngineMapper::registerSource(const QString &_source, | |||||||
|         QString key = _source; |         QString key = _source; | ||||||
|         key.remove("battery/"); |         key.remove("battery/"); | ||||||
|         m_map[_source] = key; |         m_map[_source] = key; | ||||||
|         m_formatter[key] = _source.contains("rate") |         m_formatter[key] = _source.contains("rate") ? AWKeysAggregator::FormatterType::Float | ||||||
|                                ? AWKeysAggregator::FormatterType::Float |  | ||||||
|                                                     : AWKeysAggregator::FormatterType::IntegerThree; |                                                     : AWKeysAggregator::FormatterType::IntegerThree; | ||||||
|     } else if (_source == "cpu/system/TotalLoad") { |     } else if (_source == "cpu/system/TotalLoad") { | ||||||
|         // cpu |         // cpu | ||||||
| @ -338,12 +332,10 @@ QStringList AWDataEngineMapper::registerSource(const QString &_source, | |||||||
|         // free swap |         // free swap | ||||||
|         // mb |         // mb | ||||||
|         m_map[_source] = "swapfreemb"; |         m_map[_source] = "swapfreemb"; | ||||||
|         m_formatter["swapfreemb"] |         m_formatter["swapfreemb"] = AWKeysAggregator::FormatterType::MemMBFormat; | ||||||
|             = AWKeysAggregator::FormatterType::MemMBFormat; |  | ||||||
|         // gb |         // gb | ||||||
|         m_map.insertMulti(_source, "swapfreegb"); |         m_map.insertMulti(_source, "swapfreegb"); | ||||||
|         m_formatter["swapfreegb"] |         m_formatter["swapfreegb"] = AWKeysAggregator::FormatterType::MemGBFormat; | ||||||
|             = AWKeysAggregator::FormatterType::MemGBFormat; |  | ||||||
|     } else if (_source == "mem/swap/used") { |     } else if (_source == "mem/swap/used") { | ||||||
|         // used swap |         // used swap | ||||||
|         // mb |         // mb | ||||||
| @ -361,8 +353,7 @@ QStringList AWDataEngineMapper::registerSource(const QString &_source, | |||||||
|         if (index > -1) { |         if (index > -1) { | ||||||
|             QString key = QString("temp%1").arg(index); |             QString key = QString("temp%1").arg(index); | ||||||
|             m_map[_source] = key; |             m_map[_source] = key; | ||||||
|             m_formatter[key] |             m_formatter[key] = _units == "°C" ? AWKeysAggregator::FormatterType::Temperature | ||||||
|                 = _units == "°C" ? AWKeysAggregator::FormatterType::Temperature |  | ||||||
|                                               : AWKeysAggregator::FormatterType::Integer; |                                               : AWKeysAggregator::FormatterType::Integer; | ||||||
|         } |         } | ||||||
|     } else if (_source == "Local") { |     } else if (_source == "Local") { | ||||||
| @ -417,8 +408,7 @@ QStringList AWDataEngineMapper::registerSource(const QString &_source, | |||||||
|     QStringList customFormattersKeys; |     QStringList customFormattersKeys; | ||||||
|     if (m_customFormatters) |     if (m_customFormatters) | ||||||
|         customFormattersKeys = m_customFormatters->definedFormatters(); |         customFormattersKeys = m_customFormatters->definedFormatters(); | ||||||
|     qCInfo(LOG_AW) << "Looking for formatters" << foundKeys << "in" |     qCInfo(LOG_AW) << "Looking for formatters" << foundKeys << "in" << customFormattersKeys; | ||||||
|                    << customFormattersKeys; |  | ||||||
|     for (auto &key : foundKeys) { |     for (auto &key : foundKeys) { | ||||||
|         if (!customFormattersKeys.contains(key)) |         if (!customFormattersKeys.contains(key)) | ||||||
|             continue; |             continue; | ||||||
| @ -427,11 +417,9 @@ QStringList AWDataEngineMapper::registerSource(const QString &_source, | |||||||
|  |  | ||||||
|     // drop key from dictionary if no one user requested key required it |     // drop key from dictionary if no one user requested key required it | ||||||
|     qCInfo(LOG_AW) << "Looking for keys" << foundKeys << "in" << _keys; |     qCInfo(LOG_AW) << "Looking for keys" << foundKeys << "in" << _keys; | ||||||
|     bool required |     bool required = _keys.isEmpty() | ||||||
|         = _keys.isEmpty() || std::any_of(foundKeys.cbegin(), foundKeys.cend(), |                     || std::any_of(foundKeys.cbegin(), foundKeys.cend(), | ||||||
|                                          [&_keys](const QString &key) { |                                    [&_keys](const QString &key) { return _keys.contains(key); }); | ||||||
|                                              return _keys.contains(key); |  | ||||||
|                                          }); |  | ||||||
|     if (!required) { |     if (!required) { | ||||||
|         m_map.remove(_source); |         m_map.remove(_source); | ||||||
|         for (auto &key : foundKeys) |         for (auto &key : foundKeys) | ||||||
|  | |||||||
| @ -32,8 +32,7 @@ class AWDataEngineMapper : public QObject | |||||||
|     Q_OBJECT |     Q_OBJECT | ||||||
|  |  | ||||||
| public: | public: | ||||||
|     explicit AWDataEngineMapper(QObject *_parent = nullptr, |     explicit AWDataEngineMapper(QObject *_parent = nullptr, AWFormatterHelper *_custom = nullptr); | ||||||
|                                 AWFormatterHelper *_custom = nullptr); |  | ||||||
|     virtual ~AWDataEngineMapper(); |     virtual ~AWDataEngineMapper(); | ||||||
|     // get methods |     // get methods | ||||||
|     AWKeysAggregator::FormatterType formatter(const QString &_key) const; |     AWKeysAggregator::FormatterType formatter(const QString &_key) const; | ||||||
|  | |||||||
| @ -40,8 +40,8 @@ AWDBusAdaptor::~AWDBusAdaptor() | |||||||
|  |  | ||||||
| QStringList AWDBusAdaptor::ActiveServices() const | QStringList AWDBusAdaptor::ActiveServices() const | ||||||
| { | { | ||||||
|     QDBusMessage listServices = QDBusConnection::sessionBus().interface()->call( |     QDBusMessage listServices | ||||||
|         QDBus::BlockWithGui, "ListNames"); |         = QDBusConnection::sessionBus().interface()->call(QDBus::BlockWithGui, "ListNames"); | ||||||
|     if (listServices.arguments().isEmpty()) { |     if (listServices.arguments().isEmpty()) { | ||||||
|         qCWarning(LOG_DBUS) << "Could not find any DBus service"; |         qCWarning(LOG_DBUS) << "Could not find any DBus service"; | ||||||
|         return {}; |         return {}; | ||||||
| @ -86,8 +86,8 @@ void AWDBusAdaptor::SetLogLevel(const QString &what, const int level) | |||||||
|     qCDebug(LOG_DBUS) << "Set log level" << level << "for" << what; |     qCDebug(LOG_DBUS) << "Set log level" << level << "for" << what; | ||||||
|  |  | ||||||
|     if (level >= m_logLevels.count()) { |     if (level >= m_logLevels.count()) { | ||||||
|         qCDebug(LOG_DBUS) << "Invalid logging level" << level |         qCDebug(LOG_DBUS) << "Invalid logging level" << level << "should be less than" | ||||||
|                           << "should be less than" << m_logLevels.count(); |                           << m_logLevels.count(); | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @ -96,19 +96,15 @@ void AWDBusAdaptor::SetLogLevel(const QString &what, const int level) | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| void AWDBusAdaptor::SetLogLevel(const QString &what, const QString &level, | void AWDBusAdaptor::SetLogLevel(const QString &what, const QString &level, const bool enabled) | ||||||
|                                 const bool enabled) |  | ||||||
| { | { | ||||||
|     qCDebug(LOG_DBUS) << "Set log level" << level << "enabled" << enabled |     qCDebug(LOG_DBUS) << "Set log level" << level << "enabled" << enabled << "for" << what; | ||||||
|                       << "for" << what; |  | ||||||
|  |  | ||||||
|     if (!m_logLevels.contains(level)) { |     if (!m_logLevels.contains(level)) { | ||||||
|         qCDebug(LOG_DBUS) << "Invalid logging level" << level << "should be in" |         qCDebug(LOG_DBUS) << "Invalid logging level" << level << "should be in" << m_logLevels; | ||||||
|                           << m_logLevels; |  | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     QString state = enabled ? "true" : "false"; |     QString state = enabled ? "true" : "false"; | ||||||
|     QLoggingCategory::setFilterRules( |     QLoggingCategory::setFilterRules(QString("%1.%2=%3").arg(what).arg(level).arg(state)); | ||||||
|         QString("%1.%2=%3").arg(what).arg(level).arg(state)); |  | ||||||
| } | } | ||||||
|  | |||||||
| @ -44,8 +44,7 @@ public slots: | |||||||
|     qlonglong WhoAmI() const; |     qlonglong WhoAmI() const; | ||||||
|     // set methods |     // set methods | ||||||
|     void SetLogLevel(const QString &what, const int level); |     void SetLogLevel(const QString &what, const int level); | ||||||
|     void SetLogLevel(const QString &what, const QString &level, |     void SetLogLevel(const QString &what, const QString &level, const bool enabled); | ||||||
|                      const bool enabled); |  | ||||||
|  |  | ||||||
| private: | private: | ||||||
|     AWKeys *m_plugin = nullptr; |     AWKeys *m_plugin = nullptr; | ||||||
|  | |||||||
| @ -35,8 +35,7 @@ | |||||||
|  |  | ||||||
| AWFormatterHelper::AWFormatterHelper(QWidget *_parent) | AWFormatterHelper::AWFormatterHelper(QWidget *_parent) | ||||||
|     : AbstractExtItemAggregator(_parent, "formatters") |     : AbstractExtItemAggregator(_parent, "formatters") | ||||||
|     , AWAbstractPairHelper("awesomewidgets/formatters/formatters.ini", |     , AWAbstractPairHelper("awesomewidgets/formatters/formatters.ini", "Formatters") | ||||||
|                            "Formatters") |  | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; |     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; | ||||||
|  |  | ||||||
| @ -63,8 +62,7 @@ void AWFormatterHelper::initItems() | |||||||
|     for (auto &key : pairs().keys()) { |     for (auto &key : pairs().keys()) { | ||||||
|         auto name = pairs()[key]; |         auto name = pairs()[key]; | ||||||
|         if (!m_formattersClasses.contains(name)) { |         if (!m_formattersClasses.contains(name)) { | ||||||
|             qCWarning(LOG_AW) |             qCWarning(LOG_AW) << "Invalid formatter" << name << "found in" << key; | ||||||
|                 << "Invalid formatter" << name << "found in" << key; |  | ||||||
|             continue; |             continue; | ||||||
|         } |         } | ||||||
|  |  | ||||||
| @ -73,13 +71,11 @@ void AWFormatterHelper::initItems() | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| QString AWFormatterHelper::convert(const QVariant &_value, | QString AWFormatterHelper::convert(const QVariant &_value, const QString &_name) const | ||||||
|                                    const QString &_name) const |  | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Convert value" << _value << "for" << _name; |     qCDebug(LOG_AW) << "Convert value" << _value << "for" << _name; | ||||||
|  |  | ||||||
|     return m_formatters.contains(_name) ? m_formatters[_name]->convert(_value) |     return m_formatters.contains(_name) ? m_formatters[_name]->convert(_value) : _value.toString(); | ||||||
|                                         : _value.toString(); |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -130,8 +126,7 @@ AWFormatterHelper::defineFormatterClass(const QString &_stringType) const | |||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Define formatter class for" << _stringType; |     qCDebug(LOG_AW) << "Define formatter class for" << _stringType; | ||||||
|  |  | ||||||
|     AWAbstractFormatter::FormatterClass formatter |     AWAbstractFormatter::FormatterClass formatter = AWAbstractFormatter::FormatterClass::NoFormat; | ||||||
|         = AWAbstractFormatter::FormatterClass::NoFormat; |  | ||||||
|     if (_stringType == "DateTime") |     if (_stringType == "DateTime") | ||||||
|         formatter = AWAbstractFormatter::FormatterClass::DateTime; |         formatter = AWAbstractFormatter::FormatterClass::DateTime; | ||||||
|     else if (_stringType == "Float") |     else if (_stringType == "Float") | ||||||
| @ -177,32 +172,25 @@ void AWFormatterHelper::initFormatters() | |||||||
|             auto metadata = readMetadata(filePath); |             auto metadata = readMetadata(filePath); | ||||||
|             switch (metadata.second) { |             switch (metadata.second) { | ||||||
|             case AWAbstractFormatter::FormatterClass::DateTime: |             case AWAbstractFormatter::FormatterClass::DateTime: | ||||||
|                 m_formattersClasses[metadata.first] |                 m_formattersClasses[metadata.first] = new AWDateTimeFormatter(this, filePath); | ||||||
|                     = new AWDateTimeFormatter(this, filePath); |  | ||||||
|                 break; |                 break; | ||||||
|             case AWAbstractFormatter::FormatterClass::Float: |             case AWAbstractFormatter::FormatterClass::Float: | ||||||
|                 m_formattersClasses[metadata.first] |                 m_formattersClasses[metadata.first] = new AWFloatFormatter(this, filePath); | ||||||
|                     = new AWFloatFormatter(this, filePath); |  | ||||||
|                 break; |                 break; | ||||||
|             case AWAbstractFormatter::FormatterClass::List: |             case AWAbstractFormatter::FormatterClass::List: | ||||||
|                 m_formattersClasses[metadata.first] |                 m_formattersClasses[metadata.first] = new AWListFormatter(this, filePath); | ||||||
|                     = new AWListFormatter(this, filePath); |  | ||||||
|                 break; |                 break; | ||||||
|             case AWAbstractFormatter::FormatterClass::Script: |             case AWAbstractFormatter::FormatterClass::Script: | ||||||
|                 m_formattersClasses[metadata.first] |                 m_formattersClasses[metadata.first] = new AWScriptFormatter(this, filePath); | ||||||
|                     = new AWScriptFormatter(this, filePath); |  | ||||||
|                 break; |                 break; | ||||||
|             case AWAbstractFormatter::FormatterClass::String: |             case AWAbstractFormatter::FormatterClass::String: | ||||||
|                 m_formattersClasses[metadata.first] |                 m_formattersClasses[metadata.first] = new AWStringFormatter(this, filePath); | ||||||
|                     = new AWStringFormatter(this, filePath); |  | ||||||
|                 break; |                 break; | ||||||
|             case AWAbstractFormatter::FormatterClass::Json: |             case AWAbstractFormatter::FormatterClass::Json: | ||||||
|                 m_formattersClasses[metadata.first] |                 m_formattersClasses[metadata.first] = new AWJsonFormatter(this, filePath); | ||||||
|                     = new AWJsonFormatter(this, filePath); |  | ||||||
|                 break; |                 break; | ||||||
|             case AWAbstractFormatter::FormatterClass::NoFormat: |             case AWAbstractFormatter::FormatterClass::NoFormat: | ||||||
|                 m_formattersClasses[metadata.first] |                 m_formattersClasses[metadata.first] = new AWNoFormatter(this, filePath); | ||||||
|                     = new AWNoFormatter(this, filePath); |  | ||||||
|                 break; |                 break; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
| @ -228,19 +216,17 @@ AWFormatterHelper::readMetadata(const QString &_filePath) const | |||||||
|  |  | ||||||
| void AWFormatterHelper::doCreateItem() | void AWFormatterHelper::doCreateItem() | ||||||
| { | { | ||||||
|     QStringList selection |     QStringList selection = {"NoFormat", "DateTime", "Float", "List", "Script", "String", "Json"}; | ||||||
|         = {"NoFormat", "DateTime", "Float", "List", "Script", "String", "Json"}; |  | ||||||
|     bool ok; |     bool ok; | ||||||
|     QString select = QInputDialog::getItem( |     QString select | ||||||
|         this, i18n("Select type"), i18n("Type:"), selection, 0, false, &ok); |         = QInputDialog::getItem(this, i18n("Select type"), i18n("Type:"), selection, 0, false, &ok); | ||||||
|     if (!ok) { |     if (!ok) { | ||||||
|         qCWarning(LOG_AW) << "No type selected"; |         qCWarning(LOG_AW) << "No type selected"; | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     qCInfo(LOG_AW) << "Selected type" << select; |     qCInfo(LOG_AW) << "Selected type" << select; | ||||||
|     AWAbstractFormatter::FormatterClass formatter |     AWAbstractFormatter::FormatterClass formatter = defineFormatterClass(select); | ||||||
|         = defineFormatterClass(select); |  | ||||||
|     switch (formatter) { |     switch (formatter) { | ||||||
|     case AWAbstractFormatter::FormatterClass::DateTime: |     case AWAbstractFormatter::FormatterClass::DateTime: | ||||||
|         return createItem<AWDateTimeFormatter>(); |         return createItem<AWDateTimeFormatter>(); | ||||||
|  | |||||||
| @ -24,8 +24,7 @@ | |||||||
| #include "awabstractpairhelper.h" | #include "awabstractpairhelper.h" | ||||||
|  |  | ||||||
|  |  | ||||||
| class AWFormatterHelper : public AbstractExtItemAggregator, | class AWFormatterHelper : public AbstractExtItemAggregator, public AWAbstractPairHelper | ||||||
|                           public AWAbstractPairHelper |  | ||||||
| { | { | ||||||
|     Q_OBJECT |     Q_OBJECT | ||||||
|  |  | ||||||
| @ -48,8 +47,7 @@ public slots: | |||||||
|  |  | ||||||
| private: | private: | ||||||
|     // methods |     // methods | ||||||
|     AWAbstractFormatter::FormatterClass |     AWAbstractFormatter::FormatterClass defineFormatterClass(const QString &_stringType) const; | ||||||
|     defineFormatterClass(const QString &_stringType) const; |  | ||||||
|     void initFormatters(); |     void initFormatters(); | ||||||
|     QPair<QString, AWAbstractFormatter::FormatterClass> |     QPair<QString, AWAbstractFormatter::FormatterClass> | ||||||
|     readMetadata(const QString &_filePath) const; |     readMetadata(const QString &_filePath) const; | ||||||
|  | |||||||
| @ -29,9 +29,9 @@ bool AWKeyCache::addKeyToCache(const QString &_type, const QString &_key) | |||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Key" << _key << "with type" << _type; |     qCDebug(LOG_AW) << "Key" << _key << "with type" << _type; | ||||||
|  |  | ||||||
|     QString fileName = QString("%1/awesomewidgets.ndx") |     QString fileName | ||||||
|                            .arg(QStandardPaths::writableLocation( |         = QString("%1/awesomewidgets.ndx") | ||||||
|                                QStandardPaths::GenericCacheLocation)); |               .arg(QStandardPaths::writableLocation(QStandardPaths::GenericCacheLocation)); | ||||||
|     qCInfo(LOG_AW) << "Cache file" << fileName; |     qCInfo(LOG_AW) << "Cache file" << fileName; | ||||||
|     QSettings cache(fileName, QSettings::IniFormat); |     QSettings cache(fileName, QSettings::IniFormat); | ||||||
|  |  | ||||||
| @ -41,8 +41,7 @@ bool AWKeyCache::addKeyToCache(const QString &_type, const QString &_key) | |||||||
|         cachedValues.append(cache.value(number).toString()); |         cachedValues.append(cache.value(number).toString()); | ||||||
|  |  | ||||||
|     if (_type == "hdd") { |     if (_type == "hdd") { | ||||||
|         QStringList allDevices |         QStringList allDevices = QDir("/dev").entryList(QDir::System, QDir::Name); | ||||||
|             = QDir("/dev").entryList(QDir::System, QDir::Name); |  | ||||||
|         QStringList devices = allDevices.filter(QRegExp("^[hms]d[a-z]$")); |         QStringList devices = allDevices.filter(QRegExp("^[hms]d[a-z]$")); | ||||||
|         for (auto &dev : devices) { |         for (auto &dev : devices) { | ||||||
|             QString device = QString("/dev/%1").arg(dev); |             QString device = QString("/dev/%1").arg(dev); | ||||||
| @ -50,30 +49,23 @@ bool AWKeyCache::addKeyToCache(const QString &_type, const QString &_key) | |||||||
|                 continue; |                 continue; | ||||||
|             qCInfo(LOG_AW) << "Found new key" << device << "for type" << _type; |             qCInfo(LOG_AW) << "Found new key" << device << "for type" << _type; | ||||||
|             cachedValues.append(device); |             cachedValues.append(device); | ||||||
|             cache.setValue( |             cache.setValue(QString("%1").arg(cache.allKeys().count(), 3, 10, QChar('0')), device); | ||||||
|                 QString("%1").arg(cache.allKeys().count(), 3, 10, QChar('0')), |  | ||||||
|                 device); |  | ||||||
|         } |         } | ||||||
|     } else if (_type == "net") { |     } else if (_type == "net") { | ||||||
|         QList<QNetworkInterface> rawInterfaceList |         QList<QNetworkInterface> rawInterfaceList = QNetworkInterface::allInterfaces(); | ||||||
|             = QNetworkInterface::allInterfaces(); |  | ||||||
|         for (auto &interface : rawInterfaceList) { |         for (auto &interface : rawInterfaceList) { | ||||||
|             QString device = interface.name(); |             QString device = interface.name(); | ||||||
|             if (cachedValues.contains(device)) |             if (cachedValues.contains(device)) | ||||||
|                 continue; |                 continue; | ||||||
|             qCInfo(LOG_AW) << "Found new key" << device << "for type" << _type; |             qCInfo(LOG_AW) << "Found new key" << device << "for type" << _type; | ||||||
|             cachedValues.append(device); |             cachedValues.append(device); | ||||||
|             cache.setValue( |             cache.setValue(QString("%1").arg(cache.allKeys().count(), 3, 10, QChar('0')), device); | ||||||
|                 QString("%1").arg(cache.allKeys().count(), 3, 10, QChar('0')), |  | ||||||
|                 device); |  | ||||||
|         } |         } | ||||||
|     } else { |     } else { | ||||||
|         if (cachedValues.contains(_key)) |         if (cachedValues.contains(_key)) | ||||||
|             return false; |             return false; | ||||||
|         qCInfo(LOG_AW) << "Found new key" << _key << "for type" << _type; |         qCInfo(LOG_AW) << "Found new key" << _key << "for type" << _type; | ||||||
|         cache.setValue( |         cache.setValue(QString("%1").arg(cache.allKeys().count(), 3, 10, QChar('0')), _key); | ||||||
|             QString("%1").arg(cache.allKeys().count(), 3, 10, QChar('0')), |  | ||||||
|             _key); |  | ||||||
|     } |     } | ||||||
|     cache.endGroup(); |     cache.endGroup(); | ||||||
|  |  | ||||||
| @ -82,14 +74,12 @@ bool AWKeyCache::addKeyToCache(const QString &_type, const QString &_key) | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| QStringList AWKeyCache::getRequiredKeys(const QStringList &_keys, | QStringList AWKeyCache::getRequiredKeys(const QStringList &_keys, const QStringList &_bars, | ||||||
|                                         const QStringList &_bars, |                                         const QVariantMap &_tooltip, const QStringList &_userKeys, | ||||||
|                                         const QVariantMap &_tooltip, |  | ||||||
|                                         const QStringList &_userKeys, |  | ||||||
|                                         const QStringList &_allKeys) |                                         const QStringList &_allKeys) | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Looking for required keys in" << _keys << _bars |     qCDebug(LOG_AW) << "Looking for required keys in" << _keys << _bars << "using tooltip settings" | ||||||
|                     << "using tooltip settings" << _tooltip; |                     << _tooltip; | ||||||
|  |  | ||||||
|     // initial copy |     // initial copy | ||||||
|     QSet<QString> used = QSet<QString>::fromList(_keys); |     QSet<QString> used = QSet<QString>::fromList(_keys); | ||||||
| @ -110,8 +100,7 @@ QStringList AWKeyCache::getRequiredKeys(const QStringList &_keys, | |||||||
|             continue; |             continue; | ||||||
|         key.remove("hddtotmb"); |         key.remove("hddtotmb"); | ||||||
|         int index = key.toInt(); |         int index = key.toInt(); | ||||||
|         used << QString("hddfreemb%1").arg(index) |         used << QString("hddfreemb%1").arg(index) << QString("hddmb%1").arg(index); | ||||||
|              << QString("hddmb%1").arg(index); |  | ||||||
|     } |     } | ||||||
|     // hddtotgb* |     // hddtotgb* | ||||||
|     for (auto &key : _allKeys.filter(QRegExp("^hddtotgb"))) { |     for (auto &key : _allKeys.filter(QRegExp("^hddtotgb"))) { | ||||||
| @ -119,8 +108,7 @@ QStringList AWKeyCache::getRequiredKeys(const QStringList &_keys, | |||||||
|             continue; |             continue; | ||||||
|         key.remove("hddtotgb"); |         key.remove("hddtotgb"); | ||||||
|         int index = key.toInt(); |         int index = key.toInt(); | ||||||
|         used << QString("hddfreegb%1").arg(index) |         used << QString("hddfreegb%1").arg(index) << QString("hddgb%1").arg(index); | ||||||
|              << QString("hddgb%1").arg(index); |  | ||||||
|     } |     } | ||||||
|     // mem |     // mem | ||||||
|     if (used.contains("mem")) |     if (used.contains("mem")) | ||||||
| @ -147,13 +135,12 @@ QStringList AWKeyCache::getRequiredKeys(const QStringList &_keys, | |||||||
|         used << "swapgb" |         used << "swapgb" | ||||||
|              << "swapfreegb"; |              << "swapfreegb"; | ||||||
|     // network keys |     // network keys | ||||||
|     QStringList netKeys({"up", "upkb", "uptot", "uptotkb", "upunits", "down", |     QStringList netKeys({"up", "upkb", "uptot", "uptotkb", "upunits", "down", "downkb", "downtot", | ||||||
|                          "downkb", "downtot", "downtotkb", "downunits"}); |                          "downtotkb", "downunits"}); | ||||||
|     for (auto &key : netKeys) { |     for (auto &key : netKeys) { | ||||||
|         if (!used.contains(key)) |         if (!used.contains(key)) | ||||||
|             continue; |             continue; | ||||||
|         QStringList filt |         QStringList filt = _allKeys.filter(QRegExp(QString("^%1[0-9]{1,}").arg(key))); | ||||||
|             = _allKeys.filter(QRegExp(QString("^%1[0-9]{1,}").arg(key))); |  | ||||||
|         for (auto &filtered : filt) |         for (auto &filtered : filt) | ||||||
|             used << filtered; |             used << filtered; | ||||||
|     } |     } | ||||||
| @ -173,9 +160,9 @@ QStringList AWKeyCache::getRequiredKeys(const QStringList &_keys, | |||||||
|  |  | ||||||
| QHash<QString, QStringList> AWKeyCache::loadKeysFromCache() | QHash<QString, QStringList> AWKeyCache::loadKeysFromCache() | ||||||
| { | { | ||||||
|     QString fileName = QString("%1/awesomewidgets.ndx") |     QString fileName | ||||||
|                            .arg(QStandardPaths::writableLocation( |         = QString("%1/awesomewidgets.ndx") | ||||||
|                                QStandardPaths::GenericCacheLocation)); |               .arg(QStandardPaths::writableLocation(QStandardPaths::GenericCacheLocation)); | ||||||
|     qCInfo(LOG_AW) << "Cache file" << fileName; |     qCInfo(LOG_AW) << "Cache file" << fileName; | ||||||
|     QSettings cache(fileName, QSettings::IniFormat); |     QSettings cache(fileName, QSettings::IniFormat); | ||||||
|  |  | ||||||
|  | |||||||
| @ -28,8 +28,7 @@ namespace AWKeyCache | |||||||
| { | { | ||||||
| bool addKeyToCache(const QString &_type, const QString &_key = ""); | bool addKeyToCache(const QString &_type, const QString &_key = ""); | ||||||
| QStringList getRequiredKeys(const QStringList &_keys, const QStringList &_bars, | QStringList getRequiredKeys(const QStringList &_keys, const QStringList &_bars, | ||||||
|                             const QVariantMap &_tooltip, |                             const QVariantMap &_tooltip, const QStringList &_userKeys, | ||||||
|                             const QStringList &_userKeys, |  | ||||||
|                             const QStringList &_allKeys); |                             const QStringList &_allKeys); | ||||||
| QHash<QString, QStringList> loadKeysFromCache(); | QHash<QString, QStringList> loadKeysFromCache(); | ||||||
| }; | }; | ||||||
|  | |||||||
| @ -41,10 +41,8 @@ AWKeyOperations::AWKeyOperations(QObject *_parent) | |||||||
|     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; |     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; | ||||||
|  |  | ||||||
|     m_customKeys = new AWCustomKeysHelper(this); |     m_customKeys = new AWCustomKeysHelper(this); | ||||||
|     m_graphicalItems |     m_graphicalItems = new ExtItemAggregator<GraphicalItem>(nullptr, "desktops"); | ||||||
|         = new ExtItemAggregator<GraphicalItem>(nullptr, "desktops"); |     m_extNetRequest = new ExtItemAggregator<ExtNetworkRequest>(nullptr, "requests"); | ||||||
|     m_extNetRequest |  | ||||||
|         = new ExtItemAggregator<ExtNetworkRequest>(nullptr, "requests"); |  | ||||||
|     m_extQuotes = new ExtItemAggregator<ExtQuotes>(nullptr, "quotes"); |     m_extQuotes = new ExtItemAggregator<ExtQuotes>(nullptr, "quotes"); | ||||||
|     m_extScripts = new ExtItemAggregator<ExtScript>(nullptr, "scripts"); |     m_extScripts = new ExtItemAggregator<ExtScript>(nullptr, "scripts"); | ||||||
|     m_extUpgrade = new ExtItemAggregator<ExtUpgrade>(nullptr, "upgrade"); |     m_extUpgrade = new ExtItemAggregator<ExtUpgrade>(nullptr, "upgrade"); | ||||||
| @ -134,8 +132,7 @@ QStringList AWKeyOperations::dictKeys() const | |||||||
|     // battery |     // battery | ||||||
|     QStringList allBatteryDevices |     QStringList allBatteryDevices | ||||||
|         = QDir("/sys/class/power_supply") |         = QDir("/sys/class/power_supply") | ||||||
|               .entryList(QStringList({"BAT*"}), |               .entryList(QStringList({"BAT*"}), QDir::Dirs | QDir::NoDotAndDotDot, QDir::Name); | ||||||
|                          QDir::Dirs | QDir::NoDotAndDotDot, QDir::Name); |  | ||||||
|     for (int i = 0; i < allBatteryDevices.count(); i++) { |     for (int i = 0; i < allBatteryDevices.count(); i++) { | ||||||
|         allKeys.append(QString("bat%1").arg(i)); |         allKeys.append(QString("bat%1").arg(i)); | ||||||
|         allKeys.append(QString("batleft%1").arg(i)); |         allKeys.append(QString("batleft%1").arg(i)); | ||||||
| @ -148,15 +145,12 @@ QStringList AWKeyOperations::dictKeys() const | |||||||
|         allKeys.append(item->tag("pkgcount")); |         allKeys.append(item->tag("pkgcount")); | ||||||
|     // quotes |     // quotes | ||||||
|     for (auto &item : m_extQuotes->activeItems()) { |     for (auto &item : m_extQuotes->activeItems()) { | ||||||
|         allKeys.append(item->tag("ask")); |  | ||||||
|         allKeys.append(item->tag("askchg")); |  | ||||||
|         allKeys.append(item->tag("percaskchg")); |  | ||||||
|         allKeys.append(item->tag("bid")); |  | ||||||
|         allKeys.append(item->tag("bidchg")); |  | ||||||
|         allKeys.append(item->tag("percbidchg")); |  | ||||||
|         allKeys.append(item->tag("price")); |         allKeys.append(item->tag("price")); | ||||||
|         allKeys.append(item->tag("pricechg")); |         allKeys.append(item->tag("pricechg")); | ||||||
|         allKeys.append(item->tag("percpricechg")); |         allKeys.append(item->tag("percpricechg")); | ||||||
|  |         allKeys.append(item->tag("volume")); | ||||||
|  |         allKeys.append(item->tag("volumechg")); | ||||||
|  |         allKeys.append(item->tag("percvolumechg")); | ||||||
|     } |     } | ||||||
|     // custom |     // custom | ||||||
|     for (auto &item : m_extScripts->activeItems()) |     for (auto &item : m_extScripts->activeItems()) | ||||||
| @ -228,8 +222,7 @@ QString AWKeyOperations::infoByKey(const QString &_key) const | |||||||
|         QString index = _key; |         QString index = _key; | ||||||
|         index.remove(QRegExp("hdd[rw]")); |         index.remove(QRegExp("hdd[rw]")); | ||||||
|         output = m_devices["disk"][index.toInt()]; |         output = m_devices["disk"][index.toInt()]; | ||||||
|     } else if (_key.contains( |     } else if (_key.contains(QRegExp("^hdd([0-9]|mb|gb|freemb|freegb|totmb|totgb)"))) { | ||||||
|                    QRegExp("^hdd([0-9]|mb|gb|freemb|freegb|totmb|totgb)"))) { |  | ||||||
|         QString index = _key; |         QString index = _key; | ||||||
|         index.remove(QRegExp("^hdd(|mb|gb|freemb|freegb|totmb|totgb)")); |         index.remove(QRegExp("^hdd(|mb|gb|freemb|freegb|totmb|totgb)")); | ||||||
|         output = m_devices["mount"][index.toInt()]; |         output = m_devices["mount"][index.toInt()]; | ||||||
| @ -249,8 +242,7 @@ QString AWKeyOperations::infoByKey(const QString &_key) const | |||||||
|         AbstractExtItem *item = m_extQuotes->itemByTag(_key, stripped); |         AbstractExtItem *item = m_extQuotes->itemByTag(_key, stripped); | ||||||
|         if (item) |         if (item) | ||||||
|             output = item->uniq(); |             output = item->uniq(); | ||||||
|     } else if (_key.contains(QRegExp( |     } else if (_key.contains(QRegExp("(weather|weatherId|humidity|pressure|temperature)"))) { | ||||||
|                    "(weather|weatherId|humidity|pressure|temperature)"))) { |  | ||||||
|         AbstractExtItem *item = m_extWeather->itemByTag(_key, stripped); |         AbstractExtItem *item = m_extWeather->itemByTag(_key, stripped); | ||||||
|         if (item) |         if (item) | ||||||
|             output = item->uniq(); |             output = item->uniq(); | ||||||
| @ -289,8 +281,8 @@ void AWKeyOperations::editItem(const QString &_type) | |||||||
|     qCDebug(LOG_AW) << "Item type" << _type; |     qCDebug(LOG_AW) << "Item type" << _type; | ||||||
|  |  | ||||||
|     if (_type == "graphicalitem") { |     if (_type == "graphicalitem") { | ||||||
|         QStringList keys = dictKeys().filter( |         QStringList keys | ||||||
|             QRegExp("^(cpu(?!cl).*|gpu$|mem$|swap$|hdd[0-9].*|bat.*)")); |             = dictKeys().filter(QRegExp("^(cpu(?!cl).*|gpu$|mem$|swap$|hdd[0-9].*|bat.*)")); | ||||||
|         keys.sort(); |         keys.sort(); | ||||||
|         m_graphicalItems->setConfigArgs(keys); |         m_graphicalItems->setConfigArgs(keys); | ||||||
|         return m_graphicalItems->editItems(); |         return m_graphicalItems->editItems(); | ||||||
|  | |||||||
| @ -62,11 +62,11 @@ AWKeys::AWKeys(QObject *_parent) | |||||||
|     // transfer signal from AWDataAggregator object to QML ui |     // transfer signal from AWDataAggregator object to QML ui | ||||||
|     connect(m_dataAggregator, SIGNAL(toolTipPainted(const QString &)), this, |     connect(m_dataAggregator, SIGNAL(toolTipPainted(const QString &)), this, | ||||||
|             SIGNAL(needToolTipToBeUpdated(const QString &))); |             SIGNAL(needToolTipToBeUpdated(const QString &))); | ||||||
|     connect(this, SIGNAL(dropSourceFromDataengine(const QString &)), |     connect(this, SIGNAL(dropSourceFromDataengine(const QString &)), m_dataEngineAggregator, | ||||||
|             m_dataEngineAggregator, SLOT(dropSource(const QString &))); |             SLOT(dropSource(const QString &))); | ||||||
|     // transfer signal from dataengine to update source list |     // transfer signal from dataengine to update source list | ||||||
|     connect(m_dataEngineAggregator, SIGNAL(deviceAdded(const QString &)), |     connect(m_dataEngineAggregator, SIGNAL(deviceAdded(const QString &)), m_keyOperator, | ||||||
|             m_keyOperator, SLOT(addDevice(const QString &))); |             SLOT(addDevice(const QString &))); | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -91,17 +91,15 @@ void AWKeys::initDataAggregator(const QVariantMap &_tooltipParams) | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| void AWKeys::initKeys(const QString &_currentPattern, const int _interval, | void AWKeys::initKeys(const QString &_currentPattern, const int _interval, const int _limit, | ||||||
|                       const int _limit, const bool _optimize) |                       const bool _optimize) | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Pattern" << _currentPattern << "with interval" |     qCDebug(LOG_AW) << "Pattern" << _currentPattern << "with interval" << _interval | ||||||
|                     << _interval << "and queue limit" << _limit |                     << "and queue limit" << _limit << "with optimization" << _optimize; | ||||||
|                     << "with optimization" << _optimize; |  | ||||||
|  |  | ||||||
|     // init |     // init | ||||||
|     m_optimize = _optimize; |     m_optimize = _optimize; | ||||||
|     m_threadPool->setMaxThreadCount(_limit == 0 ? QThread::idealThreadCount() |     m_threadPool->setMaxThreadCount(_limit == 0 ? QThread::idealThreadCount() : _limit); | ||||||
|                                                 : _limit); |  | ||||||
|     // child objects |     // child objects | ||||||
|     m_aggregator->initFormatters(); |     m_aggregator->initFormatters(); | ||||||
|     m_keyOperator->setPattern(_currentPattern); |     m_keyOperator->setPattern(_currentPattern); | ||||||
| @ -138,8 +136,7 @@ void AWKeys::updateCache() | |||||||
|  |  | ||||||
| QStringList AWKeys::dictKeys(const bool _sorted, const QString &_regexp) const | QStringList AWKeys::dictKeys(const bool _sorted, const QString &_regexp) const | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Should be sorted" << _sorted << "and filter applied" |     qCDebug(LOG_AW) << "Should be sorted" << _sorted << "and filter applied" << _regexp; | ||||||
|                     << _regexp; |  | ||||||
|  |  | ||||||
|     // check if functions asked |     // check if functions asked | ||||||
|     if (_regexp == "functions") |     if (_regexp == "functions") | ||||||
| @ -190,8 +187,7 @@ QString AWKeys::valueByKey(const QString &_key) const | |||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Requested value for key" << _key; |     qCDebug(LOG_AW) << "Requested value for key" << _key; | ||||||
|  |  | ||||||
|     QString trueKey |     QString trueKey = _key.startsWith("bar") ? m_keyOperator->infoByKey(_key) : _key; | ||||||
|         = _key.startsWith("bar") ? m_keyOperator->infoByKey(_key) : _key; |  | ||||||
|  |  | ||||||
|     return m_aggregator->formatter(m_values[trueKey], trueKey); |     return m_aggregator->formatter(m_values[trueKey], trueKey); | ||||||
| } | } | ||||||
| @ -205,12 +201,10 @@ void AWKeys::editItem(const QString &_type) | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| void AWKeys::dataUpdated(const QString &_sourceName, | void AWKeys::dataUpdated(const QString &_sourceName, const Plasma::DataEngine::Data &_data) | ||||||
|                          const Plasma::DataEngine::Data &_data) |  | ||||||
| { | { | ||||||
|     // run concurrent data update |     // run concurrent data update | ||||||
|     QtConcurrent::run(m_threadPool, this, &AWKeys::setDataBySource, _sourceName, |     QtConcurrent::run(m_threadPool, this, &AWKeys::setDataBySource, _sourceName, _data); | ||||||
|                       _data); |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -219,26 +213,22 @@ void AWKeys::reinitKeys(const QStringList &_currentKeys) | |||||||
|     qCDebug(LOG_AW) << "Update found keys by using list" << _currentKeys; |     qCDebug(LOG_AW) << "Update found keys by using list" << _currentKeys; | ||||||
|  |  | ||||||
|     // append lists |     // append lists | ||||||
|     m_foundBars = AWPatternFunctions::findKeys(m_keyOperator->pattern(), |     m_foundBars = AWPatternFunctions::findKeys(m_keyOperator->pattern(), _currentKeys, true); | ||||||
|                                                _currentKeys, true); |     m_foundKeys = AWPatternFunctions::findKeys(m_keyOperator->pattern(), _currentKeys, false); | ||||||
|     m_foundKeys = AWPatternFunctions::findKeys(m_keyOperator->pattern(), |  | ||||||
|                                                _currentKeys, false); |  | ||||||
|     m_foundLambdas = AWPatternFunctions::findLambdas(m_keyOperator->pattern()); |     m_foundLambdas = AWPatternFunctions::findLambdas(m_keyOperator->pattern()); | ||||||
|     // generate list of required keys for bars |     // generate list of required keys for bars | ||||||
|     QStringList barKeys; |     QStringList barKeys; | ||||||
|     for (auto &bar : m_foundBars) { |     for (auto &bar : m_foundBars) { | ||||||
|         GraphicalItem *item = m_keyOperator->giByKey(bar); |         GraphicalItem *item = m_keyOperator->giByKey(bar); | ||||||
|         if (item->isCustom()) |         if (item->isCustom()) | ||||||
|             item->setUsedKeys( |             item->setUsedKeys(AWPatternFunctions::findKeys(item->bar(), _currentKeys, false)); | ||||||
|                 AWPatternFunctions::findKeys(item->bar(), _currentKeys, false)); |  | ||||||
|         else |         else | ||||||
|             item->setUsedKeys(QStringList() << item->bar()); |             item->setUsedKeys(QStringList() << item->bar()); | ||||||
|         barKeys.append(item->usedKeys()); |         barKeys.append(item->usedKeys()); | ||||||
|     } |     } | ||||||
|     // get required keys |     // get required keys | ||||||
|     m_requiredKeys = m_optimize |     m_requiredKeys | ||||||
|                          ? AWKeyCache::getRequiredKeys( |         = m_optimize ? AWKeyCache::getRequiredKeys(m_foundKeys, barKeys, m_tooltipParams, | ||||||
|                                m_foundKeys, barKeys, m_tooltipParams, |  | ||||||
|                                                    m_keyOperator->requiredUserKeys(), _currentKeys) |                                                    m_keyOperator->requiredUserKeys(), _currentKeys) | ||||||
|                      : QStringList(); |                      : QStringList(); | ||||||
|  |  | ||||||
| @ -278,17 +268,13 @@ void AWKeys::calculateValues() | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     // memtot* |     // memtot* | ||||||
|     m_values["memtotmb"] |     m_values["memtotmb"] = m_values["memusedmb"].toInt() + m_values["memfreemb"].toInt(); | ||||||
|         = m_values["memusedmb"].toInt() + m_values["memfreemb"].toInt(); |     m_values["memtotgb"] = m_values["memusedgb"].toFloat() + m_values["memfreegb"].toFloat(); | ||||||
|     m_values["memtotgb"] |  | ||||||
|         = m_values["memusedgb"].toFloat() + m_values["memfreegb"].toFloat(); |  | ||||||
|     // mem |     // mem | ||||||
|     m_values["mem"] |     m_values["mem"] = 100.0f * m_values["memmb"].toFloat() / m_values["memtotmb"].toFloat(); | ||||||
|         = 100.0f * m_values["memmb"].toFloat() / m_values["memtotmb"].toFloat(); |  | ||||||
|  |  | ||||||
|     // up, down, upkb, downkb, upunits, downunits |     // up, down, upkb, downkb, upunits, downunits | ||||||
|     int netIndex |     int netIndex = m_keyOperator->devices("net").indexOf(m_values["netdev"].toString()); | ||||||
|         = m_keyOperator->devices("net").indexOf(m_values["netdev"].toString()); |  | ||||||
|     m_values["down"] = m_values[QString("down%1").arg(netIndex)]; |     m_values["down"] = m_values[QString("down%1").arg(netIndex)]; | ||||||
|     m_values["downkb"] = m_values[QString("downkb%1").arg(netIndex)]; |     m_values["downkb"] = m_values[QString("downkb%1").arg(netIndex)]; | ||||||
|     m_values["downtot"] = m_values[QString("downtot%1").arg(netIndex)]; |     m_values["downtot"] = m_values[QString("downtot%1").arg(netIndex)]; | ||||||
| @ -301,13 +287,10 @@ void AWKeys::calculateValues() | |||||||
|     m_values["upunits"] = m_values[QString("upunits%1").arg(netIndex)]; |     m_values["upunits"] = m_values[QString("upunits%1").arg(netIndex)]; | ||||||
|  |  | ||||||
|     // swaptot* |     // swaptot* | ||||||
|     m_values["swaptotmb"] |     m_values["swaptotmb"] = m_values["swapmb"].toInt() + m_values["swapfreemb"].toInt(); | ||||||
|         = m_values["swapmb"].toInt() + m_values["swapfreemb"].toInt(); |     m_values["swaptotgb"] = m_values["swapgb"].toFloat() + m_values["swapfreegb"].toFloat(); | ||||||
|     m_values["swaptotgb"] |  | ||||||
|         = m_values["swapgb"].toFloat() + m_values["swapfreegb"].toFloat(); |  | ||||||
|     // swap |     // swap | ||||||
|     m_values["swap"] = 100.0f * m_values["swapmb"].toFloat() |     m_values["swap"] = 100.0f * m_values["swapmb"].toFloat() / m_values["swaptotmb"].toFloat(); | ||||||
|                        / m_values["swaptotmb"].toFloat(); |  | ||||||
|  |  | ||||||
|     // user defined keys |     // user defined keys | ||||||
|     for (auto &key : m_keyOperator->userKeys()) |     for (auto &key : m_keyOperator->userKeys()) | ||||||
| @ -315,8 +298,7 @@ void AWKeys::calculateValues() | |||||||
|  |  | ||||||
|     // lambdas |     // lambdas | ||||||
|     for (auto &key : m_foundLambdas) |     for (auto &key : m_foundLambdas) | ||||||
|         m_values[key] = AWPatternFunctions::expandLambdas( |         m_values[key] = AWPatternFunctions::expandLambdas(key, m_aggregator, m_values, m_foundKeys); | ||||||
|             key, m_aggregator, m_values, m_foundKeys); |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -329,8 +311,7 @@ void AWKeys::createDBusInterface() | |||||||
|     QDBusConnection instanceBus = QDBusConnection::sessionBus(); |     QDBusConnection instanceBus = QDBusConnection::sessionBus(); | ||||||
|     // HACK we are going to use different services because it binds to |     // HACK we are going to use different services because it binds to | ||||||
|     // application |     // application | ||||||
|     if (instanceBus.registerService( |     if (instanceBus.registerService(QString("%1.i%2").arg(AWDBUS_SERVICE).arg(id))) { | ||||||
|             QString("%1.i%2").arg(AWDBUS_SERVICE).arg(id))) { |  | ||||||
|         if (!instanceBus.registerObject(AWDBUS_PATH, new AWDBusAdaptor(this), |         if (!instanceBus.registerObject(AWDBUS_PATH, new AWDBusAdaptor(this), | ||||||
|                                         QDBusConnection::ExportAllContents)) |                                         QDBusConnection::ExportAllContents)) | ||||||
|             qCWarning(LOG_AW) << "Could not register DBus object, last error" |             qCWarning(LOG_AW) << "Could not register DBus object, last error" | ||||||
| @ -359,14 +340,12 @@ QString AWKeys::parsePattern(QString _pattern) const | |||||||
|  |  | ||||||
|     // main keys |     // main keys | ||||||
|     for (auto &key : m_foundKeys) |     for (auto &key : m_foundKeys) | ||||||
|         _pattern.replace(QString("$%1").arg(key), |         _pattern.replace(QString("$%1").arg(key), m_aggregator->formatter(m_values[key], key)); | ||||||
|                          m_aggregator->formatter(m_values[key], key)); |  | ||||||
|  |  | ||||||
|     // bars |     // bars | ||||||
|     for (auto &bar : m_foundBars) { |     for (auto &bar : m_foundBars) { | ||||||
|         GraphicalItem *item = m_keyOperator->giByKey(bar); |         GraphicalItem *item = m_keyOperator->giByKey(bar); | ||||||
|         QString image |         QString image = item->isCustom() | ||||||
|             = item->isCustom() |  | ||||||
|                             ? item->image(AWPatternFunctions::expandLambdas( |                             ? item->image(AWPatternFunctions::expandLambdas( | ||||||
|                                   item->bar(), m_aggregator, m_values, item->usedKeys())) |                                   item->bar(), m_aggregator, m_values, item->usedKeys())) | ||||||
|                             : item->image(m_values[item->bar()]); |                             : item->image(m_values[item->bar()]); | ||||||
| @ -382,16 +361,14 @@ QString AWKeys::parsePattern(QString _pattern) const | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| void AWKeys::setDataBySource(const QString &_sourceName, | void AWKeys::setDataBySource(const QString &_sourceName, const QVariantMap &_data) | ||||||
|                              const QVariantMap &_data) |  | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Source" << _sourceName << "with data" << _data; |     qCDebug(LOG_AW) << "Source" << _sourceName << "with data" << _data; | ||||||
|  |  | ||||||
|     // first list init |     // first list init | ||||||
|     QStringList tags = m_aggregator->keysFromSource(_sourceName); |     QStringList tags = m_aggregator->keysFromSource(_sourceName); | ||||||
|     if (tags.isEmpty()) |     if (tags.isEmpty()) | ||||||
|         tags = m_aggregator->registerSource( |         tags = m_aggregator->registerSource(_sourceName, _data["units"].toString(), m_requiredKeys); | ||||||
|             _sourceName, _data["units"].toString(), m_requiredKeys); |  | ||||||
|  |  | ||||||
|     // update data or drop source if there are no matches and exit |     // update data or drop source if there are no matches and exit | ||||||
|     if (tags.isEmpty()) { |     if (tags.isEmpty()) { | ||||||
| @ -401,10 +378,8 @@ void AWKeys::setDataBySource(const QString &_sourceName, | |||||||
|  |  | ||||||
|     m_mutex.lock(); |     m_mutex.lock(); | ||||||
|     // HACK workaround for time values which are stored in the different path |     // HACK workaround for time values which are stored in the different path | ||||||
|     std::for_each(tags.cbegin(), tags.cend(), |     std::for_each(tags.cbegin(), tags.cend(), [this, &_data, &_sourceName](const QString &tag) { | ||||||
|                   [this, &_data, &_sourceName](const QString &tag) { |         m_values[tag] = _sourceName == "Local" ? _data["DateTime"] : _data["value"]; | ||||||
|                       m_values[tag] = _sourceName == "Local" ? _data["DateTime"] |  | ||||||
|                                                              : _data["value"]; |  | ||||||
|     }); |     }); | ||||||
|     m_mutex.unlock(); |     m_mutex.unlock(); | ||||||
| } | } | ||||||
|  | |||||||
| @ -40,18 +40,15 @@ public: | |||||||
|     explicit AWKeys(QObject *_parent = nullptr); |     explicit AWKeys(QObject *_parent = nullptr); | ||||||
|     virtual ~AWKeys(); |     virtual ~AWKeys(); | ||||||
|     Q_INVOKABLE void initDataAggregator(const QVariantMap &_tooltipParams); |     Q_INVOKABLE void initDataAggregator(const QVariantMap &_tooltipParams); | ||||||
|     Q_INVOKABLE void initKeys(const QString &_currentPattern, |     Q_INVOKABLE void initKeys(const QString &_currentPattern, const int _interval, const int _limit, | ||||||
|                               const int _interval, const int _limit, |  | ||||||
|                               const bool _optimize); |                               const bool _optimize); | ||||||
|     Q_INVOKABLE void setAggregatorProperty(const QString &_key, |     Q_INVOKABLE void setAggregatorProperty(const QString &_key, const QVariant &_value); | ||||||
|                                            const QVariant &_value); |  | ||||||
|     Q_INVOKABLE void setWrapNewLines(const bool _wrap); |     Q_INVOKABLE void setWrapNewLines(const bool _wrap); | ||||||
|     // additional method to force load keys from Qml UI. Used in some |     // additional method to force load keys from Qml UI. Used in some | ||||||
|     // configuration pages |     // configuration pages | ||||||
|     Q_INVOKABLE void updateCache(); |     Q_INVOKABLE void updateCache(); | ||||||
|     // keys |     // keys | ||||||
|     Q_INVOKABLE QStringList dictKeys(const bool _sorted = false, |     Q_INVOKABLE QStringList dictKeys(const bool _sorted = false, const QString &_regexp = "") const; | ||||||
|                                      const QString &_regexp = "") const; |  | ||||||
|     Q_INVOKABLE QVariantList getHddDevices() const; |     Q_INVOKABLE QVariantList getHddDevices() const; | ||||||
|     // values |     // values | ||||||
|     Q_INVOKABLE QString infoByKey(const QString &_key) const; |     Q_INVOKABLE QString infoByKey(const QString &_key) const; | ||||||
| @ -60,8 +57,7 @@ public: | |||||||
|     Q_INVOKABLE void editItem(const QString &_type); |     Q_INVOKABLE void editItem(const QString &_type); | ||||||
|  |  | ||||||
| public slots: | public slots: | ||||||
|     void dataUpdated(const QString &_sourceName, |     void dataUpdated(const QString &_sourceName, const Plasma::DataEngine::Data &_data); | ||||||
|                      const Plasma::DataEngine::Data &_data); |  | ||||||
|     // dummy method required by DataEngine connections |     // dummy method required by DataEngine connections | ||||||
|     void modelChanged(QString, QAbstractItemModel *){}; |     void modelChanged(QString, QAbstractItemModel *){}; | ||||||
|  |  | ||||||
|  | |||||||
| @ -55,8 +55,7 @@ void AWKeysAggregator::initFormatters() | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| QString AWKeysAggregator::formatter(const QVariant &_data, | QString AWKeysAggregator::formatter(const QVariant &_data, const QString &_key) const | ||||||
|                                     const QString &_key) const |  | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Data" << _data << "for key" << _key; |     qCDebug(LOG_AW) << "Data" << _data << "for key" << _key; | ||||||
|  |  | ||||||
| @ -86,8 +85,7 @@ QString AWKeysAggregator::formatter(const QVariant &_data, | |||||||
|         output = _data.toBool() ? m_acOnline : m_acOffline; |         output = _data.toBool() ? m_acOnline : m_acOffline; | ||||||
|         break; |         break; | ||||||
|     case FormatterType::MemGBFormat: |     case FormatterType::MemGBFormat: | ||||||
|         output |         output = QString("%1").arg(_data.toFloat() / (1024.0 * 1024.0), 5, 'f', 1); | ||||||
|             = QString("%1").arg(_data.toFloat() / (1024.0 * 1024.0), 5, 'f', 1); |  | ||||||
|         break; |         break; | ||||||
|     case FormatterType::MemMBFormat: |     case FormatterType::MemMBFormat: | ||||||
|         output = QString("%1").arg(_data.toFloat() / 1024.0, 5, 'f', 0); |         output = QString("%1").arg(_data.toFloat() / 1024.0, 5, 'f', 0); | ||||||
| @ -134,8 +132,7 @@ QString AWKeysAggregator::formatter(const QVariant &_data, | |||||||
|         output = loc.toString(_data.toDateTime(), QLocale::ShortFormat); |         output = loc.toString(_data.toDateTime(), QLocale::ShortFormat); | ||||||
|         break; |         break; | ||||||
|     case FormatterType::Timestamp: |     case FormatterType::Timestamp: | ||||||
|         output = QString("%1").arg( |         output = QString("%1").arg(_data.toDateTime().toMSecsSinceEpoch() / 1000.0, 10, 'f', 0); | ||||||
|             _data.toDateTime().toMSecsSinceEpoch() / 1000.0, 10, 'f', 0); |  | ||||||
|         break; |         break; | ||||||
|     case FormatterType::Uptime: |     case FormatterType::Uptime: | ||||||
|     case FormatterType::UptimeCustom: |     case FormatterType::UptimeCustom: | ||||||
| @ -145,19 +142,14 @@ QString AWKeysAggregator::formatter(const QVariant &_data, | |||||||
|                 int minutes = seconds / 60 % 60; |                 int minutes = seconds / 60 % 60; | ||||||
|                 int hours = ((seconds / 60) - minutes) / 60 % 24; |                 int hours = ((seconds / 60) - minutes) / 60 % 24; | ||||||
|                 int days = (((seconds / 60) - minutes) / 60 - hours) / 24; |                 int days = (((seconds / 60) - minutes) / 60 - hours) / 24; | ||||||
|                 source.replace("$dd", |                 source.replace("$dd", QString("%1").arg(days, 3, 10, QChar('0'))); | ||||||
|                                QString("%1").arg(days, 3, 10, QChar('0'))); |  | ||||||
|                 source.replace("$d", QString("%1").arg(days)); |                 source.replace("$d", QString("%1").arg(days)); | ||||||
|                 source.replace("$hh", |                 source.replace("$hh", QString("%1").arg(hours, 2, 10, QChar('0'))); | ||||||
|                                QString("%1").arg(hours, 2, 10, QChar('0'))); |  | ||||||
|                 source.replace("$h", QString("%1").arg(hours)); |                 source.replace("$h", QString("%1").arg(hours)); | ||||||
|                 source.replace("$mm", |                 source.replace("$mm", QString("%1").arg(minutes, 2, 10, QChar('0'))); | ||||||
|                                QString("%1").arg(minutes, 2, 10, QChar('0'))); |  | ||||||
|                 source.replace("$m", QString("%1").arg(minutes)); |                 source.replace("$m", QString("%1").arg(minutes)); | ||||||
|                 return source; |                 return source; | ||||||
|             }(m_mapper->formatter(_key) == FormatterType::Uptime |             }(m_mapper->formatter(_key) == FormatterType::Uptime ? "$ddd$hhh$mmm" : m_customUptime, | ||||||
|                   ? "$ddd$hhh$mmm" |  | ||||||
|                   : m_customUptime, |  | ||||||
|               static_cast<int>(_data.toFloat())); |               static_cast<int>(_data.toFloat())); | ||||||
|         break; |         break; | ||||||
|     case FormatterType::NoFormat: |     case FormatterType::NoFormat: | ||||||
| @ -241,8 +233,7 @@ void AWKeysAggregator::setTranslate(const bool _translate) | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| QStringList AWKeysAggregator::registerSource(const QString &_source, | QStringList AWKeysAggregator::registerSource(const QString &_source, const QString &_units, | ||||||
|                                              const QString &_units, |  | ||||||
|                                              const QStringList &_keys) |                                              const QStringList &_keys) | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Source" << _source << "with units" << _units; |     qCDebug(LOG_AW) << "Source" << _source << "with units" << _units; | ||||||
|  | |||||||
| @ -32,8 +32,7 @@ class AWKeysAggregator : public QObject | |||||||
|     Q_PROPERTY(QString acOffline MEMBER m_acOffline WRITE setAcOffline); |     Q_PROPERTY(QString acOffline MEMBER m_acOffline WRITE setAcOffline); | ||||||
|     Q_PROPERTY(QString acOnline MEMBER m_acOnline WRITE setAcOnline); |     Q_PROPERTY(QString acOnline MEMBER m_acOnline WRITE setAcOnline); | ||||||
|     Q_PROPERTY(QString customTime MEMBER m_customTime WRITE setCustomTime); |     Q_PROPERTY(QString customTime MEMBER m_customTime WRITE setCustomTime); | ||||||
|     Q_PROPERTY( |     Q_PROPERTY(QString customUptime MEMBER m_customUptime WRITE setCustomUptime); | ||||||
|         QString customUptime MEMBER m_customUptime WRITE setCustomUptime); |  | ||||||
|     Q_PROPERTY(QString tempUnits MEMBER m_tempUnits WRITE setTempUnits); |     Q_PROPERTY(QString tempUnits MEMBER m_tempUnits WRITE setTempUnits); | ||||||
|     Q_PROPERTY(bool translate MEMBER m_translate WRITE setTranslate); |     Q_PROPERTY(bool translate MEMBER m_translate WRITE setTranslate); | ||||||
|  |  | ||||||
|  | |||||||
| @ -24,8 +24,7 @@ | |||||||
| #include "awkeysaggregator.h" | #include "awkeysaggregator.h" | ||||||
|  |  | ||||||
|  |  | ||||||
| QString AWPatternFunctions::expandLambdas(QString _code, | QString AWPatternFunctions::expandLambdas(QString _code, AWKeysAggregator *_aggregator, | ||||||
|                                           AWKeysAggregator *_aggregator, |  | ||||||
|                                           const QVariantHash &_metadata, |                                           const QVariantHash &_metadata, | ||||||
|                                           const QStringList &_usedKeys) |                                           const QStringList &_usedKeys) | ||||||
| { | { | ||||||
| @ -41,9 +40,8 @@ QString AWPatternFunctions::expandLambdas(QString _code, | |||||||
|     qCInfo(LOG_AW) << "Expression" << _code; |     qCInfo(LOG_AW) << "Expression" << _code; | ||||||
|     QJSValue result = engine.evaluate(_code); |     QJSValue result = engine.evaluate(_code); | ||||||
|     if (result.isError()) { |     if (result.isError()) { | ||||||
|         qCWarning(LOG_AW) << "Uncaught exception at line" |         qCWarning(LOG_AW) << "Uncaught exception at line" << result.property("lineNumber").toInt() | ||||||
|                           << result.property("lineNumber").toInt() << ":" |                           << ":" << result.toString(); | ||||||
|                           << result.toString(); |  | ||||||
|         return ""; |         return ""; | ||||||
|     } else { |     } else { | ||||||
|         return result.toString(); |         return result.toString(); | ||||||
| @ -57,8 +55,7 @@ QString AWPatternFunctions::expandTemplates(QString _code) | |||||||
|  |  | ||||||
|     // match the following construction $template{{some code here}} |     // match the following construction $template{{some code here}} | ||||||
|     QRegularExpression templatesRegexp("\\$template\\{\\{(?<body>.*?)\\}\\}"); |     QRegularExpression templatesRegexp("\\$template\\{\\{(?<body>.*?)\\}\\}"); | ||||||
|     templatesRegexp.setPatternOptions( |     templatesRegexp.setPatternOptions(QRegularExpression::DotMatchesEverythingOption); | ||||||
|         QRegularExpression::DotMatchesEverythingOption); |  | ||||||
|  |  | ||||||
|     QRegularExpressionMatchIterator it = templatesRegexp.globalMatch(_code); |     QRegularExpressionMatchIterator it = templatesRegexp.globalMatch(_code); | ||||||
|     while (it.hasNext()) { |     while (it.hasNext()) { | ||||||
| @ -71,8 +68,7 @@ QString AWPatternFunctions::expandTemplates(QString _code) | |||||||
|         QString templateResult = ""; |         QString templateResult = ""; | ||||||
|         if (result.isError()) { |         if (result.isError()) { | ||||||
|             qCWarning(LOG_AW) << "Uncaught exception at line" |             qCWarning(LOG_AW) << "Uncaught exception at line" | ||||||
|                               << result.property("lineNumber").toInt() << ":" |                               << result.property("lineNumber").toInt() << ":" << result.toString(); | ||||||
|                               << result.toString(); |  | ||||||
|         } else { |         } else { | ||||||
|             templateResult = result.toString(); |             templateResult = result.toString(); | ||||||
|         } |         } | ||||||
| @ -86,8 +82,7 @@ QString AWPatternFunctions::expandTemplates(QString _code) | |||||||
|  |  | ||||||
|  |  | ||||||
| QList<AWPatternFunctions::AWFunction> | QList<AWPatternFunctions::AWFunction> | ||||||
| AWPatternFunctions::findFunctionCalls(const QString &_function, | AWPatternFunctions::findFunctionCalls(const QString &_function, const QString &_code) | ||||||
|                                       const QString &_code) |  | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Looking for function" << _function << "in" << _code; |     qCDebug(LOG_AW) << "Looking for function" << _function << "in" << _code; | ||||||
|  |  | ||||||
| @ -98,8 +93,7 @@ AWPatternFunctions::findFunctionCalls(const QString &_function, | |||||||
|     // * body depends on the function name, double brackets should be screened |     // * body depends on the function name, double brackets should be screened | ||||||
|     // by using $, e.g. ${ |     // by using $, e.g. ${ | ||||||
|     QRegularExpression regex( |     QRegularExpression regex( | ||||||
|         QString("\\$%1\\<(?<args>.*?)\\>\\{\\{(?<body>.*?)\\}\\}") |         QString("\\$%1\\<(?<args>.*?)\\>\\{\\{(?<body>.*?)\\}\\}").arg(_function)); | ||||||
|             .arg(_function)); |  | ||||||
|     regex.setPatternOptions(QRegularExpression::DotMatchesEverythingOption); |     regex.setPatternOptions(QRegularExpression::DotMatchesEverythingOption); | ||||||
|  |  | ||||||
|     QList<AWPatternFunctions::AWFunction> foundFunctions; |     QList<AWPatternFunctions::AWFunction> foundFunctions; | ||||||
| @ -116,9 +110,8 @@ AWPatternFunctions::findFunctionCalls(const QString &_function, | |||||||
|             // replace '$,' to 0x1d |             // replace '$,' to 0x1d | ||||||
|             argsString.replace("$,", QString(0x1d)); |             argsString.replace("$,", QString(0x1d)); | ||||||
|             QStringList args = argsString.split(','); |             QStringList args = argsString.split(','); | ||||||
|             std::for_each(args.begin(), args.end(), [](QString &arg) { |             std::for_each(args.begin(), args.end(), | ||||||
|                 arg.replace(QString(0x1d), ","); |                           [](QString &arg) { arg.replace(QString(0x1d), ","); }); | ||||||
|             }); |  | ||||||
|             metadata.args = args; |             metadata.args = args; | ||||||
|         } |         } | ||||||
|         // other variables |         // other variables | ||||||
| @ -134,20 +127,17 @@ AWPatternFunctions::findFunctionCalls(const QString &_function, | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| QString AWPatternFunctions::insertAllKeys(QString _code, | QString AWPatternFunctions::insertAllKeys(QString _code, const QStringList &_keys) | ||||||
|                                           const QStringList &_keys) |  | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Looking for keys in code" << _code << "using list" |     qCDebug(LOG_AW) << "Looking for keys in code" << _code << "using list" << _keys; | ||||||
|                     << _keys; |  | ||||||
|  |  | ||||||
|     QList<AWPatternFunctions::AWFunction> found |     QList<AWPatternFunctions::AWFunction> found | ||||||
|         = AWPatternFunctions::findFunctionCalls("aw_all", _code); |         = AWPatternFunctions::findFunctionCalls("aw_all", _code); | ||||||
|     for (auto &function : found) { |     for (auto &function : found) { | ||||||
|         QString separator = function.args.isEmpty() ? "," : function.args.at(0); |         QString separator = function.args.isEmpty() ? "," : function.args.at(0); | ||||||
|         QStringList required = _keys.filter(QRegExp(function.body)); |         QStringList required = _keys.filter(QRegExp(function.body)); | ||||||
|         std::for_each(required.begin(), required.end(), [](QString &value) { |         std::for_each(required.begin(), required.end(), | ||||||
|             value = QString("%1: $%1").arg(value); |                       [](QString &value) { value = QString("%1: $%1").arg(value); }); | ||||||
|         }); |  | ||||||
|  |  | ||||||
|         _code.replace(function.what, required.join(separator)); |         _code.replace(function.what, required.join(separator)); | ||||||
|     } |     } | ||||||
| @ -156,11 +146,9 @@ QString AWPatternFunctions::insertAllKeys(QString _code, | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| QString AWPatternFunctions::insertKeyCount(QString _code, | QString AWPatternFunctions::insertKeyCount(QString _code, const QStringList &_keys) | ||||||
|                                            const QStringList &_keys) |  | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Looking for count in code" << _code << "using list" |     qCDebug(LOG_AW) << "Looking for count in code" << _code << "using list" << _keys; | ||||||
|                     << _keys; |  | ||||||
|  |  | ||||||
|     QList<AWPatternFunctions::AWFunction> found |     QList<AWPatternFunctions::AWFunction> found | ||||||
|         = AWPatternFunctions::findFunctionCalls("aw_count", _code); |         = AWPatternFunctions::findFunctionCalls("aw_count", _code); | ||||||
| @ -174,11 +162,9 @@ QString AWPatternFunctions::insertKeyCount(QString _code, | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| QString AWPatternFunctions::insertKeyNames(QString _code, | QString AWPatternFunctions::insertKeyNames(QString _code, const QStringList &_keys) | ||||||
|                                            const QStringList &_keys) |  | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Looking for key names in code" << _code << "using list" |     qCDebug(LOG_AW) << "Looking for key names in code" << _code << "using list" << _keys; | ||||||
|                     << _keys; |  | ||||||
|  |  | ||||||
|     QList<AWPatternFunctions::AWFunction> found |     QList<AWPatternFunctions::AWFunction> found | ||||||
|         = AWPatternFunctions::findFunctionCalls("aw_names", _code); |         = AWPatternFunctions::findFunctionCalls("aw_names", _code); | ||||||
| @ -195,17 +181,15 @@ QString AWPatternFunctions::insertKeyNames(QString _code, | |||||||
|  |  | ||||||
| QString AWPatternFunctions::insertKeys(QString _code, const QStringList &_keys) | QString AWPatternFunctions::insertKeys(QString _code, const QStringList &_keys) | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Looking for keys in code" << _code << "using list" |     qCDebug(LOG_AW) << "Looking for keys in code" << _code << "using list" << _keys; | ||||||
|                     << _keys; |  | ||||||
|  |  | ||||||
|     QList<AWPatternFunctions::AWFunction> found |     QList<AWPatternFunctions::AWFunction> found | ||||||
|         = AWPatternFunctions::findFunctionCalls("aw_keys", _code); |         = AWPatternFunctions::findFunctionCalls("aw_keys", _code); | ||||||
|     for (auto &function : found) { |     for (auto &function : found) { | ||||||
|         QString separator = function.args.isEmpty() ? "," : function.args.at(0); |         QString separator = function.args.isEmpty() ? "," : function.args.at(0); | ||||||
|         QStringList required = _keys.filter(QRegExp(function.body)); |         QStringList required = _keys.filter(QRegExp(function.body)); | ||||||
|         std::for_each(required.begin(), required.end(), [](QString &value) { |         std::for_each(required.begin(), required.end(), | ||||||
|             value = QString("$%1").arg(value); |                       [](QString &value) { value = QString("$%1").arg(value); }); | ||||||
|         }); |  | ||||||
|  |  | ||||||
|         _code.replace(function.what, required.join(separator)); |         _code.replace(function.what, required.join(separator)); | ||||||
|     } |     } | ||||||
| @ -229,12 +213,10 @@ QString AWPatternFunctions::insertMacros(QString _code) | |||||||
|         QString name = macro.args.takeFirst(); |         QString name = macro.args.takeFirst(); | ||||||
|         // find macro usage |         // find macro usage | ||||||
|         QList<AWPatternFunctions::AWFunction> macroUsage |         QList<AWPatternFunctions::AWFunction> macroUsage | ||||||
|             = AWPatternFunctions::findFunctionCalls( |             = AWPatternFunctions::findFunctionCalls(QString("aw_macro_%1").arg(name), _code); | ||||||
|                 QString("aw_macro_%1").arg(name), _code); |  | ||||||
|         for (auto &function : macroUsage) { |         for (auto &function : macroUsage) { | ||||||
|             if (function.args.count() != macro.args.count()) { |             if (function.args.count() != macro.args.count()) { | ||||||
|                 qCWarning(LOG_AW) |                 qCWarning(LOG_AW) << "Invalid args count found for call" << function.what | ||||||
|                     << "Invalid args count found for call" << function.what |  | ||||||
|                                   << "with macro" << macro.what; |                                   << "with macro" << macro.what; | ||||||
|                 continue; |                 continue; | ||||||
|             } |             } | ||||||
| @ -243,8 +225,7 @@ QString AWPatternFunctions::insertMacros(QString _code) | |||||||
|             std::for_each(macro.args.cbegin(), macro.args.cend(), |             std::for_each(macro.args.cbegin(), macro.args.cend(), | ||||||
|                           [&result, macro, function](const QString &arg) { |                           [&result, macro, function](const QString &arg) { | ||||||
|                               int index = macro.args.indexOf(arg); |                               int index = macro.args.indexOf(arg); | ||||||
|                               result.replace(QString("$%1").arg(arg), |                               result.replace(QString("$%1").arg(arg), function.args.at(index)); | ||||||
|                                              function.args.at(index)); |  | ||||||
|                           }); |                           }); | ||||||
|             // do replace |             // do replace | ||||||
|             _code.replace(function.what, result); |             _code.replace(function.what, result); | ||||||
| @ -258,20 +239,17 @@ QString AWPatternFunctions::insertMacros(QString _code) | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| QStringList AWPatternFunctions::findKeys(const QString &_code, | QStringList AWPatternFunctions::findKeys(const QString &_code, const QStringList &_keys, | ||||||
|                                          const QStringList &_keys, |  | ||||||
|                                          const bool _isBars) |                                          const bool _isBars) | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Looking for keys in code" << _code << "using list" |     qCDebug(LOG_AW) << "Looking for keys in code" << _code << "using list" << _keys; | ||||||
|                     << _keys; |  | ||||||
|  |  | ||||||
|     QStringList selectedKeys; |     QStringList selectedKeys; | ||||||
|     QString replacedCode = _code; |     QString replacedCode = _code; | ||||||
|     for (auto &key : _keys) |     for (auto &key : _keys) | ||||||
|         if ((key.startsWith("bar") == _isBars) |         if ((key.startsWith("bar") == _isBars) | ||||||
|             && (replacedCode.contains(QString("$%1").arg(key)))) { |             && (replacedCode.contains(QString("$%1").arg(key)))) { | ||||||
|             qCInfo(LOG_AW) << "Found key" << key << "with bar enabled" |             qCInfo(LOG_AW) << "Found key" << key << "with bar enabled" << _isBars; | ||||||
|                            << _isBars; |  | ||||||
|             selectedKeys.append(key); |             selectedKeys.append(key); | ||||||
|             replacedCode.replace(QString("$%1").arg(key), ""); |             replacedCode.replace(QString("$%1").arg(key), ""); | ||||||
|         } |         } | ||||||
| @ -289,8 +267,7 @@ QStringList AWPatternFunctions::findLambdas(const QString &_code) | |||||||
|     QStringList selectedKeys; |     QStringList selectedKeys; | ||||||
|     // match the following construction ${{some code here}} |     // match the following construction ${{some code here}} | ||||||
|     QRegularExpression lambdaRegexp("\\$\\{\\{(?<body>.*?)\\}\\}"); |     QRegularExpression lambdaRegexp("\\$\\{\\{(?<body>.*?)\\}\\}"); | ||||||
|     lambdaRegexp.setPatternOptions( |     lambdaRegexp.setPatternOptions(QRegularExpression::DotMatchesEverythingOption); | ||||||
|         QRegularExpression::DotMatchesEverythingOption); |  | ||||||
|  |  | ||||||
|     QRegularExpressionMatchIterator it = lambdaRegexp.globalMatch(_code); |     QRegularExpressionMatchIterator it = lambdaRegexp.globalMatch(_code); | ||||||
|     while (it.hasNext()) { |     while (it.hasNext()) { | ||||||
|  | |||||||
| @ -34,20 +34,17 @@ typedef struct { | |||||||
| } AWFunction; | } AWFunction; | ||||||
|  |  | ||||||
| // insert methods | // insert methods | ||||||
| QString expandLambdas(QString _code, AWKeysAggregator *_aggregator, | QString expandLambdas(QString _code, AWKeysAggregator *_aggregator, const QVariantHash &_metadata, | ||||||
|                       const QVariantHash &_metadata, |  | ||||||
|                       const QStringList &_usedKeys); |                       const QStringList &_usedKeys); | ||||||
| QString expandTemplates(QString _code); | QString expandTemplates(QString _code); | ||||||
| QList<AWFunction> findFunctionCalls(const QString &_function, | QList<AWFunction> findFunctionCalls(const QString &_function, const QString &_code); | ||||||
|                                     const QString &_code); |  | ||||||
| QString insertAllKeys(QString _code, const QStringList &_keys); | QString insertAllKeys(QString _code, const QStringList &_keys); | ||||||
| QString insertKeyCount(QString _code, const QStringList &_keys); | QString insertKeyCount(QString _code, const QStringList &_keys); | ||||||
| QString insertKeyNames(QString _code, const QStringList &_keys); | QString insertKeyNames(QString _code, const QStringList &_keys); | ||||||
| QString insertKeys(QString _code, const QStringList &_keys); | QString insertKeys(QString _code, const QStringList &_keys); | ||||||
| QString insertMacros(QString _code); | QString insertMacros(QString _code); | ||||||
| // find methods | // find methods | ||||||
| QStringList findKeys(const QString &_code, const QStringList &_keys, | QStringList findKeys(const QString &_code, const QStringList &_keys, const bool _isBars); | ||||||
|                      const bool _isBars); |  | ||||||
| QStringList findLambdas(const QString &_code); | QStringList findLambdas(const QString &_code); | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | |||||||
| @ -27,15 +27,13 @@ | |||||||
| #include "awdebug.h" | #include "awdebug.h" | ||||||
|  |  | ||||||
|  |  | ||||||
| AWTelemetryHandler::AWTelemetryHandler(QObject *_parent, | AWTelemetryHandler::AWTelemetryHandler(QObject *_parent, const QString &_clientId) | ||||||
|                                        const QString &_clientId) |  | ||||||
|     : QObject(_parent) |     : QObject(_parent) | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; |     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; | ||||||
|  |  | ||||||
|     m_localFile = QString("%1/awesomewidgets/telemetry.ini") |     m_localFile = QString("%1/awesomewidgets/telemetry.ini") | ||||||
|                       .arg(QStandardPaths::writableLocation( |                       .arg(QStandardPaths::writableLocation(QStandardPaths::GenericDataLocation)); | ||||||
|                           QStandardPaths::GenericDataLocation)); |  | ||||||
|  |  | ||||||
|     // override client id if any |     // override client id if any | ||||||
|     if (!_clientId.isEmpty()) |     if (!_clientId.isEmpty()) | ||||||
| @ -73,11 +71,10 @@ QString AWTelemetryHandler::getLast(const QString &_group) const | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| void AWTelemetryHandler::init(const int _count, const bool _enableRemote, | void AWTelemetryHandler::init(const int _count, const bool _enableRemote, const QString &_clientId) | ||||||
|                               const QString &_clientId) |  | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Init telemetry with count" << _count << "enable remote" |     qCDebug(LOG_AW) << "Init telemetry with count" << _count << "enable remote" << _enableRemote | ||||||
|                     << _enableRemote << "client ID" << _clientId; |                     << "client ID" << _clientId; | ||||||
|  |  | ||||||
|     m_storeCount = _count; |     m_storeCount = _count; | ||||||
|     m_uploadEnabled = _enableRemote; |     m_uploadEnabled = _enableRemote; | ||||||
| @ -87,8 +84,7 @@ void AWTelemetryHandler::init(const int _count, const bool _enableRemote, | |||||||
|  |  | ||||||
| bool AWTelemetryHandler::put(const QString &_group, const QString &_value) const | bool AWTelemetryHandler::put(const QString &_group, const QString &_value) const | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Store data with group" << _group << "and value" |     qCDebug(LOG_AW) << "Store data with group" << _group << "and value" << _value; | ||||||
|                     << _value; |  | ||||||
|  |  | ||||||
|     QSettings settings(m_localFile, QSettings::IniFormat); |     QSettings settings(m_localFile, QSettings::IniFormat); | ||||||
|     settings.beginGroup(_group); |     settings.beginGroup(_group); | ||||||
| @ -99,8 +95,7 @@ bool AWTelemetryHandler::put(const QString &_group, const QString &_value) const | |||||||
|         saved.append(settings.value(key).toString()); |         saved.append(settings.value(key).toString()); | ||||||
|     // check if this value is already saved |     // check if this value is already saved | ||||||
|     if (saved.contains(_value)) { |     if (saved.contains(_value)) { | ||||||
|         qCInfo(LOG_AW) << "Configuration" << _value << "for group" << _group |         qCInfo(LOG_AW) << "Configuration" << _value << "for group" << _group << "is already saved"; | ||||||
|                        << "is already saved"; |  | ||||||
|         return false; |         return false; | ||||||
|     } |     } | ||||||
|     saved.append(_value); |     saved.append(_value); | ||||||
| @ -123,11 +118,9 @@ bool AWTelemetryHandler::put(const QString &_group, const QString &_value) const | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| void AWTelemetryHandler::uploadTelemetry(const QString &_group, | void AWTelemetryHandler::uploadTelemetry(const QString &_group, const QString &_value) | ||||||
|                                          const QString &_value) |  | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Upload data with group" << _group << "and value" |     qCDebug(LOG_AW) << "Upload data with group" << _group << "and value" << _value; | ||||||
|                     << _value; |  | ||||||
|     if (!m_uploadEnabled) { |     if (!m_uploadEnabled) { | ||||||
|         qCInfo(LOG_AW) << "Upload disabled by configuration"; |         qCInfo(LOG_AW) << "Upload disabled by configuration"; | ||||||
|         return; |         return; | ||||||
| @ -148,10 +141,8 @@ void AWTelemetryHandler::uploadTelemetry(const QString &_group, | |||||||
|     payload["metadata"] = _value; |     payload["metadata"] = _value; | ||||||
|     payload["type"] = _group; |     payload["type"] = _group; | ||||||
|     // convert to QByteArray to send request |     // convert to QByteArray to send request | ||||||
|     QByteArray data |     QByteArray data = QJsonDocument::fromVariant(payload).toJson(QJsonDocument::Compact); | ||||||
|         = QJsonDocument::fromVariant(payload).toJson(QJsonDocument::Compact); |     qCInfo(LOG_AW) << "Send request with body" << data.data() << "and size" << data.size(); | ||||||
|     qCInfo(LOG_AW) << "Send request with body" << data.data() << "and size" |  | ||||||
|                    << data.size(); |  | ||||||
|  |  | ||||||
|     manager->post(request, data); |     manager->post(request, data); | ||||||
| } | } | ||||||
| @ -160,8 +151,8 @@ void AWTelemetryHandler::uploadTelemetry(const QString &_group, | |||||||
| void AWTelemetryHandler::telemetryReplyRecieved(QNetworkReply *_reply) | void AWTelemetryHandler::telemetryReplyRecieved(QNetworkReply *_reply) | ||||||
| { | { | ||||||
|     if (_reply->error() != QNetworkReply::NoError) { |     if (_reply->error() != QNetworkReply::NoError) { | ||||||
|         qCWarning(LOG_AW) << "An error occurs" << _reply->error() |         qCWarning(LOG_AW) << "An error occurs" << _reply->error() << "with message" | ||||||
|                           << "with message" << _reply->errorString(); |                           << _reply->errorString(); | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  | |||||||
| @ -31,16 +31,13 @@ class AWTelemetryHandler : public QObject | |||||||
| public: | public: | ||||||
|     const char *REMOTE_TELEMETRY_URL = "https://arcanis.me/telemetry"; |     const char *REMOTE_TELEMETRY_URL = "https://arcanis.me/telemetry"; | ||||||
|  |  | ||||||
|     explicit AWTelemetryHandler(QObject *_parent = nullptr, |     explicit AWTelemetryHandler(QObject *_parent = nullptr, const QString &_clientId = ""); | ||||||
|                                 const QString &_clientId = ""); |  | ||||||
|     virtual ~AWTelemetryHandler(); |     virtual ~AWTelemetryHandler(); | ||||||
|     Q_INVOKABLE QStringList get(const QString &_group) const; |     Q_INVOKABLE QStringList get(const QString &_group) const; | ||||||
|     Q_INVOKABLE QString getLast(const QString &_group) const; |     Q_INVOKABLE QString getLast(const QString &_group) const; | ||||||
|     Q_INVOKABLE void init(const int _count, const bool _enableRemote, |     Q_INVOKABLE void init(const int _count, const bool _enableRemote, const QString &_clientId); | ||||||
|                           const QString &_clientId); |  | ||||||
|     Q_INVOKABLE bool put(const QString &_group, const QString &_value) const; |     Q_INVOKABLE bool put(const QString &_group, const QString &_value) const; | ||||||
|     Q_INVOKABLE void uploadTelemetry(const QString &_group, |     Q_INVOKABLE void uploadTelemetry(const QString &_group, const QString &_value); | ||||||
|                                      const QString &_value); |  | ||||||
|  |  | ||||||
| signals: | signals: | ||||||
|     void replyReceived(const QString &_message); |     void replyReceived(const QString &_message); | ||||||
|  | |||||||
| @ -34,9 +34,9 @@ AWUpdateHelper::AWUpdateHelper(QObject *_parent) | |||||||
|     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; |     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; | ||||||
|  |  | ||||||
|     m_foundVersion = QVersionNumber::fromString(VERSION); |     m_foundVersion = QVersionNumber::fromString(VERSION); | ||||||
|     m_genericConfig = QString("%1/awesomewidgets/general.ini") |     m_genericConfig | ||||||
|                           .arg(QStandardPaths::writableLocation( |         = QString("%1/awesomewidgets/general.ini") | ||||||
|                               QStandardPaths::GenericDataLocation)); |               .arg(QStandardPaths::writableLocation(QStandardPaths::GenericDataLocation)); | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -53,8 +53,7 @@ void AWUpdateHelper::checkUpdates(const bool _showAnyway) | |||||||
|     // showAnyway options requires to show message if no updates found on direct |     // showAnyway options requires to show message if no updates found on direct | ||||||
|     // request. In case of automatic check no message will be shown |     // request. In case of automatic check no message will be shown | ||||||
|     QNetworkAccessManager *manager = new QNetworkAccessManager(nullptr); |     QNetworkAccessManager *manager = new QNetworkAccessManager(nullptr); | ||||||
|     connect(manager, &QNetworkAccessManager::finished, |     connect(manager, &QNetworkAccessManager::finished, [_showAnyway, this](QNetworkReply *reply) { | ||||||
|             [_showAnyway, this](QNetworkReply *reply) { |  | ||||||
|         return versionReplyRecieved(reply, _showAnyway); |         return versionReplyRecieved(reply, _showAnyway); | ||||||
|     }); |     }); | ||||||
|  |  | ||||||
| @ -65,17 +64,16 @@ void AWUpdateHelper::checkUpdates(const bool _showAnyway) | |||||||
| bool AWUpdateHelper::checkVersion() | bool AWUpdateHelper::checkVersion() | ||||||
| { | { | ||||||
|     QSettings settings(m_genericConfig, QSettings::IniFormat); |     QSettings settings(m_genericConfig, QSettings::IniFormat); | ||||||
|     QVersionNumber version = QVersionNumber::fromString( |     QVersionNumber version | ||||||
|         settings.value("Version", QString(VERSION)).toString()); |         = QVersionNumber::fromString(settings.value("Version", QString(VERSION)).toString()); | ||||||
|     // update version |     // update version | ||||||
|     settings.setValue("Version", QString(VERSION)); |     settings.setValue("Version", QString(VERSION)); | ||||||
|     settings.sync(); |     settings.sync(); | ||||||
|     qCInfo(LOG_AW) << "Found version" << version << "actual one is" |     qCInfo(LOG_AW) << "Found version" << version << "actual one is" << m_foundVersion; | ||||||
|                    << m_foundVersion; |  | ||||||
|  |  | ||||||
|     if ((version != m_foundVersion) && (!QString(CHANGELOG).isEmpty())) { |     if ((version != m_foundVersion) && (!QString(CHANGELOG).isEmpty())) { | ||||||
|         genMessageBox(i18n("Changelog of %1", VERSION), |         genMessageBox(i18n("Changelog of %1", VERSION), QString(CHANGELOG).replace('@', '\n'), | ||||||
|                       QString(CHANGELOG).replace('@', '\n'), QMessageBox::Ok) |                       QMessageBox::Ok) | ||||||
|             ->open(); |             ->open(); | ||||||
|         return true; |         return true; | ||||||
|     } else if (version != m_foundVersion) { |     } else if (version != m_foundVersion) { | ||||||
| @ -93,12 +91,10 @@ void AWUpdateHelper::showInfo(const QVersionNumber &_version) | |||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Version" << _version; |     qCDebug(LOG_AW) << "Version" << _version; | ||||||
|  |  | ||||||
|     QString text |     QString text = i18n("You are using the actual version %1", _version.toString()); | ||||||
|         = 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)); | ||||||
|     return genMessageBox(i18n("No new version found"), text, QMessageBox::Ok) |     return genMessageBox(i18n("No new version found"), text, QMessageBox::Ok)->open(); | ||||||
|         ->open(); |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -108,28 +104,23 @@ void AWUpdateHelper::showUpdates(const QVersionNumber &_version) | |||||||
|  |  | ||||||
|     QString text; |     QString text; | ||||||
|     text += i18n("Current version : %1", VERSION); |     text += i18n("Current version : %1", VERSION); | ||||||
|     text += QString(COMMIT_SHA).isEmpty() |     text += QString(COMMIT_SHA).isEmpty() ? "\n" : QString(" (%1)\n").arg(QString(COMMIT_SHA)); | ||||||
|                 ? "\n" |  | ||||||
|                 : QString(" (%1)\n").arg(QString(COMMIT_SHA)); |  | ||||||
|     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"); | ||||||
|  |  | ||||||
|     genMessageBox(i18n("There are updates"), text, |     genMessageBox(i18n("There are updates"), text, QMessageBox::Ok | QMessageBox::Cancel) | ||||||
|                   QMessageBox::Ok | QMessageBox::Cancel) |  | ||||||
|         ->open(this, SLOT(userReplyOnUpdates(QAbstractButton *))); |         ->open(this, SLOT(userReplyOnUpdates(QAbstractButton *))); | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| void AWUpdateHelper::userReplyOnUpdates(QAbstractButton *_button) | void AWUpdateHelper::userReplyOnUpdates(QAbstractButton *_button) | ||||||
| { | { | ||||||
|     QMessageBox::ButtonRole ret |     QMessageBox::ButtonRole ret = static_cast<QMessageBox *>(sender())->buttonRole(_button); | ||||||
|         = static_cast<QMessageBox *>(sender())->buttonRole(_button); |  | ||||||
|     qCInfo(LOG_AW) << "User select" << ret; |     qCInfo(LOG_AW) << "User select" << ret; | ||||||
|  |  | ||||||
|     switch (ret) { |     switch (ret) { | ||||||
|     case QMessageBox::AcceptRole: |     case QMessageBox::AcceptRole: | ||||||
|         QDesktopServices::openUrl(QString(RELEASES) |         QDesktopServices::openUrl(QString(RELEASES) + m_foundVersion.toString()); | ||||||
|                                   + m_foundVersion.toString()); |  | ||||||
|         break; |         break; | ||||||
|     case QMessageBox::RejectRole: |     case QMessageBox::RejectRole: | ||||||
|     default: |     default: | ||||||
| @ -138,13 +129,12 @@ void AWUpdateHelper::userReplyOnUpdates(QAbstractButton *_button) | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| void AWUpdateHelper::versionReplyRecieved(QNetworkReply *_reply, | void AWUpdateHelper::versionReplyRecieved(QNetworkReply *_reply, const bool _showAnyway) | ||||||
|                                           const bool _showAnyway) |  | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Show message anyway" << _showAnyway; |     qCDebug(LOG_AW) << "Show message anyway" << _showAnyway; | ||||||
|     if (_reply->error() != QNetworkReply::NoError) { |     if (_reply->error() != QNetworkReply::NoError) { | ||||||
|         qCWarning(LOG_AW) << "An error occurs" << _reply->error() |         qCWarning(LOG_AW) << "An error occurs" << _reply->error() << "with message" | ||||||
|                           << "with message" << _reply->errorString(); |                           << _reply->errorString(); | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @ -172,12 +162,10 @@ void AWUpdateHelper::versionReplyRecieved(QNetworkReply *_reply, | |||||||
|  |  | ||||||
|  |  | ||||||
| // 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 | ||||||
| QMessageBox * | QMessageBox *AWUpdateHelper::genMessageBox(const QString &_title, const QString &_body, | ||||||
| AWUpdateHelper::genMessageBox(const QString &_title, const QString &_body, |  | ||||||
|                                            const QMessageBox::StandardButtons _buttons) |                                            const QMessageBox::StandardButtons _buttons) | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Construct message box with title" << _title |     qCDebug(LOG_AW) << "Construct message box with title" << _title << "and body" << _body; | ||||||
|                     << "and body" << _body; |  | ||||||
|  |  | ||||||
|     QMessageBox *msgBox = new QMessageBox(nullptr); |     QMessageBox *msgBox = new QMessageBox(nullptr); | ||||||
|     msgBox->setAttribute(Qt::WA_DeleteOnClose); |     msgBox->setAttribute(Qt::WA_DeleteOnClose); | ||||||
|  | |||||||
| @ -57,8 +57,7 @@ void AbstractExtItem::bumpApi(const int _newVer) | |||||||
|  |  | ||||||
|     // update for current API |     // update for current API | ||||||
|     if ((apiVersion() > 0) && (apiVersion() < _newVer)) { |     if ((apiVersion() > 0) && (apiVersion() < _newVer)) { | ||||||
|         qCWarning(LOG_LIB) << "Bump API version from" << apiVersion() << "to" |         qCWarning(LOG_LIB) << "Bump API version from" << apiVersion() << "to" << _newVer; | ||||||
|                            << _newVer; |  | ||||||
|         setApiVersion(_newVer); |         setApiVersion(_newVer); | ||||||
|         writeConfiguration(); |         writeConfiguration(); | ||||||
|     } |     } | ||||||
| @ -104,8 +103,7 @@ QString AbstractExtItem::writtableConfig() const | |||||||
|     QString dir = QFileInfo(path).fileName(); |     QString dir = QFileInfo(path).fileName(); | ||||||
|  |  | ||||||
|     return QString("%1/awesomewidgets/%2/%3") |     return QString("%1/awesomewidgets/%2/%3") | ||||||
|         .arg(QStandardPaths::writableLocation( |         .arg(QStandardPaths::writableLocation(QStandardPaths::GenericDataLocation)) | ||||||
|             QStandardPaths::GenericDataLocation)) |  | ||||||
|         .arg(dir) |         .arg(dir) | ||||||
|         .arg(name); |         .arg(name); | ||||||
| } | } | ||||||
| @ -202,8 +200,7 @@ void AbstractExtItem::setCron(const QString &_cron) | |||||||
|     qCDebug(LOG_LIB) << "Cron string" << _cron; |     qCDebug(LOG_LIB) << "Cron string" << _cron; | ||||||
|     // deinit module first |     // deinit module first | ||||||
|     if (m_scheduler) { |     if (m_scheduler) { | ||||||
|         disconnect(m_scheduler, SIGNAL(activated()), this, |         disconnect(m_scheduler, SIGNAL(activated()), this, SIGNAL(requestDataUpdate())); | ||||||
|                    SIGNAL(requestDataUpdate())); |  | ||||||
|         delete m_scheduler; |         delete m_scheduler; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @ -214,8 +211,7 @@ void AbstractExtItem::setCron(const QString &_cron) | |||||||
|     // init scheduler |     // init scheduler | ||||||
|     m_scheduler = new QCronScheduler(this); |     m_scheduler = new QCronScheduler(this); | ||||||
|     m_scheduler->parse(cron()); |     m_scheduler->parse(cron()); | ||||||
|     connect(m_scheduler, SIGNAL(activated()), this, |     connect(m_scheduler, SIGNAL(activated()), this, SIGNAL(requestDataUpdate())); | ||||||
|             SIGNAL(requestDataUpdate())); |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -276,8 +272,7 @@ void AbstractExtItem::deinitSocket() | |||||||
|     m_socket->close(); |     m_socket->close(); | ||||||
|     m_socket->removeServer(socket()); |     m_socket->removeServer(socket()); | ||||||
|     delete m_socket; |     delete m_socket; | ||||||
|     disconnect(m_socket, SIGNAL(newConnection()), this, |     disconnect(m_socket, SIGNAL(newConnection()), this, SLOT(newConnectionReceived())); | ||||||
|                SLOT(newConnectionReceived())); |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -289,8 +284,7 @@ void AbstractExtItem::initSocket() | |||||||
|     m_socket = new QLocalServer(this); |     m_socket = new QLocalServer(this); | ||||||
|     bool listening = m_socket->listen(socket()); |     bool listening = m_socket->listen(socket()); | ||||||
|     qCInfo(LOG_LIB) << "Server listening on" << socket() << listening; |     qCInfo(LOG_LIB) << "Server listening on" << socket() << listening; | ||||||
|     connect(m_socket, SIGNAL(newConnection()), this, |     connect(m_socket, SIGNAL(newConnection()), this, SLOT(newConnectionReceived())); | ||||||
|             SLOT(newConnectionReceived())); |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | |||||||
| @ -40,12 +40,10 @@ class AbstractExtItem : public QDialog | |||||||
|     Q_PROPERTY(QString uniq READ uniq) |     Q_PROPERTY(QString uniq READ uniq) | ||||||
|  |  | ||||||
| public: | public: | ||||||
|     explicit AbstractExtItem(QWidget *_parent = nullptr, |     explicit AbstractExtItem(QWidget *_parent = nullptr, const QString &_filePath = ""); | ||||||
|                              const QString &_filePath = ""); |  | ||||||
|     virtual ~AbstractExtItem(); |     virtual ~AbstractExtItem(); | ||||||
|     virtual void bumpApi(const int _newVer); |     virtual void bumpApi(const int _newVer); | ||||||
|     virtual AbstractExtItem *copy(const QString &_fileName, const int _number) |     virtual AbstractExtItem *copy(const QString &_fileName, const int _number) = 0; | ||||||
|         = 0; |  | ||||||
|     virtual void copyDefaults(AbstractExtItem *_other) const; |     virtual void copyDefaults(AbstractExtItem *_other) const; | ||||||
|     virtual void startTimer(); |     virtual void startTimer(); | ||||||
|     QString writtableConfig() const; |     QString writtableConfig() const; | ||||||
|  | |||||||
| @ -25,8 +25,7 @@ | |||||||
| #include <QPushButton> | #include <QPushButton> | ||||||
|  |  | ||||||
|  |  | ||||||
| AbstractExtItemAggregator::AbstractExtItemAggregator(QWidget *_parent, | AbstractExtItemAggregator::AbstractExtItemAggregator(QWidget *_parent, const QString &_type) | ||||||
|                                                      const QString &_type) |  | ||||||
|     : QDialog(_parent) |     : QDialog(_parent) | ||||||
|     , ui(new Ui::AbstractExtItemAggregator) |     , ui(new Ui::AbstractExtItemAggregator) | ||||||
|     , m_type(_type) |     , m_type(_type) | ||||||
| @ -34,21 +33,18 @@ AbstractExtItemAggregator::AbstractExtItemAggregator(QWidget *_parent, | |||||||
|     qCDebug(LOG_LIB) << __PRETTY_FUNCTION__; |     qCDebug(LOG_LIB) << __PRETTY_FUNCTION__; | ||||||
|  |  | ||||||
|     // create directory at $HOME |     // create directory at $HOME | ||||||
|     QString localDir = QString("%1/awesomewidgets/%2") |     QString localDir | ||||||
|                            .arg(QStandardPaths::writableLocation( |         = QString("%1/awesomewidgets/%2") | ||||||
|                                QStandardPaths::GenericDataLocation)) |               .arg(QStandardPaths::writableLocation(QStandardPaths::GenericDataLocation)) | ||||||
|               .arg(type()); |               .arg(type()); | ||||||
|     QDir localDirectory; |     QDir localDirectory; | ||||||
|     if (localDirectory.mkpath(localDir)) |     if (localDirectory.mkpath(localDir)) | ||||||
|         qCInfo(LOG_LIB) << "Created directory" << localDir; |         qCInfo(LOG_LIB) << "Created directory" << localDir; | ||||||
|  |  | ||||||
|     ui->setupUi(this); |     ui->setupUi(this); | ||||||
|     copyButton |     copyButton = ui->buttonBox->addButton(i18n("Copy"), QDialogButtonBox::ActionRole); | ||||||
|         = ui->buttonBox->addButton(i18n("Copy"), QDialogButtonBox::ActionRole); |     createButton = ui->buttonBox->addButton(i18n("Create"), QDialogButtonBox::ActionRole); | ||||||
|     createButton = ui->buttonBox->addButton(i18n("Create"), |     deleteButton = ui->buttonBox->addButton(i18n("Remove"), QDialogButtonBox::ActionRole); | ||||||
|                                             QDialogButtonBox::ActionRole); |  | ||||||
|     deleteButton = ui->buttonBox->addButton(i18n("Remove"), |  | ||||||
|                                             QDialogButtonBox::ActionRole); |  | ||||||
|  |  | ||||||
|     connect(ui->buttonBox, SIGNAL(clicked(QAbstractButton *)), this, |     connect(ui->buttonBox, SIGNAL(clicked(QAbstractButton *)), this, | ||||||
|             SLOT(editItemButtonPressed(QAbstractButton *))); |             SLOT(editItemButtonPressed(QAbstractButton *))); | ||||||
| @ -72,8 +68,7 @@ void AbstractExtItemAggregator::copyItem() | |||||||
|     QString fileName = getName(); |     QString fileName = getName(); | ||||||
|     int number = uniqNumber(); |     int number = uniqNumber(); | ||||||
|     QString dir = QString("%1/awesomewidgets/%2") |     QString dir = QString("%1/awesomewidgets/%2") | ||||||
|                       .arg(QStandardPaths::writableLocation( |                       .arg(QStandardPaths::writableLocation(QStandardPaths::GenericDataLocation)) | ||||||
|                           QStandardPaths::GenericDataLocation)) |  | ||||||
|                       .arg(m_type); |                       .arg(m_type); | ||||||
|     if ((!source) || (fileName.isEmpty())) { |     if ((!source) || (fileName.isEmpty())) { | ||||||
|         qCWarning(LOG_LIB) << "Nothing to copy"; |         qCWarning(LOG_LIB) << "Nothing to copy"; | ||||||
| @ -122,9 +117,8 @@ void AbstractExtItemAggregator::editItem() | |||||||
| QString AbstractExtItemAggregator::getName() | QString AbstractExtItemAggregator::getName() | ||||||
| { | { | ||||||
|     bool ok; |     bool ok; | ||||||
|     QString name |     QString name = QInputDialog::getText(this, i18n("Enter file name"), i18n("File name"), | ||||||
|         = QInputDialog::getText(this, i18n("Enter file name"), |                                          QLineEdit::Normal, "", &ok); | ||||||
|                                 i18n("File name"), QLineEdit::Normal, "", &ok); |  | ||||||
|     if ((!ok) || (name.isEmpty())) |     if ((!ok) || (name.isEmpty())) | ||||||
|         return ""; |         return ""; | ||||||
|     if (!name.endsWith(".desktop")) |     if (!name.endsWith(".desktop")) | ||||||
| @ -149,8 +143,7 @@ AbstractExtItem *AbstractExtItemAggregator::itemFromWidget() | |||||||
|         break; |         break; | ||||||
|     } |     } | ||||||
|     if (!found) |     if (!found) | ||||||
|         qCWarning(LOG_LIB) << "Could not find item by name" |         qCWarning(LOG_LIB) << "Could not find item by name" << widgetItem->text(); | ||||||
|                            << widgetItem->text(); |  | ||||||
|  |  | ||||||
|     return found; |     return found; | ||||||
| } | } | ||||||
| @ -193,8 +186,7 @@ QVariant AbstractExtItemAggregator::configArgs() const | |||||||
|  |  | ||||||
| QStringList AbstractExtItemAggregator::directories() const | QStringList AbstractExtItemAggregator::directories() const | ||||||
| { | { | ||||||
|     auto dirs |     auto dirs = QStandardPaths::locateAll(QStandardPaths::GenericDataLocation, | ||||||
|         = QStandardPaths::locateAll(QStandardPaths::GenericDataLocation, |  | ||||||
|                                           QString("awesomewidgets/%1").arg(type()), |                                           QString("awesomewidgets/%1").arg(type()), | ||||||
|                                           QStandardPaths::LocateDirectory); |                                           QStandardPaths::LocateDirectory); | ||||||
|  |  | ||||||
|  | |||||||
| @ -47,9 +47,9 @@ public: | |||||||
|     { |     { | ||||||
|         QString fileName = getName(); |         QString fileName = getName(); | ||||||
|         int number = uniqNumber(); |         int number = uniqNumber(); | ||||||
|         QString dir = QString("%1/awesomewidgets/%2") |         QString dir | ||||||
|                           .arg(QStandardPaths::writableLocation( |             = QString("%1/awesomewidgets/%2") | ||||||
|                               QStandardPaths::GenericDataLocation)) |                   .arg(QStandardPaths::writableLocation(QStandardPaths::GenericDataLocation)) | ||||||
|                   .arg(m_type); |                   .arg(m_type); | ||||||
|         if (fileName.isEmpty()) { |         if (fileName.isEmpty()) { | ||||||
|             qCWarning(LOG_LIB) << "Nothing to create"; |             qCWarning(LOG_LIB) << "Nothing to create"; | ||||||
|  | |||||||
							
								
								
									
										45
									
								
								sources/awesomewidgets/abstractquotesprovider.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										45
									
								
								sources/awesomewidgets/abstractquotesprovider.h
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,45 @@ | |||||||
|  | /*************************************************************************** | ||||||
|  |  *   This file is part of awesome-widgets                                  * | ||||||
|  |  *                                                                         * | ||||||
|  |  *   awesome-widgets is free software: you can redistribute it and/or      * | ||||||
|  |  *   modify it under the terms of the GNU General Public License as        * | ||||||
|  |  *   published by the Free Software Foundation, either version 3 of the    * | ||||||
|  |  *   License, or (at your option) any later version.                       * | ||||||
|  |  *                                                                         * | ||||||
|  |  *   awesome-widgets is distributed in the hope that it will be useful,    * | ||||||
|  |  *   but WITHOUT ANY WARRANTY; without even the implied warranty of        * | ||||||
|  |  *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         * | ||||||
|  |  *   GNU General Public License for more details.                          * | ||||||
|  |  *                                                                         * | ||||||
|  |  *   You should have received a copy of the GNU General Public License     * | ||||||
|  |  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||||
|  |  ***************************************************************************/ | ||||||
|  |  | ||||||
|  | #ifndef ABSTRACTQUOTESPROVIDER_H | ||||||
|  | #define ABSTRACTQUOTESPROVIDER_H | ||||||
|  |  | ||||||
|  | #include <QObject> | ||||||
|  | #include <QUrl> | ||||||
|  |  | ||||||
|  | #include "abstractextitem.h" | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class AbstractQuotesProvider : public QObject | ||||||
|  | { | ||||||
|  |     Q_OBJECT | ||||||
|  |  | ||||||
|  | public: | ||||||
|  |     explicit AbstractQuotesProvider(QObject *_parent) | ||||||
|  |         : QObject(_parent){}; | ||||||
|  |     virtual ~AbstractQuotesProvider(){}; | ||||||
|  |     virtual void initUrl(const QString &_asset) = 0; | ||||||
|  |     virtual QVariantHash parse(const QByteArray &_source, const QVariantHash &_oldValues) const = 0; | ||||||
|  |     QString tag(const QString &_type) const | ||||||
|  |     { | ||||||
|  |         return static_cast<AbstractExtItem *>(parent())->tag(_type); | ||||||
|  |     }; | ||||||
|  |     virtual QUrl url() const = 0; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | #endif /* ABSTRACTQUOTESPROVIDER_H */ | ||||||
| @ -21,26 +21,24 @@ | |||||||
| #include <QObject> | #include <QObject> | ||||||
| #include <QUrl> | #include <QUrl> | ||||||
|  |  | ||||||
|  | #include "abstractextitem.h" | ||||||
|  |  | ||||||
|  |  | ||||||
| class AbstractWeatherProvider : public QObject | class AbstractWeatherProvider : public QObject | ||||||
| { | { | ||||||
|     Q_OBJECT |     Q_OBJECT | ||||||
|     Q_PROPERTY(int number READ number) |  | ||||||
|  |  | ||||||
| public: | public: | ||||||
|     explicit AbstractWeatherProvider(QObject *_parent, const int _number) |     explicit AbstractWeatherProvider(QObject *_parent) | ||||||
|         : QObject(_parent) |         : QObject(_parent){}; | ||||||
|         , m_number(_number){}; |  | ||||||
|     virtual ~AbstractWeatherProvider(){}; |     virtual ~AbstractWeatherProvider(){}; | ||||||
|     virtual void initUrl(const QString &_city, const QString &_country, |     virtual void initUrl(const QString &_city, const QString &_country, const int _ts) = 0; | ||||||
|                          const int _ts) |  | ||||||
|         = 0; |  | ||||||
|     virtual QVariantHash parse(const QVariantMap &_json) const = 0; |     virtual QVariantHash parse(const QVariantMap &_json) const = 0; | ||||||
|  |     QString tag(const QString &_type) const | ||||||
|  |     { | ||||||
|  |         return static_cast<AbstractExtItem *>(parent())->tag(_type); | ||||||
|  |     }; | ||||||
|     virtual QUrl url() const = 0; |     virtual QUrl url() const = 0; | ||||||
|     int number() const { return m_number; }; |  | ||||||
|  |  | ||||||
| private: |  | ||||||
|     int m_number; |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | |||||||
| @ -22,8 +22,7 @@ | |||||||
| #include "awdebug.h" | #include "awdebug.h" | ||||||
|  |  | ||||||
|  |  | ||||||
| AWAbstractFormatter::AWAbstractFormatter(QWidget *_parent, | AWAbstractFormatter::AWAbstractFormatter(QWidget *_parent, const QString &_filePath) | ||||||
|                                          const QString &_filePath) |  | ||||||
|     : AbstractExtItem(_parent, _filePath) |     : AbstractExtItem(_parent, _filePath) | ||||||
| { | { | ||||||
|     qCDebug(LOG_LIB) << __PRETTY_FUNCTION__; |     qCDebug(LOG_LIB) << __PRETTY_FUNCTION__; | ||||||
| @ -108,8 +107,7 @@ void AWAbstractFormatter::setStrType(const QString &_type) | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| void AWAbstractFormatter::setType( | void AWAbstractFormatter::setType(const AWAbstractFormatter::FormatterClass _type) | ||||||
|     const AWAbstractFormatter::FormatterClass _type) |  | ||||||
| { | { | ||||||
|     qCDebug(LOG_LIB) << "Type" << static_cast<int>(_type); |     qCDebug(LOG_LIB) << "Type" << static_cast<int>(_type); | ||||||
|  |  | ||||||
|  | |||||||
| @ -28,18 +28,9 @@ class AWAbstractFormatter : public AbstractExtItem | |||||||
|     Q_PROPERTY(QString strType READ strType WRITE setStrType) |     Q_PROPERTY(QString strType READ strType WRITE setStrType) | ||||||
|  |  | ||||||
| public: | public: | ||||||
|     enum class FormatterClass { |     enum class FormatterClass { DateTime, Float, List, Script, String, NoFormat, Json }; | ||||||
|         DateTime, |  | ||||||
|         Float, |  | ||||||
|         List, |  | ||||||
|         Script, |  | ||||||
|         String, |  | ||||||
|         NoFormat, |  | ||||||
|         Json |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     explicit AWAbstractFormatter(QWidget *_parent = nullptr, |     explicit AWAbstractFormatter(QWidget *_parent = nullptr, const QString &_filePath = ""); | ||||||
|                                  const QString &_filePath = ""); |  | ||||||
|     virtual ~AWAbstractFormatter(); |     virtual ~AWAbstractFormatter(); | ||||||
|     virtual QString convert(const QVariant &_value) const = 0; |     virtual QString convert(const QVariant &_value) const = 0; | ||||||
|     void copyDefaults(AbstractExtItem *_other) const; |     void copyDefaults(AbstractExtItem *_other) const; | ||||||
|  | |||||||
| @ -27,8 +27,7 @@ | |||||||
| #include "awdebug.h" | #include "awdebug.h" | ||||||
|  |  | ||||||
|  |  | ||||||
| AWDateTimeFormatter::AWDateTimeFormatter(QWidget *_parent, | AWDateTimeFormatter::AWDateTimeFormatter(QWidget *_parent, const QString &_filePath) | ||||||
|                                          const QString &_filePath) |  | ||||||
|     : AWAbstractFormatter(_parent, _filePath) |     : AWAbstractFormatter(_parent, _filePath) | ||||||
|     , ui(new Ui::AWDateTimeFormatter) |     , ui(new Ui::AWDateTimeFormatter) | ||||||
| { | { | ||||||
| @ -57,8 +56,7 @@ QString AWDateTimeFormatter::convert(const QVariant &_value) const | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| AWDateTimeFormatter *AWDateTimeFormatter::copy(const QString &_fileName, | AWDateTimeFormatter *AWDateTimeFormatter::copy(const QString &_fileName, const int _number) | ||||||
|                                                const int _number) |  | ||||||
| { | { | ||||||
|     qCDebug(LOG_LIB) << "File" << _fileName << "with number" << _number; |     qCDebug(LOG_LIB) << "File" << _fileName << "with number" << _number; | ||||||
|  |  | ||||||
| @ -110,8 +108,7 @@ void AWDateTimeFormatter::readConfiguration() | |||||||
|  |  | ||||||
|     settings.beginGroup("Desktop Entry"); |     settings.beginGroup("Desktop Entry"); | ||||||
|     setFormat(settings.value("X-AW-Format", format()).toString()); |     setFormat(settings.value("X-AW-Format", format()).toString()); | ||||||
|     setTranslateString( |     setTranslateString(settings.value("X-AW-Translate", translateString()).toBool()); | ||||||
|         settings.value("X-AW-Translate", translateString()).toBool()); |  | ||||||
|     settings.endGroup(); |     settings.endGroup(); | ||||||
|  |  | ||||||
|     bumpApi(AW_FORMATTER_API); |     bumpApi(AW_FORMATTER_API); | ||||||
| @ -126,8 +123,7 @@ int AWDateTimeFormatter::showConfiguration(const QVariant &_args) | |||||||
|     ui->lineEdit_comment->setText(comment()); |     ui->lineEdit_comment->setText(comment()); | ||||||
|     ui->label_typeValue->setText("DateTime"); |     ui->label_typeValue->setText("DateTime"); | ||||||
|     ui->lineEdit_format->setText(format()); |     ui->lineEdit_format->setText(format()); | ||||||
|     ui->checkBox_translate->setCheckState(translateString() ? Qt::Checked |     ui->checkBox_translate->setCheckState(translateString() ? Qt::Checked : Qt::Unchecked); | ||||||
|                                                             : Qt::Unchecked); |  | ||||||
|  |  | ||||||
|     int ret = exec(); |     int ret = exec(); | ||||||
|     if (ret != 1) |     if (ret != 1) | ||||||
|  | |||||||
| @ -32,12 +32,10 @@ class AWDateTimeFormatter : public AWAbstractFormatter | |||||||
| { | { | ||||||
|     Q_OBJECT |     Q_OBJECT | ||||||
|     Q_PROPERTY(QString format READ format WRITE setFormat) |     Q_PROPERTY(QString format READ format WRITE setFormat) | ||||||
|     Q_PROPERTY( |     Q_PROPERTY(bool translateString READ translateString WRITE setTranslateString) | ||||||
|         bool translateString READ translateString WRITE setTranslateString) |  | ||||||
|  |  | ||||||
| public: | public: | ||||||
|     explicit AWDateTimeFormatter(QWidget *_parent = nullptr, |     explicit AWDateTimeFormatter(QWidget *_parent = nullptr, const QString &_filePath = ""); | ||||||
|                                  const QString &_filePath = ""); |  | ||||||
|     virtual ~AWDateTimeFormatter(); |     virtual ~AWDateTimeFormatter(); | ||||||
|     QString convert(const QVariant &_value) const; |     QString convert(const QVariant &_value) const; | ||||||
|     AWDateTimeFormatter *copy(const QString &_fileName, const int _number); |     AWDateTimeFormatter *copy(const QString &_fileName, const int _number); | ||||||
|  | |||||||
| @ -51,9 +51,8 @@ QString AWFloatFormatter::convert(const QVariant &_value) const | |||||||
| { | { | ||||||
|     qCDebug(LOG_LIB) << "Convert value" << _value; |     qCDebug(LOG_LIB) << "Convert value" << _value; | ||||||
|  |  | ||||||
|     QString output |     QString output = QString("%1").arg(_value.toDouble() * multiplier() + summand(), count(), | ||||||
|         = QString("%1").arg(_value.toDouble() * multiplier() + summand(), |                                        format(), precision(), fillChar()); | ||||||
|                             count(), format(), precision(), fillChar()); |  | ||||||
|     if (forceWidth()) |     if (forceWidth()) | ||||||
|         output = output.left(count()); |         output = output.left(count()); | ||||||
|  |  | ||||||
| @ -61,13 +60,11 @@ QString AWFloatFormatter::convert(const QVariant &_value) const | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| AWFloatFormatter *AWFloatFormatter::copy(const QString &_fileName, | AWFloatFormatter *AWFloatFormatter::copy(const QString &_fileName, const int _number) | ||||||
|                                          const int _number) |  | ||||||
| { | { | ||||||
|     qCDebug(LOG_LIB) << "File" << _fileName << "with number" << _number; |     qCDebug(LOG_LIB) << "File" << _fileName << "with number" << _number; | ||||||
|  |  | ||||||
|     AWFloatFormatter *item |     AWFloatFormatter *item = new AWFloatFormatter(static_cast<QWidget *>(parent()), _fileName); | ||||||
|         = new AWFloatFormatter(static_cast<QWidget *>(parent()), _fileName); |  | ||||||
|     AWAbstractFormatter::copyDefaults(item); |     AWAbstractFormatter::copyDefaults(item); | ||||||
|     item->setCount(count()); |     item->setCount(count()); | ||||||
|     item->setFormat(format()); |     item->setFormat(format()); | ||||||
| @ -152,8 +149,8 @@ void AWFloatFormatter::setFormat(char _format) | |||||||
| { | { | ||||||
|     qCDebug(LOG_LIB) << "Set format" << _format; |     qCDebug(LOG_LIB) << "Set format" << _format; | ||||||
|     // http://doc.qt.io/qt-5/qstring.html#argument-formats |     // http://doc.qt.io/qt-5/qstring.html#argument-formats | ||||||
|     if ((_format != 'e') && (_format != 'E') && (_format != 'f') |     if ((_format != 'e') && (_format != 'E') && (_format != 'f') && (_format != 'g') | ||||||
|         && (_format != 'g') && (_format != 'G')) { |         && (_format != 'G')) { | ||||||
|         qCWarning(LOG_LIB) << "Invalid format" << _format; |         qCWarning(LOG_LIB) << "Invalid format" << _format; | ||||||
|         _format = 'f'; |         _format = 'f'; | ||||||
|     } |     } | ||||||
| @ -196,10 +193,7 @@ void AWFloatFormatter::readConfiguration() | |||||||
|     setCount(settings.value("X-AW-Width", count()).toInt()); |     setCount(settings.value("X-AW-Width", count()).toInt()); | ||||||
|     setFillChar(settings.value("X-AW-FillChar", fillChar()).toString().at(0)); |     setFillChar(settings.value("X-AW-FillChar", fillChar()).toString().at(0)); | ||||||
|     setForceWidth(settings.value("X-AW-ForceWidth", forceWidth()).toBool()); |     setForceWidth(settings.value("X-AW-ForceWidth", forceWidth()).toBool()); | ||||||
|     setFormat(settings.value("X-AW-Format", QString(format())) |     setFormat(settings.value("X-AW-Format", QString(format())).toString().at(0).toLatin1()); | ||||||
|                   .toString() |  | ||||||
|                   .at(0) |  | ||||||
|                   .toLatin1()); |  | ||||||
|     setMultiplier(settings.value("X-AW-Multiplier", multiplier()).toDouble()); |     setMultiplier(settings.value("X-AW-Multiplier", multiplier()).toDouble()); | ||||||
|     setPrecision(settings.value("X-AW-Precision", precision()).toInt()); |     setPrecision(settings.value("X-AW-Precision", precision()).toInt()); | ||||||
|     setSummand(settings.value("X-AW-Summand", summand()).toDouble()); |     setSummand(settings.value("X-AW-Summand", summand()).toDouble()); | ||||||
| @ -216,13 +210,11 @@ int AWFloatFormatter::showConfiguration(const QVariant &_args) | |||||||
|     ui->lineEdit_name->setText(name()); |     ui->lineEdit_name->setText(name()); | ||||||
|     ui->lineEdit_comment->setText(comment()); |     ui->lineEdit_comment->setText(comment()); | ||||||
|     ui->label_typeValue->setText("Float"); |     ui->label_typeValue->setText("Float"); | ||||||
|     ui->comboBox_format->setCurrentIndex( |     ui->comboBox_format->setCurrentIndex(ui->comboBox_format->findText(QString(format()))); | ||||||
|         ui->comboBox_format->findText(QString(format()))); |  | ||||||
|     ui->spinBox_precision->setValue(precision()); |     ui->spinBox_precision->setValue(precision()); | ||||||
|     ui->spinBox_width->setValue(count()); |     ui->spinBox_width->setValue(count()); | ||||||
|     ui->lineEdit_fill->setText(QString(fillChar())); |     ui->lineEdit_fill->setText(QString(fillChar())); | ||||||
|     ui->checkBox_forceWidth->setCheckState(forceWidth() ? Qt::Checked |     ui->checkBox_forceWidth->setCheckState(forceWidth() ? Qt::Checked : Qt::Unchecked); | ||||||
|                                                         : Qt::Unchecked); |  | ||||||
|     ui->doubleSpinBox_multiplier->setValue(multiplier()); |     ui->doubleSpinBox_multiplier->setValue(multiplier()); | ||||||
|     ui->doubleSpinBox_summand->setValue(summand()); |     ui->doubleSpinBox_summand->setValue(summand()); | ||||||
|  |  | ||||||
|  | |||||||
| @ -38,8 +38,7 @@ class AWFloatFormatter : public AWAbstractFormatter | |||||||
|     Q_PROPERTY(double summand READ summand WRITE setSummand) |     Q_PROPERTY(double summand READ summand WRITE setSummand) | ||||||
|  |  | ||||||
| public: | public: | ||||||
|     explicit AWFloatFormatter(QWidget *_parent = nullptr, |     explicit AWFloatFormatter(QWidget *_parent = nullptr, const QString &_filePath = ""); | ||||||
|                               const QString &_filePath = ""); |  | ||||||
|     virtual ~AWFloatFormatter(); |     virtual ~AWFloatFormatter(); | ||||||
|     QString convert(const QVariant &_value) const; |     QString convert(const QVariant &_value) const; | ||||||
|     AWFloatFormatter *copy(const QString &_fileName, const int _number); |     AWFloatFormatter *copy(const QString &_fileName, const int _number); | ||||||
|  | |||||||
| @ -53,8 +53,7 @@ QString AWJsonFormatter::convert(const QVariant &_value) const | |||||||
|     qCDebug(LOG_LIB) << "Convert value" << _value; |     qCDebug(LOG_LIB) << "Convert value" << _value; | ||||||
|  |  | ||||||
|     // check if _value is string and parse first if required |     // check if _value is string and parse first if required | ||||||
|     QJsonDocument json |     QJsonDocument json = _value.type() == QVariant::String | ||||||
|         = _value.type() == QVariant::String |  | ||||||
|                              ? QJsonDocument::fromJson(_value.toString().toUtf8()) |                              ? QJsonDocument::fromJson(_value.toString().toUtf8()) | ||||||
|                              : QJsonDocument::fromVariant(_value); |                              : QJsonDocument::fromVariant(_value); | ||||||
|     QVariant converted = json.toVariant(); |     QVariant converted = json.toVariant(); | ||||||
| @ -65,13 +64,11 @@ QString AWJsonFormatter::convert(const QVariant &_value) const | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| AWJsonFormatter *AWJsonFormatter::copy(const QString &_fileName, | AWJsonFormatter *AWJsonFormatter::copy(const QString &_fileName, const int _number) | ||||||
|                                        const int _number) |  | ||||||
| { | { | ||||||
|     qCDebug(LOG_LIB) << "File" << _fileName << "with number" << _number; |     qCDebug(LOG_LIB) << "File" << _fileName << "with number" << _number; | ||||||
|  |  | ||||||
|     AWJsonFormatter *item |     AWJsonFormatter *item = new AWJsonFormatter(static_cast<QWidget *>(parent()), _fileName); | ||||||
|         = new AWJsonFormatter(static_cast<QWidget *>(parent()), _fileName); |  | ||||||
|     AWAbstractFormatter::copyDefaults(item); |     AWAbstractFormatter::copyDefaults(item); | ||||||
|     item->setNumber(_number); |     item->setNumber(_number); | ||||||
|     item->setPath(path()); |     item->setPath(path()); | ||||||
| @ -147,8 +144,7 @@ void AWJsonFormatter::writeConfiguration() const | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| QVariant AWJsonFormatter::getFromJson(const QVariant &_value, | QVariant AWJsonFormatter::getFromJson(const QVariant &_value, const QVariant &_element) const | ||||||
|                                       const QVariant &_element) const |  | ||||||
| { | { | ||||||
|     qCDebug(LOG_LIB) << "Looking for element" << _element << "in" << _value; |     qCDebug(LOG_LIB) << "Looking for element" << _element << "in" << _value; | ||||||
|  |  | ||||||
| @ -163,8 +159,7 @@ QVariant AWJsonFormatter::getFromJson(const QVariant &_value, | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| QVariant AWJsonFormatter::getFromList(const QVariant &_value, | QVariant AWJsonFormatter::getFromList(const QVariant &_value, const int _index) const | ||||||
|                                       const int _index) const |  | ||||||
| { | { | ||||||
|     qCDebug(LOG_LIB) << "Looking for index" << _index << "in" << _value; |     qCDebug(LOG_LIB) << "Looking for index" << _index << "in" << _value; | ||||||
|  |  | ||||||
| @ -172,8 +167,7 @@ QVariant AWJsonFormatter::getFromList(const QVariant &_value, | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| QVariant AWJsonFormatter::getFromMap(const QVariant &_value, | QVariant AWJsonFormatter::getFromMap(const QVariant &_value, const QString &_key) const | ||||||
|                                      const QString &_key) const |  | ||||||
| { | { | ||||||
|     qCDebug(LOG_LIB) << "Looking for key" << _key << "in" << _value; |     qCDebug(LOG_LIB) << "Looking for key" << _key << "in" << _value; | ||||||
|  |  | ||||||
|  | |||||||
| @ -32,8 +32,7 @@ class AWJsonFormatter : public AWAbstractFormatter | |||||||
|     Q_PROPERTY(QString path READ path WRITE setPath) |     Q_PROPERTY(QString path READ path WRITE setPath) | ||||||
|  |  | ||||||
| public: | public: | ||||||
|     explicit AWJsonFormatter(QWidget *_parent = nullptr, |     explicit AWJsonFormatter(QWidget *_parent = nullptr, const QString &_filePath = ""); | ||||||
|                              const QString &_filePath = ""); |  | ||||||
|     virtual ~AWJsonFormatter(); |     virtual ~AWJsonFormatter(); | ||||||
|     QString convert(const QVariant &_value) const; |     QString convert(const QVariant &_value) const; | ||||||
|     AWJsonFormatter *copy(const QString &_fileName, const int _number); |     AWJsonFormatter *copy(const QString &_fileName, const int _number); | ||||||
| @ -48,8 +47,7 @@ public slots: | |||||||
|  |  | ||||||
| private: | private: | ||||||
|     Ui::AWJsonFormatter *ui = nullptr; |     Ui::AWJsonFormatter *ui = nullptr; | ||||||
|     QVariant getFromJson(const QVariant &_value, |     QVariant getFromJson(const QVariant &_value, const QVariant &_element) const; | ||||||
|                          const QVariant &_element) const; |  | ||||||
|     QVariant getFromList(const QVariant &_value, const int _index) const; |     QVariant getFromList(const QVariant &_value, const int _index) const; | ||||||
|     QVariant getFromMap(const QVariant &_value, const QString &_key) const; |     QVariant getFromMap(const QVariant &_value, const QString &_key) const; | ||||||
|     void initPath(); |     void initPath(); | ||||||
|  | |||||||
| @ -59,13 +59,11 @@ QString AWListFormatter::convert(const QVariant &_value) const | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| AWListFormatter *AWListFormatter::copy(const QString &_fileName, | AWListFormatter *AWListFormatter::copy(const QString &_fileName, const int _number) | ||||||
|                                        const int _number) |  | ||||||
| { | { | ||||||
|     qCDebug(LOG_LIB) << "File" << _fileName << "with number" << _number; |     qCDebug(LOG_LIB) << "File" << _fileName << "with number" << _number; | ||||||
|  |  | ||||||
|     AWListFormatter *item |     AWListFormatter *item = new AWListFormatter(static_cast<QWidget *>(parent()), _fileName); | ||||||
|         = new AWListFormatter(static_cast<QWidget *>(parent()), _fileName); |  | ||||||
|     AWAbstractFormatter::copyDefaults(item); |     AWAbstractFormatter::copyDefaults(item); | ||||||
|     item->setFilter(filter()); |     item->setFilter(filter()); | ||||||
|     item->setSeparator(separator()); |     item->setSeparator(separator()); | ||||||
| @ -144,8 +142,7 @@ int AWListFormatter::showConfiguration(const QVariant &_args) | |||||||
|     ui->label_typeValue->setText("List"); |     ui->label_typeValue->setText("List"); | ||||||
|     ui->lineEdit_filter->setText(filter()); |     ui->lineEdit_filter->setText(filter()); | ||||||
|     ui->lineEdit_separator->setText(separator()); |     ui->lineEdit_separator->setText(separator()); | ||||||
|     ui->checkBox_sorted->setCheckState(isSorted() ? Qt::Checked |     ui->checkBox_sorted->setCheckState(isSorted() ? Qt::Checked : Qt::Unchecked); | ||||||
|                                                   : Qt::Unchecked); |  | ||||||
|  |  | ||||||
|     int ret = exec(); |     int ret = exec(); | ||||||
|     if (ret != 1) |     if (ret != 1) | ||||||
|  | |||||||
| @ -34,8 +34,7 @@ class AWListFormatter : public AWAbstractFormatter | |||||||
|     Q_PROPERTY(bool sorted READ isSorted WRITE setSorted) |     Q_PROPERTY(bool sorted READ isSorted WRITE setSorted) | ||||||
|  |  | ||||||
| public: | public: | ||||||
|     explicit AWListFormatter(QWidget *_parent = nullptr, |     explicit AWListFormatter(QWidget *_parent = nullptr, const QString &_filePath = ""); | ||||||
|                              const QString &_filePath = ""); |  | ||||||
|     virtual ~AWListFormatter(); |     virtual ~AWListFormatter(); | ||||||
|     QString convert(const QVariant &_value) const; |     QString convert(const QVariant &_value) const; | ||||||
|     AWListFormatter *copy(const QString &_fileName, const int _number); |     AWListFormatter *copy(const QString &_fileName, const int _number); | ||||||
|  | |||||||
| @ -57,8 +57,7 @@ AWNoFormatter *AWNoFormatter::copy(const QString &_fileName, const int _number) | |||||||
| { | { | ||||||
|     qCDebug(LOG_LIB) << "File" << _fileName << "with number" << _number; |     qCDebug(LOG_LIB) << "File" << _fileName << "with number" << _number; | ||||||
|  |  | ||||||
|     AWNoFormatter *item |     AWNoFormatter *item = new AWNoFormatter(static_cast<QWidget *>(parent()), _fileName); | ||||||
|         = new AWNoFormatter(static_cast<QWidget *>(parent()), _fileName); |  | ||||||
|     AWAbstractFormatter::copyDefaults(item); |     AWAbstractFormatter::copyDefaults(item); | ||||||
|     item->setNumber(_number); |     item->setNumber(_number); | ||||||
|  |  | ||||||
|  | |||||||
| @ -31,8 +31,7 @@ class AWNoFormatter : public AWAbstractFormatter | |||||||
|     Q_OBJECT |     Q_OBJECT | ||||||
|  |  | ||||||
| public: | public: | ||||||
|     explicit AWNoFormatter(QWidget *_parent = nullptr, |     explicit AWNoFormatter(QWidget *_parent = nullptr, const QString &_filePath = ""); | ||||||
|                            const QString &_filePath = ""); |  | ||||||
|     virtual ~AWNoFormatter(); |     virtual ~AWNoFormatter(); | ||||||
|     QString convert(const QVariant &_value) const; |     QString convert(const QVariant &_value) const; | ||||||
|     AWNoFormatter *copy(const QString &_fileName, const int _number); |     AWNoFormatter *copy(const QString &_fileName, const int _number); | ||||||
|  | |||||||
| @ -59,9 +59,8 @@ QString AWScriptFormatter::convert(const QVariant &_value) const | |||||||
|     QJSValue result = fn.call(args); |     QJSValue result = fn.call(args); | ||||||
|  |  | ||||||
|     if (result.isError()) { |     if (result.isError()) { | ||||||
|         qCWarning(LOG_LIB) << "Uncaught exception at line" |         qCWarning(LOG_LIB) << "Uncaught exception at line" << result.property("lineNumber").toInt() | ||||||
|                            << result.property("lineNumber").toInt() << ":" |                            << ":" << result.toString(); | ||||||
|                            << result.toString(); |  | ||||||
|         return ""; |         return ""; | ||||||
|     } else { |     } else { | ||||||
|         return result.toString(); |         return result.toString(); | ||||||
| @ -69,13 +68,11 @@ QString AWScriptFormatter::convert(const QVariant &_value) const | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| AWScriptFormatter *AWScriptFormatter::copy(const QString &_fileName, | AWScriptFormatter *AWScriptFormatter::copy(const QString &_fileName, const int _number) | ||||||
|                                            const int _number) |  | ||||||
| { | { | ||||||
|     qCDebug(LOG_LIB) << "File" << _fileName << "with number" << _number; |     qCDebug(LOG_LIB) << "File" << _fileName << "with number" << _number; | ||||||
|  |  | ||||||
|     AWScriptFormatter *item |     AWScriptFormatter *item = new AWScriptFormatter(static_cast<QWidget *>(parent()), _fileName); | ||||||
|         = new AWScriptFormatter(static_cast<QWidget *>(parent()), _fileName); |  | ||||||
|     AWAbstractFormatter::copyDefaults(item); |     AWAbstractFormatter::copyDefaults(item); | ||||||
|     item->setAppendCode(appendCode()); |     item->setAppendCode(appendCode()); | ||||||
|     item->setCode(code()); |     item->setCode(code()); | ||||||
| @ -160,10 +157,8 @@ int AWScriptFormatter::showConfiguration(const QVariant &_args) | |||||||
|     ui->lineEdit_name->setText(name()); |     ui->lineEdit_name->setText(name()); | ||||||
|     ui->lineEdit_comment->setText(comment()); |     ui->lineEdit_comment->setText(comment()); | ||||||
|     ui->label_typeValue->setText("Script"); |     ui->label_typeValue->setText("Script"); | ||||||
|     ui->checkBox_appendCode->setCheckState(appendCode() ? Qt::Checked |     ui->checkBox_appendCode->setCheckState(appendCode() ? Qt::Checked : Qt::Unchecked); | ||||||
|                                                         : Qt::Unchecked); |     ui->checkBox_hasReturn->setCheckState(hasReturn() ? Qt::Checked : Qt::Unchecked); | ||||||
|     ui->checkBox_hasReturn->setCheckState(hasReturn() ? Qt::Checked |  | ||||||
|                                                       : Qt::Unchecked); |  | ||||||
|     ui->textEdit_code->setPlainText(code()); |     ui->textEdit_code->setPlainText(code()); | ||||||
|  |  | ||||||
|     int ret = exec(); |     int ret = exec(); | ||||||
|  | |||||||
| @ -35,8 +35,7 @@ class AWScriptFormatter : public AWAbstractFormatter | |||||||
|     Q_PROPERTY(QString program READ program) |     Q_PROPERTY(QString program READ program) | ||||||
|  |  | ||||||
| public: | public: | ||||||
|     explicit AWScriptFormatter(QWidget *_parent = nullptr, |     explicit AWScriptFormatter(QWidget *_parent = nullptr, const QString &_filePath = ""); | ||||||
|                                const QString &_filePath = ""); |  | ||||||
|     virtual ~AWScriptFormatter(); |     virtual ~AWScriptFormatter(); | ||||||
|     QString convert(const QVariant &_value) const; |     QString convert(const QVariant &_value) const; | ||||||
|     AWScriptFormatter *copy(const QString &_fileName, const int _number); |     AWScriptFormatter *copy(const QString &_fileName, const int _number); | ||||||
|  | |||||||
| @ -59,13 +59,11 @@ QString AWStringFormatter::convert(const QVariant &_value) const | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| AWStringFormatter *AWStringFormatter::copy(const QString &_fileName, | AWStringFormatter *AWStringFormatter::copy(const QString &_fileName, const int _number) | ||||||
|                                            const int _number) |  | ||||||
| { | { | ||||||
|     qCDebug(LOG_LIB) << "File" << _fileName << "with number" << _number; |     qCDebug(LOG_LIB) << "File" << _fileName << "with number" << _number; | ||||||
|  |  | ||||||
|     AWStringFormatter *item |     AWStringFormatter *item = new AWStringFormatter(static_cast<QWidget *>(parent()), _fileName); | ||||||
|         = new AWStringFormatter(static_cast<QWidget *>(parent()), _fileName); |  | ||||||
|     AWAbstractFormatter::copyDefaults(item); |     AWAbstractFormatter::copyDefaults(item); | ||||||
|     item->setCount(count()); |     item->setCount(count()); | ||||||
|     item->setFillChar(fillChar()); |     item->setFillChar(fillChar()); | ||||||
| @ -143,8 +141,7 @@ int AWStringFormatter::showConfiguration(const QVariant &_args) | |||||||
|     ui->label_typeValue->setText("String"); |     ui->label_typeValue->setText("String"); | ||||||
|     ui->spinBox_width->setValue(count()); |     ui->spinBox_width->setValue(count()); | ||||||
|     ui->lineEdit_fill->setText(QString(fillChar())); |     ui->lineEdit_fill->setText(QString(fillChar())); | ||||||
|     ui->checkBox_forceWidth->setCheckState(forceWidth() ? Qt::Checked |     ui->checkBox_forceWidth->setCheckState(forceWidth() ? Qt::Checked : Qt::Unchecked); | ||||||
|                                                         : Qt::Unchecked); |  | ||||||
|  |  | ||||||
|     int ret = exec(); |     int ret = exec(); | ||||||
|     if (ret != 1) |     if (ret != 1) | ||||||
|  | |||||||
| @ -34,8 +34,7 @@ class AWStringFormatter : public AWAbstractFormatter | |||||||
|     Q_PROPERTY(bool forceWidth READ forceWidth WRITE setForceWidth) |     Q_PROPERTY(bool forceWidth READ forceWidth WRITE setForceWidth) | ||||||
|  |  | ||||||
| public: | public: | ||||||
|     explicit AWStringFormatter(QWidget *_parent = nullptr, |     explicit AWStringFormatter(QWidget *_parent = nullptr, const QString &_filePath = ""); | ||||||
|                                const QString &_filePath = ""); |  | ||||||
|     virtual ~AWStringFormatter(); |     virtual ~AWStringFormatter(); | ||||||
|     QString convert(const QVariant &_value) const; |     QString convert(const QVariant &_value) const; | ||||||
|     AWStringFormatter *copy(const QString &_fileName, const int _number); |     AWStringFormatter *copy(const QString &_fileName, const int _number); | ||||||
|  | |||||||
| @ -139,8 +139,7 @@ private: | |||||||
|                 qCInfo(LOG_LIB) << "Found file" << file << "in" << dir; |                 qCInfo(LOG_LIB) << "Found file" << file << "in" << dir; | ||||||
|                 QString filePath = QString("%1/%2").arg(dir).arg(file); |                 QString filePath = QString("%1/%2").arg(dir).arg(file); | ||||||
|                 // check if already exists |                 // check if already exists | ||||||
|                 if (std::any_of(items.cbegin(), items.cend(), |                 if (std::any_of(items.cbegin(), items.cend(), [&filePath](AbstractExtItem *item) { | ||||||
|                                 [&filePath](AbstractExtItem *item) { |  | ||||||
|                         return (item->fileName() == filePath); |                         return (item->fileName() == filePath); | ||||||
|                     })) |                     })) | ||||||
|                     continue; |                     continue; | ||||||
|  | |||||||
| @ -65,13 +65,11 @@ ExtNetworkRequest::~ExtNetworkRequest() | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| ExtNetworkRequest *ExtNetworkRequest::copy(const QString &_fileName, | ExtNetworkRequest *ExtNetworkRequest::copy(const QString &_fileName, const int _number) | ||||||
|                                            const int _number) |  | ||||||
| { | { | ||||||
|     qCDebug(LOG_LIB) << "File" << _fileName << "with number" << _number; |     qCDebug(LOG_LIB) << "File" << _fileName << "with number" << _number; | ||||||
|  |  | ||||||
|     ExtNetworkRequest *item |     ExtNetworkRequest *item = new ExtNetworkRequest(static_cast<QWidget *>(parent()), _fileName); | ||||||
|         = new ExtNetworkRequest(static_cast<QWidget *>(parent()), _fileName); |  | ||||||
|     copyDefaults(item); |     copyDefaults(item); | ||||||
|     item->setNumber(_number); |     item->setNumber(_number); | ||||||
|     item->setStringUrl(stringUrl()); |     item->setStringUrl(stringUrl()); | ||||||
| @ -133,8 +131,7 @@ int ExtNetworkRequest::showConfiguration(const QVariant &_args) | |||||||
|     ui->lineEdit_comment->setText(comment()); |     ui->lineEdit_comment->setText(comment()); | ||||||
|     ui->label_numberValue->setText(QString("%1").arg(number())); |     ui->label_numberValue->setText(QString("%1").arg(number())); | ||||||
|     ui->lineEdit_url->setText(stringUrl()); |     ui->lineEdit_url->setText(stringUrl()); | ||||||
|     ui->checkBox_active->setCheckState(isActive() ? Qt::Checked |     ui->checkBox_active->setCheckState(isActive() ? Qt::Checked : Qt::Unchecked); | ||||||
|                                                   : Qt::Unchecked); |  | ||||||
|     ui->lineEdit_schedule->setText(cron()); |     ui->lineEdit_schedule->setText(cron()); | ||||||
|     ui->lineEdit_socket->setText(socket()); |     ui->lineEdit_socket->setText(socket()); | ||||||
|     ui->spinBox_interval->setValue(interval()); |     ui->spinBox_interval->setValue(interval()); | ||||||
| @ -174,8 +171,8 @@ void ExtNetworkRequest::writeConfiguration() const | |||||||
| void ExtNetworkRequest::networkReplyReceived(QNetworkReply *_reply) | void ExtNetworkRequest::networkReplyReceived(QNetworkReply *_reply) | ||||||
| { | { | ||||||
|     if (_reply->error() != QNetworkReply::NoError) { |     if (_reply->error() != QNetworkReply::NoError) { | ||||||
|         qCWarning(LOG_AW) << "An error occurs" << _reply->error() |         qCWarning(LOG_AW) << "An error occurs" << _reply->error() << "with message" | ||||||
|                           << "with message" << _reply->errorString(); |                           << _reply->errorString(); | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  | |||||||
| @ -34,8 +34,7 @@ class ExtNetworkRequest : public AbstractExtItem | |||||||
|     Q_PROPERTY(QString stringUrl READ stringUrl WRITE setStringUrl) |     Q_PROPERTY(QString stringUrl READ stringUrl WRITE setStringUrl) | ||||||
|  |  | ||||||
| public: | public: | ||||||
|     explicit ExtNetworkRequest(QWidget *_parent = nullptr, |     explicit ExtNetworkRequest(QWidget *_parent = nullptr, const QString &_filePath = ""); | ||||||
|                                const QString &_filePath = ""); |  | ||||||
|     virtual ~ExtNetworkRequest(); |     virtual ~ExtNetworkRequest(); | ||||||
|     ExtNetworkRequest *copy(const QString &_fileName, const int _number); |     ExtNetworkRequest *copy(const QString &_fileName, const int _number); | ||||||
|     // get methods |     // get methods | ||||||
|  | |||||||
| @ -21,13 +21,13 @@ | |||||||
| #include <KI18n/KLocalizedString> | #include <KI18n/KLocalizedString> | ||||||
|  |  | ||||||
| #include <QDir> | #include <QDir> | ||||||
| #include <QJsonDocument> |  | ||||||
| #include <QSettings> | #include <QSettings> | ||||||
| #include <QUrlQuery> |  | ||||||
|  |  | ||||||
| #include <qreplytimeout/qreplytimeout.h> | #include <qreplytimeout/qreplytimeout.h> | ||||||
|  |  | ||||||
| #include "awdebug.h" | #include "awdebug.h" | ||||||
|  | #include "stooqquotesprovider.h" | ||||||
|  | #include "yahooquotesprovider.h" | ||||||
|  |  | ||||||
|  |  | ||||||
| ExtQuotes::ExtQuotes(QWidget *_parent, const QString &_filePath) | ExtQuotes::ExtQuotes(QWidget *_parent, const QString &_filePath) | ||||||
| @ -41,15 +41,12 @@ ExtQuotes::ExtQuotes(QWidget *_parent, const QString &_filePath) | |||||||
|     ui->setupUi(this); |     ui->setupUi(this); | ||||||
|     translate(); |     translate(); | ||||||
|  |  | ||||||
|     m_values[tag("ask")] = 0.0; |  | ||||||
|     m_values[tag("askchg")] = 0.0; |  | ||||||
|     m_values[tag("percaskchg")] = 0.0; |  | ||||||
|     m_values[tag("bid")] = 0.0; |  | ||||||
|     m_values[tag("bidchg")] = 0.0; |  | ||||||
|     m_values[tag("percbidchg")] = 0.0; |  | ||||||
|     m_values[tag("price")] = 0.0; |     m_values[tag("price")] = 0.0; | ||||||
|     m_values[tag("pricechg")] = 0.0; |     m_values[tag("pricechg")] = 0.0; | ||||||
|     m_values[tag("percpricechg")] = 0.0; |     m_values[tag("percpricechg")] = 0.0; | ||||||
|  |     m_values[tag("volume")] = 0; | ||||||
|  |     m_values[tag("volumechg")] = 0; | ||||||
|  |     m_values[tag("percvolumechg")] = 0.0; | ||||||
|  |  | ||||||
|     // HACK declare as child of nullptr to avoid crash with plasmawindowed |     // HACK declare as child of nullptr to avoid crash with plasmawindowed | ||||||
|     // in the destructor |     // in the destructor | ||||||
| @ -78,8 +75,7 @@ ExtQuotes *ExtQuotes::copy(const QString &_fileName, const int _number) | |||||||
| { | { | ||||||
|     qCDebug(LOG_LIB) << "File" << _fileName << "with number" << _number; |     qCDebug(LOG_LIB) << "File" << _fileName << "with number" << _number; | ||||||
|  |  | ||||||
|     ExtQuotes *item |     ExtQuotes *item = new ExtQuotes(static_cast<QWidget *>(parent()), _fileName); | ||||||
|         = new ExtQuotes(static_cast<QWidget *>(parent()), _fileName); |  | ||||||
|     copyDefaults(item); |     copyDefaults(item); | ||||||
|     item->setNumber(_number); |     item->setNumber(_number); | ||||||
|     item->setTicker(ticker()); |     item->setTicker(ticker()); | ||||||
| @ -105,7 +101,7 @@ void ExtQuotes::setTicker(const QString &_ticker) | |||||||
|     qCDebug(LOG_LIB) << "Ticker" << _ticker; |     qCDebug(LOG_LIB) << "Ticker" << _ticker; | ||||||
|  |  | ||||||
|     m_ticker = _ticker; |     m_ticker = _ticker; | ||||||
|     initUrl(); |     initProvider(); | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -141,8 +137,7 @@ int ExtQuotes::showConfiguration(const QVariant &_args) | |||||||
|     ui->lineEdit_comment->setText(comment()); |     ui->lineEdit_comment->setText(comment()); | ||||||
|     ui->label_numberValue->setText(QString("%1").arg(number())); |     ui->label_numberValue->setText(QString("%1").arg(number())); | ||||||
|     ui->lineEdit_ticker->setText(ticker()); |     ui->lineEdit_ticker->setText(ticker()); | ||||||
|     ui->checkBox_active->setCheckState(isActive() ? Qt::Checked |     ui->checkBox_active->setCheckState(isActive() ? Qt::Checked : Qt::Unchecked); | ||||||
|                                                   : Qt::Unchecked); |  | ||||||
|     ui->lineEdit_schedule->setText(cron()); |     ui->lineEdit_schedule->setText(cron()); | ||||||
|     ui->lineEdit_socket->setText(socket()); |     ui->lineEdit_socket->setText(socket()); | ||||||
|     ui->spinBox_interval->setValue(interval()); |     ui->spinBox_interval->setValue(interval()); | ||||||
| @ -182,49 +177,19 @@ void ExtQuotes::writeConfiguration() const | |||||||
| void ExtQuotes::quotesReplyReceived(QNetworkReply *_reply) | void ExtQuotes::quotesReplyReceived(QNetworkReply *_reply) | ||||||
| { | { | ||||||
|     if (_reply->error() != QNetworkReply::NoError) { |     if (_reply->error() != QNetworkReply::NoError) { | ||||||
|         qCWarning(LOG_AW) << "An error occurs" << _reply->error() |         qCWarning(LOG_AW) << "An error occurs" << _reply->error() << "with message" | ||||||
|                           << "with message" << _reply->errorString(); |                           << _reply->errorString(); | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     m_isRunning = false; |     m_isRunning = false; | ||||||
|     QJsonParseError error; |     auto text = _reply->readAll(); | ||||||
|     QJsonDocument jsonDoc = QJsonDocument::fromJson(_reply->readAll(), &error); |  | ||||||
|     _reply->deleteLater(); |     _reply->deleteLater(); | ||||||
|     if (error.error != QJsonParseError::NoError) { |  | ||||||
|         qCWarning(LOG_LIB) << "Parse error" << error.errorString(); |     QVariantHash data = m_providerObject->parse(text, m_values); | ||||||
|  |     if (data.isEmpty()) | ||||||
|         return; |         return; | ||||||
|     } |     m_values = data; | ||||||
|     QVariantMap jsonQuotes = jsonDoc.toVariant().toMap()["query"].toMap(); |  | ||||||
|     jsonQuotes = jsonQuotes["results"].toMap()["quote"].toMap(); |  | ||||||
|     double value; |  | ||||||
|  |  | ||||||
|     // ask |  | ||||||
|     value = jsonQuotes["Ask"].toString().toDouble(); |  | ||||||
|     m_values[tag("askchg")] = m_values[tag("ask")].toDouble() == 0.0 |  | ||||||
|                                   ? 0.0 |  | ||||||
|                                   : value - m_values[tag("ask")].toDouble(); |  | ||||||
|     m_values[tag("percaskchg")] = 100.0 * m_values[tag("askchg")].toDouble() |  | ||||||
|                                   / m_values[tag("ask")].toDouble(); |  | ||||||
|     m_values[tag("ask")] = value; |  | ||||||
|  |  | ||||||
|     // bid |  | ||||||
|     value = jsonQuotes["Bid"].toString().toDouble(); |  | ||||||
|     m_values[tag("bidchg")] = m_values[tag("bid")].toDouble() == 0.0 |  | ||||||
|                                   ? 0.0 |  | ||||||
|                                   : value - m_values[tag("bid")].toDouble(); |  | ||||||
|     m_values[tag("percbidchg")] = 100.0 * m_values[tag("bidchg")].toDouble() |  | ||||||
|                                   / m_values[tag("bid")].toDouble(); |  | ||||||
|     m_values[tag("bid")] = value; |  | ||||||
|  |  | ||||||
|     // last trade |  | ||||||
|     value = jsonQuotes["LastTradePriceOnly"].toString().toDouble(); |  | ||||||
|     m_values[tag("pricechg")] = m_values[tag("price")].toDouble() == 0.0 |  | ||||||
|                                     ? 0.0 |  | ||||||
|                                     : value - m_values[tag("price")].toDouble(); |  | ||||||
|     m_values[tag("percpricechg")] = 100.0 * m_values[tag("pricechg")].toDouble() |  | ||||||
|                                     / m_values[tag("price")].toDouble(); |  | ||||||
|     m_values[tag("price")] = value; |  | ||||||
|  |  | ||||||
|     emit(dataReceived(m_values)); |     emit(dataReceived(m_values)); | ||||||
| } | } | ||||||
| @ -233,20 +198,19 @@ void ExtQuotes::quotesReplyReceived(QNetworkReply *_reply) | |||||||
| void ExtQuotes::sendRequest() | void ExtQuotes::sendRequest() | ||||||
| { | { | ||||||
|     m_isRunning = true; |     m_isRunning = true; | ||||||
|     QNetworkReply *reply = m_manager->get(QNetworkRequest(m_url)); |     QNetworkReply *reply = m_manager->get(QNetworkRequest(m_providerObject->url())); | ||||||
|     new QReplyTimeout(reply, REQUEST_TIMEOUT); |     new QReplyTimeout(reply, REQUEST_TIMEOUT); | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| void ExtQuotes::initUrl() | void ExtQuotes::initProvider() | ||||||
| { | { | ||||||
|     // init query |     delete m_providerObject; | ||||||
|     m_url = QUrl(YAHOO_QUOTES_URL); |  | ||||||
|     QUrlQuery params; |     // in the future release it is possible to change provider here | ||||||
|     params.addQueryItem("format", "json"); |     m_providerObject = new StooqQuotesProvider(this); | ||||||
|     params.addQueryItem("env", "store://datatables.org/alltableswithkeys"); |  | ||||||
|     params.addQueryItem("q", QString(YAHOO_QUOTES_QUERY).arg(ticker())); |     return m_providerObject->initUrl(ticker()); | ||||||
|     m_url.setQuery(params); |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -256,10 +220,9 @@ void ExtQuotes::translate() | |||||||
|     ui->label_comment->setText(i18n("Comment")); |     ui->label_comment->setText(i18n("Comment")); | ||||||
|     ui->label_number->setText(i18n("Tag")); |     ui->label_number->setText(i18n("Tag")); | ||||||
|     ui->label->setText( |     ui->label->setText( | ||||||
|         i18n("<html><head/><body><p>Use YAHOO! finance ticker to \ |         i18n("<html><head/><body><p>Use Stooq ticker to get quotes for the instrument. Refer to <a " | ||||||
| get quotes for the instrument. Refer to <a href=\"http://finance.yahoo.com/\">\ |              "href=\"https://stooq.com/\"><span style=\" text-decoration: underline; " | ||||||
| <span style=\" text-decoration: underline; color:#0057ae;\">http://finance.yahoo.com/\ |              "color:#0057ae;\">https://stooq.com/</span></a></p></body></html>")); | ||||||
| </span></a></p></body></html>")); |  | ||||||
|     ui->label_ticker->setText(i18n("Ticker")); |     ui->label_ticker->setText(i18n("Ticker")); | ||||||
|     ui->checkBox_active->setText(i18n("Active")); |     ui->checkBox_active->setText(i18n("Active")); | ||||||
|     ui->label_schedule->setText(i18n("Schedule")); |     ui->label_schedule->setText(i18n("Schedule")); | ||||||
|  | |||||||
| @ -23,6 +23,7 @@ | |||||||
| #include "abstractextitem.h" | #include "abstractextitem.h" | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class AbstractQuotesProvider; | ||||||
| namespace Ui | namespace Ui | ||||||
| { | { | ||||||
| class ExtQuotes; | class ExtQuotes; | ||||||
| @ -34,12 +35,7 @@ class ExtQuotes : public AbstractExtItem | |||||||
|     Q_PROPERTY(QString ticker READ ticker WRITE setTicker) |     Q_PROPERTY(QString ticker READ ticker WRITE setTicker) | ||||||
|  |  | ||||||
| public: | public: | ||||||
|     const char *YAHOO_QUOTES_URL = "https://query.yahooapis.com/v1/public/yql"; |     explicit ExtQuotes(QWidget *_parent = nullptr, const QString &_filePath = ""); | ||||||
|     const char *YAHOO_QUOTES_QUERY |  | ||||||
|         = "select * from yahoo.finance.quotes where symbol='%1'"; |  | ||||||
|  |  | ||||||
|     explicit ExtQuotes(QWidget *_parent = nullptr, |  | ||||||
|                        const QString &_filePath = ""); |  | ||||||
|     virtual ~ExtQuotes(); |     virtual ~ExtQuotes(); | ||||||
|     ExtQuotes *copy(const QString &_fileName, const int _number); |     ExtQuotes *copy(const QString &_fileName, const int _number); | ||||||
|     // get methods |     // get methods | ||||||
| @ -59,11 +55,11 @@ private slots: | |||||||
|     void sendRequest(); |     void sendRequest(); | ||||||
|  |  | ||||||
| private: | private: | ||||||
|  |     AbstractQuotesProvider *m_providerObject = nullptr; | ||||||
|     QNetworkAccessManager *m_manager = nullptr; |     QNetworkAccessManager *m_manager = nullptr; | ||||||
|     QUrl m_url; |  | ||||||
|     bool m_isRunning = false; |     bool m_isRunning = false; | ||||||
|     Ui::ExtQuotes *ui = nullptr; |     Ui::ExtQuotes *ui = nullptr; | ||||||
|     void initUrl(); |     void initProvider(); | ||||||
|     void translate(); |     void translate(); | ||||||
|     // properties |     // properties | ||||||
|     QString m_ticker = "EURUSD=X"; |     QString m_ticker = "EURUSD=X"; | ||||||
|  | |||||||
| @ -84,7 +84,7 @@ | |||||||
|    <item> |    <item> | ||||||
|     <widget class="QLabel" name="label"> |     <widget class="QLabel" name="label"> | ||||||
|      <property name="text"> |      <property name="text"> | ||||||
|       <string><html><head/><body><p>Use YAHOO! finance ticker to get quotes for the instrument. Refer to <a href="http://finance.yahoo.com/"><span style=" text-decoration: underline; color:#0057ae;">http://finance.yahoo.com/</span></a></p></body></html></string> |       <string><html><head/><body><p>Use Stooq ticker to get quotes for the instrument. Refer to <a href="https://stooq.com/"><span style=" text-decoration: underline; color:#0057ae;">https://stooq.com/</span></a></p></body></html></string> | ||||||
|      </property> |      </property> | ||||||
|      <property name="alignment"> |      <property name="alignment"> | ||||||
|       <set>Qt::AlignCenter</set> |       <set>Qt::AlignCenter</set> | ||||||
|  | |||||||
| @ -44,8 +44,7 @@ ExtScript::ExtScript(QWidget *_parent, const QString &_filePath) | |||||||
|     m_values[tag("custom")] = ""; |     m_values[tag("custom")] = ""; | ||||||
|  |  | ||||||
|     m_process = new QProcess(nullptr); |     m_process = new QProcess(nullptr); | ||||||
|     connect(m_process, SIGNAL(finished(int, QProcess::ExitStatus)), this, |     connect(m_process, SIGNAL(finished(int, QProcess::ExitStatus)), this, SLOT(updateValue())); | ||||||
|             SLOT(updateValue())); |  | ||||||
|     m_process->waitForFinished(0); |     m_process->waitForFinished(0); | ||||||
|  |  | ||||||
|     connect(this, SIGNAL(requestDataUpdate()), this, SLOT(startProcess())); |     connect(this, SIGNAL(requestDataUpdate()), this, SLOT(startProcess())); | ||||||
| @ -56,8 +55,7 @@ ExtScript::~ExtScript() | |||||||
| { | { | ||||||
|     qCDebug(LOG_LIB) << __PRETTY_FUNCTION__; |     qCDebug(LOG_LIB) << __PRETTY_FUNCTION__; | ||||||
|  |  | ||||||
|     disconnect(m_process, SIGNAL(finished(int, QProcess::ExitStatus)), this, |     disconnect(m_process, SIGNAL(finished(int, QProcess::ExitStatus)), this, SLOT(updateValue())); | ||||||
|                SLOT(updateValue())); |  | ||||||
|     m_process->kill(); |     m_process->kill(); | ||||||
|     m_process->deleteLater(); |     m_process->deleteLater(); | ||||||
|     disconnect(this, SIGNAL(requestDataUpdate()), this, SLOT(startProcess())); |     disconnect(this, SIGNAL(requestDataUpdate()), this, SLOT(startProcess())); | ||||||
| @ -69,8 +67,7 @@ ExtScript *ExtScript::copy(const QString &_fileName, const int _number) | |||||||
| { | { | ||||||
|     qCDebug(LOG_LIB) << "File" << _fileName << "with number" << _number; |     qCDebug(LOG_LIB) << "File" << _fileName << "with number" << _number; | ||||||
|  |  | ||||||
|     ExtScript *item |     ExtScript *item = new ExtScript(static_cast<QWidget *>(parent()), _fileName); | ||||||
|         = new ExtScript(static_cast<QWidget *>(parent()), _fileName); |  | ||||||
|     copyDefaults(item); |     copyDefaults(item); | ||||||
|     item->setExecutable(executable()); |     item->setExecutable(executable()); | ||||||
|     item->setNumber(_number); |     item->setNumber(_number); | ||||||
| @ -84,8 +81,8 @@ ExtScript *ExtScript::copy(const QString &_fileName, const int _number) | |||||||
|  |  | ||||||
| QString ExtScript::jsonFiltersFile() const | QString ExtScript::jsonFiltersFile() const | ||||||
| { | { | ||||||
|     QString fileName = QStandardPaths::locate( |     QString fileName | ||||||
|         QStandardPaths::GenericDataLocation, |         = QStandardPaths::locate(QStandardPaths::GenericDataLocation, | ||||||
|                                  "awesomewidgets/scripts/awesomewidgets-extscripts-filters.json"); |                                  "awesomewidgets/scripts/awesomewidgets-extscripts-filters.json"); | ||||||
|     qCInfo(LOG_LIB) << "Filters file" << fileName; |     qCInfo(LOG_LIB) << "Filters file" << fileName; | ||||||
|  |  | ||||||
| @ -157,8 +154,7 @@ void ExtScript::setFilters(const QStringList &_filters) | |||||||
| { | { | ||||||
|     qCDebug(LOG_LIB) << "Filters" << _filters; |     qCDebug(LOG_LIB) << "Filters" << _filters; | ||||||
|  |  | ||||||
|     std::for_each( |     std::for_each(_filters.cbegin(), _filters.cend(), | ||||||
|         _filters.cbegin(), _filters.cend(), |  | ||||||
|                   [this](const QString &filter) { return updateFilter(filter, true); }); |                   [this](const QString &filter) { return updateFilter(filter, true); }); | ||||||
| } | } | ||||||
|  |  | ||||||
| @ -202,8 +198,7 @@ QString ExtScript::applyFilters(QString _value) const | |||||||
|         qCInfo(LOG_LIB) << "Found filter" << filt; |         qCInfo(LOG_LIB) << "Found filter" << filt; | ||||||
|         QVariantMap filter = m_jsonFilters[filt].toMap(); |         QVariantMap filter = m_jsonFilters[filt].toMap(); | ||||||
|         if (filter.isEmpty()) { |         if (filter.isEmpty()) { | ||||||
|             qCWarning(LOG_LIB) |             qCWarning(LOG_LIB) << "Could not find filter" << _value << "in the json"; | ||||||
|                 << "Could not find filter" << _value << "in the json"; |  | ||||||
|             continue; |             continue; | ||||||
|         } |         } | ||||||
|         for (auto &f : filter.keys()) |         for (auto &f : filter.keys()) | ||||||
| @ -239,9 +234,8 @@ void ExtScript::readConfiguration() | |||||||
|     setPrefix(settings.value("X-AW-Prefix", prefix()).toString()); |     setPrefix(settings.value("X-AW-Prefix", prefix()).toString()); | ||||||
|     setStrRedirect(settings.value("X-AW-Redirect", strRedirect()).toString()); |     setStrRedirect(settings.value("X-AW-Redirect", strRedirect()).toString()); | ||||||
|     // api == 3 |     // api == 3 | ||||||
|     setFilters(settings.value("X-AW-Filters", filters()) |     setFilters( | ||||||
|                    .toString() |         settings.value("X-AW-Filters", filters()).toString().split(',', QString::SkipEmptyParts)); | ||||||
|                    .split(',', QString::SkipEmptyParts)); |  | ||||||
|     settings.endGroup(); |     settings.endGroup(); | ||||||
|  |  | ||||||
|     bumpApi(AW_EXTSCRIPT_API); |     bumpApi(AW_EXTSCRIPT_API); | ||||||
| @ -290,19 +284,18 @@ int ExtScript::showConfiguration(const QVariant &_args) | |||||||
|     ui->label_numberValue->setText(QString("%1").arg(number())); |     ui->label_numberValue->setText(QString("%1").arg(number())); | ||||||
|     ui->lineEdit_command->setText(executable()); |     ui->lineEdit_command->setText(executable()); | ||||||
|     ui->lineEdit_prefix->setText(prefix()); |     ui->lineEdit_prefix->setText(prefix()); | ||||||
|     ui->checkBox_active->setCheckState(isActive() ? Qt::Checked |     ui->checkBox_active->setCheckState(isActive() ? Qt::Checked : Qt::Unchecked); | ||||||
|                                                   : Qt::Unchecked); |  | ||||||
|     ui->comboBox_redirect->setCurrentIndex(static_cast<int>(redirect())); |     ui->comboBox_redirect->setCurrentIndex(static_cast<int>(redirect())); | ||||||
|     ui->lineEdit_schedule->setText(cron()); |     ui->lineEdit_schedule->setText(cron()); | ||||||
|     ui->lineEdit_socket->setText(socket()); |     ui->lineEdit_socket->setText(socket()); | ||||||
|     ui->spinBox_interval->setValue(interval()); |     ui->spinBox_interval->setValue(interval()); | ||||||
|     // filters |     // filters | ||||||
|     ui->checkBox_colorFilter->setCheckState( |     ui->checkBox_colorFilter->setCheckState(filters().contains("color") ? Qt::Checked | ||||||
|         filters().contains("color") ? Qt::Checked : Qt::Unchecked); |                                                                         : Qt::Unchecked); | ||||||
|     ui->checkBox_linesFilter->setCheckState( |     ui->checkBox_linesFilter->setCheckState(filters().contains("newline") ? Qt::Checked | ||||||
|         filters().contains("newline") ? Qt::Checked : Qt::Unchecked); |                                                                           : Qt::Unchecked); | ||||||
|     ui->checkBox_spaceFilter->setCheckState( |     ui->checkBox_spaceFilter->setCheckState(filters().contains("space") ? Qt::Checked | ||||||
|         filters().contains("space") ? Qt::Checked : Qt::Unchecked); |                                                                         : Qt::Unchecked); | ||||||
|  |  | ||||||
|     int ret = exec(); |     int ret = exec(); | ||||||
|     if (ret != 1) |     if (ret != 1) | ||||||
| @ -319,12 +312,9 @@ int ExtScript::showConfiguration(const QVariant &_args) | |||||||
|     setSocket(ui->lineEdit_socket->text()); |     setSocket(ui->lineEdit_socket->text()); | ||||||
|     setInterval(ui->spinBox_interval->value()); |     setInterval(ui->spinBox_interval->value()); | ||||||
|     // filters |     // filters | ||||||
|     updateFilter("color", |     updateFilter("color", ui->checkBox_colorFilter->checkState() == Qt::Checked); | ||||||
|                  ui->checkBox_colorFilter->checkState() == Qt::Checked); |     updateFilter("newline", ui->checkBox_linesFilter->checkState() == Qt::Checked); | ||||||
|     updateFilter("newline", |     updateFilter("space", ui->checkBox_spaceFilter->checkState() == Qt::Checked); | ||||||
|                  ui->checkBox_linesFilter->checkState() == Qt::Checked); |  | ||||||
|     updateFilter("space", |  | ||||||
|                  ui->checkBox_spaceFilter->checkState() == Qt::Checked); |  | ||||||
|  |  | ||||||
|     writeConfiguration(); |     writeConfiguration(); | ||||||
|     return ret; |     return ret; | ||||||
| @ -363,13 +353,11 @@ void ExtScript::startProcess() | |||||||
| void ExtScript::updateValue() | void ExtScript::updateValue() | ||||||
| { | { | ||||||
|     qCInfo(LOG_LIB) << "Cmd returns" << m_process->exitCode(); |     qCInfo(LOG_LIB) << "Cmd returns" << m_process->exitCode(); | ||||||
|     QString qdebug = QTextCodec::codecForMib(106) |     QString qdebug | ||||||
|                          ->toUnicode(m_process->readAllStandardError()) |         = QTextCodec::codecForMib(106)->toUnicode(m_process->readAllStandardError()).trimmed(); | ||||||
|                          .trimmed(); |  | ||||||
|     qCInfo(LOG_LIB) << "Error" << qdebug; |     qCInfo(LOG_LIB) << "Error" << qdebug; | ||||||
|     QString qoutput = QTextCodec::codecForMib(106) |     QString qoutput | ||||||
|                           ->toUnicode(m_process->readAllStandardOutput()) |         = QTextCodec::codecForMib(106)->toUnicode(m_process->readAllStandardOutput()).trimmed(); | ||||||
|                           .trimmed(); |  | ||||||
|     qCInfo(LOG_LIB) << "Output" << qoutput; |     qCInfo(LOG_LIB) << "Output" << qoutput; | ||||||
|     QString strValue; |     QString strValue; | ||||||
|  |  | ||||||
|  | |||||||
| @ -37,15 +37,9 @@ class ExtScript : public AbstractExtItem | |||||||
|     Q_PROPERTY(Redirect redirect READ redirect WRITE setRedirect) |     Q_PROPERTY(Redirect redirect READ redirect WRITE setRedirect) | ||||||
|  |  | ||||||
| public: | public: | ||||||
|     enum class Redirect { |     enum class Redirect { stdout2stderr = 0, nothing = 1, stderr2stdout = 2, swap = 3 }; | ||||||
|         stdout2stderr = 0, |  | ||||||
|         nothing = 1, |  | ||||||
|         stderr2stdout = 2, |  | ||||||
|         swap = 3 |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     explicit ExtScript(QWidget *_parent = nullptr, |     explicit ExtScript(QWidget *_parent = nullptr, const QString &_filePath = ""); | ||||||
|                        const QString &_filePath = ""); |  | ||||||
|     virtual ~ExtScript(); |     virtual ~ExtScript(); | ||||||
|     ExtScript *copy(const QString &_fileName, const int _number); |     ExtScript *copy(const QString &_fileName, const int _number); | ||||||
|     QString jsonFiltersFile() const; |     QString jsonFiltersFile() const; | ||||||
|  | |||||||
| @ -63,8 +63,7 @@ ExtUpgrade *ExtUpgrade::copy(const QString &_fileName, const int _number) | |||||||
| { | { | ||||||
|     qCDebug(LOG_LIB) << "File" << _fileName << "with number" << _number; |     qCDebug(LOG_LIB) << "File" << _fileName << "with number" << _number; | ||||||
|  |  | ||||||
|     ExtUpgrade *item |     ExtUpgrade *item = new ExtUpgrade(static_cast<QWidget *>(parent()), _fileName); | ||||||
|         = new ExtUpgrade(static_cast<QWidget *>(parent()), _fileName); |  | ||||||
|     copyDefaults(item); |     copyDefaults(item); | ||||||
|     item->setExecutable(executable()); |     item->setExecutable(executable()); | ||||||
|     item->setFilter(filter()); |     item->setFilter(filter()); | ||||||
| @ -161,8 +160,7 @@ int ExtUpgrade::showConfiguration(const QVariant &_args) | |||||||
|     ui->label_numberValue->setText(QString("%1").arg(number())); |     ui->label_numberValue->setText(QString("%1").arg(number())); | ||||||
|     ui->lineEdit_command->setText(executable()); |     ui->lineEdit_command->setText(executable()); | ||||||
|     ui->lineEdit_filter->setText(filter()); |     ui->lineEdit_filter->setText(filter()); | ||||||
|     ui->checkBox_active->setCheckState(isActive() ? Qt::Checked |     ui->checkBox_active->setCheckState(isActive() ? Qt::Checked : Qt::Unchecked); | ||||||
|                                                   : Qt::Unchecked); |  | ||||||
|     ui->spinBox_null->setValue(null()); |     ui->spinBox_null->setValue(null()); | ||||||
|     ui->lineEdit_schedule->setText(cron()); |     ui->lineEdit_schedule->setText(cron()); | ||||||
|     ui->lineEdit_socket->setText(socket()); |     ui->lineEdit_socket->setText(socket()); | ||||||
| @ -218,16 +216,12 @@ void ExtUpgrade::updateValue() | |||||||
|     qCInfo(LOG_LIB) << "Cmd returns" << m_process->exitCode(); |     qCInfo(LOG_LIB) << "Cmd returns" << m_process->exitCode(); | ||||||
|     qCInfo(LOG_LIB) << "Error" << m_process->readAllStandardError(); |     qCInfo(LOG_LIB) << "Error" << m_process->readAllStandardError(); | ||||||
|  |  | ||||||
|     QString qoutput = QTextCodec::codecForMib(106) |     QString qoutput | ||||||
|                           ->toUnicode(m_process->readAllStandardOutput()) |         = QTextCodec::codecForMib(106)->toUnicode(m_process->readAllStandardOutput()).trimmed(); | ||||||
|                           .trimmed(); |  | ||||||
|     m_values[tag("pkgcount")] = [this](QString output) { |     m_values[tag("pkgcount")] = [this](QString output) { | ||||||
|         return filter().isEmpty() |         return filter().isEmpty() | ||||||
|                    ? output.split('\n', QString::SkipEmptyParts).count() |                    ? output.split('\n', QString::SkipEmptyParts).count() - null() | ||||||
|                          - null() |                    : output.split('\n', QString::SkipEmptyParts).filter(QRegExp(filter())).count(); | ||||||
|                    : output.split('\n', QString::SkipEmptyParts) |  | ||||||
|                          .filter(QRegExp(filter())) |  | ||||||
|                          .count(); |  | ||||||
|     }(qoutput); |     }(qoutput); | ||||||
|  |  | ||||||
|     emit(dataReceived(m_values)); |     emit(dataReceived(m_values)); | ||||||
|  | |||||||
| @ -36,8 +36,7 @@ class ExtUpgrade : public AbstractExtItem | |||||||
|     Q_PROPERTY(int null READ null WRITE setNull) |     Q_PROPERTY(int null READ null WRITE setNull) | ||||||
|  |  | ||||||
| public: | public: | ||||||
|     explicit ExtUpgrade(QWidget *_parent = nullptr, |     explicit ExtUpgrade(QWidget *_parent = nullptr, const QString &_filePath = ""); | ||||||
|                         const QString &_filePath = ""); |  | ||||||
|     virtual ~ExtUpgrade(); |     virtual ~ExtUpgrade(); | ||||||
|     ExtUpgrade *copy(const QString &_fileName, const int _number); |     ExtUpgrade *copy(const QString &_fileName, const int _number); | ||||||
|     // get methods |     // get methods | ||||||
|  | |||||||
| @ -77,8 +77,7 @@ ExtWeather *ExtWeather::copy(const QString &_fileName, const int _number) | |||||||
| { | { | ||||||
|     qCDebug(LOG_LIB) << "File" << _fileName << "number" << _number; |     qCDebug(LOG_LIB) << "File" << _fileName << "number" << _number; | ||||||
|  |  | ||||||
|     ExtWeather *item |     ExtWeather *item = new ExtWeather(static_cast<QWidget *>(parent()), _fileName); | ||||||
|         = new ExtWeather(static_cast<QWidget *>(parent()), _fileName); |  | ||||||
|     copyDefaults(item); |     copyDefaults(item); | ||||||
|     item->setCity(city()); |     item->setCity(city()); | ||||||
|     item->setCountry(country()); |     item->setCountry(country()); | ||||||
| @ -93,8 +92,8 @@ ExtWeather *ExtWeather::copy(const QString &_fileName, const int _number) | |||||||
|  |  | ||||||
| QString ExtWeather::jsonMapFile() const | QString ExtWeather::jsonMapFile() const | ||||||
| { | { | ||||||
|     QString fileName = QStandardPaths::locate( |     QString fileName | ||||||
|         QStandardPaths::GenericDataLocation, |         = QStandardPaths::locate(QStandardPaths::GenericDataLocation, | ||||||
|                                  "awesomewidgets/weather/awesomewidgets-extweather-ids.json"); |                                  "awesomewidgets/weather/awesomewidgets-extweather-ids.json"); | ||||||
|     qCInfo(LOG_LIB) << "Map file" << fileName; |     qCInfo(LOG_LIB) << "Map file" << fileName; | ||||||
|  |  | ||||||
| @ -283,8 +282,7 @@ int ExtWeather::showConfiguration(const QVariant &_args) | |||||||
|     ui->lineEdit_country->setText(country()); |     ui->lineEdit_country->setText(country()); | ||||||
|     ui->spinBox_timestamp->setValue(ts()); |     ui->spinBox_timestamp->setValue(ts()); | ||||||
|     ui->checkBox_image->setCheckState(image() ? Qt::Checked : Qt::Unchecked); |     ui->checkBox_image->setCheckState(image() ? Qt::Checked : Qt::Unchecked); | ||||||
|     ui->checkBox_active->setCheckState(isActive() ? Qt::Checked |     ui->checkBox_active->setCheckState(isActive() ? Qt::Checked : Qt::Unchecked); | ||||||
|                                                   : Qt::Unchecked); |  | ||||||
|     ui->lineEdit_schedule->setText(cron()); |     ui->lineEdit_schedule->setText(cron()); | ||||||
|     ui->lineEdit_socket->setText(socket()); |     ui->lineEdit_socket->setText(socket()); | ||||||
|     ui->spinBox_interval->setValue(interval()); |     ui->spinBox_interval->setValue(interval()); | ||||||
| @ -333,8 +331,7 @@ void ExtWeather::writeConfiguration() const | |||||||
| void ExtWeather::sendRequest() | void ExtWeather::sendRequest() | ||||||
| { | { | ||||||
|     m_isRunning = true; |     m_isRunning = true; | ||||||
|     QNetworkReply *reply |     QNetworkReply *reply = m_manager->get(QNetworkRequest(m_providerObject->url())); | ||||||
|         = m_manager->get(QNetworkRequest(m_providerObject->url())); |  | ||||||
|     new QReplyTimeout(reply, REQUEST_TIMEOUT); |     new QReplyTimeout(reply, REQUEST_TIMEOUT); | ||||||
| } | } | ||||||
|  |  | ||||||
| @ -342,8 +339,8 @@ void ExtWeather::sendRequest() | |||||||
| void ExtWeather::weatherReplyReceived(QNetworkReply *_reply) | void ExtWeather::weatherReplyReceived(QNetworkReply *_reply) | ||||||
| { | { | ||||||
|     if (_reply->error() != QNetworkReply::NoError) { |     if (_reply->error() != QNetworkReply::NoError) { | ||||||
|         qCWarning(LOG_AW) << "An error occurs" << _reply->error() |         qCWarning(LOG_AW) << "An error occurs" << _reply->error() << "with message" | ||||||
|                           << "with message" << _reply->errorString(); |                           << _reply->errorString(); | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @ -360,8 +357,7 @@ void ExtWeather::weatherReplyReceived(QNetworkReply *_reply) | |||||||
|     if (data.isEmpty()) |     if (data.isEmpty()) | ||||||
|         return; |         return; | ||||||
|     m_values = data; |     m_values = data; | ||||||
|     m_values[tag("weather")] |     m_values[tag("weather")] = weatherFromInt(m_values[tag("weatherId")].toInt()); | ||||||
|         = weatherFromInt(m_values[tag("weatherId")].toInt()); |  | ||||||
|  |  | ||||||
|     emit(dataReceived(m_values)); |     emit(dataReceived(m_values)); | ||||||
| } | } | ||||||
| @ -373,10 +369,10 @@ void ExtWeather::initProvider() | |||||||
|  |  | ||||||
|     switch (m_provider) { |     switch (m_provider) { | ||||||
|     case Provider::OWM: |     case Provider::OWM: | ||||||
|         m_providerObject = new OWMWeatherProvider(this, number()); |         m_providerObject = new OWMWeatherProvider(this); | ||||||
|         break; |         break; | ||||||
|     case Provider::Yahoo: |     case Provider::Yahoo: | ||||||
|         m_providerObject = new YahooWeatherProvider(this, number()); |         m_providerObject = new YahooWeatherProvider(this); | ||||||
|         break; |         break; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  | |||||||
| @ -42,8 +42,7 @@ class ExtWeather : public AbstractExtItem | |||||||
| public: | public: | ||||||
|     enum class Provider { OWM = 0, Yahoo = 1 }; |     enum class Provider { OWM = 0, Yahoo = 1 }; | ||||||
|  |  | ||||||
|     explicit ExtWeather(QWidget *_parent = nullptr, |     explicit ExtWeather(QWidget *_parent = nullptr, const QString &_filePath = ""); | ||||||
|                         const QString &_filePath = ""); |  | ||||||
|     virtual ~ExtWeather(); |     virtual ~ExtWeather(); | ||||||
|     ExtWeather *copy(const QString &_fileName, const int _number); |     ExtWeather *copy(const QString &_fileName, const int _number); | ||||||
|     QString jsonMapFile() const; |     QString jsonMapFile() const; | ||||||
| @ -76,8 +75,8 @@ private slots: | |||||||
|     void weatherReplyReceived(QNetworkReply *_reply); |     void weatherReplyReceived(QNetworkReply *_reply); | ||||||
|  |  | ||||||
| private: | private: | ||||||
|     QNetworkAccessManager *m_manager = nullptr; |  | ||||||
|     AbstractWeatherProvider *m_providerObject = nullptr; |     AbstractWeatherProvider *m_providerObject = nullptr; | ||||||
|  |     QNetworkAccessManager *m_manager = nullptr; | ||||||
|     bool m_isRunning = false; |     bool m_isRunning = false; | ||||||
|     Ui::ExtWeather *ui = nullptr; |     Ui::ExtWeather *ui = nullptr; | ||||||
|     void initProvider(); |     void initProvider(); | ||||||
|  | |||||||
| @ -56,14 +56,10 @@ GraphicalItem::GraphicalItem(QWidget *_parent, const QString &_filePath) | |||||||
|     ui->setupUi(this); |     ui->setupUi(this); | ||||||
|     translate(); |     translate(); | ||||||
|  |  | ||||||
|     connect(ui->checkBox_custom, SIGNAL(stateChanged(int)), this, |     connect(ui->checkBox_custom, SIGNAL(stateChanged(int)), this, SLOT(changeValue(int))); | ||||||
|             SLOT(changeValue(int))); |     connect(ui->comboBox_type, SIGNAL(currentIndexChanged(int)), this, SLOT(changeCountState(int))); | ||||||
|     connect(ui->comboBox_type, SIGNAL(currentIndexChanged(int)), this, |     connect(ui->toolButton_activeColor, SIGNAL(clicked()), this, SLOT(changeColor())); | ||||||
|             SLOT(changeCountState(int))); |     connect(ui->toolButton_inactiveColor, SIGNAL(clicked()), this, SLOT(changeColor())); | ||||||
|     connect(ui->toolButton_activeColor, SIGNAL(clicked()), this, |  | ||||||
|             SLOT(changeColor())); |  | ||||||
|     connect(ui->toolButton_inactiveColor, SIGNAL(clicked()), this, |  | ||||||
|             SLOT(changeColor())); |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -79,8 +75,7 @@ GraphicalItem *GraphicalItem::copy(const QString &_fileName, const int _number) | |||||||
| { | { | ||||||
|     qCDebug(LOG_LIB) << "File" << _fileName << "with number" << _number; |     qCDebug(LOG_LIB) << "File" << _fileName << "with number" << _number; | ||||||
|  |  | ||||||
|     GraphicalItem *item |     GraphicalItem *item = new GraphicalItem(static_cast<QWidget *>(parent()), _fileName); | ||||||
|         = new GraphicalItem(static_cast<QWidget *>(parent()), _fileName); |  | ||||||
|     copyDefaults(item); |     copyDefaults(item); | ||||||
|     item->setActiveColor(activeColor()); |     item->setActiveColor(activeColor()); | ||||||
|     item->setBar(bar()); |     item->setBar(bar()); | ||||||
| @ -105,8 +100,7 @@ QString GraphicalItem::image(const QVariant &value) | |||||||
|  |  | ||||||
|     m_scene->clear(); |     m_scene->clear(); | ||||||
|     int scale[2] = {1, 1}; |     int scale[2] = {1, 1}; | ||||||
|     float converted |     float converted = m_helper->getPercents(value.toFloat(), minValue(), maxValue()); | ||||||
|         = m_helper->getPercents(value.toFloat(), minValue(), maxValue()); |  | ||||||
|  |  | ||||||
|     // paint |     // paint | ||||||
|     switch (m_type) { |     switch (m_type) { | ||||||
| @ -138,13 +132,12 @@ QString GraphicalItem::image(const QVariant &value) | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     // convert |     // convert | ||||||
|     QPixmap pixmap |     QPixmap pixmap = m_view->grab().transformed(QTransform().scale(scale[0], scale[1])); | ||||||
|         = m_view->grab().transformed(QTransform().scale(scale[0], scale[1])); |  | ||||||
|     QByteArray byteArray; |     QByteArray byteArray; | ||||||
|     QBuffer buffer(&byteArray); |     QBuffer buffer(&byteArray); | ||||||
|     pixmap.save(&buffer, "PNG"); |     pixmap.save(&buffer, "PNG"); | ||||||
|     QString url = QString("<img src=\"data:image/png;base64,%1\"/>") |     QString url | ||||||
|                       .arg(QString(byteArray.toBase64())); |         = QString("<img src=\"data:image/png;base64,%1\"/>").arg(QString(byteArray.toBase64())); | ||||||
|  |  | ||||||
|     return url; |     return url; | ||||||
| } | } | ||||||
| @ -153,8 +146,7 @@ QString GraphicalItem::image(const QVariant &value) | |||||||
| void GraphicalItem::initScene() | void GraphicalItem::initScene() | ||||||
| { | { | ||||||
|     m_view->resize(m_width + 5, m_height + 5); |     m_view->resize(m_width + 5, m_height + 5); | ||||||
|     m_helper->setParameters(activeColor(), inactiveColor(), itemWidth(), |     m_helper->setParameters(activeColor(), inactiveColor(), itemWidth(), itemHeight(), count()); | ||||||
|                             itemHeight(), count()); |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -426,23 +418,18 @@ void GraphicalItem::readConfiguration() | |||||||
|     setBar(settings.value("X-AW-Value", bar()).toString()); |     setBar(settings.value("X-AW-Value", bar()).toString()); | ||||||
|     setMaxValue(settings.value("X-AW-Max", maxValue()).toFloat()); |     setMaxValue(settings.value("X-AW-Max", maxValue()).toFloat()); | ||||||
|     setMinValue(settings.value("X-AW-Min", minValue()).toFloat()); |     setMinValue(settings.value("X-AW-Min", minValue()).toFloat()); | ||||||
|     setActiveColor( |     setActiveColor(settings.value("X-AW-ActiveColor", activeColor()).toString()); | ||||||
|         settings.value("X-AW-ActiveColor", activeColor()).toString()); |     setInactiveColor(settings.value("X-AW-InactiveColor", inactiveColor()).toString()); | ||||||
|     setInactiveColor( |  | ||||||
|         settings.value("X-AW-InactiveColor", inactiveColor()).toString()); |  | ||||||
|     setStrType(settings.value("X-AW-Type", strType()).toString()); |     setStrType(settings.value("X-AW-Type", strType()).toString()); | ||||||
|     setStrDirection( |     setStrDirection(settings.value("X-AW-Direction", strDirection()).toString()); | ||||||
|         settings.value("X-AW-Direction", strDirection()).toString()); |  | ||||||
|     setItemHeight(settings.value("X-AW-Height", itemHeight()).toInt()); |     setItemHeight(settings.value("X-AW-Height", itemHeight()).toInt()); | ||||||
|     setItemWidth(settings.value("X-AW-Width", itemWidth()).toInt()); |     setItemWidth(settings.value("X-AW-Width", itemWidth()).toInt()); | ||||||
|     // api == 5 |     // api == 5 | ||||||
|     if (apiVersion() < 5) { |     if (apiVersion() < 5) { | ||||||
|         QString prefix; |         QString prefix; | ||||||
|         prefix = activeColor().startsWith("/") ? QString("file://%1") |         prefix = activeColor().startsWith("/") ? QString("file://%1") : QString("color://%1"); | ||||||
|                                                : QString("color://%1"); |  | ||||||
|         m_activeColor = prefix.arg(activeColor()); |         m_activeColor = prefix.arg(activeColor()); | ||||||
|         prefix = inactiveColor().startsWith("/") ? QString("file://%1") |         prefix = inactiveColor().startsWith("/") ? QString("file://%1") : QString("color://%1"); | ||||||
|                                                  : QString("color://%1"); |  | ||||||
|         m_inactiveColor = prefix.arg(inactiveColor()); |         m_inactiveColor = prefix.arg(inactiveColor()); | ||||||
|     } |     } | ||||||
|     settings.endGroup(); |     settings.endGroup(); | ||||||
| @ -487,8 +474,7 @@ int GraphicalItem::showConfiguration(const QVariant &_args) | |||||||
|     ui->spinBox_width->setValue(itemWidth()); |     ui->spinBox_width->setValue(itemWidth()); | ||||||
|  |  | ||||||
|     // update UI |     // update UI | ||||||
|     emit(ui->comboBox_type->currentIndexChanged( |     emit(ui->comboBox_type->currentIndexChanged(ui->comboBox_type->currentIndex())); | ||||||
|         ui->comboBox_type->currentIndex())); |  | ||||||
|     emit(ui->checkBox_custom->stateChanged(ui->checkBox_custom->checkState())); |     emit(ui->checkBox_custom->stateChanged(ui->checkBox_custom->checkState())); | ||||||
|  |  | ||||||
|     int ret = exec(); |     int ret = exec(); | ||||||
| @ -499,15 +485,13 @@ int GraphicalItem::showConfiguration(const QVariant &_args) | |||||||
|     setApiVersion(AW_GRAPHITEM_API); |     setApiVersion(AW_GRAPHITEM_API); | ||||||
|     setCount(ui->spinBox_count->value()); |     setCount(ui->spinBox_count->value()); | ||||||
|     setCustom(ui->checkBox_custom->isChecked()); |     setCustom(ui->checkBox_custom->isChecked()); | ||||||
|     setBar(m_custom ? ui->lineEdit_customValue->text() |     setBar(m_custom ? ui->lineEdit_customValue->text() : ui->comboBox_value->currentText()); | ||||||
|                     : ui->comboBox_value->currentText()); |  | ||||||
|     setMaxValue(ui->doubleSpinBox_max->value()); |     setMaxValue(ui->doubleSpinBox_max->value()); | ||||||
|     setMinValue(ui->doubleSpinBox_min->value()); |     setMinValue(ui->doubleSpinBox_min->value()); | ||||||
|     setActiveColor(ui->lineEdit_activeColor->text()); |     setActiveColor(ui->lineEdit_activeColor->text()); | ||||||
|     setInactiveColor(ui->lineEdit_inactiveColor->text()); |     setInactiveColor(ui->lineEdit_inactiveColor->text()); | ||||||
|     setType(static_cast<Type>(ui->comboBox_type->currentIndex())); |     setType(static_cast<Type>(ui->comboBox_type->currentIndex())); | ||||||
|     setDirection( |     setDirection(static_cast<Direction>(ui->comboBox_direction->currentIndex())); | ||||||
|         static_cast<Direction>(ui->comboBox_direction->currentIndex())); |  | ||||||
|     setItemHeight(ui->spinBox_height->value()); |     setItemHeight(ui->spinBox_height->value()); | ||||||
|     setItemWidth(ui->spinBox_width->value()); |     setItemWidth(ui->spinBox_width->value()); | ||||||
|  |  | ||||||
| @ -557,8 +541,8 @@ void GraphicalItem::changeColor() | |||||||
|     QString outputColor; |     QString outputColor; | ||||||
|     if (state == 0) { |     if (state == 0) { | ||||||
|         QColor color = m_helper->stringToColor(lineEdit->text()); |         QColor color = m_helper->stringToColor(lineEdit->text()); | ||||||
|         QColor newColor = QColorDialog::getColor( |         QColor newColor = QColorDialog::getColor(color, this, i18n("Select color"), | ||||||
|             color, this, i18n("Select color"), QColorDialog::ShowAlphaChannel); |                                                  QColorDialog::ShowAlphaChannel); | ||||||
|         if (!newColor.isValid()) |         if (!newColor.isValid()) | ||||||
|             return; |             return; | ||||||
|         qCInfo(LOG_LIB) << "Selected color" << newColor; |         qCInfo(LOG_LIB) << "Selected color" << newColor; | ||||||
| @ -573,8 +557,8 @@ void GraphicalItem::changeColor() | |||||||
|     } else if (state == 1) { |     } else if (state == 1) { | ||||||
|         QString path = lineEdit->text(); |         QString path = lineEdit->text(); | ||||||
|         QString directory = QFileInfo(path).absolutePath(); |         QString directory = QFileInfo(path).absolutePath(); | ||||||
|         outputColor = QFileDialog::getOpenFileUrl( |         outputColor | ||||||
|                           this, i18n("Select path"), directory, |             = QFileDialog::getOpenFileUrl(this, i18n("Select path"), directory, | ||||||
|                                           i18n("Images (*.png *.bpm *.jpg);;All files (*.*)")) |                                           i18n("Images (*.png *.bpm *.jpg);;All files (*.*)")) | ||||||
|                   .toString(); |                   .toString(); | ||||||
|  |  | ||||||
|  | |||||||
| @ -50,16 +50,9 @@ class GraphicalItem : public AbstractExtItem | |||||||
|  |  | ||||||
| public: | public: | ||||||
|     enum class Direction { LeftToRight = 0, RightToLeft = 1 }; |     enum class Direction { LeftToRight = 0, RightToLeft = 1 }; | ||||||
|     enum class Type { |     enum class Type { Horizontal = 0, Vertical = 1, Circle = 2, Graph = 3, Bars = 4 }; | ||||||
|         Horizontal = 0, |  | ||||||
|         Vertical = 1, |  | ||||||
|         Circle = 2, |  | ||||||
|         Graph = 3, |  | ||||||
|         Bars = 4 |  | ||||||
|     }; |  | ||||||
|  |  | ||||||
|     explicit GraphicalItem(QWidget *_parent = nullptr, |     explicit GraphicalItem(QWidget *_parent = nullptr, const QString &_filePath = ""); | ||||||
|                            const QString &_filePath = ""); |  | ||||||
|     virtual ~GraphicalItem(); |     virtual ~GraphicalItem(); | ||||||
|     GraphicalItem *copy(const QString &_fileName, const int _number); |     GraphicalItem *copy(const QString &_fileName, const int _number); | ||||||
|     QString image(const QVariant &value); |     QString image(const QVariant &value); | ||||||
|  | |||||||
| @ -26,8 +26,7 @@ | |||||||
| #include "awdebug.h" | #include "awdebug.h" | ||||||
|  |  | ||||||
|  |  | ||||||
| GraphicalItemHelper::GraphicalItemHelper(QObject *_parent, | GraphicalItemHelper::GraphicalItemHelper(QObject *_parent, QGraphicsScene *_scene) | ||||||
|                                          QGraphicsScene *_scene) |  | ||||||
|     : QObject(_parent) |     : QObject(_parent) | ||||||
|     , m_scene(_scene) |     , m_scene(_scene) | ||||||
| { | { | ||||||
| @ -41,14 +40,11 @@ GraphicalItemHelper::~GraphicalItemHelper() | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| void GraphicalItemHelper::setParameters(const QString &_active, | void GraphicalItemHelper::setParameters(const QString &_active, const QString &_inactive, | ||||||
|                                         const QString &_inactive, |                                         const int _width, const int _height, const int _count) | ||||||
|                                         const int _width, const int _height, |  | ||||||
|                                         const int _count) |  | ||||||
| { | { | ||||||
|     qCDebug(LOG_LIB) << "Use active color" << _active << ", inactive" |     qCDebug(LOG_LIB) << "Use active color" << _active << ", inactive" << _inactive << ", width" | ||||||
|                      << _inactive << ", width" << _width << ", height" |                      << _width << ", height" << _height << ", count" << _count; | ||||||
|                      << _height << ", count" << _count; |  | ||||||
|  |  | ||||||
|     // put images to pens if any otherwise set pen colors |     // put images to pens if any otherwise set pen colors | ||||||
|     // Images resize to content here as well |     // Images resize to content here as well | ||||||
| @ -67,8 +63,7 @@ void GraphicalItemHelper::setParameters(const QString &_active, | |||||||
|     if (isColor(_inactive)) { |     if (isColor(_inactive)) { | ||||||
|         m_inactivePen.setBrush(QBrush(stringToColor(_inactive))); |         m_inactivePen.setBrush(QBrush(stringToColor(_inactive))); | ||||||
|     } else { |     } else { | ||||||
|         qCInfo(LOG_LIB) << "Found path, trying to load Pixmap from" |         qCInfo(LOG_LIB) << "Found path, trying to load Pixmap from" << _inactive; | ||||||
|                         << _inactive; |  | ||||||
|         QPixmap pixmap = QPixmap(QUrl(_inactive).toLocalFile()); |         QPixmap pixmap = QPixmap(QUrl(_inactive).toLocalFile()); | ||||||
|         if (pixmap.isNull()) { |         if (pixmap.isNull()) { | ||||||
|             qCWarning(LOG_LIB) << "Invalid pixmap found" << _inactive; |             qCWarning(LOG_LIB) << "Invalid pixmap found" << _inactive; | ||||||
| @ -93,8 +88,7 @@ void GraphicalItemHelper::paintBars(const float _value) | |||||||
|     storeValue(_value); |     storeValue(_value); | ||||||
|  |  | ||||||
|     // default norms |     // default norms | ||||||
|     float normX |     float normX = static_cast<float>(m_width) / static_cast<float>(m_values.count()); | ||||||
|         = static_cast<float>(m_width) / static_cast<float>(m_values.count()); |  | ||||||
|     float normY = static_cast<float>(m_height - 1); |     float normY = static_cast<float>(m_height - 1); | ||||||
|     // paint graph |     // paint graph | ||||||
|     for (int i = 0; i < m_values.count(); i++) { |     for (int i = 0; i < m_values.count(); i++) { | ||||||
| @ -118,13 +112,11 @@ void GraphicalItemHelper::paintCircle(const float _percent) | |||||||
|     // Returns the start angle for an ellipse segment in 16ths of a degree |     // Returns the start angle for an ellipse segment in 16ths of a degree | ||||||
|  |  | ||||||
|     // inactive |     // inactive | ||||||
|     circle = m_scene->addEllipse(0.0, 0.0, m_width, m_height, m_inactivePen, |     circle = m_scene->addEllipse(0.0, 0.0, m_width, m_height, m_inactivePen, m_inactivePen.brush()); | ||||||
|                                  m_inactivePen.brush()); |  | ||||||
|     circle->setSpanAngle(-(1.0f - _percent) * 360.0f * 16.0f); |     circle->setSpanAngle(-(1.0f - _percent) * 360.0f * 16.0f); | ||||||
|     circle->setStartAngle(90.0f * 16.0f - _percent * 360.0f * 16.0f); |     circle->setStartAngle(90.0f * 16.0f - _percent * 360.0f * 16.0f); | ||||||
|     // active |     // active | ||||||
|     circle = m_scene->addEllipse(0.0, 0.0, m_width, m_height, m_activePen, |     circle = m_scene->addEllipse(0.0, 0.0, m_width, m_height, m_activePen, m_activePen.brush()); | ||||||
|                                  m_activePen.brush()); |  | ||||||
|     circle->setSpanAngle(-_percent * 360.0f * 16.0f); |     circle->setSpanAngle(-_percent * 360.0f * 16.0f); | ||||||
|     circle->setStartAngle(90 * 16); |     circle->setStartAngle(90 * 16); | ||||||
| } | } | ||||||
| @ -140,8 +132,7 @@ void GraphicalItemHelper::paintGraph(const float _value) | |||||||
|     storeValue(_value); |     storeValue(_value); | ||||||
|  |  | ||||||
|     // default norms |     // default norms | ||||||
|     float normX |     float normX = static_cast<float>(m_width) / static_cast<float>(m_values.count()); | ||||||
|         = static_cast<float>(m_width) / static_cast<float>(m_values.count()); |  | ||||||
|     float normY = static_cast<float>(m_height - 1); |     float normY = static_cast<float>(m_height - 1); | ||||||
|     // paint graph |     // paint graph | ||||||
|     for (int i = 0; i < m_values.count() - 1; i++) { |     for (int i = 0; i < m_values.count() - 1; i++) { | ||||||
| @ -162,12 +153,11 @@ void GraphicalItemHelper::paintHorizontal(const float _percent) | |||||||
|     m_activePen.setWidth(m_height); |     m_activePen.setWidth(m_height); | ||||||
|     m_inactivePen.setWidth(m_height); |     m_inactivePen.setWidth(m_height); | ||||||
|     // inactive |     // inactive | ||||||
|     m_scene->addLine(_percent * m_width + 0.5 * m_height, 0.5 * m_height, |     m_scene->addLine(_percent * m_width + 0.5 * m_height, 0.5 * m_height, m_width + 0.5 * m_height, | ||||||
|                      m_width + 0.5 * m_height, 0.5 * m_height, m_inactivePen); |                      0.5 * m_height, m_inactivePen); | ||||||
|     // active |     // active | ||||||
|     m_scene->addLine(-0.5 * m_height, 0.5 * m_height, |     m_scene->addLine(-0.5 * m_height, 0.5 * m_height, _percent * m_width - 0.5 * m_height, | ||||||
|                      _percent * m_width - 0.5 * m_height, 0.5 * m_height, |                      0.5 * m_height, m_activePen); | ||||||
|                      m_activePen); |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -179,16 +169,14 @@ void GraphicalItemHelper::paintVertical(const float _percent) | |||||||
|     m_inactivePen.setWidth(m_height); |     m_inactivePen.setWidth(m_height); | ||||||
|     // inactive |     // inactive | ||||||
|     m_scene->addLine(0.5 * m_width, -0.5 * m_width, 0.5 * m_width, |     m_scene->addLine(0.5 * m_width, -0.5 * m_width, 0.5 * m_width, | ||||||
|                      (1.0 - _percent) * m_height - 0.5 * m_width, |                      (1.0 - _percent) * m_height - 0.5 * m_width, m_inactivePen); | ||||||
|                      m_inactivePen); |  | ||||||
|     // active |     // active | ||||||
|     m_scene->addLine(0.5 * m_width, (1.0 - _percent) * m_height + 0.5 * m_width, |     m_scene->addLine(0.5 * m_width, (1.0 - _percent) * m_height + 0.5 * m_width, 0.5 * m_width, | ||||||
|                      0.5 * m_width, m_height + 0.5 * m_width, m_activePen); |                      m_height + 0.5 * m_width, m_activePen); | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| float GraphicalItemHelper::getPercents(const float _value, const float _min, | float GraphicalItemHelper::getPercents(const float _value, const float _min, const float _max) | ||||||
|                                        const float _max) |  | ||||||
| { | { | ||||||
|     qCDebug(LOG_LIB) << "Get percent value from" << _value; |     qCDebug(LOG_LIB) << "Get percent value from" << _value; | ||||||
|     // newest Qt crashes here if value is nan |     // newest Qt crashes here if value is nan | ||||||
|  | |||||||
| @ -30,12 +30,11 @@ class GraphicalItemHelper : public QObject | |||||||
|     Q_OBJECT |     Q_OBJECT | ||||||
|  |  | ||||||
| public: | public: | ||||||
|     explicit GraphicalItemHelper(QObject *_parent = nullptr, |     explicit GraphicalItemHelper(QObject *_parent = nullptr, QGraphicsScene *_scene = nullptr); | ||||||
|                                  QGraphicsScene *_scene = nullptr); |  | ||||||
|     virtual ~GraphicalItemHelper(); |     virtual ~GraphicalItemHelper(); | ||||||
|     // parameters |     // parameters | ||||||
|     void setParameters(const QString &_active, const QString &_inactive, |     void setParameters(const QString &_active, const QString &_inactive, const int _width, | ||||||
|                        const int _width, const int _height, const int _count); |                        const int _height, const int _count); | ||||||
|     // paint methods |     // paint methods | ||||||
|     void paintBars(const float _value); |     void paintBars(const float _value); | ||||||
|     void paintCircle(const float _percent); |     void paintCircle(const float _percent); | ||||||
|  | |||||||
| @ -23,8 +23,8 @@ | |||||||
| #include "awdebug.h" | #include "awdebug.h" | ||||||
|  |  | ||||||
|  |  | ||||||
| OWMWeatherProvider::OWMWeatherProvider(QObject *_parent, const int _number) | OWMWeatherProvider::OWMWeatherProvider(QObject *_parent) | ||||||
|     : AbstractWeatherProvider(_parent, _number) |     : AbstractWeatherProvider(_parent) | ||||||
| { | { | ||||||
|     qCDebug(LOG_LIB) << __PRETTY_FUNCTION__; |     qCDebug(LOG_LIB) << __PRETTY_FUNCTION__; | ||||||
| } | } | ||||||
| @ -36,11 +36,9 @@ OWMWeatherProvider::~OWMWeatherProvider() | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| void OWMWeatherProvider::initUrl(const QString &_city, const QString &_country, | void OWMWeatherProvider::initUrl(const QString &_city, const QString &_country, const int ts) | ||||||
|                                  const int ts) |  | ||||||
| { | { | ||||||
|     qCDebug(LOG_LIB) << "Init query for" << _city << _country << "with ts" |     qCDebug(LOG_LIB) << "Init query for" << _city << _country << "with ts" << ts; | ||||||
|                      << ts; |  | ||||||
|  |  | ||||||
|     m_ts = ts; |     m_ts = ts; | ||||||
|  |  | ||||||
| @ -60,8 +58,7 @@ QVariantHash OWMWeatherProvider::parse(const QVariantMap &_json) const | |||||||
|     qCDebug(LOG_LIB) << "Parse json" << _json; |     qCDebug(LOG_LIB) << "Parse json" << _json; | ||||||
|  |  | ||||||
|     if (_json["cod"].toInt() != 200) { |     if (_json["cod"].toInt() != 200) { | ||||||
|         qCWarning(LOG_LIB) << "Invalid OpenWeatherMap return code" |         qCWarning(LOG_LIB) << "Invalid OpenWeatherMap return code" << _json["cod"].toInt(); | ||||||
|                            << _json["cod"].toInt(); |  | ||||||
|         return QVariantHash(); |         return QVariantHash(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @ -91,23 +88,19 @@ QVariantHash OWMWeatherProvider::parseSingleJson(const QVariantMap &_json) const | |||||||
|     QVariantList weather = _json["weather"].toList(); |     QVariantList weather = _json["weather"].toList(); | ||||||
|     if (!weather.isEmpty()) { |     if (!weather.isEmpty()) { | ||||||
|         int id = weather.first().toMap()["id"].toInt(); |         int id = weather.first().toMap()["id"].toInt(); | ||||||
|         output[QString("weatherId%1").arg(number())] = id; |         output[tag("weatherId")] = id; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     // main data |     // main data | ||||||
|     QVariantMap mainWeather = _json["main"].toMap(); |     QVariantMap mainWeather = _json["main"].toMap(); | ||||||
|     if (!weather.isEmpty()) { |     if (!weather.isEmpty()) { | ||||||
|         output[QString("humidity%1").arg(number())] |         output[tag("humidity")] = mainWeather["humidity"].toFloat(); | ||||||
|             = mainWeather["humidity"].toFloat(); |         output[tag("pressure")] = mainWeather["pressure"].toFloat(); | ||||||
|         output[QString("pressure%1").arg(number())] |         output[tag("temperature")] = mainWeather["temp"].toFloat(); | ||||||
|             = mainWeather["pressure"].toFloat(); |  | ||||||
|         output[QString("temperature%1").arg(number())] |  | ||||||
|             = mainWeather["temp"].toFloat(); |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     // timestamp |     // timestamp | ||||||
|     output[QString("timestamp%1").arg(number())] |     output[tag("timestamp")] = QDateTime::fromTime_t(_json["dt"].toUInt()).toUTC(); | ||||||
|         = QDateTime::fromTime_t(_json["dt"].toUInt()).toUTC(); |  | ||||||
|  |  | ||||||
|     return output; |     return output; | ||||||
| } | } | ||||||
|  | |||||||
| @ -31,7 +31,7 @@ public: | |||||||
|     const char *OWM_WEATHER_URL = "https://arcanis.me/weather"; |     const char *OWM_WEATHER_URL = "https://arcanis.me/weather"; | ||||||
|     const char *OWM_FORECAST_URL = "https://arcanis.me/forecast"; |     const char *OWM_FORECAST_URL = "https://arcanis.me/forecast"; | ||||||
|  |  | ||||||
|     explicit OWMWeatherProvider(QObject *_parent, const int _number); |     explicit OWMWeatherProvider(QObject *_parent); | ||||||
|     virtual ~OWMWeatherProvider(); |     virtual ~OWMWeatherProvider(); | ||||||
|     void initUrl(const QString &_city, const QString &_country, const int); |     void initUrl(const QString &_city, const QString &_country, const int); | ||||||
|     QVariantHash parse(const QVariantMap &_json) const; |     QVariantHash parse(const QVariantMap &_json) const; | ||||||
|  | |||||||
| @ -76,11 +76,9 @@ void QCronScheduler::expired() | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| QList<int> QCronScheduler::parseField(const QString &_value, const int _min, | QList<int> QCronScheduler::parseField(const QString &_value, const int _min, const int _max) const | ||||||
|                                       const int _max) const |  | ||||||
| { | { | ||||||
|     qCDebug(LOG_LIB) << "Parse field" << _value << "with corner values" << _min |     qCDebug(LOG_LIB) << "Parse field" << _value << "with corner values" << _min << _max; | ||||||
|                      << _max; |  | ||||||
|  |  | ||||||
|     QList<int> parsed; |     QList<int> parsed; | ||||||
|     auto fields = _value.split(','); |     auto fields = _value.split(','); | ||||||
| @ -89,9 +87,7 @@ QList<int> QCronScheduler::parseField(const QString &_value, const int _min, | |||||||
|         parsedField.fromRange(field.split('/').first(), _min, _max); |         parsedField.fromRange(field.split('/').first(), _min, _max); | ||||||
|         if (field.contains('/')) { |         if (field.contains('/')) { | ||||||
|             bool status; |             bool status; | ||||||
|             parsedField.div = field.split('/', QString::SkipEmptyParts) |             parsedField.div = field.split('/', QString::SkipEmptyParts).at(1).toInt(&status); | ||||||
|                                   .at(1) |  | ||||||
|                                   .toInt(&status); |  | ||||||
|             if (!status) |             if (!status) | ||||||
|                 parsedField.div = 1; |                 parsedField.div = 1; | ||||||
|         } |         } | ||||||
| @ -103,11 +99,9 @@ QList<int> QCronScheduler::parseField(const QString &_value, const int _min, | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| void QCronScheduler::QCronField::fromRange(const QString &_range, | void QCronScheduler::QCronField::fromRange(const QString &_range, const int _min, const int _max) | ||||||
|                                            const int _min, const int _max) |  | ||||||
| { | { | ||||||
|     qCDebug(LOG_LIB) << "Parse field from range" << _range |     qCDebug(LOG_LIB) << "Parse field from range" << _range << "with corner values" << _min << _max; | ||||||
|                      << "with corner values" << _min << _max; |  | ||||||
|  |  | ||||||
|     if (_range == "*") { |     if (_range == "*") { | ||||||
|         minValue = _min; |         minValue = _min; | ||||||
|  | |||||||
| @ -56,8 +56,7 @@ private slots: | |||||||
| private: | private: | ||||||
|     QCronRunSchedule m_schedule; |     QCronRunSchedule m_schedule; | ||||||
|     QTimer *m_timer = nullptr; |     QTimer *m_timer = nullptr; | ||||||
|     QList<int> parseField(const QString &_value, const int _min, |     QList<int> parseField(const QString &_value, const int _min, const int _max) const; | ||||||
|                           const int _max) const; |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | |||||||
| @ -4,7 +4,7 @@ Name=AAPL.NASDAQ | |||||||
| Comment=Apple Inc | Comment=Apple Inc | ||||||
| X-AW-Ticker="AAPL" | X-AW-Ticker="AAPL" | ||||||
| X-AW-Active=false | X-AW-Active=false | ||||||
| X-AW-ApiVersion=4 | X-AW-ApiVersion=5 | ||||||
| X-AW-Interval=60 | X-AW-Interval=60 | ||||||
| X-AW-Number=0 | X-AW-Number=0 | ||||||
| X-AW-Schedule= | X-AW-Schedule= | ||||||
|  | |||||||
| @ -2,9 +2,9 @@ | |||||||
| Encoding=UTF-8 | Encoding=UTF-8 | ||||||
| Name=EUR/RUB | Name=EUR/RUB | ||||||
| Comment=EUR/RUB | Comment=EUR/RUB | ||||||
| X-AW-Ticker="EURRUB=X" | X-AW-Ticker="EURRUB" | ||||||
| X-AW-Active=false | X-AW-Active=false | ||||||
| X-AW-ApiVersion=4 | X-AW-ApiVersion=5 | ||||||
| X-AW-Interval=60 | X-AW-Interval=60 | ||||||
| X-AW-Number=1 | X-AW-Number=1 | ||||||
| X-AW-Schedule= | X-AW-Schedule= | ||||||
|  | |||||||
| @ -2,9 +2,9 @@ | |||||||
| Encoding=UTF-8 | Encoding=UTF-8 | ||||||
| Name=EUR/USD | Name=EUR/USD | ||||||
| Comment=EUR/USD | Comment=EUR/USD | ||||||
| X-AW-Ticker="EURUSD=X" | X-AW-Ticker="EURUSD" | ||||||
| X-AW-Active=false | X-AW-Active=false | ||||||
| X-AW-ApiVersion=4 | X-AW-ApiVersion=5 | ||||||
| X-AW-Interval=60 | X-AW-Interval=60 | ||||||
| X-AW-Number=2 | X-AW-Number=2 | ||||||
| X-AW-Schedule= | X-AW-Schedule= | ||||||
|  | |||||||
| @ -4,7 +4,7 @@ Name=GOOG.NASDAQ | |||||||
| Comment=Google Inc | Comment=Google Inc | ||||||
| X-AW-Ticker="GOOG" | X-AW-Ticker="GOOG" | ||||||
| X-AW-Active=false | X-AW-Active=false | ||||||
| X-AW-ApiVersion=4 | X-AW-ApiVersion=5 | ||||||
| X-AW-Interval=60 | X-AW-Interval=60 | ||||||
| X-AW-Number=3 | X-AW-Number=3 | ||||||
| X-AW-Schedule= | X-AW-Schedule= | ||||||
|  | |||||||
| @ -4,7 +4,7 @@ Name=MSFT.NASDAQ | |||||||
| Comment=Microsoft Corp | Comment=Microsoft Corp | ||||||
| X-AW-Ticker="MSFT" | X-AW-Ticker="MSFT" | ||||||
| X-AW-Active=false | X-AW-Active=false | ||||||
| X-AW-ApiVersion=4 | X-AW-ApiVersion=5 | ||||||
| X-AW-Interval=60 | X-AW-Interval=60 | ||||||
| X-AW-Number=4 | X-AW-Number=4 | ||||||
| X-AW-Schedule= | X-AW-Schedule= | ||||||
|  | |||||||
| @ -2,10 +2,10 @@ | |||||||
| Encoding=UTF-8 | Encoding=UTF-8 | ||||||
| Name=RTS | Name=RTS | ||||||
| Comment=RTS Index | Comment=RTS Index | ||||||
| X-AW-Ticker="RTS.RS" | X-AW-Ticker="^RTS" | ||||||
| X-AW-Active=false | X-AW-Active=false | ||||||
| X-AW-ApiVersion=4 | X-AW-ApiVersion=5 | ||||||
| X-AW-Interval=60 | X-AW-Interval=60 | ||||||
| X-AW-Number=5 | X-AW-Number=4 | ||||||
| X-AW-Schedule= | X-AW-Schedule= | ||||||
| X-AW-Socket= | X-AW-Socket= | ||||||
|  | |||||||
| @ -1,11 +0,0 @@ | |||||||
| [Desktop Entry] |  | ||||||
| Encoding=UTF-8 |  | ||||||
| Name=S&P |  | ||||||
| Comment=S&P 500 Index |  | ||||||
| X-AW-Ticker="^GSPC" |  | ||||||
| X-AW-Active=false |  | ||||||
| X-AW-ApiVersion=4 |  | ||||||
| X-AW-Interval=60 |  | ||||||
| X-AW-Number=6 |  | ||||||
| X-AW-Schedule= |  | ||||||
| X-AW-Socket= |  | ||||||
| @ -2,9 +2,9 @@ | |||||||
| Encoding=UTF-8 | Encoding=UTF-8 | ||||||
| Name=USD/RUB | Name=USD/RUB | ||||||
| Comment=USD/RUB | Comment=USD/RUB | ||||||
| X-AW-Ticker="USDRUB=X" | X-AW-Ticker="USDRUB" | ||||||
| X-AW-Active=false | X-AW-Active=false | ||||||
| X-AW-ApiVersion=4 | X-AW-ApiVersion=5 | ||||||
| X-AW-Interval=60 | X-AW-Interval=60 | ||||||
| X-AW-Number=8 | X-AW-Number=8 | ||||||
| X-AW-Schedule= | X-AW-Schedule= | ||||||
|  | |||||||
| @ -1,11 +0,0 @@ | |||||||
| [Desktop Entry] |  | ||||||
| Encoding=UTF-8 |  | ||||||
| Name=VIX |  | ||||||
| Comment=Volatility S&P 500 |  | ||||||
| X-AW-Ticker="^VIX" |  | ||||||
| X-AW-Active=false |  | ||||||
| X-AW-ApiVersion=4 |  | ||||||
| X-AW-Interval=60 |  | ||||||
| X-AW-Number=7 |  | ||||||
| X-AW-Schedule= |  | ||||||
| X-AW-Socket= |  | ||||||
							
								
								
									
										88
									
								
								sources/awesomewidgets/stooqquotesprovider.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										88
									
								
								sources/awesomewidgets/stooqquotesprovider.cpp
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,88 @@ | |||||||
|  | /*************************************************************************** | ||||||
|  |  *   This file is part of awesome-widgets                                  * | ||||||
|  |  *                                                                         * | ||||||
|  |  *   awesome-widgets is free software: you can redistribute it and/or      * | ||||||
|  |  *   modify it under the terms of the GNU General Public License as        * | ||||||
|  |  *   published by the Free Software Foundation, either version 3 of the    * | ||||||
|  |  *   License, or (at your option) any later version.                       * | ||||||
|  |  *                                                                         * | ||||||
|  |  *   awesome-widgets is distributed in the hope that it will be useful,    * | ||||||
|  |  *   but WITHOUT ANY WARRANTY; without even the implied warranty of        * | ||||||
|  |  *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         * | ||||||
|  |  *   GNU General Public License for more details.                          * | ||||||
|  |  *                                                                         * | ||||||
|  |  *   You should have received a copy of the GNU General Public License     * | ||||||
|  |  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||||
|  |  ***************************************************************************/ | ||||||
|  |  | ||||||
|  | #include "stooqquotesprovider.h" | ||||||
|  |  | ||||||
|  | #include <QTextCodec> | ||||||
|  | #include <QUrlQuery> | ||||||
|  |  | ||||||
|  | #include "awdebug.h" | ||||||
|  |  | ||||||
|  |  | ||||||
|  | StooqQuotesProvider::StooqQuotesProvider(QObject *_parent) | ||||||
|  |     : AbstractQuotesProvider(_parent) | ||||||
|  | { | ||||||
|  |     qCDebug(LOG_LIB) << __PRETTY_FUNCTION__; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | StooqQuotesProvider::~StooqQuotesProvider() | ||||||
|  | { | ||||||
|  |     qCDebug(LOG_LIB) << __PRETTY_FUNCTION__; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | void StooqQuotesProvider::initUrl(const QString &_asset) | ||||||
|  | { | ||||||
|  |     qCDebug(LOG_LIB) << "Init query for" << _asset; | ||||||
|  |  | ||||||
|  |     m_url = QUrl(STOOQ_QUOTES_URL); | ||||||
|  |     QUrlQuery params; | ||||||
|  |     params.addQueryItem("s", _asset); | ||||||
|  |     params.addQueryItem("f", "pv"); | ||||||
|  |     params.addQueryItem("e", "csv"); | ||||||
|  |     m_url.setQuery(params); | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | QVariantHash StooqQuotesProvider::parse(const QByteArray &_source, | ||||||
|  |                                         const QVariantHash &_oldValues) const | ||||||
|  | { | ||||||
|  |     qCDebug(LOG_LIB) << "Parse csv" << _source; | ||||||
|  |  | ||||||
|  |     QVariantHash values; | ||||||
|  |  | ||||||
|  |     QStringList sourceValues | ||||||
|  |         = QTextCodec::codecForMib(106)->toUnicode(_source).trimmed().split(','); | ||||||
|  |     if (sourceValues.count() != 2) { | ||||||
|  |         qCWarning(LOG_LIB) << "Parse error" << sourceValues; | ||||||
|  |         return values; | ||||||
|  |     } | ||||||
|  |  | ||||||
|  |     // extract old data | ||||||
|  |     auto oldPrice = _oldValues[tag("price")].toDouble(); | ||||||
|  |     auto oldVolume = _oldValues[tag("volume")].toInt(); | ||||||
|  |  | ||||||
|  |     // last trade | ||||||
|  |     auto price = sourceValues.at(0).toDouble(); | ||||||
|  |     values[tag("pricechg")] = oldPrice == 0.0 ? 0.0 : price - oldPrice; | ||||||
|  |     values[tag("percpricechg")] = 100.0 * values[tag("pricechg")].toDouble() / price; | ||||||
|  |     values[tag("price")] = price; | ||||||
|  |     // volume | ||||||
|  |     auto volume = sourceValues.at(1).toInt(); | ||||||
|  |     values[tag("volumechg")] = oldVolume == 0 ? 0 : volume - oldVolume; | ||||||
|  |     values[tag("percvolumechg")] = 100.0 * values[tag("volumechg")].toDouble() / volume; | ||||||
|  |     values[tag("volume")] = volume; | ||||||
|  |  | ||||||
|  |     return values; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | QUrl StooqQuotesProvider::url() const | ||||||
|  | { | ||||||
|  |     return m_url; | ||||||
|  | } | ||||||
							
								
								
									
										42
									
								
								sources/awesomewidgets/stooqquotesprovider.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										42
									
								
								sources/awesomewidgets/stooqquotesprovider.h
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,42 @@ | |||||||
|  | /*************************************************************************** | ||||||
|  |  *   This file is part of awesome-widgets                                  * | ||||||
|  |  *                                                                         * | ||||||
|  |  *   awesome-widgets is free software: you can redistribute it and/or      * | ||||||
|  |  *   modify it under the terms of the GNU General Public License as        * | ||||||
|  |  *   published by the Free Software Foundation, either version 3 of the    * | ||||||
|  |  *   License, or (at your option) any later version.                       * | ||||||
|  |  *                                                                         * | ||||||
|  |  *   awesome-widgets is distributed in the hope that it will be useful,    * | ||||||
|  |  *   but WITHOUT ANY WARRANTY; without even the implied warranty of        * | ||||||
|  |  *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         * | ||||||
|  |  *   GNU General Public License for more details.                          * | ||||||
|  |  *                                                                         * | ||||||
|  |  *   You should have received a copy of the GNU General Public License     * | ||||||
|  |  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||||
|  |  ***************************************************************************/ | ||||||
|  |  | ||||||
|  | #ifndef STOOQQUOTESPROVIDER_H | ||||||
|  | #define STOOQQUOTESPROVIDER_H | ||||||
|  |  | ||||||
|  | #include "abstractquotesprovider.h" | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class StooqQuotesProvider : public AbstractQuotesProvider | ||||||
|  | { | ||||||
|  |     Q_OBJECT | ||||||
|  |  | ||||||
|  | public: | ||||||
|  |     const char *STOOQ_QUOTES_URL = "https://stooq.com/q/l/"; | ||||||
|  |  | ||||||
|  |     explicit StooqQuotesProvider(QObject *_parent); | ||||||
|  |     virtual ~StooqQuotesProvider(); | ||||||
|  |     void initUrl(const QString &_asset); | ||||||
|  |     QVariantHash parse(const QByteArray &_source, const QVariantHash &_oldValues) const; | ||||||
|  |     QUrl url() const; | ||||||
|  |  | ||||||
|  | private: | ||||||
|  |     QUrl m_url; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | #endif /* STOOQQUOTESPROVIDER_H */ | ||||||
							
								
								
									
										88
									
								
								sources/awesomewidgets/yahooquotesprovider.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										88
									
								
								sources/awesomewidgets/yahooquotesprovider.cpp
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,88 @@ | |||||||
|  | /*************************************************************************** | ||||||
|  |  *   This file is part of awesome-widgets                                  * | ||||||
|  |  *                                                                         * | ||||||
|  |  *   awesome-widgets is free software: you can redistribute it and/or      * | ||||||
|  |  *   modify it under the terms of the GNU General Public License as        * | ||||||
|  |  *   published by the Free Software Foundation, either version 3 of the    * | ||||||
|  |  *   License, or (at your option) any later version.                       * | ||||||
|  |  *                                                                         * | ||||||
|  |  *   awesome-widgets is distributed in the hope that it will be useful,    * | ||||||
|  |  *   but WITHOUT ANY WARRANTY; without even the implied warranty of        * | ||||||
|  |  *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         * | ||||||
|  |  *   GNU General Public License for more details.                          * | ||||||
|  |  *                                                                         * | ||||||
|  |  *   You should have received a copy of the GNU General Public License     * | ||||||
|  |  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||||
|  |  ***************************************************************************/ | ||||||
|  |  | ||||||
|  | #include "yahooquotesprovider.h" | ||||||
|  |  | ||||||
|  | #include <QJsonDocument> | ||||||
|  | #include <QUrlQuery> | ||||||
|  |  | ||||||
|  | #include "awdebug.h" | ||||||
|  |  | ||||||
|  |  | ||||||
|  | YahooQuotesProvider::YahooQuotesProvider(QObject *_parent) | ||||||
|  |     : AbstractQuotesProvider(_parent) | ||||||
|  | { | ||||||
|  |     qCDebug(LOG_LIB) << __PRETTY_FUNCTION__; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | YahooQuotesProvider::~YahooQuotesProvider() | ||||||
|  | { | ||||||
|  |     qCDebug(LOG_LIB) << __PRETTY_FUNCTION__; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | void YahooQuotesProvider::initUrl(const QString &_asset) | ||||||
|  | { | ||||||
|  |     qCDebug(LOG_LIB) << "Init query for" << _asset; | ||||||
|  |  | ||||||
|  |     m_url = QUrl(YAHOO_QUOTES_URL); | ||||||
|  |     QUrlQuery params; | ||||||
|  |     params.addQueryItem("format", "json"); | ||||||
|  |     params.addQueryItem("env", "store://datatables.org/alltableswithkeys"); | ||||||
|  |     params.addQueryItem("q", QString(YAHOO_QUOTES_QUERY).arg(_asset)); | ||||||
|  |     m_url.setQuery(params); | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | QVariantHash YahooQuotesProvider::parse(const QByteArray &_source, | ||||||
|  |                                         const QVariantHash &_oldValues) const | ||||||
|  | { | ||||||
|  |     qCDebug(LOG_LIB) << "Parse json" << _source; | ||||||
|  |  | ||||||
|  |     QVariantHash values; | ||||||
|  |  | ||||||
|  |     QJsonParseError error; | ||||||
|  |     QJsonDocument jsonDoc = QJsonDocument::fromJson(_source, &error); | ||||||
|  |     if (error.error != QJsonParseError::NoError) { | ||||||
|  |         qCWarning(LOG_LIB) << "Parse error" << error.errorString(); | ||||||
|  |         return values; | ||||||
|  |     } | ||||||
|  |     QVariantMap jsonQuotes = jsonDoc.toVariant().toMap()["query"].toMap(); | ||||||
|  |     jsonQuotes = jsonQuotes["results"].toMap()["quote"].toMap(); | ||||||
|  |  | ||||||
|  |     // extract old data | ||||||
|  |     auto oldPrice = _oldValues[tag("price")].toDouble(); | ||||||
|  |  | ||||||
|  |     // last trade | ||||||
|  |     auto value = jsonQuotes["LastTradePriceOnly"].toString().toDouble(); | ||||||
|  |     values[tag("pricechg")] = oldPrice == 0.0 ? 0.0 : value - oldPrice; | ||||||
|  |     values[tag("percpricechg")] = 100.0 * values[tag("pricechg")].toDouble() / value; | ||||||
|  |     values[tag("price")] = value; | ||||||
|  |     // volume | ||||||
|  |     values[tag("volume")] = 0; | ||||||
|  |     values[tag("volumechg")] = 0; | ||||||
|  |     values[tag("percvolumechg")] = 0.0; | ||||||
|  |  | ||||||
|  |     return values; | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | QUrl YahooQuotesProvider::url() const | ||||||
|  | { | ||||||
|  |     return m_url; | ||||||
|  | } | ||||||
							
								
								
									
										43
									
								
								sources/awesomewidgets/yahooquotesprovider.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										43
									
								
								sources/awesomewidgets/yahooquotesprovider.h
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,43 @@ | |||||||
|  | /*************************************************************************** | ||||||
|  |  *   This file is part of awesome-widgets                                  * | ||||||
|  |  *                                                                         * | ||||||
|  |  *   awesome-widgets is free software: you can redistribute it and/or      * | ||||||
|  |  *   modify it under the terms of the GNU General Public License as        * | ||||||
|  |  *   published by the Free Software Foundation, either version 3 of the    * | ||||||
|  |  *   License, or (at your option) any later version.                       * | ||||||
|  |  *                                                                         * | ||||||
|  |  *   awesome-widgets is distributed in the hope that it will be useful,    * | ||||||
|  |  *   but WITHOUT ANY WARRANTY; without even the implied warranty of        * | ||||||
|  |  *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the         * | ||||||
|  |  *   GNU General Public License for more details.                          * | ||||||
|  |  *                                                                         * | ||||||
|  |  *   You should have received a copy of the GNU General Public License     * | ||||||
|  |  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||||
|  |  ***************************************************************************/ | ||||||
|  |  | ||||||
|  | #ifndef YAHOOQUOTESPROVIDER_H | ||||||
|  | #define YAHOOQUOTESPROVIDER_H | ||||||
|  |  | ||||||
|  | #include "abstractquotesprovider.h" | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class YahooQuotesProvider : public AbstractQuotesProvider | ||||||
|  | { | ||||||
|  |     Q_OBJECT | ||||||
|  |  | ||||||
|  | public: | ||||||
|  |     const char *YAHOO_QUOTES_URL = "https://query.yahooapis.com/v1/public/yql"; | ||||||
|  |     const char *YAHOO_QUOTES_QUERY = "select * from yahoo.finance.quotes where symbol='%1'"; | ||||||
|  |  | ||||||
|  |     explicit YahooQuotesProvider(QObject *_parent); | ||||||
|  |     virtual ~YahooQuotesProvider(); | ||||||
|  |     void initUrl(const QString &_asset); | ||||||
|  |     QVariantHash parse(const QByteArray &_source, const QVariantHash &_oldValues) const; | ||||||
|  |     QUrl url() const; | ||||||
|  |  | ||||||
|  | private: | ||||||
|  |     QUrl m_url; | ||||||
|  | }; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | #endif /* YAHOOQUOTESPROVIDER_H */ | ||||||
| @ -22,8 +22,8 @@ | |||||||
| #include "awdebug.h" | #include "awdebug.h" | ||||||
|  |  | ||||||
|  |  | ||||||
| YahooWeatherProvider::YahooWeatherProvider(QObject *_parent, const int _number) | YahooWeatherProvider::YahooWeatherProvider(QObject *_parent) | ||||||
|     : AbstractWeatherProvider(_parent, _number) |     : AbstractWeatherProvider(_parent) | ||||||
| { | { | ||||||
|     qCDebug(LOG_LIB) << __PRETTY_FUNCTION__; |     qCDebug(LOG_LIB) << __PRETTY_FUNCTION__; | ||||||
| } | } | ||||||
| @ -35,11 +35,9 @@ YahooWeatherProvider::~YahooWeatherProvider() | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| void YahooWeatherProvider::initUrl(const QString &_city, | void YahooWeatherProvider::initUrl(const QString &_city, const QString &_country, const int ts) | ||||||
|                                    const QString &_country, const int ts) |  | ||||||
| { | { | ||||||
|     qCDebug(LOG_LIB) << "Init query for" << _city << _country << "with ts" |     qCDebug(LOG_LIB) << "Init query for" << _city << _country << "with ts" << ts; | ||||||
|                      << ts; |  | ||||||
|  |  | ||||||
|     m_ts = ts; |     m_ts = ts; | ||||||
|  |  | ||||||
| @ -58,8 +56,7 @@ QVariantHash YahooWeatherProvider::parse(const QVariantMap &_json) const | |||||||
|  |  | ||||||
|     QVariantMap jsonMap = _json["query"].toMap(); |     QVariantMap jsonMap = _json["query"].toMap(); | ||||||
|     if (jsonMap["count"].toInt() != 1) { |     if (jsonMap["count"].toInt() != 1) { | ||||||
|         qCWarning(LOG_LIB) << "Found data count" << _json["count"].toInt() |         qCWarning(LOG_LIB) << "Found data count" << _json["count"].toInt() << "is not 1"; | ||||||
|                            << "is not 1"; |  | ||||||
|         return QVariantHash(); |         return QVariantHash(); | ||||||
|     } |     } | ||||||
|     QVariantMap results = jsonMap["results"].toMap()["channel"].toMap(); |     QVariantMap results = jsonMap["results"].toMap()["channel"].toMap(); | ||||||
| @ -76,8 +73,7 @@ QUrl YahooWeatherProvider::url() const | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| QVariantHash | QVariantHash YahooWeatherProvider::parseCurrent(const QVariantMap &_json, | ||||||
| YahooWeatherProvider::parseCurrent(const QVariantMap &_json, |  | ||||||
|                                                 const QVariantMap &_atmosphere) const |                                                 const QVariantMap &_atmosphere) const | ||||||
| { | { | ||||||
|     qCDebug(LOG_LIB) << "Parse current weather from" << _json; |     qCDebug(LOG_LIB) << "Parse current weather from" << _json; | ||||||
| @ -86,14 +82,12 @@ YahooWeatherProvider::parseCurrent(const QVariantMap &_json, | |||||||
|  |  | ||||||
|     QVariantHash values; |     QVariantHash values; | ||||||
|     int id = _json["condition"].toMap()["code"].toInt(); |     int id = _json["condition"].toMap()["code"].toInt(); | ||||||
|     values[QString("weatherId%1").arg(number())] = id; |     values[tag("weatherId")] = id; | ||||||
|     values[QString("temperature%1").arg(number())] = condition["temp"].toInt(); |     values[tag("temperature")] = condition["temp"].toInt(); | ||||||
|     values[QString("timestamp%1").arg(number())] = condition["date"].toString(); |     values[tag("timestamp")] = condition["date"].toString(); | ||||||
|     values[QString("humidity%1").arg(number())] |     values[tag("humidity")] = _atmosphere["humidity"].toInt(); | ||||||
|         = _atmosphere["humidity"].toInt(); |  | ||||||
|     // HACK temporary fix of invalid values on Yahoo! side |     // HACK temporary fix of invalid values on Yahoo! side | ||||||
|     values[QString("pressure%1").arg(number())] |     values[tag("pressure")] = static_cast<int>(_atmosphere["pressure"].toFloat() / 33.863753); | ||||||
|         = static_cast<int>(_atmosphere["pressure"].toFloat() / 33.863753); |  | ||||||
|  |  | ||||||
|     return values; |     return values; | ||||||
| } | } | ||||||
| @ -105,19 +99,16 @@ QVariantHash YahooWeatherProvider::parseForecast(const QVariantMap &_json) const | |||||||
|  |  | ||||||
|     QVariantHash values; |     QVariantHash values; | ||||||
|     QVariantList weatherList = _json["forecast"].toList(); |     QVariantList weatherList = _json["forecast"].toList(); | ||||||
|     QVariantMap weatherMap = weatherList.count() < m_ts |     QVariantMap weatherMap | ||||||
|                                  ? weatherList.last().toMap() |         = weatherList.count() < m_ts ? weatherList.last().toMap() : weatherList.at(m_ts).toMap(); | ||||||
|                                  : weatherList.at(m_ts).toMap(); |  | ||||||
|     int id = weatherMap["code"].toInt(); |     int id = weatherMap["code"].toInt(); | ||||||
|     values[QString("weatherId%1").arg(number())] = id; |     values[tag("weatherId")] = id; | ||||||
|     values[QString("timestamp%1").arg(number())] |     values[tag("timestamp")] = weatherMap["date"].toString(); | ||||||
|         = weatherMap["date"].toString(); |  | ||||||
|     // yahoo provides high and low temperatures. Lets calculate average one |     // yahoo provides high and low temperatures. Lets calculate average one | ||||||
|     values[QString("temperature%1").arg(number())] |     values[tag("temperature")] = (weatherMap["high"].toFloat() + weatherMap["low"].toFloat()) / 2.0; | ||||||
|         = (weatherMap["high"].toFloat() + weatherMap["low"].toFloat()) / 2.0; |  | ||||||
|     // ... and no forecast data for humidity and pressure |     // ... and no forecast data for humidity and pressure | ||||||
|     values[QString("humidity%1").arg(number())] = 0; |     values[tag("humidity")] = 0; | ||||||
|     values[QString("pressure%1").arg(number())] = 0.0; |     values[tag("pressure")] = 0.0; | ||||||
|  |  | ||||||
|     return values; |     return values; | ||||||
| } | } | ||||||
|  | |||||||
| @ -31,15 +31,14 @@ public: | |||||||
|                                       "u='c' and woeid in (select woeid from " |                                       "u='c' and woeid in (select woeid from " | ||||||
|                                       "geo.places(1) where text='%1, %2')"; |                                       "geo.places(1) where text='%1, %2')"; | ||||||
|  |  | ||||||
|     explicit YahooWeatherProvider(QObject *_parent, const int _number); |     explicit YahooWeatherProvider(QObject *_parent); | ||||||
|     virtual ~YahooWeatherProvider(); |     virtual ~YahooWeatherProvider(); | ||||||
|     void initUrl(const QString &_city, const QString &_country, const int); |     void initUrl(const QString &_city, const QString &_country, const int); | ||||||
|     QVariantHash parse(const QVariantMap &_json) const; |     QVariantHash parse(const QVariantMap &_json) const; | ||||||
|     QUrl url() const; |     QUrl url() const; | ||||||
|  |  | ||||||
| private: | private: | ||||||
|     QVariantHash parseCurrent(const QVariantMap &_json, |     QVariantHash parseCurrent(const QVariantMap &_json, const QVariantMap &_atmosphere) const; | ||||||
|                               const QVariantMap &_atmosphere) const; |  | ||||||
|     QVariantHash parseForecast(const QVariantMap &_json) const; |     QVariantHash parseForecast(const QVariantMap &_json) const; | ||||||
|     int m_ts = 0; |     int m_ts = 0; | ||||||
|     QUrl m_url; |     QUrl m_url; | ||||||
|  | |||||||
| @ -44,10 +44,8 @@ DPAdds::DPAdds(QObject *_parent) | |||||||
|  |  | ||||||
|     connect(KWindowSystem::self(), SIGNAL(currentDesktopChanged(int)), this, |     connect(KWindowSystem::self(), SIGNAL(currentDesktopChanged(int)), this, | ||||||
|             SIGNAL(desktopChanged())); |             SIGNAL(desktopChanged())); | ||||||
|     connect(KWindowSystem::self(), SIGNAL(windowAdded(WId)), this, |     connect(KWindowSystem::self(), SIGNAL(windowAdded(WId)), this, SIGNAL(windowListChanged())); | ||||||
|             SIGNAL(windowListChanged())); |     connect(KWindowSystem::self(), SIGNAL(windowRemoved(WId)), this, SIGNAL(windowListChanged())); | ||||||
|     connect(KWindowSystem::self(), SIGNAL(windowRemoved(WId)), this, |  | ||||||
|             SIGNAL(windowListChanged())); |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -72,8 +70,7 @@ int DPAdds::currentDesktop() const | |||||||
|  |  | ||||||
| QStringList DPAdds::dictKeys(const bool _sorted, const QString &_regexp) const | QStringList DPAdds::dictKeys(const bool _sorted, const QString &_regexp) const | ||||||
| { | { | ||||||
|     qCDebug(LOG_DP) << "Should be sorted" << _sorted << "and filter applied" |     qCDebug(LOG_DP) << "Should be sorted" << _sorted << "and filter applied" << _regexp; | ||||||
|                     << _regexp; |  | ||||||
|  |  | ||||||
|     QStringList allKeys; |     QStringList allKeys; | ||||||
|     allKeys.append("mark"); |     allKeys.append("mark"); | ||||||
| @ -106,11 +103,9 @@ QString DPAdds::toolTipImage(const int _desktop) const | |||||||
|     // special tooltip format for names |     // special tooltip format for names | ||||||
|     if (m_tooltipType == "names") { |     if (m_tooltipType == "names") { | ||||||
|         QStringList windowList; |         QStringList windowList; | ||||||
|         std::for_each( |         std::for_each(info.windowsData.cbegin(), info.windowsData.cend(), | ||||||
|             info.windowsData.cbegin(), info.windowsData.cend(), |  | ||||||
|                       [&windowList](WindowData data) { windowList.append(data.name); }); |                       [&windowList](WindowData data) { windowList.append(data.name); }); | ||||||
|         return QString("<ul><li>%1</li></ul>") |         return QString("<ul><li>%1</li></ul>").arg(windowList.join("</li><li>")); | ||||||
|             .arg(windowList.join("</li><li>")); |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     // init |     // init | ||||||
| @ -133,8 +128,7 @@ QString DPAdds::toolTipImage(const int _desktop) const | |||||||
|     toolTipScene->addLine(0, info.desktop.height() + 2.0 * margin, |     toolTipScene->addLine(0, info.desktop.height() + 2.0 * margin, | ||||||
|                           info.desktop.width() + 2.0 * margin, |                           info.desktop.width() + 2.0 * margin, | ||||||
|                           info.desktop.height() + 2.0 * margin); |                           info.desktop.height() + 2.0 * margin); | ||||||
|     toolTipScene->addLine(info.desktop.width() + 2.0 * margin, |     toolTipScene->addLine(info.desktop.width() + 2.0 * margin, info.desktop.height() + 2.0 * margin, | ||||||
|                           info.desktop.height() + 2.0 * margin, |  | ||||||
|                           info.desktop.width() + 2.0 * margin, 0); |                           info.desktop.width() + 2.0 * margin, 0); | ||||||
|     toolTipScene->addLine(info.desktop.width() + 2.0 * margin, 0, 0, 0); |     toolTipScene->addLine(info.desktop.width() + 2.0 * margin, 0, 0, 0); | ||||||
|  |  | ||||||
| @ -145,39 +139,35 @@ QString DPAdds::toolTipImage(const int _desktop) const | |||||||
|         for (auto &data : info.windowsData) { |         for (auto &data : info.windowsData) { | ||||||
|             QRect rect = data.rect; |             QRect rect = data.rect; | ||||||
|             toolTipScene->addLine(rect.left() + margin, rect.bottom() + margin, |             toolTipScene->addLine(rect.left() + margin, rect.bottom() + margin, | ||||||
|                                   rect.left() + margin, rect.top() + margin, |                                   rect.left() + margin, rect.top() + margin, pen); | ||||||
|                                   pen); |             toolTipScene->addLine(rect.left() + margin, rect.top() + margin, rect.right() + margin, | ||||||
|             toolTipScene->addLine(rect.left() + margin, rect.top() + margin, |                                   rect.top() + margin, pen); | ||||||
|                                   rect.right() + margin, rect.top() + margin, |             toolTipScene->addLine(rect.right() + margin, rect.top() + margin, rect.right() + margin, | ||||||
|                                   pen); |                                   rect.bottom() + margin, pen); | ||||||
|             toolTipScene->addLine(rect.right() + margin, rect.top() + margin, |  | ||||||
|                                   rect.right() + margin, rect.bottom() + margin, |  | ||||||
|                                   pen); |  | ||||||
|             toolTipScene->addLine(rect.right() + margin, rect.bottom() + margin, |             toolTipScene->addLine(rect.right() + margin, rect.bottom() + margin, | ||||||
|                                   rect.left() + margin, rect.bottom() + margin, |                                   rect.left() + margin, rect.bottom() + margin, pen); | ||||||
|                                   pen); |  | ||||||
|         } |         } | ||||||
|     } else if (m_tooltipType == "clean") { |     } else if (m_tooltipType == "clean") { | ||||||
|         QScreen *screen = QGuiApplication::primaryScreen(); |         QScreen *screen = QGuiApplication::primaryScreen(); | ||||||
|         std::for_each(info.desktopsData.cbegin(), info.desktopsData.cend(), |         std::for_each(info.desktopsData.cbegin(), info.desktopsData.cend(), | ||||||
|                       [&toolTipScene, &screen](const WindowData &data) { |                       [&toolTipScene, &screen](const WindowData &data) { | ||||||
|                           QPixmap desktop = screen->grabWindow(data.id); |                           QPixmap desktop = screen->grabWindow(data.id); | ||||||
|                           toolTipScene->addPixmap(desktop)->setOffset( |                           toolTipScene->addPixmap(desktop)->setOffset(data.rect.left(), | ||||||
|                               data.rect.left(), data.rect.top()); |                                                                       data.rect.top()); | ||||||
|                       }); |                       }); | ||||||
|     } else if (m_tooltipType == "windows") { |     } else if (m_tooltipType == "windows") { | ||||||
|         QScreen *screen = QGuiApplication::primaryScreen(); |         QScreen *screen = QGuiApplication::primaryScreen(); | ||||||
|         std::for_each(info.desktopsData.cbegin(), info.desktopsData.cend(), |         std::for_each(info.desktopsData.cbegin(), info.desktopsData.cend(), | ||||||
|                       [&toolTipScene, &screen](const WindowData &data) { |                       [&toolTipScene, &screen](const WindowData &data) { | ||||||
|                           QPixmap desktop = screen->grabWindow(data.id); |                           QPixmap desktop = screen->grabWindow(data.id); | ||||||
|                           toolTipScene->addPixmap(desktop)->setOffset( |                           toolTipScene->addPixmap(desktop)->setOffset(data.rect.left(), | ||||||
|                               data.rect.left(), data.rect.top()); |                                                                       data.rect.top()); | ||||||
|                       }); |                       }); | ||||||
|         std::for_each(info.windowsData.cbegin(), info.windowsData.cend(), |         std::for_each(info.windowsData.cbegin(), info.windowsData.cend(), | ||||||
|                       [&toolTipScene, &screen](const WindowData &data) { |                       [&toolTipScene, &screen](const WindowData &data) { | ||||||
|                           QPixmap window = screen->grabWindow(data.id); |                           QPixmap window = screen->grabWindow(data.id); | ||||||
|                           toolTipScene->addPixmap(window)->setOffset( |                           toolTipScene->addPixmap(window)->setOffset(data.rect.left(), | ||||||
|                               data.rect.left(), data.rect.top()); |                                                                      data.rect.top()); | ||||||
|                       }); |                       }); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @ -189,8 +179,7 @@ QString DPAdds::toolTipImage(const int _desktop) const | |||||||
|     delete toolTipView; |     delete toolTipView; | ||||||
|     delete toolTipScene; |     delete toolTipScene; | ||||||
|  |  | ||||||
|     return QString("<img src=\"data:image/png;base64,%1\"/>") |     return QString("<img src=\"data:image/png;base64,%1\"/>").arg(QString(byteArray.toBase64())); | ||||||
|         .arg(QString(byteArray.toBase64())); |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -271,11 +260,9 @@ QVariantMap DPAdds::getFont(const QVariantMap &_defaultFont) const | |||||||
|  |  | ||||||
|     QVariantMap fontMap; |     QVariantMap fontMap; | ||||||
|     int ret = 0; |     int ret = 0; | ||||||
|     CFont defaultCFont |     CFont defaultCFont = CFont(_defaultFont["family"].toString(), _defaultFont["size"].toInt(), 400, | ||||||
|         = CFont(_defaultFont["family"].toString(), _defaultFont["size"].toInt(), |                                false, _defaultFont["color"].toString()); | ||||||
|                 400, false, _defaultFont["color"].toString()); |     CFont font = CFontDialog::getFont(i18n("Select font"), defaultCFont, false, false, &ret); | ||||||
|     CFont font = CFontDialog::getFont(i18n("Select font"), defaultCFont, false, |  | ||||||
|                                       false, &ret); |  | ||||||
|  |  | ||||||
|     fontMap["applied"] = ret; |     fontMap["applied"] = ret; | ||||||
|     fontMap["color"] = font.color().name(); |     fontMap["color"] = font.color().name(); | ||||||
| @ -291,10 +278,9 @@ void DPAdds::sendNotification(const QString &_eventId, const QString &_message) | |||||||
| { | { | ||||||
|     qCDebug(LOG_DP) << "Event" << _eventId << "with message" << _message; |     qCDebug(LOG_DP) << "Event" << _eventId << "with message" << _message; | ||||||
|  |  | ||||||
|     KNotification *notification = KNotification::event( |     KNotification *notification | ||||||
|         _eventId, QString("Desktop Panel ::: %1").arg(_eventId), _message); |         = KNotification::event(_eventId, QString("Desktop Panel ::: %1").arg(_eventId), _message); | ||||||
|     notification->setComponentName( |     notification->setComponentName("plasma-applet-org.kde.plasma.desktop-panel"); | ||||||
|         "plasma-applet-org.kde.plasma.desktop-panel"); |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -317,18 +303,15 @@ DPAdds::DesktopWindowsInfo DPAdds::getInfoByDesktop(const int _desktop) const | |||||||
|  |  | ||||||
|     for (auto &id : KWindowSystem::windows()) { |     for (auto &id : KWindowSystem::windows()) { | ||||||
|         KWindowInfo winInfo = KWindowInfo( |         KWindowInfo winInfo = KWindowInfo( | ||||||
|             id, |             id, NET::Property::WMDesktop | NET::Property::WMGeometry | NET::Property::WMState | ||||||
|             NET::Property::WMDesktop | NET::Property::WMGeometry |                     | NET::Property::WMWindowType | NET::Property::WMVisibleName); | ||||||
|                 | NET::Property::WMState | NET::Property::WMWindowType |  | ||||||
|                 | NET::Property::WMVisibleName); |  | ||||||
|         if (!winInfo.isOnDesktop(_desktop)) |         if (!winInfo.isOnDesktop(_desktop)) | ||||||
|             continue; |             continue; | ||||||
|         WindowData data; |         WindowData data; | ||||||
|         data.id = id; |         data.id = id; | ||||||
|         data.name = winInfo.visibleName(); |         data.name = winInfo.visibleName(); | ||||||
|         data.rect = winInfo.geometry(); |         data.rect = winInfo.geometry(); | ||||||
|         if (winInfo.windowType(NET::WindowTypeMask::NormalMask) |         if (winInfo.windowType(NET::WindowTypeMask::NormalMask) == NET::WindowType::Normal) { | ||||||
|             == NET::WindowType::Normal) { |  | ||||||
|             if (winInfo.isMinimized()) |             if (winInfo.isMinimized()) | ||||||
|                 continue; |                 continue; | ||||||
|             info.windowsData.append(data); |             info.windowsData.append(data); | ||||||
|  | |||||||
| @ -45,18 +45,15 @@ public: | |||||||
|     virtual ~DPAdds(); |     virtual ~DPAdds(); | ||||||
|     Q_INVOKABLE bool isDebugEnabled() const; |     Q_INVOKABLE bool isDebugEnabled() const; | ||||||
|     Q_INVOKABLE int currentDesktop() const; |     Q_INVOKABLE int currentDesktop() const; | ||||||
|     Q_INVOKABLE QStringList dictKeys(const bool _sorted = true, |     Q_INVOKABLE QStringList dictKeys(const bool _sorted = true, const QString &_regexp = "") const; | ||||||
|                                      const QString &_regexp = "") const; |  | ||||||
|     Q_INVOKABLE int numberOfDesktops() const; |     Q_INVOKABLE int numberOfDesktops() const; | ||||||
|     Q_INVOKABLE QString toolTipImage(const int _desktop) const; |     Q_INVOKABLE QString toolTipImage(const int _desktop) const; | ||||||
|     Q_INVOKABLE QString parsePattern(const QString &_pattern, |     Q_INVOKABLE QString parsePattern(const QString &_pattern, const int _desktop) const; | ||||||
|                                      const int _desktop) const; |  | ||||||
|     // values |     // values | ||||||
|     Q_INVOKABLE void setMark(const QString &_newMark); |     Q_INVOKABLE void setMark(const QString &_newMark); | ||||||
|     Q_INVOKABLE void setToolTipData(const QVariantMap &_tooltipData); |     Q_INVOKABLE void setToolTipData(const QVariantMap &_tooltipData); | ||||||
|     Q_INVOKABLE QString infoByKey(const QString &_key) const; |     Q_INVOKABLE QString infoByKey(const QString &_key) const; | ||||||
|     Q_INVOKABLE QString valueByKey(const QString &_key, |     Q_INVOKABLE QString valueByKey(const QString &_key, int _desktop = -1) const; | ||||||
|                                    int _desktop = -1) const; |  | ||||||
|     // configuration slots |     // configuration slots | ||||||
|     Q_INVOKABLE QString getAboutText(const QString &_type) const; |     Q_INVOKABLE QString getAboutText(const QString &_type) const; | ||||||
|     Q_INVOKABLE QVariantMap getFont(const QVariantMap &_defaultFont) const; |     Q_INVOKABLE QVariantMap getFont(const QVariantMap &_defaultFont) const; | ||||||
| @ -66,8 +63,7 @@ signals: | |||||||
|     void windowListChanged() const; |     void windowListChanged() const; | ||||||
|  |  | ||||||
| public slots: | public slots: | ||||||
|     Q_INVOKABLE static void sendNotification(const QString &_eventId, |     Q_INVOKABLE static void sendNotification(const QString &_eventId, const QString &_message); | ||||||
|                                              const QString &_message); |  | ||||||
|     Q_INVOKABLE void setCurrentDesktop(const int _desktop) const; |     Q_INVOKABLE void setCurrentDesktop(const int _desktop) const; | ||||||
|  |  | ||||||
| private: | private: | ||||||
|  | |||||||
| @ -86,26 +86,22 @@ bool ExtendedSysMon::updateSourceEvent(const QString &_source) | |||||||
|  |  | ||||||
| void ExtendedSysMon::readConfiguration() | void ExtendedSysMon::readConfiguration() | ||||||
| { | { | ||||||
|     QString fileName = QStandardPaths::locate( |     QString fileName = QStandardPaths::locate(QStandardPaths::ConfigLocation, | ||||||
|         QStandardPaths::ConfigLocation, "plasma-dataengine-extsysmon.conf"); |                                               "plasma-dataengine-extsysmon.conf"); | ||||||
|     qCInfo(LOG_ESM) << "Configuration file" << fileName; |     qCInfo(LOG_ESM) << "Configuration file" << fileName; | ||||||
|     QSettings settings(fileName, QSettings::IniFormat); |     QSettings settings(fileName, QSettings::IniFormat); | ||||||
|     QHash<QString, QString> rawConfig; |     QHash<QString, QString> rawConfig; | ||||||
|  |  | ||||||
|     settings.beginGroup("Configuration"); |     settings.beginGroup("Configuration"); | ||||||
|     rawConfig["ACPIPATH"] |     rawConfig["ACPIPATH"] = settings.value("ACPIPATH", "/sys/class/power_supply/").toString(); | ||||||
|         = settings.value("ACPIPATH", "/sys/class/power_supply/").toString(); |  | ||||||
|     rawConfig["GPUDEV"] = settings.value("GPUDEV", "auto").toString(); |     rawConfig["GPUDEV"] = settings.value("GPUDEV", "auto").toString(); | ||||||
|     rawConfig["HDDDEV"] = settings.value("HDDDEV", "all").toString(); |     rawConfig["HDDDEV"] = settings.value("HDDDEV", "all").toString(); | ||||||
|     rawConfig["HDDTEMPCMD"] |     rawConfig["HDDTEMPCMD"] = settings.value("HDDTEMPCMD", "sudo smartctl -a").toString(); | ||||||
|         = settings.value("HDDTEMPCMD", "sudo smartctl -a").toString(); |     rawConfig["MPDADDRESS"] = settings.value("MPDADDRESS", "localhost").toString(); | ||||||
|     rawConfig["MPDADDRESS"] |  | ||||||
|         = settings.value("MPDADDRESS", "localhost").toString(); |  | ||||||
|     rawConfig["MPDPORT"] = settings.value("MPDPORT", "6600").toString(); |     rawConfig["MPDPORT"] = settings.value("MPDPORT", "6600").toString(); | ||||||
|     rawConfig["MPRIS"] = settings.value("MPRIS", "auto").toString(); |     rawConfig["MPRIS"] = settings.value("MPRIS", "auto").toString(); | ||||||
|     rawConfig["PLAYER"] = settings.value("PLAYER", "mpris").toString(); |     rawConfig["PLAYER"] = settings.value("PLAYER", "mpris").toString(); | ||||||
|     rawConfig["PLAYERSYMBOLS"] |     rawConfig["PLAYERSYMBOLS"] = settings.value("PLAYERSYMBOLS", "10").toString(); | ||||||
|         = settings.value("PLAYERSYMBOLS", "10").toString(); |  | ||||||
|     settings.endGroup(); |     settings.endGroup(); | ||||||
|  |  | ||||||
|     m_configuration = updateConfiguration(rawConfig); |     m_configuration = updateConfiguration(rawConfig); | ||||||
| @ -122,8 +118,7 @@ ExtendedSysMon::updateConfiguration(QHash<QString, QString> _rawConfig) const | |||||||
|         ; |         ; | ||||||
|     else if (_rawConfig["GPUDEV"] == "auto") |     else if (_rawConfig["GPUDEV"] == "auto") | ||||||
|         _rawConfig["GPUDEV"] = GPULoadSource::autoGpu(); |         _rawConfig["GPUDEV"] = GPULoadSource::autoGpu(); | ||||||
|     else if ((_rawConfig["GPUDEV"] != "ati") |     else if ((_rawConfig["GPUDEV"] != "ati") && (_rawConfig["GPUDEV"] != "nvidia")) | ||||||
|              && (_rawConfig["GPUDEV"] != "nvidia")) |  | ||||||
|         _rawConfig["GPUDEV"] = GPULoadSource::autoGpu(); |         _rawConfig["GPUDEV"] = GPULoadSource::autoGpu(); | ||||||
|     // hdddev |     // hdddev | ||||||
|     QStringList allHddDevices = HDDTemperatureSource::allHdd(); |     QStringList allHddDevices = HDDTemperatureSource::allHdd(); | ||||||
| @ -132,8 +127,7 @@ ExtendedSysMon::updateConfiguration(QHash<QString, QString> _rawConfig) const | |||||||
|     } else if (_rawConfig["HDDDEV"] == "disable") { |     } else if (_rawConfig["HDDDEV"] == "disable") { | ||||||
|         _rawConfig["HDDDEV"] = ""; |         _rawConfig["HDDDEV"] = ""; | ||||||
|     } else { |     } else { | ||||||
|         QStringList deviceList |         QStringList deviceList = _rawConfig["HDDDEV"].split(',', QString::SkipEmptyParts); | ||||||
|             = _rawConfig["HDDDEV"].split(',', QString::SkipEmptyParts); |  | ||||||
|         QStringList devices; |         QStringList devices; | ||||||
|         QRegExp diskRegexp = QRegExp("^/dev/[hms]d[a-z]$"); |         QRegExp diskRegexp = QRegExp("^/dev/[hms]d[a-z]$"); | ||||||
|         for (auto &device : deviceList) |         for (auto &device : deviceList) | ||||||
| @ -158,7 +152,6 @@ ExtendedSysMon::updateConfiguration(QHash<QString, QString> _rawConfig) const | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| K_EXPORT_PLASMA_DATAENGINE_WITH_JSON(extsysmon, ExtendedSysMon, | K_EXPORT_PLASMA_DATAENGINE_WITH_JSON(extsysmon, ExtendedSysMon, "plasma-dataengine-extsysmon.json") | ||||||
|                                      "plasma-dataengine-extsysmon.json") |  | ||||||
|  |  | ||||||
| #include "extsysmon.moc" | #include "extsysmon.moc" | ||||||
|  | |||||||
| @ -42,8 +42,7 @@ private: | |||||||
|     QHash<QString, QString> m_configuration; |     QHash<QString, QString> m_configuration; | ||||||
|     // methods |     // methods | ||||||
|     void readConfiguration(); |     void readConfiguration(); | ||||||
|     QHash<QString, QString> |     QHash<QString, QString> updateConfiguration(QHash<QString, QString> _rawConfig) const; | ||||||
|     updateConfiguration(QHash<QString, QString> _rawConfig) const; |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
|  | |||||||
| @ -34,8 +34,7 @@ | |||||||
| #include "weathersource.h" | #include "weathersource.h" | ||||||
|  |  | ||||||
|  |  | ||||||
| ExtSysMonAggregator::ExtSysMonAggregator(QObject *_parent, | ExtSysMonAggregator::ExtSysMonAggregator(QObject *_parent, const QHash<QString, QString> &_config) | ||||||
|                                          const QHash<QString, QString> &_config) |  | ||||||
|     : QObject(_parent) |     : QObject(_parent) | ||||||
| { | { | ||||||
|     qCDebug(LOG_ESM) << __PRETTY_FUNCTION__; |     qCDebug(LOG_ESM) << __PRETTY_FUNCTION__; | ||||||
| @ -72,8 +71,7 @@ QVariantMap ExtSysMonAggregator::initialData(const QString &_source) const | |||||||
| { | { | ||||||
|     qCDebug(LOG_ESM) << "Source" << _source; |     qCDebug(LOG_ESM) << "Source" << _source; | ||||||
|  |  | ||||||
|     return hasSource(_source) ? m_map[_source]->initialData(_source) |     return hasSource(_source) ? m_map[_source]->initialData(_source) : QVariantMap(); | ||||||
|                               : QVariantMap(); |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -97,8 +95,7 @@ void ExtSysMonAggregator::init(const QHash<QString, QString> &_config) | |||||||
|     for (auto &source : customItem->sources()) |     for (auto &source : customItem->sources()) | ||||||
|         m_map[source] = customItem; |         m_map[source] = customItem; | ||||||
|     // desktop |     // desktop | ||||||
|     AbstractExtSysMonSource *desktopItem |     AbstractExtSysMonSource *desktopItem = new DesktopSource(this, QStringList()); | ||||||
|         = new DesktopSource(this, QStringList()); |  | ||||||
|     for (auto &source : desktopItem->sources()) |     for (auto &source : desktopItem->sources()) | ||||||
|         m_map[source] = desktopItem; |         m_map[source] = desktopItem; | ||||||
|     // gpu load |     // gpu load | ||||||
| @ -112,30 +109,26 @@ void ExtSysMonAggregator::init(const QHash<QString, QString> &_config) | |||||||
|     for (auto &source : gpuTempItem->sources()) |     for (auto &source : gpuTempItem->sources()) | ||||||
|         m_map[source] = gpuTempItem; |         m_map[source] = gpuTempItem; | ||||||
|     // hdd temperature |     // hdd temperature | ||||||
|     AbstractExtSysMonSource *hddTempItem = new HDDTemperatureSource( |     AbstractExtSysMonSource *hddTempItem | ||||||
|         this, QStringList({_config["HDDDEV"], _config["HDDTEMPCMD"]})); |         = new HDDTemperatureSource(this, QStringList({_config["HDDDEV"], _config["HDDTEMPCMD"]})); | ||||||
|     for (auto &source : hddTempItem->sources()) |     for (auto &source : hddTempItem->sources()) | ||||||
|         m_map[source] = hddTempItem; |         m_map[source] = hddTempItem; | ||||||
|     // network |     // network | ||||||
|     AbstractExtSysMonSource *networkItem |     AbstractExtSysMonSource *networkItem = new NetworkSource(this, QStringList()); | ||||||
|         = new NetworkSource(this, QStringList()); |  | ||||||
|     for (auto &source : networkItem->sources()) |     for (auto &source : networkItem->sources()) | ||||||
|         m_map[source] = networkItem; |         m_map[source] = networkItem; | ||||||
|     // player |     // player | ||||||
|     AbstractExtSysMonSource *playerItem = new PlayerSource( |     AbstractExtSysMonSource *playerItem = new PlayerSource( | ||||||
|         this, QStringList({_config["PLAYER"], _config["MPDADDRESS"], |         this, QStringList({_config["PLAYER"], _config["MPDADDRESS"], _config["MPDPORT"], | ||||||
|                            _config["MPDPORT"], _config["MPRIS"], |                            _config["MPRIS"], _config["PLAYERSYMBOLS"]})); | ||||||
|                            _config["PLAYERSYMBOLS"]})); |  | ||||||
|     for (auto &source : playerItem->sources()) |     for (auto &source : playerItem->sources()) | ||||||
|         m_map[source] = playerItem; |         m_map[source] = playerItem; | ||||||
|     // processes |     // processes | ||||||
|     AbstractExtSysMonSource *processesItem |     AbstractExtSysMonSource *processesItem = new ProcessesSource(this, QStringList()); | ||||||
|         = new ProcessesSource(this, QStringList()); |  | ||||||
|     for (auto &source : processesItem->sources()) |     for (auto &source : processesItem->sources()) | ||||||
|         m_map[source] = processesItem; |         m_map[source] = processesItem; | ||||||
|     // network request |     // network request | ||||||
|     AbstractExtSysMonSource *requestItem |     AbstractExtSysMonSource *requestItem = new RequestSource(this, QStringList()); | ||||||
|         = new RequestSource(this, QStringList()); |  | ||||||
|     for (auto &source : requestItem->sources()) |     for (auto &source : requestItem->sources()) | ||||||
|         m_map[source] = requestItem; |         m_map[source] = requestItem; | ||||||
|     // quotes |     // quotes | ||||||
| @ -143,13 +136,11 @@ void ExtSysMonAggregator::init(const QHash<QString, QString> &_config) | |||||||
|     for (auto &source : quotesItem->sources()) |     for (auto &source : quotesItem->sources()) | ||||||
|         m_map[source] = quotesItem; |         m_map[source] = quotesItem; | ||||||
|     // upgrade |     // upgrade | ||||||
|     AbstractExtSysMonSource *upgradeItem |     AbstractExtSysMonSource *upgradeItem = new UpgradeSource(this, QStringList()); | ||||||
|         = new UpgradeSource(this, QStringList()); |  | ||||||
|     for (auto &source : upgradeItem->sources()) |     for (auto &source : upgradeItem->sources()) | ||||||
|         m_map[source] = upgradeItem; |         m_map[source] = upgradeItem; | ||||||
|     // weather |     // weather | ||||||
|     AbstractExtSysMonSource *weatherItem |     AbstractExtSysMonSource *weatherItem = new WeatherSource(this, QStringList()); | ||||||
|         = new WeatherSource(this, QStringList()); |  | ||||||
|     for (auto &source : weatherItem->sources()) |     for (auto &source : weatherItem->sources()) | ||||||
|         m_map[source] = weatherItem; |         m_map[source] = weatherItem; | ||||||
| #ifdef BUILD_LOAD | #ifdef BUILD_LOAD | ||||||
|  | |||||||
| @ -28,8 +28,7 @@ class ExtSysMonAggregator : public QObject | |||||||
|     Q_OBJECT |     Q_OBJECT | ||||||
|  |  | ||||||
| public: | public: | ||||||
|     explicit ExtSysMonAggregator(QObject *_parent, |     explicit ExtSysMonAggregator(QObject *_parent, const QHash<QString, QString> &_config); | ||||||
|                                  const QHash<QString, QString> &_config); |  | ||||||
|     virtual ~ExtSysMonAggregator(); |     virtual ~ExtSysMonAggregator(); | ||||||
|     QVariant data(const QString &_source) const; |     QVariant data(const QString &_source) const; | ||||||
|     bool hasSource(const QString &_source) const; |     bool hasSource(const QString &_source) const; | ||||||
|  | |||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user