mirror of
				https://github.com/arcan1s/awesome-widgets.git
				synced 2025-11-03 22:33:42 +00:00 
			
		
		
		
	Compare commits
	
		
			5 Commits
		
	
	
		
			67640cccdc
			...
			4.0.0alpha
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 161ff64293 | |||
| 115bef3dbe | |||
| b6ade7310a | |||
| 0555185044 | |||
| 23e197789f | 
							
								
								
									
										24
									
								
								.github/workflows/release.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										24
									
								
								.github/workflows/release.yml
									
									
									
									
										vendored
									
									
								
							@ -25,17 +25,17 @@ jobs:
 | 
				
			|||||||
        env:
 | 
					        env:
 | 
				
			||||||
          VERSION: ${{ steps.version.outputs.VERSION }}
 | 
					          VERSION: ${{ steps.version.outputs.VERSION }}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      - name: build debian package
 | 
					#      - name: build debian package
 | 
				
			||||||
        run: |
 | 
					#        run: |
 | 
				
			||||||
          sudo apt update && \
 | 
					#          sudo apt update && \
 | 
				
			||||||
          sudo apt install -yq cmake extra-cmake-modules g++ git gettext make && \
 | 
					#          sudo apt install -yq cmake extra-cmake-modules g++ git gettext make && \
 | 
				
			||||||
          sudo apt install -yq libkf5i18n-dev libkf5notifications-dev libkf5service-dev \
 | 
					#          sudo apt install -yq libkf5i18n-dev libkf5notifications-dev libkf5service-dev \
 | 
				
			||||||
            libkf5windowsystem-dev libkf5plasma-dev qtbase5-dev qtdeclarative5-dev \
 | 
					#            libkf5windowsystem-dev libkf5plasma-dev qtbase5-dev qtdeclarative5-dev \
 | 
				
			||||||
            plasma-workspace-dev && \
 | 
					#            plasma-workspace-dev && \
 | 
				
			||||||
          cmake -B build-deb -DKDE_INSTALL_USE_QT_SYS_PATHS=ON -DCMAKE_INSTALL_PREFIX=/usr -DCMAKE_BUILD_TYPE=Optimization -DBUILD_FUTURE=ON -DBUILD_DEB_PACKAGE=ON sources && \
 | 
					#          cmake -B build-deb -DKDE_INSTALL_USE_QT_SYS_PATHS=ON -DCMAKE_INSTALL_PREFIX=/usr -DCMAKE_BUILD_TYPE=Optimization -DBUILD_FUTURE=ON -DBUILD_DEB_PACKAGE=ON sources && \
 | 
				
			||||||
          cd build-deb && \
 | 
					#          cd build-deb && \
 | 
				
			||||||
          make package && \
 | 
					#          make package && \
 | 
				
			||||||
          cd ..
 | 
					#          cd ..
 | 
				
			||||||
 | 
					
 | 
				
			||||||
      - name: release
 | 
					      - name: release
 | 
				
			||||||
        uses: softprops/action-gh-release@v1
 | 
					        uses: softprops/action-gh-release@v1
 | 
				
			||||||
@ -45,7 +45,7 @@ jobs:
 | 
				
			|||||||
            ${{ steps.changelog.outputs.changelog }}
 | 
					            ${{ steps.changelog.outputs.changelog }}
 | 
				
			||||||
          files: |
 | 
					          files: |
 | 
				
			||||||
            awesome-widgets-*-src.tar.xz
 | 
					            awesome-widgets-*-src.tar.xz
 | 
				
			||||||
            build-deb/plasma-widget-awesome-widgets-*.deb
 | 
					#            build-deb/plasma-widget-awesome-widgets-*.deb
 | 
				
			||||||
          fail_on_unmatched_files: true
 | 
					          fail_on_unmatched_files: true
 | 
				
			||||||
        env:
 | 
					        env:
 | 
				
			||||||
          GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
 | 
					          GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
 | 
				
			||||||
 | 
				
			|||||||
@ -1,3 +1,6 @@
 | 
				
			|||||||
 | 
					Ver.4.0.0:
 | 
				
			||||||
 | 
					* migration to plasma 6
 | 
				
			||||||
 | 
					
 | 
				
			||||||
Ver.3.5.0:
 | 
					Ver.3.5.0:
 | 
				
			||||||
+ wayland support
 | 
					+ wayland support
 | 
				
			||||||
* update code to latest standards
 | 
					* update code to latest standards
 | 
				
			||||||
@ -12,7 +15,6 @@ Ver.3.4.2:
 | 
				
			|||||||
* update to new qt api
 | 
					* update to new qt api
 | 
				
			||||||
- fix non printable spaces (#142, #143)
 | 
					- fix non printable spaces (#142, #143)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 | 
				
			||||||
Ver.3.3.3:
 | 
					Ver.3.3.3:
 | 
				
			||||||
+ add custom keys support (#101)
 | 
					+ add custom keys support (#101)
 | 
				
			||||||
* DBus interface improvements
 | 
					* DBus interface improvements
 | 
				
			||||||
 | 
				
			|||||||
@ -1,41 +1,33 @@
 | 
				
			|||||||
# Maintainer: Evgeniy Alekseev <arcanis at archlinux dot org>
 | 
					# Maintainer: Evgeniy Alekseev <arcanis at archlinux dot org>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
pkgname=plasma5-applet-awesome-widgets
 | 
					pkgname=plasma6-applet-awesome-widgets
 | 
				
			||||||
_pkgname=awesome-widgets
 | 
					_pkgname=awesome-widgets
 | 
				
			||||||
pkgver=3.4.3
 | 
					pkgver=4.0.0alpha1
 | 
				
			||||||
pkgrel=1
 | 
					pkgrel=1
 | 
				
			||||||
pkgdesc="Collection of minimalistic Plasmoids which look like Awesome WM widgets (ex-PyTextMonitor)"
 | 
					pkgdesc="Collection of minimalistic Plasmoids which look like Awesome WM widgets (ex-PyTextMonitor)"
 | 
				
			||||||
arch=('i686' 'x86_64')
 | 
					arch=('x86_64')
 | 
				
			||||||
url="https://arcanis.me/projects/awesome-widgets"
 | 
					url="https://arcanis.me/projects/awesome-widgets"
 | 
				
			||||||
license=('GPL3')
 | 
					license=('GPL3')
 | 
				
			||||||
depends=('ksysguard' 'plasma-framework')
 | 
					depends=('plasma-workspace')
 | 
				
			||||||
optdepends=("catalyst: for GPU monitor"
 | 
					optdepends=("hddtemp: for HDD temperature monitor"
 | 
				
			||||||
            "hddtemp: for HDD temperature monitor"
 | 
					 | 
				
			||||||
            "smartmontools: for HDD temperature monitor"
 | 
					            "smartmontools: for HDD temperature monitor"
 | 
				
			||||||
            "mpd: for music player monitor"
 | 
					            "mpd: for music player monitor"
 | 
				
			||||||
            "nvidia-utils: for GPU monitor")
 | 
					            "nvidia-utils: for GPU monitor")
 | 
				
			||||||
makedepends=('cmake' 'extra-cmake-modules' 'python')
 | 
					makedepends=('cmake' 'extra-cmake-modules' 'python')
 | 
				
			||||||
source=(https://github.com/arcan1s/awesome-widgets/releases/download/V.${pkgver}/${_pkgname}-${pkgver}-src.tar.xz)
 | 
					source=(https://github.com/arcan1s/awesome-widgets/releases/download/${pkgver}/${_pkgname}-${pkgver}-src.tar.xz)
 | 
				
			||||||
install=${pkgname}.install
 | 
					install="$pkgname.install"
 | 
				
			||||||
md5sums=('5953ba518191bb6fff83cdb8633c735c')
 | 
					 | 
				
			||||||
backup=('etc/xdg/plasma-dataengine-extsysmon.conf')
 | 
					backup=('etc/xdg/plasma-dataengine-extsysmon.conf')
 | 
				
			||||||
 | 
					
 | 
				
			||||||
prepare() {
 | 
					 | 
				
			||||||
  rm -rf "${srcdir}/build"
 | 
					 | 
				
			||||||
  mkdir "${srcdir}/build"
 | 
					 | 
				
			||||||
}
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
build () {
 | 
					build () {
 | 
				
			||||||
  cd "${srcdir}/build"
 | 
					    cmake -B build -S "${_pkgname}" \
 | 
				
			||||||
  cmake -DKDE_INSTALL_USE_QT_SYS_PATHS=ON \
 | 
					 | 
				
			||||||
          -DCMAKE_BUILD_TYPE=Optimization \
 | 
					          -DCMAKE_BUILD_TYPE=Optimization \
 | 
				
			||||||
        -DCMAKE_INSTALL_PREFIX=/usr \
 | 
					 | 
				
			||||||
          -DBUILD_FUTURE=ON \
 | 
					          -DBUILD_FUTURE=ON \
 | 
				
			||||||
        "../${_pkgname}"
 | 
					          -DBUILD_TESTING=OFF
 | 
				
			||||||
  make
 | 
					    cmake --build build
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
package() {
 | 
					package() {
 | 
				
			||||||
  cd "${srcdir}/build"
 | 
					      DESTDIR="$pkgdir" cmake --install build
 | 
				
			||||||
  make DESTDIR="${pkgdir}" install
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					sha256sums=('b2a7b07a1df6f710f4e0d6e5898933f4ddb131818b922dc4b8e48afe3e98a664')
 | 
				
			||||||
 | 
				
			|||||||
@ -14,9 +14,9 @@ project(awesomewidgets)
 | 
				
			|||||||
set(PROJECT_AUTHOR "Evgeniy Alekseev")
 | 
					set(PROJECT_AUTHOR "Evgeniy Alekseev")
 | 
				
			||||||
set(PROJECT_CONTACT "esalexeev@gmail.com")
 | 
					set(PROJECT_CONTACT "esalexeev@gmail.com")
 | 
				
			||||||
set(PROJECT_LICENSE "GPL3")
 | 
					set(PROJECT_LICENSE "GPL3")
 | 
				
			||||||
set(PROJECT_VERSION_MAJOR "3")
 | 
					set(PROJECT_VERSION_MAJOR "4")
 | 
				
			||||||
set(PROJECT_VERSION_MINOR "5")
 | 
					set(PROJECT_VERSION_MINOR "0")
 | 
				
			||||||
set(PROJECT_VERSION_PATCH "1")
 | 
					set(PROJECT_VERSION_PATCH "0")
 | 
				
			||||||
set(PROJECT_VERSION "${PROJECT_VERSION_MAJOR}.${PROJECT_VERSION_MINOR}.${PROJECT_VERSION_PATCH}")
 | 
					set(PROJECT_VERSION "${PROJECT_VERSION_MAJOR}.${PROJECT_VERSION_MINOR}.${PROJECT_VERSION_PATCH}")
 | 
				
			||||||
# append git version if any
 | 
					# append git version if any
 | 
				
			||||||
set(PROJECT_COMMIT_SHA "Commit hash" CACHE INTERNAL "")
 | 
					set(PROJECT_COMMIT_SHA "Commit hash" CACHE INTERNAL "")
 | 
				
			||||||
 | 
				
			|||||||
@ -17,15 +17,17 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
#include "awdataengineaggregator.h"
 | 
					#include "awdataengineaggregator.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#include <QDBusConnection>
 | 
					 | 
				
			||||||
#include <ksysguard/formatter/Unit.h>
 | 
					#include <ksysguard/formatter/Unit.h>
 | 
				
			||||||
#include <ksysguard/systemstats/DBusInterface.h>
 | 
					#include <ksysguard/systemstats/DBusInterface.h>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include <QDBusConnection>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#include "awdebug.h"
 | 
					#include "awdebug.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
AWDataEngineAggregator::AWDataEngineAggregator(QObject *_parent)
 | 
					AWDataEngineAggregator::AWDataEngineAggregator(QObject *_parent)
 | 
				
			||||||
    : QObject(_parent)
 | 
					    : QObject(_parent)
 | 
				
			||||||
 | 
					    , m_interface(new KSysGuard::SystemStats::DBusInterface())
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
    qCDebug(LOG_AW) << __PRETTY_FUNCTION__;
 | 
					    qCDebug(LOG_AW) << __PRETTY_FUNCTION__;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -34,12 +36,14 @@ AWDataEngineAggregator::AWDataEngineAggregator(QObject *_parent)
 | 
				
			|||||||
    qDBusRegisterMetaType<KSysGuard::SensorDataList>();
 | 
					    qDBusRegisterMetaType<KSysGuard::SensorDataList>();
 | 
				
			||||||
    qDBusRegisterMetaType<QHash<QString, KSysGuard::SensorInfo>>();
 | 
					    qDBusRegisterMetaType<QHash<QString, KSysGuard::SensorInfo>>();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    m_interface = new KSysGuard::SystemStats::DBusInterface();
 | 
					    connect(m_interface, &KSysGuard::SystemStats::DBusInterface::newSensorData, this,
 | 
				
			||||||
 | 
					            &AWDataEngineAggregator::updateData);
 | 
				
			||||||
    connect(m_interface, &KSysGuard::SystemStats::DBusInterface::newSensorData, this, &AWDataEngineAggregator::updateData);
 | 
					    connect(m_interface, &KSysGuard::SystemStats::DBusInterface::sensorMetaDataChanged, this,
 | 
				
			||||||
    connect(m_interface, &KSysGuard::SystemStats::DBusInterface::sensorMetaDataChanged, this, &AWDataEngineAggregator::updateSensors);
 | 
					            &AWDataEngineAggregator::updateSensors);
 | 
				
			||||||
    connect(m_interface, &KSysGuard::SystemStats::DBusInterface::sensorAdded, this, &AWDataEngineAggregator::sensorAdded);
 | 
					    connect(m_interface, &KSysGuard::SystemStats::DBusInterface::sensorAdded, this,
 | 
				
			||||||
    connect(m_interface, &KSysGuard::SystemStats::DBusInterface::sensorRemoved, this, &AWDataEngineAggregator::sensorRemoved);
 | 
					            &AWDataEngineAggregator::sensorAdded);
 | 
				
			||||||
 | 
					    connect(m_interface, &KSysGuard::SystemStats::DBusInterface::sensorRemoved, this,
 | 
				
			||||||
 | 
					            &AWDataEngineAggregator::sensorRemoved);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    loadSources();
 | 
					    loadSources();
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
@ -54,9 +58,20 @@ AWDataEngineAggregator::~AWDataEngineAggregator()
 | 
				
			|||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void AWDataEngineAggregator::connectSources()
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    auto keys = m_sensors.keys();
 | 
				
			||||||
 | 
					    auto newKeys = QSet(keys.cbegin(), keys.cend()) - m_subscribed;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    m_interface->subscribe(newKeys.values()).waitForFinished();
 | 
				
			||||||
 | 
					    m_subscribed.unite(newKeys);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void AWDataEngineAggregator::disconnectSources()
 | 
					void AWDataEngineAggregator::disconnectSources()
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
    m_interface->unsubscribe(m_sensors.keys());
 | 
					    m_interface->unsubscribe(m_subscribed.values()).waitForFinished();
 | 
				
			||||||
 | 
					    m_subscribed.clear();
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -73,15 +88,7 @@ void AWDataEngineAggregator::loadSources()
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    auto sensors = response.value();
 | 
					    auto sensors = response.value();
 | 
				
			||||||
    updateSensors(sensors);
 | 
					    updateSensors(sensors);
 | 
				
			||||||
}
 | 
					    connectSources();
 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
void AWDataEngineAggregator::reconnectSources(const int interval)
 | 
					 | 
				
			||||||
{
 | 
					 | 
				
			||||||
    qCDebug(LOG_AW) << "Reconnect all sensors with update interval" << interval;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    disconnectSources();
 | 
					 | 
				
			||||||
    m_interface->subscribe(m_sensors.keys());
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -89,7 +96,10 @@ void AWDataEngineAggregator::dropSource(const QString &_source)
 | 
				
			|||||||
{
 | 
					{
 | 
				
			||||||
    qCDebug(LOG_AW) << "Disconnect sensor" << _source;
 | 
					    qCDebug(LOG_AW) << "Disconnect sensor" << _source;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    m_interface->unsubscribe({_source});
 | 
					    if (m_subscribed.contains(_source)) {
 | 
				
			||||||
 | 
					        m_interface->unsubscribe({_source}).waitForFinished();
 | 
				
			||||||
 | 
					        m_subscribed.remove(_source);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -100,13 +110,17 @@ void AWDataEngineAggregator::sensorAdded(const QString &_sensor)
 | 
				
			|||||||
    // check if sensor is actually valid
 | 
					    // check if sensor is actually valid
 | 
				
			||||||
    auto response = m_interface->sensors({_sensor});
 | 
					    auto response = m_interface->sensors({_sensor});
 | 
				
			||||||
    response.waitForFinished();
 | 
					    response.waitForFinished();
 | 
				
			||||||
    auto info = response.value();
 | 
					
 | 
				
			||||||
    if (info.count() != 1)
 | 
					    auto info = response.value().value(_sensor);
 | 
				
			||||||
 | 
					    if (!isValidSensor(info))
 | 
				
			||||||
        return;
 | 
					        return;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    qCWarning(LOG_AW) << info.keys();
 | 
					    m_sensors[_sensor] = info;
 | 
				
			||||||
 | 
					    dropSource(_sensor); // force reconnect
 | 
				
			||||||
    m_interface->subscribe({_sensor});
 | 
					    if (!m_subscribed.contains(_sensor)) {
 | 
				
			||||||
 | 
					        m_interface->subscribe({_sensor}).waitForFinished();
 | 
				
			||||||
 | 
					        m_subscribed.insert(_sensor);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -115,9 +129,10 @@ void AWDataEngineAggregator::sensorRemoved(const QString &_sensor)
 | 
				
			|||||||
    qCDebug(LOG_AW) << "Sensor" << _sensor << "has been removed";
 | 
					    qCDebug(LOG_AW) << "Sensor" << _sensor << "has been removed";
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    m_sensors.remove(_sensor);
 | 
					    m_sensors.remove(_sensor);
 | 
				
			||||||
    m_interface->unsubscribe({_sensor});
 | 
					    dropSource(_sensor);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void AWDataEngineAggregator::updateData(KSysGuard::SensorDataList _data)
 | 
					void AWDataEngineAggregator::updateData(KSysGuard::SensorDataList _data)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
    emit(dataUpdated(m_sensors, _data));
 | 
					    emit(dataUpdated(m_sensors, _data));
 | 
				
			||||||
 | 
				
			|||||||
@ -15,9 +15,7 @@
 | 
				
			|||||||
 *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  *
 | 
					 *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  *
 | 
				
			||||||
 ***************************************************************************/
 | 
					 ***************************************************************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#pragma once
 | 
				
			||||||
#ifndef AWDATAENGINEAGGREGATOR_H
 | 
					 | 
				
			||||||
#define AWDATAENGINEAGGREGATOR_H
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
#include <ksysguard/systemstats/SensorInfo.h>
 | 
					#include <ksysguard/systemstats/SensorInfo.h>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -31,7 +29,6 @@ namespace KSysGuard::SystemStats
 | 
				
			|||||||
class DBusInterface;
 | 
					class DBusInterface;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					 | 
				
			||||||
class AWDataEngineAggregator : public QObject
 | 
					class AWDataEngineAggregator : public QObject
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
    Q_OBJECT
 | 
					    Q_OBJECT
 | 
				
			||||||
@ -39,10 +36,10 @@ class AWDataEngineAggregator : public QObject
 | 
				
			|||||||
public:
 | 
					public:
 | 
				
			||||||
    explicit AWDataEngineAggregator(QObject *_parent = nullptr);
 | 
					    explicit AWDataEngineAggregator(QObject *_parent = nullptr);
 | 
				
			||||||
    ~AWDataEngineAggregator() override;
 | 
					    ~AWDataEngineAggregator() override;
 | 
				
			||||||
 | 
					    void connectSources();
 | 
				
			||||||
    void disconnectSources();
 | 
					    void disconnectSources();
 | 
				
			||||||
    [[nodiscard]] bool isValidSensor(const KSysGuard::SensorInfo &_sensor);
 | 
					    [[nodiscard]] static bool isValidSensor(const KSysGuard::SensorInfo &_sensor);
 | 
				
			||||||
    void loadSources();
 | 
					    void loadSources();
 | 
				
			||||||
    void reconnectSources(const int interval);
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
signals:
 | 
					signals:
 | 
				
			||||||
    void dataUpdated(const QHash<QString, KSysGuard::SensorInfo> &_sensors, const KSysGuard::SensorDataList &_data);
 | 
					    void dataUpdated(const QHash<QString, KSysGuard::SensorInfo> &_sensors, const KSysGuard::SensorDataList &_data);
 | 
				
			||||||
@ -58,7 +55,5 @@ public slots:
 | 
				
			|||||||
private:
 | 
					private:
 | 
				
			||||||
    KSysGuard::SystemStats::DBusInterface *m_interface = nullptr;
 | 
					    KSysGuard::SystemStats::DBusInterface *m_interface = nullptr;
 | 
				
			||||||
    QHash<QString, KSysGuard::SensorInfo> m_sensors;
 | 
					    QHash<QString, KSysGuard::SensorInfo> m_sensors;
 | 
				
			||||||
 | 
					    QSet<QString> m_subscribed;
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#endif /* AWDATAENGINEAGGREGATOR_H */
 | 
					 | 
				
			||||||
 | 
				
			|||||||
@ -84,6 +84,7 @@ QStringList AWDataEngineMapper::registerSource(const QString &_source, const KSy
 | 
				
			|||||||
    // regular expressions
 | 
					    // regular expressions
 | 
				
			||||||
    auto cpuRegExp = QRegularExpression("^cpu/cpu.*/usage$");
 | 
					    auto cpuRegExp = QRegularExpression("^cpu/cpu.*/usage$");
 | 
				
			||||||
    auto cpuclRegExp = QRegularExpression("^cpu/cpu.*/frequency$");
 | 
					    auto cpuclRegExp = QRegularExpression("^cpu/cpu.*/frequency$");
 | 
				
			||||||
 | 
					    auto cpuTempRegExp = QRegularExpression("^cpu/cpu.*/temperature$");
 | 
				
			||||||
    auto hddrRegExp = QRegularExpression("^disk/.*/read$");
 | 
					    auto hddrRegExp = QRegularExpression("^disk/.*/read$");
 | 
				
			||||||
    auto hddwRegExp = QRegularExpression("^disk/.*/write$");
 | 
					    auto hddwRegExp = QRegularExpression("^disk/.*/write$");
 | 
				
			||||||
    auto mountFillRegExp = QRegularExpression("^disk/.*/usedPercent$");
 | 
					    auto mountFillRegExp = QRegularExpression("^disk/.*/usedPercent$");
 | 
				
			||||||
@ -130,15 +131,15 @@ QStringList AWDataEngineMapper::registerSource(const QString &_source, const KSy
 | 
				
			|||||||
        key.remove("extsysmon/custom/");
 | 
					        key.remove("extsysmon/custom/");
 | 
				
			||||||
        m_map.insert(_source, key);
 | 
					        m_map.insert(_source, key);
 | 
				
			||||||
        m_formatter[key] = AWKeysAggregator::FormatterType::NoFormat;
 | 
					        m_formatter[key] = AWKeysAggregator::FormatterType::NoFormat;
 | 
				
			||||||
    } else if (_source == "extsysmon/desktop/current/name") {
 | 
					    } else if (_source == "extsysmon/desktop/name") {
 | 
				
			||||||
        // current desktop name
 | 
					        // current desktop name
 | 
				
			||||||
        m_map.insert(_source, "desktop");
 | 
					        m_map.insert(_source, "desktop");
 | 
				
			||||||
        m_formatter["desktop"] = AWKeysAggregator::FormatterType::NoFormat;
 | 
					        m_formatter["desktop"] = AWKeysAggregator::FormatterType::NoFormat;
 | 
				
			||||||
    } else if (_source == "extsysmon/desktop/current/number") {
 | 
					    } else if (_source == "extsysmon/desktop/number") {
 | 
				
			||||||
        // current desktop number
 | 
					        // current desktop number
 | 
				
			||||||
        m_map.insert(_source, "ndesktop");
 | 
					        m_map.insert(_source, "ndesktop");
 | 
				
			||||||
        m_formatter["ndesktop"] = AWKeysAggregator::FormatterType::NoFormat;
 | 
					        m_formatter["ndesktop"] = AWKeysAggregator::FormatterType::NoFormat;
 | 
				
			||||||
    } else if (_source == "extsysmon/desktop/total/number") {
 | 
					    } else if (_source == "extsysmon/desktop/count") {
 | 
				
			||||||
        // desktop count
 | 
					        // desktop count
 | 
				
			||||||
        m_map.insert(_source, "tdesktops");
 | 
					        m_map.insert(_source, "tdesktops");
 | 
				
			||||||
        m_formatter["tdesktops"] = AWKeysAggregator::FormatterType::NoFormat;
 | 
					        m_formatter["tdesktops"] = AWKeysAggregator::FormatterType::NoFormat;
 | 
				
			||||||
@ -216,7 +217,7 @@ QStringList AWDataEngineMapper::registerSource(const QString &_source, const KSy
 | 
				
			|||||||
    } else if (_source.startsWith("extsysmon/hdd/temperature")) {
 | 
					    } else if (_source.startsWith("extsysmon/hdd/temperature")) {
 | 
				
			||||||
        // hdd temperature
 | 
					        // hdd temperature
 | 
				
			||||||
        QString device = _source;
 | 
					        QString device = _source;
 | 
				
			||||||
        device.remove("hdd/temperature");
 | 
					        device.remove("extsysmon/hdd/temperature");
 | 
				
			||||||
        int index = m_devices["hdd"].indexOf(device);
 | 
					        int index = m_devices["hdd"].indexOf(device);
 | 
				
			||||||
        if (index > -1) {
 | 
					        if (index > -1) {
 | 
				
			||||||
            QString key = QString("hddtemp%1").arg(index);
 | 
					            QString key = QString("hddtemp%1").arg(index);
 | 
				
			||||||
@ -312,15 +313,15 @@ QStringList AWDataEngineMapper::registerSource(const QString &_source, const KSy
 | 
				
			|||||||
        key.remove("extsysmon/player/");
 | 
					        key.remove("extsysmon/player/");
 | 
				
			||||||
        m_map.insert(_source, key);
 | 
					        m_map.insert(_source, key);
 | 
				
			||||||
        m_formatter[key] = AWKeysAggregator::FormatterType::NoFormat;
 | 
					        m_formatter[key] = AWKeysAggregator::FormatterType::NoFormat;
 | 
				
			||||||
    } else if (_source == "extsysmon/ps/running/count") {
 | 
					    } else if (_source == "extsysmon/ps/running") {
 | 
				
			||||||
        // running processes count
 | 
					        // running processes count
 | 
				
			||||||
        m_map.insert(_source, "pscount");
 | 
					        m_map.insert(_source, "pscount");
 | 
				
			||||||
        m_formatter["pscount"] = AWKeysAggregator::FormatterType::NoFormat;
 | 
					        m_formatter["pscount"] = AWKeysAggregator::FormatterType::NoFormat;
 | 
				
			||||||
    } else if (_source == "extsysmon/ps/running/list") {
 | 
					    } else if (_source == "extsysmon/ps/list") {
 | 
				
			||||||
        // list of running processes
 | 
					        // list of running processes
 | 
				
			||||||
        m_map.insert(_source, "ps");
 | 
					        m_map.insert(_source, "ps");
 | 
				
			||||||
        m_formatter["ps"] = AWKeysAggregator::FormatterType::List;
 | 
					        m_formatter["ps"] = AWKeysAggregator::FormatterType::List;
 | 
				
			||||||
    } else if (_source == "extsysmon/ps/total/count") {
 | 
					    } else if (_source == "extsysmon/ps/count") {
 | 
				
			||||||
        // total processes count
 | 
					        // total processes count
 | 
				
			||||||
        m_map.insert(_source, "pstot");
 | 
					        m_map.insert(_source, "pstot");
 | 
				
			||||||
        m_formatter["pstot"] = AWKeysAggregator::FormatterType::NoFormat;
 | 
					        m_formatter["pstot"] = AWKeysAggregator::FormatterType::NoFormat;
 | 
				
			||||||
@ -346,9 +347,10 @@ QStringList AWDataEngineMapper::registerSource(const QString &_source, const KSy
 | 
				
			|||||||
        // gb
 | 
					        // gb
 | 
				
			||||||
        m_map.insert(_source, "swapgb");
 | 
					        m_map.insert(_source, "swapgb");
 | 
				
			||||||
        m_formatter["swapgb"] = AWKeysAggregator::FormatterType::MemGBFormat;
 | 
					        m_formatter["swapgb"] = AWKeysAggregator::FormatterType::MemGBFormat;
 | 
				
			||||||
    } else if (_source.startsWith("lmsensors/")) {
 | 
					    } else if (_source.startsWith("lmsensors/") || _source.contains(cpuTempRegExp)
 | 
				
			||||||
 | 
					               || _source == "cpu/all/averageTemperature") {
 | 
				
			||||||
        // temperature
 | 
					        // temperature
 | 
				
			||||||
        int index = m_devices["temp"].indexOf(_source);
 | 
					        auto index = m_devices["temp"].indexOf(_source);
 | 
				
			||||||
        // HACK on DE initialization there are no units key
 | 
					        // HACK on DE initialization there are no units key
 | 
				
			||||||
        if (_units == KSysGuard::UnitInvalid)
 | 
					        if (_units == KSysGuard::UnitInvalid)
 | 
				
			||||||
            return QStringList({QString("temp%1").arg(index)});
 | 
					            return QStringList({QString("temp%1").arg(index)});
 | 
				
			||||||
@ -358,7 +360,7 @@ QStringList AWDataEngineMapper::registerSource(const QString &_source, const KSy
 | 
				
			|||||||
            m_formatter[key] = _units == KSysGuard::UnitCelsius ? AWKeysAggregator::FormatterType::Temperature
 | 
					            m_formatter[key] = _units == KSysGuard::UnitCelsius ? AWKeysAggregator::FormatterType::Temperature
 | 
				
			||||||
                                                                : AWKeysAggregator::FormatterType::Integer;
 | 
					                                                                : AWKeysAggregator::FormatterType::Integer;
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
    } else if (_source == "Local") {
 | 
					    } else if (_source == "extsysmon/time/now") {
 | 
				
			||||||
        // time
 | 
					        // time
 | 
				
			||||||
        m_map.insert(_source, "time");
 | 
					        m_map.insert(_source, "time");
 | 
				
			||||||
        m_formatter["time"] = AWKeysAggregator::FormatterType::Time;
 | 
					        m_formatter["time"] = AWKeysAggregator::FormatterType::Time;
 | 
				
			||||||
@ -410,7 +412,7 @@ QStringList AWDataEngineMapper::registerSource(const QString &_source, const KSy
 | 
				
			|||||||
        m_formatter[key] = AWKeysAggregator::FormatterType::Temperature;
 | 
					        m_formatter[key] = AWKeysAggregator::FormatterType::Temperature;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    QStringList foundKeys = keysFromSource(_source);
 | 
					    auto foundKeys = keysFromSource(_source);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    // rewrite formatters for custom ones
 | 
					    // rewrite formatters for custom ones
 | 
				
			||||||
    QStringList customFormattersKeys;
 | 
					    QStringList customFormattersKeys;
 | 
				
			||||||
@ -425,7 +427,7 @@ QStringList AWDataEngineMapper::registerSource(const QString &_source, const KSy
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    // 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 = _keys.isEmpty() || std::any_of(foundKeys.cbegin(), foundKeys.cend(), [&_keys](const QString &key) {
 | 
					    auto required = _keys.isEmpty() || std::any_of(foundKeys.cbegin(), foundKeys.cend(), [&_keys](const QString &key) {
 | 
				
			||||||
                        return _keys.contains(key);
 | 
					                        return _keys.contains(key);
 | 
				
			||||||
                    });
 | 
					                    });
 | 
				
			||||||
    if (!required) {
 | 
					    if (!required) {
 | 
				
			||||||
 | 
				
			|||||||
@ -302,18 +302,20 @@ void AWKeyOperations::addDevice(const QString &_source)
 | 
				
			|||||||
{
 | 
					{
 | 
				
			||||||
    qCDebug(LOG_AW) << "Source" << _source;
 | 
					    qCDebug(LOG_AW) << "Source" << _source;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    auto diskRegexp = QRegularExpression("disk/(?:md|sd|hd)[a-z|0-9]_.*/Rate/(?:rblk)");
 | 
					    auto diskRegexp = QRegularExpression("disk/.*/read");
 | 
				
			||||||
    auto mountRegexp = QRegularExpression("partitions/.*/filllevel");
 | 
					    auto mountRegexp = QRegularExpression("disk/.*/usedPercent");
 | 
				
			||||||
 | 
					    auto cpuTempRegExp = QRegularExpression("^cpu/cpu.*/temperature$");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    if (_source.contains(diskRegexp)) {
 | 
					    if (_source.contains(diskRegexp)) {
 | 
				
			||||||
        QString device = _source;
 | 
					        auto device = _source;
 | 
				
			||||||
        device.remove("/Rate/rblk");
 | 
					        device.remove("disk/").remove("/read");
 | 
				
			||||||
        addKeyToCache("disk", device);
 | 
					        addKeyToCache("disk", device);
 | 
				
			||||||
    } else if (_source.contains(mountRegexp)) {
 | 
					    } else if (_source.contains(mountRegexp)) {
 | 
				
			||||||
        QString device = _source;
 | 
					        auto device = _source;
 | 
				
			||||||
        device.remove("partitions").remove("/filllevel");
 | 
					        device.remove("disk/").remove("/usedPercent");
 | 
				
			||||||
        addKeyToCache("mount", device);
 | 
					        addKeyToCache("mount", device);
 | 
				
			||||||
    } else if (_source.startsWith("lmsensors")) {
 | 
					    } else if (_source.startsWith("lmsensors") || _source.contains(cpuTempRegExp)
 | 
				
			||||||
 | 
					               || _source == "cpu/all/averageTemperature") {
 | 
				
			||||||
        addKeyToCache("temp", _source);
 | 
					        addKeyToCache("temp", _source);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
				
			|||||||
@ -60,7 +60,8 @@ AWKeys::AWKeys(QObject *_parent)
 | 
				
			|||||||
    connect(m_timer, &QTimer::timeout, this, &AWKeys::updateTextData);
 | 
					    connect(m_timer, &QTimer::timeout, this, &AWKeys::updateTextData);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    // transfer signal from AWDataAggregator object to QML ui
 | 
					    // transfer signal from AWDataAggregator object to QML ui
 | 
				
			||||||
    connect(m_dataAggregator, &AWDataAggregator::toolTipPainted, [this](const QString &_tooltip) { emit(needToolTipToBeUpdated(_tooltip)); });
 | 
					    connect(m_dataAggregator, &AWDataAggregator::toolTipPainted,
 | 
				
			||||||
 | 
					            [this](const QString &_tooltip) { emit(needToolTipToBeUpdated(_tooltip)); });
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    connect(this, &AWKeys::dropSourceFromDataengine, m_dataEngineAggregator, &AWDataEngineAggregator::dropSource);
 | 
					    connect(this, &AWKeys::dropSourceFromDataengine, m_dataEngineAggregator, &AWDataEngineAggregator::dropSource);
 | 
				
			||||||
    connect(m_dataEngineAggregator, &AWDataEngineAggregator::dataUpdated, this, &AWKeys::dataUpdated);
 | 
					    connect(m_dataEngineAggregator, &AWDataEngineAggregator::dataUpdated, this, &AWKeys::dataUpdated);
 | 
				
			||||||
@ -102,7 +103,6 @@ void AWKeys::initKeys(const QString &_currentPattern, const int _interval, const
 | 
				
			|||||||
    m_aggregator->initFormatters();
 | 
					    m_aggregator->initFormatters();
 | 
				
			||||||
    m_keyOperator->setPattern(_currentPattern);
 | 
					    m_keyOperator->setPattern(_currentPattern);
 | 
				
			||||||
    m_keyOperator->updateCache();
 | 
					    m_keyOperator->updateCache();
 | 
				
			||||||
    m_dataEngineAggregator->reconnectSources(_interval);
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
    // timer
 | 
					    // timer
 | 
				
			||||||
    m_timer->setInterval(_interval);
 | 
					    m_timer->setInterval(_interval);
 | 
				
			||||||
@ -373,7 +373,6 @@ void AWKeys::setDataBySource(const QString &_source, const KSysGuard::SensorInfo
 | 
				
			|||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    m_mutex.lock();
 | 
					    m_mutex.lock();
 | 
				
			||||||
    // HACK workaround for time values which are stored in the different path
 | 
					 | 
				
			||||||
    std::for_each(tags.cbegin(), tags.cend(), [this, &_data](const QString &tag) { m_values[tag] = _data.payload; });
 | 
					    std::for_each(tags.cbegin(), tags.cend(), [this, &_data](const QString &tag) { m_values[tag] = _data.payload; });
 | 
				
			||||||
    m_mutex.unlock();
 | 
					    m_mutex.unlock();
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
				
			|||||||
@ -113,26 +113,26 @@ QString AWKeysAggregator::formatter(const QVariant &_data, const QString &_key,
 | 
				
			|||||||
        output = QString("%1").arg(temperature(_data.toDouble()), 5, 'f', 1);
 | 
					        output = QString("%1").arg(temperature(_data.toDouble()), 5, 'f', 1);
 | 
				
			||||||
        break;
 | 
					        break;
 | 
				
			||||||
    case FormatterType::Time:
 | 
					    case FormatterType::Time:
 | 
				
			||||||
        output = _data.toDateTime().toString();
 | 
					        output = QDateTime::fromSecsSinceEpoch(_data.toLongLong()).toString();
 | 
				
			||||||
        break;
 | 
					        break;
 | 
				
			||||||
    case FormatterType::TimeCustom:
 | 
					    case FormatterType::TimeCustom:
 | 
				
			||||||
        output = m_customTime;
 | 
					        output = m_customTime;
 | 
				
			||||||
        [&output, loc, this](const QDateTime &dt) {
 | 
					        [&output, loc, this](const QDateTime &dt) {
 | 
				
			||||||
            for (auto &key : m_timeKeys)
 | 
					            for (auto &key : m_timeKeys)
 | 
				
			||||||
                output.replace(QString("$%1").arg(key), loc.toString(dt, key));
 | 
					                output.replace(QString("$%1").arg(key), loc.toString(dt, key));
 | 
				
			||||||
        }(_data.toDateTime());
 | 
					        }(QDateTime::fromSecsSinceEpoch(_data.toLongLong()));
 | 
				
			||||||
        break;
 | 
					        break;
 | 
				
			||||||
    case FormatterType::TimeISO:
 | 
					    case FormatterType::TimeISO:
 | 
				
			||||||
        output = _data.toDateTime().toString(Qt::ISODate);
 | 
					        output = QDateTime::fromSecsSinceEpoch(_data.toLongLong()).toString(Qt::ISODate);
 | 
				
			||||||
        break;
 | 
					        break;
 | 
				
			||||||
    case FormatterType::TimeLong:
 | 
					    case FormatterType::TimeLong:
 | 
				
			||||||
        output = loc.toString(_data.toDateTime(), QLocale::LongFormat);
 | 
					        output = loc.toString(QDateTime::fromSecsSinceEpoch(_data.toLongLong()), QLocale::LongFormat);
 | 
				
			||||||
        break;
 | 
					        break;
 | 
				
			||||||
    case FormatterType::TimeShort:
 | 
					    case FormatterType::TimeShort:
 | 
				
			||||||
        output = loc.toString(_data.toDateTime(), QLocale::ShortFormat);
 | 
					        output = loc.toString(QDateTime::fromSecsSinceEpoch(_data.toLongLong()), QLocale::ShortFormat);
 | 
				
			||||||
        break;
 | 
					        break;
 | 
				
			||||||
    case FormatterType::Timestamp:
 | 
					    case FormatterType::Timestamp:
 | 
				
			||||||
        output = QString("%1").arg(_data.toDateTime().toMSecsSinceEpoch() / 1000.0, 10, 'f', 0);
 | 
					        output = _data.toString();
 | 
				
			||||||
        break;
 | 
					        break;
 | 
				
			||||||
    case FormatterType::Uptime:
 | 
					    case FormatterType::Uptime:
 | 
				
			||||||
    case FormatterType::UptimeCustom:
 | 
					    case FormatterType::UptimeCustom:
 | 
				
			||||||
 | 
				
			|||||||
@ -33,13 +33,13 @@ add_library(${SUBPROJECT} STATIC ${SUBPROJECT_SOURCE} ${SUBPROJECT_HEADER} ${SUB
 | 
				
			|||||||
target_link_libraries(${SUBPROJECT} ${Qt_LIBRARIES} ${Kf6_LIBRARIES})
 | 
					target_link_libraries(${SUBPROJECT} ${Qt_LIBRARIES} ${Kf6_LIBRARIES})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# install
 | 
					# install
 | 
				
			||||||
install(DIRECTORY ${SUBPROJECT_CONFIGS} DESTINATION ${DATA_INSTALL_DIR}/${PROJECT_NAME})
 | 
					install(DIRECTORY ${SUBPROJECT_CONFIGS} DESTINATION ${KDE_INSTALL_DATADIR}/${PROJECT_NAME})
 | 
				
			||||||
install(DIRECTORY ${SUBPROJECT_FORMATTERS} DESTINATION ${DATA_INSTALL_DIR}/${PROJECT_NAME})
 | 
					install(DIRECTORY ${SUBPROJECT_FORMATTERS} DESTINATION ${KDE_INSTALL_DATADIR}/${PROJECT_NAME})
 | 
				
			||||||
install(DIRECTORY ${SUBPROJECT_GRAPHITEMS} DESTINATION ${DATA_INSTALL_DIR}/${PROJECT_NAME})
 | 
					install(DIRECTORY ${SUBPROJECT_GRAPHITEMS} DESTINATION ${KDE_INSTALL_DATADIR}/${PROJECT_NAME})
 | 
				
			||||||
install(DIRECTORY ${SUBPROJECT_QUOTES} DESTINATION ${DATA_INSTALL_DIR}/${PROJECT_NAME})
 | 
					install(DIRECTORY ${SUBPROJECT_QUOTES} DESTINATION ${KDE_INSTALL_DATADIR}/${PROJECT_NAME})
 | 
				
			||||||
install(DIRECTORY ${SUBPROJECT_SCRIPTS} DESTINATION ${DATA_INSTALL_DIR}/${PROJECT_NAME})
 | 
					install(DIRECTORY ${SUBPROJECT_SCRIPTS} DESTINATION ${KDE_INSTALL_DATADIR}/${PROJECT_NAME})
 | 
				
			||||||
install(DIRECTORY ${SUBPROJECT_REQUESTS} DESTINATION ${DATA_INSTALL_DIR}/${PROJECT_NAME})
 | 
					install(DIRECTORY ${SUBPROJECT_REQUESTS} DESTINATION ${KDE_INSTALL_DATADIR}/${PROJECT_NAME})
 | 
				
			||||||
install(DIRECTORY ${SUBPROJECT_UPGRADE} DESTINATION ${DATA_INSTALL_DIR}/${PROJECT_NAME})
 | 
					install(DIRECTORY ${SUBPROJECT_UPGRADE} DESTINATION ${KDE_INSTALL_DATADIR}/${PROJECT_NAME})
 | 
				
			||||||
install(DIRECTORY ${SUBPROJECT_WEATHER} DESTINATION ${DATA_INSTALL_DIR}/${PROJECT_NAME})
 | 
					install(DIRECTORY ${SUBPROJECT_WEATHER} DESTINATION ${KDE_INSTALL_DATADIR}/${PROJECT_NAME})
 | 
				
			||||||
install(FILES ${SUBPROJECT_INI} DESTINATION ${KDE_INSTALL_CONFDIR})
 | 
					install(FILES ${SUBPROJECT_INI} DESTINATION /${KDE_INSTALL_CONFDIR})
 | 
				
			||||||
install(FILES ${CMAKE_CURRENT_BINARY_DIR}/${SUBPROJECT_WEATHER_JSON} DESTINATION ${DATA_INSTALL_DIR}/${PROJECT_NAME}/weather)
 | 
					install(FILES ${CMAKE_CURRENT_BINARY_DIR}/${SUBPROJECT_WEATHER_JSON} DESTINATION ${KDE_INSTALL_DATADIR}/${PROJECT_NAME}/weather)
 | 
				
			||||||
 | 
				
			|||||||
@ -5,120 +5,120 @@
 | 
				
			|||||||
    "image": {
 | 
					    "image": {
 | 
				
			||||||
        "__comment": "should be described as html image with full path inside",
 | 
					        "__comment": "should be described as html image with full path inside",
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        "default": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/3200.gif\">",
 | 
					        "default": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/3200.gif\">",
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        "800": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/01d.png\">",
 | 
					        "800": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/01d.png\">",
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        "801": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/02d.png\">",
 | 
					        "801": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/02d.png\">",
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        "802": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/03d.png\">",
 | 
					        "802": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/03d.png\">",
 | 
				
			||||||
        "803": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/03d.png\">",
 | 
					        "803": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/03d.png\">",
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        "804": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/04d.png\">",
 | 
					                "804": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/04d.png\">",
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        "300": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/09d.png\">",
 | 
					        "300": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/09d.png\">",
 | 
				
			||||||
        "301": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/09d.png\">",
 | 
					        "301": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/09d.png\">",
 | 
				
			||||||
        "302": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/09d.png\">",
 | 
					        "302": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/09d.png\">",
 | 
				
			||||||
        "310": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/09d.png\">",
 | 
					        "310": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/09d.png\">",
 | 
				
			||||||
        "311": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/09d.png\">",
 | 
					        "311": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/09d.png\">",
 | 
				
			||||||
        "312": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/09d.png\">",
 | 
					        "312": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/09d.png\">",
 | 
				
			||||||
        "313": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/09d.png\">",
 | 
					        "313": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/09d.png\">",
 | 
				
			||||||
        "314": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/09d.png\">",
 | 
					        "314": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/09d.png\">",
 | 
				
			||||||
        "321": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/09d.png\">",
 | 
					        "321": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/09d.png\">",
 | 
				
			||||||
        "520": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/09d.png\">",
 | 
					        "520": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/09d.png\">",
 | 
				
			||||||
        "521": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/09d.png\">",
 | 
					        "521": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/09d.png\">",
 | 
				
			||||||
        "522": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/09d.png\">",
 | 
					        "522": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/09d.png\">",
 | 
				
			||||||
        "531": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/09d.png\">",
 | 
					        "531": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/09d.png\">",
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        "500": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/10d.png\">",
 | 
					        "500": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/10d.png\">",
 | 
				
			||||||
        "501": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/10d.png\">",
 | 
					        "501": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/10d.png\">",
 | 
				
			||||||
        "502": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/10d.png\">",
 | 
					        "502": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/10d.png\">",
 | 
				
			||||||
        "503": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/10d.png\">",
 | 
					        "503": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/10d.png\">",
 | 
				
			||||||
        "504": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/10d.png\">",
 | 
					        "504": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/10d.png\">",
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        "200": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/11d.png\">",
 | 
					        "200": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/11d.png\">",
 | 
				
			||||||
        "201": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/11d.png\">",
 | 
					        "201": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/11d.png\">",
 | 
				
			||||||
        "202": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/11d.png\">",
 | 
					        "202": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/11d.png\">",
 | 
				
			||||||
        "210": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/11d.png\">",
 | 
					        "210": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/11d.png\">",
 | 
				
			||||||
        "211": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/11d.png\">",
 | 
					        "211": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/11d.png\">",
 | 
				
			||||||
        "212": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/11d.png\">",
 | 
					        "212": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/11d.png\">",
 | 
				
			||||||
        "221": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/11d.png\">",
 | 
					        "221": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/11d.png\">",
 | 
				
			||||||
        "230": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/11d.png\">",
 | 
					        "230": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/11d.png\">",
 | 
				
			||||||
        "231": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/11d.png\">",
 | 
					        "231": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/11d.png\">",
 | 
				
			||||||
        "232": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/11d.png\">",
 | 
					        "232": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/11d.png\">",
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        "511": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/13d.png\">",
 | 
					        "511": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/13d.png\">",
 | 
				
			||||||
        "600": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/13d.png\">",
 | 
					        "600": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/13d.png\">",
 | 
				
			||||||
        "601": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/13d.png\">",
 | 
					        "601": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/13d.png\">",
 | 
				
			||||||
        "602": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/13d.png\">",
 | 
					        "602": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/13d.png\">",
 | 
				
			||||||
        "611": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/13d.png\">",
 | 
					        "611": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/13d.png\">",
 | 
				
			||||||
        "612": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/13d.png\">",
 | 
					        "612": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/13d.png\">",
 | 
				
			||||||
        "615": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/13d.png\">",
 | 
					        "615": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/13d.png\">",
 | 
				
			||||||
        "616": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/13d.png\">",
 | 
					        "616": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/13d.png\">",
 | 
				
			||||||
        "620": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/13d.png\">",
 | 
					        "620": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/13d.png\">",
 | 
				
			||||||
        "621": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/13d.png\">",
 | 
					        "621": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/13d.png\">",
 | 
				
			||||||
        "622": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/13d.png\">",
 | 
					        "622": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/13d.png\">",
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        "701": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/50d.png\">",
 | 
					        "701": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/50d.png\">",
 | 
				
			||||||
        "711": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/50d.png\">",
 | 
					        "711": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/50d.png\">",
 | 
				
			||||||
        "721": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/50d.png\">",
 | 
					        "721": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/50d.png\">",
 | 
				
			||||||
        "731": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/50d.png\">",
 | 
					        "731": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/50d.png\">",
 | 
				
			||||||
        "741": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/50d.png\">",
 | 
					        "741": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/50d.png\">",
 | 
				
			||||||
        "751": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/50d.png\">",
 | 
					        "751": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/50d.png\">",
 | 
				
			||||||
        "761": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/50d.png\">",
 | 
					        "761": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/50d.png\">",
 | 
				
			||||||
        "762": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/50d.png\">",
 | 
					        "762": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/50d.png\">",
 | 
				
			||||||
        "771": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/50d.png\">",
 | 
					        "771": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/50d.png\">",
 | 
				
			||||||
        "781": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/50d.png\">",
 | 
					        "781": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/50d.png\">",
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        "0": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/0.gif\">",
 | 
					        "0": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/0.gif\">",
 | 
				
			||||||
        "1": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/1.gif\">",
 | 
					        "1": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/1.gif\">",
 | 
				
			||||||
        "2": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/2.gif\">",
 | 
					        "2": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/2.gif\">",
 | 
				
			||||||
        "3": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/3.gif\">",
 | 
					        "3": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/3.gif\">",
 | 
				
			||||||
        "4": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/4.gif\">",
 | 
					        "4": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/4.gif\">",
 | 
				
			||||||
        "5": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/5.gif\">",
 | 
					        "5": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/5.gif\">",
 | 
				
			||||||
        "6": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/6.gif\">",
 | 
					        "6": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/6.gif\">",
 | 
				
			||||||
        "7": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/7.gif\">",
 | 
					        "7": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/7.gif\">",
 | 
				
			||||||
        "8": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/8.gif\">",
 | 
					        "8": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/8.gif\">",
 | 
				
			||||||
        "9": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/9.gif\">",
 | 
					        "9": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/9.gif\">",
 | 
				
			||||||
        "10": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/10.gif\">",
 | 
					        "10": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/10.gif\">",
 | 
				
			||||||
        "11": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/11.gif\">",
 | 
					        "11": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/11.gif\">",
 | 
				
			||||||
        "12": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/12.gif\">",
 | 
					        "12": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/12.gif\">",
 | 
				
			||||||
        "13": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/13.gif\">",
 | 
					        "13": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/13.gif\">",
 | 
				
			||||||
        "14": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/14.gif\">",
 | 
					        "14": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/14.gif\">",
 | 
				
			||||||
        "15": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/15.gif\">",
 | 
					        "15": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/15.gif\">",
 | 
				
			||||||
        "16": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/16.gif\">",
 | 
					        "16": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/16.gif\">",
 | 
				
			||||||
        "17": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/17.gif\">",
 | 
					        "17": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/17.gif\">",
 | 
				
			||||||
        "18": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/18.gif\">",
 | 
					        "18": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/18.gif\">",
 | 
				
			||||||
        "19": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/19.gif\">",
 | 
					        "19": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/19.gif\">",
 | 
				
			||||||
        "20": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/20.gif\">",
 | 
					        "20": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/20.gif\">",
 | 
				
			||||||
        "21": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/21.gif\">",
 | 
					        "21": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/21.gif\">",
 | 
				
			||||||
        "22": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/22.gif\">",
 | 
					        "22": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/22.gif\">",
 | 
				
			||||||
        "23": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/23.gif\">",
 | 
					        "23": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/23.gif\">",
 | 
				
			||||||
        "24": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/24.gif\">",
 | 
					        "24": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/24.gif\">",
 | 
				
			||||||
        "25": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/25.gif\">",
 | 
					        "25": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/25.gif\">",
 | 
				
			||||||
        "26": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/26.gif\">",
 | 
					        "26": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/26.gif\">",
 | 
				
			||||||
        "27": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/27.gif\">",
 | 
					        "27": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/27.gif\">",
 | 
				
			||||||
        "28": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/28.gif\">",
 | 
					        "28": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/28.gif\">",
 | 
				
			||||||
        "29": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/29.gif\">",
 | 
					        "29": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/29.gif\">",
 | 
				
			||||||
        "30": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/30.gif\">",
 | 
					        "30": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/30.gif\">",
 | 
				
			||||||
        "31": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/31.gif\">",
 | 
					        "31": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/31.gif\">",
 | 
				
			||||||
        "32": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/32.gif\">",
 | 
					        "32": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/32.gif\">",
 | 
				
			||||||
        "33": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/33.gif\">",
 | 
					        "33": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/33.gif\">",
 | 
				
			||||||
        "34": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/34.gif\">",
 | 
					        "34": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/34.gif\">",
 | 
				
			||||||
        "35": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/35.gif\">",
 | 
					        "35": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/35.gif\">",
 | 
				
			||||||
        "36": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/36.gif\">",
 | 
					        "36": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/36.gif\">",
 | 
				
			||||||
        "37": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/37.gif\">",
 | 
					        "37": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/37.gif\">",
 | 
				
			||||||
        "38": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/38.gif\">",
 | 
					        "38": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/38.gif\">",
 | 
				
			||||||
        "39": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/39.gif\">",
 | 
					        "39": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/39.gif\">",
 | 
				
			||||||
        "40": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/40.gif\">",
 | 
					        "40": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/40.gif\">",
 | 
				
			||||||
        "41": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/41.gif\">",
 | 
					        "41": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/41.gif\">",
 | 
				
			||||||
        "42": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/42.gif\">",
 | 
					        "42": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/42.gif\">",
 | 
				
			||||||
        "43": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/43.gif\">",
 | 
					        "43": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/43.gif\">",
 | 
				
			||||||
        "44": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/44.gif\">",
 | 
					        "44": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/44.gif\">",
 | 
				
			||||||
        "45": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/45.gif\">",
 | 
					        "45": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/45.gif\">",
 | 
				
			||||||
        "46": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/46.gif\">",
 | 
					        "46": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/46.gif\">",
 | 
				
			||||||
        "47": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/47.gif\">",
 | 
					        "47": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/47.gif\">",
 | 
				
			||||||
        "3200": "<img src=\"@CMAKE_INSTALL_PREFIX@/@DATA_INSTALL_DIR@/@PROJECT_NAME@/weather/3200.gif\">"
 | 
					        "3200": "<img src=\"@KDE_INSTALL_FULL_DATADIR@/@PROJECT_NAME@/weather/3200.gif\">"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    "text": {
 | 
					    "text": {
 | 
				
			||||||
 | 
				
			|||||||
@ -93,9 +93,9 @@ QVariantHash OWMWeatherProvider::parseSingleJson(const QVariantMap &_json) const
 | 
				
			|||||||
    // main data
 | 
					    // main data
 | 
				
			||||||
    QVariantMap mainWeather = _json["main"].toMap();
 | 
					    QVariantMap mainWeather = _json["main"].toMap();
 | 
				
			||||||
    if (!weather.isEmpty()) {
 | 
					    if (!weather.isEmpty()) {
 | 
				
			||||||
        output[tag("humidity")] = mainWeather["humidity"].toFloat();
 | 
					        output[tag("humidity")] = mainWeather["humidity"].toDouble();
 | 
				
			||||||
        output[tag("pressure")] = mainWeather["pressure"].toFloat();
 | 
					        output[tag("pressure")] = mainWeather["pressure"].toDouble();
 | 
				
			||||||
        output[tag("temperature")] = mainWeather["temp"].toFloat();
 | 
					        output[tag("temperature")] = mainWeather["temp"].toDouble();
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    // timestamp
 | 
					    // timestamp
 | 
				
			||||||
 | 
				
			|||||||
@ -86,7 +86,7 @@ QVariantHash YahooWeatherProvider::parseCurrent(const QVariantMap &_json, const
 | 
				
			|||||||
    values[tag("timestamp")] = condition["date"].toString();
 | 
					    values[tag("timestamp")] = condition["date"].toString();
 | 
				
			||||||
    values[tag("humidity")] = _atmosphere["humidity"].toInt();
 | 
					    values[tag("humidity")] = _atmosphere["humidity"].toInt();
 | 
				
			||||||
    // HACK temporary fix of invalid values on Yahoo! side
 | 
					    // HACK temporary fix of invalid values on Yahoo! side
 | 
				
			||||||
    values[tag("pressure")] = static_cast<int>(_atmosphere["pressure"].toFloat() / 33.863753);
 | 
					    values[tag("pressure")] = static_cast<int>(_atmosphere["pressure"].toDouble() / 33.863753);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    return values;
 | 
					    return values;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
@ -103,7 +103,7 @@ QVariantHash YahooWeatherProvider::parseForecast(const QVariantMap &_json) const
 | 
				
			|||||||
    values[tag("weatherId")] = id;
 | 
					    values[tag("weatherId")] = id;
 | 
				
			||||||
    values[tag("timestamp")] = weatherMap["date"].toString();
 | 
					    values[tag("timestamp")] = weatherMap["date"].toString();
 | 
				
			||||||
    // yahoo provides high and low temperatures. Lets calculate average one
 | 
					    // yahoo provides high and low temperatures. Lets calculate average one
 | 
				
			||||||
    values[tag("temperature")] = (weatherMap["high"].toFloat() + weatherMap["low"].toFloat()) / 2.0;
 | 
					    values[tag("temperature")] = (weatherMap["high"].toDouble() + weatherMap["low"].toDouble()) / 2.0;
 | 
				
			||||||
    // ... and no forecast data for humidity and pressure
 | 
					    // ... and no forecast data for humidity and pressure
 | 
				
			||||||
    values[tag("humidity")] = 0;
 | 
					    values[tag("humidity")] = 0;
 | 
				
			||||||
    values[tag("pressure")] = 0.0;
 | 
					    values[tag("pressure")] = 0.0;
 | 
				
			||||||
 | 
				
			|||||||
@ -1,7 +1,7 @@
 | 
				
			|||||||
set(SUBPROJECT plasma_applet_desktop-panel)
 | 
					set(SUBPROJECT plasma_applet_desktop-panel)
 | 
				
			||||||
message(STATUS "Subproject ${SUBPROJECT}")
 | 
					message(STATUS "Subproject ${SUBPROJECT}")
 | 
				
			||||||
 | 
					
 | 
				
			||||||
configure_file(metadata.desktop ${CMAKE_CURRENT_SOURCE_DIR}/package/metadata.desktop)
 | 
					configure_file(metadata.json ${CMAKE_CURRENT_SOURCE_DIR}/package/metadata.json)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
add_subdirectory(plugin)
 | 
					add_subdirectory(plugin)
 | 
				
			||||||
plasma_install_package(package org.kde.plasma.desktoppanel)
 | 
					plasma_install_package(package org.kde.plasma.desktoppanel)
 | 
				
			||||||
 | 
				
			|||||||
@ -1,26 +0,0 @@
 | 
				
			|||||||
[Desktop Entry]
 | 
					 | 
				
			||||||
Encoding=UTF-8
 | 
					 | 
				
			||||||
Name=Desktop Panel
 | 
					 | 
				
			||||||
Comment=A minimalistic Plasmoid
 | 
					 | 
				
			||||||
Comment[en]=A minimalistic Plasmoid
 | 
					 | 
				
			||||||
Comment[es]=Un plasmoide minimalista
 | 
					 | 
				
			||||||
Comment[es]=Un script Plasmoïde minimaliste
 | 
					 | 
				
			||||||
Comment[pt_BR]=Um script Plasmoid
 | 
					 | 
				
			||||||
Comment[ru]=Минималистичный плазмоид
 | 
					 | 
				
			||||||
Comment[uk]=Мінімалістичний плазмоїд
 | 
					 | 
				
			||||||
X-KDE-ServiceTypes=Plasma/Applet
 | 
					 | 
				
			||||||
Type=Service
 | 
					 | 
				
			||||||
Icon=utilities-system-monitor
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
X-KDE-ServiceTypes=Plasma/Applet
 | 
					 | 
				
			||||||
X-Plasma-API=declarativeappletscript
 | 
					 | 
				
			||||||
X-Plasma-MainScript=ui/main.qml
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
X-KDE-PluginInfo-Author=Evgeniy Alekseev aka arcanis
 | 
					 | 
				
			||||||
X-KDE-PluginInfo-Email=esalexeev@gmail.com
 | 
					 | 
				
			||||||
X-KDE-PluginInfo-Name=org.kde.plasma.desktoppanel
 | 
					 | 
				
			||||||
X-KDE-PluginInfo-Version=@PROJECT_VERSION@
 | 
					 | 
				
			||||||
X-KDE-PluginInfo-Website=https://arcanis.me/projects/awesome-widgets/
 | 
					 | 
				
			||||||
X-KDE-PluginInfo-Category=System Information
 | 
					 | 
				
			||||||
X-KDE-PluginInfo-License=GPLv3
 | 
					 | 
				
			||||||
X-KDE-PluginInfo-EnabledByDefault=true
 | 
					 | 
				
			||||||
@ -1,4 +1,5 @@
 | 
				
			|||||||
{
 | 
					{
 | 
				
			||||||
 | 
					    "KPackageStructure": "Plasma/Applet",
 | 
				
			||||||
    "KPlugin": {
 | 
					    "KPlugin": {
 | 
				
			||||||
        "Authors": [
 | 
					        "Authors": [
 | 
				
			||||||
            {
 | 
					            {
 | 
				
			||||||
@ -18,12 +19,8 @@
 | 
				
			|||||||
        "Id": "org.kde.plasma.desktoppanel",
 | 
					        "Id": "org.kde.plasma.desktoppanel",
 | 
				
			||||||
        "License": "GPLv3",
 | 
					        "License": "GPLv3",
 | 
				
			||||||
        "Name": "Desktop Panel",
 | 
					        "Name": "Desktop Panel",
 | 
				
			||||||
        "ServiceTypes": [
 | 
					 | 
				
			||||||
            "Plasma/Applet"
 | 
					 | 
				
			||||||
        ],
 | 
					 | 
				
			||||||
        "Version": "@PROJECT_VERSION@",
 | 
					        "Version": "@PROJECT_VERSION@",
 | 
				
			||||||
        "Website": "https://arcanis.me/projects/awesome-widgets/"
 | 
					        "Website": "https://arcanis.me/projects/awesome-widgets/"
 | 
				
			||||||
    },
 | 
					    },
 | 
				
			||||||
    "X-Plasma-API": "declarativeappletscript",
 | 
					    "X-Plasma-API-Minimum-Version": "6.0"
 | 
				
			||||||
    "X-Plasma-MainScript": "ui/main.qml"
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
				
			|||||||
@ -15,7 +15,7 @@
 | 
				
			|||||||
 *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  *
 | 
					 *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  *
 | 
				
			||||||
 ***************************************************************************/
 | 
					 ***************************************************************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import QtQuick 2.0
 | 
					import QtQuick 2.15
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import org.kde.plasma.configuration 2.0
 | 
					import org.kde.plasma.configuration 2.0
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -7,88 +7,88 @@
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    <group name="Widget">
 | 
					    <group name="Widget">
 | 
				
			||||||
        <!--   widget -->
 | 
					        <!--   widget -->
 | 
				
			||||||
        <entry name="text" type="string">
 | 
					        <entry name="text" type="String">
 | 
				
			||||||
            <default>[$mark$number/$total: $name]</default>
 | 
					            <default>[$mark$number/$total: $name]</default>
 | 
				
			||||||
        </entry>
 | 
					        </entry>
 | 
				
			||||||
    </group>
 | 
					    </group>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <group name="Advanced">
 | 
					    <group name="Advanced">
 | 
				
			||||||
        <!--   advanced -->
 | 
					        <!--   advanced -->
 | 
				
			||||||
        <entry name="background" type="bool">
 | 
					        <entry name="background" type="Bool">
 | 
				
			||||||
            <default>true</default>
 | 
					            <default>true</default>
 | 
				
			||||||
        </entry>
 | 
					        </entry>
 | 
				
			||||||
        <entry name="verticalLayout" type="bool">
 | 
					        <entry name="verticalLayout" type="Bool">
 | 
				
			||||||
            <default>false</default>
 | 
					            <default>false</default>
 | 
				
			||||||
        </entry>
 | 
					        </entry>
 | 
				
			||||||
        <entry name="height" type="int">
 | 
					        <entry name="height" type="Int">
 | 
				
			||||||
            <default>0</default>
 | 
					            <default>0</default>
 | 
				
			||||||
        </entry>
 | 
					        </entry>
 | 
				
			||||||
        <entry name="width" type="int">
 | 
					        <entry name="width" type="Int">
 | 
				
			||||||
            <default>0</default>
 | 
					            <default>0</default>
 | 
				
			||||||
        </entry>
 | 
					        </entry>
 | 
				
			||||||
        <entry name="mark" type="string">
 | 
					        <entry name="mark" type="String">
 | 
				
			||||||
            <default>¤</default>
 | 
					            <default>¤</default>
 | 
				
			||||||
        </entry>
 | 
					        </entry>
 | 
				
			||||||
        <entry name="tooltipType" type="string">
 | 
					        <entry name="tooltipType" type="String">
 | 
				
			||||||
            <default>contours</default>
 | 
					            <default>contours</default>
 | 
				
			||||||
        </entry>
 | 
					        </entry>
 | 
				
			||||||
        <entry name="tooltipWidth" type="int">
 | 
					        <entry name="tooltipWidth" type="Int">
 | 
				
			||||||
            <default>200</default>
 | 
					            <default>200</default>
 | 
				
			||||||
        </entry>
 | 
					        </entry>
 | 
				
			||||||
        <entry name="tooltipColor" type="string">
 | 
					        <entry name="tooltipColor" type="String">
 | 
				
			||||||
            <default>#ffffff</default>
 | 
					            <default>#ffffff</default>
 | 
				
			||||||
        </entry>
 | 
					        </entry>
 | 
				
			||||||
    </group>
 | 
					    </group>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    <group name="Appearance">
 | 
					    <group name="Appearance">
 | 
				
			||||||
        <!--   appearance -->
 | 
					        <!--   appearance -->
 | 
				
			||||||
        <entry name="textAlign" type="string">
 | 
					        <entry name="textAlign" type="String">
 | 
				
			||||||
            <default>center</default>
 | 
					            <default>center</default>
 | 
				
			||||||
        </entry>
 | 
					        </entry>
 | 
				
			||||||
        <entry name="fontFamily" type="string">
 | 
					        <entry name="fontFamily" type="String">
 | 
				
			||||||
            <default>Terminus</default>
 | 
					            <default>Terminus</default>
 | 
				
			||||||
        </entry>
 | 
					        </entry>
 | 
				
			||||||
        <entry name="fontSize" type="int">
 | 
					        <entry name="fontSize" type="Int">
 | 
				
			||||||
            <default>12</default>
 | 
					            <default>12</default>
 | 
				
			||||||
        </entry>
 | 
					        </entry>
 | 
				
			||||||
        <entry name="fontColor" type="string">
 | 
					        <entry name="fontColor" type="String">
 | 
				
			||||||
            <default>#000000</default>
 | 
					            <default>#000000</default>
 | 
				
			||||||
        </entry>
 | 
					        </entry>
 | 
				
			||||||
        <entry name="fontWeight" type="string">
 | 
					        <entry name="fontWeight" type="String">
 | 
				
			||||||
            <default>normal</default>
 | 
					            <default>normal</default>
 | 
				
			||||||
        </entry>
 | 
					        </entry>
 | 
				
			||||||
        <entry name="fontStyle" type="string">
 | 
					        <entry name="fontStyle" type="String">
 | 
				
			||||||
            <default>normal</default>
 | 
					            <default>normal</default>
 | 
				
			||||||
        </entry>
 | 
					        </entry>
 | 
				
			||||||
        <entry name="textStyle" type="string">
 | 
					        <entry name="textStyle" type="String">
 | 
				
			||||||
            <default>normal</default>
 | 
					            <default>normal</default>
 | 
				
			||||||
        </entry>
 | 
					        </entry>
 | 
				
			||||||
        <entry name="textStyleColor" type="string">
 | 
					        <entry name="textStyleColor" type="String">
 | 
				
			||||||
            <default>#000000</default>
 | 
					            <default>#000000</default>
 | 
				
			||||||
        </entry>
 | 
					        </entry>
 | 
				
			||||||
        <!--   current -->
 | 
					        <!--   current -->
 | 
				
			||||||
        <entry name="currentTextAlign" type="string">
 | 
					        <entry name="currentTextAlign" type="String">
 | 
				
			||||||
            <default>center</default>
 | 
					            <default>center</default>
 | 
				
			||||||
        </entry>
 | 
					        </entry>
 | 
				
			||||||
        <entry name="currentFontFamily" type="string">
 | 
					        <entry name="currentFontFamily" type="String">
 | 
				
			||||||
            <default>Terminus</default>
 | 
					            <default>Terminus</default>
 | 
				
			||||||
        </entry>
 | 
					        </entry>
 | 
				
			||||||
        <entry name="currentFontSize" type="int">
 | 
					        <entry name="currentFontSize" type="Int">
 | 
				
			||||||
            <default>12</default>
 | 
					            <default>12</default>
 | 
				
			||||||
        </entry>
 | 
					        </entry>
 | 
				
			||||||
        <entry name="currentFontColor" type="string">
 | 
					        <entry name="currentFontColor" type="String">
 | 
				
			||||||
            <default>#ff0000</default>
 | 
					            <default>#ff0000</default>
 | 
				
			||||||
        </entry>
 | 
					        </entry>
 | 
				
			||||||
        <entry name="currentFontWeight" type="string">
 | 
					        <entry name="currentFontWeight" type="String">
 | 
				
			||||||
            <default>normal</default>
 | 
					            <default>normal</default>
 | 
				
			||||||
        </entry>
 | 
					        </entry>
 | 
				
			||||||
        <entry name="currentFontStyle" type="string">
 | 
					        <entry name="currentFontStyle" type="String">
 | 
				
			||||||
            <default>normal</default>
 | 
					            <default>normal</default>
 | 
				
			||||||
        </entry>
 | 
					        </entry>
 | 
				
			||||||
        <entry name="currentTextStyle" type="string">
 | 
					        <entry name="currentTextStyle" type="String">
 | 
				
			||||||
            <default>normal</default>
 | 
					            <default>normal</default>
 | 
				
			||||||
        </entry>
 | 
					        </entry>
 | 
				
			||||||
        <entry name="currentTextStyleColor" type="string">
 | 
					        <entry name="currentTextStyleColor" type="String">
 | 
				
			||||||
            <default>#000000</default>
 | 
					            <default>#000000</default>
 | 
				
			||||||
        </entry>
 | 
					        </entry>
 | 
				
			||||||
    </group>
 | 
					    </group>
 | 
				
			||||||
 | 
				
			|||||||
@ -15,7 +15,7 @@
 | 
				
			|||||||
 *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  *
 | 
					 *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  *
 | 
				
			||||||
 ***************************************************************************/
 | 
					 ***************************************************************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import QtQuick 2.0
 | 
					import QtQuick 2.15
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import org.kde.plasma.private.desktoppanel 1.0
 | 
					import org.kde.plasma.private.desktoppanel 1.0
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -15,7 +15,7 @@
 | 
				
			|||||||
 *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  *
 | 
					 *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  *
 | 
				
			||||||
 ***************************************************************************/
 | 
					 ***************************************************************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import QtQuick 2.0
 | 
					import QtQuick 2.15
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import org.kde.plasma.private.desktoppanel 1.0
 | 
					import org.kde.plasma.private.desktoppanel 1.0
 | 
				
			||||||
import "."
 | 
					import "."
 | 
				
			||||||
 | 
				
			|||||||
@ -15,8 +15,8 @@
 | 
				
			|||||||
 *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  *
 | 
					 *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  *
 | 
				
			||||||
 ***************************************************************************/
 | 
					 ***************************************************************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import QtQuick 2.0
 | 
					import QtQuick 2.15
 | 
				
			||||||
import QtQuick.Controls 1.3 as QtControls
 | 
					import QtQuick.Controls
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import org.kde.plasma.private.desktoppanel 1.0
 | 
					import org.kde.plasma.private.desktoppanel 1.0
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -131,7 +131,7 @@ Item {
 | 
				
			|||||||
            onValueEdited: cfg_mark = newValue
 | 
					            onValueEdited: cfg_mark = newValue
 | 
				
			||||||
        }
 | 
					        }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        QtControls.GroupBox {
 | 
					        GroupBox {
 | 
				
			||||||
            height: implicitHeight
 | 
					            height: implicitHeight
 | 
				
			||||||
            width: parent.width
 | 
					            width: parent.width
 | 
				
			||||||
            title: i18n("Tooltip")
 | 
					            title: i18n("Tooltip")
 | 
				
			||||||
 | 
				
			|||||||
@ -15,7 +15,7 @@
 | 
				
			|||||||
 *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  *
 | 
					 *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  *
 | 
				
			||||||
 ***************************************************************************/
 | 
					 ***************************************************************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import QtQuick 2.0
 | 
					import QtQuick 2.15
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import org.kde.plasma.private.desktoppanel 1.0
 | 
					import org.kde.plasma.private.desktoppanel 1.0
 | 
				
			||||||
import "."
 | 
					import "."
 | 
				
			||||||
 | 
				
			|||||||
@ -15,18 +15,17 @@
 | 
				
			|||||||
 *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  *
 | 
					 *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  *
 | 
				
			||||||
 ***************************************************************************/
 | 
					 ***************************************************************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import QtQuick 2.4
 | 
					import QtQuick 2.15
 | 
				
			||||||
import QtQuick.Controls 1.3 as QtControls
 | 
					import QtQuick.Controls
 | 
				
			||||||
import QtQuick.Layouts 1.1
 | 
					import QtQuick.Layouts
 | 
				
			||||||
 | 
					import org.kde.plasma.core as PlasmaCore
 | 
				
			||||||
import org.kde.plasma.plasmoid 2.0
 | 
					import org.kde.plasma.plasmoid 2.0
 | 
				
			||||||
import org.kde.plasma.core 2.0 as PlasmaCore
 | 
					 | 
				
			||||||
import org.kde.plasma.components 2.0 as PlasmaComponents
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
import org.kde.plasma.private.desktoppanel 1.0
 | 
					import org.kde.plasma.private.desktoppanel 1.0
 | 
				
			||||||
import "."
 | 
					import "."
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
Item {
 | 
					PlasmoidItem {
 | 
				
			||||||
    id: main
 | 
					    id: main
 | 
				
			||||||
    // backend
 | 
					    // backend
 | 
				
			||||||
    DPAdds {
 | 
					    DPAdds {
 | 
				
			||||||
@ -46,9 +45,6 @@ Item {
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    // init
 | 
					    // init
 | 
				
			||||||
    Plasmoid.preferredRepresentation: Plasmoid.fullRepresentation
 | 
					 | 
				
			||||||
    Plasmoid.compactRepresentation: Plasmoid.fullRepresentation
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
    Layout.alignment: Qt.AlignVCenter | Qt.AlignHCenter
 | 
					    Layout.alignment: Qt.AlignVCenter | Qt.AlignHCenter
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    Plasmoid.icon: "utilities-system-monitor"
 | 
					    Plasmoid.icon: "utilities-system-monitor"
 | 
				
			||||||
 | 
				
			|||||||
@ -15,7 +15,7 @@
 | 
				
			|||||||
 *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  *
 | 
					 *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  *
 | 
				
			||||||
 ***************************************************************************/
 | 
					 ***************************************************************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import QtQuick 2.0
 | 
					import QtQuick 2.15
 | 
				
			||||||
 | 
					
 | 
				
			||||||
import org.kde.plasma.private.desktoppanel 1.0
 | 
					import org.kde.plasma.private.desktoppanel 1.0
 | 
				
			||||||
import "."
 | 
					import "."
 | 
				
			||||||
 | 
				
			|||||||
@ -1,26 +0,0 @@
 | 
				
			|||||||
[Desktop Entry]
 | 
					 | 
				
			||||||
Encoding=UTF-8
 | 
					 | 
				
			||||||
Name=Desktop Panel
 | 
					 | 
				
			||||||
Comment=A minimalistic Plasmoid
 | 
					 | 
				
			||||||
Comment[en]=A minimalistic Plasmoid
 | 
					 | 
				
			||||||
Comment[es]=Un plasmoide minimalista
 | 
					 | 
				
			||||||
Comment[es]=Un script Plasmoïde minimaliste
 | 
					 | 
				
			||||||
Comment[pt_BR]=Um script Plasmoid
 | 
					 | 
				
			||||||
Comment[ru]=Минималистичный плазмоид
 | 
					 | 
				
			||||||
Comment[uk]=Мінімалістичний плазмоїд
 | 
					 | 
				
			||||||
X-KDE-ServiceTypes=Plasma/Applet
 | 
					 | 
				
			||||||
Type=Service
 | 
					 | 
				
			||||||
Icon=utilities-system-monitor
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
X-KDE-ServiceTypes=Plasma/Applet
 | 
					 | 
				
			||||||
X-Plasma-API=declarativeappletscript
 | 
					 | 
				
			||||||
X-Plasma-MainScript=ui/main.qml
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
X-KDE-PluginInfo-Author=Evgeniy Alekseev aka arcanis
 | 
					 | 
				
			||||||
X-KDE-PluginInfo-Email=esalexeev@gmail.com
 | 
					 | 
				
			||||||
X-KDE-PluginInfo-Name=org.kde.plasma.desktoppanel
 | 
					 | 
				
			||||||
X-KDE-PluginInfo-Version=3.5.1
 | 
					 | 
				
			||||||
X-KDE-PluginInfo-Website=https://arcanis.me/projects/awesome-widgets/
 | 
					 | 
				
			||||||
X-KDE-PluginInfo-Category=System Information
 | 
					 | 
				
			||||||
X-KDE-PluginInfo-License=GPLv3
 | 
					 | 
				
			||||||
X-KDE-PluginInfo-EnabledByDefault=true
 | 
					 | 
				
			||||||
							
								
								
									
										26
									
								
								sources/desktop-panel/package/metadata.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								sources/desktop-panel/package/metadata.json
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,26 @@
 | 
				
			|||||||
 | 
					{
 | 
				
			||||||
 | 
					    "KPackageStructure": "Plasma/Applet",
 | 
				
			||||||
 | 
					    "KPlugin": {
 | 
				
			||||||
 | 
					        "Authors": [
 | 
				
			||||||
 | 
					            {
 | 
				
			||||||
 | 
					                "Email": "esalexeev@gmail.com",
 | 
				
			||||||
 | 
					                "Name": "Evgeniy Alekseev aka arcanis"
 | 
				
			||||||
 | 
					            }
 | 
				
			||||||
 | 
					        ],
 | 
				
			||||||
 | 
					        "Category": "System Information",
 | 
				
			||||||
 | 
					        "Description": "A minimalistic Plasmoid",
 | 
				
			||||||
 | 
					        "Description[en]": "A minimalistic Plasmoid",
 | 
				
			||||||
 | 
					        "Description[es]": "Un script Plasmoïde minimaliste",
 | 
				
			||||||
 | 
					        "Description[pt_BR]": "Um script Plasmoid",
 | 
				
			||||||
 | 
					        "Description[ru]": "Минималистичный плазмоид",
 | 
				
			||||||
 | 
					        "Description[uk]": "Мінімалістичний плазмоїд",
 | 
				
			||||||
 | 
					        "EnabledByDefault": true,
 | 
				
			||||||
 | 
					        "Icon": "utilities-system-monitor",
 | 
				
			||||||
 | 
					        "Id": "org.kde.plasma.desktoppanel",
 | 
				
			||||||
 | 
					        "License": "GPLv3",
 | 
				
			||||||
 | 
					        "Name": "Desktop Panel",
 | 
				
			||||||
 | 
					        "Version": "3.5.1",
 | 
				
			||||||
 | 
					        "Website": "https://arcanis.me/projects/awesome-widgets/"
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    "X-Plasma-API-Minimum-Version": "6.0"
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@ -15,6 +15,6 @@ file(GLOB SUBPROJECT_NOTIFY *.notifyrc)
 | 
				
			|||||||
add_library(${PLUGIN_NAME} SHARED ${SUBPROJECT_SOURCE})
 | 
					add_library(${PLUGIN_NAME} SHARED ${SUBPROJECT_SOURCE})
 | 
				
			||||||
target_link_libraries(${PLUGIN_NAME} ${Qt_LIBRARIES} ${Kf6_LIBRARIES})
 | 
					target_link_libraries(${PLUGIN_NAME} ${Qt_LIBRARIES} ${Kf6_LIBRARIES})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
install(TARGETS ${PLUGIN_NAME} DESTINATION ${QML_INSTALL_DIR}/org/kde/plasma/private/desktoppanel)
 | 
					install(TARGETS ${PLUGIN_NAME} DESTINATION ${KDE_INSTALL_QMLDIR}/org/kde/plasma/private/desktoppanel)
 | 
				
			||||||
install(FILES qmldir DESTINATION ${QML_INSTALL_DIR}/org/kde/plasma/private/desktoppanel)
 | 
					install(FILES qmldir DESTINATION ${KDE_INSTALL_QMLDIR}/org/kde/plasma/private/desktoppanel)
 | 
				
			||||||
install(FILES ${SUBPROJECT_NOTIFY} DESTINATION ${KDE_INSTALL_KNOTIFYRCDIR})
 | 
					install(FILES ${SUBPROJECT_NOTIFY} DESTINATION ${KDE_INSTALL_KNOTIFYRCDIR})
 | 
				
			||||||
 | 
				
			|||||||
@ -223,7 +223,7 @@ QString DPAdds::valueByKey(const QString &_key, int _desktop) const
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    QString currentMark = currentDesktop() == _desktop ? m_mark : "";
 | 
					    QString currentMark = currentDesktop() == _desktop ? m_mark : "";
 | 
				
			||||||
    if (_key == "mark")
 | 
					    if (_key == "mark")
 | 
				
			||||||
        return QString("%1").arg(currentMark, m_mark.count(), QLatin1Char(' ')).replace(" ", " ");
 | 
					        return QString("%1").arg(currentMark, m_mark.size(), QLatin1Char(' ')).replace(" ", " ");
 | 
				
			||||||
    else if (_key == "name") {
 | 
					    else if (_key == "name") {
 | 
				
			||||||
        auto name = m_vdi->desktopNames().at(_desktop);
 | 
					        auto name = m_vdi->desktopNames().at(_desktop);
 | 
				
			||||||
        return name.replace(" ", " ");
 | 
					        return name.replace(" ", " ");
 | 
				
			||||||
 | 
				
			|||||||
@ -24,4 +24,4 @@ target_link_libraries(${SUBPROJECT}
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
# install
 | 
					# install
 | 
				
			||||||
install(TARGETS ${SUBPROJECT} DESTINATION ${KDE_INSTALL_PLUGINDIR}/ksystemstats)
 | 
					install(TARGETS ${SUBPROJECT} DESTINATION ${KDE_INSTALL_PLUGINDIR}/ksystemstats)
 | 
				
			||||||
install(FILES ${SUBPROJECT_CONF} DESTINATION ${KDE_INSTALL_CONFDIR})
 | 
					install(FILES ${SUBPROJECT_CONF} DESTINATION /${KDE_INSTALL_CONFDIR})
 | 
				
			||||||
 | 
				
			|||||||
@ -32,6 +32,7 @@
 | 
				
			|||||||
#include "quotessource.h"
 | 
					#include "quotessource.h"
 | 
				
			||||||
#include "requestsource.h"
 | 
					#include "requestsource.h"
 | 
				
			||||||
#include "systeminfosource.h"
 | 
					#include "systeminfosource.h"
 | 
				
			||||||
 | 
					#include "timesource.h"
 | 
				
			||||||
#include "upgradesource.h"
 | 
					#include "upgradesource.h"
 | 
				
			||||||
#include "weathersource.h"
 | 
					#include "weathersource.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -63,7 +64,6 @@ void ExtSysMonAggregator::init(const QHash<QString, QString> &_config)
 | 
				
			|||||||
    // custom
 | 
					    // custom
 | 
				
			||||||
    createSensor("custom", i18n("Scripts"), new CustomSource(this, {}));
 | 
					    createSensor("custom", i18n("Scripts"), new CustomSource(this, {}));
 | 
				
			||||||
    // desktop
 | 
					    // desktop
 | 
				
			||||||
    // FIXME causes segfault
 | 
					 | 
				
			||||||
    createSensor("desktop", i18n("Desktop"), new DesktopSource(this, {}));
 | 
					    createSensor("desktop", i18n("Desktop"), new DesktopSource(this, {}));
 | 
				
			||||||
    // gpu load
 | 
					    // gpu load
 | 
				
			||||||
    createSensor("gpuload", i18n("GPU load"), new GPULoadSource(this, {_config["GPUDEV"]}));
 | 
					    createSensor("gpuload", i18n("GPU load"), new GPULoadSource(this, {_config["GPUDEV"]}));
 | 
				
			||||||
@ -86,6 +86,8 @@ void ExtSysMonAggregator::init(const QHash<QString, QString> &_config)
 | 
				
			|||||||
    createSensor("quotes", i18n("Quotes"), new QuotesSource(this, {}));
 | 
					    createSensor("quotes", i18n("Quotes"), new QuotesSource(this, {}));
 | 
				
			||||||
    // system
 | 
					    // system
 | 
				
			||||||
    createSensor("system", i18n("System"), new SystemInfoSource(this, {}));
 | 
					    createSensor("system", i18n("System"), new SystemInfoSource(this, {}));
 | 
				
			||||||
 | 
					    // current time
 | 
				
			||||||
 | 
					    createSensor("time", i18n("Time"), new TimeSource(this, {}));
 | 
				
			||||||
    // upgrade
 | 
					    // upgrade
 | 
				
			||||||
    createSensor("upgrade", i18n("Upgrades"), new UpgradeSource(this, {}));
 | 
					    createSensor("upgrade", i18n("Upgrades"), new UpgradeSource(this, {}));
 | 
				
			||||||
    // weather
 | 
					    // weather
 | 
				
			||||||
 | 
				
			|||||||
@ -15,8 +15,7 @@
 | 
				
			|||||||
 *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  *
 | 
					 *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  *
 | 
				
			||||||
 ***************************************************************************/
 | 
					 ***************************************************************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
#ifndef EXTSYSMONAGGREGATOR_H
 | 
					#pragma once
 | 
				
			||||||
#define EXTSYSMONAGGREGATOR_H
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
#include <QObject>
 | 
					#include <QObject>
 | 
				
			||||||
#include <ksysguard/systemstats/SensorContainer.h>
 | 
					#include <ksysguard/systemstats/SensorContainer.h>
 | 
				
			||||||
@ -39,6 +38,3 @@ private:
 | 
				
			|||||||
    void createSensor(const QString &_id, const QString &_name, AbstractExtSysMonSource *_source);
 | 
					    void createSensor(const QString &_id, const QString &_name, AbstractExtSysMonSource *_source);
 | 
				
			||||||
    void init(const QHash<QString, QString> &_config);
 | 
					    void init(const QHash<QString, QString> &_config);
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
#endif /* EXTSYSMONAGGREGATOR_H */
 | 
					 | 
				
			||||||
 | 
				
			|||||||
@ -51,13 +51,13 @@ QVariant DesktopSource::data(const QString &_source)
 | 
				
			|||||||
    auto decrement = KWindowSystem::isPlatformX11() ? 1 : 0;
 | 
					    auto decrement = KWindowSystem::isPlatformX11() ? 1 : 0;
 | 
				
			||||||
    auto current = nativeIndex - decrement;
 | 
					    auto current = nativeIndex - decrement;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    if (_source == "current/name") {
 | 
					    if (_source == "name") {
 | 
				
			||||||
        return m_vdi->desktopNames().at(current);
 | 
					        return m_vdi->desktopNames().at(current);
 | 
				
			||||||
    } else if (_source == "current/number") {
 | 
					    } else if (_source == "number") {
 | 
				
			||||||
        return current + 1;
 | 
					        return current + 1;
 | 
				
			||||||
    } else if (_source == "total/name") {
 | 
					    } else if (_source == "names") {
 | 
				
			||||||
        return m_vdi->desktopNames();
 | 
					        return m_vdi->desktopNames();
 | 
				
			||||||
    } else if (_source == "total/number") {
 | 
					    } else if (_source == "count") {
 | 
				
			||||||
        return m_vdi->numberOfDesktops();
 | 
					        return m_vdi->numberOfDesktops();
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -70,20 +70,20 @@ KSysGuard::SensorInfo *DesktopSource::initialData(const QString &_source) const
 | 
				
			|||||||
    qCDebug(LOG_ESS) << "Source" << _source;
 | 
					    qCDebug(LOG_ESS) << "Source" << _source;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    auto data = new KSysGuard::SensorInfo();
 | 
					    auto data = new KSysGuard::SensorInfo();
 | 
				
			||||||
    if (_source == "current/name") {
 | 
					    if (_source == "name") {
 | 
				
			||||||
        data->name = "Current desktop name";
 | 
					        data->name = "Current desktop name";
 | 
				
			||||||
        data->variantType = QVariant::String;
 | 
					        data->variantType = QVariant::String;
 | 
				
			||||||
        data->unit = KSysGuard::UnitNone;
 | 
					        data->unit = KSysGuard::UnitNone;
 | 
				
			||||||
    } else if (_source == "current/number") {
 | 
					    } else if (_source == "number") {
 | 
				
			||||||
        data->min = 0;
 | 
					        data->min = 0;
 | 
				
			||||||
        data->name = "Current desktop number";
 | 
					        data->name = "Current desktop number";
 | 
				
			||||||
        data->variantType = QVariant::Int;
 | 
					        data->variantType = QVariant::Int;
 | 
				
			||||||
        data->unit = KSysGuard::UnitNone;
 | 
					        data->unit = KSysGuard::UnitNone;
 | 
				
			||||||
    } else if (_source == "total/name") {
 | 
					    } else if (_source == "names") {
 | 
				
			||||||
        data->name = "All desktops by name";
 | 
					        data->name = "All desktops by name";
 | 
				
			||||||
        data->variantType = QVariant::StringList;
 | 
					        data->variantType = QVariant::StringList;
 | 
				
			||||||
        data->unit = KSysGuard::UnitNone;
 | 
					        data->unit = KSysGuard::UnitNone;
 | 
				
			||||||
    } else if (_source == "total/number") {
 | 
					    } else if (_source == "count") {
 | 
				
			||||||
        data->min = 0;
 | 
					        data->min = 0;
 | 
				
			||||||
        data->name = "Desktops count";
 | 
					        data->name = "Desktops count";
 | 
				
			||||||
        data->variantType = QVariant::Int;
 | 
					        data->variantType = QVariant::Int;
 | 
				
			||||||
@ -97,10 +97,10 @@ KSysGuard::SensorInfo *DesktopSource::initialData(const QString &_source) const
 | 
				
			|||||||
QStringList DesktopSource::sources() const
 | 
					QStringList DesktopSource::sources() const
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
    QStringList sources;
 | 
					    QStringList sources;
 | 
				
			||||||
    sources.append("current/name");
 | 
					    sources.append("name");
 | 
				
			||||||
    sources.append("current/number");
 | 
					    sources.append("number");
 | 
				
			||||||
    sources.append("total/name");
 | 
					    sources.append("names");
 | 
				
			||||||
    sources.append("total/number");
 | 
					    sources.append("count");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    return sources;
 | 
					    return sources;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
				
			|||||||
@ -67,7 +67,6 @@ void ExtSysMonSensor::update()
 | 
				
			|||||||
            continue; // skip properties which are not explicitly subscribed
 | 
					            continue; // skip properties which are not explicitly subscribed
 | 
				
			||||||
 | 
					
 | 
				
			||||||
        auto value = m_source->data(source);
 | 
					        auto value = m_source->data(source);
 | 
				
			||||||
        qCWarning(LOG_ESS) << source << value;
 | 
					 | 
				
			||||||
        property->setValue(value);
 | 
					        property->setValue(value);
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
				
			|||||||
@ -52,7 +52,7 @@ NetworkSource::~NetworkSource()
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
QVariant NetworkSource::data(const QString &_source)
 | 
					QVariant NetworkSource::data(const QString &_source)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
    qCWarning(LOG_ESS) << "Source" << _source;
 | 
					    qCDebug(LOG_ESS) << "Source" << _source;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    if (!m_values.contains(_source))
 | 
					    if (!m_values.contains(_source))
 | 
				
			||||||
        run();
 | 
					        run();
 | 
				
			||||||
@ -82,8 +82,10 @@ KSysGuard::SensorInfo *NetworkSource::initialData(const QString &_source) const
 | 
				
			|||||||
void NetworkSource::run()
 | 
					void NetworkSource::run()
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
    m_values["device"] = NetworkSource::getCurrentDevice();
 | 
					    m_values["device"] = NetworkSource::getCurrentDevice();
 | 
				
			||||||
 | 
					    if (m_process->state() == QProcess::ProcessState::NotRunning) {
 | 
				
			||||||
        m_process->start("iwgetid", {"-r"});
 | 
					        m_process->start("iwgetid", {"-r"});
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
QStringList NetworkSource::sources() const
 | 
					QStringList NetworkSource::sources() const
 | 
				
			||||||
 | 
				
			|||||||
@ -56,17 +56,17 @@ KSysGuard::SensorInfo *ProcessesSource::initialData(const QString &_source) cons
 | 
				
			|||||||
    qCDebug(LOG_ESS) << "Source" << _source;
 | 
					    qCDebug(LOG_ESS) << "Source" << _source;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    auto data = new KSysGuard::SensorInfo();
 | 
					    auto data = new KSysGuard::SensorInfo();
 | 
				
			||||||
    if (_source == "running/count") {
 | 
					    if (_source == "running") {
 | 
				
			||||||
        data->min = 0;
 | 
					        data->min = 0;
 | 
				
			||||||
        data->max = 0;
 | 
					        data->max = 0;
 | 
				
			||||||
        data->name = "Count of running processes";
 | 
					        data->name = "Count of running processes";
 | 
				
			||||||
        data->variantType = QVariant::Int;
 | 
					        data->variantType = QVariant::Int;
 | 
				
			||||||
        data->unit = KSysGuard::UnitNone;
 | 
					        data->unit = KSysGuard::UnitNone;
 | 
				
			||||||
    } else if (_source == "running/list") {
 | 
					    } else if (_source == "list") {
 | 
				
			||||||
        data->name = "All running processes list";
 | 
					        data->name = "All running processes list";
 | 
				
			||||||
        data->variantType = QVariant::StringList;
 | 
					        data->variantType = QVariant::StringList;
 | 
				
			||||||
        data->unit = KSysGuard::UnitNone;
 | 
					        data->unit = KSysGuard::UnitNone;
 | 
				
			||||||
    } else if (_source == "total/count") {
 | 
					    } else if (_source == "count") {
 | 
				
			||||||
        data->min = 0;
 | 
					        data->min = 0;
 | 
				
			||||||
        data->max = 0;
 | 
					        data->max = 0;
 | 
				
			||||||
        data->name = "Total count of processes";
 | 
					        data->name = "Total count of processes";
 | 
				
			||||||
@ -99,18 +99,18 @@ void ProcessesSource::run()
 | 
				
			|||||||
        cmdFile.close();
 | 
					        cmdFile.close();
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    m_values["running/count"] = running.count();
 | 
					    m_values["running"] = running.count();
 | 
				
			||||||
    m_values["running/list"] = running;
 | 
					    m_values["list"] = running;
 | 
				
			||||||
    m_values["total/count"] = directories.count();
 | 
					    m_values["count"] = directories.count();
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
QStringList ProcessesSource::sources() const
 | 
					QStringList ProcessesSource::sources() const
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
    QStringList sources;
 | 
					    QStringList sources;
 | 
				
			||||||
    sources.append("running/count");
 | 
					    sources.append("running");
 | 
				
			||||||
    sources.append("running/list");
 | 
					    sources.append("list");
 | 
				
			||||||
    sources.append("total/count");
 | 
					    sources.append("count");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    return sources;
 | 
					    return sources;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
				
			|||||||
							
								
								
									
										62
									
								
								sources/extsysmonsources/timesource.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										62
									
								
								sources/extsysmonsources/timesource.cpp
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,62 @@
 | 
				
			|||||||
 | 
					/***************************************************************************
 | 
				
			||||||
 | 
					 *   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 "timesource.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include <ksysguard/formatter/Unit.h>
 | 
				
			||||||
 | 
					#include <ksysguard/systemstats/SensorInfo.h>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "awdebug.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					TimeSource::TimeSource(QObject *_parent, const QStringList &_args)
 | 
				
			||||||
 | 
					    : AbstractExtSysMonSource(_parent, _args)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    Q_ASSERT(_args.count() == 0);
 | 
				
			||||||
 | 
					    qCDebug(LOG_ESS) << __PRETTY_FUNCTION__;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					QVariant TimeSource::data(const QString &_source)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    qCDebug(LOG_ESS) << "Source" << _source;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    if (_source == "now") {
 | 
				
			||||||
 | 
					        return QDateTime::currentSecsSinceEpoch();
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return {};
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					KSysGuard::SensorInfo *TimeSource::initialData(const QString &_source) const
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    qCDebug(LOG_ESS) << "Source" << _source;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    auto data = new KSysGuard::SensorInfo();
 | 
				
			||||||
 | 
					    data->name = "Current time";
 | 
				
			||||||
 | 
					    data->variantType = QVariant::LongLong;
 | 
				
			||||||
 | 
					    data->unit = KSysGuard::UnitSecond;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    return data;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					QStringList TimeSource::sources() const
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    return QStringList({"now"});
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
							
								
								
									
										36
									
								
								sources/extsysmonsources/timesource.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										36
									
								
								sources/extsysmonsources/timesource.h
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,36 @@
 | 
				
			|||||||
 | 
					/***************************************************************************
 | 
				
			||||||
 | 
					 *   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/  *
 | 
				
			||||||
 | 
					 ***************************************************************************/
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#pragma once
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include <QObject>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#include "abstractextsysmonsource.h"
 | 
				
			||||||
 | 
					#include "extitemaggregator.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					class TimeSource : public AbstractExtSysMonSource
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
					    Q_OBJECT
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					public:
 | 
				
			||||||
 | 
					    explicit TimeSource(QObject *_parent, const QStringList &_args);
 | 
				
			||||||
 | 
					    QVariant data(const QString &_source) override;
 | 
				
			||||||
 | 
					    [[nodiscard]] KSysGuard::SensorInfo *initialData(const QString &_source) const override;
 | 
				
			||||||
 | 
					    void run() override{};
 | 
				
			||||||
 | 
					    [[nodiscard]] QStringList sources() const override;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
@ -49,12 +49,10 @@ QVariant WeatherSource::data(const QString &_source)
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    int ind = index(_source);
 | 
					    int ind = index(_source);
 | 
				
			||||||
    if (!m_values.contains(_source)) {
 | 
					    if (!m_values.contains(_source)) {
 | 
				
			||||||
        QVariantHash data = m_extWeather->itemByTagNumber(ind)->run();
 | 
					        auto data = m_extWeather->itemByTagNumber(ind)->run();
 | 
				
			||||||
        for (auto &key : data.keys())
 | 
					        m_values.insert(data);
 | 
				
			||||||
            m_values[key] = data[key];
 | 
					 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
    QVariant value = m_values.take(_source);
 | 
					    return m_values.take(_source);
 | 
				
			||||||
    return value;
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -94,7 +92,7 @@ KSysGuard::SensorInfo *WeatherSource::initialData(const QString &_source) const
 | 
				
			|||||||
        data->unit = KSysGuard::UnitCelsius;
 | 
					        data->unit = KSysGuard::UnitCelsius;
 | 
				
			||||||
    } else if (_source.startsWith("timestamp")) {
 | 
					    } else if (_source.startsWith("timestamp")) {
 | 
				
			||||||
        data->name = QString("Timestamp for '%1'").arg(m_extWeather->itemByTagNumber(ind)->uniq());
 | 
					        data->name = QString("Timestamp for '%1'").arg(m_extWeather->itemByTagNumber(ind)->uniq());
 | 
				
			||||||
        data->variantType = QVariant::String;
 | 
					        data->variantType = QVariant::DateTime;
 | 
				
			||||||
        data->unit = KSysGuard::UnitNone;
 | 
					        data->unit = KSysGuard::UnitNone;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
				
			|||||||
@ -18,13 +18,15 @@ set(Qt_LIBRARIES
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
# kf6 libraries
 | 
					# kf6 libraries
 | 
				
			||||||
find_package(ECM 0.0.11 REQUIRED NO_MODULE)
 | 
					find_package(ECM 0.0.11 REQUIRED NO_MODULE)
 | 
				
			||||||
set(CMAKE_MODULE_PATH ${CMAKE_MODULE_PATH} ${ECM_MODULE_PATH} ${ECM_KDE_MODULE_DIR})
 | 
					set(CMAKE_MODULE_PATH ${CMAKE_MODULE_PATH} ${ECM_MODULE_PATH})
 | 
				
			||||||
find_package(KF6 REQUIRED COMPONENTS I18n Notifications Service WindowSystem)
 | 
					find_package(KF6 REQUIRED COMPONENTS I18n Notifications Service WindowSystem)
 | 
				
			||||||
 | 
					find_package(KSysGuard REQUIRED)
 | 
				
			||||||
find_package(LibTaskManager REQUIRED)
 | 
					find_package(LibTaskManager REQUIRED)
 | 
				
			||||||
find_package(Plasma REQUIRED)
 | 
					find_package(Plasma REQUIRED)
 | 
				
			||||||
find_package(KSysGuard REQUIRED)
 | 
					
 | 
				
			||||||
include(KDEInstallDirs)
 | 
					include(KDEInstallDirs)
 | 
				
			||||||
include(KDECMakeSettings)
 | 
					include(KDECMakeSettings)
 | 
				
			||||||
include(KDECompilerSettings)
 | 
					include(KDECompilerSettings)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
set(Kf6_INCLUDE ${KDE_INSTALL_FULL_INCLUDEDIR_KF})
 | 
					set(Kf6_INCLUDE ${KDE_INSTALL_FULL_INCLUDEDIR_KF})
 | 
				
			||||||
set(Kf6_LIBRARIES KF6::CoreAddons KF6::I18n KF6::Notifications KF6::WindowSystem KSysGuard::Sensors KSysGuard::SensorFaces KSysGuard::SystemStats PW::LibTaskManager)
 | 
					set(Kf6_LIBRARIES KF6::CoreAddons KF6::I18n KF6::Notifications KF6::WindowSystem KSysGuard::Sensors KSysGuard::SensorFaces KSysGuard::SystemStats PW::LibTaskManager)
 | 
				
			||||||
 | 
				
			|||||||
@ -20,9 +20,9 @@ include_directories(
 | 
				
			|||||||
set(AWTESTLIBRARY_HEADERS awtestlibrary.h)
 | 
					set(AWTESTLIBRARY_HEADERS awtestlibrary.h)
 | 
				
			||||||
set(AWTESTLIBRARY_SOURCES awtestlibrary.cpp)
 | 
					set(AWTESTLIBRARY_SOURCES awtestlibrary.cpp)
 | 
				
			||||||
add_library(${SUBPROJECT}-awtest STATIC ${AWTESTLIBRARY_SOURCES} ${AWTESTLIBRARY_HEADERS})
 | 
					add_library(${SUBPROJECT}-awtest STATIC ${AWTESTLIBRARY_SOURCES} ${AWTESTLIBRARY_HEADERS})
 | 
				
			||||||
target_link_libraries(${SUBPROJECT}-awtest ${Qt_LIBRARIES} ${Qt5Test_LIBRARIES} ${Kf6_LIBRARIES})
 | 
					target_link_libraries(${SUBPROJECT}-awtest ${Qt_LIBRARIES} ${Qt6Test_LIBRARIES} ${Kf6_LIBRARIES})
 | 
				
			||||||
set(LIBRARY_TEST_SET ${SUBPROJECT}-awtest ${PROJECT_LIBRARY} ${PROJECT_MONITORSOURCES}
 | 
					set(LIBRARY_TEST_SET ${SUBPROJECT}-awtest ${PROJECT_LIBRARY} ${PROJECT_MONITORSOURCES}
 | 
				
			||||||
        ${Qt_LIBRARIES} ${Kf6_LIBRARIES} ${Qt5Test_LIBRARIES})
 | 
					        ${Qt_LIBRARIES} ${Kf6_LIBRARIES} ${Qt6Test_LIBRARIES})
 | 
				
			||||||
 | 
					
 | 
				
			||||||
# modules
 | 
					# modules
 | 
				
			||||||
set(TEST_MODULES
 | 
					set(TEST_MODULES
 | 
				
			||||||
 | 
				
			|||||||
@ -16,12 +16,12 @@ foreach (_current_PO_FILE ${_po_files})
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
    install(
 | 
					    install(
 | 
				
			||||||
            FILES ${CMAKE_CURRENT_BINARY_DIR}/${_lang}.gmo
 | 
					            FILES ${CMAKE_CURRENT_BINARY_DIR}/${_lang}.gmo
 | 
				
			||||||
            DESTINATION ${LOCALE_INSTALL_DIR}/${_lang}/LC_MESSAGES/
 | 
					            DESTINATION ${KDE_INSTALL_LOCALEDIR}/${_lang}/LC_MESSAGES/
 | 
				
			||||||
            RENAME ${MO_NAME}
 | 
					            RENAME ${MO_NAME}
 | 
				
			||||||
    )
 | 
					    )
 | 
				
			||||||
    install(
 | 
					    install(
 | 
				
			||||||
            FILES ${CMAKE_CURRENT_BINARY_DIR}/${_lang}.gmo
 | 
					            FILES ${CMAKE_CURRENT_BINARY_DIR}/${_lang}.gmo
 | 
				
			||||||
            DESTINATION ${LOCALE_INSTALL_DIR}/${_lang}/LC_MESSAGES/
 | 
					            DESTINATION ${KDE_INSTALL_LOCALEDIR}/${_lang}/LC_MESSAGES/
 | 
				
			||||||
            RENAME ${SND_MO_NAME}
 | 
					            RENAME ${SND_MO_NAME}
 | 
				
			||||||
    )
 | 
					    )
 | 
				
			||||||
    list(APPEND _gmoFiles ${_gmoFile})
 | 
					    list(APPEND _gmoFiles ${_gmoFile})
 | 
				
			||||||
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user