mirror of
				https://github.com/arcan1s/awesome-widgets.git
				synced 2025-10-27 03:43:41 +00:00 
			
		
		
		
	Compare commits
	
		
			27 Commits
		
	
	
		
			4.0.0alpha
			...
			571417f786
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 571417f786 | |||
| e3d24d1890 | |||
| ee7bd90aae | |||
| f79c94e9e2 | |||
| 66baa78cda | |||
| 79a148a21a | |||
| 64b4618904 | |||
| 95572364c1 | |||
| ba60be932a | |||
| f121db3b75 | |||
| 56c0a5837f | |||
| fd24ded6b8 | |||
| ed5ae40624 | |||
| 2f4f05b5af | |||
| c608c40c97 | |||
| 95d5bb99c0 | |||
| 397b523180 | |||
| 54acc5f780 | |||
| 332d78eb25 | |||
| 960640f5bc | |||
| ac52888b0d | |||
| a35b57e5d2 | |||
| 0bcceefd47 | |||
| f27050afbc | |||
| d71f85eaad | |||
| b0df3535a5 | |||
| 4d01b87088 | 
							
								
								
									
										12
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										12
									
								
								.github/workflows/build.yml
									
									
									
									
										vendored
									
									
								
							| @ -2,9 +2,11 @@ name: build & tests | ||||
|  | ||||
| on: | ||||
|   push: | ||||
|     branches: [ development, master ] | ||||
|     branches: | ||||
|       - master | ||||
|   pull_request: | ||||
|     branches: [ development, master ] | ||||
|     branches: | ||||
|       - master | ||||
|  | ||||
| env: | ||||
|   BUILD_TYPE: Release | ||||
| @ -24,13 +26,13 @@ jobs: | ||||
|     - uses: actions/checkout@v3 | ||||
|  | ||||
|     - name: create build environment | ||||
|       run: pacman -Sy --noconfirm base-devel cmake extra-cmake-modules python util-linux-libs xorg-server-xvfb | ||||
|       run: pacman -Syu --noconfirm base-devel cmake extra-cmake-modules python util-linux-libs xorg-server-xvfb | ||||
|      | ||||
|     - name: install dependencies | ||||
|       run: pacman -S --noconfirm plasma-workspace ksysguard | ||||
|       run: pacman -S --noconfirm plasma-workspace | ||||
|      | ||||
|     - name: configure cmake | ||||
|       run: cmake -B build -DKDE_INSTALL_USE_QT_SYS_PATHS=ON -DCMAKE_INSTALL_PREFIX=/usr -DCMAKE_BUILD_TYPE=${{env.BUILD_TYPE}} -DBUILD_FUTURE=ON -DBUILD_TESTING=ON sources | ||||
|       run: cmake -B build -S sources -DCMAKE_BUILD_TYPE=${{env.BUILD_TYPE}} -DBUILD_FUTURE=ON -DBUILD_TESTING=ON | ||||
|      | ||||
|     - name: build | ||||
|       working-directory: /repo/build | ||||
|  | ||||
							
								
								
									
										24
									
								
								.github/workflows/release.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										24
									
								
								.github/workflows/release.yml
									
									
									
									
										vendored
									
									
								
							| @ -25,17 +25,17 @@ jobs: | ||||
|         env: | ||||
|           VERSION: ${{ steps.version.outputs.VERSION }} | ||||
|  | ||||
|       - name: build debian package | ||||
|         run: | | ||||
|           sudo apt update && \ | ||||
|           sudo apt install -yq cmake extra-cmake-modules g++ git gettext make && \ | ||||
|           sudo apt install -yq libkf5i18n-dev libkf5notifications-dev libkf5service-dev \ | ||||
|             libkf5windowsystem-dev libkf5plasma-dev qtbase5-dev qtdeclarative5-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 && \ | ||||
|           cd build-deb && \ | ||||
|           make package && \ | ||||
|           cd .. | ||||
| #      - name: build debian package | ||||
| #        run: | | ||||
| #          sudo apt update && \ | ||||
| #          sudo apt install -yq cmake extra-cmake-modules g++ git gettext make && \ | ||||
| #          sudo apt install -yq libkf5i18n-dev libkf5notifications-dev libkf5service-dev \ | ||||
| #            libkf5windowsystem-dev libkf5plasma-dev qtbase5-dev qtdeclarative5-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 && \ | ||||
| #          cd build-deb && \ | ||||
| #          make package && \ | ||||
| #          cd .. | ||||
|  | ||||
|       - name: release | ||||
|         uses: softprops/action-gh-release@v1 | ||||
| @ -45,7 +45,7 @@ jobs: | ||||
|             ${{ steps.changelog.outputs.changelog }} | ||||
|           files: | | ||||
|             awesome-widgets-*-src.tar.xz | ||||
|             build-deb/plasma-widget-awesome-widgets-*.deb | ||||
| #            build-deb/plasma-widget-awesome-widgets-*.deb | ||||
|           fail_on_unmatched_files: true | ||||
|         env: | ||||
|           GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | ||||
|  | ||||
							
								
								
									
										12
									
								
								CHANGELOG
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								CHANGELOG
									
									
									
									
									
								
							| @ -1,3 +1,14 @@ | ||||
| Ver.4.0.1: | ||||
| - temporary disable tooltip painting in main widget | ||||
|  | ||||
| Ver.4.0.0: | ||||
| * migration to plasma 6 | ||||
| * dialog windows have been replaced by notifications | ||||
| + $gpuN keys have been added | ||||
| + new key $ssid | ||||
| - $cuptime key has been removed in favour of $uptime | ||||
| - $gputemp key has been replaced by $gpuN | ||||
|  | ||||
| Ver.3.5.0: | ||||
| + wayland support | ||||
| * update code to latest standards | ||||
| @ -12,7 +23,6 @@ Ver.3.4.2: | ||||
| * update to new qt api | ||||
| - fix non printable spaces (#142, #143) | ||||
|  | ||||
|  | ||||
| Ver.3.3.3: | ||||
| + add custom keys support (#101) | ||||
| * DBus interface improvements | ||||
|  | ||||
							
								
								
									
										115
									
								
								CONTRIBUTING.md
									
									
									
									
									
								
							
							
						
						
									
										115
									
								
								CONTRIBUTING.md
									
									
									
									
									
								
							| @ -6,27 +6,20 @@ for more details. To avoid manual labor there is automatic cmake target named | ||||
| `clangformat` (see below). Some additional detail see below. | ||||
|  | ||||
| * Indent is only spaces. 4 spaces. | ||||
| * Any private variable should start with `m_` prefix (`m_foo`). The only one | ||||
|   exception is `Ui` object which should be named as `ui`. | ||||
| * Any private variable should start with `m_` prefix (`m_foo`). The only one exception is `Ui` object which should be named as `ui`. | ||||
| * Avoid to create a large methods. Exception: if method contains lambda functions. | ||||
| * If some method is called only once, it is recommended to use lambda functions. | ||||
|   Exception is `Q_INVOKABLE` methods. | ||||
| * STL containers are not recommended, use Qt ones instead. | ||||
| * In other hand Qt specific variables types (`qint`, `qfloat`, etc) are not | ||||
|   recommended. | ||||
| * In other hand Qt specific variables types (`qint`, `qfloat`, etc) are not recommended. | ||||
| * Do not repeat yourself ([DRY](https://en.wikipedia.org/wiki/Don't_repeat_yourself)). | ||||
| * Headers declaration: | ||||
|     * Include only those headers which are strictly necessary inside headers. Use | ||||
|       forward class declaration instead. Exception is base class header declaration. | ||||
|     * In a`*.cpp` file header declaration should have the following order separated | ||||
|       by a new line in the alphabet order: | ||||
|     * Include only those headers which are strictly necessary inside headers. Use forward class declaration instead. Exception is base class header declaration. | ||||
|     * In a`*.cpp` file header declaration should have the following order separated by a new line in the alphabet order: | ||||
|         1. Class header. | ||||
|         2. KDE specific headers. | ||||
|         3. Qt specific headers. | ||||
|         4. Third party headers. | ||||
|         5. Project headers. | ||||
|     * Any header should have [include guard](https://en.wikipedia.org/wiki/Include_guard) | ||||
|       named as `CLASSNAMECAPS_H` | ||||
|     * Any header should have `#pragma once`. | ||||
| * If any `#if` directive is used condition should be mentioned in `#endif`: | ||||
|  | ||||
|   ``` | ||||
| @ -36,80 +29,60 @@ for more details. To avoid manual labor there is automatic cmake target named | ||||
|   ``` | ||||
|  | ||||
| * `Q_PROPERTY` macro is allowed and recommended for QObject based classes. | ||||
| * Qt macros (e.g. `signals`, `slots`, `Q_OBJECT`, etc) are allowed. In other hand | ||||
| `Q_FOREACH` (`foreach`) is not allowed use `for (auto &foo : bar)` instead. | ||||
| * Current project standard is **C++17**. | ||||
| * Qt macros (e.g. `signals`, `slots`, `Q_OBJECT`, etc) are allowed. In other hand `Q_FOREACH` (`foreach`) is not allowed use `for (auto &foo : bar)` instead. | ||||
| * Current project standard is **C++23**. | ||||
| * Do not use C-like code: | ||||
|     * C-like style iteration if possible. Use `for (auto &foo : bar)` and | ||||
|       `std::for_each` instead if possible. It is also recommended to use iterators. | ||||
|     * C-like casts, use `const_cast`, `static_cast`, `dymanic_Cast` instead. Using | ||||
|       of `reinterpret_cast` is not recommended. It is highly recommended to use | ||||
|       `dynamic_cast` with the exception catching. It is also possible to use | ||||
|       `qvariant_cast` if required. | ||||
|     * C-like style iteration if possible. Use `for (auto &foo : bar)` and `std::for_each` instead if possible. It is also recommended to use iterators. | ||||
|     * C-like casts, use `const_cast`, `static_cast`, `dymanic_Cast` instead. Using of `reinterpret_cast` is not recommended. It is highly recommended to use `dynamic_cast` with the exception catching. It is also possible to use `qvariant_cast` if required. | ||||
|     * C-like `NULL`, use `nullptr` instead. | ||||
|     * C-like constant definition, use `const vartype foo = bar` definition instead. | ||||
|     * C-like constant definition, use `static const vartype foo = bar` definition instead. | ||||
| * Abstract classes (which have at least one pure virtual method) are allowed. | ||||
| * Templates are allowed and recommended. Templates usually should be described | ||||
|   inside header not source code file. | ||||
| * Hardcode is not recommended. But it is possible to use cmake variables to | ||||
|   configure some items during build time. | ||||
| * Templates are allowed and recommended. Templates usually should be described inside header not source code file. | ||||
| * Hardcode is not recommended. But it is possible to use cmake variables to configure some items during build time. | ||||
| * Build should not require any additional system variable declaration/changing. | ||||
| * Any line should not end with space. | ||||
| * Do not hesitate move public methods to private one if possible. | ||||
| * Do not hesitate use `const` modifier. In other hand `volatile` modifier is not | ||||
|   recommended. | ||||
| * Do not hesitate use `const` modifier. In other hand `volatile` modifier is not recommended. | ||||
| * New lines rules: | ||||
|     * One line after license header. | ||||
|     * One line between header group declaration (see above). | ||||
|     * Two lines after header declaration and before declaration at the end of a | ||||
|       file. | ||||
|     * Two lines after header declaration and before declaration at the end of a file. | ||||
|     * One line after class and types forward declarations in headers. | ||||
|     * One line before each method modifiers (`public`, `public slots`, etc). | ||||
|     * Two lines between methods inside source code (`*.cpp`). | ||||
|     * One line after `qCDebug()` information (see below). | ||||
|     * One line inside a method to improve code reading. | ||||
| * Each destructor should be virtual. | ||||
| * Class constructor should have default arguments. Use `QObject *parent` property | ||||
|   for QObject based classes. | ||||
| * Class constructor should have default arguments. Use `QObject *_parent` property for QObject based classes. | ||||
| * QObject based classes constructors should have explicit modifier. | ||||
| * Create one file (source and header) per class. | ||||
| * `else if` construction is allowed and recommended. | ||||
| * 'true ? foo : bar' construction is allowed and recommended for one-line assignment. | ||||
| * Any global pointer should be assign to `nullptr` after deletion and before | ||||
|   initialization. Exception: if object is deleted into class destructor. | ||||
| * Any global pointer should be assigned to `nullptr` after deletion and before initialization. Exception: if object is deleted into class destructor. | ||||
| * Do not use semicolon in qml files unless it is required. | ||||
| * Any method argument including class constructors should start with `_`. | ||||
|  | ||||
| Comments | ||||
| -------- | ||||
|  | ||||
| Please do not hesitate to use comments inside source code (especially in non-obvious | ||||
| blocks). Comments also may use the following keywords: | ||||
| Please do not hesitate to use comments inside source code (especially in non-obvious blocks). Comments also may use the following keywords: | ||||
|  | ||||
| * **TODO** - indicates that some new code should be implemented here later. Please | ||||
|   note that usually these methods should be implemented before the next release. | ||||
| * **TODO** - indicates that some new code should be implemented here later. Please note that usually these methods should be implemented before the next release. | ||||
| * **FIXME** - some dirty hacks and/or methods which should be done better. | ||||
| * **HACK** - hacks inside code which requires to avoid some restrictions and/or | ||||
|   which adds additional non-obvious optimizations. | ||||
| * **HACK** - hacks inside code which requires to avoid some restrictions and/or which adds additional non-obvious optimizations. | ||||
|  | ||||
| Do not use dots at the end of the comment line. | ||||
|  | ||||
| Development | ||||
| ----------- | ||||
|  | ||||
| * Officially the latest libraries versions should be used. In addition it is | ||||
|   possible to add workarounds for all versions (usually by using preprocessor | ||||
|   directives); in this case patches should be placed to `packages` directory. | ||||
| * Officially the latest libraries versions should be used. In addition, it is possible to add workarounds for all versions (usually by using preprocessor directives); in this case patches should be placed to `packages` directory. | ||||
| * Build should not contain any warning. | ||||
| * Try to minimize message in Release build with logging disabled. It is highly | ||||
|   recommended to fix KDE/Qt specific warning if possible | ||||
| * Do not use dependency to KDE libraries if there are no any strictly necessary. | ||||
|   Exceptions are KNotification and KI18n libraries. | ||||
| * Try to minimize message in Release build with logging disabled. It is highly recommended to fix KDE/Qt specific warning if possible | ||||
| * Do not use dependency to KDE libraries if there are no any strictly necessary. Exceptions are KNotification and KI18n libraries. | ||||
| * It is highly recommended to use submodules for third party libraries if possible. | ||||
| * The main branch is **development**. Changes in this branch may be merged to the | ||||
|   master one only if it is a 'stable' build. | ||||
| * For experimental features development new branch `feature-foo` creation is allowed | ||||
|   and recommended. | ||||
| * The main branch is **master**. | ||||
| * For experimental features development new branch `feature/foo` creation is allowed and recommended. | ||||
| * Experimental features should be added inside `BUILD_FUTURE` definition: | ||||
|  | ||||
|   ``` | ||||
| @ -118,54 +91,41 @@ Development | ||||
|   #endif /* BUILD_FUTURE */ | ||||
|   ``` | ||||
|  | ||||
| * Any project specific build variable should be mentioned inside `version.h` as | ||||
|   well. | ||||
| * Any project specific build variable should be mentioned inside `version.h` as well. | ||||
| * Recommended compiler is `clang`. | ||||
|  | ||||
| HIG | ||||
| --- | ||||
|  | ||||
| The recommended HIG is [KDE one](https://techbase.kde.org/Projects/Usability/HIG). | ||||
| Avoid to paint interfaces inside plugin because QML and C++ parts may have different | ||||
| theming. | ||||
| The recommended HIG is [KDE one](https://techbase.kde.org/Projects/Usability/HIG). Avoid to paint interfaces inside plugin because QML and C++ parts may have different theming. | ||||
|  | ||||
| Licensing | ||||
| --------- | ||||
|  | ||||
| All files should be licensed under GPLv3, the owner of the license should be the | ||||
| project (i.e. **awesome-widgets**). See **Tools** section for more details. | ||||
| All files should be licensed under GPLv3, the owner of the license should be the project (i.e. **awesome-widgets**). See **Tools** section for more details. | ||||
|  | ||||
| Logging | ||||
| ------- | ||||
|  | ||||
| For logging please use [QLoggingCategory](http://doc.qt.io/qt-5/qloggingcategory.html). | ||||
| Available categories should be declared in `awdebug.*` files. The following log | ||||
| levels should be used: | ||||
| For logging please use [QLoggingCategory](http://doc.qt.io/qt-5/qloggingcategory.html). Available categories should be declared in `awdebug.*` files. The following log levels should be used: | ||||
|  | ||||
| * **debug** (`qCDebug()`) - method arguments information. Please note that it | ||||
|   is recommended to logging all arguments in the one line. | ||||
| * **debug** (`qCDebug()`) - method arguments information. Please note that it is recommended to logging all arguments in the one line. | ||||
| * **info** (`qCInfo()`) - additional information inside methods. | ||||
| * **warning** (`qCWarning()`) - not critical information, which may be caused by | ||||
|   mistakes in configuration for example. | ||||
| * **critical** (`qCCritical()`) - a critical error. After this error program may | ||||
|   be terminated. | ||||
| * **warning** (`qCWarning()`) - not critical information, which may be caused by mistakes in configuration for example. | ||||
| * **critical** (`qCCritical()`) - a critical error. After this error program may be terminated. | ||||
|  | ||||
| The empty log string (e.g. `qCDebug();`) is not allowed because the method names | ||||
| will be stripped by compiler with `Release` build type. To log class constructor | ||||
| and destructor use `__PRETTY_FUNCTION__` macro. | ||||
| The empty log string (e.g. `qCDebug();`) is not allowed because the method names will be stripped by compiler with `Release` build type. To log class constructor and destructor use `__PRETTY_FUNCTION__` macro. | ||||
|  | ||||
| Testing | ||||
| ------- | ||||
|  | ||||
| * Any changes should be tested by using `plasmawindowed` and `plasmashell` applications. | ||||
|   (It is also possible to use `plasmaengineexplorer` and `plasmoidviewer` in addition.) | ||||
| * Any changes should be tested by using `plasmawindowed` and `plasmashell` applications. (It is also possible to use `plasmaengineexplorer` and `plasmoidviewer` in addition.) | ||||
| * Any test should be performed on real (not Virtual Machine) system. | ||||
| * Test builds should be: | ||||
|     1. `-DCMAKE_BUILD_TYPE=Debug`. | ||||
|     2. `-DCMAKE_BUILD_TYPE=Debug -DBUILD_TESTING=ON`. | ||||
|     3. `-DCMAKE_BUILD_TYPE=Release`. | ||||
| * Additional test functions should be declated and used only inside `BUILD_TESTING` | ||||
|   definition. | ||||
| * Additional test functions should be declated and used only inside `BUILD_TESTING` definition. | ||||
|  | ||||
| Tools | ||||
| ----- | ||||
| @ -222,7 +182,6 @@ Tools | ||||
|         // declare with default value | ||||
|         bool m_prop = false; | ||||
|   ``` | ||||
| * Use `cppcheck` to avoid common errors in the code. To start application just | ||||
|   run `make cppcheck`. | ||||
| * Use `clang-format` to apply valid code format. To start application just run | ||||
|   `make clangformat`. | ||||
| * Use `cppcheck` to avoid common errors in the code. To start application just run `make cppcheck`. | ||||
| * Use `clang-format` to apply valid code format. To start application just run `make clangformat`. | ||||
| * use `-DCMAKE_CXX_COMPILER=clang++` in order to enable clang-tidy checks. | ||||
|  | ||||
							
								
								
									
										27
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										27
									
								
								README.md
									
									
									
									
									
								
							| @ -14,11 +14,11 @@ A collection of minimalistic widgets which looks like Awesome Window Manager wid | ||||
| Features | ||||
| ======== | ||||
|  | ||||
| * easy and fully configurable native Plasma widget which may be used as Conky widget or as Awesome-like information panel | ||||
| * panel which shows active desktop status | ||||
| * clear Conky-like configuration with html tags support | ||||
| * easy and fully configurable native Plasma widget which may be used as desktop or panel widget | ||||
| * additionnal widget which shows active desktop status | ||||
| * clear text configuration with html tags support | ||||
| * custom command support (it may be simple action as well as special custom tag) | ||||
| * graphical item support - tooltips, bars | ||||
| * graphical widgets support - tooltips, bars | ||||
|  | ||||
| See [links](#Links) for more details. | ||||
|  | ||||
| @ -30,15 +30,11 @@ Instruction | ||||
| Dependencies | ||||
| ------------ | ||||
|  | ||||
| * plasma-framework | ||||
| * ksysguard (since plasma 5.22) | ||||
| * plasma-workspace | ||||
|  | ||||
| Optional dependencies | ||||
| --------------------- | ||||
|  | ||||
| * proprietary video driver | ||||
| * hddtemp | ||||
| * smartmontools | ||||
| * music player (mpd or MPRIS supported) | ||||
| * wireless_tools | ||||
|  | ||||
| @ -48,19 +44,20 @@ Make dependencies | ||||
| * cmake | ||||
| * extra-cmake-modules | ||||
|  | ||||
| In addition some distros might require to install some -dev packages, e.g. the list of required packages for deb-based distros can be found [here](https://github.com/arcan1s/awesome-widgets/blob/development/.docker/Dockerfile-ubuntu-amd64#L7). | ||||
| In addition, some distros might require to install some -dev packages, e.g. the list of required packages for deb-based distros can be found [here](https://github.com/arcan1s/awesome-widgets/blob/development/.docker/Dockerfile-ubuntu-amd64#L7). | ||||
|  | ||||
| Installation | ||||
| ------------ | ||||
|  | ||||
| * download sources | ||||
| * install | ||||
| * build package | ||||
|  | ||||
|         mkdir build && cd build | ||||
|         cmake -DCMAKE_BUILD_TYPE=Release -DCMAKE_INSTALL_PREFIX=/usr ../sources | ||||
|         make && sudo make install | ||||
|       cmake -B build -S sources -DCMAKE_BUILD_TYPE=Release | ||||
|       cmake --build build | ||||
|  | ||||
|   **NOTE** on Plasma 5 it very likely requires `-DKDE_INSTALL_USE_QT_SYS_PATHS=ON` flag | ||||
| * install package  | ||||
|  | ||||
|       cmake --install build | ||||
|  | ||||
| Additional information | ||||
| ====================== | ||||
|  | ||||
| @ -5,7 +5,7 @@ VERSION="$(git describe --tags --abbrev=0)" | ||||
|  | ||||
| # build widget | ||||
| ARCHIVE="awesome-widgets" | ||||
| FILES="AUTHORS CHANGELOG COPYING packages patches sources" | ||||
| FILES="AUTHORS CHANGELOG COPYING packages patches" | ||||
| IGNORELIST="build usr .kdev4 *.kdev4 .idea packages/*src.tar.xz" | ||||
| # create archive | ||||
| [[ -e ${ARCHIVE}-${VERSION}-src.tar.xz ]] && rm -f "${ARCHIVE}-${VERSION}-src.tar.xz" | ||||
|  | ||||
| @ -1,41 +1,31 @@ | ||||
| # Maintainer: Evgeniy Alekseev <arcanis at archlinux dot org> | ||||
|  | ||||
| pkgname=plasma5-applet-awesome-widgets | ||||
| pkgname=plasma6-applet-awesome-widgets | ||||
| _pkgname=awesome-widgets | ||||
| pkgver=3.4.3 | ||||
| pkgver=4.0.0alpha2 | ||||
| pkgrel=1 | ||||
| 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" | ||||
| license=('GPL3') | ||||
| depends=('ksysguard' 'plasma-framework') | ||||
| optdepends=("catalyst: for GPU monitor" | ||||
|             "hddtemp: for HDD temperature monitor" | ||||
|             "smartmontools: for HDD temperature monitor" | ||||
|             "mpd: for music player monitor" | ||||
|             "nvidia-utils: for GPU monitor") | ||||
| depends=('plasma-workspace') | ||||
| optdepends=("mpd: for music player monitor" | ||||
|             "wireless_tools: wifi information") | ||||
| makedepends=('cmake' 'extra-cmake-modules' 'python') | ||||
| source=(https://github.com/arcan1s/awesome-widgets/releases/download/V.${pkgver}/${_pkgname}-${pkgver}-src.tar.xz) | ||||
| install=${pkgname}.install | ||||
| md5sums=('5953ba518191bb6fff83cdb8633c735c') | ||||
| source=(https://github.com/arcan1s/awesome-widgets/releases/download/${pkgver}/${_pkgname}-${pkgver}-src.tar.xz) | ||||
| install="$pkgname.install" | ||||
| backup=('etc/xdg/plasma-dataengine-extsysmon.conf') | ||||
|  | ||||
| prepare() { | ||||
|   rm -rf "${srcdir}/build" | ||||
|   mkdir "${srcdir}/build" | ||||
| } | ||||
|  | ||||
| build () { | ||||
|   cd "${srcdir}/build" | ||||
|   cmake -DKDE_INSTALL_USE_QT_SYS_PATHS=ON \ | ||||
|         -DCMAKE_BUILD_TYPE=Optimization \ | ||||
|         -DCMAKE_INSTALL_PREFIX=/usr \ | ||||
|         -DBUILD_FUTURE=ON \ | ||||
|         "../${_pkgname}" | ||||
|   make | ||||
|     cmake -B build -S "${_pkgname}" \ | ||||
|           -DCMAKE_BUILD_TYPE=Optimization \ | ||||
|           -DBUILD_FUTURE=ON \ | ||||
|           -DBUILD_TESTING=OFF | ||||
|     cmake --build build | ||||
| } | ||||
|  | ||||
| package() { | ||||
|   cd "${srcdir}/build" | ||||
|   make DESTDIR="${pkgdir}" install | ||||
|       DESTDIR="$pkgdir" cmake --install build | ||||
| } | ||||
|  | ||||
| sha256sums=('b2a7b07a1df6f710f4e0d6e5898933f4ddb131818b922dc4b8e48afe3e98a664') | ||||
|  | ||||
							
								
								
									
										81
									
								
								sources/3rdparty/fontdialog/fontdialog.cpp
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										81
									
								
								sources/3rdparty/fontdialog/fontdialog.cpp
									
									
									
									
										vendored
									
									
								
							| @ -39,81 +39,6 @@ void CFont::setCurrentColor(const QColor color) | ||||
| } | ||||
|  | ||||
|  | ||||
| int CFont::html2QFont(const int htmlWeight) | ||||
| { | ||||
|     int weight = 16; | ||||
|     switch(htmlWeight) { | ||||
|     case 100: | ||||
|         weight = 16; | ||||
|         break; | ||||
|     case 200: | ||||
|     case 300: | ||||
|         weight = 25; | ||||
|         break; | ||||
|     case 400: | ||||
|         weight = 50; | ||||
|         break; | ||||
|     case 500: | ||||
|     case 600: | ||||
|         weight = 63; | ||||
|         break; | ||||
|     case 700: | ||||
|     case 800: | ||||
|         weight = 75; | ||||
|         break; | ||||
|     case 900: | ||||
|         weight = 87; | ||||
|         break; | ||||
|     default: | ||||
|         break; | ||||
|     } | ||||
|  | ||||
|     return weight; | ||||
| } | ||||
|  | ||||
|  | ||||
| int CFont::qFont2html(const int weight) | ||||
| { | ||||
|     int htmlWeight = 400; | ||||
|     switch(weight) { | ||||
|     case 16: | ||||
|         htmlWeight = 100; | ||||
|         break; | ||||
|     case 25: | ||||
|         htmlWeight = 300; | ||||
|         break; | ||||
|     case 50: | ||||
|         htmlWeight = 400; | ||||
|         break; | ||||
|     case 63: | ||||
|         htmlWeight = 600; | ||||
|         break; | ||||
|     case 75: | ||||
|         htmlWeight = 800; | ||||
|         break; | ||||
|     case 87: | ||||
|         htmlWeight = 900; | ||||
|         break; | ||||
|     default: | ||||
|         break; | ||||
|     } | ||||
|  | ||||
|     return htmlWeight; | ||||
| } | ||||
|  | ||||
|  | ||||
| int CFont::htmlWeight() | ||||
| { | ||||
|     return CFont::qFont2html(weight()); | ||||
| } | ||||
|  | ||||
|  | ||||
| void CFont::setHtmlWeight(const int htmlWeight) | ||||
| { | ||||
|     setWeight(CFont::html2QFont(htmlWeight)); | ||||
| } | ||||
|  | ||||
|  | ||||
| CFont CFont::fromQFont(const QFont font, const QColor color) | ||||
| { | ||||
|     return CFont(font.family(), font.pointSize(), font.weight(), font.italic(), color); | ||||
| @ -133,7 +58,7 @@ CFontDialog::CFontDialog(QWidget *parent, bool needWeight, bool needItalic) | ||||
|     setLayout(mainGrid); | ||||
|  | ||||
|     colorBox = new QComboBox(this); | ||||
|     connect(colorBox, SIGNAL(currentIndexChanged(QString)), this, SLOT(updateColor(QString))); | ||||
|     connect(colorBox, &QComboBox::currentTextChanged, this, &CFontDialog::updateColor); | ||||
|     QStringList colorNames = QColor::colorNames(); | ||||
|     int index = 0; | ||||
|     for (int i=0; i<colorNames.count(); i++) { | ||||
| @ -156,8 +81,8 @@ CFontDialog::CFontDialog(QWidget *parent, bool needWeight, bool needItalic) | ||||
|  | ||||
|     buttons = new QDialogButtonBox(QDialogButtonBox::Ok | QDialogButtonBox::Cancel, | ||||
|                                    Qt::Horizontal, this); | ||||
|     QObject::connect(buttons, SIGNAL(accepted()), this, SLOT(accept())); | ||||
|     QObject::connect(buttons, SIGNAL(rejected()), this, SLOT(reject())); | ||||
|     QObject::connect(buttons, &QDialogButtonBox::accepted, this, &CFontDialog::accept); | ||||
|     QObject::connect(buttons, &QDialogButtonBox::rejected, this, &CFontDialog::reject); | ||||
|     mainGrid->addWidget(buttons, 1, 0, 1, 5); | ||||
|  | ||||
|     italicBox->setHidden(!needItalic); | ||||
|  | ||||
							
								
								
									
										11
									
								
								sources/3rdparty/fontdialog/fontdialog.h
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										11
									
								
								sources/3rdparty/fontdialog/fontdialog.h
									
									
									
									
										vendored
									
									
								
							| @ -15,8 +15,7 @@ | ||||
|  *  License along with this library.                                       * | ||||
|  ***************************************************************************/ | ||||
|  | ||||
| #ifndef FONTDIALOG_H | ||||
| #define FONTDIALOG_H | ||||
| #pragma once | ||||
|  | ||||
| #include <QComboBox> | ||||
| #include <QDialog> | ||||
| @ -34,11 +33,6 @@ public: | ||||
|     // color properties | ||||
|     QColor color(); | ||||
|     void setCurrentColor(const QColor color); | ||||
|     // html weight properties | ||||
|     static int html2QFont(const int htmlWeight); | ||||
|     static int qFont2html(const int weight); | ||||
|     int htmlWeight(); | ||||
|     void setHtmlWeight(const int htmlWeight); | ||||
|     // conversion to QFont | ||||
|     static CFont fromQFont(const QFont font, | ||||
|                            const QColor color = QColor(QString("#000000"))); | ||||
| @ -77,6 +71,3 @@ private: | ||||
|     QSpinBox *sizeBox; | ||||
|     QSpinBox *weightBox; | ||||
| }; | ||||
|  | ||||
|  | ||||
| #endif /* FONTDIALOG_H */ | ||||
|  | ||||
| @ -12,7 +12,7 @@ QReplyTimeout::QReplyTimeout(QNetworkReply *reply, const int timeout) | ||||
|  | ||||
| void QReplyTimeout::timeout() | ||||
| { | ||||
|     auto *reply = dynamic_cast<QNetworkReply *>(parent()); | ||||
|     auto reply = dynamic_cast<QNetworkReply *>(parent()); | ||||
|     if (reply->isRunning()) | ||||
|         reply->close(); | ||||
| } | ||||
|  | ||||
| @ -9,13 +9,16 @@ endif () | ||||
| if (POLICY CMP0071) | ||||
|     cmake_policy(SET CMP0071 NEW) | ||||
| endif () | ||||
| if (POLICY CMP0160) | ||||
|     cmake_policy(SET CMP0160 OLD) | ||||
| endif () | ||||
|  | ||||
| project(awesomewidgets) | ||||
| set(PROJECT_AUTHOR "Evgeniy Alekseev") | ||||
| set(PROJECT_CONTACT "esalexeev@gmail.com") | ||||
| set(PROJECT_LICENSE "GPL3") | ||||
| set(PROJECT_VERSION_MAJOR "3") | ||||
| set(PROJECT_VERSION_MINOR "5") | ||||
| set(PROJECT_VERSION_MAJOR "4") | ||||
| set(PROJECT_VERSION_MINOR "0") | ||||
| set(PROJECT_VERSION_PATCH "1") | ||||
| set(PROJECT_VERSION "${PROJECT_VERSION_MAJOR}.${PROJECT_VERSION_MINOR}.${PROJECT_VERSION_PATCH}") | ||||
| # append git version if any | ||||
|  | ||||
| @ -15,7 +15,9 @@ | ||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||
|  ***************************************************************************/ | ||||
|  | ||||
|  | ||||
| #ifndef NDEBUG | ||||
| #define NDEBUG | ||||
| #endif /* NDEBUG */ | ||||
| #include <KI18n/KLocalizedString> | ||||
|  | ||||
| #include "awdebug.h" | ||||
| @ -41,35 +43,32 @@ QString AWDebug::getAboutText(const QString &_type) | ||||
|     } else if (_type == "description") { | ||||
|         text = i18n("A set of minimalistic plasmoid widgets"); | ||||
|     } else if (_type == "links") { | ||||
|         text = i18n("Links:") + "<ul>" + QString("<li><a href=\"%1\">%2</a></li>").arg(HOMEPAGE).arg(i18n("Homepage")) | ||||
|                + QString("<li><a href=\"%1\">%2</a></li>").arg(REPOSITORY).arg(i18n("Repository")) | ||||
|                + QString("<li><a href=\"%1\">%2</a></li>").arg(BUGTRACKER).arg(i18n("Bugtracker")) | ||||
|                + QString("<li><a href=\"%1\">%2</a></li>").arg(TRANSLATION).arg(i18n("Translation issue")) | ||||
|                + QString("<li><a href=\"%1\">%2</a></li>").arg(AUR_PACKAGES).arg(i18n("AUR packages")) | ||||
|                + QString("<li><a href=\"%1\">%2</a></li>").arg(OPENSUSE_PACKAGES).arg(i18n("openSUSE packages")) | ||||
|                + "</ul>"; | ||||
|         text = i18n("Links:") + "<ul>" + QString("<li><a href=\"%1\">%2</a></li>").arg(HOMEPAGE, i18n("Homepage")) | ||||
|                + QString("<li><a href=\"%1\">%2</a></li>").arg(REPOSITORY, i18n("Repository")) | ||||
|                + QString("<li><a href=\"%1\">%2</a></li>").arg(BUGTRACKER, i18n("Bugtracker")) | ||||
|                + QString("<li><a href=\"%1\">%2</a></li>").arg(TRANSLATION, i18n("Translation issue")) | ||||
|                + QString("<li><a href=\"%1\">%2</a></li>").arg(AUR_PACKAGES, i18n("AUR packages")) | ||||
|                + QString("<li><a href=\"%1\">%2</a></li>").arg(OPENSUSE_PACKAGES, i18n("openSUSE packages")) + "</ul>"; | ||||
|     } else if (_type == "copy") { | ||||
|         text = QString("<small>© %1 <a href=\"mailto:%2\">%3</a><br>").arg(DATE).arg(EMAIL).arg(AUTHOR) | ||||
|                + i18nc("This software is licensed under %1", LICENSE) + "</small>"; | ||||
|         text = QString("<small>© %1 <a href=\"mailto:%2\">%3</a><br>").arg(DATE, EMAIL, AUTHOR) | ||||
|                + i18n("This software is licensed under %1", LICENSE) + "</small>"; | ||||
|     } else if (_type == "translators") { | ||||
|         QStringList translatorList = QString(TRANSLATORS).split(','); | ||||
|         auto translatorList = QString(TRANSLATORS).split(','); | ||||
|         for (auto &translator : translatorList) | ||||
|             translator = QString("<li>%1</li>").arg(translator); | ||||
|         text = i18n("Translators:") + "<ul>" + translatorList.join("") + "</ul>"; | ||||
|     } else if (_type == "3rdparty") { | ||||
|         QStringList trdPartyList = QString(TRDPARTY_LICENSE).split(';', Qt::SkipEmptyParts); | ||||
|         for (int i = 0; i < trdPartyList.count(); i++) | ||||
|         auto trdPartyList = QString(TRDPARTY_LICENSE).split(';', Qt::SkipEmptyParts); | ||||
|         for (auto i = 0; i < trdPartyList.count(); ++i) | ||||
|             trdPartyList[i] = QString("<li><a href=\"%3\">%1</a> (%2 license)</li>") | ||||
|                                   .arg(trdPartyList.at(i).split(',')[0]) | ||||
|                                   .arg(trdPartyList.at(i).split(',')[1]) | ||||
|                                   .arg(trdPartyList.at(i).split(',')[2]); | ||||
|                                   .arg(trdPartyList.at(i).split(',')[0], trdPartyList.at(i).split(',')[1], | ||||
|                                        trdPartyList.at(i).split(',')[2]); | ||||
|         text = i18n("This software uses:") + "<ul>" + trdPartyList.join("") + "</ul>"; | ||||
|     } else if (_type == "thanks") { | ||||
|         QStringList thanks = QString(SPECIAL_THANKS).split(';', Qt::SkipEmptyParts); | ||||
|         for (int i = 0; i < thanks.count(); i++) | ||||
|             thanks[i] = QString("<li><a href=\"%2\">%1</a></li>") | ||||
|                             .arg(thanks.at(i).split(',')[0]) | ||||
|                             .arg(thanks.at(i).split(',')[1]); | ||||
|         auto thanks = QString(SPECIAL_THANKS).split(';', Qt::SkipEmptyParts); | ||||
|         for (auto i = 0; i < thanks.count(); ++i) | ||||
|             thanks[i] | ||||
|                 = QString("<li><a href=\"%2\">%1</a></li>").arg(thanks.at(i).split(',')[0], thanks.at(i).split(',')[1]); | ||||
|         text = i18n("Special thanks to:") + "<ul>" + thanks.join("") + "</ul>"; | ||||
|     } | ||||
|  | ||||
|  | ||||
| @ -15,9 +15,7 @@ | ||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||
|  ***************************************************************************/ | ||||
|  | ||||
|  | ||||
| #ifndef AWDEBUG_H | ||||
| #define AWDEBUG_H | ||||
| #pragma once | ||||
|  | ||||
| #include <QLoggingCategory> | ||||
|  | ||||
| @ -42,6 +40,3 @@ Q_DECLARE_LOGGING_CATEGORY(LOG_DP) | ||||
| Q_DECLARE_LOGGING_CATEGORY(LOG_ESM) | ||||
| Q_DECLARE_LOGGING_CATEGORY(LOG_ESS) | ||||
| Q_DECLARE_LOGGING_CATEGORY(LOG_LIB) | ||||
|  | ||||
|  | ||||
| #endif /* AWDEBUG_H */ | ||||
|  | ||||
| @ -1,7 +1,7 @@ | ||||
| set(SUBPROJECT plasma_applet_awesome-widget) | ||||
| 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) | ||||
| plasma_install_package(package org.kde.plasma.awesomewidget) | ||||
|  | ||||
| @ -1,26 +0,0 @@ | ||||
| [Desktop Entry] | ||||
| Encoding=UTF-8 | ||||
| Name=Awesome Widget | ||||
| 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.awesomewidget | ||||
| 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 | ||||
							
								
								
									
										26
									
								
								sources/awesome-widget/metadata.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								sources/awesome-widget/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.awesomewidget", | ||||
|         "License": "GPLv3", | ||||
|         "Name": "Awesome Widget", | ||||
|         "Version": "@PROJECT_VERSION@", | ||||
|         "Website": "https://arcanis.me/projects/awesome-widgets/" | ||||
|     }, | ||||
|     "X-Plasma-API-Minimum-Version": "6.0" | ||||
| } | ||||
| @ -15,7 +15,7 @@ | ||||
|  *   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 | ||||
|  | ||||
| @ -51,6 +51,12 @@ ConfigModel { | ||||
|         source: "dataengine.qml" | ||||
|     } | ||||
|  | ||||
|     ConfigCategory { | ||||
|         name: i18n("Report bug") | ||||
|         icon: "tools-report-bug" | ||||
|         source: "bug.qml" | ||||
|     } | ||||
|  | ||||
|     ConfigCategory { | ||||
|         name: i18n("About") | ||||
|         icon: "help-about" | ||||
|  | ||||
| @ -7,150 +7,141 @@ | ||||
|  | ||||
|     <group name="Widget"> | ||||
|         <!--   widget --> | ||||
|         <entry name="text" type="string"> | ||||
|         <entry name="text" type="String"> | ||||
|             <default>[cpu: $cpu%] [mem: $mem%] [swap: $swap%] [$netdev: $down/$upKB/s]</default> | ||||
|         </entry> | ||||
|     </group> | ||||
|  | ||||
|     <group name="Advanced"> | ||||
|         <!--   advanced --> | ||||
|         <entry name="background" type="bool"> | ||||
|         <entry name="background" type="Bool"> | ||||
|             <default>true</default> | ||||
|         </entry> | ||||
|         <entry name="translateStrings" type="bool"> | ||||
|         <entry name="translateStrings" type="Bool"> | ||||
|             <default>true</default> | ||||
|         </entry> | ||||
|         <entry name="wrapNewLines" type="bool"> | ||||
|         <entry name="wrapNewLines" type="Bool"> | ||||
|             <default>false</default> | ||||
|         </entry> | ||||
|         <entry name="wrapText" type="bool"> | ||||
|         <entry name="wrapText" type="Bool"> | ||||
|             <default>false</default> | ||||
|         </entry> | ||||
|         <entry name="notify" type="bool"> | ||||
|         <entry name="notify" type="Bool"> | ||||
|             <default>true</default> | ||||
|         </entry> | ||||
|         <entry name="checkUpdates" type="bool"> | ||||
|         <entry name="checkUpdates" type="Bool"> | ||||
|             <default>true</default> | ||||
|         </entry> | ||||
|         <entry name="optimize" type="bool"> | ||||
|         <entry name="optimize" type="Bool"> | ||||
|             <default>true</default> | ||||
|         </entry> | ||||
|         <entry name="height" type="int"> | ||||
|         <entry name="height" type="Int"> | ||||
|             <default>0</default> | ||||
|         </entry> | ||||
|         <entry name="width" type="int"> | ||||
|         <entry name="width" type="Int"> | ||||
|             <default>0</default> | ||||
|         </entry> | ||||
|         <entry name="interval" type="int"> | ||||
|         <entry name="interval" type="Int"> | ||||
|             <default>1000</default> | ||||
|         </entry> | ||||
|         <entry name="queueLimit" type="int"> | ||||
|             <default>0</default> | ||||
|         </entry> | ||||
|         <entry name="tempUnits" type="string"> | ||||
|         <entry name="tempUnits" type="String"> | ||||
|             <default>Celsius</default> | ||||
|         </entry> | ||||
|         <entry name="customTime" type="string"> | ||||
|         <entry name="customTime" type="String"> | ||||
|             <default>$hh:$mm</default> | ||||
|         </entry> | ||||
|         <entry name="customUptime" type="string"> | ||||
|         <entry name="customUptime" type="String"> | ||||
|             <default>$dd,$hh,$mm</default> | ||||
|         </entry> | ||||
|         <entry name="acOnline" type="string"> | ||||
|         <entry name="acOnline" type="String"> | ||||
|             <default>(*)</default> | ||||
|         </entry> | ||||
|         <entry name="acOffline" type="string"> | ||||
|         <entry name="acOffline" type="String"> | ||||
|             <default>( )</default> | ||||
|         </entry> | ||||
|         <entry name="telemetryCount" type="int"> | ||||
|         <entry name="historyCount" type="Int"> | ||||
|             <default>100</default> | ||||
|         </entry> | ||||
|         <entry name="telemetryRemote" type="bool"> | ||||
|             <default>false</default> | ||||
|         </entry> | ||||
|         <entry name="telemetryId" type="string"> | ||||
|             <default></default> | ||||
|         </entry> | ||||
|     </group> | ||||
|  | ||||
|     <group name="Tooltip"> | ||||
|         <entry name="tooltipNumber" type="int"> | ||||
|         <entry name="tooltipNumber" type="Int"> | ||||
|             <default>100</default> | ||||
|         </entry> | ||||
|         <entry name="useTooltipBackground" type="bool"> | ||||
|         <entry name="useTooltipBackground" type="Bool"> | ||||
|             <default>true</default> | ||||
|         </entry> | ||||
|         <entry name="tooltipBackground" type="string"> | ||||
|         <entry name="tooltipBackground" type="String"> | ||||
|             <default>#ffffff</default> | ||||
|         </entry> | ||||
|         <entry name="cpuTooltip" type="bool"> | ||||
|         <entry name="cpuTooltip" type="Bool"> | ||||
|             <default>true</default> | ||||
|         </entry> | ||||
|         <entry name="cpuTooltipColor" type="string"> | ||||
|         <entry name="cpuTooltipColor" type="String"> | ||||
|             <default>#ff0000</default> | ||||
|         </entry> | ||||
|         <entry name="cpuclTooltip" type="bool"> | ||||
|         <entry name="cpuclTooltip" type="Bool"> | ||||
|             <default>true</default> | ||||
|         </entry> | ||||
|         <entry name="cpuclTooltipColor" type="string"> | ||||
|         <entry name="cpuclTooltipColor" type="String"> | ||||
|             <default>#00ff00</default> | ||||
|         </entry> | ||||
|         <entry name="memTooltip" type="bool"> | ||||
|         <entry name="memTooltip" type="Bool"> | ||||
|             <default>true</default> | ||||
|         </entry> | ||||
|         <entry name="memTooltipColor" type="string"> | ||||
|         <entry name="memTooltipColor" type="String"> | ||||
|             <default>#0000ff</default> | ||||
|         </entry> | ||||
|         <entry name="swapTooltip" type="bool"> | ||||
|         <entry name="swapTooltip" type="Bool"> | ||||
|             <default>true</default> | ||||
|         </entry> | ||||
|         <entry name="swapTooltipColor" type="string"> | ||||
|         <entry name="swapTooltipColor" type="String"> | ||||
|             <default>#ffff00</default> | ||||
|         </entry> | ||||
|         <entry name="downkbTooltip" type="bool"> | ||||
|         <entry name="downkbTooltip" type="Bool"> | ||||
|             <default>true</default> | ||||
|         </entry> | ||||
|         <entry name="downkbTooltipColor" type="string"> | ||||
|         <entry name="downkbTooltipColor" type="String"> | ||||
|             <default>#00ffff</default> | ||||
|         </entry> | ||||
|         <entry name="upkbTooltipColor" type="string"> | ||||
|         <entry name="upkbTooltipColor" type="String"> | ||||
|             <default>#ff00ff</default> | ||||
|         </entry> | ||||
|         <entry name="batTooltip" type="bool"> | ||||
|         <entry name="batTooltip" type="Bool"> | ||||
|             <default>true</default> | ||||
|         </entry> | ||||
|         <entry name="batTooltipColor" type="string"> | ||||
|         <entry name="batTooltipColor" type="String"> | ||||
|             <default>#008800</default> | ||||
|         </entry> | ||||
|         <entry name="batInTooltipColor" type="string"> | ||||
|         <entry name="batInTooltipColor" type="String"> | ||||
|             <default>#880000</default> | ||||
|         </entry> | ||||
|     </group> | ||||
|  | ||||
|     <group name="Appearance"> | ||||
|         <!--   appearance --> | ||||
|         <entry name="textAlign" type="string"> | ||||
|         <entry name="textAlign" type="String"> | ||||
|             <default>center</default> | ||||
|         </entry> | ||||
|         <entry name="fontFamily" type="string"> | ||||
|         <entry name="fontFamily" type="String"> | ||||
|             <default>Terminus</default> | ||||
|         </entry> | ||||
|         <entry name="fontSize" type="int"> | ||||
|         <entry name="fontSize" type="Int"> | ||||
|             <default>12</default> | ||||
|         </entry> | ||||
|         <entry name="fontColor" type="string"> | ||||
|         <entry name="fontColor" type="String"> | ||||
|             <default>#000000</default> | ||||
|         </entry> | ||||
|         <entry name="fontWeight" type="string"> | ||||
|         <entry name="fontWeight" type="String"> | ||||
|             <default>normal</default> | ||||
|         </entry> | ||||
|         <entry name="fontStyle" type="string"> | ||||
|         <entry name="fontStyle" type="String"> | ||||
|             <default>normal</default> | ||||
|         </entry> | ||||
|         <entry name="textStyle" type="string"> | ||||
|         <entry name="textStyle" type="String"> | ||||
|             <default>normal</default> | ||||
|         </entry> | ||||
|         <entry name="textStyleColor" type="string"> | ||||
|         <entry name="textStyleColor" type="String"> | ||||
|             <default>#000000</default> | ||||
|         </entry> | ||||
|     </group> | ||||
|  | ||||
| @ -15,28 +15,22 @@ | ||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||
|  ***************************************************************************/ | ||||
|  | ||||
| import QtQuick 2.0 | ||||
| import QtQuick 2.15 | ||||
| import org.kde.kcmutils as KCM | ||||
|  | ||||
| import org.kde.plasma.private.awesomewidget 1.0 | ||||
| import org.kde.plasma.awesomewidgets | ||||
| import org.kde.plasma.private.awesomewidget | ||||
|  | ||||
|  | ||||
| Item { | ||||
| KCM.SimpleKCM { | ||||
|     id: aboutPage | ||||
|  | ||||
|     // backend | ||||
|     AWActions { | ||||
|         id: awActions | ||||
|     } | ||||
|  | ||||
|     width: childrenRect.width | ||||
|     height: childrenRect.height | ||||
|  | ||||
|     property bool debug: awActions.isDebugEnabled() | ||||
|  | ||||
|     AboutTab { | ||||
|         textProvider: awActions | ||||
|     } | ||||
|  | ||||
|     Component.onCompleted: { | ||||
|         if (debug) console.debug() | ||||
|     } | ||||
| } | ||||
|  | ||||
| @ -15,26 +15,22 @@ | ||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||
|  ***************************************************************************/ | ||||
|  | ||||
| import QtQuick 2.0 | ||||
| import QtQuick.Controls 1.3 as QtControls | ||||
| import QtQuick 2.15 | ||||
| import QtQuick.Controls | ||||
| import org.kde.kcmutils as KCM | ||||
|  | ||||
| import org.kde.plasma.private.awesomewidget 1.0 | ||||
| import org.kde.plasma.awesomewidgets | ||||
| import org.kde.plasma.private.awesomewidget | ||||
|  | ||||
|  | ||||
| Item { | ||||
| KCM.SimpleKCM { | ||||
|     id: advancedPage | ||||
|  | ||||
|     // backend | ||||
|     AWActions { | ||||
|         id: awActions | ||||
|     AWConfigHelper { | ||||
|         id: awConfig | ||||
|     } | ||||
|  | ||||
|     width: childrenRect.width | ||||
|     height: childrenRect.height | ||||
|     implicitWidth: pageColumn.implicitWidth | ||||
|     implicitHeight: pageColumn.implicitHeight | ||||
|  | ||||
|     property bool debug: awActions.isDebugEnabled() | ||||
|  | ||||
|     property alias cfg_background: background.checked | ||||
|     property alias cfg_translateStrings: translate.checked | ||||
|     property alias cfg_wrapNewLines: wrapNewLines.checked | ||||
| @ -45,19 +41,14 @@ Item { | ||||
|     property alias cfg_height: widgetHeight.value | ||||
|     property alias cfg_width: widgetWidth.value | ||||
|     property alias cfg_interval: update.value | ||||
|     property alias cfg_queueLimit: queueLimit.value | ||||
|     property string cfg_tempUnits: tempUnits.value | ||||
|     property alias cfg_customTime: customTime.value | ||||
|     property alias cfg_customUptime: customUptime.value | ||||
|     property alias cfg_acOnline: acOnline.value | ||||
|     property alias cfg_acOffline: acOffline.value | ||||
|     property alias cfg_telemetryCount: telemetryCount.value | ||||
|     property alias cfg_telemetryRemote: telemetryRemote.checked | ||||
|     property alias cfg_telemetryId: telemetryId.value | ||||
|  | ||||
|     property alias cfg_historyCount: historyCount.value | ||||
|  | ||||
|     Column { | ||||
|         id: pageColumn | ||||
|         anchors.fill: parent | ||||
|  | ||||
|         CheckBoxSelector { | ||||
| @ -122,50 +113,41 @@ Item { | ||||
|             value: plasmoid.configuration.interval | ||||
|         } | ||||
|  | ||||
|         IntegerSelector { | ||||
|             id: queueLimit | ||||
|             maximumValue: 99 | ||||
|             minimumValue: 0 | ||||
|             stepSize: 1 | ||||
|             text: i18n("Messages queue limit") | ||||
|             value: plasmoid.configuration.queueLimit | ||||
|         } | ||||
|  | ||||
|         ComboBoxSelector { | ||||
|             id: tempUnits | ||||
|             model: [ | ||||
|                 { | ||||
|                     'label': i18n("Celsius"), | ||||
|                     'name': "Celsius" | ||||
|                     "label": i18n("Celsius"), | ||||
|                     "name": "Celsius" | ||||
|                 }, | ||||
|                 { | ||||
|                     'label': i18n("Fahrenheit"), | ||||
|                     'name': "Fahrenheit" | ||||
|                     "label": i18n("Fahrenheit"), | ||||
|                     "name": "Fahrenheit" | ||||
|                 }, | ||||
|                 { | ||||
|                     'label': i18n("Kelvin"), | ||||
|                     'name': "Kelvin" | ||||
|                     "label": i18n("Kelvin"), | ||||
|                     "name": "Kelvin" | ||||
|                 }, | ||||
|                 { | ||||
|                     'label': i18n("Reaumur"), | ||||
|                     'name': "Reaumur" | ||||
|                     "label": i18n("Reaumur"), | ||||
|                     "name": "Reaumur" | ||||
|                 }, | ||||
|                 { | ||||
|                     'label': i18n("cm^-1"), | ||||
|                     'name': "cm^-1" | ||||
|                     "label": i18n("cm^-1"), | ||||
|                     "name": "cm^-1" | ||||
|                 }, | ||||
|                 { | ||||
|                     'label': i18n("kJ/mol"), | ||||
|                     'name': "kJ/mol" | ||||
|                     "label": i18n("kJ/mol"), | ||||
|                     "name": "kJ/mol" | ||||
|                 }, | ||||
|                 { | ||||
|                     'label': i18n("kcal/mol"), | ||||
|                     'name': "kcal/mol" | ||||
|                     "label": i18n("kcal/mol"), | ||||
|                     "name": "kcal/mol" | ||||
|                 } | ||||
|             ] | ||||
|             text: i18n("Temperature units") | ||||
|             value: plasmoid.configuration.tempUnits | ||||
|             onValueEdited: cfg_tempUnits = newValue | ||||
|             onValueEdited: newValue => cfg_tempUnits = newValue | ||||
|         } | ||||
|  | ||||
|         LineSelector { | ||||
| @ -192,18 +174,20 @@ Item { | ||||
|             value: plasmoid.configuration.acOffline | ||||
|         } | ||||
|  | ||||
|         QtControls.GroupBox { | ||||
|             height: implicitHeight | ||||
|         GroupBox { | ||||
|             width: parent.width | ||||
|             height: implicitHeight | ||||
|             title: i18n("Actions") | ||||
|  | ||||
|             Column { | ||||
|                 height: implicitHeight | ||||
|                 width: parent.width | ||||
|  | ||||
|                 ButtonSelector { | ||||
|                     value: i18n("Drop key cache") | ||||
|                     onButtonActivated: awActions.dropCache() | ||||
|                     onButtonActivated: awConfig.dropCache() | ||||
|                 } | ||||
|  | ||||
|                 ButtonSelector { | ||||
|                     ExportDialog { | ||||
|                         id: saveConfigAs | ||||
| @ -212,11 +196,12 @@ Item { | ||||
|                     value: i18n("Export configuration") | ||||
|                     onButtonActivated: saveConfigAs.open() | ||||
|                 } | ||||
|  | ||||
|                 ButtonSelector { | ||||
|                     ImportDialog { | ||||
|                         id: loadConfigFrom | ||||
|                         onConfigurationReceived: { | ||||
|                             for (var key in configuration) | ||||
|                             for (const key in configuration) | ||||
|                                 plasmoid.configuration[key] = configuration[key] | ||||
|                         } | ||||
|                     } | ||||
| @ -226,37 +211,24 @@ Item { | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         QtControls.GroupBox { | ||||
|         GroupBox { | ||||
|             height: implicitHeight | ||||
|             width: parent.width | ||||
|             title: i18n("Telemetry") | ||||
|             title: i18n("History") | ||||
|  | ||||
|             Column { | ||||
|                 height: implicitHeight | ||||
|                 width: parent.width | ||||
|                 CheckBoxSelector { | ||||
|                     id: telemetryRemote | ||||
|                     text: i18n("Enable remote telemetry") | ||||
|                 } | ||||
|  | ||||
|                 IntegerSelector { | ||||
|                     id: telemetryCount | ||||
|                     id: historyCount | ||||
|                     maximumValue: 10000 | ||||
|                     minimumValue: 0 | ||||
|                     stepSize: 50 | ||||
|                     text: i18n("History count") | ||||
|                     value: plasmoid.configuration.telemetryCount | ||||
|                 } | ||||
|                 LineSelector { | ||||
|                     id: telemetryId | ||||
|                     text: i18n("Telemetry ID") | ||||
|                     value: plasmoid.configuration.telemetryId | ||||
|                     value: plasmoid.configuration.historyCount | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|  | ||||
|     Component.onCompleted: { | ||||
|         if (debug) console.debug() | ||||
|     } | ||||
| } | ||||
|  | ||||
| @ -15,31 +15,22 @@ | ||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||
|  ***************************************************************************/ | ||||
|  | ||||
| import QtQuick 2.0 | ||||
| import QtQuick 2.15 | ||||
| import org.kde.kcmutils as KCM | ||||
|  | ||||
| import org.kde.plasma.private.awesomewidget 1.0 | ||||
| import "." | ||||
| import org.kde.plasma.awesomewidgets | ||||
| import org.kde.plasma.private.awesomewidget | ||||
|  | ||||
|  | ||||
| Item { | ||||
| KCM.SimpleKCM { | ||||
|     id: appearancePage | ||||
|     // backend | ||||
|     AWActions { | ||||
|         id: awActions | ||||
|     } | ||||
|  | ||||
|     width: childrenRect.width | ||||
|     height: childrenRect.height | ||||
|     implicitWidth: pageColumn.implicitWidth | ||||
|     implicitHeight: pageColumn.implicitHeight | ||||
|  | ||||
|     property bool debug: awActions.isDebugEnabled() | ||||
|     property variant weight: { | ||||
|         25: 0, | ||||
|         50: 1, | ||||
|         63: 3, | ||||
|         75: 4, | ||||
|         87: 5 | ||||
|         87: 5, | ||||
|     } | ||||
|  | ||||
|     property alias cfg_fontFamily: font.value | ||||
| @ -50,9 +41,7 @@ Item { | ||||
|     property alias cfg_textStyleColor: selectStyleColor.value | ||||
|     property string cfg_textStyle: textStyle.value | ||||
|  | ||||
|  | ||||
|     Column { | ||||
|         id: pageColumn | ||||
|         anchors.fill: parent | ||||
|  | ||||
|         FontSelector { | ||||
| @ -75,7 +64,7 @@ Item { | ||||
|             model: General.fontWeightModel | ||||
|             text: i18n("Font weight") | ||||
|             value: plasmoid.configuration.fontWeight | ||||
|             onValueEdited: cfg_fontWeight = newValue | ||||
|             onValueEdited: newValue => cfg_fontWeight = newValue | ||||
|         } | ||||
|  | ||||
|         ComboBoxSelector { | ||||
| @ -83,7 +72,7 @@ Item { | ||||
|             model: General.fontStyleModel | ||||
|             text: i18n("Font style") | ||||
|             value: plasmoid.configuration.fontStyle | ||||
|             onValueEdited: cfg_fontStyle = newValue | ||||
|             onValueEdited: newValue => cfg_fontStyle = newValue | ||||
|         } | ||||
|  | ||||
|         ColorSelector { | ||||
| @ -97,7 +86,7 @@ Item { | ||||
|             model: General.textStyleModel | ||||
|             text: i18n("Style") | ||||
|             value: plasmoid.configuration.textStyle | ||||
|             onValueEdited: cfg_textStyle = newValue | ||||
|             onValueEdited: newValue => cfg_textStyle = newValue | ||||
|         } | ||||
|  | ||||
|         ColorSelector { | ||||
| @ -106,9 +95,4 @@ Item { | ||||
|             value: plasmoid.configuration.textStyleColor | ||||
|         } | ||||
|     } | ||||
|  | ||||
|  | ||||
|     Component.onCompleted: { | ||||
|         if (debug) console.debug() | ||||
|     } | ||||
| } | ||||
|  | ||||
| @ -15,16 +15,19 @@ | ||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||
|  ***************************************************************************/ | ||||
| 
 | ||||
| import QtQuick 2.0 | ||||
| import QtQuick.Controls 1.3 as QtControls | ||||
| import QtQuick.Dialogs 1.2 as QtDialogs | ||||
| import QtQuick.Layouts 1.2 as QtLayouts | ||||
| import QtQuick 2.15 | ||||
| import QtQuick.Controls | ||||
| import QtQuick.Dialogs | ||||
| import QtQuick.Layouts | ||||
| import org.kde.kcmutils as KCM | ||||
| 
 | ||||
| import org.kde.plasma.private.awesomewidget 1.0 | ||||
| import org.kde.plasma.awesomewidgets | ||||
| import org.kde.plasma.private.awesomewidget | ||||
| 
 | ||||
| 
 | ||||
| QtDialogs.Dialog { | ||||
|     id: reportDialog | ||||
| KCM.SimpleKCM { | ||||
|     id: bugPage | ||||
| 
 | ||||
|     AWActions { | ||||
|         id: awActions | ||||
|     } | ||||
| @ -32,121 +35,125 @@ QtDialogs.Dialog { | ||||
|         id: awBugReporter | ||||
|     } | ||||
| 
 | ||||
|     width: 640 | ||||
|     height: 480 | ||||
|     property bool debug: awActions.isDebugEnabled() | ||||
| 
 | ||||
| 
 | ||||
|     title: i18n("Report a bug") | ||||
|     standardButtons: QtDialogs.StandardButton.Ok | QtDialogs.StandardButton.Cancel | QtDialogs.StandardButton.Reset | ||||
| 
 | ||||
|     QtLayouts.ColumnLayout { | ||||
|     ColumnLayout { | ||||
|         anchors.fill: parent | ||||
| 
 | ||||
|         QtControls.TextField { | ||||
|         TextField { | ||||
|             id: title | ||||
|             QtLayouts.Layout.fillWidth: true | ||||
|             Layout.fillWidth: true | ||||
|             placeholderText: i18n("Report subject") | ||||
|         } | ||||
|         QtLayouts.ColumnLayout { | ||||
|             QtLayouts.Layout.fillWidth: true | ||||
| 
 | ||||
|             QtControls.GroupBox { | ||||
|                 QtLayouts.Layout.fillWidth: true | ||||
|                 height: parent.height / 5 | ||||
|         ColumnLayout { | ||||
|             Layout.fillWidth: true | ||||
| 
 | ||||
|             GroupBox { | ||||
|                 Layout.fillWidth: true | ||||
|                 title: i18n("Description") | ||||
|                 QtControls.TextArea { | ||||
| 
 | ||||
|                 TextArea { | ||||
|                     id: description | ||||
|                     anchors.fill: parent | ||||
|                     textFormat: TextEdit.PlainText | ||||
|                 } | ||||
|             } | ||||
|             QtControls.GroupBox { | ||||
|                 QtLayouts.Layout.fillWidth: true | ||||
|                 height: parent.height / 5 | ||||
| 
 | ||||
|             GroupBox { | ||||
|                 Layout.fillWidth: true | ||||
|                 title: i18n("Steps to reproduce") | ||||
|                 QtControls.TextArea { | ||||
| 
 | ||||
|                 TextArea { | ||||
|                     id: reproduce | ||||
|                     anchors.fill: parent | ||||
|                     textFormat: TextEdit.PlainText | ||||
|                 } | ||||
|             } | ||||
|             QtControls.GroupBox { | ||||
|                 QtLayouts.Layout.fillWidth: true | ||||
|                 height: parent.height / 5 | ||||
| 
 | ||||
|             GroupBox { | ||||
|                 Layout.fillWidth: true | ||||
|                 title: i18n("Expected result") | ||||
|                 QtControls.TextArea { | ||||
| 
 | ||||
|                 TextArea { | ||||
|                     id: expected | ||||
|                     anchors.fill: parent | ||||
|                     textFormat: TextEdit.PlainText | ||||
|                 } | ||||
|             } | ||||
|             QtControls.GroupBox { | ||||
|                 QtLayouts.Layout.fillWidth: true | ||||
|                 QtLayouts.Layout.alignment: Qt.AlignBottom | ||||
| 
 | ||||
|             GroupBox { | ||||
|                 Layout.fillWidth: true | ||||
|                 Layout.alignment: Qt.AlignBottom | ||||
|                 title: i18n("Logs") | ||||
|                 QtLayouts.ColumnLayout { | ||||
| 
 | ||||
|                 ColumnLayout { | ||||
|                     anchors.fill: parent | ||||
|                     QtLayouts.Layout.fillWidth: true | ||||
|                     Layout.fillWidth: true | ||||
| 
 | ||||
|                     Row { | ||||
|                           QtLayouts.Layout.fillWidth: true | ||||
|                         QtControls.Label { | ||||
|                         Layout.fillWidth: true | ||||
| 
 | ||||
|                         Label { | ||||
|                             width: parent.width * 2 / 5 | ||||
|                             horizontalAlignment: Text.AlignJustify | ||||
|                             verticalAlignment: Text.AlignVCenter | ||||
|                             wrapMode: Text.WordWrap | ||||
|                             text: i18n("Use command") | ||||
|                         } | ||||
|                         QtControls.TextField { | ||||
| 
 | ||||
|                         TextField { | ||||
|                             width: parent.width * 3 / 5 | ||||
|                             readOnly: true | ||||
|                             text: "QT_LOGGING_RULES=*=true plasmawindowed org.kde.plasma.awesomewidget" | ||||
|                         } | ||||
|                     } | ||||
|                     QtControls.Button { | ||||
|                         QtLayouts.Layout.fillWidth: true | ||||
| 
 | ||||
|                     Button { | ||||
|                         Layout.fillWidth: true | ||||
|                         text: i18n("Load log file") | ||||
|                         onClicked: logPath.open() | ||||
|                     } | ||||
|                     QtControls.TextArea { | ||||
| 
 | ||||
|                     TextArea { | ||||
|                         id: logBody | ||||
|                         QtLayouts.Layout.fillWidth: true | ||||
|                         QtLayouts.Layout.alignment: Qt.AlignBottom | ||||
|                         Layout.fillWidth: true | ||||
|                         Layout.alignment: Qt.AlignBottom | ||||
|                         textFormat: TextEdit.PlainText | ||||
|                     } | ||||
|                 } | ||||
| 
 | ||||
|                 QtDialogs.FileDialog { | ||||
|                 FileDialog { | ||||
|                     id: logPath | ||||
|                     title: i18n("Open log file") | ||||
|                     onAccepted: | ||||
|                     logBody.text = awActions.getFileContent(logPath.fileUrl.toString().replace("file://", "")) | ||||
|                     onAccepted: logBody.text = awActions.getFileContent(logPath.selectedFile.toString().replace("file://", "")) | ||||
|                 } | ||||
|             } | ||||
| 
 | ||||
|             DialogButtonBox { | ||||
|                 Layout.fillWidth: true | ||||
| 
 | ||||
|                 standardButtons: DialogButtonBox.Ok | DialogButtonBox.Reset | ||||
|                 alignment: Qt.AlignRight | ||||
|                 onAccepted: sendBugReport() | ||||
|                 onReset: resetDialog() | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| 
 | ||||
|     onAccepted: { | ||||
|         if (debug) console.debug() | ||||
| 
 | ||||
|         var text = awBugReporter.generateText(description.text, reproduce.text, | ||||
|                                               expected.text, logBody.text) | ||||
|     function sendBugReport() { | ||||
|         const text = awBugReporter.generateText(description.text, reproduce.text, expected.text, logBody.text) | ||||
|         awBugReporter.sendBugReport(title.text, text) | ||||
|     } | ||||
| 
 | ||||
|     onReset: { | ||||
|         if (debug) console.debug() | ||||
| 
 | ||||
|     function resetDialog() { | ||||
|         title.text = "" | ||||
|         description.text = "" | ||||
|         reproduce.text = "" | ||||
|         expected.text = "" | ||||
|         logBody.text = "" | ||||
|     } | ||||
| 
 | ||||
|     Component.onCompleted: { | ||||
|         if (debug) console.debug() | ||||
| 
 | ||||
|         resetDialog() | ||||
|         awBugReporter.doConnect() | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| @ -15,105 +15,46 @@ | ||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||
|  ***************************************************************************/ | ||||
|  | ||||
| import QtQuick 2.0 | ||||
| import QtQuick.Controls 1.3 as QtControls | ||||
| import QtQuick.Dialogs 1.1 as QtDialogs | ||||
| import QtQuick 2.15 | ||||
| import QtQuick.Controls | ||||
| import org.kde.kcmutils as KCM | ||||
|  | ||||
| import org.kde.plasma.private.awesomewidget 1.0 | ||||
| import org.kde.plasma.awesomewidgets | ||||
| import org.kde.plasma.private.awesomewidget | ||||
|  | ||||
|  | ||||
| Item { | ||||
| KCM.SimpleKCM { | ||||
|     id: dataenginePage | ||||
|  | ||||
|     // backend | ||||
|     AWKeys { | ||||
|         id: awKeys | ||||
|     } | ||||
|     AWActions { | ||||
|         id: awActions | ||||
|     } | ||||
|     AWConfigHelper { | ||||
|         id: awConfig | ||||
|     } | ||||
|  | ||||
|     width: childrenRect.width | ||||
|     height: childrenRect.height | ||||
|     implicitWidth: pageColumn.implicitWidth | ||||
|     implicitHeight: pageColumn.implicitHeight | ||||
|  | ||||
|     property bool debug: awActions.isDebugEnabled() | ||||
|  | ||||
|     property variant cfg_dataengine: awConfig.readDataEngineConfiguration() | ||||
|  | ||||
|  | ||||
|     Column { | ||||
|         id: pageColumn | ||||
|         anchors.fill: parent | ||||
|         QtControls.GroupBox { | ||||
|  | ||||
|         GroupBox { | ||||
|             height: implicitHeight | ||||
|             width: parent.width | ||||
|             title: i18n("ACPI") | ||||
|             LineSelector { | ||||
|                 text: i18n("ACPI path") | ||||
|                 value: cfg_dataengine["ACPIPATH"] | ||||
|                 onValueEdited: cfg_dataengine["ACPIPATH"] = newValue | ||||
|                 onValueEdited: newValue => cfg_dataengine["ACPIPATH"] = newValue | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         QtControls.GroupBox { | ||||
|             height: implicitHeight | ||||
|             width: parent.width | ||||
|             title: i18n("GPU") | ||||
|             ComboBoxSelector { | ||||
|                 model: [ | ||||
|                     { | ||||
|                         'label': "auto", | ||||
|                         'name': "auto" | ||||
|                     }, | ||||
|                     { | ||||
|                         'label': "disable", | ||||
|                         'name': "disable" | ||||
|                     }, | ||||
|                     { | ||||
|                         'label': "ati", | ||||
|                         'name': "ati" | ||||
|                     }, | ||||
|                     { | ||||
|                         'label': "nvidia", | ||||
|                         'name': "nvidia" | ||||
|                     } | ||||
|                 ] | ||||
|                 text: i18n("GPU device") | ||||
|                 value: cfg_dataengine["GPUDEV"] | ||||
|                 onValueEdited: cfg_dataengine["GPUDEV"] = newValue | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         QtControls.GroupBox { | ||||
|             height: implicitHeight | ||||
|             width: parent.width | ||||
|             title: i18n("HDD temperature") | ||||
|             Column { | ||||
|                 height: implicitHeight | ||||
|                 width: parent.width | ||||
|                 ComboBoxSelector { | ||||
|                     id: hdd | ||||
|                     text: i18n("HDD") | ||||
|                     value: cfg_dataengine["HDDDEV"] | ||||
|                     onValueEdited: cfg_dataengine["HDDDEV"] = newValue | ||||
|                 } | ||||
|  | ||||
|                 LineSelector { | ||||
|                     text: i18n("hddtemp cmd") | ||||
|                     value: cfg_dataengine["HDDTEMPCMD"] | ||||
|                     onValueEdited: cfg_dataengine["HDDTEMPCMD"] = newValue | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         QtControls.GroupBox { | ||||
|         GroupBox { | ||||
|             height: implicitHeight | ||||
|             width: parent.width | ||||
|             title: i18n("Player") | ||||
|  | ||||
|             Column { | ||||
|                 height: implicitHeight | ||||
|                 width: parent.width | ||||
| @ -123,27 +64,27 @@ Item { | ||||
|                     stepSize: 1 | ||||
|                     text: i18n("Player data symbols") | ||||
|                     value: cfg_dataengine["PLAYERSYMBOLS"] | ||||
|                     onValueEdited: cfg_dataengine["PLAYERSYMBOLS"] = newValue | ||||
|                     onValueEdited: newValue => cfg_dataengine["PLAYERSYMBOLS"] = newValue | ||||
|                 } | ||||
|  | ||||
|                 ComboBoxSelector { | ||||
|                     model: [ | ||||
|                         { | ||||
|                             'label': "disable", | ||||
|                             'name': "disable" | ||||
|                             "label": "disable", | ||||
|                             "name": "disable" | ||||
|                         }, | ||||
|                         { | ||||
|                             'label': "mpris", | ||||
|                             'name': "mpris" | ||||
|                             "label": "mpris", | ||||
|                             "name": "mpris" | ||||
|                         }, | ||||
|                         { | ||||
|                             'label': "mpd", | ||||
|                             'name': "mpd" | ||||
|                             "label": "mpd", | ||||
|                             "name": "mpd" | ||||
|                         } | ||||
|                     ] | ||||
|                     text: i18n("Music player") | ||||
|                     value: cfg_dataengine["PLAYER"] | ||||
|                     onValueEdited: cfg_dataengine["PLAYER"] = newValue | ||||
|                     onValueEdited: newValue => cfg_dataengine["PLAYER"] = newValue | ||||
|                 } | ||||
|  | ||||
|                 ComboBoxSelector { | ||||
| @ -151,40 +92,40 @@ Item { | ||||
|                     editable: true | ||||
|                     model: [ | ||||
|                         { | ||||
|                             'label': 'auto', | ||||
|                             'name': 'auto' | ||||
|                             "label": "auto", | ||||
|                             "name": "auto" | ||||
|                         }, | ||||
|                         { | ||||
|                             'label': 'amarok', | ||||
|                             'name': 'amarok' | ||||
|                             "label": "amarok", | ||||
|                             "name": "amarok" | ||||
|                         }, | ||||
|                         { | ||||
|                             'label': 'audacious', | ||||
|                             'name': 'audacious' | ||||
|                             "label": "audacious", | ||||
|                             "name": "audacious" | ||||
|                         }, | ||||
|                         { | ||||
|                             'label': 'clementine', | ||||
|                             'name': 'clementine' | ||||
|                             "label": "clementine", | ||||
|                             "name": "clementine" | ||||
|                         }, | ||||
|                         { | ||||
|                             'label': 'DeaDBeeF', | ||||
|                             'name': 'DeaDBeeF' | ||||
|                             "label": "DeaDBeeF", | ||||
|                             "name": "DeaDBeeF" | ||||
|                         }, | ||||
|                         { | ||||
|                             'label': 'vlc', | ||||
|                             'name': 'vlc' | ||||
|                             "label": "vlc", | ||||
|                             "name": "vlc" | ||||
|                         }, | ||||
|                         { | ||||
|                             'label': 'qmmp', | ||||
|                             'name': 'qmmp' | ||||
|                             "label": "qmmp", | ||||
|                             "name": "qmmp" | ||||
|                         }, | ||||
|                         { | ||||
|                             'label': 'xmms2', | ||||
|                             'name': 'xmms2' | ||||
|                             "label": "xmms2", | ||||
|                             "name": "xmms2" | ||||
|                         }, | ||||
|                         { | ||||
|                             'label': cfg_dataengine["MPRIS"], | ||||
|                             'name': cfg_dataengine["MPRIS"] | ||||
|                             "label": cfg_dataengine["MPRIS"], | ||||
|                             "name": cfg_dataengine["MPRIS"] | ||||
|                         } | ||||
|                     ] | ||||
|                     text: i18n("MPRIS player name") | ||||
| @ -194,7 +135,7 @@ Item { | ||||
|                 LineSelector { | ||||
|                     text: i18n("MPD address") | ||||
|                     value: cfg_dataengine["MPDADDRESS"] | ||||
|                     onValueEdited: cfg_dataengine["MPDADDRESS"] = newValue | ||||
|                     onValueEdited: newValue => cfg_dataengine["MPDADDRESS"] = newValue | ||||
|                 } | ||||
|  | ||||
|                 IntegerSelector { | ||||
| @ -203,18 +144,20 @@ Item { | ||||
|                     stepSize: 1 | ||||
|                     text: i18n("MPD port") | ||||
|                     value: cfg_dataengine["MPDPORT"] | ||||
|                     onValueEdited: cfg_dataengine["MPDPORT"] = newValue | ||||
|                     onValueEdited: newValue => cfg_dataengine["MPDPORT"] = newValue | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         QtControls.GroupBox { | ||||
|         GroupBox { | ||||
|             height: implicitHeight | ||||
|             width: parent.width | ||||
|             title: i18n("Extensions") | ||||
|  | ||||
|             Column { | ||||
|                 height: implicitHeight | ||||
|                 width: parent.width | ||||
|  | ||||
|                 ButtonSelector { | ||||
|                     value: i18n("Custom scripts") | ||||
|                     onButtonActivated: awKeys.editItem("extscript") | ||||
| @ -245,19 +188,11 @@ Item { | ||||
|  | ||||
|  | ||||
|     Component.onCompleted: { | ||||
|         if (debug) console.debug() | ||||
|  | ||||
|         // init submodule | ||||
|         awKeys.updateCache() | ||||
|  | ||||
|         // update hdd model | ||||
|         hdd.model = awKeys.getHddDevices() | ||||
|         hdd.onCompleted | ||||
|     } | ||||
|  | ||||
|     Component.onDestruction: { | ||||
|         if (debug) console.debug() | ||||
|  | ||||
|         cfg_dataengine["MPRIS"] = mpris.editText | ||||
|         awConfig.writeDataEngineConfiguration(cfg_dataengine) | ||||
|     } | ||||
|  | ||||
| @ -15,20 +15,18 @@ | ||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||
|  ***************************************************************************/ | ||||
|  | ||||
| import QtQuick 2.4 | ||||
| import QtQuick.Controls 1.3 as QtControls | ||||
| import QtQuick.Dialogs 1.2 as QtDialogs | ||||
| import QtQuick.Layouts 1.1 | ||||
| import QtQuick 2.15 | ||||
| import QtQuick.Layouts | ||||
| import org.kde.plasma.core as PlasmaCore | ||||
| 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.awesomewidget 1.0 | ||||
| import "." | ||||
| import org.kde.plasma.awesomewidgets | ||||
| import org.kde.plasma.private.awesomewidget | ||||
|  | ||||
|  | ||||
| Item { | ||||
| PlasmoidItem { | ||||
|     id: main | ||||
|  | ||||
|     // backend | ||||
|     AWKeys { | ||||
|         id: awKeys | ||||
| @ -39,11 +37,7 @@ Item { | ||||
|     AWTelemetryHandler { | ||||
|         id: awTelemetryHandler | ||||
|     } | ||||
|     BugReport { | ||||
|         id: bugReport | ||||
|     } | ||||
|  | ||||
|     property bool debug: awActions.isDebugEnabled() | ||||
|     property variant tooltipSettings: { | ||||
|         "tooltipNumber": plasmoid.configuration.tooltipNumber, | ||||
|         "useTooltipBackground": plasmoid.configuration.useTooltipBackground, | ||||
| @ -73,19 +67,12 @@ Item { | ||||
|     signal needToolTipUpdate(string newText) | ||||
|     signal sizeUpdate | ||||
|  | ||||
|  | ||||
|     // init | ||||
|     Plasmoid.preferredRepresentation: Plasmoid.fullRepresentation | ||||
|     Plasmoid.compactRepresentation: Plasmoid.fullRepresentation | ||||
|  | ||||
|     Layout.fillWidth: plasmoid.formFactor != PlasmaCore.Planar | ||||
|     Layout.fillHeight: plasmoid.formFactor != PlasmaCore.Planar | ||||
|     Layout.fillWidth: PlasmoidItem.formFactor !== PlasmaCore.Planar | ||||
|     Layout.fillHeight: PlasmoidItem.formFactor !== PlasmaCore.Planar | ||||
|     Layout.alignment: Qt.AlignVCenter | Qt.AlignHCenter | ||||
|  | ||||
|     Plasmoid.icon: "utilities-system-monitor" | ||||
|     Plasmoid.backgroundHints: plasmoid.configuration.background ? "DefaultBackground" : "NoBackground" | ||||
|     Plasmoid.associatedApplication: "ksysguard" | ||||
|  | ||||
|  | ||||
|     // ui | ||||
|     Text { | ||||
| @ -100,7 +87,7 @@ Item { | ||||
|  | ||||
|         color: plasmoid.configuration.fontColor | ||||
|         font.family: plasmoid.configuration.fontFamily | ||||
|         font.italic: plasmoid.configuration.fontStyle == "italic" ? true : false | ||||
|         font.italic: plasmoid.configuration.fontStyle === "italic" | ||||
|         font.pointSize: plasmoid.configuration.fontSize | ||||
|         font.weight: General.fontWeight[plasmoid.configuration.fontWeight] | ||||
|  | ||||
| @ -119,73 +106,55 @@ Item { | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     QtDialogs.Dialog { | ||||
|         id: tagSelector | ||||
|         title: i18n("Select tag") | ||||
|  | ||||
|         QtControls.ComboBox { | ||||
|             id: tagSelectorBox | ||||
|             width: parent.width | ||||
|             editable: true | ||||
|     Plasmoid.contextualActions: [ | ||||
|         PlasmaCore.Action { | ||||
|             text: i18n("Run monitor") | ||||
|             icon.name: "utilities-system-monitor" | ||||
|             onTriggered: awActions.runCmd("plasma-systemmonitor", []) | ||||
|         }, | ||||
|         PlasmaCore.Action { | ||||
|             text: i18n("Show README") | ||||
|             icon.name: "text-x-readme" | ||||
|             onTriggered: awActions.showReadme() | ||||
|         }, | ||||
|         PlasmaCore.Action { | ||||
|             text: i18n("Check updates") | ||||
|             icon.name: "system-software-update" | ||||
|             onTriggered: awActions.checkUpdates(true) | ||||
|         } | ||||
|  | ||||
|         onAccepted: { | ||||
|             var tag = tagSelectorBox.editText | ||||
|             var message = i18n("Tag: %1", tag) | ||||
|             message += "<br>" | ||||
|             message += i18n("Value: %1", awKeys.valueByKey(tag)) | ||||
|             message += "<br>" | ||||
|             message += i18n("Info: %1", awKeys.infoByKey(tag)) | ||||
|             awActions.sendNotification("tag", message) | ||||
|         } | ||||
|     } | ||||
|     ] | ||||
|  | ||||
|  | ||||
|     Component.onCompleted: { | ||||
|         if (debug) console.debug() | ||||
|  | ||||
|         // actions | ||||
|         // it makes no sense to use this field with optimization enable | ||||
|         if (!plasmoid.configuration.optimize) | ||||
|             plasmoid.setAction("requestKey", i18n("Request key"), "utilities-system-monitor") | ||||
|         plasmoid.setAction("showReadme", i18n("Show README"), "text-x-readme") | ||||
|         plasmoid.setAction("checkUpdates", i18n("Check updates"), "system-software-update") | ||||
|         plasmoid.setAction("reportBug", i18n("Report bug"), "tools-report-bug") | ||||
|         // init submodule | ||||
|         Plasmoid.userConfiguringChanged(false) | ||||
|         // connect data | ||||
|         awKeys.needTextToBeUpdated.connect(needTextUpdate) | ||||
|         awKeys.needToolTipToBeUpdated.connect(needToolTipUpdate) | ||||
|         //awKeys.needToolTipToBeUpdated.connect(needToolTipUpdate) | ||||
|         // check updates if required | ||||
|         if (plasmoid.configuration.checkUpdates) return awActions.checkUpdates(false) | ||||
|     } | ||||
|  | ||||
|     onNeedTextUpdate: { | ||||
|         if (debug) console.debug() | ||||
|  | ||||
|     onNeedTextUpdate: newText => { | ||||
|         text.text = newText | ||||
|         sizeUpdate() | ||||
|     } | ||||
|  | ||||
|     onNeedToolTipUpdate: { | ||||
|         if (debug) console.debug() | ||||
|  | ||||
|     onNeedToolTipUpdate: newText => { | ||||
|         tooltip.text = newText | ||||
|     } | ||||
|  | ||||
|     onSizeUpdate: { | ||||
|         if (debug) console.debug() | ||||
|         // 16 is a magic number | ||||
|         // in other case plasmoid will increase own size on each update | ||||
|  | ||||
|         if (plasmoid.configuration.height == 0) { | ||||
|         if (plasmoid.configuration.height === 0) { | ||||
|             Layout.minimumHeight = text.contentHeight - 16 | ||||
|             Layout.maximumHeight = -1 | ||||
|         } else { | ||||
|             Layout.minimumHeight = plasmoid.configuration.height | ||||
|             Layout.maximumHeight = plasmoid.configuration.height | ||||
|         } | ||||
|         if (plasmoid.configuration.width == 0) { | ||||
|         if (plasmoid.configuration.width === 0) { | ||||
|             Layout.minimumWidth = text.contentWidth - 16 | ||||
|             Layout.maximumWidth = -1 | ||||
|         } else { | ||||
| @ -196,12 +165,10 @@ Item { | ||||
|  | ||||
|     Plasmoid.onUserConfiguringChanged: { | ||||
|         if (plasmoid.userConfiguring) return | ||||
|         if (debug) console.debug() | ||||
|  | ||||
|         // init submodule | ||||
|         awKeys.initDataAggregator(tooltipSettings) | ||||
|         awKeys.initKeys(plasmoid.configuration.text, plasmoid.configuration.interval, | ||||
|                         plasmoid.configuration.queueLimit, plasmoid.configuration.optimize) | ||||
|         awKeys.initKeys(plasmoid.configuration.text, plasmoid.configuration.interval, plasmoid.configuration.optimize) | ||||
|         awKeys.setWrapNewLines(plasmoid.configuration.wrapNewLines) | ||||
|         // configure aggregator | ||||
|         awKeys.setAggregatorProperty("acOffline", plasmoid.configuration.acOffline) | ||||
| @ -210,49 +177,8 @@ Item { | ||||
|         awKeys.setAggregatorProperty("customUptime", plasmoid.configuration.customUptime) | ||||
|         awKeys.setAggregatorProperty("tempUnits", plasmoid.configuration.tempUnits) | ||||
|         awKeys.setAggregatorProperty("translate", plasmoid.configuration.translateStrings) | ||||
|         // update telemetry ID | ||||
|         if (plasmoid.configuration.telemetryId.length == 0) | ||||
|             plasmoid.configuration.telemetryId = generateUuid() | ||||
|         // save telemetry | ||||
|         awTelemetryHandler.init(plasmoid.configuration.telemetryCount, | ||||
|                                 plasmoid.configuration.telemetryRemote, | ||||
|                                 plasmoid.configuration.telemetryId) | ||||
|         if (awTelemetryHandler.put("awwidgetconfig", plasmoid.configuration.text)) | ||||
|             awTelemetryHandler.uploadTelemetry("awwidgetconfig", plasmoid.configuration.text) | ||||
|     } | ||||
|  | ||||
|  | ||||
|     function action_checkUpdates() { | ||||
|         if (debug) console.debug() | ||||
|  | ||||
|         return awActions.checkUpdates(true) | ||||
|     } | ||||
|  | ||||
|     function action_showReadme() { | ||||
|         if (debug) console.debug() | ||||
|  | ||||
|         return awActions.showReadme() | ||||
|     } | ||||
|  | ||||
|     function action_reportBug() { | ||||
|         if (debug) console.debug() | ||||
|  | ||||
|         bugReport.reset() | ||||
|         bugReport.open() | ||||
|     } | ||||
|  | ||||
|     function action_requestKey() { | ||||
|         if (debug) console.debug() | ||||
|  | ||||
|         tagSelectorBox.model = awKeys.dictKeys(true) | ||||
|         return tagSelector.open() | ||||
|     } | ||||
|  | ||||
|     // code from http://stackoverflow.com/questions/105034/create-guid-uuid-in-javascript | ||||
|     function generateUuid() { | ||||
|         return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function(c) { | ||||
|             var r = Math.random() * 16 | 0, v = c == 'x' ? r : (r & 0x3 | 0x8); | ||||
|             return v.toString(16); | ||||
|         }); | ||||
|         awTelemetryHandler.init(plasmoid.configuration.historyCount) | ||||
|         awTelemetryHandler.put("awwidgetconfig", plasmoid.configuration.text) | ||||
|     } | ||||
| } | ||||
|  | ||||
| @ -1,27 +0,0 @@ | ||||
| # Do not edit qmldir directly it will be overrided during compilation, | ||||
| # edit qml/qmldir.in file instead. | ||||
|  | ||||
|  | ||||
| # common QML constants | ||||
| singleton General 1.0 file:///usr/share/awesomewidgets/qml/General.qml | ||||
|  | ||||
| # custom QML UI classes | ||||
| AboutTab file:///usr/share/awesomewidgets/qml/AboutTab.qml | ||||
| AWExtensions file:///usr/share/awesomewidgets/qml/AWExtensions.qml | ||||
| AWInfoLabel file:///usr/share/awesomewidgets/qml/AWInfoLabel.qml | ||||
| AWTagSelector file:///usr/share/awesomewidgets/qml/AWTagSelector.qml | ||||
| AWTextEditor file:///usr/share/awesomewidgets/qml/AWTextEditor.qml | ||||
| BugReport file:///usr/share/awesomewidgets/qml/BugReport.qml | ||||
| ButtonSelector file:///usr/share/awesomewidgets/qml/ButtonSelector.qml | ||||
| CheckBoxSelector file:///usr/share/awesomewidgets/qml/CheckBoxSelector.qml | ||||
| ColorSelector file:///usr/share/awesomewidgets/qml/ColorSelector.qml | ||||
| ComboBoxSelector file:///usr/share/awesomewidgets/qml/ComboBoxSelector.qml | ||||
| ExportDialog file:///usr/share/awesomewidgets/qml/ExportDialog.qml | ||||
| FontSelector file:///usr/share/awesomewidgets/qml/FontSelector.qml | ||||
| HtmlDefaultFunctionsBar file:///usr/share/awesomewidgets/qml/HtmlDefaultFunctionsBar.qml | ||||
| HtmlEditorButton file:///usr/share/awesomewidgets/qml/HtmlEditorButton.qml | ||||
| HtmlEditorColor file:///usr/share/awesomewidgets/qml/HtmlEditorColor.qml | ||||
| HtmlEditorFont file:///usr/share/awesomewidgets/qml/HtmlEditorFont.qml | ||||
| ImportDialog file:///usr/share/awesomewidgets/qml/ImportDialog.qml | ||||
| IntegerSelector file:///usr/share/awesomewidgets/qml/IntegerSelector.qml | ||||
| LineSelector file:///usr/share/awesomewidgets/qml/LineSelector.qml | ||||
| @ -15,25 +15,16 @@ | ||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||
|  ***************************************************************************/ | ||||
|  | ||||
| import QtQuick 2.0 | ||||
| import QtQuick.Controls 1.3 as QtControls | ||||
| import QtQuick 2.15 | ||||
| import QtQuick.Controls | ||||
| import org.kde.kcmutils as KCM | ||||
|  | ||||
| import org.kde.plasma.private.awesomewidget 1.0 | ||||
| import org.kde.plasma.awesomewidgets | ||||
| import org.kde.plasma.private.awesomewidget | ||||
|  | ||||
|  | ||||
| Item { | ||||
| KCM.SimpleKCM { | ||||
|     id: tooltipPage | ||||
|     // backend | ||||
|     AWActions { | ||||
|         id: awActions | ||||
|     } | ||||
|  | ||||
|     width: childrenRect.width | ||||
|     height: childrenRect.height | ||||
|     implicitWidth: pageColumn.implicitWidth | ||||
|     implicitHeight: pageColumn.implicitHeight | ||||
|  | ||||
|     property bool debug: awActions.isDebugEnabled() | ||||
|  | ||||
|     property alias cfg_tooltipNumber: tooltipNumber.value | ||||
|     property alias cfg_useTooltipBackground: useTooltipBackground.checked | ||||
| @ -46,18 +37,17 @@ Item { | ||||
|     property alias cfg_memTooltipColor: memTooltipColor.value | ||||
|     property alias cfg_swapTooltip: swapTooltip.checked | ||||
|     property alias cfg_swapTooltipColor: swapTooltipColor.value | ||||
|     property alias cfg_downkbTooltip: downkbTooltip.checked | ||||
|     property alias cfg_downkbTooltip: networkTooltip.checked | ||||
|     property alias cfg_downkbTooltipColor: downkbTooltipColor.value | ||||
|     property alias cfg_upkbTooltipColor: upkbTooltipColor.value | ||||
|     property alias cfg_batTooltip: batTooltip.checked | ||||
|     property alias cfg_batTooltipColor: batTooltipColor.value | ||||
|     property alias cfg_batInTooltipColor: batInTooltipColor.value | ||||
|  | ||||
|  | ||||
|     Column { | ||||
|         id: pageColumn | ||||
|         anchors.fill: parent | ||||
|         QtControls.Label { | ||||
|  | ||||
|         Label { | ||||
|           width: parent.width | ||||
|           horizontalAlignment: Text.AlignHCenter | ||||
|           verticalAlignment: Text.AlignVCenter | ||||
| @ -74,85 +64,116 @@ Item { | ||||
|             value: plasmoid.configuration.tooltipNumber | ||||
|         } | ||||
|  | ||||
|         QtControls.GroupBox { | ||||
|         GroupBox { | ||||
|             id: useTooltipBackground | ||||
|             height: implicitHeight | ||||
|             width: parent.width | ||||
|             checkable: true | ||||
|             title: i18n("Background") | ||||
|  | ||||
|             property alias checked: useTooltipBackgroundLabel.checked | ||||
|             label: CheckBox { | ||||
|                 id: useTooltipBackgroundLabel | ||||
|                 text: i18n("Background") | ||||
|             } | ||||
|  | ||||
|             ColorSelector { | ||||
|                 id: tooltipBackground | ||||
|                 enabled: useTooltipBackgroundLabel.checked | ||||
|                 text: i18n("Background color") | ||||
|                 value: plasmoid.configuration.tooltipBackground | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         QtControls.GroupBox { | ||||
|         GroupBox { | ||||
|             id: cpuTooltip | ||||
|             height: implicitHeight | ||||
|             width: parent.width | ||||
|             checkable: true | ||||
|             title: i18n("CPU") | ||||
|  | ||||
|             property alias checked: cpuTooltipLabel.checked | ||||
|             label: CheckBox { | ||||
|                 id: cpuTooltipLabel | ||||
|                 text: i18n("CPU") | ||||
|             } | ||||
|  | ||||
|             ColorSelector { | ||||
|                 id: cpuTooltipColor | ||||
|                 enabled: cpuTooltipLabel.checked | ||||
|                 text: i18n("CPU color") | ||||
|                 value: plasmoid.configuration.cpuTooltipColor | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         QtControls.GroupBox { | ||||
|         GroupBox { | ||||
|             id: cpuclTooltip | ||||
|             height: implicitHeight | ||||
|             width: parent.width | ||||
|             checkable: true | ||||
|             title: i18n("CPU clock") | ||||
|  | ||||
|             property alias checked: cpuclTooltipLabel.checked | ||||
|             label: CheckBox { | ||||
|                 id: cpuclTooltipLabel | ||||
|                 text: i18n("CPU clock") | ||||
|             } | ||||
|  | ||||
|             ColorSelector { | ||||
|                 id: cpuclTooltipColor | ||||
|                 enabled: cpuclTooltipLabel.checked | ||||
|                 text: i18n("CPU clock color") | ||||
|                 value: plasmoid.configuration.cpuclTooltipColor | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         QtControls.GroupBox { | ||||
|         GroupBox { | ||||
|             id: memTooltip | ||||
|             height: implicitHeight | ||||
|             width: parent.width | ||||
|             checkable: true | ||||
|             title: i18n("Memory") | ||||
|  | ||||
|             property alias checked: memTooltipLabel.checked | ||||
|             label: CheckBox { | ||||
|                 id: memTooltipLabel | ||||
|                 text: i18n("Memory") | ||||
|             } | ||||
|  | ||||
|             ColorSelector { | ||||
|                 id: memTooltipColor | ||||
|                 enabled: memTooltipLabel.checked | ||||
|                 text: i18n("Memory color") | ||||
|                 value: plasmoid.configuration.memTooltipColor | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         QtControls.GroupBox { | ||||
|         GroupBox { | ||||
|             id: swapTooltip | ||||
|             height: implicitHeight | ||||
|             width: parent.width | ||||
|             checkable: true | ||||
|             title: i18n("Swap") | ||||
|  | ||||
|             property alias checked: swapTooltipLabel.checked | ||||
|             label: CheckBox { | ||||
|                 id: swapTooltipLabel | ||||
|                 text: i18n("Swap") | ||||
|             } | ||||
|  | ||||
|             ColorSelector { | ||||
|                 id: swapTooltipColor | ||||
|                 enabled: swapTooltipLabel.checked | ||||
|                 text: i18n("Swap color") | ||||
|                 value: plasmoid.configuration.swapTooltipColor | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         QtControls.GroupBox { | ||||
|             id: downkbTooltip | ||||
|             height: implicitHeight | ||||
|         GroupBox { | ||||
|             id: networkTooltip | ||||
|             width: parent.width | ||||
|             checkable: true | ||||
|             title: i18n("Network") | ||||
|  | ||||
|             property alias checked: networkTooltipLabel.checked | ||||
|             label: CheckBox { | ||||
|                 id: networkTooltipLabel | ||||
|                 text: i18n("Network") | ||||
|             } | ||||
|  | ||||
|             Column { | ||||
|                 height: implicitHeight | ||||
|                 width: parent.width | ||||
|                 enabled: networkTooltipLabel.checked | ||||
|  | ||||
|                 ColorSelector { | ||||
|                     id: downkbTooltipColor | ||||
|                     text: i18n("Download speed color") | ||||
|                     value: plasmoid.configuration.downkbTooltipColor | ||||
|                 } | ||||
|  | ||||
|                 ColorSelector { | ||||
|                     id: upkbTooltipColor | ||||
|                     text: i18n("Upload speed color") | ||||
| @ -161,20 +182,26 @@ Item { | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         QtControls.GroupBox { | ||||
|         GroupBox { | ||||
|             id: batTooltip | ||||
|             height: implicitHeight | ||||
|             width: parent.width | ||||
|             checkable: true | ||||
|             title: i18n("Battery") | ||||
|  | ||||
|             property alias checked: batteryTooltipLabel.checked | ||||
|             label: CheckBox { | ||||
|                 id: batteryTooltipLabel | ||||
|                 text: i18n("Battery") | ||||
|             } | ||||
|  | ||||
|             Column { | ||||
|                 height: implicitHeight | ||||
|                 width: parent.width | ||||
|                 enabled: batteryTooltipLabel.checked | ||||
|  | ||||
|                 ColorSelector { | ||||
|                     id: batTooltipColor | ||||
|                     text: i18n("Battery active color") | ||||
|                     value: plasmoid.configuration.batTooltipColor | ||||
|                 } | ||||
|  | ||||
|                 ColorSelector { | ||||
|                     id: batInTooltipColor | ||||
|                     text: i18n("Battery inactive color") | ||||
| @ -183,9 +210,4 @@ Item { | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|  | ||||
|     Component.onCompleted: { | ||||
|         if (debug) console.debug() | ||||
|     } | ||||
| } | ||||
|  | ||||
| @ -15,14 +15,17 @@ | ||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||
|  ***************************************************************************/ | ||||
|  | ||||
| import QtQuick 2.2 | ||||
| import QtQuick 2.15 | ||||
| import QtQuick.Controls | ||||
| import org.kde.kcmutils as KCM | ||||
|  | ||||
| import org.kde.plasma.private.awesomewidget 1.0 | ||||
| import "." | ||||
| import org.kde.plasma.awesomewidgets | ||||
| import org.kde.plasma.private.awesomewidget | ||||
|  | ||||
|  | ||||
| Item { | ||||
| KCM.SimpleKCM { | ||||
|     id: widgetPage | ||||
|  | ||||
|     // backend | ||||
|     AWKeys { | ||||
|         id: awKeys | ||||
| @ -31,21 +34,12 @@ Item { | ||||
|         id: awActions | ||||
|     } | ||||
|  | ||||
|     width: childrenRect.width | ||||
|     height: childrenRect.height | ||||
|     implicitWidth: pageColumn.implicitWidth | ||||
|     implicitHeight: pageColumn.implicitHeight | ||||
|  | ||||
|     property bool debug: awActions.isDebugEnabled() | ||||
|  | ||||
|     property alias cfg_text: textPattern.text | ||||
|     property bool lock: true | ||||
|  | ||||
|     signal needTextUpdate(string newText) | ||||
|  | ||||
|  | ||||
|     Column { | ||||
|         id: pageColumn | ||||
|         anchors.fill: parent | ||||
|  | ||||
|         AWInfoLabel {} | ||||
| @ -74,10 +68,7 @@ Item { | ||||
|         } | ||||
|     } | ||||
|  | ||||
|  | ||||
|     Component.onCompleted: { | ||||
|         if (debug) console.debug() | ||||
|  | ||||
|         awKeys.needTextToBeUpdated.connect(needTextUpdate) | ||||
|         // init submodule | ||||
|         awKeys.initKeys(plasmoid.configuration.text, plasmoid.configuration.interval, | ||||
| @ -90,9 +81,8 @@ Item { | ||||
|         awKeys.setAggregatorProperty("translate", plasmoid.configuration.translateStrings) | ||||
|     } | ||||
|  | ||||
|     onNeedTextUpdate: { | ||||
|     onNeedTextUpdate: newText => { | ||||
|         if (lock) return | ||||
|         if (debug) console.debug() | ||||
|  | ||||
|         extensions.showMessage(newText) | ||||
|         lock = true | ||||
|  | ||||
| @ -1,26 +0,0 @@ | ||||
| [Desktop Entry] | ||||
| Encoding=UTF-8 | ||||
| Name=Awesome Widget | ||||
| 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.awesomewidget | ||||
| 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/awesome-widget/package/metadata.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								sources/awesome-widget/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.awesomewidget", | ||||
|         "License": "GPLv3", | ||||
|         "Name": "Awesome Widget", | ||||
|         "Version": "4.0.1", | ||||
|         "Website": "https://arcanis.me/projects/awesome-widgets/" | ||||
|     }, | ||||
|     "X-Plasma-API-Minimum-Version": "6.0" | ||||
| } | ||||
| @ -7,17 +7,17 @@ include_directories( | ||||
|         ${CMAKE_CURRENT_SOURCE_DIR}/../../${PROJECT_LIBRARY}/ | ||||
|         ${PROJECT_TRDPARTY_DIR} | ||||
|         ${Qt_INCLUDE} | ||||
|         ${Kf5_INCLUDE} | ||||
|         ${Kf6_INCLUDE} | ||||
| ) | ||||
|  | ||||
| file(GLOB SUBPROJECT_SOURCE *.cpp ${PROJECT_TRDPARTY_DIR}/fontdialog/*.cpp ${CMAKE_SOURCE_DIR}/*.cpp) | ||||
| file(GLOB SUBPROJECT_SOURCE *.cpp formatters/*.cpp matchers/*.cpp ${PROJECT_TRDPARTY_DIR}/fontdialog/*.cpp ${CMAKE_SOURCE_DIR}/*.cpp) | ||||
| file(GLOB SUBPROJECT_UI *.ui) | ||||
| file(GLOB SUBPROJECT_NOTIFY *.notifyrc) | ||||
|  | ||||
| qt5_wrap_ui(SUBPROJECT_UI_HEADER ${SUBPROJECT_UI}) | ||||
| qt6_wrap_ui(SUBPROJECT_UI_HEADER ${SUBPROJECT_UI} OPTIONS --translate ui_i18n) | ||||
| add_library(${PLUGIN_NAME} SHARED ${SUBPROJECT_SOURCE} ${SUBPROJECT_UI_HEADER}) | ||||
| target_link_libraries(${PLUGIN_NAME} ${PROJECT_LIBRARY} ${Qt_LIBRARIES} ${Kf5_LIBRARIES}) | ||||
| target_link_libraries(${PLUGIN_NAME} ${PROJECT_LIBRARY} ${Qt_LIBRARIES} ${Kf6_LIBRARIES}) | ||||
|  | ||||
| install(TARGETS ${PLUGIN_NAME} DESTINATION ${QML_INSTALL_DIR}/org/kde/plasma/private/awesomewidget) | ||||
| install(FILES qmldir DESTINATION ${QML_INSTALL_DIR}/org/kde/plasma/private/awesomewidget) | ||||
| install(FILES ${SUBPROJECT_NOTIFY} DESTINATION ${KNOTIFYRC_INSTALL_DIR}) | ||||
| install(TARGETS ${PLUGIN_NAME} DESTINATION ${KDE_INSTALL_QMLDIR}/org/kde/plasma/private/awesomewidget) | ||||
| install(FILES qmldir DESTINATION ${KDE_INSTALL_QMLDIR}/org/kde/plasma/private/awesomewidget) | ||||
| install(FILES ${SUBPROJECT_NOTIFY} DESTINATION ${KDE_INSTALL_KNOTIFYRCDIR}) | ||||
|  | ||||
| @ -37,13 +37,13 @@ AWAbstractPairConfig::AWAbstractPairConfig(QWidget *_parent, const bool _hasEdit | ||||
|  | ||||
|     ui->setupUi(this); | ||||
|  | ||||
|     connect(ui->buttonBox, SIGNAL(accepted()), this, SLOT(accept())); | ||||
|     connect(ui->buttonBox, SIGNAL(rejected()), this, SLOT(reject())); | ||||
|     connect(ui->buttonBox, &QDialogButtonBox::accepted, this, &AWAbstractPairConfig::accept); | ||||
|     connect(ui->buttonBox, &QDialogButtonBox::rejected, this, &AWAbstractPairConfig::reject); | ||||
|  | ||||
|     // edit feature | ||||
|     if (m_hasEdit) { | ||||
|         m_editButton = ui->buttonBox->addButton(i18n("Edit"), QDialogButtonBox::ActionRole); | ||||
|         connect(m_editButton, SIGNAL(clicked(bool)), this, SLOT(edit())); | ||||
|         connect(m_editButton, &QPushButton::clicked, [this]() { return edit(); }); | ||||
|     } | ||||
| } | ||||
|  | ||||
| @ -58,6 +58,12 @@ AWAbstractPairConfig::~AWAbstractPairConfig() | ||||
| } | ||||
|  | ||||
|  | ||||
| void AWAbstractPairConfig::setHelper(std::unique_ptr<AWAbstractPairHelper> _helper) | ||||
| { | ||||
|     m_helper = std::move(_helper); | ||||
| } | ||||
|  | ||||
|  | ||||
| void AWAbstractPairConfig::showDialog() | ||||
| { | ||||
|     // update dialog | ||||
| @ -84,14 +90,14 @@ void AWAbstractPairConfig::edit() | ||||
|  | ||||
| void AWAbstractPairConfig::updateUi() | ||||
| { | ||||
|     QPair<QString, QString> current = dynamic_cast<AWAbstractSelector *>(sender())->current(); | ||||
|     int index = m_selectors.indexOf(dynamic_cast<AWAbstractSelector *>(sender())); | ||||
|     auto current = dynamic_cast<AWAbstractSelector *>(sender())->current(); | ||||
|     auto index = m_selectors.indexOf(dynamic_cast<AWAbstractSelector *>(sender())); | ||||
|  | ||||
|     if ((current.first.isEmpty()) && (current.second.isEmpty())) { | ||||
|         // remove current selector if it is empty and does not last | ||||
|         if (sender() == m_selectors.last()) | ||||
|             return; | ||||
|         AWAbstractSelector *selector = m_selectors.takeAt(index); | ||||
|         auto selector = m_selectors.takeAt(index); | ||||
|         ui->verticalLayout->removeWidget(selector); | ||||
|         selector->deleteLater(); | ||||
|     } else { | ||||
| @ -109,18 +115,18 @@ void AWAbstractPairConfig::addSelector(const QStringList &_keys, const QStringLi | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Add selector with keys" << _keys << "values" << _values << "and current ones" << _current; | ||||
|  | ||||
|     auto *selector = new AWAbstractSelector(ui->scrollAreaWidgetContents, m_editable); | ||||
|     auto selector = new AWAbstractSelector(ui->scrollAreaWidgetContents, m_editable); | ||||
|     selector->init(_keys, _values, _current); | ||||
|     ui->verticalLayout->insertWidget(ui->verticalLayout->count() - 1, selector); | ||||
|     connect(selector, SIGNAL(selectionChanged()), this, SLOT(updateUi())); | ||||
|     connect(selector, &AWAbstractSelector::selectionChanged, this, &AWAbstractPairConfig::updateUi); | ||||
|     m_selectors.append(selector); | ||||
| } | ||||
|  | ||||
|  | ||||
| void AWAbstractPairConfig::clearSelectors() | ||||
| { | ||||
|     for (auto &selector : m_selectors) { | ||||
|         disconnect(selector, SIGNAL(selectionChanged()), this, SLOT(updateUi())); | ||||
|     for (auto selector : m_selectors) { | ||||
|         disconnect(selector, &AWAbstractSelector::selectionChanged, this, &AWAbstractPairConfig::updateUi); | ||||
|         ui->verticalLayout->removeWidget(selector); | ||||
|         selector->deleteLater(); | ||||
|     } | ||||
| @ -130,10 +136,10 @@ void AWAbstractPairConfig::clearSelectors() | ||||
|  | ||||
| void AWAbstractPairConfig::execDialog() | ||||
| { | ||||
|     int ret = exec(); | ||||
|     auto ret = exec(); | ||||
|     QHash<QString, QString> data; | ||||
|     for (auto &selector : m_selectors) { | ||||
|         QPair<QString, QString> select = selector->current(); | ||||
|     for (auto selector : m_selectors) { | ||||
|         auto select = selector->current(); | ||||
|         if (select.first.isEmpty()) | ||||
|             continue; | ||||
|         data[select.first] = select.second; | ||||
| @ -160,11 +166,12 @@ QPair<QStringList, QStringList> AWAbstractPairConfig::initKeys() const | ||||
|     QStringList left = {""}; | ||||
|     left.append(m_helper->leftKeys().isEmpty() ? m_keys : m_helper->leftKeys()); | ||||
|     left.sort(); | ||||
|  | ||||
|     QStringList right = {""}; | ||||
|     right.append(m_helper->rightKeys().isEmpty() ? m_keys : m_helper->rightKeys()); | ||||
|     right.sort(); | ||||
|  | ||||
|     return QPair<QStringList, QStringList>(left, right); | ||||
|     return {left, right}; | ||||
| } | ||||
|  | ||||
|  | ||||
| @ -175,7 +182,7 @@ void AWAbstractPairConfig::updateDialog() | ||||
|     auto keys = initKeys(); | ||||
|  | ||||
|     for (auto &key : m_helper->keys()) | ||||
|         addSelector(keys.first, keys.second, QPair<QString, QString>(key, m_helper->pairs()[key])); | ||||
|         addSelector(keys.first, keys.second, {key, pairs[key]}); | ||||
|     // empty one | ||||
|     addSelector(keys.first, keys.second, QPair<QString, QString>()); | ||||
|     addSelector(keys.first, keys.second, {}); | ||||
| } | ||||
|  | ||||
| @ -15,9 +15,7 @@ | ||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||
|  ***************************************************************************/ | ||||
|  | ||||
|  | ||||
| #ifndef AWABSTRACTPAIRCONFIG_H | ||||
| #define AWABSTRACTPAIRCONFIG_H | ||||
| #pragma once | ||||
|  | ||||
| #include <QDialog> | ||||
|  | ||||
| @ -35,14 +33,9 @@ class AWAbstractPairConfig : public QDialog | ||||
|     Q_OBJECT | ||||
|  | ||||
| public: | ||||
|     explicit AWAbstractPairConfig(QWidget *_parent = nullptr, bool _hasEdit = false, QStringList _keys = QStringList()); | ||||
|     explicit AWAbstractPairConfig(QWidget *_parent = nullptr, bool _hasEdit = false, QStringList _keys = {}); | ||||
|     ~AWAbstractPairConfig() override; | ||||
|     template <class T> void initHelper() | ||||
|     { | ||||
|  | ||||
|         delete m_helper; | ||||
|         m_helper = new T(this); | ||||
|     } | ||||
|     void setHelper(std::unique_ptr<AWAbstractPairHelper> _helper); | ||||
|     void showDialog(); | ||||
|     // properties | ||||
|     void setEditable(bool _first, bool _second); | ||||
| @ -54,7 +47,7 @@ private slots: | ||||
| private: | ||||
|     QPushButton *m_editButton = nullptr; | ||||
|     Ui::AWAbstractPairConfig *ui = nullptr; | ||||
|     AWAbstractPairHelper *m_helper = nullptr; | ||||
|     std::unique_ptr<AWAbstractPairHelper> m_helper; | ||||
|     QList<AWAbstractSelector *> m_selectors; | ||||
|     // properties | ||||
|     QPair<bool, bool> m_editable = {false, false}; | ||||
| @ -67,6 +60,3 @@ private: | ||||
|     [[nodiscard]] QPair<QStringList, QStringList> initKeys() const; | ||||
|     void updateDialog(); | ||||
| }; | ||||
|  | ||||
|  | ||||
| #endif /* AWABSTRACTPAIRCONFIG_H */ | ||||
|  | ||||
| @ -34,12 +34,6 @@ AWAbstractPairHelper::AWAbstractPairHelper(QString _filePath, QString _section) | ||||
| } | ||||
|  | ||||
|  | ||||
| AWAbstractPairHelper::~AWAbstractPairHelper() | ||||
| { | ||||
|     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; | ||||
| } | ||||
|  | ||||
|  | ||||
| QStringList AWAbstractPairHelper::keys() const | ||||
| { | ||||
|     return m_pairs.keys(); | ||||
| @ -69,16 +63,16 @@ void AWAbstractPairHelper::initItems() | ||||
| { | ||||
|     m_pairs.clear(); | ||||
|  | ||||
|     QStringList configs = QStandardPaths::locateAll(QStandardPaths::GenericDataLocation, m_filePath); | ||||
|     auto configs = QStandardPaths::locateAll(QStandardPaths::GenericDataLocation, m_filePath); | ||||
|  | ||||
|     for (auto &fileName : configs) { | ||||
|         QSettings settings(fileName, QSettings::IniFormat); | ||||
|         qCInfo(LOG_AW) << "Configuration file" << settings.fileName(); | ||||
|  | ||||
|         settings.beginGroup(m_section); | ||||
|         QStringList keys = settings.childKeys(); | ||||
|         auto keys = settings.childKeys(); | ||||
|         for (auto &key : keys) { | ||||
|             QString value = settings.value(key).toString(); | ||||
|             auto value = settings.value(key).toString(); | ||||
|             qCInfo(LOG_AW) << "Found key" << key << "for value" << value << "in" << settings.fileName(); | ||||
|             if (value.isEmpty()) { | ||||
|                 qCInfo(LOG_AW) << "Skip empty value for" << key; | ||||
| @ -95,8 +89,8 @@ bool AWAbstractPairHelper::writeItems(const QHash<QString, QString> &_configurat | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Write configuration" << _configuration; | ||||
|  | ||||
|     QString fileName | ||||
|         = QString("%1/%2").arg(QStandardPaths::writableLocation(QStandardPaths::GenericDataLocation)).arg(m_filePath); | ||||
|     auto fileName | ||||
|         = QString("%1/%2").arg(QStandardPaths::writableLocation(QStandardPaths::GenericDataLocation), m_filePath); | ||||
|     QSettings settings(fileName, QSettings::IniFormat); | ||||
|     qCInfo(LOG_AW) << "Configuration file" << fileName; | ||||
|  | ||||
| @ -107,7 +101,7 @@ bool AWAbstractPairHelper::writeItems(const QHash<QString, QString> &_configurat | ||||
|  | ||||
|     settings.sync(); | ||||
|  | ||||
|     return (settings.status() == QSettings::NoError); | ||||
|     return settings.status() == QSettings::NoError; | ||||
| } | ||||
|  | ||||
|  | ||||
| @ -115,14 +109,13 @@ bool AWAbstractPairHelper::removeUnusedKeys(const QStringList &_keys) const | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Remove keys" << _keys; | ||||
|  | ||||
|     QString fileName | ||||
|         = QString("%1/%2").arg(QStandardPaths::writableLocation(QStandardPaths::GenericDataLocation)).arg(m_filePath); | ||||
|     auto fileName | ||||
|         = QString("%1/%2").arg(QStandardPaths::writableLocation(QStandardPaths::GenericDataLocation), m_filePath); | ||||
|     QSettings settings(fileName, QSettings::IniFormat); | ||||
|     qCInfo(LOG_AW) << "Configuration file" << fileName; | ||||
|  | ||||
|     settings.beginGroup(m_section); | ||||
|     QStringList foundKeys = settings.childKeys(); | ||||
|     for (auto &key : foundKeys) { | ||||
|     for (auto &key : settings.childKeys()) { | ||||
|         if (_keys.contains(key)) | ||||
|             continue; | ||||
|         settings.remove(key); | ||||
| @ -131,5 +124,5 @@ bool AWAbstractPairHelper::removeUnusedKeys(const QStringList &_keys) const | ||||
|  | ||||
|     settings.sync(); | ||||
|  | ||||
|     return (settings.status() == QSettings::NoError); | ||||
|     return settings.status() == QSettings::NoError; | ||||
| } | ||||
| @ -15,9 +15,7 @@ | ||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||
|  ***************************************************************************/ | ||||
|  | ||||
|  | ||||
| #ifndef AWABSTRACTPAIRHELPER_H | ||||
| #define AWABSTRACTPAIRHELPER_H | ||||
| #pragma once | ||||
|  | ||||
| #include <QHash> | ||||
|  | ||||
| @ -26,7 +24,7 @@ class AWAbstractPairHelper | ||||
| { | ||||
| public: | ||||
|     explicit AWAbstractPairHelper(QString _filePath = "", QString _section = ""); | ||||
|     virtual ~AWAbstractPairHelper(); | ||||
|     virtual ~AWAbstractPairHelper() = default; | ||||
|     [[nodiscard]] QStringList keys() const; | ||||
|     [[nodiscard]] QHash<QString, QString> pairs() const; | ||||
|     [[nodiscard]] QStringList values() const; | ||||
| @ -46,6 +44,3 @@ private: | ||||
|     QString m_filePath; | ||||
|     QString m_section; | ||||
| }; | ||||
|  | ||||
|  | ||||
| #endif /* AWABSTRACTPAIRHELPER_H */ | ||||
|  | ||||
| @ -31,8 +31,8 @@ AWAbstractSelector::AWAbstractSelector(QWidget *_parent, const QPair<bool, bool> | ||||
|     ui->comboBox_key->setEditable(_editable.first); | ||||
|     ui->comboBox_value->setEditable(_editable.second); | ||||
|  | ||||
|     connect(ui->comboBox_key, SIGNAL(currentIndexChanged(int)), this, SIGNAL(selectionChanged())); | ||||
|     connect(ui->comboBox_value, SIGNAL(currentIndexChanged(int)), this, SIGNAL(selectionChanged())); | ||||
|     connect(ui->comboBox_key, &QComboBox::currentIndexChanged, this, &AWAbstractSelector::selectionChanged); | ||||
|     connect(ui->comboBox_value, &QComboBox::currentIndexChanged, this, &AWAbstractSelector::selectionChanged); | ||||
| } | ||||
|  | ||||
|  | ||||
| @ -46,10 +46,10 @@ AWAbstractSelector::~AWAbstractSelector() | ||||
|  | ||||
| QPair<QString, QString> AWAbstractSelector::current() const | ||||
| { | ||||
|     QString key = ui->comboBox_key->currentText(); | ||||
|     QString value = ui->comboBox_value->currentText(); | ||||
|     auto key = ui->comboBox_key->currentText(); | ||||
|     auto value = ui->comboBox_value->currentText(); | ||||
|  | ||||
|     return QPair<QString, QString>(key, value); | ||||
|     return {key, value}; | ||||
| } | ||||
|  | ||||
|  | ||||
|  | ||||
| @ -15,9 +15,7 @@ | ||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||
|  ***************************************************************************/ | ||||
|  | ||||
|  | ||||
| #ifndef AWABSTRACTSELECTOR_H | ||||
| #define AWABSTRACTSELECTOR_H | ||||
| #pragma once | ||||
|  | ||||
| #include <QWidget> | ||||
|  | ||||
| @ -43,6 +41,3 @@ signals: | ||||
| private: | ||||
|     Ui::AWAbstractSelector *ui = nullptr; | ||||
| }; | ||||
|  | ||||
|  | ||||
| #endif /* AWABSTRACTSELECTOR_H */ | ||||
|  | ||||
| @ -40,12 +40,6 @@ AWActions::AWActions(QObject *_parent) | ||||
| } | ||||
|  | ||||
|  | ||||
| AWActions::~AWActions() | ||||
| { | ||||
|     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; | ||||
| } | ||||
|  | ||||
|  | ||||
| void AWActions::checkUpdates(const bool _showAnyway) | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Show anyway" << _showAnyway; | ||||
| @ -65,24 +59,17 @@ QString AWActions::getFileContent(const QString &_path) | ||||
|         return ""; | ||||
|     } | ||||
|  | ||||
|     QString output = inputFile.readAll(); | ||||
|     auto output = inputFile.readAll(); | ||||
|     inputFile.close(); | ||||
|     return output; | ||||
| } | ||||
|  | ||||
|  | ||||
| // HACK: since QML could not use QLoggingCategory I need this hack | ||||
| bool AWActions::isDebugEnabled() | ||||
| { | ||||
|     return LOG_AW().isDebugEnabled(); | ||||
| } | ||||
|  | ||||
|  | ||||
| bool AWActions::runCmd(const QString &_cmd, const QStringList &_args) | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Cmd" << _cmd << "args" << _args; | ||||
|  | ||||
|     sendNotification(QString("Info"), i18n("Run %1", _cmd)); | ||||
|     sendNotification("system", i18n("Run %1", _cmd)); | ||||
|  | ||||
|     return QProcess::startDetached(_cmd, _args); | ||||
| } | ||||
| @ -95,20 +82,6 @@ void AWActions::showReadme() | ||||
| } | ||||
|  | ||||
|  | ||||
| void AWActions::showLegacyInfo() | ||||
| { | ||||
|     auto *msgBox = new QMessageBox(nullptr); | ||||
|     msgBox->setAttribute(Qt::WA_DeleteOnClose); | ||||
|     msgBox->setModal(false); | ||||
|     msgBox->setWindowTitle(i18n("Not supported")); | ||||
|     msgBox->setText(i18n("You are using mammoth's Qt version, try to update it first")); | ||||
|     msgBox->setStandardButtons(QMessageBox::Ok); | ||||
|     msgBox->setIcon(QMessageBox::Information); | ||||
|  | ||||
|     msgBox->open(); | ||||
| } | ||||
|  | ||||
|  | ||||
| // HACK: this method uses variables from version.h | ||||
| QString AWActions::getAboutText(const QString &_type) | ||||
| { | ||||
| @ -123,10 +96,10 @@ QVariantMap AWActions::getFont(const QVariantMap &_defaultFont) | ||||
|     qCDebug(LOG_AW) << "Default font is" << _defaultFont; | ||||
|  | ||||
|     QVariantMap fontMap; | ||||
|     int ret = 0; | ||||
|     CFont defaultCFont = CFont(_defaultFont["family"].toString(), _defaultFont["size"].toInt(), 400, false, | ||||
|                                _defaultFont["color"].toString()); | ||||
|     CFont font = CFontDialog::getFont(i18n("Select font"), defaultCFont, false, false, &ret); | ||||
|     auto ret = 0; | ||||
|     auto defaultCFont = CFont(_defaultFont["family"].toString(), _defaultFont["size"].toInt(), 400, false, | ||||
|                               _defaultFont["color"].toString()); | ||||
|     auto font = CFontDialog::getFont(i18n("Select font"), defaultCFont, false, false, &ret); | ||||
|  | ||||
|     fontMap["applied"] = ret; | ||||
|     fontMap["color"] = font.color().name(); | ||||
| @ -142,7 +115,6 @@ void AWActions::sendNotification(const QString &_eventId, const QString &_messag | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Event" << _eventId << "with message" << _message; | ||||
|  | ||||
|     KNotification *notification | ||||
|         = KNotification::event(_eventId, QString("Awesome Widget ::: %1").arg(_eventId), _message); | ||||
|     notification->setComponentName("plasma-applet-org.kde.plasma.awesome-widget"); | ||||
|     auto event = KNotification::event(_eventId, QString("Awesome Widget ::: %1").arg(_eventId), _message); | ||||
|     event->setComponentName("plasma-applet-org.kde.plasma.awesome-widget"); | ||||
| } | ||||
|  | ||||
| @ -15,9 +15,7 @@ | ||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||
|  ***************************************************************************/ | ||||
|  | ||||
|  | ||||
| #ifndef AWACTIONS_H | ||||
| #define AWACTIONS_H | ||||
| #pragma once | ||||
|  | ||||
| #include <QMap> | ||||
| #include <QObject> | ||||
| @ -31,12 +29,10 @@ class AWActions : public QObject | ||||
|  | ||||
| public: | ||||
|     explicit AWActions(QObject *_parent = nullptr); | ||||
|     ~AWActions() override; | ||||
|     ~AWActions() override = default; | ||||
|     Q_INVOKABLE void checkUpdates(bool _showAnyway = false); | ||||
|     Q_INVOKABLE static QString getFileContent(const QString &_path); | ||||
|     Q_INVOKABLE static bool isDebugEnabled(); | ||||
|     Q_INVOKABLE static bool runCmd(const QString &_cmd, const QStringList &_args); | ||||
|     Q_INVOKABLE static void showLegacyInfo(); | ||||
|     Q_INVOKABLE static void showReadme(); | ||||
|     // configuration slots | ||||
|     Q_INVOKABLE static QString getAboutText(const QString &_type); | ||||
| @ -48,6 +44,3 @@ public slots: | ||||
| private: | ||||
|     AWUpdateHelper *m_updateHelper = nullptr; | ||||
| }; | ||||
|  | ||||
|  | ||||
| #endif /* AWACTIONS_H */ | ||||
|  | ||||
| @ -18,6 +18,7 @@ | ||||
| #include "awbugreporter.h" | ||||
|  | ||||
| #include <KI18n/KLocalizedString> | ||||
| #include <KNotifications/KNotification> | ||||
|  | ||||
| #include <QDesktopServices> | ||||
| #include <QJsonDocument> | ||||
| @ -32,19 +33,24 @@ AWBugReporter::AWBugReporter(QObject *_parent) | ||||
|     : QObject(_parent) | ||||
| { | ||||
|     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; | ||||
|  | ||||
|     m_manager = new QNetworkAccessManager(nullptr); | ||||
|     connect(m_manager, &QNetworkAccessManager::finished, this, &AWBugReporter::issueReplyReceived); | ||||
| } | ||||
|  | ||||
|  | ||||
| AWBugReporter::~AWBugReporter() | ||||
| { | ||||
|     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; | ||||
|  | ||||
|     m_manager->deleteLater(); | ||||
| } | ||||
|  | ||||
|  | ||||
| void AWBugReporter::doConnect() | ||||
| void AWBugReporter::doConnect() const | ||||
| { | ||||
|     // additional method for testing needs | ||||
|     connect(this, SIGNAL(replyReceived(const int, const QString &)), this, SLOT(showInformation(int, const QString &))); | ||||
|     connect(this, &AWBugReporter::replyReceived, this, &AWBugReporter::showInformation); | ||||
| } | ||||
|  | ||||
|  | ||||
| @ -71,26 +77,24 @@ void AWBugReporter::sendBugReport(const QString &_title, const QString &_body) | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Send bug report with title" << _title << "and body" << _body; | ||||
|  | ||||
|     auto *manager = new QNetworkAccessManager(nullptr); | ||||
|     connect(manager, SIGNAL(finished(QNetworkReply *)), this, SLOT(issueReplyRecieved(QNetworkReply *))); | ||||
|  | ||||
|     QNetworkRequest request = QNetworkRequest(QUrl(BUGTRACKER_API)); | ||||
|     auto request = QNetworkRequest(QUrl(BUGTRACKER_API)); | ||||
|     request.setHeader(QNetworkRequest::ContentTypeHeader, "application/json"); | ||||
|  | ||||
|     // generate payload | ||||
|     QVariantMap payload; | ||||
|     payload["title"] = _title; | ||||
|     payload["body"] = _body; | ||||
|     payload["labels"] = QStringList() << "from application"; | ||||
|     payload["labels"] = QStringList({"from application"}); | ||||
|     // convert to QByteArray to send request | ||||
|     QByteArray data = QJsonDocument::fromVariant(payload).toJson(QJsonDocument::Compact); | ||||
|     auto data = QJsonDocument::fromVariant(payload).toJson(QJsonDocument::Compact); | ||||
|     qCInfo(LOG_AW) << "Send request with _body" << data.data() << "and size" << data.size(); | ||||
|  | ||||
|     manager->post(request, data); | ||||
|     m_manager->post(request, data); | ||||
| } | ||||
|  | ||||
|  | ||||
| void AWBugReporter::issueReplyRecieved(QNetworkReply *_reply) | ||||
| void AWBugReporter::issueReplyReceived(QNetworkReply *_reply) | ||||
| { | ||||
|     if (_reply->error() != QNetworkReply::NoError) { | ||||
|         qCWarning(LOG_AW) << "An error occurs" << _reply->error() << "with message" << _reply->errorString(); | ||||
| @ -98,7 +102,7 @@ void AWBugReporter::issueReplyRecieved(QNetworkReply *_reply) | ||||
|     } | ||||
|  | ||||
|     QJsonParseError error{}; | ||||
|     QJsonDocument jsonDoc = QJsonDocument::fromJson(_reply->readAll(), &error); | ||||
|     auto jsonDoc = QJsonDocument::fromJson(_reply->readAll(), &error); | ||||
|     if (error.error != QJsonParseError::NoError) { | ||||
|         qCWarning(LOG_AW) << "Parse error" << error.errorString(); | ||||
|         return emit(replyReceived(0, "")); | ||||
| @ -106,14 +110,20 @@ void AWBugReporter::issueReplyRecieved(QNetworkReply *_reply) | ||||
|     _reply->deleteLater(); | ||||
|  | ||||
|     // convert to map | ||||
|     QVariantMap response = jsonDoc.toVariant().toMap(); | ||||
|     QString url = response["html_url"].toString(); | ||||
|     int number = response["number"].toInt(); | ||||
|     auto response = jsonDoc.toVariant().toMap(); | ||||
|     auto url = response["html_url"].toString(); | ||||
|     auto number = response["number"].toInt(); | ||||
|  | ||||
|     return emit(replyReceived(number, url)); | ||||
| } | ||||
|  | ||||
|  | ||||
| void AWBugReporter::openBugReport() | ||||
| { | ||||
|     QDesktopServices::openUrl(m_lastBugUrl); | ||||
| } | ||||
|  | ||||
|  | ||||
| void AWBugReporter::showInformation(const int _number, const QString &_url) | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Created issue with number" << _number << "and url" << _url; | ||||
| @ -121,29 +131,9 @@ void AWBugReporter::showInformation(const int _number, const QString &_url) | ||||
|     // cache url first | ||||
|     m_lastBugUrl = _url; | ||||
|  | ||||
|     auto *msgBox = new QMessageBox(nullptr); | ||||
|     msgBox->setAttribute(Qt::WA_DeleteOnClose); | ||||
|     msgBox->setModal(false); | ||||
|     msgBox->setWindowTitle(i18n("Issue created")); | ||||
|     msgBox->setText(i18n("Issue %1 has been created", _number)); | ||||
|     msgBox->setStandardButtons(QMessageBox::Open | QMessageBox::Close); | ||||
|     msgBox->setIcon(QMessageBox::Information); | ||||
|     auto event = KNotification::event("system", i18n("Issue created"), i18n("Issue %1 has been created", _number)); | ||||
|     event->setComponentName("plasma-applet-org.kde.plasma.awesome-widget"); | ||||
|  | ||||
|     msgBox->open(this, SLOT(userReplyOnBugReport(QAbstractButton *))); | ||||
| } | ||||
|  | ||||
|  | ||||
| void AWBugReporter::userReplyOnBugReport(QAbstractButton *_button) | ||||
| { | ||||
|     QMessageBox::ButtonRole ret = dynamic_cast<QMessageBox *>(sender())->buttonRole(_button); | ||||
|     qCInfo(LOG_AW) << "User select" << ret; | ||||
|  | ||||
|     switch (ret) { | ||||
|     case QMessageBox::AcceptRole: | ||||
|         QDesktopServices::openUrl(m_lastBugUrl); | ||||
|         break; | ||||
|     case QMessageBox::RejectRole: | ||||
|     default: | ||||
|         break; | ||||
|     } | ||||
|     auto action = event->addAction(i18n("Details")); | ||||
|     connect(action, &KNotificationAction::activated, this, &AWBugReporter::openBugReport); | ||||
| } | ||||
|  | ||||
| @ -15,24 +15,22 @@ | ||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||
|  ***************************************************************************/ | ||||
|  | ||||
|  | ||||
| #ifndef AWBUGREPORTER_H | ||||
| #define AWBUGREPORTER_H | ||||
| #pragma once | ||||
|  | ||||
| #include <QObject> | ||||
|  | ||||
|  | ||||
| class QAbstractButton; | ||||
| class QNetworkAccessManager; | ||||
| class QNetworkReply; | ||||
|  | ||||
| class AWBugReporter : public QObject | ||||
| class __attribute__((visibility("default"))) AWBugReporter : public QObject | ||||
| { | ||||
|     Q_OBJECT | ||||
|  | ||||
| public: | ||||
|     explicit AWBugReporter(QObject *_parent = nullptr); | ||||
|     ~AWBugReporter() override; | ||||
|     Q_INVOKABLE void doConnect(); | ||||
|     Q_INVOKABLE void doConnect() const; | ||||
|     Q_INVOKABLE static QString generateText(const QString &_description, const QString &_reproduce, | ||||
|                                             const QString &_expected, const QString &_logs); | ||||
|     Q_INVOKABLE void sendBugReport(const QString &_title, const QString &_body); | ||||
| @ -41,13 +39,11 @@ signals: | ||||
|     void replyReceived(int _number, const QString &_url); | ||||
|  | ||||
| private slots: | ||||
|     void issueReplyRecieved(QNetworkReply *_reply); | ||||
|     void issueReplyReceived(QNetworkReply *_reply); | ||||
|     void openBugReport(); | ||||
|     void showInformation(int _number, const QString &_url); | ||||
|     void userReplyOnBugReport(QAbstractButton *_button); | ||||
|  | ||||
| private: | ||||
|     QString m_lastBugUrl; | ||||
|     QNetworkAccessManager *m_manager = nullptr; | ||||
| }; | ||||
|  | ||||
|  | ||||
| #endif /* AWBUGREPORTER_H */ | ||||
|  | ||||
| @ -21,7 +21,6 @@ | ||||
| #include <QQmlPropertyMap> | ||||
| #include <QSettings> | ||||
| #include <QStandardPaths> | ||||
| #include <QTextCodec> | ||||
|  | ||||
| #include "awdebug.h" | ||||
|  | ||||
| @ -35,17 +34,11 @@ AWConfigHelper::AWConfigHelper(QObject *_parent) | ||||
| } | ||||
|  | ||||
|  | ||||
| AWConfigHelper::~AWConfigHelper() | ||||
| { | ||||
|     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; | ||||
| } | ||||
|  | ||||
|  | ||||
| QString AWConfigHelper::configurationDirectory() | ||||
| { | ||||
|     // get readable directory | ||||
|     QString localDir = QString("%1/awesomewidgets/configs") | ||||
|                            .arg(QStandardPaths::writableLocation(QStandardPaths::GenericDataLocation)); | ||||
|     auto localDir = QString("%1/awesomewidgets/configs") | ||||
|                         .arg(QStandardPaths::writableLocation(QStandardPaths::GenericDataLocation)); | ||||
|  | ||||
|     // create directory and copy files from default settings | ||||
|     QDir localDirectory; | ||||
| @ -60,7 +53,7 @@ QString AWConfigHelper::configurationDirectory() | ||||
|  | ||||
| bool AWConfigHelper::dropCache() | ||||
| { | ||||
|     QString fileName | ||||
|     auto fileName | ||||
|         = QString("%1/awesomewidgets.ndx").arg(QStandardPaths::writableLocation(QStandardPaths::GenericCacheLocation)); | ||||
|  | ||||
|     return QFile(fileName).remove(); | ||||
| @ -73,10 +66,10 @@ bool AWConfigHelper::exportConfiguration(QObject *_nativeConfig, const QString & | ||||
|  | ||||
|     QSettings settings(_fileName, QSettings::IniFormat); | ||||
|     // plasmoid configuration | ||||
|     const auto *configuration = dynamic_cast<const QQmlPropertyMap *>(_nativeConfig); | ||||
|     auto configuration = dynamic_cast<const QQmlPropertyMap *>(_nativeConfig); | ||||
|     settings.beginGroup("plasmoid"); | ||||
|     for (auto &key : configuration->keys()) { | ||||
|         QVariant value = configuration->value(key); | ||||
|         auto value = configuration->value(key); | ||||
|         if (!value.isValid()) | ||||
|             continue; | ||||
|         settings.setValue(key, value); | ||||
| @ -85,8 +78,7 @@ bool AWConfigHelper::exportConfiguration(QObject *_nativeConfig, const QString & | ||||
|  | ||||
|     // extensions | ||||
|     for (auto &item : m_dirs) { | ||||
|         QStringList items | ||||
|             = QDir(QString("%1/%2").arg(m_baseDir).arg(item)).entryList(QStringList() << "*.desktop", QDir::Files); | ||||
|         auto items = QDir(QString("%1/%2").arg(m_baseDir, item)).entryList({"*.desktop"}, QDir::Files); | ||||
|         settings.beginGroup(item); | ||||
|         for (auto &it : items) | ||||
|             copyExtensions(it, item, settings, false); | ||||
| @ -164,16 +156,13 @@ QVariantMap AWConfigHelper::importConfiguration(const QString &_fileName, const | ||||
|  | ||||
| QVariantMap AWConfigHelper::readDataEngineConfiguration() | ||||
| { | ||||
|     QString fileName = QStandardPaths::locate(QStandardPaths::ConfigLocation, "plasma-dataengine-extsysmon.conf"); | ||||
|     auto fileName = QStandardPaths::locate(QStandardPaths::ConfigLocation, "plasma-dataengine-extsysmon.conf"); | ||||
|     qCInfo(LOG_AW) << "Configuration file" << fileName; | ||||
|     QSettings settings(fileName, QSettings::IniFormat); | ||||
|     QVariantMap configuration; | ||||
|  | ||||
|     settings.beginGroup("Configuration"); | ||||
|     configuration["ACPIPATH"] = settings.value("ACPIPATH", "/sys/class/power_supply/"); | ||||
|     configuration["GPUDEV"] = settings.value("GPUDEV", "auto"); | ||||
|     configuration["HDDDEV"] = settings.value("HDDDEV", "all"); | ||||
|     configuration["HDDTEMPCMD"] = settings.value("HDDTEMPCMD", "sudo smartctl -a"); | ||||
|     configuration["MPDADDRESS"] = settings.value("MPDADDRESS", "localhost"); | ||||
|     configuration["MPDPORT"] = settings.value("MPDPORT", "6600"); | ||||
|     configuration["MPRIS"] = settings.value("MPRIS", "auto"); | ||||
| @ -191,16 +180,13 @@ bool AWConfigHelper::writeDataEngineConfiguration(const QVariantMap &_configurat | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Configuration" << _configuration; | ||||
|  | ||||
|     QString fileName = QString("%1/plasma-dataengine-extsysmon.conf") | ||||
|                            .arg(QStandardPaths::writableLocation(QStandardPaths::ConfigLocation)); | ||||
|     auto fileName = QString("%1/plasma-dataengine-extsysmon.conf") | ||||
|                         .arg(QStandardPaths::writableLocation(QStandardPaths::ConfigLocation)); | ||||
|     QSettings settings(fileName, QSettings::IniFormat); | ||||
|     qCInfo(LOG_AW) << "Configuration file" << settings.fileName(); | ||||
|  | ||||
|     settings.beginGroup("Configuration"); | ||||
|     settings.setValue("ACPIPATH", _configuration["ACPIPATH"]); | ||||
|     settings.setValue("GPUDEV", _configuration["GPUDEV"]); | ||||
|     settings.setValue("HDDDEV", _configuration["HDDDEV"]); | ||||
|     settings.setValue("HDDTEMPCMD", _configuration["HDDTEMPCMD"]); | ||||
|     settings.setValue("MPDADDRESS", _configuration["MPDADDRESS"]); | ||||
|     settings.setValue("MPDPORT", _configuration["MPDPORT"]); | ||||
|     settings.setValue("MPRIS", _configuration["MPRIS"]); | ||||
| @ -218,15 +204,15 @@ void AWConfigHelper::copyConfigs(const QString &_localDir) | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Local directory" << _localDir; | ||||
|  | ||||
|     QStringList dirs = QStandardPaths::locateAll(QStandardPaths::GenericDataLocation, "awesomewidgets/configs", | ||||
|                                                  QStandardPaths::LocateDirectory); | ||||
|     auto dirs = QStandardPaths::locateAll(QStandardPaths::GenericDataLocation, "awesomewidgets/configs", | ||||
|                                           QStandardPaths::LocateDirectory); | ||||
|     for (auto &dir : dirs) { | ||||
|         if (dir == _localDir) | ||||
|             continue; | ||||
|         QStringList files = QDir(dir).entryList(QDir::Files); | ||||
|         auto files = QDir(dir).entryList(QDir::Files); | ||||
|         for (auto &source : files) { | ||||
|             QString destination = QString("%1/%2").arg(_localDir).arg(source); | ||||
|             bool status = QFile::copy(QString("%1/%2").arg(dir).arg(source), destination); | ||||
|             auto destination = QString("%1/%2").arg(_localDir, source); | ||||
|             auto status = QFile::copy(QString("%1/%2").arg(dir, source), destination); | ||||
|             qCInfo(LOG_AW) << "File" << source << "has been copied to" << destination << "with status" << status; | ||||
|         } | ||||
|     } | ||||
| @ -239,7 +225,7 @@ void AWConfigHelper::copyExtensions(const QString &_item, const QString &_type, | ||||
|     qCDebug(LOG_AW) << "Extension" << _item << "has type" << _type << "inverse copying" << _inverse; | ||||
|  | ||||
|     _settings.beginGroup(_item); | ||||
|     QSettings itemSettings(QString("%1/%2/%3").arg(m_baseDir).arg(_type).arg(_item), QSettings::IniFormat); | ||||
|     QSettings itemSettings(QString("%1/%2/%3").arg(m_baseDir, _type, _item), QSettings::IniFormat); | ||||
|     itemSettings.beginGroup("Desktop Entry"); | ||||
|     if (_inverse) | ||||
|         copySettings(_settings, itemSettings); | ||||
| @ -266,7 +252,7 @@ void AWConfigHelper::readFile(QSettings &_settings, const QString &_key, const Q | ||||
|  | ||||
|     QFile file(_fileName); | ||||
|     if (file.open(QIODevice::ReadOnly | QIODevice::Text)) { | ||||
|         QString text = QString::fromUtf8(file.readAll()); | ||||
|         auto text = QString::fromUtf8(file.readAll()); | ||||
|         file.close(); | ||||
|         _settings.setValue(_key, text); | ||||
|     } else { | ||||
| @ -285,7 +271,6 @@ void AWConfigHelper::writeFile(QSettings &_settings, const QString &_key, const | ||||
|     QFile file(_fileName); | ||||
|     if (file.open(QIODevice::WriteOnly | QIODevice::Text)) { | ||||
|         QTextStream out(&file); | ||||
|         out.setCodec("UTF-8"); | ||||
|         out << _settings.value(_key).toString().toUtf8(); | ||||
|         out.flush(); | ||||
|         file.close(); | ||||
|  | ||||
| @ -15,9 +15,7 @@ | ||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||
|  ***************************************************************************/ | ||||
|  | ||||
|  | ||||
| #ifndef AWCONFIGHELPER_H | ||||
| #define AWCONFIGHELPER_H | ||||
| #pragma once | ||||
|  | ||||
| #include <QObject> | ||||
| #include <QVariant> | ||||
| @ -25,13 +23,13 @@ | ||||
|  | ||||
| class QSettings; | ||||
|  | ||||
| class AWConfigHelper : public QObject | ||||
| class __attribute__((visibility("default"))) AWConfigHelper : public QObject | ||||
| { | ||||
|     Q_OBJECT | ||||
|  | ||||
| public: | ||||
|     explicit AWConfigHelper(QObject *_parent = nullptr); | ||||
|     ~AWConfigHelper() override; | ||||
|     ~AWConfigHelper() override = default; | ||||
|     Q_INVOKABLE [[nodiscard]] static QString configurationDirectory(); | ||||
|     Q_INVOKABLE static bool dropCache(); | ||||
|     Q_INVOKABLE bool exportConfiguration(QObject *_nativeConfig, const QString &_fileName) const; | ||||
| @ -52,6 +50,3 @@ private: | ||||
|     QString m_baseDir; | ||||
|     QStringList m_dirs = {"desktops", "quotes", "scripts", "upgrade", "weather", "formatters"}; | ||||
| }; | ||||
|  | ||||
|  | ||||
| #endif /* AWCONFIGHELPER_H */ | ||||
|  | ||||
| @ -27,11 +27,5 @@ AWCustomKeysConfig::AWCustomKeysConfig(QWidget *_parent, const QStringList &_key | ||||
|     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; | ||||
|  | ||||
|     setEditable(true, false); | ||||
|     initHelper<AWCustomKeysHelper>(); | ||||
| } | ||||
|  | ||||
|  | ||||
| AWCustomKeysConfig::~AWCustomKeysConfig() | ||||
| { | ||||
|     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; | ||||
|     setHelper(std::make_unique<AWCustomKeysHelper>()); | ||||
| } | ||||
|  | ||||
| @ -15,9 +15,7 @@ | ||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||
|  ***************************************************************************/ | ||||
|  | ||||
|  | ||||
| #ifndef AWCUSTOMKEYSCONFIG_H | ||||
| #define AWCUSTOMKEYSCONFIG_H | ||||
| #pragma once | ||||
|  | ||||
| #include "awabstractpairconfig.h" | ||||
|  | ||||
| @ -28,8 +26,5 @@ class AWCustomKeysConfig : public AWAbstractPairConfig | ||||
|  | ||||
| public: | ||||
|     explicit AWCustomKeysConfig(QWidget *_parent = nullptr, const QStringList &_keys = QStringList()); | ||||
|     ~AWCustomKeysConfig() override; | ||||
|     ~AWCustomKeysConfig() override = default; | ||||
| }; | ||||
|  | ||||
|  | ||||
| #endif /* AWCUSTOMKEYSCONFIG_H */ | ||||
|  | ||||
| @ -30,12 +30,6 @@ AWCustomKeysHelper::AWCustomKeysHelper(QObject *_parent) | ||||
| } | ||||
|  | ||||
|  | ||||
| AWCustomKeysHelper::~AWCustomKeysHelper() | ||||
| { | ||||
|     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; | ||||
| } | ||||
|  | ||||
|  | ||||
| QString AWCustomKeysHelper::source(const QString &_key) const | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Get source by key" << _key; | ||||
|  | ||||
| @ -15,9 +15,7 @@ | ||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||
|  ***************************************************************************/ | ||||
|  | ||||
|  | ||||
| #ifndef AWCUSTOMKEYSHELPER_H | ||||
| #define AWCUSTOMKEYSHELPER_H | ||||
| #pragma once | ||||
|  | ||||
| #include <QObject> | ||||
|  | ||||
| @ -30,7 +28,7 @@ class AWCustomKeysHelper : public QObject, public AWAbstractPairHelper | ||||
|  | ||||
| public: | ||||
|     explicit AWCustomKeysHelper(QObject *_parent = nullptr); | ||||
|     ~AWCustomKeysHelper() override; | ||||
|     ~AWCustomKeysHelper() override = default; | ||||
|     // get | ||||
|     [[nodiscard]] QString source(const QString &_key) const; | ||||
|     [[nodiscard]] QStringList sources() const; | ||||
| @ -39,9 +37,4 @@ public: | ||||
|     void editPairs() override{}; | ||||
|     QStringList leftKeys() override; | ||||
|     QStringList rightKeys() override; | ||||
|  | ||||
| private: | ||||
| }; | ||||
|  | ||||
|  | ||||
| #endif /* AWCUSTOMKEYSHELPER_H */ | ||||
|  | ||||
| @ -50,7 +50,8 @@ AWDataAggregator::~AWDataAggregator() | ||||
| { | ||||
|     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; | ||||
|  | ||||
|     delete m_toolTipScene; | ||||
|     m_toolTipView->deleteLater(); | ||||
|     m_toolTipScene->deleteLater(); | ||||
| } | ||||
|  | ||||
|  | ||||
| @ -84,26 +85,26 @@ void AWDataAggregator::setParameters(const QVariantMap &_settings) | ||||
|     // resize tooltip image | ||||
|     m_toolTipView->resize(100 * m_counts, 105); | ||||
|  | ||||
|     requiredKeys.clear(); | ||||
|     m_requiredKeys.clear(); | ||||
|     if (m_configuration["cpuTooltip"].toBool()) | ||||
|         requiredKeys.append("cpuTooltip"); | ||||
|         m_requiredKeys.append("cpuTooltip"); | ||||
|     if (m_configuration["cpuclTooltip"].toBool()) | ||||
|         requiredKeys.append("cpuclTooltip"); | ||||
|         m_requiredKeys.append("cpuclTooltip"); | ||||
|     if (m_configuration["memTooltip"].toBool()) | ||||
|         requiredKeys.append("memTooltip"); | ||||
|         m_requiredKeys.append("memTooltip"); | ||||
|     if (m_configuration["swapTooltip"].toBool()) | ||||
|         requiredKeys.append("swapTooltip"); | ||||
|         m_requiredKeys.append("swapTooltip"); | ||||
|     if (m_configuration["downkbTooltip"].toBool()) | ||||
|         requiredKeys.append("downkbTooltip"); | ||||
|         m_requiredKeys.append("downkbTooltip"); | ||||
|     if (m_configuration["upkbTooltip"].toBool()) | ||||
|         requiredKeys.append("upkbTooltip"); | ||||
|         m_requiredKeys.append("upkbTooltip"); | ||||
|     if (m_configuration["batTooltip"].toBool()) | ||||
|         requiredKeys.append("batTooltip"); | ||||
|         m_requiredKeys.append("batTooltip"); | ||||
|  | ||||
|     // background | ||||
|     m_toolTipScene->setBackgroundBrush(m_configuration["useTooltipBackground"].toBool() | ||||
|                                            ? QBrush(QColor(m_configuration["tooltipBackground"].toString())) | ||||
|                                            : QBrush(Qt::NoBrush)); | ||||
|                                            ? QColor(m_configuration["tooltipBackground"].toString()) | ||||
|                                            : Qt::NoBrush); | ||||
| } | ||||
|  | ||||
|  | ||||
| @ -112,34 +113,42 @@ QPixmap AWDataAggregator::tooltipImage() | ||||
|     // create image | ||||
|     m_toolTipScene->clear(); | ||||
|     QPen pen; | ||||
|     bool down = false; | ||||
|     for (auto &key : requiredKeys) { | ||||
|     auto shift = 0.0; | ||||
|  | ||||
|     for (auto i = 0; i < m_requiredKeys.count(); ++i) { | ||||
|         auto key = m_requiredKeys[i]; | ||||
|  | ||||
|         // create frame | ||||
|         float normX = 100.0f / static_cast<float>(m_values[key].count()); | ||||
|         float normY = 100.0f / (1.5f * m_boundaries[key]); | ||||
|         float shift = static_cast<float>(requiredKeys.indexOf(key)) * 100.0f; | ||||
|         if (down) | ||||
|             shift -= 100.0; | ||||
|         auto normX = 100.0 / static_cast<float>(m_values[key].count()); | ||||
|         auto normY = 100.0 / (1.5 * m_boundaries[key]); | ||||
|  | ||||
|         // apply pen color | ||||
|         if (key != "batTooltip") | ||||
|             pen.setColor(QColor(m_configuration[QString("%1Color").arg(key)].toString())); | ||||
|             pen.setColor(m_configuration[QString("%1Color").arg(key)].toString()); | ||||
|  | ||||
|         // paint data inside frame | ||||
|         for (int j = 0; j < m_values[key].count() - 1; j++) { | ||||
|             // some magic here | ||||
|             float x1 = j * normX + shift; | ||||
|             float y1 = -std::fabs(m_values[key].at(j)) * normY + 5.0f; | ||||
|             float x2 = (j + 1) * normX + shift; | ||||
|             float y2 = -std::fabs(m_values[key].at(j + 1)) * normY + 5.0f; | ||||
|             auto x1 = j * normX + shift; | ||||
|             auto y1 = -std::fabs(m_values[key].at(j)) * normY + 5.0; | ||||
|             auto x2 = (j + 1) * normX + shift; | ||||
|             auto y2 = -std::fabs(m_values[key].at(j + 1)) * normY + 5.0; | ||||
|             // apply color for the battery tooltip based on charge/discharge | ||||
|             if (key == "batTooltip") { | ||||
|                 if (m_values[key].at(j + 1) > 0) | ||||
|                     pen.setColor(QColor(m_configuration["batTooltipColor"].toString())); | ||||
|                 else | ||||
|                     pen.setColor(QColor(m_configuration["batInTooltipColor"].toString())); | ||||
|             } | ||||
|  | ||||
|             m_toolTipScene->addLine(x1, y1, x2, y2, pen); | ||||
|         } | ||||
|         if (key == "downkbTooltip") | ||||
|             down = true; | ||||
|  | ||||
|         // increase frame shift if not downkbtooltip | ||||
|         // Additional workaround is required because there is frame (uokb and downkb) which contains two charts | ||||
|         // with the same shift | ||||
|         if (key != "downkbTooltip") | ||||
|             shift += 100.0; | ||||
|     } | ||||
|  | ||||
|     return m_toolTipView->grab(); | ||||
| @ -154,7 +163,7 @@ void AWDataAggregator::dataUpdate(const QVariantHash &_values) | ||||
| } | ||||
|  | ||||
|  | ||||
| void AWDataAggregator::checkValue(const QString &_source, const float _value, const float _extremum) const | ||||
| void AWDataAggregator::checkValue(const QString &_source, const double _value, const double _extremum) const | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Notification source" << _source << "with value" << _value << "called with extremum" | ||||
|                     << _extremum; | ||||
| @ -227,25 +236,27 @@ void AWDataAggregator::setData(const QVariantHash &_values) | ||||
| { | ||||
|     // do not log these arguments | ||||
|     // battery update requires info is AC online or not | ||||
|     setData(_values["ac"].toString() == m_configuration["acOnline"], "batTooltip", _values["bat"].toFloat()); | ||||
|     setData(_values["ac"].toString() == m_configuration["acOnline"], "batTooltip", _values["bat"].toDouble()); | ||||
|  | ||||
|     // usual case | ||||
|     setData("cpuTooltip", _values["cpu"].toFloat(), 90.0); | ||||
|     setData("cpuclTooltip", _values["cpucl"].toFloat()); | ||||
|     setData("memTooltip", _values["mem"].toFloat(), 80.0); | ||||
|     setData("swapTooltip", _values["swap"].toFloat(), 0.0); | ||||
|     setData("downkbTooltip", _values["downkb"].toFloat()); | ||||
|     setData("upkbTooltip", _values["upkb"].toFloat()); | ||||
|     setData("cpuTooltip", _values["cpu"].toDouble(), 90.0); | ||||
|     setData("cpuclTooltip", _values["cpucl"].toDouble()); | ||||
|     setData("memTooltip", _values["mem"].toDouble(), 80.0); | ||||
|     setData("swapTooltip", _values["swap"].toDouble(), 0.0); | ||||
|     setData("downkbTooltip", _values["downkb"].toDouble()); | ||||
|     setData("upkbTooltip", _values["upkb"].toDouble()); | ||||
|  | ||||
|     // additional check for network device | ||||
|     [this](const QString &value) { | ||||
|         checkValue("netdev", m_currentNetworkDevice, value); | ||||
|         m_currentNetworkDevice = value; | ||||
|     }(_values["netdev"].toString()); | ||||
|     auto currentNetworkDevice = _values["netdev"].toString(); | ||||
|     checkValue("netdev", m_currentNetworkDevice, currentNetworkDevice); | ||||
|     m_currentNetworkDevice = currentNetworkDevice; | ||||
|  | ||||
|     // additional check for GPU load | ||||
|     [this](const float value) { checkValue("gpu", value, 90.0); }(_values["gpu"].toFloat()); | ||||
|     checkValue("gpu", _values["gpu"].toDouble(), 90.0); | ||||
| } | ||||
|  | ||||
|  | ||||
| void AWDataAggregator::setData(const QString &_source, float _value, const float _extremum) | ||||
| void AWDataAggregator::setData(const QString &_source, double _value, const double _extremum) | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Source" << _source << "to value" << _value << "with extremum" << _extremum; | ||||
|  | ||||
| @ -261,16 +272,20 @@ void AWDataAggregator::setData(const QString &_source, float _value, const float | ||||
|  | ||||
|     m_values[_source].append(_value); | ||||
|     if (_source == "downkbTooltip") { | ||||
|         QList<float> netValues = m_values["downkbTooltip"] + m_values["upkbTooltip"]; | ||||
|         // to avoid inf value of normY | ||||
|         netValues << 1.0; | ||||
|         m_boundaries["downkbTooltip"] = 1.2f * *std::max_element(netValues.cbegin(), netValues.cend()); | ||||
|         m_boundaries["upkbTooltip"] = m_boundaries["downkbTooltip"]; | ||||
|         // to avoid copying of objects to another list we find max elements in each sequence and compare them | ||||
|         auto downMax = m_values["downkbTooltip"].empty() | ||||
|                            ? 1.0 | ||||
|                            : *std::max_element(m_values["downkbTooltip"].cbegin(), m_values["downkbTooltip"].cend()); | ||||
|         auto upMax = m_values["upkbTooltip"].empty() | ||||
|                          ? 1.0 | ||||
|                          : *std::max_element(m_values["upkbTooltip"].cbegin(), m_values["upkbTooltip"].cend()); | ||||
|         // assign both | ||||
|         m_boundaries["upkbTooltip"] = m_boundaries["downkbTooltip"] = 1.2 * std::max(downMax, upMax); | ||||
|     } | ||||
| } | ||||
|  | ||||
|  | ||||
| void AWDataAggregator::setData(const bool _dontInvert, const QString &_source, float _value) | ||||
| void AWDataAggregator::setData(const bool _dontInvert, const QString &_source, double _value) | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Do not invert" << _dontInvert << "value" << _value << "for source" << _source; | ||||
|  | ||||
|  | ||||
| @ -15,18 +15,14 @@ | ||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||
|  ***************************************************************************/ | ||||
|  | ||||
| #pragma once | ||||
|  | ||||
| #ifndef AWTOOLTIP_H | ||||
| #define AWTOOLTIP_H | ||||
|  | ||||
| #include <QObject> | ||||
| #include <QVariant> | ||||
|  | ||||
|  | ||||
| class QGraphicsScene; | ||||
| class QGraphicsView; | ||||
| class QPixmap; | ||||
| class QThreadPool; | ||||
|  | ||||
| class AWDataAggregator : public QObject | ||||
| { | ||||
| @ -49,25 +45,22 @@ private: | ||||
|     // ui | ||||
|     QGraphicsScene *m_toolTipScene = nullptr; | ||||
|     QGraphicsView *m_toolTipView = nullptr; | ||||
|     void checkValue(const QString &_source, float _value, float _extremum) const; | ||||
|     void checkValue(const QString &_source, double _value, double _extremum) const; | ||||
|     void checkValue(const QString &_source, const QString &_current, const QString &_received) const; | ||||
|     void initScene(); | ||||
|     static QString notificationText(const QString &_source, float _value); | ||||
|     static QString notificationText(const QString &_source, const QString &_value); | ||||
|     // main method | ||||
|     void setData(const QVariantHash &_values); | ||||
|     void setData(const QString &_source, float _value, float _extremum = -1.0f); | ||||
|     void setData(const QString &_source, double _value, double _extremum = -1.0); | ||||
|     // different signature for battery device | ||||
|     void setData(bool _dontInvert, const QString &_source, float _value); | ||||
|     void setData(bool _dontInvert, const QString &_source, double _value); | ||||
|     // variables | ||||
|     int m_counts = 0; | ||||
|     QVariantHash m_configuration; | ||||
|     QString m_currentNetworkDevice = "lo"; | ||||
|     QHash<QString, float> m_boundaries; | ||||
|     QHash<QString, QList<float>> m_values; | ||||
|     QHash<QString, double> m_boundaries; | ||||
|     QHash<QString, QList<double>> m_values; | ||||
|     bool m_enablePopup = false; | ||||
|     QStringList requiredKeys; | ||||
|     QStringList m_requiredKeys; | ||||
| }; | ||||
|  | ||||
|  | ||||
| #endif /* AWTOOLTIP_H */ | ||||
|  | ||||
| @ -17,30 +17,35 @@ | ||||
|  | ||||
| #include "awdataengineaggregator.h" | ||||
|  | ||||
| #include <Plasma/DataContainer> | ||||
| #include <ksysguard/formatter/Unit.h> | ||||
| #include <ksysguard/systemstats/DBusInterface.h> | ||||
|  | ||||
| #include <QDBusConnection> | ||||
|  | ||||
| #include "awdebug.h" | ||||
|  | ||||
|  | ||||
| AWDataEngineAggregator::AWDataEngineAggregator(QObject *_parent) | ||||
|     : QObject(_parent) | ||||
|     , m_interface(new KSysGuard::SystemStats::DBusInterface()) | ||||
| { | ||||
|     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; | ||||
|  | ||||
|     m_consumer = new Plasma::DataEngineConsumer(); | ||||
|     m_dataEngines["systemmonitor"] = m_consumer->dataEngine("systemmonitor"); | ||||
|     m_dataEngines["extsysmon"] = m_consumer->dataEngine("extsysmon"); | ||||
|     m_dataEngines["time"] = m_consumer->dataEngine("time"); | ||||
|     qDBusRegisterMetaType<KSysGuard::SensorData>(); | ||||
|     qDBusRegisterMetaType<KSysGuard::SensorInfo>(); | ||||
|     qDBusRegisterMetaType<KSysGuard::SensorDataList>(); | ||||
|     qDBusRegisterMetaType<QHash<QString, KSysGuard::SensorInfo>>(); | ||||
|  | ||||
|     // additional method required by systemmonitor structure | ||||
|     m_newSourceConnection | ||||
|         = connect(m_dataEngines["systemmonitor"], &Plasma::DataEngine::sourceAdded, [this](const QString &source) { | ||||
|               emit(deviceAdded(source)); | ||||
|               m_dataEngines["systemmonitor"]->connectSource(source, parent(), 1000); | ||||
|           }); | ||||
|     connect(m_interface, &KSysGuard::SystemStats::DBusInterface::newSensorData, this, | ||||
|             &AWDataEngineAggregator::updateData); | ||||
|     connect(m_interface, &KSysGuard::SystemStats::DBusInterface::sensorMetaDataChanged, this, | ||||
|             &AWDataEngineAggregator::updateSensors); | ||||
|     connect(m_interface, &KSysGuard::SystemStats::DBusInterface::sensorAdded, this, | ||||
|             &AWDataEngineAggregator::sensorAdded); | ||||
|     connect(m_interface, &KSysGuard::SystemStats::DBusInterface::sensorRemoved, this, | ||||
|             &AWDataEngineAggregator::sensorRemoved); | ||||
|  | ||||
|     // required to define Qt::QueuedConnection for signal-slot connection | ||||
|     qRegisterMetaType<Plasma::DataEngine::Data>("Plasma::DataEngine::Data"); | ||||
|     loadSources(); | ||||
| } | ||||
|  | ||||
|  | ||||
| @ -49,67 +54,102 @@ AWDataEngineAggregator::~AWDataEngineAggregator() | ||||
|     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; | ||||
|  | ||||
|     disconnectSources(); | ||||
|     m_interface->deleteLater(); | ||||
| } | ||||
|  | ||||
|  | ||||
| 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() | ||||
| { | ||||
|     for (auto dataEngine : m_dataEngines.values()) | ||||
|         for (auto &source : dataEngine->sources()) | ||||
|             dataEngine->disconnectSource(source, parent()); | ||||
|     disconnect(m_newSourceConnection); | ||||
|     m_interface->unsubscribe(m_subscribed.values()).waitForFinished(); | ||||
|     m_subscribed.clear(); | ||||
| } | ||||
|  | ||||
|  | ||||
| void AWDataEngineAggregator::reconnectSources(const int _interval) | ||||
| bool AWDataEngineAggregator::isValidSensor(const KSysGuard::SensorInfo &_sensor) | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Reconnect sources with interval" << _interval; | ||||
|     return _sensor.unit != KSysGuard::UnitInvalid; | ||||
| } | ||||
|  | ||||
|     disconnectSources(); | ||||
|  | ||||
|     m_dataEngines["systemmonitor"]->connectAllSources(parent(), (uint)_interval); | ||||
|     m_dataEngines["extsysmon"]->connectAllSources(parent(), (uint)_interval); | ||||
|     m_dataEngines["time"]->connectSource("Local", parent(), 1000); | ||||
| void AWDataEngineAggregator::loadSources() | ||||
| { | ||||
|     auto response = m_interface->allSensors(); | ||||
|     response.waitForFinished(); | ||||
|  | ||||
|     m_newSourceConnection = connect( | ||||
|         m_dataEngines["systemmonitor"], &Plasma::DataEngine::sourceAdded, [this, _interval](const QString &source) { | ||||
|             emit(deviceAdded(source)); | ||||
|             m_dataEngines["systemmonitor"]->connectSource(source, parent(), (uint)_interval); | ||||
|         }); | ||||
|     auto sensors = response.value(); | ||||
|     updateSensors(sensors); | ||||
|     connectSources(); | ||||
|  | ||||
| #ifdef BUILD_FUTURE | ||||
|     createQueuedConnection(); | ||||
| #endif /* BUILD_FUTURE */ | ||||
|     for (auto &sensor : m_sensors.keys()) | ||||
|         emit(deviceAdded(sensor)); | ||||
| } | ||||
|  | ||||
|  | ||||
| void AWDataEngineAggregator::dropSource(const QString &_source) | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Source" << _source; | ||||
|     qCDebug(LOG_AW) << "Disconnect sensor" << _source; | ||||
|  | ||||
|     // HACK there is no possibility to check to which dataengine source | ||||
|     // connected we will try to disconnect it from all engines | ||||
|     for (auto dataEngine : m_dataEngines.values()) | ||||
|         dataEngine->disconnectSource(_source, parent()); | ||||
| } | ||||
|  | ||||
|  | ||||
| void AWDataEngineAggregator::createQueuedConnection() | ||||
| { | ||||
|     // HACK additional method which forces QueuedConnection instead of Auto one | ||||
|     // for more details refer to plasma-framework source code | ||||
|     for (auto &dataEngine : m_dataEngines.keys()) { | ||||
|         // different source set for different engines | ||||
|         QStringList sources = dataEngine == "time" ? QStringList() << "Local" : m_dataEngines[dataEngine]->sources(); | ||||
|         // reconnect sources | ||||
|         for (auto &source : sources) { | ||||
|             Plasma::DataContainer *container = m_dataEngines[dataEngine]->containerForSource(source); | ||||
|             // disconnect old connections first | ||||
|             disconnect(container, SIGNAL(dataUpdated(QString, Plasma::DataEngine::Data)), parent(), | ||||
|                        SLOT(dataUpdated(QString, Plasma::DataEngine::Data))); | ||||
|             // and now reconnect with Qt::QueuedConnection type | ||||
|             connect(container, SIGNAL(dataUpdated(QString, Plasma::DataEngine::Data)), parent(), | ||||
|                     SLOT(dataUpdated(QString, Plasma::DataEngine::Data)), Qt::QueuedConnection); | ||||
|         } | ||||
|     if (m_subscribed.contains(_source)) { | ||||
|         m_interface->unsubscribe({_source}).waitForFinished(); | ||||
|         m_subscribed.remove(_source); | ||||
|     } | ||||
| } | ||||
|  | ||||
|  | ||||
| void AWDataEngineAggregator::sensorAdded(const QString &_sensor) | ||||
| { | ||||
|     qCDebug(LOG_AW) << "New sensor added" << _sensor; | ||||
|  | ||||
|     // check if sensor is actually valid | ||||
|     auto response = m_interface->sensors({_sensor}); | ||||
|     response.waitForFinished(); | ||||
|  | ||||
|     auto info = response.value().value(_sensor); | ||||
|     if (!isValidSensor(info)) | ||||
|         return; | ||||
|  | ||||
|     m_sensors[_sensor] = info; | ||||
|     dropSource(_sensor); // force reconnect | ||||
|     if (!m_subscribed.contains(_sensor)) { | ||||
|         m_interface->subscribe({_sensor}).waitForFinished(); | ||||
|         m_subscribed.insert(_sensor); | ||||
|     } | ||||
|  | ||||
|     // notify about new device | ||||
|     emit(deviceAdded(_sensor)); | ||||
| } | ||||
|  | ||||
|  | ||||
| void AWDataEngineAggregator::sensorRemoved(const QString &_sensor) | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Sensor" << _sensor << "has been removed"; | ||||
|  | ||||
|     m_sensors.remove(_sensor); | ||||
|     dropSource(_sensor); | ||||
| } | ||||
|  | ||||
|  | ||||
| void AWDataEngineAggregator::updateData(const KSysGuard::SensorDataList &_data) | ||||
| { | ||||
|     emit(dataUpdated(m_sensors, _data)); | ||||
| } | ||||
|  | ||||
|  | ||||
| void AWDataEngineAggregator::updateSensors(const QHash<QString, KSysGuard::SensorInfo> &_sensors) | ||||
| { | ||||
|     for (auto [source, sensor] : _sensors.asKeyValueRange()) { | ||||
|         if (!isValidSensor(sensor)) | ||||
|             continue; | ||||
|         m_sensors.insert(source, sensor); | ||||
|     } | ||||
| } | ||||
|  | ||||
| @ -15,16 +15,20 @@ | ||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||
|  ***************************************************************************/ | ||||
|  | ||||
| #pragma once | ||||
|  | ||||
| #ifndef AWDATAENGINEAGGREGATOR_H | ||||
| #define AWDATAENGINEAGGREGATOR_H | ||||
|  | ||||
| #include <Plasma/DataEngine> | ||||
| #include <Plasma/DataEngineConsumer> | ||||
| #include <ksysguard/systemstats/SensorInfo.h> | ||||
|  | ||||
| #include <QHash> | ||||
| #include <QObject> | ||||
| #include <QSet> | ||||
|  | ||||
|  | ||||
| namespace KSysGuard::SystemStats | ||||
| { | ||||
| class DBusInterface; | ||||
| } | ||||
|  | ||||
| class AWDataEngineAggregator : public QObject | ||||
| { | ||||
|     Q_OBJECT | ||||
| @ -32,21 +36,24 @@ class AWDataEngineAggregator : public QObject | ||||
| public: | ||||
|     explicit AWDataEngineAggregator(QObject *_parent = nullptr); | ||||
|     ~AWDataEngineAggregator() override; | ||||
|     void connectSources(); | ||||
|     void disconnectSources(); | ||||
|     void reconnectSources(int _interval); | ||||
|     [[nodiscard]] static bool isValidSensor(const KSysGuard::SensorInfo &_sensor); | ||||
|     void loadSources(); | ||||
|  | ||||
| signals: | ||||
|     void dataUpdated(const QHash<QString, KSysGuard::SensorInfo> &_sensors, const KSysGuard::SensorDataList &_data); | ||||
|     void deviceAdded(const QString &_source); | ||||
|  | ||||
| public slots: | ||||
|     void dropSource(const QString &_source); | ||||
|     void sensorAdded(const QString &_sensor); | ||||
|     void sensorRemoved(const QString &_sensor); | ||||
|     void updateData(const KSysGuard::SensorDataList &_data); | ||||
|     void updateSensors(const QHash<QString, KSysGuard::SensorInfo> &_sensors); | ||||
|  | ||||
| private: | ||||
|     void createQueuedConnection(); | ||||
|     Plasma::DataEngineConsumer *m_consumer = nullptr; | ||||
|     QHash<QString, Plasma::DataEngine *> m_dataEngines; | ||||
|     QMetaObject::Connection m_newSourceConnection; | ||||
|     KSysGuard::SystemStats::DBusInterface *m_interface = nullptr; | ||||
|     QHash<QString, KSysGuard::SensorInfo> m_sensors; | ||||
|     QSet<QString> m_subscribed; | ||||
| }; | ||||
|  | ||||
|  | ||||
| #endif /* AWDATAENGINEAGGREGATOR_H */ | ||||
|  | ||||
| @ -17,10 +17,12 @@ | ||||
|  | ||||
| #include "awdataenginemapper.h" | ||||
|  | ||||
| #include <QRegExp> | ||||
| #include <QRegularExpression> | ||||
|  | ||||
| #include "awdebug.h" | ||||
| #include "awformatterhelper.h" | ||||
| #include "formatters/formatters.h" | ||||
| #include "matchers/matchers.h" | ||||
|  | ||||
|  | ||||
| AWDataEngineMapper::AWDataEngineMapper(QObject *_parent, AWFormatterHelper *_custom) | ||||
| @ -30,39 +32,25 @@ AWDataEngineMapper::AWDataEngineMapper(QObject *_parent, AWFormatterHelper *_cus | ||||
|     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; | ||||
|  | ||||
|     // default formatters | ||||
|     // memory | ||||
|     m_formatter["mem"] = AWKeysAggregator::FormatterType::Float; | ||||
|     m_formatter["memtotmb"] = AWKeysAggregator::FormatterType::MemMBFormat; | ||||
|     m_formatter["memtotgb"] = AWKeysAggregator::FormatterType::MemGBFormat; | ||||
|     // network | ||||
|     m_formatter["down"] = AWKeysAggregator::FormatterType::NetSmartFormat; | ||||
|     m_formatter["downkb"] = AWKeysAggregator::FormatterType::Integer; | ||||
|     m_formatter["downtot"] = AWKeysAggregator::FormatterType::MemMBFormat; | ||||
|     m_formatter["downtotkb"] = AWKeysAggregator::FormatterType::Integer; | ||||
|     m_formatter["downunits"] = AWKeysAggregator::FormatterType::NetSmartUnits; | ||||
|     m_formatter["up"] = AWKeysAggregator::FormatterType::NetSmartFormat; | ||||
|     m_formatter["upkb"] = AWKeysAggregator::FormatterType::Integer; | ||||
|     m_formatter["uptot"] = AWKeysAggregator::FormatterType::MemMBFormat; | ||||
|     m_formatter["uptotkb"] = AWKeysAggregator::FormatterType::Integer; | ||||
|     m_formatter["upunits"] = AWKeysAggregator::FormatterType::NetSmartUnits; | ||||
|     // swap | ||||
|     m_formatter["swap"] = AWKeysAggregator::FormatterType::Float; | ||||
|     m_formatter["swaptotmb"] = AWKeysAggregator::FormatterType::MemMBFormat; | ||||
|     m_formatter["swaptotgb"] = AWKeysAggregator::FormatterType::MemGBFormat; | ||||
|     m_formatter["down"] = AWPluginFormatterNet::instance(); | ||||
|     m_formatter["downkb"] = AWPluginFormatterMemory::instance(); | ||||
|     m_formatter["downtot"] = AWPluginFormatterMemoryMB::instance(); | ||||
|     m_formatter["downtotkb"] = AWPluginFormatterMemory::instance(); | ||||
|     m_formatter["downunits"] = AWPluginFormatterNetUnits::instance(); | ||||
|     m_formatter["up"] = AWPluginFormatterNet::instance(); | ||||
|     m_formatter["upkb"] = AWPluginFormatterMemory::instance(); | ||||
|     m_formatter["uptot"] = AWPluginFormatterMemoryMB::instance(); | ||||
|     m_formatter["uptotkb"] = AWPluginFormatterMemory::instance(); | ||||
|     m_formatter["upunits"] = AWPluginFormatterNetUnits::instance(); | ||||
| } | ||||
|  | ||||
|  | ||||
| AWDataEngineMapper::~AWDataEngineMapper() | ||||
| { | ||||
|     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; | ||||
| } | ||||
|  | ||||
|  | ||||
| AWKeysAggregator::FormatterType AWDataEngineMapper::formatter(const QString &_key) const | ||||
| AWPluginFormaterInterface *AWDataEngineMapper::formatter(const QString &_key) const | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Get formatter for key" << _key; | ||||
|  | ||||
|     return m_formatter.value(_key, AWKeysAggregator::FormatterType::NoFormat); | ||||
|     return m_formatter.value(_key, AWPluginFormatterNoFormat::instance()); | ||||
| } | ||||
|  | ||||
|  | ||||
| @ -76,370 +64,49 @@ QStringList AWDataEngineMapper::keysFromSource(const QString &_source) const | ||||
|  | ||||
| // HACK units required to define should the value be calculated as temperature | ||||
| // or fan data | ||||
| QStringList AWDataEngineMapper::registerSource(const QString &_source, const QString &_units, const QStringList &_keys) | ||||
| QStringList AWDataEngineMapper::registerSource(const QString &_source, const KSysGuard::Unit _units, | ||||
|                                                const QStringList &_keys) | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Source" << _source << "with units" << _units; | ||||
|  | ||||
|     // regular expressions | ||||
|     QRegExp cpuRegExp = QRegExp("cpu/cpu.*/TotalLoad"); | ||||
|     QRegExp cpuclRegExp = QRegExp("cpu/cpu.*/clock"); | ||||
|     QRegExp hddrRegExp = QRegExp("disk/.*/Rate/rblk"); | ||||
|     QRegExp hddwRegExp = QRegExp("disk/.*/Rate/wblk"); | ||||
|     QRegExp mountFillRegExp = QRegExp("partitions/.*/filllevel"); | ||||
|     QRegExp mountFreeRegExp = QRegExp("partitions/.*/freespace"); | ||||
|     QRegExp mountUsedRegExp = QRegExp("partitions/.*/usedspace"); | ||||
|     QRegExp netRegExp = QRegExp("network/interfaces/.*/(receiver|transmitter)/data$"); | ||||
|     QRegExp netTotalRegExp = QRegExp("network/interfaces/.*/(receiver|transmitter)/dataTotal$"); | ||||
|     auto matchers = AWPluginMatchers::matchers; | ||||
|     auto matcher = std::find_if(matchers.cbegin(), matchers.cend(), | ||||
|                                 [&_source](auto matcher) { return matcher->matches(_source); }); | ||||
|     if (matcher == matchers.cend()) | ||||
|         return {}; | ||||
|  | ||||
|     if (_source == "battery/ac") { | ||||
|         // AC | ||||
|         m_map.insert(_source, "ac"); | ||||
|         m_formatter["ac"] = AWKeysAggregator::FormatterType::ACFormat; | ||||
|     } else if (_source.startsWith("battery/")) { | ||||
|         // battery stats | ||||
|         QString key = _source; | ||||
|         key.remove("battery/"); | ||||
|         m_map.insert(_source, key); | ||||
|         m_formatter[key] = _source.contains("rate") ? AWKeysAggregator::FormatterType::Float | ||||
|                                                     : AWKeysAggregator::FormatterType::IntegerThree; | ||||
|     } else if (_source == "cpu/system/TotalLoad") { | ||||
|         // cpu | ||||
|         m_map.insert(_source, "cpu"); | ||||
|         m_formatter["cpu"] = AWKeysAggregator::FormatterType::Float; | ||||
|     } else if (_source.contains(cpuRegExp)) { | ||||
|         // cpus | ||||
|         QString key = _source; | ||||
|         key.remove("cpu/").remove("/TotalLoad"); | ||||
|         m_map.insert(_source, key); | ||||
|         m_formatter[key] = AWKeysAggregator::FormatterType::Float; | ||||
|     } else if (_source == "cpu/system/AverageClock") { | ||||
|         // cpucl | ||||
|         m_map.insert(_source, "cpucl"); | ||||
|         m_formatter["cpucl"] = AWKeysAggregator::FormatterType::Integer; | ||||
|     } else if (_source.contains(cpuclRegExp)) { | ||||
|         // cpucls | ||||
|         QString key = _source; | ||||
|         key.remove("cpu/cpu").remove("/clock"); | ||||
|         key = QString("cpucl%1").arg(key); | ||||
|         m_map.insert(_source, key); | ||||
|         m_formatter[key] = AWKeysAggregator::FormatterType::Integer; | ||||
|     } else if (_source.startsWith("custom")) { | ||||
|         // custom | ||||
|         QString key = _source; | ||||
|         key.remove("custom/"); | ||||
|         m_map.insert(_source, key); | ||||
|         m_formatter[key] = AWKeysAggregator::FormatterType::NoFormat; | ||||
|     } else if (_source == "desktop/current/name") { | ||||
|         // current desktop name | ||||
|         m_map.insert(_source, "desktop"); | ||||
|         m_formatter["desktop"] = AWKeysAggregator::FormatterType::NoFormat; | ||||
|     } else if (_source == "desktop/current/number") { | ||||
|         // current desktop number | ||||
|         m_map.insert(_source, "ndesktop"); | ||||
|         m_formatter["ndesktop"] = AWKeysAggregator::FormatterType::NoFormat; | ||||
|     } else if (_source == "desktop/total/number") { | ||||
|         // desktop count | ||||
|         m_map.insert(_source, "tdesktops"); | ||||
|         m_formatter["tdesktops"] = AWKeysAggregator::FormatterType::NoFormat; | ||||
|     } else if (_source.contains(hddrRegExp)) { | ||||
|         // read speed | ||||
|         QString device = _source; | ||||
|         device.remove("/Rate/rblk"); | ||||
|         int index = m_devices["disk"].indexOf(device); | ||||
|         if (index > -1) { | ||||
|             QString key = QString("hddr%1").arg(index); | ||||
|             m_map.insert(_source, key); | ||||
|             m_formatter[key] = AWKeysAggregator::FormatterType::Integer; | ||||
|         } | ||||
|     } else if (_source.contains(hddwRegExp)) { | ||||
|         // write speed | ||||
|         QString device = _source; | ||||
|         device.remove("/Rate/wblk"); | ||||
|         int index = m_devices["disk"].indexOf(device); | ||||
|         if (index > -1) { | ||||
|             QString key = QString("hddw%1").arg(index); | ||||
|             m_map.insert(_source, key); | ||||
|             m_formatter[key] = AWKeysAggregator::FormatterType::Integer; | ||||
|         } | ||||
|     } else if (_source == "gpu/load") { | ||||
|         // gpu load | ||||
|         m_map.insert(_source, "gpu"); | ||||
|         m_formatter["gpu"] = AWKeysAggregator::FormatterType::Float; | ||||
|     } else if (_source == "gpu/temperature") { | ||||
|         // gpu temperature | ||||
|         m_map.insert(_source, "gputemp"); | ||||
|         m_formatter["gputemp"] = AWKeysAggregator::FormatterType::Temperature; | ||||
|     } else if (_source.contains(mountFillRegExp)) { | ||||
|         // fill level | ||||
|         QString device = _source; | ||||
|         device.remove("partitions").remove("/filllevel"); | ||||
|         int index = m_devices["mount"].indexOf(device); | ||||
|         if (index > -1) { | ||||
|             QString key = QString("hdd%1").arg(index); | ||||
|             m_map.insert(_source, key); | ||||
|             m_formatter[key] = AWKeysAggregator::FormatterType::Float; | ||||
|             // additional keys | ||||
|             m_formatter[QString("hddtotmb%1").arg(index)] = AWKeysAggregator::FormatterType::MemMBFormat; | ||||
|             m_formatter[QString("hddtotgb%1").arg(index)] = AWKeysAggregator::FormatterType::MemGBFormat; | ||||
|         } | ||||
|     } else if (_source.contains(mountFreeRegExp)) { | ||||
|         // free space | ||||
|         QString device = _source; | ||||
|         device.remove("partitions").remove("/freespace"); | ||||
|         int index = m_devices["mount"].indexOf(device); | ||||
|         if (index > -1) { | ||||
|             // mb | ||||
|             QString key = QString("hddfreemb%1").arg(index); | ||||
|             m_map.insert(_source, key); | ||||
|             m_formatter[key] = AWKeysAggregator::FormatterType::MemMBFormat; | ||||
|             // gb | ||||
|             key = QString("hddfreegb%1").arg(index); | ||||
|             m_map.insert(_source, key); | ||||
|             m_formatter[key] = AWKeysAggregator::FormatterType::MemGBFormat; | ||||
|         } | ||||
|     } else if (_source.contains(mountUsedRegExp)) { | ||||
|         // used | ||||
|         QString device = _source; | ||||
|         device.remove("partitions").remove("/usedspace"); | ||||
|         int index = m_devices["mount"].indexOf(device); | ||||
|         if (index > -1) { | ||||
|             // mb | ||||
|             QString key = QString("hddmb%1").arg(index); | ||||
|             m_map.insert(_source, key); | ||||
|             m_formatter[key] = AWKeysAggregator::FormatterType::MemMBFormat; | ||||
|             // gb | ||||
|             key = QString("hddgb%1").arg(index); | ||||
|             m_map.insert(_source, key); | ||||
|             m_formatter[key] = AWKeysAggregator::FormatterType::MemGBFormat; | ||||
|         } | ||||
|     } else if (_source.startsWith("hdd/temperature")) { | ||||
|         // hdd temperature | ||||
|         QString device = _source; | ||||
|         device.remove("hdd/temperature"); | ||||
|         int index = m_devices["hdd"].indexOf(device); | ||||
|         if (index > -1) { | ||||
|             QString key = QString("hddtemp%1").arg(index); | ||||
|             m_map.insert(_source, key); | ||||
|             m_formatter[key] = AWKeysAggregator::FormatterType::Temperature; | ||||
|         } | ||||
|     } else if (_source.startsWith("cpu/system/loadavg")) { | ||||
|         // load average | ||||
|         QString time = _source; | ||||
|         time.remove("cpu/system/loadavg"); | ||||
|         QString key = QString("la%1").arg(time); | ||||
|         m_map.insert(_source, key); | ||||
|         m_formatter[key] = AWKeysAggregator::FormatterType::FloatTwoSymbols; | ||||
|     } else if (_source == "mem/physical/application") { | ||||
|         // app memory | ||||
|         // mb | ||||
|         m_map.insert(_source, "memmb"); | ||||
|         m_formatter["memmb"] = AWKeysAggregator::FormatterType::MemMBFormat; | ||||
|         // gb | ||||
|         m_map.insert(_source, "memgb"); | ||||
|         m_formatter["memgb"] = AWKeysAggregator::FormatterType::MemGBFormat; | ||||
|     } else if (_source == "mem/physical/free") { | ||||
|         // free memory | ||||
|         // mb | ||||
|         m_map.insert(_source, "memfreemb"); | ||||
|         m_formatter["memfreemb"] = AWKeysAggregator::FormatterType::MemMBFormat; | ||||
|         // gb | ||||
|         m_map.insert(_source, "memfreegb"); | ||||
|         m_formatter["memfreegb"] = AWKeysAggregator::FormatterType::MemGBFormat; | ||||
|     } else if (_source == "mem/physical/used") { | ||||
|         // used memory | ||||
|         // mb | ||||
|         m_map.insert(_source, "memusedmb"); | ||||
|         m_formatter["memusedmb"] = AWKeysAggregator::FormatterType::MemMBFormat; | ||||
|         // gb | ||||
|         m_map.insert(_source, "memusedgb"); | ||||
|         m_formatter["memusedgb"] = AWKeysAggregator::FormatterType::MemGBFormat; | ||||
|     } else if (_source == "network/current/name") { | ||||
|         // network device | ||||
|         m_map.insert(_source, "netdev"); | ||||
|         m_formatter["netdev"] = AWKeysAggregator::FormatterType::NoFormat; | ||||
|     } else if (_source == "network/current/ssid") { | ||||
|         // current ssid | ||||
|         m_map.insert(_source, "ssid"); | ||||
|         m_formatter["ssid"] = AWKeysAggregator::FormatterType::NoFormat; | ||||
|     } else if (_source.startsWith("network/response")) { | ||||
|         // network response | ||||
|         QString key = _source; | ||||
|         key.remove("network/"); | ||||
|         m_map.insert(_source, key); | ||||
|         m_formatter[key] = AWKeysAggregator::FormatterType::NoFormat; | ||||
|     } else if (_source.contains(netRegExp)) { | ||||
|         // network speed | ||||
|         QString type = _source.contains("receiver") ? "down" : "up"; | ||||
|         int index = m_devices["net"].indexOf(_source.split('/')[2]); | ||||
|         if (index > -1) { | ||||
|             // kb | ||||
|             QString key = QString("%1kb%2").arg(type).arg(index); | ||||
|             m_map.insert(_source, key); | ||||
|             m_formatter[key] = AWKeysAggregator::FormatterType::Integer; | ||||
|             // smart | ||||
|             key = QString("%1%2").arg(type).arg(index); | ||||
|             m_map.insert(_source, key); | ||||
|             m_formatter[key] = AWKeysAggregator::FormatterType::NetSmartFormat; | ||||
|             // units | ||||
|             key = QString("%1units%2").arg(type).arg(index); | ||||
|             m_map.insert(_source, key); | ||||
|             m_formatter[key] = AWKeysAggregator::FormatterType::NetSmartUnits; | ||||
|         } | ||||
|     } else if (_source.contains(netTotalRegExp)) { | ||||
|         // network data total | ||||
|         QString type = _source.contains("receiver") ? "down" : "up"; | ||||
|         int index = m_devices["net"].indexOf(_source.split('/')[2]); | ||||
|         if (index > -1) { | ||||
|             // kb | ||||
|             QString key = QString("%1totkb%2").arg(type).arg(index); | ||||
|             m_map.insert(_source, key); | ||||
|             m_formatter[key] = AWKeysAggregator::FormatterType::Integer; | ||||
|             // mb | ||||
|             key = QString("%1tot%2").arg(type).arg(index); | ||||
|             m_map.insert(_source, key); | ||||
|             m_formatter[key] = AWKeysAggregator::FormatterType::MemMBFormat; | ||||
|         } | ||||
|     } else if (_source.startsWith("upgrade")) { | ||||
|         // package manager | ||||
|         QString key = _source; | ||||
|         key.remove("upgrade/"); | ||||
|         m_map.insert(_source, key); | ||||
|         m_formatter[key] = AWKeysAggregator::FormatterType::IntegerThree; | ||||
|     } else if (_source.startsWith("player")) { | ||||
|         // player | ||||
|         QString key = _source; | ||||
|         key.remove("player/"); | ||||
|         m_map.insert(_source, key); | ||||
|         m_formatter[key] = AWKeysAggregator::FormatterType::NoFormat; | ||||
|     } else if (_source == "ps/running/count") { | ||||
|         // running processes count | ||||
|         m_map.insert(_source, "pscount"); | ||||
|         m_formatter["pscount"] = AWKeysAggregator::FormatterType::NoFormat; | ||||
|     } else if (_source == "ps/running/list") { | ||||
|         // list of running processes | ||||
|         m_map.insert(_source, "ps"); | ||||
|         m_formatter["ps"] = AWKeysAggregator::FormatterType::List; | ||||
|     } else if (_source == "ps/total/count") { | ||||
|         // total processes count | ||||
|         m_map.insert(_source, "pstot"); | ||||
|         m_formatter["pstot"] = AWKeysAggregator::FormatterType::NoFormat; | ||||
|     } else if (_source.startsWith("quotes")) { | ||||
|         // quotes | ||||
|         QString key = _source; | ||||
|         key.remove("quotes/"); | ||||
|         m_map.insert(_source, key); | ||||
|         m_formatter[key] = AWKeysAggregator::FormatterType::Quotes; | ||||
|     } else if (_source == "mem/swap/free") { | ||||
|         // free swap | ||||
|         // mb | ||||
|         m_map.insert(_source, "swapfreemb"); | ||||
|         m_formatter["swapfreemb"] = AWKeysAggregator::FormatterType::MemMBFormat; | ||||
|         // gb | ||||
|         m_map.insert(_source, "swapfreegb"); | ||||
|         m_formatter["swapfreegb"] = AWKeysAggregator::FormatterType::MemGBFormat; | ||||
|     } else if (_source == "mem/swap/used") { | ||||
|         // used swap | ||||
|         // mb | ||||
|         m_map.insert(_source, "swapmb"); | ||||
|         m_formatter["swapmb"] = AWKeysAggregator::FormatterType::MemMBFormat; | ||||
|         // gb | ||||
|         m_map.insert(_source, "swapgb"); | ||||
|         m_formatter["swapgb"] = AWKeysAggregator::FormatterType::MemGBFormat; | ||||
|     } else if (_source.startsWith("lmsensors/")) { | ||||
|         // temperature | ||||
|         int index = m_devices["temp"].indexOf(_source); | ||||
|         // HACK on DE initialization there are no units key | ||||
|         if (_units.isEmpty()) | ||||
|             return QStringList({QString("temp%1").arg(index)}); | ||||
|         if (index > -1) { | ||||
|             QString key = QString("temp%1").arg(index); | ||||
|             m_map.insert(_source, key); | ||||
|             m_formatter[key] = _units == "°C" ? AWKeysAggregator::FormatterType::Temperature | ||||
|                                               : AWKeysAggregator::FormatterType::Integer; | ||||
|         } | ||||
|     } else if (_source == "Local") { | ||||
|         // time | ||||
|         m_map.insert(_source, "time"); | ||||
|         m_formatter["time"] = AWKeysAggregator::FormatterType::Time; | ||||
|         // custom time | ||||
|         m_map.insert(_source, "ctime"); | ||||
|         m_formatter["ctime"] = AWKeysAggregator::FormatterType::TimeCustom; | ||||
|         // ISO time | ||||
|         m_map.insert(_source, "isotime"); | ||||
|         m_formatter["isotime"] = AWKeysAggregator::FormatterType::TimeISO; | ||||
|         // long time | ||||
|         m_map.insert(_source, "longtime"); | ||||
|         m_formatter["longtime"] = AWKeysAggregator::FormatterType::TimeLong; | ||||
|         // short time | ||||
|         m_map.insert(_source, "shorttime"); | ||||
|         m_formatter["shorttime"] = AWKeysAggregator::FormatterType::TimeShort; | ||||
|         // timestamp | ||||
|         m_map.insert(_source, "tstime"); | ||||
|         m_formatter["tstime"] = AWKeysAggregator::FormatterType::Timestamp; | ||||
|     } else if (_source == "system/brightness") { | ||||
|         m_map.insert(_source, "brightness"); | ||||
|         m_formatter["brightness"] = AWKeysAggregator::FormatterType::IntegerThree; | ||||
|     } else if (_source == "system/volume") { | ||||
|         m_map.insert(_source, "volume"); | ||||
|         m_formatter["volume"] = AWKeysAggregator::FormatterType::IntegerThree; | ||||
|     } else if (_source == "system/uptime") { | ||||
|         // uptime | ||||
|         m_map.insert(_source, "uptime"); | ||||
|         m_formatter["uptime"] = AWKeysAggregator::FormatterType::Uptime; | ||||
|         // custom uptime | ||||
|         m_map.insert(_source, "cuptime"); | ||||
|         m_formatter["cuptime"] = AWKeysAggregator::FormatterType::UptimeCustom; | ||||
|     } else if (_source.startsWith("weather/temperature")) { | ||||
|         // temperature | ||||
|         QString key = _source; | ||||
|         key.remove("weather/"); | ||||
|         m_map.insert(_source, key); | ||||
|         m_formatter[key] = AWKeysAggregator::FormatterType::Temperature; | ||||
|     } else if (_source.startsWith("weather/")) { | ||||
|         // other weather | ||||
|         QString key = _source; | ||||
|         key.remove("weather/"); | ||||
|         m_map.insert(_source, key); | ||||
|         m_formatter[key] = AWKeysAggregator::FormatterType::NoFormat; | ||||
|     } else if (_source.startsWith("load/load")) { | ||||
|         // load source | ||||
|         QString key = _source; | ||||
|         key.remove("load/"); | ||||
|         m_map.insert(_source, key); | ||||
|         m_formatter[key] = AWKeysAggregator::FormatterType::Temperature; | ||||
|     } | ||||
|  | ||||
|     QStringList foundKeys = keysFromSource(_source); | ||||
|     auto foundKeys = (*matcher)->keys(_source, _units, m_settings); | ||||
|     auto keys = foundKeys.keys(); // speedup a little bit | ||||
|  | ||||
|     // rewrite formatters for custom ones | ||||
|     QStringList customFormattersKeys; | ||||
|     if (m_customFormatters) | ||||
|         customFormattersKeys = m_customFormatters->definedFormatters(); | ||||
|     qCInfo(LOG_AW) << "Looking for formatters" << foundKeys << "in" << customFormattersKeys; | ||||
|     for (auto &key : foundKeys) { | ||||
|     qCInfo(LOG_AW) << "Looking for formatters" << keys << "in" << customFormattersKeys; | ||||
|     for (auto &key : keys) { | ||||
|         if (!customFormattersKeys.contains(key)) | ||||
|             continue; | ||||
|         m_formatter[key] = AWKeysAggregator::FormatterType::Custom; | ||||
|         foundKeys[key] = AWPluginFormatterCustom::instance(); | ||||
|     } | ||||
|  | ||||
|     // drop key from dictionary if no one user requested key required it | ||||
|     qCInfo(LOG_AW) << "Looking for keys" << foundKeys << "in" << _keys; | ||||
|     bool required = _keys.isEmpty() || std::any_of(foundKeys.cbegin(), foundKeys.cend(), [&_keys](const QString &key) { | ||||
|                         return _keys.contains(key); | ||||
|                     }); | ||||
|     if (!required) { | ||||
|         m_map.remove(_source); | ||||
|         for (auto &key : foundKeys) | ||||
|             m_formatter.remove(key); | ||||
|     // check if keys were actually requested | ||||
|     qCInfo(LOG_AW) << "Looking for keys" << keys << "in" << _keys; | ||||
|     auto required = _keys.isEmpty() | ||||
|                     || std::any_of(keys.cbegin(), keys.cend(), [&_keys](auto &key) { return _keys.contains(key); }); | ||||
|     if (!required) | ||||
|         return {}; | ||||
|  | ||||
|     // insert keys into memory | ||||
|     for (auto [key, formatter] : foundKeys.asKeyValueRange()) { | ||||
|         m_map.insert(_source, key); | ||||
|         m_formatter[key] = formatter; | ||||
|     } | ||||
|  | ||||
|     return keysFromSource(_source); | ||||
|     return keys; | ||||
| } | ||||
|  | ||||
|  | ||||
| void AWDataEngineMapper::setDevices(const QHash<QString, QStringList> &_devices) | ||||
| void AWDataEngineMapper::setDevices(const AWPluginMatcherSettings &_settings) | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Devices" << _devices; | ||||
|  | ||||
|     m_devices = _devices; | ||||
|     m_settings = _settings; | ||||
| } | ||||
|  | ||||
| @ -15,14 +15,15 @@ | ||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||
|  ***************************************************************************/ | ||||
|  | ||||
| #pragma once | ||||
|  | ||||
| #ifndef AWDATAENGINEMAPPER_H | ||||
| #define AWDATAENGINEMAPPER_H | ||||
| #include <ksysguard/formatter/Unit.h> | ||||
|  | ||||
| #include <QMultiHash> | ||||
| #include <QObject> | ||||
|  | ||||
| #include "awkeysaggregator.h" | ||||
| #include "formatters/awpluginformatter.h" | ||||
| #include "matchers/awpluginmatchersettings.h" | ||||
|  | ||||
|  | ||||
| class AWFormatterHelper; | ||||
| @ -33,21 +34,19 @@ class AWDataEngineMapper : public QObject | ||||
|  | ||||
| public: | ||||
|     explicit AWDataEngineMapper(QObject *_parent = nullptr, AWFormatterHelper *_custom = nullptr); | ||||
|     ~AWDataEngineMapper() override; | ||||
|     ~AWDataEngineMapper() override = default; | ||||
|     // get methods | ||||
|     [[nodiscard]] AWKeysAggregator::FormatterType formatter(const QString &_key) const; | ||||
|     [[nodiscard]] AWPluginFormaterInterface *formatter(const QString &_key) const; | ||||
|     [[nodiscard]] QStringList keysFromSource(const QString &_source) const; | ||||
|     // set methods | ||||
|     QStringList registerSource(const QString &_source, const QString &_units, const QStringList &_keys); | ||||
|     void setDevices(const QHash<QString, QStringList> &_devices); | ||||
|     QStringList registerSource(const QString &_source, KSysGuard::Unit _units, const QStringList &_keys); | ||||
|     void setDevices(const AWPluginMatcherSettings &_settings); | ||||
|  | ||||
| private: | ||||
|     AWFormatterHelper *m_customFormatters = nullptr; | ||||
|     AWPluginMatcherSettings m_settings; | ||||
|     // variables | ||||
|     QHash<QString, QStringList> m_devices; | ||||
|     QHash<QString, AWKeysAggregator::FormatterType> m_formatter; | ||||
|     QHash<QString, AWPluginFormaterInterface *> m_formatter; | ||||
|     QMultiHash<QString, QString> m_map; | ||||
| }; | ||||
|  | ||||
|  | ||||
| #endif /* AWDATAENGINEMAPPER_H */ | ||||
|  | ||||
| @ -32,27 +32,20 @@ AWDBusAdaptor::AWDBusAdaptor(AWKeys *_parent) | ||||
| } | ||||
|  | ||||
|  | ||||
| AWDBusAdaptor::~AWDBusAdaptor() | ||||
| { | ||||
|     qCDebug(LOG_DBUS) << __PRETTY_FUNCTION__; | ||||
| } | ||||
|  | ||||
|  | ||||
| QStringList AWDBusAdaptor::ActiveServices() | ||||
| { | ||||
|     QDBusMessage listServices = QDBusConnection::sessionBus().interface()->call(QDBus::BlockWithGui, "ListNames"); | ||||
|     auto listServices = QDBusConnection::sessionBus().interface()->call(QDBus::BlockWithGui, "ListNames"); | ||||
|     if (listServices.arguments().isEmpty()) { | ||||
|         qCWarning(LOG_DBUS) << "Could not find any DBus service"; | ||||
|         return {}; | ||||
|     } | ||||
|     QStringList arguments = listServices.arguments().first().toStringList(); | ||||
|     auto arguments = listServices.arguments().first().toStringList(); | ||||
|  | ||||
|     return std::accumulate(arguments.cbegin(), arguments.cend(), QStringList(), | ||||
|                            [](QStringList source, const QString &service) { | ||||
|                                if (service.startsWith(AWDBUS_SERVICE)) | ||||
|                                    source.append(service); | ||||
|                                return source; | ||||
|                            }); | ||||
|     return std::accumulate(arguments.cbegin(), arguments.cend(), QStringList(), [](auto source, auto &service) { | ||||
|         if (service.startsWith(AWDBUS_SERVICE)) | ||||
|             source.append(service); | ||||
|         return source; | ||||
|     }); | ||||
| } | ||||
|  | ||||
|  | ||||
| @ -103,6 +96,6 @@ void AWDBusAdaptor::SetLogLevel(const QString &what, const QString &level, const | ||||
|         return; | ||||
|     } | ||||
|  | ||||
|     QString state = enabled ? "true" : "false"; | ||||
|     QLoggingCategory::setFilterRules(QString("%1.%2=%3").arg(what).arg(level).arg(state)); | ||||
|     auto state = enabled ? "true" : "false"; | ||||
|     QLoggingCategory::setFilterRules(QString("%1.%2=%3").arg(what, level, state)); | ||||
| } | ||||
|  | ||||
| @ -15,9 +15,7 @@ | ||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||
|  ***************************************************************************/ | ||||
|  | ||||
|  | ||||
| #ifndef AWDBUSADAPTOR_H | ||||
| #define AWDBUSADAPTOR_H | ||||
| #pragma once | ||||
|  | ||||
| #include <QDBusAbstractAdaptor> | ||||
|  | ||||
| @ -33,7 +31,7 @@ class AWDBusAdaptor : public QDBusAbstractAdaptor | ||||
|  | ||||
| public: | ||||
|     explicit AWDBusAdaptor(AWKeys *_parent = nullptr); | ||||
|     ~AWDBusAdaptor() override; | ||||
|     ~AWDBusAdaptor() override = default; | ||||
|  | ||||
| public slots: | ||||
|     // get methods | ||||
| @ -50,6 +48,3 @@ private: | ||||
|     AWKeys *m_plugin = nullptr; | ||||
|     QStringList m_logLevels = {"debug", "info", "warning", "critical"}; | ||||
| }; | ||||
|  | ||||
|  | ||||
| #endif /* AWDBUSADAPTOR_H */ | ||||
|  | ||||
| @ -15,9 +15,7 @@ | ||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||
|  ***************************************************************************/ | ||||
|  | ||||
|  | ||||
| #ifndef AWPLUGIN_H | ||||
| #define AWPLUGIN_H | ||||
| #pragma once | ||||
|  | ||||
| #include <QQmlExtensionPlugin> | ||||
|  | ||||
| @ -30,6 +28,3 @@ class AWPlugin : public QQmlExtensionPlugin | ||||
| public: | ||||
|     void registerTypes(const char *uri) override; | ||||
| }; | ||||
|  | ||||
|  | ||||
| #endif /* AWPLUGIN_H */ | ||||
|  | ||||
| @ -27,11 +27,5 @@ AWFormatterConfig::AWFormatterConfig(QWidget *_parent, const QStringList &_keys) | ||||
|     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; | ||||
|  | ||||
|     setEditable(false, false); | ||||
|     initHelper<AWFormatterHelper>(); | ||||
| } | ||||
|  | ||||
|  | ||||
| AWFormatterConfig::~AWFormatterConfig() | ||||
| { | ||||
|     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; | ||||
|     setHelper(std::make_unique<AWFormatterHelper>()); | ||||
| } | ||||
|  | ||||
| @ -15,9 +15,7 @@ | ||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||
|  ***************************************************************************/ | ||||
|  | ||||
|  | ||||
| #ifndef AWFORMATTERCONFIG_H | ||||
| #define AWFORMATTERCONFIG_H | ||||
| #pragma once | ||||
|  | ||||
| #include "awabstractpairconfig.h" | ||||
|  | ||||
| @ -28,8 +26,5 @@ class AWFormatterConfig : public AWAbstractPairConfig | ||||
|  | ||||
| public: | ||||
|     explicit AWFormatterConfig(QWidget *_parent = nullptr, const QStringList &_keys = QStringList()); | ||||
|     ~AWFormatterConfig() override; | ||||
|     ~AWFormatterConfig() override = default; | ||||
| }; | ||||
|  | ||||
|  | ||||
| #endif /* AWFORMATTERCONFIG_H */ | ||||
|  | ||||
| @ -33,7 +33,7 @@ | ||||
| #include "awstringformatter.h" | ||||
|  | ||||
|  | ||||
| AWFormatterHelper::AWFormatterHelper(QWidget *_parent) | ||||
| AWFormatterHelper::AWFormatterHelper(QObject *_parent) | ||||
|     : AbstractExtItemAggregator(_parent, "formatters") | ||||
|     , AWAbstractPairHelper("awesomewidgets/formatters/formatters.ini", "Formatters") | ||||
| { | ||||
| @ -58,8 +58,7 @@ void AWFormatterHelper::initItems() | ||||
|  | ||||
|     // assign internal storage | ||||
|     m_formatters.clear(); | ||||
|     for (auto &key : pairs().keys()) { | ||||
|         auto name = pairs()[key]; | ||||
|     for (auto [key, name] : pairs().asKeyValueRange()) { | ||||
|         if (!m_formattersClasses.contains(name)) { | ||||
|             qCWarning(LOG_AW) << "Invalid formatter" << name << "found in" << key; | ||||
|             continue; | ||||
| @ -87,7 +86,7 @@ QStringList AWFormatterHelper::definedFormatters() const | ||||
| QList<AbstractExtItem *> AWFormatterHelper::items() const | ||||
| { | ||||
|     QList<AbstractExtItem *> converted; | ||||
|     for (auto &item : m_formattersClasses.values()) | ||||
|     for (auto item : m_formattersClasses.values()) | ||||
|         converted.append(item); | ||||
|  | ||||
|     return converted; | ||||
| @ -114,8 +113,7 @@ QStringList AWFormatterHelper::rightKeys() | ||||
|  | ||||
| void AWFormatterHelper::editItems() | ||||
| { | ||||
|     repaintList(); | ||||
|     int ret = exec(); | ||||
|     auto ret = exec(); | ||||
|     qCInfo(LOG_AW) << "Dialog returns" << ret; | ||||
| } | ||||
|  | ||||
| @ -124,7 +122,7 @@ AWAbstractFormatter::FormatterClass AWFormatterHelper::defineFormatterClass(cons | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Define formatter class for" << _stringType; | ||||
|  | ||||
|     AWAbstractFormatter::FormatterClass formatter = AWAbstractFormatter::FormatterClass::NoFormat; | ||||
|     auto formatter = AWAbstractFormatter::FormatterClass::NoFormat; | ||||
|     if (_stringType == "DateTime") | ||||
|         formatter = AWAbstractFormatter::FormatterClass::DateTime; | ||||
|     else if (_stringType == "Float") | ||||
| @ -152,17 +150,17 @@ void AWFormatterHelper::initFormatters() | ||||
|  | ||||
|     auto dirs = directories(); | ||||
|     for (auto &dir : dirs) { | ||||
|         QStringList files = QDir(dir).entryList(QDir::Files, QDir::Name); | ||||
|         auto files = QDir(dir).entryList(QDir::Files, QDir::Name); | ||||
|         for (auto &file : files) { | ||||
|             // check filename | ||||
|             if (!file.endsWith(".desktop")) | ||||
|                 continue; | ||||
|             qCInfo(LOG_AW) << "Found file" << file << "in" << dir; | ||||
|             QString filePath = QString("%1/%2").arg(dir).arg(file); | ||||
|             auto filePath = QString("%1/%2").arg(dir, file); | ||||
|             // check if already exists | ||||
|             auto values = m_formattersClasses.values(); | ||||
|             if (std::any_of(values.cbegin(), values.cend(), | ||||
|                             [&filePath](const AWAbstractFormatter *item) { return (item->fileName() == filePath); })) | ||||
|                             [&filePath](auto item) { return (item->filePath() == filePath); })) | ||||
|                 continue; | ||||
|  | ||||
|             auto metadata = readMetadata(filePath); | ||||
| @ -199,42 +197,43 @@ QPair<QString, AWAbstractFormatter::FormatterClass> AWFormatterHelper::readMetad | ||||
|     qCDebug(LOG_AW) << "Read initial parameters from" << _filePath; | ||||
|  | ||||
|     QSettings settings(_filePath, QSettings::IniFormat); | ||||
|  | ||||
|     settings.beginGroup("Desktop Entry"); | ||||
|     QString name = settings.value("Name", _filePath).toString(); | ||||
|     QString type = settings.value("X-AW-Type", "NoFormat").toString(); | ||||
|     AWAbstractFormatter::FormatterClass formatter = defineFormatterClass(type); | ||||
|     auto name = settings.value("Name", _filePath).toString(); | ||||
|     auto type = settings.value("X-AW-Type", "NoFormat").toString(); | ||||
|     auto formatter = defineFormatterClass(type); | ||||
|     settings.endGroup(); | ||||
|  | ||||
|     return QPair<QString, AWAbstractFormatter::FormatterClass>(name, formatter); | ||||
|     return {name, formatter}; | ||||
| } | ||||
|  | ||||
|  | ||||
| void AWFormatterHelper::doCreateItem() | ||||
| void AWFormatterHelper::doCreateItem(QListWidget *_widget) | ||||
| { | ||||
|     QStringList selection = {"NoFormat", "DateTime", "Float", "List", "Script", "String", "Json"}; | ||||
|     bool ok; | ||||
|     QString select = QInputDialog::getItem(this, i18n("Select type"), i18n("Type:"), selection, 0, false, &ok); | ||||
|     auto select = QInputDialog::getItem(nullptr, i18n("Select type"), i18n("Type:"), selection, 0, false, &ok); | ||||
|     if (!ok) { | ||||
|         qCWarning(LOG_AW) << "No type selected"; | ||||
|         return; | ||||
|     } | ||||
|  | ||||
|     qCInfo(LOG_AW) << "Selected type" << select; | ||||
|     AWAbstractFormatter::FormatterClass formatter = defineFormatterClass(select); | ||||
|     auto formatter = defineFormatterClass(select); | ||||
|     switch (formatter) { | ||||
|     case AWAbstractFormatter::FormatterClass::DateTime: | ||||
|         return createItem<AWDateTimeFormatter>(); | ||||
|         return createItem<AWDateTimeFormatter>(_widget); | ||||
|     case AWAbstractFormatter::FormatterClass::Float: | ||||
|         return createItem<AWFloatFormatter>(); | ||||
|         return createItem<AWFloatFormatter>(_widget); | ||||
|     case AWAbstractFormatter::FormatterClass::List: | ||||
|         return createItem<AWListFormatter>(); | ||||
|         return createItem<AWListFormatter>(_widget); | ||||
|     case AWAbstractFormatter::FormatterClass::Script: | ||||
|         return createItem<AWScriptFormatter>(); | ||||
|         return createItem<AWScriptFormatter>(_widget); | ||||
|     case AWAbstractFormatter::FormatterClass::String: | ||||
|         return createItem<AWStringFormatter>(); | ||||
|         return createItem<AWStringFormatter>(_widget); | ||||
|     case AWAbstractFormatter::FormatterClass::Json: | ||||
|         return createItem<AWJsonFormatter>(); | ||||
|         return createItem<AWJsonFormatter>(_widget); | ||||
|     case AWAbstractFormatter::FormatterClass::NoFormat: | ||||
|         return createItem<AWNoFormatter>(); | ||||
|         return createItem<AWNoFormatter>(_widget); | ||||
|     } | ||||
| } | ||||
|  | ||||
| @ -15,9 +15,7 @@ | ||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||
|  ***************************************************************************/ | ||||
|  | ||||
|  | ||||
| #ifndef AWFORMATTERHELPER_H | ||||
| #define AWFORMATTERHELPER_H | ||||
| #pragma once | ||||
|  | ||||
| #include "abstractextitemaggregator.h" | ||||
| #include "awabstractformatter.h" | ||||
| @ -29,7 +27,7 @@ class AWFormatterHelper : public AbstractExtItemAggregator, public AWAbstractPai | ||||
|     Q_OBJECT | ||||
|  | ||||
| public: | ||||
|     explicit AWFormatterHelper(QWidget *_parent = nullptr); | ||||
|     explicit AWFormatterHelper(QObject *_parent = nullptr); | ||||
|     ~AWFormatterHelper() override; | ||||
|     // read-write methods | ||||
|     void initItems() override; | ||||
| @ -51,11 +49,8 @@ private: | ||||
|     void initFormatters(); | ||||
|     [[nodiscard]] static QPair<QString, AWAbstractFormatter::FormatterClass> readMetadata(const QString &_filePath); | ||||
|     // parent methods | ||||
|     void doCreateItem() override; | ||||
|     void doCreateItem(QListWidget *_widget) override; | ||||
|     // properties | ||||
|     QHash<QString, AWAbstractFormatter *> m_formatters; | ||||
|     QHash<QString, AWAbstractFormatter *> m_formattersClasses; | ||||
| }; | ||||
|  | ||||
|  | ||||
| #endif /* AWFORMATTERHELPER_H */ | ||||
|  | ||||
| @ -20,6 +20,7 @@ | ||||
|  | ||||
| #include <QDir> | ||||
| #include <QNetworkInterface> | ||||
| #include <QRegularExpression> | ||||
| #include <QSettings> | ||||
| #include <QStandardPaths> | ||||
|  | ||||
| @ -30,7 +31,7 @@ bool AWKeyCache::addKeyToCache(const QString &_type, const QString &_key) | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Key" << _key << "with type" << _type; | ||||
|  | ||||
|     QString fileName | ||||
|     auto fileName | ||||
|         = QString("%1/awesomewidgets.ndx").arg(QStandardPaths::writableLocation(QStandardPaths::GenericCacheLocation)); | ||||
|     qCInfo(LOG_AW) << "Cache file" << fileName; | ||||
|     QSettings cache(fileName, QSettings::IniFormat); | ||||
| @ -40,21 +41,10 @@ bool AWKeyCache::addKeyToCache(const QString &_type, const QString &_key) | ||||
|     for (auto &number : cache.allKeys()) | ||||
|         cachedValues.append(cache.value(number).toString()); | ||||
|  | ||||
|     if (_type == "hdd") { | ||||
|         QStringList allDevices = QDir("/dev").entryList(QDir::System, QDir::Name); | ||||
|         QStringList devices = allDevices.filter(QRegExp("^[hms]d[a-z]$")); | ||||
|         for (auto &dev : devices) { | ||||
|             QString device = QString("/dev/%1").arg(dev); | ||||
|             if (cachedValues.contains(device)) | ||||
|                 continue; | ||||
|             qCInfo(LOG_AW) << "Found new key" << device << "for type" << _type; | ||||
|             cachedValues.append(device); | ||||
|             cache.setValue(QString("%1").arg(cache.allKeys().count(), 3, 10, QChar('0')), device); | ||||
|         } | ||||
|     } else if (_type == "net") { | ||||
|         QList<QNetworkInterface> rawInterfaceList = QNetworkInterface::allInterfaces(); | ||||
|     if (_type == "net") { | ||||
|         auto rawInterfaceList = QNetworkInterface::allInterfaces(); | ||||
|         for (auto &interface : rawInterfaceList) { | ||||
|             QString device = interface.name(); | ||||
|             auto device = interface.name(); | ||||
|             if (cachedValues.contains(device)) | ||||
|                 continue; | ||||
|             qCInfo(LOG_AW) << "Found new key" << device << "for type" << _type; | ||||
| @ -84,66 +74,27 @@ QStringList AWKeyCache::getRequiredKeys(const QStringList &_keys, const QStringL | ||||
|     used.unite(QSet(_bars.cbegin(), _bars.cend())); | ||||
|     used.unite(QSet(_userKeys.cbegin(), _userKeys.cend())); | ||||
|     // insert keys from tooltip | ||||
|     for (auto &key : _tooltip.keys()) { | ||||
|         if ((key.endsWith("Tooltip")) && (_tooltip[key].toBool())) { | ||||
|             key.remove("Tooltip"); | ||||
|             used << key; | ||||
|     for (auto [key, value] : _tooltip.asKeyValueRange()) { | ||||
|         if ((key.endsWith("Tooltip")) && value.toBool()) { | ||||
|             auto local = key; | ||||
|             local.remove("Tooltip"); | ||||
|             used << local; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     // insert depending keys, refer to AWKeys::calculateValues() | ||||
|     // hddtotmb* | ||||
|     for (auto &key : _allKeys.filter(QRegExp("^hddtotmb"))) { | ||||
|         if (!used.contains(key)) | ||||
|             continue; | ||||
|         key.remove("hddtotmb"); | ||||
|         int index = key.toInt(); | ||||
|         used << QString("hddfreemb%1").arg(index) << QString("hddmb%1").arg(index); | ||||
|     } | ||||
|     // hddtotgb* | ||||
|     for (auto &key : _allKeys.filter(QRegExp("^hddtotgb"))) { | ||||
|         if (!used.contains(key)) | ||||
|             continue; | ||||
|         key.remove("hddtotgb"); | ||||
|         int index = key.toInt(); | ||||
|         used << QString("hddfreegb%1").arg(index) << QString("hddgb%1").arg(index); | ||||
|     } | ||||
|     // mem | ||||
|     if (used.contains("mem")) | ||||
|         used << "memmb" | ||||
|              << "memtotmb"; | ||||
|     // memtotmb | ||||
|     if (used.contains("memtotmb")) | ||||
|         used << "memusedmb" | ||||
|              << "memfreemb"; | ||||
|     // memtotgb | ||||
|     if (used.contains("memtotgb")) | ||||
|         used << "memusedgb" | ||||
|              << "memfreegb"; | ||||
|     // swap | ||||
|     if (used.contains("swap")) | ||||
|         used << "swapmb" | ||||
|              << "swaptotmb"; | ||||
|     // swaptotmb | ||||
|     if (used.contains("swaptotmb")) | ||||
|         used << "swapmb" | ||||
|              << "swapfreemb"; | ||||
|     // memtotgb | ||||
|     if (used.contains("swaptotgb")) | ||||
|         used << "swapgb" | ||||
|              << "swapfreegb"; | ||||
|     // insert keys which depend on others, refer to AWKeys::calculateValues() | ||||
|     // network keys | ||||
|     QStringList netKeys( | ||||
|         {"up", "upkb", "uptot", "uptotkb", "upunits", "down", "downkb", "downtot", "downtotkb", "downunits"}); | ||||
|     for (auto &key : netKeys) { | ||||
|         if (!used.contains(key)) | ||||
|             continue; | ||||
|         QStringList filt = _allKeys.filter(QRegExp(QString("^%1[0-9]{1,}").arg(key))); | ||||
|         auto filt = _allKeys.filter(QRegularExpression(QString("^%1[0-9]{1,}").arg(key))); | ||||
|         for (auto &filtered : filt) | ||||
|             used << filtered; | ||||
|     } | ||||
|     // netdev key | ||||
|     if (std::any_of(netKeys.cbegin(), netKeys.cend(), [&used](const QString &key) { return used.contains(key); })) | ||||
|     if (std::any_of(netKeys.cbegin(), netKeys.cend(), [&used](auto &key) { return used.contains(key); })) | ||||
|         used << "netdev"; | ||||
|  | ||||
|     // HACK append dummy if there are no other keys. This hack is required | ||||
| @ -155,18 +106,23 @@ QStringList AWKeyCache::getRequiredKeys(const QStringList &_keys, const QStringL | ||||
| } | ||||
|  | ||||
|  | ||||
| QHash<QString, QStringList> AWKeyCache::loadKeysFromCache() | ||||
| AWPluginMatcherSettings AWKeyCache::loadKeysFromCache() | ||||
| { | ||||
|     QString fileName | ||||
|     auto fileName | ||||
|         = QString("%1/awesomewidgets.ndx").arg(QStandardPaths::writableLocation(QStandardPaths::GenericCacheLocation)); | ||||
|     qCInfo(LOG_AW) << "Cache file" << fileName; | ||||
|     QSettings cache(fileName, QSettings::IniFormat); | ||||
|  | ||||
|     QHash<QString, QStringList> devices; | ||||
|     for (auto &group : cache.childGroups()) { | ||||
|     AWPluginMatcherSettings devices; | ||||
|     QHash<QString, QStringList *> groups = { | ||||
|         {"disk", &devices.disk},   {"gpu", &devices.gpu},      {"mount", &devices.mount}, | ||||
|         {"net", &devices.network}, {"temp", &devices.sensors}, | ||||
|     }; | ||||
|  | ||||
|     for (auto [group, list] : groups.asKeyValueRange()) { | ||||
|         cache.beginGroup(group); | ||||
|         for (auto &key : cache.allKeys()) | ||||
|             devices[group].append(cache.value(key).toString()); | ||||
|             list->append(cache.value(key).toString()); | ||||
|         cache.endGroup(); | ||||
|     } | ||||
|  | ||||
|  | ||||
| @ -15,22 +15,18 @@ | ||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||
|  ***************************************************************************/ | ||||
|  | ||||
| #pragma once | ||||
|  | ||||
| #ifndef AWKEYCACHE_H | ||||
| #define AWKEYCACHE_H | ||||
|  | ||||
| #include <QHash> | ||||
| #include <QString> | ||||
| #include <QVariant> | ||||
|  | ||||
| #include <matchers/awpluginmatchersettings.h> | ||||
|  | ||||
|  | ||||
| namespace AWKeyCache | ||||
| { | ||||
| bool addKeyToCache(const QString &_type, const QString &_key = ""); | ||||
| QStringList getRequiredKeys(const QStringList &_keys, const QStringList &_bars, const QVariantMap &_tooltip, | ||||
|                             const QStringList &_userKeys, const QStringList &_allKeys); | ||||
| QHash<QString, QStringList> loadKeysFromCache(); | ||||
| AWPluginMatcherSettings loadKeysFromCache(); | ||||
| } // namespace AWKeyCache | ||||
|  | ||||
|  | ||||
| #endif /* AWKEYCACHE_H */ | ||||
|  | ||||
| @ -18,7 +18,7 @@ | ||||
| #include "awkeyoperations.h" | ||||
|  | ||||
| #include <QDir> | ||||
| #include <QRegExp> | ||||
| #include <QRegularExpression> | ||||
| #include <QThread> | ||||
|  | ||||
| #include "awcustomkeyshelper.h" | ||||
| @ -40,30 +40,16 @@ AWKeyOperations::AWKeyOperations(QObject *_parent) | ||||
|     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; | ||||
|  | ||||
|     m_customKeys = new AWCustomKeysHelper(this); | ||||
|     m_graphicalItems = new ExtItemAggregator<GraphicalItem>(nullptr, "desktops"); | ||||
|     m_extNetRequest = new ExtItemAggregator<ExtNetworkRequest>(nullptr, "requests"); | ||||
|     m_extQuotes = new ExtItemAggregator<ExtQuotes>(nullptr, "quotes"); | ||||
|     m_extScripts = new ExtItemAggregator<ExtScript>(nullptr, "scripts"); | ||||
|     m_extUpgrade = new ExtItemAggregator<ExtUpgrade>(nullptr, "upgrade"); | ||||
|     m_extWeather = new ExtItemAggregator<ExtWeather>(nullptr, "weather"); | ||||
|     m_graphicalItems = new ExtItemAggregator<GraphicalItem>(this, "desktops"); | ||||
|     m_extNetRequest = new ExtItemAggregator<ExtNetworkRequest>(this, "requests"); | ||||
|     m_extQuotes = new ExtItemAggregator<ExtQuotes>(this, "quotes"); | ||||
|     m_extScripts = new ExtItemAggregator<ExtScript>(this, "scripts"); | ||||
|     m_extUpgrade = new ExtItemAggregator<ExtUpgrade>(this, "upgrade"); | ||||
|     m_extWeather = new ExtItemAggregator<ExtWeather>(this, "weather"); | ||||
| } | ||||
|  | ||||
|  | ||||
| AWKeyOperations::~AWKeyOperations() | ||||
| { | ||||
|     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; | ||||
| } | ||||
|  | ||||
|  | ||||
| QStringList AWKeyOperations::devices(const QString &_type) const | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Looking for type" << _type; | ||||
|  | ||||
|     return m_devices[_type]; | ||||
| } | ||||
|  | ||||
|  | ||||
| QHash<QString, QStringList> AWKeyOperations::devices() const | ||||
| AWPluginMatcherSettings AWKeyOperations::devices() const | ||||
| { | ||||
|     return m_devices; | ||||
| } | ||||
| @ -72,7 +58,6 @@ QHash<QString, QStringList> AWKeyOperations::devices() const | ||||
| void AWKeyOperations::updateCache() | ||||
| { | ||||
|     // update network and hdd list | ||||
|     addKeyToCache("hdd"); | ||||
|     addKeyToCache("net"); | ||||
| } | ||||
|  | ||||
| @ -81,7 +66,7 @@ QStringList AWKeyOperations::dictKeys() const | ||||
| { | ||||
|     QStringList allKeys; | ||||
|     // weather | ||||
|     for (auto &item : m_extWeather->activeItems()) { | ||||
|     for (auto item : m_extWeather->activeItems()) { | ||||
|         allKeys.append(item->tag("weatherId")); | ||||
|         allKeys.append(item->tag("weather")); | ||||
|         allKeys.append(item->tag("humidity")); | ||||
| @ -90,15 +75,20 @@ QStringList AWKeyOperations::dictKeys() const | ||||
|         allKeys.append(item->tag("timestamp")); | ||||
|     } | ||||
|     // cpuclock & cpu | ||||
|     for (int i = 0; i < QThread::idealThreadCount(); i++) { | ||||
|     for (auto i = 0; i < QThread::idealThreadCount(); ++i) { | ||||
|         allKeys.append(QString("cpucl%1").arg(i)); | ||||
|         allKeys.append(QString("cpu%1").arg(i)); | ||||
|     } | ||||
|     // temperature | ||||
|     for (int i = 0; i < m_devices["temp"].count(); i++) | ||||
|     for (auto i = 0; i < m_devices.sensors.count(); ++i) | ||||
|         allKeys.append(QString("temp%1").arg(i)); | ||||
|     // gpu | ||||
|     for (auto i = 0; i < m_devices.gpu.count(); ++i) { | ||||
|         allKeys.append(QString("gpu%1").arg(i)); | ||||
|         allKeys.append(QString("gputemp%1").arg(i)); | ||||
|     } | ||||
|     // hdd | ||||
|     for (int i = 0; i < m_devices["mount"].count(); i++) { | ||||
|     for (auto i = 0; i < m_devices.mount.count(); ++i) { | ||||
|         allKeys.append(QString("hddmb%1").arg(i)); | ||||
|         allKeys.append(QString("hddgb%1").arg(i)); | ||||
|         allKeys.append(QString("hddfreemb%1").arg(i)); | ||||
| @ -108,15 +98,12 @@ QStringList AWKeyOperations::dictKeys() const | ||||
|         allKeys.append(QString("hdd%1").arg(i)); | ||||
|     } | ||||
|     // hdd speed | ||||
|     for (int i = 0; i < m_devices["disk"].count(); i++) { | ||||
|     for (auto i = 0; i < m_devices.disk.count(); ++i) { | ||||
|         allKeys.append(QString("hddr%1").arg(i)); | ||||
|         allKeys.append(QString("hddw%1").arg(i)); | ||||
|     } | ||||
|     // hdd temp | ||||
|     for (int i = 0; i < m_devices["hdd"].count(); i++) | ||||
|         allKeys.append(QString("hddtemp%1").arg(i)); | ||||
|     // network | ||||
|     for (int i = 0; i < m_devices["net"].count(); i++) { | ||||
|     for (auto i = 0; i < m_devices.network.count(); ++i) { | ||||
|         allKeys.append(QString("downunits%1").arg(i)); | ||||
|         allKeys.append(QString("upunits%1").arg(i)); | ||||
|         allKeys.append(QString("downtotkb%1").arg(i)); | ||||
| @ -129,10 +116,9 @@ QStringList AWKeyOperations::dictKeys() const | ||||
|         allKeys.append(QString("up%1").arg(i)); | ||||
|     } | ||||
|     // battery | ||||
|     QStringList allBatteryDevices | ||||
|         = QDir("/sys/class/power_supply") | ||||
|               .entryList(QStringList({"BAT*"}), QDir::Dirs | QDir::NoDotAndDotDot, QDir::Name); | ||||
|     for (int i = 0; i < allBatteryDevices.count(); i++) { | ||||
|     auto allBatteryDevices = QDir("/sys/class/power_supply") | ||||
|                                  .entryList(QStringList({"BAT*"}), QDir::Dirs | QDir::NoDotAndDotDot, QDir::Name); | ||||
|     for (int i = 0; i < allBatteryDevices.count(); ++i) { | ||||
|         allKeys.append(QString("bat%1").arg(i)); | ||||
|         allKeys.append(QString("batleft%1").arg(i)); | ||||
|         allKeys.append(QString("batnow%1").arg(i)); | ||||
| @ -140,10 +126,10 @@ QStringList AWKeyOperations::dictKeys() const | ||||
|         allKeys.append(QString("battotal%1").arg(i)); | ||||
|     } | ||||
|     // package manager | ||||
|     for (auto &item : m_extUpgrade->activeItems()) | ||||
|     for (auto item : m_extUpgrade->activeItems()) | ||||
|         allKeys.append(item->tag("pkgcount")); | ||||
|     // quotes | ||||
|     for (auto &item : m_extQuotes->activeItems()) { | ||||
|     for (auto item : m_extQuotes->activeItems()) { | ||||
|         allKeys.append(item->tag("price")); | ||||
|         allKeys.append(item->tag("pricechg")); | ||||
|         allKeys.append(item->tag("percpricechg")); | ||||
| @ -152,13 +138,13 @@ QStringList AWKeyOperations::dictKeys() const | ||||
|         allKeys.append(item->tag("percvolumechg")); | ||||
|     } | ||||
|     // custom | ||||
|     for (auto &item : m_extScripts->activeItems()) | ||||
|     for (auto item : m_extScripts->activeItems()) | ||||
|         allKeys.append(item->tag("custom")); | ||||
|     // network requests | ||||
|     for (auto &item : m_extNetRequest->activeItems()) | ||||
|     for (auto item : m_extNetRequest->activeItems()) | ||||
|         allKeys.append(item->tag("response")); | ||||
|     // bars | ||||
|     for (auto &item : m_graphicalItems->activeItems()) | ||||
|     for (auto item : m_graphicalItems->activeItems()) | ||||
|         allKeys.append(item->tag("bar")); | ||||
|     // user defined keys | ||||
|     allKeys.append(m_customKeys->keys()); | ||||
| @ -205,52 +191,58 @@ QString AWKeyOperations::infoByKey(const QString &_key) const | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Requested key" << _key; | ||||
|  | ||||
|     QString stripped = _key; | ||||
|     stripped.remove(QRegExp("\\d+")); | ||||
|     static auto numberRegExp = QRegularExpression("\\d+"); | ||||
|  | ||||
|     auto stripped = _key; | ||||
|     stripped.remove(numberRegExp); | ||||
|     QString output; | ||||
|  | ||||
|     static auto hddRegExp = QRegularExpression("^hdd(|mb|gb|freemb|freegb|totmb|totgb)"); | ||||
|     static auto hddrwRegExp = QRegularExpression("^hdd[rw]"); | ||||
|     static auto hddMatchRegExp = QRegularExpression("^hdd([0-9]|mb|gb|freemb|freegb|totmb|totgb)"); | ||||
|     static auto netRegExp = QRegularExpression("^(down|up)"); | ||||
|     static auto netMatchRegExp = QRegularExpression("^(down|up)[0-9]"); | ||||
|     static auto quotesRegExp = QRegularExpression("^(|perc)(ask|bid|price)(chg|)"); | ||||
|     static auto weatherRegExp = QRegularExpression("^(weather|weatherId|humidity|pressure|temperature)"); | ||||
|  | ||||
|     if (_key.startsWith("bar")) { | ||||
|         AbstractExtItem *item = m_graphicalItems->itemByTag(_key, stripped); | ||||
|         auto item = m_graphicalItems->itemByTag(_key, stripped); | ||||
|         if (item) | ||||
|             output = item->uniq(); | ||||
|     } else if (_key.startsWith("custom")) { | ||||
|         AbstractExtItem *item = m_extScripts->itemByTag(_key, stripped); | ||||
|         auto item = m_extScripts->itemByTag(_key, stripped); | ||||
|         if (item) | ||||
|             output = item->uniq(); | ||||
|     } else if (_key.contains(QRegExp("^hdd[rw]"))) { | ||||
|         QString index = _key; | ||||
|         index.remove(QRegExp("hdd[rw]")); | ||||
|         output = m_devices["disk"][index.toInt()]; | ||||
|     } else if (_key.contains(QRegExp("^hdd([0-9]|mb|gb|freemb|freegb|totmb|totgb)"))) { | ||||
|         QString index = _key; | ||||
|         index.remove(QRegExp("^hdd(|mb|gb|freemb|freegb|totmb|totgb)")); | ||||
|         output = m_devices["mount"][index.toInt()]; | ||||
|     } else if (_key.startsWith("hddtemp")) { | ||||
|         QString index = _key; | ||||
|         index.remove("hddtemp"); | ||||
|         output = m_devices["hdd"][index.toInt()]; | ||||
|     } else if (_key.contains(QRegExp("^(down|up)[0-9]"))) { | ||||
|         QString index = _key; | ||||
|         index.remove(QRegExp("^(down|up)")); | ||||
|         output = m_devices["net"][index.toInt()]; | ||||
|     } else if (_key.contains(hddrwRegExp)) { | ||||
|         auto index = _key; | ||||
|         index.remove(hddrwRegExp); | ||||
|         output = m_devices.disk[index.toInt()]; | ||||
|     } else if (_key.contains(hddMatchRegExp)) { | ||||
|         auto index = _key; | ||||
|         index.remove(hddRegExp); | ||||
|         output = m_devices.mount[index.toInt()]; | ||||
|     } else if (_key.contains(netMatchRegExp)) { | ||||
|         auto index = _key; | ||||
|         index.remove(netRegExp); | ||||
|         output = m_devices.network[index.toInt()]; | ||||
|     } else if (_key.startsWith("pkgcount")) { | ||||
|         AbstractExtItem *item = m_extUpgrade->itemByTag(_key, stripped); | ||||
|         auto item = m_extUpgrade->itemByTag(_key, stripped); | ||||
|         if (item) | ||||
|             output = item->uniq(); | ||||
|     } else if (_key.contains(QRegExp("(^|perc)(ask|bid|price)(chg|)"))) { | ||||
|         AbstractExtItem *item = m_extQuotes->itemByTag(_key, stripped); | ||||
|     } else if (_key.contains(quotesRegExp)) { | ||||
|         auto item = m_extQuotes->itemByTag(_key, stripped); | ||||
|         if (item) | ||||
|             output = item->uniq(); | ||||
|     } else if (_key.contains(QRegExp("(weather|weatherId|humidity|pressure|temperature)"))) { | ||||
|         AbstractExtItem *item = m_extWeather->itemByTag(_key, stripped); | ||||
|     } else if (_key.contains(weatherRegExp)) { | ||||
|         auto item = m_extWeather->itemByTag(_key, stripped); | ||||
|         if (item) | ||||
|             output = item->uniq(); | ||||
|     } else if (_key.startsWith("temp")) { | ||||
|         QString index = _key; | ||||
|         auto index = _key; | ||||
|         index.remove("temp"); | ||||
|         output = m_devices["temp"][index.toInt()]; | ||||
|         output = m_devices.sensors[index.toInt()]; | ||||
|     } else if (_key.startsWith("response")) { | ||||
|         AbstractExtItem *item = m_extNetRequest->itemByTag(_key, stripped); | ||||
|         auto item = m_extNetRequest->itemByTag(_key, stripped); | ||||
|         if (item) | ||||
|             output = item->uniq(); | ||||
|     } else { | ||||
| @ -279,8 +271,10 @@ void AWKeyOperations::editItem(const QString &_type) | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Item type" << _type; | ||||
|  | ||||
|     static auto supportsGraphicalRegExp = QRegularExpression("^(cpu(?!cl).*|gpu$|mem$|swap$|hdd[0-9].*|bat.*)"); | ||||
|  | ||||
|     if (_type == "graphicalitem") { | ||||
|         QStringList keys = dictKeys().filter(QRegExp("^(cpu(?!cl).*|gpu$|mem$|swap$|hdd[0-9].*|bat.*)")); | ||||
|         auto keys = dictKeys().filter(supportsGraphicalRegExp); | ||||
|         keys.sort(); | ||||
|         m_graphicalItems->setConfigArgs(keys); | ||||
|         return m_graphicalItems->editItems(); | ||||
| @ -302,19 +296,26 @@ void AWKeyOperations::addDevice(const QString &_source) | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Source" << _source; | ||||
|  | ||||
|     QRegExp diskRegexp = QRegExp("disk/(?:md|sd|hd)[a-z|0-9]_.*/Rate/(?:rblk)"); | ||||
|     QRegExp mountRegexp = QRegExp("partitions/.*/filllevel"); | ||||
|     static auto diskRegexp = QRegularExpression("^disk/.*/read$"); | ||||
|     static auto mountRegexp = QRegularExpression("^disk/.*/usedPercent$"); | ||||
|     static auto cpuTempRegExp = QRegularExpression("^cpu/cpu.*/temperature$"); | ||||
|     static auto gpuRegExp = QRegularExpression("^gpu/gpu.*/usage$"); | ||||
|  | ||||
|     if (_source.contains(diskRegexp)) { | ||||
|         QString device = _source; | ||||
|         device.remove("/Rate/rblk"); | ||||
|         auto device = _source; | ||||
|         device.remove("disk/").remove("/read"); | ||||
|         addKeyToCache("disk", device); | ||||
|     } else if (_source.contains(mountRegexp)) { | ||||
|         QString device = _source; | ||||
|         device.remove("partitions").remove("/filllevel"); | ||||
|         auto device = _source; | ||||
|         device.remove("disk/").remove("/usedPercent"); | ||||
|         addKeyToCache("mount", device); | ||||
|     } else if (_source.startsWith("lmsensors")) { | ||||
|     } else if (_source.startsWith("lmsensors") || _source.contains(cpuTempRegExp) | ||||
|                || _source == "cpu/all/averageTemperature") { | ||||
|         addKeyToCache("temp", _source); | ||||
|     } else if (_source.contains(gpuRegExp)) { | ||||
|         auto device = _source; | ||||
|         device.remove("gpu/").remove("/usage"); | ||||
|         addKeyToCache("gpu", device); | ||||
|     } | ||||
| } | ||||
|  | ||||
| @ -341,7 +342,7 @@ void AWKeyOperations::reinitKeys() | ||||
|     m_extWeather->initItems(); | ||||
|  | ||||
|     // init | ||||
|     QStringList allKeys = dictKeys(); | ||||
|     auto allKeys = dictKeys(); | ||||
|  | ||||
|     // apply aw_* functions | ||||
|     m_pattern = AWPatternFunctions::insertAllKeys(m_pattern, allKeys); | ||||
|  | ||||
| @ -15,13 +15,12 @@ | ||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||
|  ***************************************************************************/ | ||||
|  | ||||
|  | ||||
| #ifndef AWKEYOPERATIONS_H | ||||
| #define AWKEYOPERATIONS_H | ||||
| #pragma once | ||||
|  | ||||
| #include <QObject> | ||||
|  | ||||
| #include "extitemaggregator.h" | ||||
| #include "matchers/awpluginmatchersettings.h" | ||||
|  | ||||
|  | ||||
| class AWCustomKeysHelper; | ||||
| @ -39,9 +38,8 @@ class AWKeyOperations : public QObject | ||||
|  | ||||
| public: | ||||
|     explicit AWKeyOperations(QObject *_parent = nullptr); | ||||
|     ~AWKeyOperations() override; | ||||
|     [[nodiscard]] QStringList devices(const QString &_type) const; | ||||
|     [[nodiscard]] QHash<QString, QStringList> devices() const; | ||||
|     ~AWKeyOperations() override = default; | ||||
|     [[nodiscard]] AWPluginMatcherSettings devices() const; | ||||
|     void updateCache(); | ||||
|     // keys | ||||
|     [[nodiscard]] QStringList dictKeys() const; | ||||
| @ -75,9 +73,6 @@ private: | ||||
|     ExtItemAggregator<ExtUpgrade> *m_extUpgrade = nullptr; | ||||
|     ExtItemAggregator<ExtWeather> *m_extWeather = nullptr; | ||||
|     // variables | ||||
|     QHash<QString, QStringList> m_devices; | ||||
|     AWPluginMatcherSettings m_devices; | ||||
|     QString m_pattern; | ||||
| }; | ||||
|  | ||||
|  | ||||
| #endif /* AWKEYOPERATIONS_H */ | ||||
|  | ||||
| @ -19,9 +19,8 @@ | ||||
|  | ||||
| #include <QDBusConnection> | ||||
| #include <QDBusError> | ||||
| #include <QThread> | ||||
| #include <QRegularExpression> | ||||
| #include <QTimer> | ||||
| #include <QtConcurrent/QtConcurrent> | ||||
|  | ||||
| #include "awdataaggregator.h" | ||||
| #include "awdataengineaggregator.h" | ||||
| @ -42,9 +41,6 @@ AWKeys::AWKeys(QObject *_parent) | ||||
|     for (auto &metadata : AWDebug::getBuildData()) | ||||
|         qCDebug(LOG_AW) << metadata; | ||||
|  | ||||
|     // thread pool | ||||
|     m_threadPool = new QThreadPool(this); | ||||
|  | ||||
|     m_aggregator = new AWKeysAggregator(this); | ||||
|     m_dataAggregator = new AWDataAggregator(this); | ||||
|     m_dataEngineAggregator = new AWDataEngineAggregator(this); | ||||
| @ -56,16 +52,17 @@ AWKeys::AWKeys(QObject *_parent) | ||||
|     createDBusInterface(); | ||||
|  | ||||
|     // update key data if required | ||||
|     connect(m_keyOperator, SIGNAL(updateKeys(const QStringList &)), this, SLOT(reinitKeys(const QStringList &))); | ||||
|     connect(m_timer, SIGNAL(timeout()), this, SLOT(updateTextData())); | ||||
|     connect(m_keyOperator, &AWKeyOperations::updateKeys, this, &AWKeys::reinitKeys); | ||||
|     connect(m_timer, &QTimer::timeout, this, &AWKeys::updateTextData); | ||||
|  | ||||
|     // transfer signal from AWDataAggregator object to QML ui | ||||
|     connect(m_dataAggregator, SIGNAL(toolTipPainted(const QString &)), this, | ||||
|             SIGNAL(needToolTipToBeUpdated(const QString &))); | ||||
|     connect(this, SIGNAL(dropSourceFromDataengine(const QString &)), m_dataEngineAggregator, | ||||
|             SLOT(dropSource(const QString &))); | ||||
|     connect(m_dataAggregator, &AWDataAggregator::toolTipPainted, | ||||
|             [this](const QString &_tooltip) { emit(needToolTipToBeUpdated(_tooltip)); }); | ||||
|  | ||||
|     connect(this, &AWKeys::dropSourceFromDataengine, m_dataEngineAggregator, &AWDataEngineAggregator::dropSource); | ||||
|     connect(m_dataEngineAggregator, &AWDataEngineAggregator::dataUpdated, this, &AWKeys::dataUpdated); | ||||
|     // transfer signal from dataengine to update source list | ||||
|     connect(m_dataEngineAggregator, SIGNAL(deviceAdded(const QString &)), m_keyOperator, | ||||
|             SLOT(addDevice(const QString &))); | ||||
|     connect(m_dataEngineAggregator, &AWDataEngineAggregator::deviceAdded, m_keyOperator, &AWKeyOperations::addDevice); | ||||
| } | ||||
|  | ||||
|  | ||||
| @ -90,19 +87,17 @@ void AWKeys::initDataAggregator(const QVariantMap &_tooltipParams) | ||||
| } | ||||
|  | ||||
|  | ||||
| void AWKeys::initKeys(const QString &_currentPattern, const int _interval, const int _limit, const bool _optimize) | ||||
| void AWKeys::initKeys(const QString &_currentPattern, const int _interval, const bool _optimize) | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Pattern" << _currentPattern << "with interval" << _interval << "and queue limit" << _limit | ||||
|                     << "with optimization" << _optimize; | ||||
|     qCDebug(LOG_AW) << "Pattern" << _currentPattern << "with interval" << _interval << "with optimization" << _optimize; | ||||
|  | ||||
|     // init | ||||
|     m_optimize = _optimize; | ||||
|     m_threadPool->setMaxThreadCount(_limit == 0 ? QThread::idealThreadCount() : _limit); | ||||
|     // child objects | ||||
|     m_aggregator->initFormatters(); | ||||
|     m_keyOperator->setPattern(_currentPattern); | ||||
|     m_keyOperator->updateCache(); | ||||
|     m_dataEngineAggregator->reconnectSources(_interval); | ||||
|     m_dataEngineAggregator->loadSources(); | ||||
|  | ||||
|     // timer | ||||
|     m_timer->setInterval(_interval); | ||||
| @ -148,27 +143,7 @@ QStringList AWKeys::dictKeys(const bool _sorted, const QString &_regexp) const | ||||
|     if (_sorted) | ||||
|         allKeys.sort(); | ||||
|  | ||||
|     return allKeys.filter(QRegExp(_regexp)); | ||||
| } | ||||
|  | ||||
|  | ||||
| QVariantList AWKeys::getHddDevices() const | ||||
| { | ||||
|     QStringList hddDevices = m_keyOperator->devices("hdd"); | ||||
|     // required by selector in the UI | ||||
|     hddDevices.insert(0, "disable"); | ||||
|     hddDevices.insert(0, "auto"); | ||||
|  | ||||
|     // build model | ||||
|     QVariantList devices; | ||||
|     for (auto &device : hddDevices) { | ||||
|         QVariantMap model; | ||||
|         model["label"] = device; | ||||
|         model["name"] = device; | ||||
|         devices.append(model); | ||||
|     } | ||||
|  | ||||
|     return devices; | ||||
|     return allKeys.filter(QRegularExpression(_regexp)); | ||||
| } | ||||
|  | ||||
|  | ||||
| @ -185,9 +160,9 @@ QString AWKeys::valueByKey(const QString &_key) const | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Requested value for key" << _key; | ||||
|  | ||||
|     QString trueKey = _key.startsWith("bar") ? m_keyOperator->infoByKey(_key) : _key; | ||||
|     auto realKey = _key.startsWith("bar") ? m_keyOperator->infoByKey(_key) : _key; | ||||
|  | ||||
|     return m_aggregator->formatter(m_values[trueKey], trueKey, true); | ||||
|     return m_aggregator->formatter(m_values[realKey], realKey, true); | ||||
| } | ||||
|  | ||||
|  | ||||
| @ -199,10 +174,16 @@ void AWKeys::editItem(const QString &_type) | ||||
| } | ||||
|  | ||||
|  | ||||
| void AWKeys::dataUpdated(const QString &_sourceName, const Plasma::DataEngine::Data &_data) | ||||
| void AWKeys::dataUpdated(const QHash<QString, KSysGuard::SensorInfo> &_sensors, const KSysGuard::SensorDataList &_data) | ||||
| { | ||||
|     // run concurrent data update | ||||
|     QtConcurrent::run(m_threadPool, this, &AWKeys::setDataBySource, _sourceName, _data); | ||||
|     qCDebug(LOG_AW) << "Update data for" << _data.count() << "items"; | ||||
|  | ||||
|     for (auto &data : _data) { | ||||
|         if (!_sensors.contains(data.sensorProperty)) | ||||
|             continue; | ||||
|         auto sensor = _sensors[data.sensorProperty]; | ||||
|         setDataBySource(data.sensorProperty, sensor, data.payload); | ||||
|     } | ||||
| } | ||||
|  | ||||
|  | ||||
| @ -217,7 +198,7 @@ void AWKeys::reinitKeys(const QStringList &_currentKeys) | ||||
|     // generate list of required keys for bars | ||||
|     QStringList barKeys; | ||||
|     for (auto &bar : m_foundBars) { | ||||
|         GraphicalItem *item = m_keyOperator->giByKey(bar); | ||||
|         auto item = m_keyOperator->giByKey(bar); | ||||
|         if (item->isCustom()) | ||||
|             item->setUsedKeys(AWPatternFunctions::findKeys(item->bar(), _currentKeys, false)); | ||||
|         else | ||||
| @ -237,12 +218,10 @@ void AWKeys::reinitKeys(const QStringList &_currentKeys) | ||||
| void AWKeys::updateTextData() | ||||
| { | ||||
|     // do not do it in parallel to avoid race condition | ||||
|     m_mutex.lock(); | ||||
|     calculateValues(); | ||||
|     QString text = parsePattern(m_keyOperator->pattern()); | ||||
|     auto text = parsePattern(m_keyOperator->pattern()); | ||||
|     // update tooltip values under lock | ||||
|     m_dataAggregator->dataUpdate(m_values); | ||||
|     m_mutex.unlock(); | ||||
|  | ||||
|     emit(needTextToBeUpdated(text)); | ||||
| } | ||||
| @ -252,24 +231,10 @@ void AWKeys::updateTextData() | ||||
| // specified pattern. Usually they are values which depend on several others | ||||
| void AWKeys::calculateValues() | ||||
| { | ||||
|     // hddtot* | ||||
|     QStringList mountDevices = m_keyOperator->devices("mount"); | ||||
|     for (auto &device : mountDevices) { | ||||
|         int index = mountDevices.indexOf(device); | ||||
|         m_values[QString("hddtotmb%1").arg(index)] | ||||
|             = m_values[QString("hddfreemb%1").arg(index)].toFloat() + m_values[QString("hddmb%1").arg(index)].toFloat(); | ||||
|         m_values[QString("hddtotgb%1").arg(index)] | ||||
|             = m_values[QString("hddfreegb%1").arg(index)].toFloat() + m_values[QString("hddgb%1").arg(index)].toFloat(); | ||||
|     } | ||||
|  | ||||
|     // memtot* | ||||
|     m_values["memtotmb"] = m_values["memusedmb"].toInt() + m_values["memfreemb"].toInt(); | ||||
|     m_values["memtotgb"] = m_values["memusedgb"].toFloat() + m_values["memfreegb"].toFloat(); | ||||
|     // mem | ||||
|     m_values["mem"] = 100.0f * m_values["memmb"].toFloat() / m_values["memtotmb"].toFloat(); | ||||
|     auto devices = m_keyOperator->devices(); | ||||
|  | ||||
|     // up, down, upkb, downkb, upunits, downunits | ||||
|     int netIndex = m_keyOperator->devices("net").indexOf(m_values["netdev"].toString()); | ||||
|     auto netIndex = devices.network.indexOf(m_values["netdev"].toString()); | ||||
|     m_values["down"] = m_values[QString("down%1").arg(netIndex)]; | ||||
|     m_values["downkb"] = m_values[QString("downkb%1").arg(netIndex)]; | ||||
|     m_values["downtot"] = m_values[QString("downtot%1").arg(netIndex)]; | ||||
| @ -281,12 +246,6 @@ void AWKeys::calculateValues() | ||||
|     m_values["uptotkb"] = m_values[QString("uptotkb%1").arg(netIndex)]; | ||||
|     m_values["upunits"] = m_values[QString("upunits%1").arg(netIndex)]; | ||||
|  | ||||
|     // swaptot* | ||||
|     m_values["swaptotmb"] = m_values["swapmb"].toInt() + m_values["swapfreemb"].toInt(); | ||||
|     m_values["swaptotgb"] = m_values["swapgb"].toFloat() + m_values["swapfreegb"].toFloat(); | ||||
|     // swap | ||||
|     m_values["swap"] = 100.0f * m_values["swapmb"].toFloat() / m_values["swaptotmb"].toFloat(); | ||||
|  | ||||
|     // user defined keys | ||||
|     for (auto &key : m_keyOperator->userKeys()) | ||||
|         m_values[key] = m_values[m_keyOperator->userKeySource(key)]; | ||||
| @ -303,7 +262,7 @@ void AWKeys::createDBusInterface() | ||||
|     auto id = reinterpret_cast<qlonglong>(this); | ||||
|  | ||||
|     // create session | ||||
|     QDBusConnection instanceBus = QDBusConnection::sessionBus(); | ||||
|     auto instanceBus = QDBusConnection::sessionBus(); | ||||
|     // HACK we are going to use different services because it binds to | ||||
|     // application | ||||
|     if (instanceBus.registerService(QString("%1.i%2").arg(AWDBUS_SERVICE).arg(id))) { | ||||
| @ -314,7 +273,7 @@ void AWKeys::createDBusInterface() | ||||
|     } | ||||
|  | ||||
|     // and same instance but for id independent service | ||||
|     QDBusConnection commonBus = QDBusConnection::sessionBus(); | ||||
|     auto commonBus = QDBusConnection::sessionBus(); | ||||
|     if (commonBus.registerService(AWDBUS_SERVICE)) | ||||
|         commonBus.registerObject(AWDBUS_PATH, new AWDBusAdaptor(this), QDBusConnection::ExportAllContents); | ||||
| } | ||||
| @ -323,7 +282,7 @@ void AWKeys::createDBusInterface() | ||||
| QString AWKeys::parsePattern(QString _pattern) const | ||||
| { | ||||
|     // screen sign | ||||
|     _pattern.replace("$$", QString(0x1d)); | ||||
|     _pattern.replace("$$", QChar(0x1d)); | ||||
|  | ||||
|     // lambdas | ||||
|     for (auto &key : m_foundLambdas) | ||||
| @ -335,15 +294,15 @@ QString AWKeys::parsePattern(QString _pattern) const | ||||
|  | ||||
|     // bars | ||||
|     for (auto &bar : m_foundBars) { | ||||
|         GraphicalItem *item = m_keyOperator->giByKey(bar); | ||||
|         QString image = item->isCustom() ? item->image( | ||||
|                             AWPatternFunctions::expandLambdas(item->bar(), m_aggregator, m_values, item->usedKeys())) | ||||
|                                          : item->image(m_values[item->bar()]); | ||||
|         auto item = m_keyOperator->giByKey(bar); | ||||
|         auto image = item->isCustom() ? item->image( | ||||
|                          AWPatternFunctions::expandLambdas(item->bar(), m_aggregator, m_values, item->usedKeys())) | ||||
|                                       : item->image(m_values[item->bar()]); | ||||
|         _pattern.replace(QString("$%1").arg(bar), image); | ||||
|     } | ||||
|  | ||||
|     // prepare strings | ||||
|     _pattern.replace(QString(0x1d), "$"); | ||||
|     _pattern.replace(QChar(0x1d), "$"); | ||||
|     if (m_wrapNewLines) | ||||
|         _pattern.replace("\n", "<br>"); | ||||
|  | ||||
| @ -351,25 +310,20 @@ QString AWKeys::parsePattern(QString _pattern) const | ||||
| } | ||||
|  | ||||
|  | ||||
| void AWKeys::setDataBySource(const QString &_sourceName, const QVariantMap &_data) | ||||
| void AWKeys::setDataBySource(const QString &_source, const KSysGuard::SensorInfo &_sensor, const QVariant &_value) | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Source" << _sourceName << "with data" << _data; | ||||
|     qCDebug(LOG_AW) << "Source" << _source << _sensor.name << "with data" << _value; | ||||
|  | ||||
|     // first list init | ||||
|     QStringList tags = m_aggregator->keysFromSource(_sourceName); | ||||
|     auto tags = m_aggregator->keysFromSource(_source); | ||||
|     if (tags.isEmpty()) | ||||
|         tags = m_aggregator->registerSource(_sourceName, _data["units"].toString(), m_requiredKeys); | ||||
|         tags = m_aggregator->registerSource(_source, _sensor.unit, m_requiredKeys); | ||||
|  | ||||
|     // update data or drop source if there are no matches and exit | ||||
|     if (tags.isEmpty()) { | ||||
|         qCInfo(LOG_AW) << "Source" << _sourceName << "not found"; | ||||
|         return emit(dropSourceFromDataengine(_sourceName)); | ||||
|         qCInfo(LOG_AW) << "Sensor" << _source << "not found"; | ||||
|         return emit(dropSourceFromDataengine(_source)); | ||||
|     } | ||||
|  | ||||
|     m_mutex.lock(); | ||||
|     // HACK workaround for time values which are stored in the different path | ||||
|     std::for_each(tags.cbegin(), tags.cend(), [this, &_data, &_sourceName](const QString &tag) { | ||||
|         m_values[tag] = _sourceName == "Local" ? _data["DateTime"] : _data["value"]; | ||||
|     }); | ||||
|     m_mutex.unlock(); | ||||
|     std::for_each(tags.cbegin(), tags.cend(), [this, _value](const QString &tag) { m_values[tag] = _value; }); | ||||
| } | ||||
|  | ||||
| @ -15,24 +15,20 @@ | ||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||
|  ***************************************************************************/ | ||||
|  | ||||
| #pragma once | ||||
|  | ||||
| #ifndef AWKEYS_H | ||||
| #define AWKEYS_H | ||||
|  | ||||
| #include <Plasma/DataEngine> | ||||
|  | ||||
| #include <QMutex> | ||||
| #include <QObject> | ||||
|  | ||||
| #include <ksysguard/systemstats/SensorInfo.h> | ||||
|  | ||||
|  | ||||
| class AWDataAggregator; | ||||
| class AWDataEngineAggregator; | ||||
| class AWKeyOperations; | ||||
| class AWKeysAggregator; | ||||
| class QThreadPool; | ||||
| class QTimer; | ||||
|  | ||||
| class AWKeys : public QObject | ||||
| class __attribute__((visibility("default"))) AWKeys : public QObject | ||||
| { | ||||
|     Q_OBJECT | ||||
|  | ||||
| @ -40,7 +36,7 @@ public: | ||||
|     explicit AWKeys(QObject *_parent = nullptr); | ||||
|     ~AWKeys() override; | ||||
|     Q_INVOKABLE void initDataAggregator(const QVariantMap &_tooltipParams); | ||||
|     Q_INVOKABLE void initKeys(const QString &_currentPattern, int _interval, int _limit, bool _optimize); | ||||
|     Q_INVOKABLE void initKeys(const QString &_currentPattern, int _interval, bool _optimize); | ||||
|     Q_INVOKABLE void setAggregatorProperty(const QString &_key, const QVariant &_value); | ||||
|     Q_INVOKABLE void setWrapNewLines(bool _wrap); | ||||
|     // additional method to force load keys from Qml UI. Used in some | ||||
| @ -48,24 +44,19 @@ public: | ||||
|     Q_INVOKABLE void updateCache(); | ||||
|     // keys | ||||
|     Q_INVOKABLE [[nodiscard]] QStringList dictKeys(bool _sorted = false, const QString &_regexp = "") const; | ||||
|     Q_INVOKABLE [[nodiscard]] QVariantList getHddDevices() const; | ||||
|     // values | ||||
|     Q_INVOKABLE [[nodiscard]] QString infoByKey(const QString &_key) const; | ||||
|     Q_INVOKABLE [[nodiscard]] QString valueByKey(const QString &_key) const; | ||||
|     // configuration | ||||
|     Q_INVOKABLE void editItem(const QString &_type); | ||||
|  | ||||
| public slots: | ||||
|     void dataUpdated(const QString &_sourceName, const Plasma::DataEngine::Data &_data); | ||||
|     // dummy method required by DataEngine connections | ||||
|     static void modelChanged(const QString &, QAbstractItemModel *){}; | ||||
|  | ||||
| signals: | ||||
|     void dropSourceFromDataengine(const QString &_source); | ||||
|     void needTextToBeUpdated(const QString &_newText) const; | ||||
|     void needToolTipToBeUpdated(const QString &_newText) const; | ||||
|  | ||||
| private slots: | ||||
|     void dataUpdated(const QHash<QString, KSysGuard::SensorInfo> &_sensors, const KSysGuard::SensorDataList &_data); | ||||
|     void reinitKeys(const QStringList &_currentKeys); | ||||
|     void updateTextData(); | ||||
|  | ||||
| @ -74,7 +65,7 @@ private: | ||||
|     void calculateValues(); | ||||
|     void createDBusInterface(); | ||||
|     [[nodiscard]] QString parsePattern(QString _pattern) const; | ||||
|     void setDataBySource(const QString &_sourceName, const QVariantMap &_data); | ||||
|     void setDataBySource(const QString &_source, const KSysGuard::SensorInfo &_sensor, const QVariant &_value); | ||||
|     // objects | ||||
|     AWDataAggregator *m_dataAggregator = nullptr; | ||||
|     AWDataEngineAggregator *m_dataEngineAggregator = nullptr; | ||||
| @ -87,10 +78,4 @@ private: | ||||
|     QVariantHash m_values; | ||||
|     bool m_optimize = false; | ||||
|     bool m_wrapNewLines = false; | ||||
|     // multithread features | ||||
|     QThreadPool *m_threadPool = nullptr; | ||||
|     QMutex m_mutex; | ||||
| }; | ||||
|  | ||||
|  | ||||
| #endif /* AWKEYS_H */ | ||||
|  | ||||
| @ -17,15 +17,9 @@ | ||||
|  | ||||
| #include "awkeysaggregator.h" | ||||
|  | ||||
| #include <KI18n/KLocalizedString> | ||||
|  | ||||
| #include <QDateTime> | ||||
| #include <QLocale> | ||||
|  | ||||
| #include "awdataenginemapper.h" | ||||
| #include "awdebug.h" | ||||
| #include "awformatterhelper.h" | ||||
| #include "version.h" | ||||
|  | ||||
|  | ||||
| AWKeysAggregator::AWKeysAggregator(QObject *_parent) | ||||
| @ -33,25 +27,38 @@ AWKeysAggregator::AWKeysAggregator(QObject *_parent) | ||||
| { | ||||
|     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; | ||||
|  | ||||
|     m_customFormatters = new AWFormatterHelper(nullptr); | ||||
|     m_mapper = new AWDataEngineMapper(this, m_customFormatters); | ||||
|  | ||||
|     // sort time keys | ||||
|     m_timeKeys = QString(TIME_KEYS).split(','); | ||||
|     m_timeKeys.sort(); | ||||
|     std::reverse(m_timeKeys.begin(), m_timeKeys.end()); | ||||
| } | ||||
|  | ||||
|  | ||||
| AWKeysAggregator::~AWKeysAggregator() | ||||
| { | ||||
|     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; | ||||
|     m_settings.customFormatters = new AWFormatterHelper(this); | ||||
|     m_mapper = new AWDataEngineMapper(this, m_settings.customFormatters); | ||||
| } | ||||
|  | ||||
|  | ||||
| void AWKeysAggregator::initFormatters() | ||||
| { | ||||
|     m_customFormatters->initItems(); | ||||
|     m_settings.customFormatters->initItems(); | ||||
| } | ||||
|  | ||||
|  | ||||
| QString AWKeysAggregator::acOffline() const | ||||
| { | ||||
|     return m_settings.acOffline; | ||||
| } | ||||
|  | ||||
|  | ||||
| QString AWKeysAggregator::acOnline() const | ||||
| { | ||||
|     return m_settings.acOnline; | ||||
| } | ||||
|  | ||||
|  | ||||
| QString AWKeysAggregator::customTime() const | ||||
| { | ||||
|     return m_settings.customTime; | ||||
| } | ||||
|  | ||||
|  | ||||
| QString AWKeysAggregator::customUptime() const | ||||
| { | ||||
|     return m_settings.customUptime; | ||||
| } | ||||
|  | ||||
|  | ||||
| @ -59,108 +66,7 @@ QString AWKeysAggregator::formatter(const QVariant &_data, const QString &_key, | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Data" << _data << "for key" << _key; | ||||
|  | ||||
|     QString output; | ||||
|     QLocale loc = m_translate ? QLocale::system() : QLocale::c(); | ||||
|     // case block | ||||
|     switch (m_mapper->formatter(_key)) { | ||||
|     case FormatterType::Float: | ||||
|         output = QString("%1").arg(_data.toFloat(), 5, 'f', 1); | ||||
|         break; | ||||
|     case FormatterType::FloatTwoSymbols: | ||||
|         output = QString("%1").arg(_data.toFloat(), 5, 'f', 2); | ||||
|         break; | ||||
|     case FormatterType::Integer: | ||||
|         output = QString("%1").arg(_data.toFloat(), 4, 'f', 0); | ||||
|         break; | ||||
|     case FormatterType::IntegerFive: | ||||
|         output = QString("%1").arg(_data.toFloat(), 5, 'f', 0); | ||||
|         break; | ||||
|     case FormatterType::IntegerThree: | ||||
|         output = QString("%1").arg(_data.toFloat(), 3, 'f', 0); | ||||
|         break; | ||||
|     case FormatterType::List: | ||||
|         output = _data.toStringList().join(','); | ||||
|         break; | ||||
|     case FormatterType::ACFormat: | ||||
|         output = _data.toBool() ? m_acOnline : m_acOffline; | ||||
|         break; | ||||
|     case FormatterType::MemGBFormat: | ||||
|         output = QString("%1").arg(_data.toFloat() / (1024.0 * 1024.0), 5, 'f', 1); | ||||
|         break; | ||||
|     case FormatterType::MemMBFormat: | ||||
|         output = QString("%1").arg(_data.toFloat() / 1024.0, 5, 'f', 0); | ||||
|         break; | ||||
|     case FormatterType::NetSmartFormat: | ||||
|         output = [](const float value) { | ||||
|             if (value > 1024.0) | ||||
|                 return QString("%1").arg(value / 1024.0, 4, 'f', 1); | ||||
|             else | ||||
|                 return QString("%1").arg(value, 4, 'f', 0); | ||||
|         }(_data.toFloat()); | ||||
|         break; | ||||
|     case FormatterType::NetSmartUnits: | ||||
|         if (_data.toFloat() > 1024.0) | ||||
|             output = m_translate ? i18n("MB/s") : "MB/s"; | ||||
|         else | ||||
|             output = m_translate ? i18n("KB/s") : "KB/s"; | ||||
|         break; | ||||
|     case FormatterType::Quotes: | ||||
|         // first cast | ||||
|         output = QString("%1").arg(_data.toDouble(), 0, 'f'); | ||||
|         output = output.rightJustified(8, QLatin1Char(' '), true); | ||||
|         break; | ||||
|     case FormatterType::Temperature: | ||||
|         output = QString("%1").arg(temperature(_data.toFloat()), 5, 'f', 1); | ||||
|         break; | ||||
|     case FormatterType::Time: | ||||
|         output = _data.toDateTime().toString(); | ||||
|         break; | ||||
|     case FormatterType::TimeCustom: | ||||
|         output = m_customTime; | ||||
|         [&output, loc, this](const QDateTime &dt) { | ||||
|             for (auto &key : m_timeKeys) | ||||
|                 output.replace(QString("$%1").arg(key), loc.toString(dt, key)); | ||||
|         }(_data.toDateTime()); | ||||
|         break; | ||||
|     case FormatterType::TimeISO: | ||||
|         output = _data.toDateTime().toString(Qt::ISODate); | ||||
|         break; | ||||
|     case FormatterType::TimeLong: | ||||
|         output = loc.toString(_data.toDateTime(), QLocale::LongFormat); | ||||
|         break; | ||||
|     case FormatterType::TimeShort: | ||||
|         output = loc.toString(_data.toDateTime(), QLocale::ShortFormat); | ||||
|         break; | ||||
|     case FormatterType::Timestamp: | ||||
|         output = QString("%1").arg(_data.toDateTime().toMSecsSinceEpoch() / 1000.0, 10, 'f', 0); | ||||
|         break; | ||||
|     case FormatterType::Uptime: | ||||
|     case FormatterType::UptimeCustom: | ||||
|         output = | ||||
|             [](QString source, const int uptime) { | ||||
|                 int seconds = uptime - uptime % 60; | ||||
|                 int minutes = seconds / 60 % 60; | ||||
|                 int hours = ((seconds / 60) - minutes) / 60 % 24; | ||||
|                 int days = (((seconds / 60) - minutes) / 60 - hours) / 24; | ||||
|                 source.replace("$dd", QString("%1").arg(days, 3, 10, QChar('0'))); | ||||
|                 source.replace("$d", QString("%1").arg(days)); | ||||
|                 source.replace("$hh", QString("%1").arg(hours, 2, 10, QChar('0'))); | ||||
|                 source.replace("$h", QString("%1").arg(hours)); | ||||
|                 source.replace("$mm", QString("%1").arg(minutes, 2, 10, QChar('0'))); | ||||
|                 source.replace("$m", QString("%1").arg(minutes)); | ||||
|                 return source; | ||||
|             }(m_mapper->formatter(_key) == FormatterType::Uptime ? "$ddd$hhh$mmm" : m_customUptime, | ||||
|               static_cast<int>(_data.toFloat())); | ||||
|         break; | ||||
|     case FormatterType::NoFormat: | ||||
|         output = _data.toString(); | ||||
|         break; | ||||
|     case FormatterType::Custom: | ||||
|         if (m_customFormatters) | ||||
|             output = m_customFormatters->convert(_data, _key); | ||||
|         break; | ||||
|     } | ||||
|  | ||||
|     auto output = m_mapper->formatter(_key)->format(_data, _key, m_settings); | ||||
|     // replace spaces to non-breakable ones | ||||
|     replaceSpace &= (!_key.startsWith("custom") && (!_key.startsWith("weather"))); | ||||
|     if (replaceSpace) | ||||
| @ -178,11 +84,23 @@ QStringList AWKeysAggregator::keysFromSource(const QString &_source) const | ||||
| } | ||||
|  | ||||
|  | ||||
| QString AWKeysAggregator::tempUnits() const | ||||
| { | ||||
|     return m_settings.tempUnits; | ||||
| } | ||||
|  | ||||
|  | ||||
| bool AWKeysAggregator::translate() const | ||||
| { | ||||
|     return m_settings.translate; | ||||
| } | ||||
|  | ||||
|  | ||||
| void AWKeysAggregator::setAcOffline(const QString &_inactive) | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Inactive AC string" << _inactive; | ||||
|  | ||||
|     m_acOffline = _inactive; | ||||
|     m_settings.acOffline = _inactive; | ||||
| } | ||||
|  | ||||
|  | ||||
| @ -190,7 +108,7 @@ void AWKeysAggregator::setAcOnline(const QString &_active) | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Active AC string" << _active; | ||||
|  | ||||
|     m_acOnline = _active; | ||||
|     m_settings.acOnline = _active; | ||||
| } | ||||
|  | ||||
|  | ||||
| @ -198,7 +116,7 @@ void AWKeysAggregator::setCustomTime(const QString &_customTime) | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Format" << _customTime; | ||||
|  | ||||
|     m_customTime = _customTime; | ||||
|     m_settings.customTime = _customTime; | ||||
| } | ||||
|  | ||||
|  | ||||
| @ -206,15 +124,13 @@ void AWKeysAggregator::setCustomUptime(const QString &_customUptime) | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Format" << _customUptime; | ||||
|  | ||||
|     m_customUptime = _customUptime; | ||||
|     m_settings.customUptime = _customUptime; | ||||
| } | ||||
|  | ||||
|  | ||||
| void AWKeysAggregator::setDevices(const QHash<QString, QStringList> &_devices) | ||||
| void AWKeysAggregator::setDevices(const AWPluginMatcherSettings &_settings) | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Devices" << _devices; | ||||
|  | ||||
|     m_mapper->setDevices(_devices); | ||||
|     m_mapper->setDevices(_settings); | ||||
| } | ||||
|  | ||||
|  | ||||
| @ -222,7 +138,7 @@ void AWKeysAggregator::setTempUnits(const QString &_units) | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Units" << _units; | ||||
|  | ||||
|     m_tempUnits = _units; | ||||
|     m_settings.tempUnits = _units; | ||||
| } | ||||
|  | ||||
|  | ||||
| @ -230,39 +146,14 @@ void AWKeysAggregator::setTranslate(const bool _translate) | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Translate" << _translate; | ||||
|  | ||||
|     m_translate = _translate; | ||||
|     m_settings.translate = _translate; | ||||
| } | ||||
|  | ||||
|  | ||||
| QStringList AWKeysAggregator::registerSource(const QString &_source, const QString &_units, const QStringList &_keys) | ||||
| QStringList AWKeysAggregator::registerSource(const QString &_source, const KSysGuard::Unit _units, | ||||
|                                              const QStringList &_keys) | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Source" << _source << "with units" << _units; | ||||
|  | ||||
|     return m_mapper->registerSource(_source, _units, _keys); | ||||
| } | ||||
|  | ||||
|  | ||||
| float AWKeysAggregator::temperature(const float temp) const | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Temperature value" << temp; | ||||
|  | ||||
|     float converted = temp; | ||||
|     if (m_tempUnits == "Celsius") { | ||||
|     } else if (m_tempUnits == "Fahrenheit") { | ||||
|         converted = temp * 9.0f / 5.0f + 32.0f; | ||||
|     } else if (m_tempUnits == "Kelvin") { | ||||
|         converted = temp + 273.15f; | ||||
|     } else if (m_tempUnits == "Reaumur") { | ||||
|         converted = temp * 0.8f; | ||||
|     } else if (m_tempUnits == "cm^-1") { | ||||
|         converted = (temp + 273.15f) * 0.695f; | ||||
|     } else if (m_tempUnits == "kJ/mol") { | ||||
|         converted = (temp + 273.15f) * 8.31f; | ||||
|     } else if (m_tempUnits == "kcal/mol") { | ||||
|         converted = (temp + 273.15f) * 1.98f; | ||||
|     } else { | ||||
|         qCWarning(LOG_AW) << "Invalid units" << m_tempUnits; | ||||
|     } | ||||
|  | ||||
|     return converted; | ||||
| } | ||||
|  | ||||
| @ -15,87 +15,55 @@ | ||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||
|  ***************************************************************************/ | ||||
|  | ||||
| #pragma once | ||||
|  | ||||
| #ifndef AWKEYSAGGREGATOR_H | ||||
| #define AWKEYSAGGREGATOR_H | ||||
| #include <ksysguard/formatter/Unit.h> | ||||
|  | ||||
| #include <QHash> | ||||
| #include <QObject> | ||||
|  | ||||
| #include "formatters/awpluginformatsettings.h" | ||||
| #include "matchers/awpluginmatchersettings.h" | ||||
|  | ||||
|  | ||||
| class AWFormatterHelper; | ||||
| class AWDataEngineMapper; | ||||
|  | ||||
| class AWKeysAggregator : public QObject | ||||
| { | ||||
|     Q_OBJECT | ||||
|     Q_PROPERTY(QString acOffline MEMBER m_acOffline WRITE setAcOffline); | ||||
|     Q_PROPERTY(QString acOnline MEMBER m_acOnline WRITE setAcOnline); | ||||
|     Q_PROPERTY(QString customTime MEMBER m_customTime WRITE setCustomTime); | ||||
|     Q_PROPERTY(QString customUptime MEMBER m_customUptime WRITE setCustomUptime); | ||||
|     Q_PROPERTY(QString tempUnits MEMBER m_tempUnits WRITE setTempUnits); | ||||
|     Q_PROPERTY(bool translate MEMBER m_translate WRITE setTranslate); | ||||
|     Q_PROPERTY(QString acOffline READ acOffline WRITE setAcOffline); | ||||
|     Q_PROPERTY(QString acOnline READ acOnline WRITE setAcOnline); | ||||
|     Q_PROPERTY(QString customTime READ customTime WRITE setCustomTime); | ||||
|     Q_PROPERTY(QString customUptime READ customUptime WRITE setCustomUptime); | ||||
|     Q_PROPERTY(QString tempUnits READ tempUnits WRITE setTempUnits); | ||||
|     Q_PROPERTY(bool translate READ translate WRITE setTranslate); | ||||
|  | ||||
| public: | ||||
|     enum class FormatterType { | ||||
|         // general formatters | ||||
|         Custom, | ||||
|         NoFormat, | ||||
|         Float, | ||||
|         FloatTwoSymbols, | ||||
|         Integer, | ||||
|         IntegerFive, | ||||
|         IntegerThree, | ||||
|         List, | ||||
|         // unit specific formatters | ||||
|         ACFormat, | ||||
|         MemGBFormat, | ||||
|         MemMBFormat, | ||||
|         NetSmartFormat, | ||||
|         NetSmartUnits, | ||||
|         Quotes, | ||||
|         Temperature, | ||||
|         Time, | ||||
|         TimeCustom, | ||||
|         TimeISO, | ||||
|         TimeLong, | ||||
|         TimeShort, | ||||
|         Timestamp, | ||||
|         Uptime, | ||||
|         UptimeCustom | ||||
|     }; | ||||
|  | ||||
|     explicit AWKeysAggregator(QObject *_parent = nullptr); | ||||
|     ~AWKeysAggregator() override; | ||||
|     ~AWKeysAggregator() override = default; | ||||
|     void initFormatters(); | ||||
|     // get methods | ||||
|     [[nodiscard]] QString acOffline() const; | ||||
|     [[nodiscard]] QString acOnline() const; | ||||
|     [[nodiscard]] QString customTime() const; | ||||
|     [[nodiscard]] QString customUptime() const; | ||||
|     [[nodiscard]] QString formatter(const QVariant &_data, const QString &_key, bool replaceSpace) const; | ||||
|     [[nodiscard]] QStringList keysFromSource(const QString &_source) const; | ||||
|     [[nodiscard]] QString tempUnits() const; | ||||
|     [[nodiscard]] bool translate() const; | ||||
|     // set methods | ||||
|     void setAcOffline(const QString &_inactive); | ||||
|     void setAcOnline(const QString &_active); | ||||
|     void setCustomTime(const QString &_customTime); | ||||
|     void setCustomUptime(const QString &_customUptime); | ||||
|     void setDevices(const QHash<QString, QStringList> &_devices); | ||||
|     void setDevices(const AWPluginMatcherSettings &_settings); | ||||
|     void setTempUnits(const QString &_units); | ||||
|     void setTranslate(bool _translate); | ||||
|  | ||||
| public slots: | ||||
|     QStringList registerSource(const QString &_source, const QString &_units, const QStringList &_keys); | ||||
|     QStringList registerSource(const QString &_source, KSysGuard::Unit _units, const QStringList &_keys); | ||||
|  | ||||
| private: | ||||
|     [[nodiscard]] float temperature(float temp) const; | ||||
|     AWFormatterHelper *m_customFormatters = nullptr; | ||||
|     AWPluginFormatSettings m_settings; | ||||
|     AWDataEngineMapper *m_mapper = nullptr; | ||||
|     QStringList m_timeKeys; | ||||
|     // variables | ||||
|     QString m_acOffline; | ||||
|     QString m_acOnline; | ||||
|     QString m_customTime; | ||||
|     QString m_customUptime; | ||||
|     QString m_tempUnits; | ||||
|     bool m_translate = false; | ||||
| }; | ||||
|  | ||||
|  | ||||
| #endif /* AWKEYSAGGREGATOR_H */ | ||||
|  | ||||
| @ -29,15 +29,9 @@ AWPairConfigFactory::AWPairConfigFactory(QObject *_parent) | ||||
| } | ||||
|  | ||||
|  | ||||
| AWPairConfigFactory::~AWPairConfigFactory() | ||||
| { | ||||
|     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; | ||||
| } | ||||
|  | ||||
|  | ||||
| void AWPairConfigFactory::showFormatterDialog(const QStringList &_keys) | ||||
| { | ||||
|     auto *config = new AWFormatterConfig(nullptr, _keys); | ||||
|     auto config = new AWFormatterConfig(nullptr, _keys); | ||||
|     config->showDialog(); | ||||
|     config->deleteLater(); | ||||
| } | ||||
| @ -45,7 +39,7 @@ void AWPairConfigFactory::showFormatterDialog(const QStringList &_keys) | ||||
|  | ||||
| void AWPairConfigFactory::showKeysDialog(const QStringList &_keys) | ||||
| { | ||||
|     auto *config = new AWCustomKeysConfig(nullptr, _keys); | ||||
|     auto config = new AWCustomKeysConfig(nullptr, _keys); | ||||
|     config->showDialog(); | ||||
|     config->deleteLater(); | ||||
| } | ||||
|  | ||||
| @ -15,9 +15,7 @@ | ||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||
|  ***************************************************************************/ | ||||
|  | ||||
|  | ||||
| #ifndef AWPAIRCONFIGFACTORY_H | ||||
| #define AWPAIRCONFIGFACTORY_H | ||||
| #pragma once | ||||
|  | ||||
| #include <QObject> | ||||
|  | ||||
| @ -28,12 +26,7 @@ class AWPairConfigFactory : public QObject | ||||
|  | ||||
| public: | ||||
|     explicit AWPairConfigFactory(QObject *_parent = nullptr); | ||||
|     ~AWPairConfigFactory() override; | ||||
|     ~AWPairConfigFactory() override = default; | ||||
|     Q_INVOKABLE static void showFormatterDialog(const QStringList &_keys); | ||||
|     Q_INVOKABLE static void showKeysDialog(const QStringList &_keys); | ||||
|  | ||||
| private: | ||||
| }; | ||||
|  | ||||
|  | ||||
| #endif /* AWPAIRCONFIGFACTORY_H */ | ||||
|  | ||||
| @ -36,7 +36,7 @@ QString AWPatternFunctions::expandLambdas(QString _code, AWKeysAggregator *_aggr | ||||
|     for (auto &lambdaKey : _usedKeys) | ||||
|         _code.replace(QString("$%1").arg(lambdaKey), _aggregator->formatter(_metadata[lambdaKey], lambdaKey, false)); | ||||
|     qCInfo(LOG_AW) << "Expression" << _code; | ||||
|     QJSValue result = engine.evaluate(_code); | ||||
|     auto result = engine.evaluate(_code); | ||||
|     if (result.isError()) { | ||||
|         qCWarning(LOG_AW) << "Uncaught exception at line" << result.property("lineNumber").toInt() << ":" | ||||
|                           << result.toString(); | ||||
| @ -52,17 +52,17 @@ QString AWPatternFunctions::expandTemplates(QString _code) | ||||
|     qCDebug(LOG_AW) << "Expand templates in" << _code; | ||||
|  | ||||
|     // match the following construction $template{{some code here}} | ||||
|     QRegularExpression templatesRegexp(R"(\$template\{\{(?<body>.*?)\}\})"); | ||||
|     static QRegularExpression templatesRegexp(R"(\$template\{\{(?<body>.*?)\}\})"); | ||||
|     templatesRegexp.setPatternOptions(QRegularExpression::DotMatchesEverythingOption); | ||||
|  | ||||
|     QRegularExpressionMatchIterator it = templatesRegexp.globalMatch(_code); | ||||
|     auto it = templatesRegexp.globalMatch(_code); | ||||
|     while (it.hasNext()) { | ||||
|         QRegularExpressionMatch match = it.next(); | ||||
|         QString body = match.captured("body"); | ||||
|         auto match = it.next(); | ||||
|         auto body = match.captured("body"); | ||||
|  | ||||
|         QJSEngine engine; | ||||
|         qCInfo(LOG_AW) << "Expression" << body; | ||||
|         QJSValue result = engine.evaluate(body); | ||||
|         auto result = engine.evaluate(body); | ||||
|         QString templateResult = ""; | ||||
|         if (result.isError()) { | ||||
|             qCWarning(LOG_AW) << "Uncaught exception at line" << result.property("lineNumber").toInt() << ":" | ||||
| @ -94,20 +94,20 @@ QList<AWPatternFunctions::AWFunction> AWPatternFunctions::findFunctionCalls(cons | ||||
|     regex.setPatternOptions(QRegularExpression::DotMatchesEverythingOption); | ||||
|  | ||||
|     QList<AWPatternFunctions::AWFunction> foundFunctions; | ||||
|     QRegularExpressionMatchIterator it = regex.globalMatch(_code); | ||||
|     auto it = regex.globalMatch(_code); | ||||
|     while (it.hasNext()) { | ||||
|         QRegularExpressionMatch match = it.next(); | ||||
|         auto match = it.next(); | ||||
|  | ||||
|         AWPatternFunctions::AWFunction metadata; | ||||
|         // work with args | ||||
|         QString argsString = match.captured("args"); | ||||
|         auto argsString = match.captured("args"); | ||||
|         if (argsString.isEmpty()) { | ||||
|             metadata.args = QStringList(); | ||||
|         } else { | ||||
|             // replace '$,' to 0x1d | ||||
|             argsString.replace("$,", QString(0x1d)); | ||||
|             QStringList args = argsString.split(','); | ||||
|             std::for_each(args.begin(), args.end(), [](QString &arg) { arg.replace(QString(0x1d), ","); }); | ||||
|             argsString.replace("$,", QChar(0x1d)); | ||||
|             auto args = argsString.split(','); | ||||
|             std::for_each(args.begin(), args.end(), [](auto &arg) { arg.replace(QChar(0x1d), ","); }); | ||||
|             metadata.args = args; | ||||
|         } | ||||
|         // other variables | ||||
| @ -127,11 +127,11 @@ QString AWPatternFunctions::insertAllKeys(QString _code, const QStringList &_key | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Looking for keys in code" << _code << "using list" << _keys; | ||||
|  | ||||
|     QList<AWPatternFunctions::AWFunction> found = AWPatternFunctions::findFunctionCalls("aw_all", _code); | ||||
|     auto found = AWPatternFunctions::findFunctionCalls("aw_all", _code); | ||||
|     for (auto &function : found) { | ||||
|         QString separator = function.args.isEmpty() ? "," : function.args.at(0); | ||||
|         QStringList required = _keys.filter(QRegExp(function.body)); | ||||
|         std::for_each(required.begin(), required.end(), [](QString &value) { value = QString("%1: $%1").arg(value); }); | ||||
|         auto separator = function.args.isEmpty() ? "," : function.args.at(0); | ||||
|         auto required = _keys.filter(QRegularExpression(function.body)); | ||||
|         std::for_each(required.begin(), required.end(), [](auto &value) { value = QString("%1: $%1").arg(value); }); | ||||
|  | ||||
|         _code.replace(function.what, required.join(separator)); | ||||
|     } | ||||
| @ -144,9 +144,9 @@ QString AWPatternFunctions::insertKeyCount(QString _code, const QStringList &_ke | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Looking for count in code" << _code << "using list" << _keys; | ||||
|  | ||||
|     QList<AWPatternFunctions::AWFunction> found = AWPatternFunctions::findFunctionCalls("aw_count", _code); | ||||
|     auto found = AWPatternFunctions::findFunctionCalls("aw_count", _code); | ||||
|     for (auto &function : found) { | ||||
|         int count = _keys.filter(QRegExp(function.body)).count(); | ||||
|         auto count = _keys.filter(QRegularExpression(function.body)).count(); | ||||
|  | ||||
|         _code.replace(function.what, QString::number(count)); | ||||
|     } | ||||
| @ -159,10 +159,10 @@ QString AWPatternFunctions::insertKeyNames(QString _code, const QStringList &_ke | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Looking for key names in code" << _code << "using list" << _keys; | ||||
|  | ||||
|     QList<AWPatternFunctions::AWFunction> found = AWPatternFunctions::findFunctionCalls("aw_names", _code); | ||||
|     auto found = AWPatternFunctions::findFunctionCalls("aw_names", _code); | ||||
|     for (auto &function : found) { | ||||
|         QString separator = function.args.isEmpty() ? "," : function.args.at(0); | ||||
|         QStringList required = _keys.filter(QRegExp(function.body)); | ||||
|         auto separator = function.args.isEmpty() ? "," : function.args.at(0); | ||||
|         auto required = _keys.filter(QRegularExpression(function.body)); | ||||
|  | ||||
|         _code.replace(function.what, required.join(separator)); | ||||
|     } | ||||
| @ -175,11 +175,11 @@ QString AWPatternFunctions::insertKeys(QString _code, const QStringList &_keys) | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Looking for keys in code" << _code << "using list" << _keys; | ||||
|  | ||||
|     QList<AWPatternFunctions::AWFunction> found = AWPatternFunctions::findFunctionCalls("aw_keys", _code); | ||||
|     auto found = AWPatternFunctions::findFunctionCalls("aw_keys", _code); | ||||
|     for (auto &function : found) { | ||||
|         QString separator = function.args.isEmpty() ? "," : function.args.at(0); | ||||
|         QStringList required = _keys.filter(QRegExp(function.body)); | ||||
|         std::for_each(required.begin(), required.end(), [](QString &value) { value = QString("$%1").arg(value); }); | ||||
|         auto separator = function.args.isEmpty() ? "," : function.args.at(0); | ||||
|         auto required = _keys.filter(QRegularExpression(function.body)); | ||||
|         std::for_each(required.begin(), required.end(), [](auto &value) { value = QString("$%1").arg(value); }); | ||||
|  | ||||
|         _code.replace(function.what, required.join(separator)); | ||||
|     } | ||||
| @ -192,26 +192,25 @@ QString AWPatternFunctions::insertMacros(QString _code) | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Looking for macros in code" << _code; | ||||
|  | ||||
|     QList<AWPatternFunctions::AWFunction> found = AWPatternFunctions::findFunctionCalls("aw_macro", _code); | ||||
|     auto found = AWPatternFunctions::findFunctionCalls("aw_macro", _code); | ||||
|     for (auto ¯o : found) { | ||||
|         // get macro params | ||||
|         if (macro.args.isEmpty()) { | ||||
|             qCWarning(LOG_AW) << "No macro name found for" << macro.what; | ||||
|             continue; | ||||
|         } | ||||
|         QString name = macro.args.takeFirst(); | ||||
|         auto name = macro.args.takeFirst(); | ||||
|         // find macro usage | ||||
|         QList<AWPatternFunctions::AWFunction> macroUsage | ||||
|             = AWPatternFunctions::findFunctionCalls(QString("aw_macro_%1").arg(name), _code); | ||||
|         auto macroUsage = AWPatternFunctions::findFunctionCalls(QString("aw_macro_%1").arg(name), _code); | ||||
|         for (auto &function : macroUsage) { | ||||
|             if (function.args.count() != macro.args.count()) { | ||||
|                 qCWarning(LOG_AW) << "Invalid args count found for call" << function.what << "with macro" << macro.what; | ||||
|                 continue; | ||||
|             } | ||||
|             // generate body to replace | ||||
|             QString result = macro.body; | ||||
|             std::for_each(macro.args.cbegin(), macro.args.cend(), [&result, macro, function](const QString &arg) { | ||||
|                 int index = macro.args.indexOf(arg); | ||||
|             auto result = macro.body; | ||||
|             std::for_each(macro.args.cbegin(), macro.args.cend(), [&result, macro, function](auto &arg) { | ||||
|                 auto index = macro.args.indexOf(arg); | ||||
|                 result.replace(QString("$%1").arg(arg), function.args.at(index)); | ||||
|             }); | ||||
|             // do replace | ||||
| @ -231,7 +230,7 @@ QStringList AWPatternFunctions::findKeys(const QString &_code, const QStringList | ||||
|     qCDebug(LOG_AW) << "Looking for keys in code" << _code << "using list" << _keys; | ||||
|  | ||||
|     QStringList selectedKeys; | ||||
|     QString replacedCode = _code; | ||||
|     auto replacedCode = _code; | ||||
|     for (auto &key : _keys) | ||||
|         if ((key.startsWith("bar") == _isBars) && (replacedCode.contains(QString("$%1").arg(key)))) { | ||||
|             qCInfo(LOG_AW) << "Found key" << key << "with bar enabled" << _isBars; | ||||
| @ -251,13 +250,13 @@ QStringList AWPatternFunctions::findLambdas(const QString &_code) | ||||
|  | ||||
|     QStringList selectedKeys; | ||||
|     // match the following construction ${{some code here}} | ||||
|     QRegularExpression lambdaRegexp(R"(\$\{\{(?<body>.*?)\}\})"); | ||||
|     static QRegularExpression lambdaRegexp(R"(\$\{\{(?<body>.*?)\}\})"); | ||||
|     lambdaRegexp.setPatternOptions(QRegularExpression::DotMatchesEverythingOption); | ||||
|  | ||||
|     QRegularExpressionMatchIterator it = lambdaRegexp.globalMatch(_code); | ||||
|     auto it = lambdaRegexp.globalMatch(_code); | ||||
|     while (it.hasNext()) { | ||||
|         QRegularExpressionMatch match = it.next(); | ||||
|         QString lambda = match.captured("body"); | ||||
|         auto match = it.next(); | ||||
|         auto lambda = match.captured("body"); | ||||
|  | ||||
|         // append | ||||
|         qCInfo(LOG_AW) << "Found lambda" << lambda; | ||||
|  | ||||
| @ -15,9 +15,7 @@ | ||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||
|  ***************************************************************************/ | ||||
|  | ||||
|  | ||||
| #ifndef AWPATTERNFUNCTIONS_H | ||||
| #define AWPATTERNFUNCTIONS_H | ||||
| #pragma once | ||||
|  | ||||
| #include <QString> | ||||
| #include <QVariant> | ||||
| @ -25,7 +23,7 @@ | ||||
|  | ||||
| class AWKeysAggregator; | ||||
|  | ||||
| namespace AWPatternFunctions | ||||
| namespace __attribute__((visibility("default"))) AWPatternFunctions | ||||
| { | ||||
| typedef struct { | ||||
|     QStringList args; | ||||
| @ -47,6 +45,3 @@ QString insertMacros(QString _code); | ||||
| QStringList findKeys(const QString &_code, const QStringList &_keys, bool _isBars); | ||||
| QStringList findLambdas(const QString &_code); | ||||
| } // namespace AWPatternFunctions | ||||
|  | ||||
|  | ||||
| #endif /* AWPATTERNFUNCTIONS_H */ | ||||
|  | ||||
| @ -18,8 +18,6 @@ | ||||
| #include "awtelemetryhandler.h" | ||||
|  | ||||
| #include <QJsonDocument> | ||||
| #include <QNetworkAccessManager> | ||||
| #include <QNetworkReply> | ||||
| #include <QSettings> | ||||
| #include <QStandardPaths> | ||||
| #include <QUuid> | ||||
| @ -27,23 +25,13 @@ | ||||
| #include "awdebug.h" | ||||
|  | ||||
|  | ||||
| AWTelemetryHandler::AWTelemetryHandler(QObject *_parent, const QString &_clientId) | ||||
| AWTelemetryHandler::AWTelemetryHandler(QObject *_parent) | ||||
|     : QObject(_parent) | ||||
| { | ||||
|     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; | ||||
|  | ||||
|     m_localFile = QString("%1/awesomewidgets/telemetry.ini") | ||||
|                       .arg(QStandardPaths::writableLocation(QStandardPaths::GenericDataLocation)); | ||||
|  | ||||
|     // override client id if any | ||||
|     if (!_clientId.isEmpty()) | ||||
|         m_clientId = _clientId; | ||||
| } | ||||
|  | ||||
|  | ||||
| AWTelemetryHandler::~AWTelemetryHandler() | ||||
| { | ||||
|     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; | ||||
| } | ||||
|  | ||||
|  | ||||
| @ -71,14 +59,11 @@ QString AWTelemetryHandler::getLast(const QString &_group) const | ||||
| } | ||||
|  | ||||
|  | ||||
| void AWTelemetryHandler::init(const int _count, const bool _enableRemote, const QString &_clientId) | ||||
| void AWTelemetryHandler::init(const int _count) | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Init telemetry with count" << _count << "enable remote" << _enableRemote << "client ID" | ||||
|                     << _clientId; | ||||
|     qCDebug(LOG_AW) << "Init telemetry with count" << _count; | ||||
|  | ||||
|     m_storeCount = _count; | ||||
|     m_uploadEnabled = _enableRemote; | ||||
|     m_clientId = _clientId; | ||||
| } | ||||
|  | ||||
|  | ||||
| @ -106,7 +91,7 @@ bool AWTelemetryHandler::put(const QString &_group, const QString &_value) const | ||||
|     settings.remove(""); | ||||
|     // and save now | ||||
|     for (auto &val : saved) { | ||||
|         QString key = getKey(settings.childKeys().count()); | ||||
|         auto key = getKey(settings.childKeys().count()); | ||||
|         settings.setValue(key, val); | ||||
|     } | ||||
|  | ||||
| @ -118,59 +103,6 @@ bool AWTelemetryHandler::put(const QString &_group, const QString &_value) const | ||||
| } | ||||
|  | ||||
|  | ||||
| void AWTelemetryHandler::uploadTelemetry(const QString &_group, const QString &_value) | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Upload data with group" << _group << "and value" << _value; | ||||
|     if (!m_uploadEnabled) { | ||||
|         qCInfo(LOG_AW) << "Upload disabled by configuration"; | ||||
|         return; | ||||
|     } | ||||
|  | ||||
|     auto *manager = new QNetworkAccessManager(nullptr); | ||||
|     connect(manager, SIGNAL(finished(QNetworkReply *)), this, SLOT(telemetryReplyRecieved(QNetworkReply *))); | ||||
|  | ||||
|     QUrl url(REMOTE_TELEMETRY_URL); | ||||
|     QNetworkRequest request(url); | ||||
|     request.setHeader(QNetworkRequest::ContentTypeHeader, "application/json"); | ||||
|  | ||||
|     // generate payload | ||||
|     QVariantMap payload; | ||||
|     payload["api"] = AW_TELEMETRY_API; | ||||
|     payload["client_id"] = m_clientId; | ||||
|     payload["metadata"] = _value; | ||||
|     payload["type"] = _group; | ||||
|     // convert to QByteArray to send request | ||||
|     QByteArray data = QJsonDocument::fromVariant(payload).toJson(QJsonDocument::Compact); | ||||
|     qCInfo(LOG_AW) << "Send request with body" << data.data() << "and size" << data.size(); | ||||
|  | ||||
|     manager->post(request, data); | ||||
| } | ||||
|  | ||||
|  | ||||
| void AWTelemetryHandler::telemetryReplyRecieved(QNetworkReply *_reply) | ||||
| { | ||||
|     if (_reply->error() != QNetworkReply::NoError) { | ||||
|         qCWarning(LOG_AW) << "An error occurs" << _reply->error() << "with message" << _reply->errorString(); | ||||
|         return; | ||||
|     } | ||||
|  | ||||
|     QJsonParseError error{}; | ||||
|     QJsonDocument jsonDoc = QJsonDocument::fromJson(_reply->readAll(), &error); | ||||
|     if (error.error != QJsonParseError::NoError) { | ||||
|         qCWarning(LOG_AW) << "Parse error" << error.errorString(); | ||||
|         return; | ||||
|     } | ||||
|     _reply->deleteLater(); | ||||
|  | ||||
|     // convert to map | ||||
|     QVariantMap response = jsonDoc.toVariant().toMap(); | ||||
|     QString message = response["message"].toString(); | ||||
|     qCInfo(LOG_AW) << "Server reply on telemetry" << message; | ||||
|  | ||||
|     return emit(replyReceived(message)); | ||||
| } | ||||
|  | ||||
|  | ||||
| QString AWTelemetryHandler::getKey(const int _count) | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Get key for keys count" << _count; | ||||
|  | ||||
| @ -15,43 +15,25 @@ | ||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||
|  ***************************************************************************/ | ||||
|  | ||||
|  | ||||
| #ifndef AWTELEMETRYHANDLER_H | ||||
| #define AWTELEMETRYHANDLER_H | ||||
| #pragma once | ||||
|  | ||||
| #include <QObject> | ||||
|  | ||||
|  | ||||
| class QNetworkReply; | ||||
|  | ||||
| class AWTelemetryHandler : public QObject | ||||
| class __attribute__((visibility("default"))) AWTelemetryHandler : public QObject | ||||
| { | ||||
|     Q_OBJECT | ||||
|  | ||||
| public: | ||||
|     const char *REMOTE_TELEMETRY_URL = "https://arcanis.me/telemetry"; | ||||
|  | ||||
|     explicit AWTelemetryHandler(QObject *_parent = nullptr, const QString &_clientId = ""); | ||||
|     ~AWTelemetryHandler() override; | ||||
|     explicit AWTelemetryHandler(QObject *_parent = nullptr); | ||||
|     ~AWTelemetryHandler() override = default; | ||||
|     Q_INVOKABLE [[nodiscard]] QStringList get(const QString &_group) const; | ||||
|     Q_INVOKABLE [[nodiscard]] QString getLast(const QString &_group) const; | ||||
|     Q_INVOKABLE void init(int _count, bool _enableRemote, const QString &_clientId); | ||||
|     Q_INVOKABLE void init(int _count); | ||||
|     Q_INVOKABLE [[nodiscard]] bool put(const QString &_group, const QString &_value) const; | ||||
|     Q_INVOKABLE void uploadTelemetry(const QString &_group, const QString &_value); | ||||
|  | ||||
| signals: | ||||
|     void replyReceived(const QString &_message); | ||||
|  | ||||
| private slots: | ||||
|     void telemetryReplyRecieved(QNetworkReply *_reply); | ||||
|  | ||||
| private: | ||||
|     static QString getKey(int _count); | ||||
|     QString m_clientId; | ||||
|     QString m_localFile; | ||||
|     int m_storeCount = 0; | ||||
|     bool m_uploadEnabled = false; | ||||
| }; | ||||
|  | ||||
|  | ||||
| #endif /* AWTELEMETRYHANDLER_H */ | ||||
|  | ||||
| @ -17,13 +17,18 @@ | ||||
|  | ||||
| #include "awupdatehelper.h" | ||||
|  | ||||
| #ifndef NDEBUG | ||||
| #define NDEBUG | ||||
| #endif /* NDEBUG */ | ||||
| #include <KI18n/KLocalizedString> | ||||
| #include <KNotifications/KNotification> | ||||
|  | ||||
| #include <QDesktopServices> | ||||
| #include <QJsonDocument> | ||||
| #include <QNetworkAccessManager> | ||||
| #include <QNetworkReply> | ||||
| #include <QSettings> | ||||
| #include <QStandardPaths> | ||||
|  | ||||
| #include "awdebug.h" | ||||
|  | ||||
| @ -39,21 +44,15 @@ AWUpdateHelper::AWUpdateHelper(QObject *_parent) | ||||
| } | ||||
|  | ||||
|  | ||||
| AWUpdateHelper::~AWUpdateHelper() | ||||
| { | ||||
|     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; | ||||
| } | ||||
|  | ||||
|  | ||||
| void AWUpdateHelper::checkUpdates(const bool _showAnyway) | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Show anyway" << _showAnyway; | ||||
|  | ||||
|     // showAnyway options requires to show message if no updates found on direct | ||||
|     // showAnyway options required to show message if no updates found on direct | ||||
|     // request. In case of automatic check no message will be shown | ||||
|     auto *manager = new QNetworkAccessManager(nullptr); | ||||
|     auto manager = new QNetworkAccessManager(nullptr); | ||||
|     connect(manager, &QNetworkAccessManager::finished, | ||||
|             [_showAnyway, this](QNetworkReply *reply) { return versionReplyRecieved(reply, _showAnyway); }); | ||||
|             [_showAnyway, this](QNetworkReply *reply) { return versionReplyReceived(reply, _showAnyway); }); | ||||
|  | ||||
|     manager->get(QNetworkRequest(QUrl(VERSION_API))); | ||||
| } | ||||
| @ -62,15 +61,14 @@ void AWUpdateHelper::checkUpdates(const bool _showAnyway) | ||||
| bool AWUpdateHelper::checkVersion() | ||||
| { | ||||
|     QSettings settings(m_genericConfig, QSettings::IniFormat); | ||||
|     QVersionNumber version = QVersionNumber::fromString(settings.value("Version", QString(VERSION)).toString()); | ||||
|     auto version = QVersionNumber::fromString(settings.value("Version", QString(VERSION)).toString()); | ||||
|     // update version | ||||
|     settings.setValue("Version", QString(VERSION)); | ||||
|     settings.sync(); | ||||
|     qCInfo(LOG_AW) << "Found version" << version << "actual one is" << m_foundVersion; | ||||
|  | ||||
|     if ((version != m_foundVersion) && (!QString(CHANGELOG).isEmpty())) { | ||||
|         genMessageBox(i18nc("Changelog of %1", VERSION), QString(CHANGELOG).replace('@', '\n'), QMessageBox::Ok) | ||||
|             ->open(); | ||||
|         sendNotification(i18n("Changelog of %1", VERSION), QString(CHANGELOG).replace('@', '\n')); | ||||
|         return true; | ||||
|     } else if (version != m_foundVersion) { | ||||
|         qCWarning(LOG_AW) << "No changelog information provided"; | ||||
| @ -83,49 +81,40 @@ bool AWUpdateHelper::checkVersion() | ||||
| } | ||||
|  | ||||
|  | ||||
| void AWUpdateHelper::openReleasesPage() | ||||
| { | ||||
|     QDesktopServices::openUrl(QString(RELEASES) + m_foundVersion.toString()); | ||||
| } | ||||
|  | ||||
|  | ||||
| void AWUpdateHelper::showInfo(const QVersionNumber &_version) | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Version" << _version; | ||||
|  | ||||
|     QString text = i18n("You are using the actual version %1", _version.toString()); | ||||
|     auto text = i18n("You are using the actual version %1", _version.toString()); | ||||
|     if (!QString(COMMIT_SHA).isEmpty()) | ||||
|         text += QString(" (%1)").arg(QString(COMMIT_SHA)); | ||||
|     return genMessageBox(i18n("No new version found"), text, QMessageBox::Ok)->open(); | ||||
|     sendNotification(i18n("No new version found"), text); | ||||
| } | ||||
|  | ||||
|  | ||||
| void AWUpdateHelper::showUpdates(const QVersionNumber &_version) | ||||
| void AWUpdateHelper::showUpdates(const QVersionNumber &_version) const | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Version" << _version; | ||||
|  | ||||
|     QString text; | ||||
|     text += i18nc("Current version : %1", VERSION); | ||||
|     text += i18n("Current version : %1", VERSION); | ||||
|     text += QString(COMMIT_SHA).isEmpty() ? "\n" : QString(" (%1)\n").arg(QString(COMMIT_SHA)); | ||||
|     text += i18n("New version : %1", _version.toString()) + "\n\n"; | ||||
|     text += i18n("Click \"Ok\" to download"); | ||||
|  | ||||
|     genMessageBox(i18n("There are updates"), text, QMessageBox::Ok | QMessageBox::Cancel) | ||||
|         ->open(this, SLOT(userReplyOnUpdates(QAbstractButton *))); | ||||
|     auto event = sendNotification(i18n("There are updates"), text); | ||||
|     auto action = event->addAction(i18n("Details")); | ||||
|     connect(action, &KNotificationAction::activated, this, &AWUpdateHelper::openReleasesPage); | ||||
| } | ||||
|  | ||||
|  | ||||
| void AWUpdateHelper::userReplyOnUpdates(QAbstractButton *_button) | ||||
| { | ||||
|     QMessageBox::ButtonRole ret = dynamic_cast<QMessageBox *>(sender())->buttonRole(_button); | ||||
|     qCInfo(LOG_AW) << "User select" << ret; | ||||
|  | ||||
|     switch (ret) { | ||||
|     case QMessageBox::AcceptRole: | ||||
|         QDesktopServices::openUrl(QString(RELEASES) + m_foundVersion.toString()); | ||||
|         break; | ||||
|     case QMessageBox::RejectRole: | ||||
|     default: | ||||
|         break; | ||||
|     } | ||||
| } | ||||
|  | ||||
|  | ||||
| void AWUpdateHelper::versionReplyRecieved(QNetworkReply *_reply, const bool _showAnyway) | ||||
| void AWUpdateHelper::versionReplyReceived(QNetworkReply *_reply, const bool _showAnyway) | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Show message anyway" << _showAnyway; | ||||
|     if (_reply->error() != QNetworkReply::NoError) { | ||||
| @ -133,22 +122,23 @@ void AWUpdateHelper::versionReplyRecieved(QNetworkReply *_reply, const bool _sho | ||||
|         return; | ||||
|     } | ||||
|  | ||||
|     QJsonParseError error = QJsonParseError(); | ||||
|     QJsonDocument jsonDoc = QJsonDocument::fromJson(_reply->readAll(), &error); | ||||
|     auto error = QJsonParseError(); | ||||
|     auto jsonDoc = QJsonDocument::fromJson(_reply->readAll(), &error); | ||||
|     if (error.error != QJsonParseError::NoError) { | ||||
|         qCWarning(LOG_AW) << "Parse error" << error.errorString(); | ||||
|         return; | ||||
|     } | ||||
|     _reply->deleteLater(); | ||||
|     _reply->manager()->deleteLater(); // remember to delete manager too | ||||
|  | ||||
|     // convert to map | ||||
|     QVariantMap firstRelease = jsonDoc.toVariant().toList().first().toMap(); | ||||
|     QString version = firstRelease["tag_name"].toString(); | ||||
|     auto firstRelease = jsonDoc.toVariant().toList().first().toMap(); | ||||
|     auto version = firstRelease["tag_name"].toString(); | ||||
|     version.remove("V."); | ||||
|     m_foundVersion = QVersionNumber::fromString(version); | ||||
|     qCInfo(LOG_AW) << "Update found version to" << m_foundVersion; | ||||
|  | ||||
|     QVersionNumber oldVersion = QVersionNumber::fromString(VERSION); | ||||
|     auto oldVersion = QVersionNumber::fromString(VERSION); | ||||
|     if (oldVersion < m_foundVersion) | ||||
|         return showUpdates(m_foundVersion); | ||||
|     else if (_showAnyway) | ||||
| @ -157,18 +147,12 @@ void AWUpdateHelper::versionReplyRecieved(QNetworkReply *_reply, const bool _sho | ||||
|  | ||||
|  | ||||
| // additional method which is used to show message box which does not block UI | ||||
| QMessageBox *AWUpdateHelper::genMessageBox(const QString &_title, const QString &_body, | ||||
|                                            const QMessageBox::StandardButtons _buttons) | ||||
| KNotification *AWUpdateHelper::sendNotification(const QString &_title, const QString &_body) | ||||
| { | ||||
|     qCDebug(LOG_AW) << "Construct message box with title" << _title << "and body" << _body; | ||||
|  | ||||
|     auto *msgBox = new QMessageBox(nullptr); | ||||
|     msgBox->setAttribute(Qt::WA_DeleteOnClose); | ||||
|     msgBox->setModal(false); | ||||
|     msgBox->setWindowTitle(_title); | ||||
|     msgBox->setText(_body); | ||||
|     msgBox->setStandardButtons(_buttons); | ||||
|     msgBox->setIcon(QMessageBox::Information); | ||||
|     auto event = KNotification::event("system", _title, _body); | ||||
|     event->setComponentName("plasma-applet-org.kde.plasma.awesome-widget"); | ||||
|  | ||||
|     return msgBox; | ||||
|     return event; | ||||
| } | ||||
|  | ||||
| @ -15,39 +15,33 @@ | ||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||
|  ***************************************************************************/ | ||||
|  | ||||
| #pragma once | ||||
|  | ||||
| #ifndef AWUPDATEHELPER_H | ||||
| #define AWUPDATEHELPER_H | ||||
|  | ||||
| #include <QMessageBox> | ||||
| #include <QObject> | ||||
| #include <QVersionNumber> | ||||
|  | ||||
|  | ||||
| class KNotification; | ||||
| class QNetworkReply; | ||||
|  | ||||
| class AWUpdateHelper : public QObject | ||||
| class __attribute__((visibility("default"))) AWUpdateHelper : public QObject | ||||
| { | ||||
|     Q_OBJECT | ||||
|  | ||||
| public: | ||||
|     explicit AWUpdateHelper(QObject *_parent = nullptr); | ||||
|     ~AWUpdateHelper() override; | ||||
|     ~AWUpdateHelper() override = default; | ||||
|     void checkUpdates(bool _showAnyway = false); | ||||
|     bool checkVersion(); | ||||
|  | ||||
| private slots: | ||||
|     void openReleasesPage(); | ||||
|     static void showInfo(const QVersionNumber &_version); | ||||
|     void showUpdates(const QVersionNumber &_version); | ||||
|     void userReplyOnUpdates(QAbstractButton *_button); | ||||
|     void versionReplyRecieved(QNetworkReply *_reply, bool _showAnyway); | ||||
|     void showUpdates(const QVersionNumber &_version) const; | ||||
|     void versionReplyReceived(QNetworkReply *_reply, bool _showAnyway); | ||||
|  | ||||
| private: | ||||
|     static QMessageBox *genMessageBox(const QString &_title, const QString &_body, | ||||
|                                       QMessageBox::StandardButtons _buttons); | ||||
|     static KNotification *sendNotification(const QString &_title, const QString &_body); | ||||
|     QVersionNumber m_foundVersion; | ||||
|     QString m_genericConfig; | ||||
| }; | ||||
|  | ||||
|  | ||||
| #endif /* AWUPDATEHELPER_H */ | ||||
|  | ||||
| @ -0,0 +1,37 @@ | ||||
| /*************************************************************************** | ||||
|  *   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 <QString> | ||||
|  | ||||
|  | ||||
| class AWFormatterHelper; | ||||
|  | ||||
| struct AWPluginFormatSettings { | ||||
|     QString acOffline; | ||||
|     QString acOnline; | ||||
|  | ||||
|     QString customTime; | ||||
|     QString customUptime; | ||||
|  | ||||
|     QString tempUnits; | ||||
|  | ||||
|     bool translate = false; | ||||
|  | ||||
|     AWFormatterHelper *customFormatters = nullptr; | ||||
| }; | ||||
							
								
								
									
										69
									
								
								sources/awesome-widget/plugin/formatters/awpluginformatter.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										69
									
								
								sources/awesome-widget/plugin/formatters/awpluginformatter.h
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,69 @@ | ||||
| /*************************************************************************** | ||||
|  *   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 <QLocale> | ||||
| #include <QVariant> | ||||
|  | ||||
| #include <memory> | ||||
|  | ||||
| #include "awpluginformatsettings.h" | ||||
|  | ||||
|  | ||||
| class AWPluginFormaterInterface | ||||
| { | ||||
| public: | ||||
|     virtual ~AWPluginFormaterInterface() = default; | ||||
|     [[nodiscard]] virtual QString format(const QVariant &_value, const QString &_key, | ||||
|                                          const AWPluginFormatSettings &_settings) const | ||||
|         = 0; | ||||
|     virtual void load(){}; | ||||
| }; | ||||
|  | ||||
|  | ||||
| template <typename Formatter> class AWPluginFormatter : public AWPluginFormaterInterface | ||||
| { | ||||
| public: | ||||
|     static constexpr double KBinBytes = 1024.0; | ||||
|     static constexpr double MBinBytes = 1024.0 * KBinBytes; | ||||
|     static constexpr double GBinBytes = 1024.0 * MBinBytes; | ||||
|  | ||||
|     AWPluginFormatter(AWPluginFormatter &) = delete; | ||||
|     void operator=(const AWPluginFormatter &) = delete; | ||||
|  | ||||
|     [[nodiscard]] static Formatter *instance() | ||||
|     { | ||||
|         static auto instance = loadInstance(); | ||||
|         return instance.get(); | ||||
|     }; | ||||
|  | ||||
|     [[nodiscard]] static QLocale locale(const AWPluginFormatSettings &_settings) | ||||
|     { | ||||
|         return _settings.translate ? QLocale::system() : QLocale::c(); | ||||
|     }; | ||||
|  | ||||
| protected: | ||||
|     AWPluginFormatter() = default; | ||||
|  | ||||
|     [[nodiscard]] static std::unique_ptr<Formatter> loadInstance() | ||||
|     { | ||||
|         auto instance = std::make_unique<Formatter>(); | ||||
|         instance->load(); | ||||
|         return instance; | ||||
|     }; | ||||
| }; | ||||
| @ -0,0 +1,25 @@ | ||||
| /*************************************************************************** | ||||
|  *   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 "awpluginformatterac.h" | ||||
|  | ||||
|  | ||||
| QString AWPluginFormatterAC::format(const QVariant &_value, const QString &, | ||||
|                                     const AWPluginFormatSettings &_settings) const | ||||
| { | ||||
|     return _value.toBool() ? _settings.acOnline : _settings.acOffline; | ||||
| } | ||||
| @ -0,0 +1,28 @@ | ||||
| /*************************************************************************** | ||||
|  *   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 "awpluginformatter.h" | ||||
|  | ||||
|  | ||||
| class AWPluginFormatterAC : public AWPluginFormatter<AWPluginFormatterAC> | ||||
| { | ||||
| public: | ||||
|     [[nodiscard]] QString format(const QVariant &_value, const QString &, | ||||
|                                  const AWPluginFormatSettings &_settings) const override; | ||||
| }; | ||||
| @ -0,0 +1,29 @@ | ||||
| /*************************************************************************** | ||||
|  *   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 "awpluginformattercustom.h" | ||||
|  | ||||
| #include "awformatterhelper.h" | ||||
|  | ||||
|  | ||||
| QString AWPluginFormatterCustom::format(const QVariant &_value, const QString &_key, | ||||
|                                         const AWPluginFormatSettings &_settings) const | ||||
| { | ||||
|     if (_settings.customFormatters) | ||||
|         return _settings.customFormatters->convert(_value, _key); | ||||
|     return _value.toString(); | ||||
| } | ||||
| @ -0,0 +1,28 @@ | ||||
| /*************************************************************************** | ||||
|  *   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 "awpluginformatter.h" | ||||
|  | ||||
|  | ||||
| class AWPluginFormatterCustom : public AWPluginFormatter<AWPluginFormatterCustom> | ||||
| { | ||||
| public: | ||||
|     [[nodiscard]] QString format(const QVariant &_value, const QString &_key, | ||||
|                                  const AWPluginFormatSettings &_settings) const override; | ||||
| }; | ||||
| @ -0,0 +1,25 @@ | ||||
| /*************************************************************************** | ||||
|  *   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 "awpluginformatterdouble.h" | ||||
|  | ||||
|  | ||||
| QString AWPluginFormatterDouble::format(const QVariant &_value, const QString &, const AWPluginFormatSettings &) const | ||||
| { | ||||
|     auto output = QString("%1").arg(_value.toDouble(), 0, 'f'); | ||||
|     return output.rightJustified(8, QLatin1Char(' '), true); | ||||
| } | ||||
| @ -0,0 +1,28 @@ | ||||
| /*************************************************************************** | ||||
|  *   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 "awpluginformatter.h" | ||||
|  | ||||
|  | ||||
| class AWPluginFormatterDouble : public AWPluginFormatter<AWPluginFormatterDouble> | ||||
| { | ||||
| public: | ||||
|     [[nodiscard]] QString format(const QVariant &_value, const QString &, | ||||
|                                  const AWPluginFormatSettings &) const override; | ||||
| }; | ||||
| @ -0,0 +1,24 @@ | ||||
| /*************************************************************************** | ||||
|  *   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 "awpluginformatterfloat.h" | ||||
|  | ||||
|  | ||||
| QString AWPluginFormatterFloat::format(const QVariant &_value, const QString &, const AWPluginFormatSettings &) const | ||||
| { | ||||
|     return QString("%1").arg(_value.toDouble(), 5, 'f', 1); | ||||
| } | ||||
| @ -0,0 +1,28 @@ | ||||
| /*************************************************************************** | ||||
|  *   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 "awpluginformatter.h" | ||||
|  | ||||
|  | ||||
| class AWPluginFormatterFloat : public AWPluginFormatter<AWPluginFormatterFloat> | ||||
| { | ||||
| public: | ||||
|     [[nodiscard]] QString format(const QVariant &_value, const QString &, | ||||
|                                  const AWPluginFormatSettings &) const override; | ||||
| }; | ||||
| @ -0,0 +1,25 @@ | ||||
| /*************************************************************************** | ||||
|  *   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 "awpluginformatterfloatprecise.h" | ||||
|  | ||||
|  | ||||
| QString AWPluginFormatterFloatPrecise::format(const QVariant &_value, const QString &, | ||||
|                                               const AWPluginFormatSettings &) const | ||||
| { | ||||
|     return QString("%1").arg(_value.toDouble(), 5, 'f', 2); | ||||
| } | ||||
| @ -0,0 +1,28 @@ | ||||
| /*************************************************************************** | ||||
|  *   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 "awpluginformatter.h" | ||||
|  | ||||
|  | ||||
| class AWPluginFormatterFloatPrecise : public AWPluginFormatter<AWPluginFormatterFloatPrecise> | ||||
| { | ||||
| public: | ||||
|     [[nodiscard]] QString format(const QVariant &_value, const QString &, | ||||
|                                  const AWPluginFormatSettings &) const override; | ||||
| }; | ||||
| @ -0,0 +1,24 @@ | ||||
| /*************************************************************************** | ||||
|  *   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 "awpluginformatterinteger.h" | ||||
|  | ||||
|  | ||||
| QString AWPluginFormatterInteger::format(const QVariant &_value, const QString &, const AWPluginFormatSettings &) const | ||||
| { | ||||
|     return QString("%1").arg(_value.toDouble(), 4, 'f', 0); | ||||
| } | ||||
| @ -0,0 +1,28 @@ | ||||
| /*************************************************************************** | ||||
|  *   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 "awpluginformatter.h" | ||||
|  | ||||
|  | ||||
| class AWPluginFormatterInteger : public AWPluginFormatter<AWPluginFormatterInteger> | ||||
| { | ||||
| public: | ||||
|     [[nodiscard]] QString format(const QVariant &_value, const QString &, | ||||
|                                  const AWPluginFormatSettings &) const override; | ||||
| }; | ||||
| @ -0,0 +1,25 @@ | ||||
| /*************************************************************************** | ||||
|  *   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 "awpluginformatterintegershort.h" | ||||
|  | ||||
|  | ||||
| QString AWPluginFormatterIntegerShort::format(const QVariant &_value, const QString &, | ||||
|                                               const AWPluginFormatSettings &) const | ||||
| { | ||||
|     return QString("%1").arg(_value.toDouble(), 3, 'f', 0); | ||||
| } | ||||
| @ -0,0 +1,28 @@ | ||||
| /*************************************************************************** | ||||
|  *   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 "awpluginformatter.h" | ||||
|  | ||||
|  | ||||
| class AWPluginFormatterIntegerShort : public AWPluginFormatter<AWPluginFormatterIntegerShort> | ||||
| { | ||||
| public: | ||||
|     [[nodiscard]] QString format(const QVariant &_value, const QString &, | ||||
|                                  const AWPluginFormatSettings &) const override; | ||||
| }; | ||||
| @ -0,0 +1,25 @@ | ||||
| /*************************************************************************** | ||||
|  *   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 "awpluginformatterintegerwide.h" | ||||
|  | ||||
|  | ||||
| QString AWPluginFormatterIntegerWide::format(const QVariant &_value, const QString &, | ||||
|                                              const AWPluginFormatSettings &) const | ||||
| { | ||||
|     return QString("%1").arg(_value.toDouble(), 5, 'f', 0); | ||||
| } | ||||
| @ -0,0 +1,28 @@ | ||||
| /*************************************************************************** | ||||
|  *   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 "awpluginformatter.h" | ||||
|  | ||||
|  | ||||
| class AWPluginFormatterIntegerWide : public AWPluginFormatter<AWPluginFormatterIntegerWide> | ||||
| { | ||||
| public: | ||||
|     [[nodiscard]] QString format(const QVariant &_value, const QString &, | ||||
|                                  const AWPluginFormatSettings &) const override; | ||||
| }; | ||||
| @ -0,0 +1,24 @@ | ||||
| /*************************************************************************** | ||||
|  *   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 "awpluginformatterlist.h" | ||||
|  | ||||
|  | ||||
| QString AWPluginFormatterList::format(const QVariant &_value, const QString &, const AWPluginFormatSettings &) const | ||||
| { | ||||
|     return _value.toStringList().join(","); | ||||
| } | ||||
| @ -0,0 +1,28 @@ | ||||
| /*************************************************************************** | ||||
|  *   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 "awpluginformatter.h" | ||||
|  | ||||
|  | ||||
| class AWPluginFormatterList : public AWPluginFormatter<AWPluginFormatterList> | ||||
| { | ||||
| public: | ||||
|     [[nodiscard]] QString format(const QVariant &_value, const QString &, | ||||
|                                  const AWPluginFormatSettings &) const override; | ||||
| }; | ||||
| @ -0,0 +1,24 @@ | ||||
| /*************************************************************************** | ||||
|  *   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 "awpluginformattermemory.h" | ||||
|  | ||||
|  | ||||
| QString AWPluginFormatterMemory::format(const QVariant &_value, const QString &, const AWPluginFormatSettings &) const | ||||
| { | ||||
|     return QString("%1").arg(_value.toDouble() / KBinBytes, 5, 'f', 0); | ||||
| } | ||||
| @ -0,0 +1,28 @@ | ||||
| /*************************************************************************** | ||||
|  *   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 "awpluginformatter.h" | ||||
|  | ||||
|  | ||||
| class AWPluginFormatterMemory : public AWPluginFormatter<AWPluginFormatterMemory> | ||||
| { | ||||
| public: | ||||
|     [[nodiscard]] QString format(const QVariant &_value, const QString &, | ||||
|                                  const AWPluginFormatSettings &) const override; | ||||
| }; | ||||
| @ -0,0 +1,24 @@ | ||||
| /*************************************************************************** | ||||
|  *   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 "awpluginformattermemorygb.h" | ||||
|  | ||||
|  | ||||
| QString AWPluginFormatterMemoryGB::format(const QVariant &_value, const QString &, const AWPluginFormatSettings &) const | ||||
| { | ||||
|     return QString("%1").arg(_value.toDouble() / GBinBytes, 5, 'f', 1); | ||||
| } | ||||
| @ -0,0 +1,28 @@ | ||||
| /*************************************************************************** | ||||
|  *   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 "awpluginformatter.h" | ||||
|  | ||||
|  | ||||
| class AWPluginFormatterMemoryGB : public AWPluginFormatter<AWPluginFormatterMemoryGB> | ||||
| { | ||||
| public: | ||||
|     [[nodiscard]] QString format(const QVariant &_value, const QString &, | ||||
|                                  const AWPluginFormatSettings &) const override; | ||||
| }; | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user
	![transifex-integration[bot]](/assets/img/avatar_default.png)