mirror of
				https://github.com/arcan1s/awesome-widgets.git
				synced 2025-10-26 03:13:42 +00:00 
			
		
		
		
	Compare commits
	
		
			18 Commits
		
	
	
		
			4.0.0alpha
			...
			84e5b7d64e
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 84e5b7d64e | |||
| 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: | on: | ||||||
|   push: |   push: | ||||||
|     branches: [ development, master ] |     branches: | ||||||
|  |       - master | ||||||
|   pull_request: |   pull_request: | ||||||
|     branches: [ development, master ] |     branches: | ||||||
|  |       - master | ||||||
|  |  | ||||||
| env: | env: | ||||||
|   BUILD_TYPE: Release |   BUILD_TYPE: Release | ||||||
| @ -24,13 +26,13 @@ jobs: | |||||||
|     - uses: actions/checkout@v3 |     - uses: actions/checkout@v3 | ||||||
|  |  | ||||||
|     - name: create build environment |     - 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 |     - name: install dependencies | ||||||
|       run: pacman -S --noconfirm plasma-workspace ksysguard |       run: pacman -S --noconfirm plasma-workspace | ||||||
|      |      | ||||||
|     - name: configure cmake |     - 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 |     - name: build | ||||||
|       working-directory: /repo/build |       working-directory: /repo/build | ||||||
|  | |||||||
							
								
								
									
										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. | `clangformat` (see below). Some additional detail see below. | ||||||
|  |  | ||||||
| * Indent is only spaces. 4 spaces. | * Indent is only spaces. 4 spaces. | ||||||
| * Any private variable should start with `m_` prefix (`m_foo`). The only one | * Any private variable should start with `m_` prefix (`m_foo`). The only one exception is `Ui` object which should be named as `ui`. | ||||||
|   exception is `Ui` object which should be named as `ui`. |  | ||||||
| * Avoid to create a large methods. Exception: if method contains lambda functions. | * 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. | * STL containers are not recommended, use Qt ones instead. | ||||||
| * In other hand Qt specific variables types (`qint`, `qfloat`, etc) are not | * In other hand Qt specific variables types (`qint`, `qfloat`, etc) are not recommended. | ||||||
|   recommended. |  | ||||||
| * Do not repeat yourself ([DRY](https://en.wikipedia.org/wiki/Don't_repeat_yourself)). | * Do not repeat yourself ([DRY](https://en.wikipedia.org/wiki/Don't_repeat_yourself)). | ||||||
| * Headers declaration: | * Headers declaration: | ||||||
|     * Include only those headers which are strictly necessary inside headers. Use |     * Include only those headers which are strictly necessary inside headers. Use forward class declaration instead. Exception is base class header declaration. | ||||||
|       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: | ||||||
|     * In a`*.cpp` file header declaration should have the following order separated |  | ||||||
|       by a new line in the alphabet order: |  | ||||||
|         1. Class header. |         1. Class header. | ||||||
|         2. KDE specific headers. |         2. KDE specific headers. | ||||||
|         3. Qt specific headers. |         3. Qt specific headers. | ||||||
|         4. Third party headers. |         4. Third party headers. | ||||||
|         5. Project headers. |         5. Project headers. | ||||||
|     * Any header should have [include guard](https://en.wikipedia.org/wiki/Include_guard) |     * Any header should have `#pragma once`. | ||||||
|       named as `CLASSNAMECAPS_H` |  | ||||||
| * If any `#if` directive is used condition should be mentioned in `#endif`: | * 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. | * `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 | * 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. | ||||||
| `Q_FOREACH` (`foreach`) is not allowed use `for (auto &foo : bar)` instead. | * Current project standard is **C++23**. | ||||||
| * Current project standard is **C++17**. |  | ||||||
| * Do not use C-like code: | * Do not use C-like code: | ||||||
|     * C-like style iteration if possible. Use `for (auto &foo : bar)` and |     * 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. | ||||||
|       `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 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 `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. | * Abstract classes (which have at least one pure virtual method) are allowed. | ||||||
| * Templates are allowed and recommended. Templates usually should be described | * Templates are allowed and recommended. Templates usually should be described inside header not source code file. | ||||||
|   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. | ||||||
| * 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. | * Build should not require any additional system variable declaration/changing. | ||||||
| * Any line should not end with space. | * Any line should not end with space. | ||||||
| * Do not hesitate move public methods to private one if possible. | * Do not hesitate move public methods to private one if possible. | ||||||
| * Do not hesitate use `const` modifier. In other hand `volatile` modifier is not | * Do not hesitate use `const` modifier. In other hand `volatile` modifier is not recommended. | ||||||
|   recommended. |  | ||||||
| * New lines rules: | * New lines rules: | ||||||
|     * One line after license header. |     * One line after license header. | ||||||
|     * One line between header group declaration (see above). |     * One line between header group declaration (see above). | ||||||
|     * Two lines after header declaration and before declaration at the end of a |     * Two lines after header declaration and before declaration at the end of a file. | ||||||
|       file. |  | ||||||
|     * One line after class and types forward declarations in headers. |     * One line after class and types forward declarations in headers. | ||||||
|     * One line before each method modifiers (`public`, `public slots`, etc). |     * One line before each method modifiers (`public`, `public slots`, etc). | ||||||
|     * Two lines between methods inside source code (`*.cpp`). |     * Two lines between methods inside source code (`*.cpp`). | ||||||
|     * One line after `qCDebug()` information (see below). |     * One line after `qCDebug()` information (see below). | ||||||
|     * One line inside a method to improve code reading. |     * One line inside a method to improve code reading. | ||||||
| * Each destructor should be virtual. | * Each destructor should be virtual. | ||||||
| * Class constructor should have default arguments. Use `QObject *parent` property | * Class constructor should have default arguments. Use `QObject *_parent` property for QObject based classes. | ||||||
|   for QObject based classes. |  | ||||||
| * QObject based classes constructors should have explicit modifier. | * QObject based classes constructors should have explicit modifier. | ||||||
| * Create one file (source and header) per class. | * Create one file (source and header) per class. | ||||||
| * `else if` construction is allowed and recommended. | * `else if` construction is allowed and recommended. | ||||||
| * 'true ? foo : bar' construction is allowed and recommended for one-line assignment. | * 'true ? foo : bar' construction is allowed and recommended for one-line assignment. | ||||||
| * Any global pointer should be assign to `nullptr` after deletion and before | * Any global pointer should be assigned to `nullptr` after deletion and before initialization. Exception: if object is deleted into class destructor. | ||||||
|   initialization. Exception: if object is deleted into class destructor. |  | ||||||
| * Do not use semicolon in qml files unless it is required. | * Do not use semicolon in qml files unless it is required. | ||||||
| * Any method argument including class constructors should start with `_`. | * Any method argument including class constructors should start with `_`. | ||||||
|  |  | ||||||
| Comments | Comments | ||||||
| -------- | -------- | ||||||
|  |  | ||||||
| Please do not hesitate to use comments inside source code (especially in non-obvious | Please do not hesitate to use comments inside source code (especially in non-obvious blocks). Comments also may use the following keywords: | ||||||
| blocks). Comments also may use the following keywords: |  | ||||||
|  |  | ||||||
| * **TODO** - indicates that some new code should be implemented here later. Please | * **TODO** - indicates that some new code should be implemented here later. Please note that usually these methods should be implemented before the next release. | ||||||
|   note that usually these methods should be implemented before the next release. |  | ||||||
| * **FIXME** - some dirty hacks and/or methods which should be done better. | * **FIXME** - some dirty hacks and/or methods which should be done better. | ||||||
| * **HACK** - hacks inside code which requires to avoid some restrictions and/or | * **HACK** - hacks inside code which requires to avoid some restrictions and/or which adds additional non-obvious optimizations. | ||||||
|   which adds additional non-obvious optimizations. |  | ||||||
|  |  | ||||||
| Do not use dots at the end of the comment line. | Do not use dots at the end of the comment line. | ||||||
|  |  | ||||||
| Development | Development | ||||||
| ----------- | ----------- | ||||||
|  |  | ||||||
| * Officially the latest libraries versions should be used. In addition it is | * 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. | ||||||
|   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. | * Build should not contain any warning. | ||||||
| * Try to minimize message in Release build with logging disabled. It is highly | * Try to minimize message in Release build with logging disabled. It is highly recommended to fix KDE/Qt specific warning if possible | ||||||
|   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. | ||||||
| * 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. | * 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 | * The main branch is **master**. | ||||||
|   master one only if it is a 'stable' build. | * For experimental features development new branch `feature/foo` creation is allowed and recommended. | ||||||
| * For experimental features development new branch `feature-foo` creation is allowed |  | ||||||
|   and recommended. |  | ||||||
| * Experimental features should be added inside `BUILD_FUTURE` definition: | * Experimental features should be added inside `BUILD_FUTURE` definition: | ||||||
|  |  | ||||||
|   ``` |   ``` | ||||||
| @ -118,54 +91,41 @@ Development | |||||||
|   #endif /* BUILD_FUTURE */ |   #endif /* BUILD_FUTURE */ | ||||||
|   ``` |   ``` | ||||||
|  |  | ||||||
| * Any project specific build variable should be mentioned inside `version.h` as | * Any project specific build variable should be mentioned inside `version.h` as well. | ||||||
|   well. |  | ||||||
| * Recommended compiler is `clang`. | * Recommended compiler is `clang`. | ||||||
|  |  | ||||||
| HIG | HIG | ||||||
| --- | --- | ||||||
|  |  | ||||||
| The recommended HIG is [KDE one](https://techbase.kde.org/Projects/Usability/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. | ||||||
| Avoid to paint interfaces inside plugin because QML and C++ parts may have different |  | ||||||
| theming. |  | ||||||
|  |  | ||||||
| Licensing | Licensing | ||||||
| --------- | --------- | ||||||
|  |  | ||||||
| All files should be licensed under GPLv3, the owner of the license should be the | 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. | ||||||
| project (i.e. **awesome-widgets**). See **Tools** section for more details. |  | ||||||
|  |  | ||||||
| Logging | Logging | ||||||
| ------- | ------- | ||||||
|  |  | ||||||
| For logging please use [QLoggingCategory](http://doc.qt.io/qt-5/qloggingcategory.html). | 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: | ||||||
| Available categories should be declared in `awdebug.*` files. The following log |  | ||||||
| levels should be used: |  | ||||||
|  |  | ||||||
| * **debug** (`qCDebug()`) - method arguments information. Please note that it | * **debug** (`qCDebug()`) - method arguments information. Please note that it is recommended to logging all arguments in the one line. | ||||||
|   is recommended to logging all arguments in the one line. |  | ||||||
| * **info** (`qCInfo()`) - additional information inside methods. | * **info** (`qCInfo()`) - additional information inside methods. | ||||||
| * **warning** (`qCWarning()`) - not critical information, which may be caused by | * **warning** (`qCWarning()`) - not critical information, which may be caused by mistakes in configuration for example. | ||||||
|   mistakes in configuration for example. | * **critical** (`qCCritical()`) - a critical error. After this error program may be terminated. | ||||||
| * **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 | 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. | ||||||
| will be stripped by compiler with `Release` build type. To log class constructor |  | ||||||
| and destructor use `__PRETTY_FUNCTION__` macro. |  | ||||||
|  |  | ||||||
| Testing | Testing | ||||||
| ------- | ------- | ||||||
|  |  | ||||||
| * Any changes should be tested by using `plasmawindowed` and `plasmashell` applications. | * Any changes should be tested by using `plasmawindowed` and `plasmashell` applications. (It is also possible to use `plasmaengineexplorer` and `plasmoidviewer` in addition.) | ||||||
|   (It is also possible to use `plasmaengineexplorer` and `plasmoidviewer` in addition.) |  | ||||||
| * Any test should be performed on real (not Virtual Machine) system. | * Any test should be performed on real (not Virtual Machine) system. | ||||||
| * Test builds should be: | * Test builds should be: | ||||||
|     1. `-DCMAKE_BUILD_TYPE=Debug`. |     1. `-DCMAKE_BUILD_TYPE=Debug`. | ||||||
|     2. `-DCMAKE_BUILD_TYPE=Debug -DBUILD_TESTING=ON`. |     2. `-DCMAKE_BUILD_TYPE=Debug -DBUILD_TESTING=ON`. | ||||||
|     3. `-DCMAKE_BUILD_TYPE=Release`. |     3. `-DCMAKE_BUILD_TYPE=Release`. | ||||||
| * Additional test functions should be declated and used only inside `BUILD_TESTING` | * Additional test functions should be declated and used only inside `BUILD_TESTING` definition. | ||||||
|   definition. |  | ||||||
|  |  | ||||||
| Tools | Tools | ||||||
| ----- | ----- | ||||||
| @ -222,7 +182,6 @@ Tools | |||||||
|         // declare with default value |         // declare with default value | ||||||
|         bool m_prop = false; |         bool m_prop = false; | ||||||
|   ``` |   ``` | ||||||
| * Use `cppcheck` to avoid common errors in the code. To start application just | * Use `cppcheck` to avoid common errors in the code. To start application just run `make cppcheck`. | ||||||
|   run `make cppcheck`. | * Use `clang-format` to apply valid code format. To start application just run `make clangformat`. | ||||||
| * Use `clang-format` to apply valid code format. To start application just run | * use `-DCMAKE_CXX_COMPILER=clang++` in order to enable clang-tidy checks. | ||||||
|   `make clangformat`. |  | ||||||
|  | |||||||
							
								
								
									
										27
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										27
									
								
								README.md
									
									
									
									
									
								
							| @ -14,11 +14,11 @@ A collection of minimalistic widgets which looks like Awesome Window Manager wid | |||||||
| Features | Features | ||||||
| ======== | ======== | ||||||
|  |  | ||||||
| * easy and fully configurable native Plasma widget which may be used as Conky widget or as Awesome-like information panel | * easy and fully configurable native Plasma widget which may be used as desktop or panel widget | ||||||
| * panel which shows active desktop status | * additionnal widget which shows active desktop status | ||||||
| * clear Conky-like configuration with html tags support | * clear text configuration with html tags support | ||||||
| * custom command support (it may be simple action as well as special custom tag) | * 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. | See [links](#Links) for more details. | ||||||
|  |  | ||||||
| @ -30,15 +30,11 @@ Instruction | |||||||
| Dependencies | Dependencies | ||||||
| ------------ | ------------ | ||||||
|  |  | ||||||
| * plasma-framework | * plasma-workspace | ||||||
| * ksysguard (since plasma 5.22) |  | ||||||
|  |  | ||||||
| Optional dependencies | Optional dependencies | ||||||
| --------------------- | --------------------- | ||||||
|  |  | ||||||
| * proprietary video driver |  | ||||||
| * hddtemp |  | ||||||
| * smartmontools |  | ||||||
| * music player (mpd or MPRIS supported) | * music player (mpd or MPRIS supported) | ||||||
| * wireless_tools | * wireless_tools | ||||||
|  |  | ||||||
| @ -48,19 +44,20 @@ Make dependencies | |||||||
| * cmake | * cmake | ||||||
| * extra-cmake-modules | * 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 | Installation | ||||||
| ------------ | ------------ | ||||||
|  |  | ||||||
| * download sources | * download sources | ||||||
| * install | * build package | ||||||
|  |  | ||||||
|         mkdir build && cd build |       cmake -B build -S sources -DCMAKE_BUILD_TYPE=Release | ||||||
|         cmake -DCMAKE_BUILD_TYPE=Release -DCMAKE_INSTALL_PREFIX=/usr ../sources |       cmake --build build | ||||||
|         make && sudo make install |  | ||||||
|  |  | ||||||
|   **NOTE** on Plasma 5 it very likely requires `-DKDE_INSTALL_USE_QT_SYS_PATHS=ON` flag | * install package  | ||||||
|  |  | ||||||
|  |       cmake --install build | ||||||
|  |  | ||||||
| Additional information | Additional information | ||||||
| ====================== | ====================== | ||||||
|  | |||||||
| @ -2,17 +2,15 @@ | |||||||
|  |  | ||||||
| pkgname=plasma6-applet-awesome-widgets | pkgname=plasma6-applet-awesome-widgets | ||||||
| _pkgname=awesome-widgets | _pkgname=awesome-widgets | ||||||
| pkgver=4.0.0alpha1 | pkgver=4.0.0alpha2 | ||||||
| pkgrel=1 | pkgrel=1 | ||||||
| pkgdesc="Collection of minimalistic Plasmoids which look like Awesome WM widgets (ex-PyTextMonitor)" | pkgdesc="Collection of minimalistic Plasmoids which look like Awesome WM widgets (ex-PyTextMonitor)" | ||||||
| arch=('x86_64') | arch=('x86_64') | ||||||
| url="https://arcanis.me/projects/awesome-widgets" | url="https://arcanis.me/projects/awesome-widgets" | ||||||
| license=('GPL3') | license=('GPL3') | ||||||
| depends=('plasma-workspace') | depends=('plasma-workspace') | ||||||
| optdepends=("hddtemp: for HDD temperature monitor" | optdepends=("mpd: for music player monitor" | ||||||
|             "smartmontools: for HDD temperature monitor" |             "wireless_tools: wifi information") | ||||||
|             "mpd: for music player monitor" |  | ||||||
|             "nvidia-utils: for GPU monitor") |  | ||||||
| makedepends=('cmake' 'extra-cmake-modules' 'python') | makedepends=('cmake' 'extra-cmake-modules' 'python') | ||||||
| source=(https://github.com/arcan1s/awesome-widgets/releases/download/${pkgver}/${_pkgname}-${pkgver}-src.tar.xz) | source=(https://github.com/arcan1s/awesome-widgets/releases/download/${pkgver}/${_pkgname}-${pkgver}-src.tar.xz) | ||||||
| install="$pkgname.install" | install="$pkgname.install" | ||||||
|  | |||||||
							
								
								
									
										284
									
								
								sensors
									
									
									
									
									
								
							
							
						
						
									
										284
									
								
								sensors
									
									
									
									
									
								
							| @ -1,284 +0,0 @@ | |||||||
| cpu |  | ||||||
| cpu/all |  | ||||||
| cpu/all/averageFrequency |  | ||||||
| cpu/all/averageTemperature |  | ||||||
| cpu/all/coreCount |  | ||||||
| cpu/all/cpuCount |  | ||||||
| cpu/all/maximumFrequency |  | ||||||
| cpu/all/maximumTemperature |  | ||||||
| cpu/all/minimumFrequency |  | ||||||
| cpu/all/minimumTemperature |  | ||||||
| cpu/all/name |  | ||||||
| cpu/all/system |  | ||||||
| cpu/all/usage |  | ||||||
| cpu/all/user |  | ||||||
| cpu/all/wait |  | ||||||
| cpu/cpu0 |  | ||||||
| cpu/cpu0/frequency |  | ||||||
| cpu/cpu0/name |  | ||||||
| cpu/cpu0/system |  | ||||||
| cpu/cpu0/temperature |  | ||||||
| cpu/cpu0/usage |  | ||||||
| cpu/cpu0/user |  | ||||||
| cpu/cpu0/wait |  | ||||||
| cpu/cpu1 |  | ||||||
| cpu/cpu1/frequency |  | ||||||
| cpu/cpu1/name |  | ||||||
| cpu/cpu1/system |  | ||||||
| cpu/cpu1/temperature |  | ||||||
| cpu/cpu1/usage |  | ||||||
| cpu/cpu1/user |  | ||||||
| cpu/cpu1/wait |  | ||||||
| cpu/cpu10 |  | ||||||
| cpu/cpu10/frequency |  | ||||||
| cpu/cpu10/name |  | ||||||
| cpu/cpu10/system |  | ||||||
| cpu/cpu10/temperature |  | ||||||
| cpu/cpu10/usage |  | ||||||
| cpu/cpu10/user |  | ||||||
| cpu/cpu10/wait |  | ||||||
| cpu/cpu11 |  | ||||||
| cpu/cpu11/frequency |  | ||||||
| cpu/cpu11/name |  | ||||||
| cpu/cpu11/system |  | ||||||
| cpu/cpu11/temperature |  | ||||||
| cpu/cpu11/usage |  | ||||||
| cpu/cpu11/user |  | ||||||
| cpu/cpu11/wait |  | ||||||
| cpu/cpu12 |  | ||||||
| cpu/cpu12/frequency |  | ||||||
| cpu/cpu12/name |  | ||||||
| cpu/cpu12/system |  | ||||||
| cpu/cpu12/temperature |  | ||||||
| cpu/cpu12/usage |  | ||||||
| cpu/cpu12/user |  | ||||||
| cpu/cpu12/wait |  | ||||||
| cpu/cpu13 |  | ||||||
| cpu/cpu13/frequency |  | ||||||
| cpu/cpu13/name |  | ||||||
| cpu/cpu13/system |  | ||||||
| cpu/cpu13/temperature |  | ||||||
| cpu/cpu13/usage |  | ||||||
| cpu/cpu13/user |  | ||||||
| cpu/cpu13/wait |  | ||||||
| cpu/cpu14 |  | ||||||
| cpu/cpu14/frequency |  | ||||||
| cpu/cpu14/name |  | ||||||
| cpu/cpu14/system |  | ||||||
| cpu/cpu14/temperature |  | ||||||
| cpu/cpu14/usage |  | ||||||
| cpu/cpu14/user |  | ||||||
| cpu/cpu14/wait |  | ||||||
| cpu/cpu15 |  | ||||||
| cpu/cpu15/frequency |  | ||||||
| cpu/cpu15/name |  | ||||||
| cpu/cpu15/system |  | ||||||
| cpu/cpu15/temperature |  | ||||||
| cpu/cpu15/usage |  | ||||||
| cpu/cpu15/user |  | ||||||
| cpu/cpu15/wait |  | ||||||
| cpu/cpu16 |  | ||||||
| cpu/cpu16/frequency |  | ||||||
| cpu/cpu16/name |  | ||||||
| cpu/cpu16/system |  | ||||||
| cpu/cpu16/temperature |  | ||||||
| cpu/cpu16/usage |  | ||||||
| cpu/cpu16/user |  | ||||||
| cpu/cpu16/wait |  | ||||||
| cpu/cpu17 |  | ||||||
| cpu/cpu17/frequency |  | ||||||
| cpu/cpu17/name |  | ||||||
| cpu/cpu17/system |  | ||||||
| cpu/cpu17/temperature |  | ||||||
| cpu/cpu17/usage |  | ||||||
| cpu/cpu17/user |  | ||||||
| cpu/cpu17/wait |  | ||||||
| cpu/cpu18 |  | ||||||
| cpu/cpu18/frequency |  | ||||||
| cpu/cpu18/name |  | ||||||
| cpu/cpu18/system |  | ||||||
| cpu/cpu18/temperature |  | ||||||
| cpu/cpu18/usage |  | ||||||
| cpu/cpu18/user |  | ||||||
| cpu/cpu18/wait |  | ||||||
| cpu/cpu19 |  | ||||||
| cpu/cpu19/frequency |  | ||||||
| cpu/cpu19/name |  | ||||||
| cpu/cpu19/system |  | ||||||
| cpu/cpu19/temperature |  | ||||||
| cpu/cpu19/usage |  | ||||||
| cpu/cpu19/user |  | ||||||
| cpu/cpu19/wait |  | ||||||
| cpu/cpu2 |  | ||||||
| cpu/cpu2/frequency |  | ||||||
| cpu/cpu2/name |  | ||||||
| cpu/cpu2/system |  | ||||||
| cpu/cpu2/temperature |  | ||||||
| cpu/cpu2/usage |  | ||||||
| cpu/cpu2/user |  | ||||||
| cpu/cpu2/wait |  | ||||||
| cpu/cpu3 |  | ||||||
| cpu/cpu3/frequency |  | ||||||
| cpu/cpu3/name |  | ||||||
| cpu/cpu3/system |  | ||||||
| cpu/cpu3/temperature |  | ||||||
| cpu/cpu3/usage |  | ||||||
| cpu/cpu3/user |  | ||||||
| cpu/cpu3/wait |  | ||||||
| cpu/cpu4 |  | ||||||
| cpu/cpu4/frequency |  | ||||||
| cpu/cpu4/name |  | ||||||
| cpu/cpu4/system |  | ||||||
| cpu/cpu4/temperature |  | ||||||
| cpu/cpu4/usage |  | ||||||
| cpu/cpu4/user |  | ||||||
| cpu/cpu4/wait |  | ||||||
| cpu/cpu5 |  | ||||||
| cpu/cpu5/frequency |  | ||||||
| cpu/cpu5/name |  | ||||||
| cpu/cpu5/system |  | ||||||
| cpu/cpu5/temperature |  | ||||||
| cpu/cpu5/usage |  | ||||||
| cpu/cpu5/user |  | ||||||
| cpu/cpu5/wait |  | ||||||
| cpu/cpu6 |  | ||||||
| cpu/cpu6/frequency |  | ||||||
| cpu/cpu6/name |  | ||||||
| cpu/cpu6/system |  | ||||||
| cpu/cpu6/temperature |  | ||||||
| cpu/cpu6/usage |  | ||||||
| cpu/cpu6/user |  | ||||||
| cpu/cpu6/wait |  | ||||||
| cpu/cpu7 |  | ||||||
| cpu/cpu7/frequency |  | ||||||
| cpu/cpu7/name |  | ||||||
| cpu/cpu7/system |  | ||||||
| cpu/cpu7/temperature |  | ||||||
| cpu/cpu7/usage |  | ||||||
| cpu/cpu7/user |  | ||||||
| cpu/cpu7/wait |  | ||||||
| cpu/cpu8 |  | ||||||
| cpu/cpu8/frequency |  | ||||||
| cpu/cpu8/name |  | ||||||
| cpu/cpu8/system |  | ||||||
| cpu/cpu8/temperature |  | ||||||
| cpu/cpu8/usage |  | ||||||
| cpu/cpu8/user |  | ||||||
| cpu/cpu8/wait |  | ||||||
| cpu/cpu9 |  | ||||||
| cpu/cpu9/frequency |  | ||||||
| cpu/cpu9/name |  | ||||||
| cpu/cpu9/system |  | ||||||
| cpu/cpu9/temperature |  | ||||||
| cpu/cpu9/usage |  | ||||||
| cpu/cpu9/user |  | ||||||
| cpu/cpu9/wait |  | ||||||
| cpu/loadaverages |  | ||||||
| cpu/loadaverages/loadaverage1 |  | ||||||
| cpu/loadaverages/loadaverage15 |  | ||||||
| cpu/loadaverages/loadaverage5 |  | ||||||
| disk |  | ||||||
| disk/52e29d18-ad4d-47ad-98c4-a09ab0914a85 |  | ||||||
| disk/52e29d18-ad4d-47ad-98c4-a09ab0914a85/free |  | ||||||
| disk/52e29d18-ad4d-47ad-98c4-a09ab0914a85/freePercent |  | ||||||
| disk/52e29d18-ad4d-47ad-98c4-a09ab0914a85/name |  | ||||||
| disk/52e29d18-ad4d-47ad-98c4-a09ab0914a85/read |  | ||||||
| disk/52e29d18-ad4d-47ad-98c4-a09ab0914a85/total |  | ||||||
| disk/52e29d18-ad4d-47ad-98c4-a09ab0914a85/used |  | ||||||
| disk/52e29d18-ad4d-47ad-98c4-a09ab0914a85/usedPercent |  | ||||||
| disk/52e29d18-ad4d-47ad-98c4-a09ab0914a85/write |  | ||||||
| disk/all |  | ||||||
| disk/all/free |  | ||||||
| disk/all/freePercent |  | ||||||
| disk/all/read |  | ||||||
| disk/all/total |  | ||||||
| disk/all/used |  | ||||||
| disk/all/usedPercent |  | ||||||
| disk/all/write |  | ||||||
| disk/d10dd7bf-e382-4e44-83d7-9af6c6df7258 |  | ||||||
| disk/d10dd7bf-e382-4e44-83d7-9af6c6df7258/free |  | ||||||
| disk/d10dd7bf-e382-4e44-83d7-9af6c6df7258/freePercent |  | ||||||
| disk/d10dd7bf-e382-4e44-83d7-9af6c6df7258/name |  | ||||||
| disk/d10dd7bf-e382-4e44-83d7-9af6c6df7258/read |  | ||||||
| disk/d10dd7bf-e382-4e44-83d7-9af6c6df7258/total |  | ||||||
| disk/d10dd7bf-e382-4e44-83d7-9af6c6df7258/used |  | ||||||
| disk/d10dd7bf-e382-4e44-83d7-9af6c6df7258/usedPercent |  | ||||||
| disk/d10dd7bf-e382-4e44-83d7-9af6c6df7258/write |  | ||||||
| disk/nvme0n1 |  | ||||||
| disk/nvme0n1/name |  | ||||||
| disk/nvme0n1/read |  | ||||||
| disk/nvme0n1/total |  | ||||||
| disk/nvme0n1/write |  | ||||||
| gpu |  | ||||||
| lmsensors |  | ||||||
| lmsensors/BAT0-acpi-0 |  | ||||||
| lmsensors/BAT0-acpi-0/in0 |  | ||||||
| lmsensors/acpitz-acpi-0 |  | ||||||
| lmsensors/acpitz-acpi-0/temp1 |  | ||||||
| lmsensors/iwlwifi_1-virtual-0 |  | ||||||
| lmsensors/iwlwifi_1-virtual-0/temp1 |  | ||||||
| lmsensors/nvme-pci-0400 |  | ||||||
| lmsensors/nvme-pci-0400/temp1 |  | ||||||
| lmsensors/thinkpad-isa-0000 |  | ||||||
| lmsensors/thinkpad-isa-0000/fan1 |  | ||||||
| lmsensors/thinkpad-isa-0000/fan2 |  | ||||||
| lmsensors/thinkpad-isa-0000/temp1 |  | ||||||
| lmsensors/thinkpad-isa-0000/temp2 |  | ||||||
| lmsensors/thinkpad-isa-0000/temp3 |  | ||||||
| lmsensors/thinkpad-isa-0000/temp4 |  | ||||||
| lmsensors/thinkpad-isa-0000/temp5 |  | ||||||
| lmsensors/thinkpad-isa-0000/temp6 |  | ||||||
| lmsensors/thinkpad-isa-0000/temp7 |  | ||||||
| lmsensors/thinkpad-isa-0000/temp8 |  | ||||||
| lmsensors/ucsi_source_psy_USBC000:001-isa-0000 |  | ||||||
| lmsensors/ucsi_source_psy_USBC000:001-isa-0000/curr1 |  | ||||||
| lmsensors/ucsi_source_psy_USBC000:001-isa-0000/in0 |  | ||||||
| lmsensors/ucsi_source_psy_USBC000:002-isa-0000 |  | ||||||
| lmsensors/ucsi_source_psy_USBC000:002-isa-0000/curr1 |  | ||||||
| lmsensors/ucsi_source_psy_USBC000:002-isa-0000/in0 |  | ||||||
| memory |  | ||||||
| memory/physical |  | ||||||
| memory/physical/application |  | ||||||
| memory/physical/applicationPercent |  | ||||||
| memory/physical/buffer |  | ||||||
| memory/physical/bufferPercent |  | ||||||
| memory/physical/cache |  | ||||||
| memory/physical/cachePercent |  | ||||||
| memory/physical/free |  | ||||||
| memory/physical/freePercent |  | ||||||
| memory/physical/total |  | ||||||
| memory/physical/used |  | ||||||
| memory/physical/usedPercent |  | ||||||
| memory/swap |  | ||||||
| memory/swap/free |  | ||||||
| memory/swap/freePercent |  | ||||||
| memory/swap/total |  | ||||||
| memory/swap/used |  | ||||||
| memory/swap/usedPercent |  | ||||||
| os |  | ||||||
| os/kernel |  | ||||||
| os/kernel/name |  | ||||||
| os/kernel/prettyName |  | ||||||
| os/kernel/version |  | ||||||
| os/plasma |  | ||||||
| os/plasma/kfVersion |  | ||||||
| os/plasma/plasmaVersion |  | ||||||
| os/plasma/qtVersion |  | ||||||
| os/plasma/windowsystem |  | ||||||
| os/system |  | ||||||
| os/system/hostname |  | ||||||
| os/system/logo |  | ||||||
| os/system/name |  | ||||||
| os/system/prettyName |  | ||||||
| os/system/uptime |  | ||||||
| os/system/url |  | ||||||
| os/system/version |  | ||||||
| power |  | ||||||
| power/4870 |  | ||||||
| power/4870/capacity |  | ||||||
| power/4870/charge |  | ||||||
| power/4870/chargePercentage |  | ||||||
| power/4870/chargeRate |  | ||||||
| power/4870/design |  | ||||||
| power/4870/health |  | ||||||
| power/4870/name |  | ||||||
							
								
								
									
										6
									
								
								sources/3rdparty/fontdialog/fontdialog.cpp
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								sources/3rdparty/fontdialog/fontdialog.cpp
									
									
									
									
										vendored
									
									
								
							| @ -58,7 +58,7 @@ CFontDialog::CFontDialog(QWidget *parent, bool needWeight, bool needItalic) | |||||||
|     setLayout(mainGrid); |     setLayout(mainGrid); | ||||||
|  |  | ||||||
|     colorBox = new QComboBox(this); |     colorBox = new QComboBox(this); | ||||||
|     connect(colorBox, SIGNAL(currentIndexChanged(QString)), this, SLOT(updateColor(QString))); |     connect(colorBox, &QComboBox::currentTextChanged, this, &CFontDialog::updateColor); | ||||||
|     QStringList colorNames = QColor::colorNames(); |     QStringList colorNames = QColor::colorNames(); | ||||||
|     int index = 0; |     int index = 0; | ||||||
|     for (int i=0; i<colorNames.count(); i++) { |     for (int i=0; i<colorNames.count(); i++) { | ||||||
| @ -81,8 +81,8 @@ CFontDialog::CFontDialog(QWidget *parent, bool needWeight, bool needItalic) | |||||||
|  |  | ||||||
|     buttons = new QDialogButtonBox(QDialogButtonBox::Ok | QDialogButtonBox::Cancel, |     buttons = new QDialogButtonBox(QDialogButtonBox::Ok | QDialogButtonBox::Cancel, | ||||||
|                                    Qt::Horizontal, this); |                                    Qt::Horizontal, this); | ||||||
|     QObject::connect(buttons, SIGNAL(accepted()), this, SLOT(accept())); |     QObject::connect(buttons, &QDialogButtonBox::accepted, this, &CFontDialog::accept); | ||||||
|     QObject::connect(buttons, SIGNAL(rejected()), this, SLOT(reject())); |     QObject::connect(buttons, &QDialogButtonBox::rejected, this, &CFontDialog::reject); | ||||||
|     mainGrid->addWidget(buttons, 1, 0, 1, 5); |     mainGrid->addWidget(buttons, 1, 0, 1, 5); | ||||||
|  |  | ||||||
|     italicBox->setHidden(!needItalic); |     italicBox->setHidden(!needItalic); | ||||||
|  | |||||||
							
								
								
									
										6
									
								
								sources/3rdparty/fontdialog/fontdialog.h
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								sources/3rdparty/fontdialog/fontdialog.h
									
									
									
									
										vendored
									
									
								
							| @ -15,8 +15,7 @@ | |||||||
|  *  License along with this library.                                       * |  *  License along with this library.                                       * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
| #ifndef FONTDIALOG_H | #pragma once | ||||||
| #define FONTDIALOG_H |  | ||||||
|  |  | ||||||
| #include <QComboBox> | #include <QComboBox> | ||||||
| #include <QDialog> | #include <QDialog> | ||||||
| @ -72,6 +71,3 @@ private: | |||||||
|     QSpinBox *sizeBox; |     QSpinBox *sizeBox; | ||||||
|     QSpinBox *weightBox; |     QSpinBox *weightBox; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| #endif /* FONTDIALOG_H */ |  | ||||||
|  | |||||||
| @ -12,7 +12,7 @@ QReplyTimeout::QReplyTimeout(QNetworkReply *reply, const int timeout) | |||||||
|  |  | ||||||
| void QReplyTimeout::timeout() | void QReplyTimeout::timeout() | ||||||
| { | { | ||||||
|     auto *reply = dynamic_cast<QNetworkReply *>(parent()); |     auto reply = dynamic_cast<QNetworkReply *>(parent()); | ||||||
|     if (reply->isRunning()) |     if (reply->isRunning()) | ||||||
|         reply->close(); |         reply->close(); | ||||||
| } | } | ||||||
|  | |||||||
| @ -9,6 +9,9 @@ endif () | |||||||
| if (POLICY CMP0071) | if (POLICY CMP0071) | ||||||
|     cmake_policy(SET CMP0071 NEW) |     cmake_policy(SET CMP0071 NEW) | ||||||
| endif () | endif () | ||||||
|  | if (POLICY CMP0160) | ||||||
|  |     cmake_policy(SET CMP0160 OLD) | ||||||
|  | endif () | ||||||
|  |  | ||||||
| project(awesomewidgets) | project(awesomewidgets) | ||||||
| set(PROJECT_AUTHOR "Evgeniy Alekseev") | set(PROJECT_AUTHOR "Evgeniy Alekseev") | ||||||
|  | |||||||
| @ -41,35 +41,32 @@ QString AWDebug::getAboutText(const QString &_type) | |||||||
|     } else if (_type == "description") { |     } else if (_type == "description") { | ||||||
|         text = i18n("A set of minimalistic plasmoid widgets"); |         text = i18n("A set of minimalistic plasmoid widgets"); | ||||||
|     } else if (_type == "links") { |     } else if (_type == "links") { | ||||||
|         text = i18n("Links:") + "<ul>" + QString("<li><a href=\"%1\">%2</a></li>").arg(HOMEPAGE).arg(i18n("Homepage")) |         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).arg(i18n("Repository")) |                + QString("<li><a href=\"%1\">%2</a></li>").arg(REPOSITORY, i18n("Repository")) | ||||||
|                + QString("<li><a href=\"%1\">%2</a></li>").arg(BUGTRACKER).arg(i18n("Bugtracker")) |                + QString("<li><a href=\"%1\">%2</a></li>").arg(BUGTRACKER, 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(TRANSLATION, 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(AUR_PACKAGES, i18n("AUR packages")) | ||||||
|                + QString("<li><a href=\"%1\">%2</a></li>").arg(OPENSUSE_PACKAGES).arg(i18n("openSUSE packages")) |                + QString("<li><a href=\"%1\">%2</a></li>").arg(OPENSUSE_PACKAGES, i18n("openSUSE packages")) + "</ul>"; | ||||||
|                + "</ul>"; |  | ||||||
|     } else if (_type == "copy") { |     } else if (_type == "copy") { | ||||||
|         text = QString("<small>© %1 <a href=\"mailto:%2\">%3</a><br>").arg(DATE).arg(EMAIL).arg(AUTHOR) |         text = QString("<small>© %1 <a href=\"mailto:%2\">%3</a><br>").arg(DATE, EMAIL, AUTHOR) | ||||||
|                + i18nc("This software is licensed under %1", LICENSE) + "</small>"; |                + i18n("This software is licensed under %1", LICENSE) + "</small>"; | ||||||
|     } else if (_type == "translators") { |     } else if (_type == "translators") { | ||||||
|         QStringList translatorList = QString(TRANSLATORS).split(','); |         auto translatorList = QString(TRANSLATORS).split(','); | ||||||
|         for (auto &translator : translatorList) |         for (auto &translator : translatorList) | ||||||
|             translator = QString("<li>%1</li>").arg(translator); |             translator = QString("<li>%1</li>").arg(translator); | ||||||
|         text = i18n("Translators:") + "<ul>" + translatorList.join("") + "</ul>"; |         text = i18n("Translators:") + "<ul>" + translatorList.join("") + "</ul>"; | ||||||
|     } else if (_type == "3rdparty") { |     } else if (_type == "3rdparty") { | ||||||
|         QStringList trdPartyList = QString(TRDPARTY_LICENSE).split(';', Qt::SkipEmptyParts); |         auto trdPartyList = QString(TRDPARTY_LICENSE).split(';', Qt::SkipEmptyParts); | ||||||
|         for (int i = 0; i < trdPartyList.count(); i++) |         for (auto i = 0; i < trdPartyList.count(); ++i) | ||||||
|             trdPartyList[i] = QString("<li><a href=\"%3\">%1</a> (%2 license)</li>") |             trdPartyList[i] = QString("<li><a href=\"%3\">%1</a> (%2 license)</li>") | ||||||
|                                   .arg(trdPartyList.at(i).split(',')[0]) |                                   .arg(trdPartyList.at(i).split(',')[0], trdPartyList.at(i).split(',')[1], | ||||||
|                                   .arg(trdPartyList.at(i).split(',')[1]) |                                        trdPartyList.at(i).split(',')[2]); | ||||||
|                                   .arg(trdPartyList.at(i).split(',')[2]); |  | ||||||
|         text = i18n("This software uses:") + "<ul>" + trdPartyList.join("") + "</ul>"; |         text = i18n("This software uses:") + "<ul>" + trdPartyList.join("") + "</ul>"; | ||||||
|     } else if (_type == "thanks") { |     } else if (_type == "thanks") { | ||||||
|         QStringList thanks = QString(SPECIAL_THANKS).split(';', Qt::SkipEmptyParts); |         auto thanks = QString(SPECIAL_THANKS).split(';', Qt::SkipEmptyParts); | ||||||
|         for (int i = 0; i < thanks.count(); i++) |         for (auto i = 0; i < thanks.count(); ++i) | ||||||
|             thanks[i] = QString("<li><a href=\"%2\">%1</a></li>") |             thanks[i] | ||||||
|                             .arg(thanks.at(i).split(',')[0]) |                 = QString("<li><a href=\"%2\">%1</a></li>").arg(thanks.at(i).split(',')[0], thanks.at(i).split(',')[1]); | ||||||
|                             .arg(thanks.at(i).split(',')[1]); |  | ||||||
|         text = i18n("Special thanks to:") + "<ul>" + thanks.join("") + "</ul>"; |         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/  * |  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
|  | #pragma once | ||||||
| #ifndef AWDEBUG_H |  | ||||||
| #define AWDEBUG_H |  | ||||||
|  |  | ||||||
| #include <QLoggingCategory> | #include <QLoggingCategory> | ||||||
|  |  | ||||||
| @ -42,6 +40,3 @@ Q_DECLARE_LOGGING_CATEGORY(LOG_DP) | |||||||
| Q_DECLARE_LOGGING_CATEGORY(LOG_ESM) | Q_DECLARE_LOGGING_CATEGORY(LOG_ESM) | ||||||
| Q_DECLARE_LOGGING_CATEGORY(LOG_ESS) | Q_DECLARE_LOGGING_CATEGORY(LOG_ESS) | ||||||
| Q_DECLARE_LOGGING_CATEGORY(LOG_LIB) | Q_DECLARE_LOGGING_CATEGORY(LOG_LIB) | ||||||
|  |  | ||||||
|  |  | ||||||
| #endif /* AWDEBUG_H */ |  | ||||||
|  | |||||||
| @ -51,6 +51,12 @@ ConfigModel { | |||||||
|         source: "dataengine.qml" |         source: "dataengine.qml" | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     ConfigCategory { | ||||||
|  |         name: i18n("Report bug") | ||||||
|  |         icon: "tools-report-bug" | ||||||
|  |         source: "bug.qml" | ||||||
|  |     } | ||||||
|  |  | ||||||
|     ConfigCategory { |     ConfigCategory { | ||||||
|         name: i18n("About") |         name: i18n("About") | ||||||
|         icon: "help-about" |         icon: "help-about" | ||||||
|  | |||||||
| @ -44,9 +44,6 @@ | |||||||
|         <entry name="interval" type="Int"> |         <entry name="interval" type="Int"> | ||||||
|             <default>1000</default> |             <default>1000</default> | ||||||
|         </entry> |         </entry> | ||||||
|         <entry name="queueLimit" type="Int"> |  | ||||||
|             <default>0</default> |  | ||||||
|         </entry> |  | ||||||
|         <entry name="tempUnits" type="String"> |         <entry name="tempUnits" type="String"> | ||||||
|             <default>Celsius</default> |             <default>Celsius</default> | ||||||
|         </entry> |         </entry> | ||||||
| @ -62,15 +59,9 @@ | |||||||
|         <entry name="acOffline" type="String"> |         <entry name="acOffline" type="String"> | ||||||
|             <default>( )</default> |             <default>( )</default> | ||||||
|         </entry> |         </entry> | ||||||
|         <entry name="telemetryCount" type="Int"> |         <entry name="historyCount" type="Int"> | ||||||
|             <default>100</default> |             <default>100</default> | ||||||
|         </entry> |         </entry> | ||||||
|         <entry name="telemetryRemote" type="Bool"> |  | ||||||
|             <default>false</default> |  | ||||||
|         </entry> |  | ||||||
|         <entry name="telemetryId" type="String"> |  | ||||||
|             <default></default> |  | ||||||
|         </entry> |  | ||||||
|     </group> |     </group> | ||||||
|  |  | ||||||
|     <group name="Tooltip"> |     <group name="Tooltip"> | ||||||
|  | |||||||
| @ -16,27 +16,21 @@ | |||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
| import QtQuick 2.15 | 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 |     id: aboutPage | ||||||
|  |  | ||||||
|     // backend |     // backend | ||||||
|     AWActions { |     AWActions { | ||||||
|         id: awActions |         id: awActions | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     width: childrenRect.width |  | ||||||
|     height: childrenRect.height |  | ||||||
|  |  | ||||||
|     property bool debug: awActions.isDebugEnabled() |  | ||||||
|  |  | ||||||
|     AboutTab { |     AboutTab { | ||||||
|         textProvider: awActions |         textProvider: awActions | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     Component.onCompleted: { |  | ||||||
|         if (debug) console.debug() |  | ||||||
|     } |  | ||||||
| } | } | ||||||
|  | |||||||
| @ -17,24 +17,20 @@ | |||||||
|  |  | ||||||
| import QtQuick 2.15 | import QtQuick 2.15 | ||||||
| import QtQuick.Controls | 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 |     id: advancedPage | ||||||
|  |  | ||||||
|     // backend |     // backend | ||||||
|     AWActions { |     AWConfigHelper { | ||||||
|         id: awActions |         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_background: background.checked | ||||||
|     property alias cfg_translateStrings: translate.checked |     property alias cfg_translateStrings: translate.checked | ||||||
|     property alias cfg_wrapNewLines: wrapNewLines.checked |     property alias cfg_wrapNewLines: wrapNewLines.checked | ||||||
| @ -45,19 +41,14 @@ Item { | |||||||
|     property alias cfg_height: widgetHeight.value |     property alias cfg_height: widgetHeight.value | ||||||
|     property alias cfg_width: widgetWidth.value |     property alias cfg_width: widgetWidth.value | ||||||
|     property alias cfg_interval: update.value |     property alias cfg_interval: update.value | ||||||
|     property alias cfg_queueLimit: queueLimit.value |  | ||||||
|     property string cfg_tempUnits: tempUnits.value |     property string cfg_tempUnits: tempUnits.value | ||||||
|     property alias cfg_customTime: customTime.value |     property alias cfg_customTime: customTime.value | ||||||
|     property alias cfg_customUptime: customUptime.value |     property alias cfg_customUptime: customUptime.value | ||||||
|     property alias cfg_acOnline: acOnline.value |     property alias cfg_acOnline: acOnline.value | ||||||
|     property alias cfg_acOffline: acOffline.value |     property alias cfg_acOffline: acOffline.value | ||||||
|     property alias cfg_telemetryCount: telemetryCount.value |     property alias cfg_historyCount: historyCount.value | ||||||
|     property alias cfg_telemetryRemote: telemetryRemote.checked |  | ||||||
|     property alias cfg_telemetryId: telemetryId.value |  | ||||||
|  |  | ||||||
|  |  | ||||||
|     Column { |     Column { | ||||||
|         id: pageColumn |  | ||||||
|         anchors.fill: parent |         anchors.fill: parent | ||||||
|  |  | ||||||
|         CheckBoxSelector { |         CheckBoxSelector { | ||||||
| @ -122,45 +113,36 @@ Item { | |||||||
|             value: plasmoid.configuration.interval |             value: plasmoid.configuration.interval | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         IntegerSelector { |  | ||||||
|             id: queueLimit |  | ||||||
|             maximumValue: 99 |  | ||||||
|             minimumValue: 0 |  | ||||||
|             stepSize: 1 |  | ||||||
|             text: i18n("Messages queue limit") |  | ||||||
|             value: plasmoid.configuration.queueLimit |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         ComboBoxSelector { |         ComboBoxSelector { | ||||||
|             id: tempUnits |             id: tempUnits | ||||||
|             model: [ |             model: [ | ||||||
|                 { |                 { | ||||||
|                     'label': i18n("Celsius"), |                     "label": i18n("Celsius"), | ||||||
|                     'name': "Celsius" |                     "name": "Celsius" | ||||||
|                 }, |                 }, | ||||||
|                 { |                 { | ||||||
|                     'label': i18n("Fahrenheit"), |                     "label": i18n("Fahrenheit"), | ||||||
|                     'name': "Fahrenheit" |                     "name": "Fahrenheit" | ||||||
|                 }, |                 }, | ||||||
|                 { |                 { | ||||||
|                     'label': i18n("Kelvin"), |                     "label": i18n("Kelvin"), | ||||||
|                     'name': "Kelvin" |                     "name": "Kelvin" | ||||||
|                 }, |                 }, | ||||||
|                 { |                 { | ||||||
|                     'label': i18n("Reaumur"), |                     "label": i18n("Reaumur"), | ||||||
|                     'name': "Reaumur" |                     "name": "Reaumur" | ||||||
|                 }, |                 }, | ||||||
|                 { |                 { | ||||||
|                     'label': i18n("cm^-1"), |                     "label": i18n("cm^-1"), | ||||||
|                     'name': "cm^-1" |                     "name": "cm^-1" | ||||||
|                 }, |                 }, | ||||||
|                 { |                 { | ||||||
|                     'label': i18n("kJ/mol"), |                     "label": i18n("kJ/mol"), | ||||||
|                     'name': "kJ/mol" |                     "name": "kJ/mol" | ||||||
|                 }, |                 }, | ||||||
|                 { |                 { | ||||||
|                     'label': i18n("kcal/mol"), |                     "label": i18n("kcal/mol"), | ||||||
|                     'name': "kcal/mol" |                     "name": "kcal/mol" | ||||||
|                 } |                 } | ||||||
|             ] |             ] | ||||||
|             text: i18n("Temperature units") |             text: i18n("Temperature units") | ||||||
| @ -194,14 +176,18 @@ Item { | |||||||
|  |  | ||||||
|         GroupBox { |         GroupBox { | ||||||
|             width: parent.width |             width: parent.width | ||||||
|  |             height: implicitHeight | ||||||
|             title: i18n("Actions") |             title: i18n("Actions") | ||||||
|  |  | ||||||
|             Column { |             Column { | ||||||
|  |                 height: implicitHeight | ||||||
|                 width: parent.width |                 width: parent.width | ||||||
|  |  | ||||||
|                 ButtonSelector { |                 ButtonSelector { | ||||||
|                     value: i18n("Drop key cache") |                     value: i18n("Drop key cache") | ||||||
|                     onButtonActivated: awActions.dropCache() |                     onButtonActivated: awConfig.dropCache() | ||||||
|                 } |                 } | ||||||
|  |  | ||||||
|                 ButtonSelector { |                 ButtonSelector { | ||||||
|                     ExportDialog { |                     ExportDialog { | ||||||
|                         id: saveConfigAs |                         id: saveConfigAs | ||||||
| @ -210,11 +196,12 @@ Item { | |||||||
|                     value: i18n("Export configuration") |                     value: i18n("Export configuration") | ||||||
|                     onButtonActivated: saveConfigAs.open() |                     onButtonActivated: saveConfigAs.open() | ||||||
|                 } |                 } | ||||||
|  |  | ||||||
|                 ButtonSelector { |                 ButtonSelector { | ||||||
|                     ImportDialog { |                     ImportDialog { | ||||||
|                         id: loadConfigFrom |                         id: loadConfigFrom | ||||||
|                         onConfigurationReceived: { |                         onConfigurationReceived: { | ||||||
|                             for (var key in configuration) |                             for (const key in configuration) | ||||||
|                                 plasmoid.configuration[key] = configuration[key] |                                 plasmoid.configuration[key] = configuration[key] | ||||||
|                         } |                         } | ||||||
|                     } |                     } | ||||||
| @ -225,34 +212,23 @@ Item { | |||||||
|         } |         } | ||||||
|  |  | ||||||
|         GroupBox { |         GroupBox { | ||||||
|  |             height: implicitHeight | ||||||
|             width: parent.width |             width: parent.width | ||||||
|             title: i18n("Telemetry") |             title: i18n("History") | ||||||
|  |  | ||||||
|             Column { |             Column { | ||||||
|  |                 height: implicitHeight | ||||||
|                 width: parent.width |                 width: parent.width | ||||||
|                 CheckBoxSelector { |  | ||||||
|                     id: telemetryRemote |  | ||||||
|                     text: i18n("Enable remote telemetry") |  | ||||||
|                 } |  | ||||||
|                 IntegerSelector { |                 IntegerSelector { | ||||||
|                     id: telemetryCount |                     id: historyCount | ||||||
|                     maximumValue: 10000 |                     maximumValue: 10000 | ||||||
|                     minimumValue: 0 |                     minimumValue: 0 | ||||||
|                     stepSize: 50 |                     stepSize: 50 | ||||||
|                     text: i18n("History count") |                     text: i18n("History count") | ||||||
|                     value: plasmoid.configuration.telemetryCount |                     value: plasmoid.configuration.historyCount | ||||||
|                 } |  | ||||||
|                 LineSelector { |  | ||||||
|                     id: telemetryId |  | ||||||
|                     text: i18n("Telemetry ID") |  | ||||||
|                     value: plasmoid.configuration.telemetryId |  | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|     Component.onCompleted: { |  | ||||||
|         if (debug) console.debug() |  | ||||||
|     } |  | ||||||
| } | } | ||||||
|  | |||||||
| @ -16,30 +16,21 @@ | |||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
| import QtQuick 2.15 | import QtQuick 2.15 | ||||||
|  | import org.kde.kcmutils as KCM | ||||||
|  |  | ||||||
| import org.kde.plasma.private.awesomewidget 1.0 | import org.kde.plasma.awesomewidgets | ||||||
| import "." | import org.kde.plasma.private.awesomewidget | ||||||
|  |  | ||||||
|  |  | ||||||
| Item { | KCM.SimpleKCM { | ||||||
|     id: appearancePage |     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: { |     property variant weight: { | ||||||
|         25: 0, |         25: 0, | ||||||
|         50: 1, |         50: 1, | ||||||
|         63: 3, |         63: 3, | ||||||
|         75: 4, |         75: 4, | ||||||
|         87: 5 |         87: 5, | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     property alias cfg_fontFamily: font.value |     property alias cfg_fontFamily: font.value | ||||||
| @ -50,9 +41,7 @@ Item { | |||||||
|     property alias cfg_textStyleColor: selectStyleColor.value |     property alias cfg_textStyleColor: selectStyleColor.value | ||||||
|     property string cfg_textStyle: textStyle.value |     property string cfg_textStyle: textStyle.value | ||||||
|  |  | ||||||
|  |  | ||||||
|     Column { |     Column { | ||||||
|         id: pageColumn |  | ||||||
|         anchors.fill: parent |         anchors.fill: parent | ||||||
|  |  | ||||||
|         FontSelector { |         FontSelector { | ||||||
| @ -106,9 +95,4 @@ Item { | |||||||
|             value: plasmoid.configuration.textStyleColor |             value: plasmoid.configuration.textStyleColor | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|     Component.onCompleted: { |  | ||||||
|         if (debug) console.debug() |  | ||||||
|     } |  | ||||||
| } | } | ||||||
|  | |||||||
| @ -19,12 +19,15 @@ import QtQuick 2.15 | |||||||
| import QtQuick.Controls | import QtQuick.Controls | ||||||
| import QtQuick.Dialogs | import QtQuick.Dialogs | ||||||
| import QtQuick.Layouts | 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 | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| Dialog { | KCM.SimpleKCM { | ||||||
|     id: reportDialog |     id: bugPage | ||||||
|  | 
 | ||||||
|     AWActions { |     AWActions { | ||||||
|         id: awActions |         id: awActions | ||||||
|     } |     } | ||||||
| @ -32,14 +35,6 @@ Dialog { | |||||||
|         id: awBugReporter |         id: awBugReporter | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     width: 640 |  | ||||||
|     height: 480 |  | ||||||
|     property bool debug: awActions.isDebugEnabled() |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
|     title: i18n("Report a bug") |  | ||||||
|     standardButtons: DialogButtonBox.Ok | DialogButtonBox.Cancel | DialogButtonBox.Reset |  | ||||||
| 
 |  | ||||||
|     ColumnLayout { |     ColumnLayout { | ||||||
|         anchors.fill: parent |         anchors.fill: parent | ||||||
| 
 | 
 | ||||||
| @ -48,48 +43,55 @@ Dialog { | |||||||
|             Layout.fillWidth: true |             Layout.fillWidth: true | ||||||
|             placeholderText: i18n("Report subject") |             placeholderText: i18n("Report subject") | ||||||
|         } |         } | ||||||
|  | 
 | ||||||
|         ColumnLayout { |         ColumnLayout { | ||||||
|             Layout.fillWidth: true |             Layout.fillWidth: true | ||||||
| 
 | 
 | ||||||
|             GroupBox { |             GroupBox { | ||||||
|                 Layout.fillWidth: true |                 Layout.fillWidth: true | ||||||
|                 height: parent.height / 5 |  | ||||||
|                 title: i18n("Description") |                 title: i18n("Description") | ||||||
|  | 
 | ||||||
|                 TextArea { |                 TextArea { | ||||||
|                     id: description |                     id: description | ||||||
|                     anchors.fill: parent |                     anchors.fill: parent | ||||||
|                     textFormat: TextEdit.PlainText |                     textFormat: TextEdit.PlainText | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|  | 
 | ||||||
|             GroupBox { |             GroupBox { | ||||||
|                 Layout.fillWidth: true |                 Layout.fillWidth: true | ||||||
|                 height: parent.height / 5 |  | ||||||
|                 title: i18n("Steps to reproduce") |                 title: i18n("Steps to reproduce") | ||||||
|  | 
 | ||||||
|                 TextArea { |                 TextArea { | ||||||
|                     id: reproduce |                     id: reproduce | ||||||
|                     anchors.fill: parent |                     anchors.fill: parent | ||||||
|                     textFormat: TextEdit.PlainText |                     textFormat: TextEdit.PlainText | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|  | 
 | ||||||
|             GroupBox { |             GroupBox { | ||||||
|                 Layout.fillWidth: true |                 Layout.fillWidth: true | ||||||
|                 height: parent.height / 5 |  | ||||||
|                 title: i18n("Expected result") |                 title: i18n("Expected result") | ||||||
|  | 
 | ||||||
|                 TextArea { |                 TextArea { | ||||||
|                     id: expected |                     id: expected | ||||||
|                     anchors.fill: parent |                     anchors.fill: parent | ||||||
|                     textFormat: TextEdit.PlainText |                     textFormat: TextEdit.PlainText | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|  | 
 | ||||||
|             GroupBox { |             GroupBox { | ||||||
|                 Layout.fillWidth: true |                 Layout.fillWidth: true | ||||||
|                 Layout.alignment: Qt.AlignBottom |                 Layout.alignment: Qt.AlignBottom | ||||||
|                 title: i18n("Logs") |                 title: i18n("Logs") | ||||||
|  | 
 | ||||||
|                 ColumnLayout { |                 ColumnLayout { | ||||||
|                     anchors.fill: parent |                     anchors.fill: parent | ||||||
|                     Layout.fillWidth: true |                     Layout.fillWidth: true | ||||||
|  | 
 | ||||||
|                     Row { |                     Row { | ||||||
|                         Layout.fillWidth: true |                         Layout.fillWidth: true | ||||||
|  | 
 | ||||||
|                         Label { |                         Label { | ||||||
|                             width: parent.width * 2 / 5 |                             width: parent.width * 2 / 5 | ||||||
|                             horizontalAlignment: Text.AlignJustify |                             horizontalAlignment: Text.AlignJustify | ||||||
| @ -97,17 +99,20 @@ Dialog { | |||||||
|                             wrapMode: Text.WordWrap |                             wrapMode: Text.WordWrap | ||||||
|                             text: i18n("Use command") |                             text: i18n("Use command") | ||||||
|                         } |                         } | ||||||
|  | 
 | ||||||
|                         TextField { |                         TextField { | ||||||
|                             width: parent.width * 3 / 5 |                             width: parent.width * 3 / 5 | ||||||
|                             readOnly: true |                             readOnly: true | ||||||
|                             text: "QT_LOGGING_RULES=*=true plasmawindowed org.kde.plasma.awesomewidget" |                             text: "QT_LOGGING_RULES=*=true plasmawindowed org.kde.plasma.awesomewidget" | ||||||
|                         } |                         } | ||||||
|                     } |                     } | ||||||
|  | 
 | ||||||
|                     Button { |                     Button { | ||||||
|                         Layout.fillWidth: true |                         Layout.fillWidth: true | ||||||
|                         text: i18n("Load log file") |                         text: i18n("Load log file") | ||||||
|                         onClicked: logPath.open() |                         onClicked: logPath.open() | ||||||
|                     } |                     } | ||||||
|  | 
 | ||||||
|                     TextArea { |                     TextArea { | ||||||
|                         id: logBody |                         id: logBody | ||||||
|                         Layout.fillWidth: true |                         Layout.fillWidth: true | ||||||
| @ -119,34 +124,36 @@ Dialog { | |||||||
|                 FileDialog { |                 FileDialog { | ||||||
|                     id: logPath |                     id: logPath | ||||||
|                     title: i18n("Open log file") |                     title: i18n("Open log file") | ||||||
|                     onAccepted: |                     onAccepted: logBody.text = awActions.getFileContent(logPath.selectedFile.toString().replace("file://", "")) | ||||||
|                     logBody.text = awActions.getFileContent(logPath.fileUrl.toString().replace("file://", "")) |  | ||||||
|                 } |                 } | ||||||
|             } |             } | ||||||
|  | 
 | ||||||
|  |             DialogButtonBox { | ||||||
|  |                 Layout.fillWidth: true | ||||||
|  | 
 | ||||||
|  |                 standardButtons: DialogButtonBox.Ok | DialogButtonBox.Reset | ||||||
|  |                 alignment: Qt.AlignRight | ||||||
|  |                 onAccepted: sendBugReport() | ||||||
|  |                 onReset: resetDialog() | ||||||
|  |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     onAccepted: { |     function sendBugReport() { | ||||||
|         if (debug) console.debug() |         const text = awBugReporter.generateText(description.text, reproduce.text, expected.text, logBody.text) | ||||||
| 
 |  | ||||||
|         var text = awBugReporter.generateText(description.text, reproduce.text, |  | ||||||
|                                               expected.text, logBody.text) |  | ||||||
|         awBugReporter.sendBugReport(title.text, text) |         awBugReporter.sendBugReport(title.text, text) | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     onReset: { |     function resetDialog() { | ||||||
|         if (debug) console.debug() |  | ||||||
| 
 |  | ||||||
|         title.text = "" |         title.text = "" | ||||||
|         description.text = "" |         description.text = "" | ||||||
|         reproduce.text = "" |         reproduce.text = "" | ||||||
|         expected.text = "" |         expected.text = "" | ||||||
|  |         logBody.text = "" | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     Component.onCompleted: { |     Component.onCompleted: { | ||||||
|         if (debug) console.debug() |         resetDialog() | ||||||
| 
 |  | ||||||
|         awBugReporter.doConnect() |         awBugReporter.doConnect() | ||||||
|     } |     } | ||||||
| } | } | ||||||
| 
 |  | ||||||
| @ -17,36 +17,28 @@ | |||||||
|  |  | ||||||
| import QtQuick 2.15 | import QtQuick 2.15 | ||||||
| import QtQuick.Controls | 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 |     id: dataenginePage | ||||||
|  |  | ||||||
|     // backend |     // backend | ||||||
|     AWKeys { |     AWKeys { | ||||||
|         id: awKeys |         id: awKeys | ||||||
|     } |     } | ||||||
|     AWActions { |  | ||||||
|         id: awActions |  | ||||||
|     } |  | ||||||
|     AWConfigHelper { |     AWConfigHelper { | ||||||
|         id: awConfig |         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() |     property variant cfg_dataengine: awConfig.readDataEngineConfiguration() | ||||||
|  |  | ||||||
|  |  | ||||||
|     Column { |     Column { | ||||||
|         id: pageColumn |  | ||||||
|         anchors.fill: parent |         anchors.fill: parent | ||||||
|  |  | ||||||
|         GroupBox { |         GroupBox { | ||||||
|             height: implicitHeight |             height: implicitHeight | ||||||
|             width: parent.width |             width: parent.width | ||||||
| @ -58,61 +50,11 @@ Item { | |||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         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: newValue => cfg_dataengine["GPUDEV"] = newValue |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         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: newValue => cfg_dataengine["HDDDEV"] = newValue |  | ||||||
|                 } |  | ||||||
|  |  | ||||||
|                 LineSelector { |  | ||||||
|                     text: i18n("hddtemp cmd") |  | ||||||
|                     value: cfg_dataengine["HDDTEMPCMD"] |  | ||||||
|                     onValueEdited: newValue => cfg_dataengine["HDDTEMPCMD"] = newValue |  | ||||||
|                 } |  | ||||||
|             } |  | ||||||
|         } |  | ||||||
|  |  | ||||||
|         GroupBox { |         GroupBox { | ||||||
|             height: implicitHeight |             height: implicitHeight | ||||||
|             width: parent.width |             width: parent.width | ||||||
|             title: i18n("Player") |             title: i18n("Player") | ||||||
|  |  | ||||||
|             Column { |             Column { | ||||||
|                 height: implicitHeight |                 height: implicitHeight | ||||||
|                 width: parent.width |                 width: parent.width | ||||||
| @ -128,16 +70,16 @@ Item { | |||||||
|                 ComboBoxSelector { |                 ComboBoxSelector { | ||||||
|                     model: [ |                     model: [ | ||||||
|                         { |                         { | ||||||
|                             'label': "disable", |                             "label": "disable", | ||||||
|                             'name': "disable" |                             "name": "disable" | ||||||
|                         }, |                         }, | ||||||
|                         { |                         { | ||||||
|                             'label': "mpris", |                             "label": "mpris", | ||||||
|                             'name': "mpris" |                             "name": "mpris" | ||||||
|                         }, |                         }, | ||||||
|                         { |                         { | ||||||
|                             'label': "mpd", |                             "label": "mpd", | ||||||
|                             'name': "mpd" |                             "name": "mpd" | ||||||
|                         } |                         } | ||||||
|                     ] |                     ] | ||||||
|                     text: i18n("Music player") |                     text: i18n("Music player") | ||||||
| @ -150,40 +92,40 @@ Item { | |||||||
|                     editable: true |                     editable: true | ||||||
|                     model: [ |                     model: [ | ||||||
|                         { |                         { | ||||||
|                             'label': 'auto', |                             "label": "auto", | ||||||
|                             'name': 'auto' |                             "name": "auto" | ||||||
|                         }, |                         }, | ||||||
|                         { |                         { | ||||||
|                             'label': 'amarok', |                             "label": "amarok", | ||||||
|                             'name': 'amarok' |                             "name": "amarok" | ||||||
|                         }, |                         }, | ||||||
|                         { |                         { | ||||||
|                             'label': 'audacious', |                             "label": "audacious", | ||||||
|                             'name': 'audacious' |                             "name": "audacious" | ||||||
|                         }, |                         }, | ||||||
|                         { |                         { | ||||||
|                             'label': 'clementine', |                             "label": "clementine", | ||||||
|                             'name': 'clementine' |                             "name": "clementine" | ||||||
|                         }, |                         }, | ||||||
|                         { |                         { | ||||||
|                             'label': 'DeaDBeeF', |                             "label": "DeaDBeeF", | ||||||
|                             'name': 'DeaDBeeF' |                             "name": "DeaDBeeF" | ||||||
|                         }, |                         }, | ||||||
|                         { |                         { | ||||||
|                             'label': 'vlc', |                             "label": "vlc", | ||||||
|                             'name': 'vlc' |                             "name": "vlc" | ||||||
|                         }, |                         }, | ||||||
|                         { |                         { | ||||||
|                             'label': 'qmmp', |                             "label": "qmmp", | ||||||
|                             'name': 'qmmp' |                             "name": "qmmp" | ||||||
|                         }, |                         }, | ||||||
|                         { |                         { | ||||||
|                             'label': 'xmms2', |                             "label": "xmms2", | ||||||
|                             'name': 'xmms2' |                             "name": "xmms2" | ||||||
|                         }, |                         }, | ||||||
|                         { |                         { | ||||||
|                             'label': cfg_dataengine["MPRIS"], |                             "label": cfg_dataengine["MPRIS"], | ||||||
|                             'name': cfg_dataengine["MPRIS"] |                             "name": cfg_dataengine["MPRIS"] | ||||||
|                         } |                         } | ||||||
|                     ] |                     ] | ||||||
|                     text: i18n("MPRIS player name") |                     text: i18n("MPRIS player name") | ||||||
| @ -211,9 +153,11 @@ Item { | |||||||
|             height: implicitHeight |             height: implicitHeight | ||||||
|             width: parent.width |             width: parent.width | ||||||
|             title: i18n("Extensions") |             title: i18n("Extensions") | ||||||
|  |  | ||||||
|             Column { |             Column { | ||||||
|                 height: implicitHeight |                 height: implicitHeight | ||||||
|                 width: parent.width |                 width: parent.width | ||||||
|  |  | ||||||
|                 ButtonSelector { |                 ButtonSelector { | ||||||
|                     value: i18n("Custom scripts") |                     value: i18n("Custom scripts") | ||||||
|                     onButtonActivated: awKeys.editItem("extscript") |                     onButtonActivated: awKeys.editItem("extscript") | ||||||
| @ -244,19 +188,11 @@ Item { | |||||||
|  |  | ||||||
|  |  | ||||||
|     Component.onCompleted: { |     Component.onCompleted: { | ||||||
|         if (debug) console.debug() |  | ||||||
|  |  | ||||||
|         // init submodule |         // init submodule | ||||||
|         awKeys.updateCache() |         awKeys.updateCache() | ||||||
|  |  | ||||||
|         // update hdd model |  | ||||||
|         hdd.model = awKeys.getHddDevices() |  | ||||||
|         hdd.onCompleted |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     Component.onDestruction: { |     Component.onDestruction: { | ||||||
|         if (debug) console.debug() |  | ||||||
|  |  | ||||||
|         cfg_dataengine["MPRIS"] = mpris.editText |         cfg_dataengine["MPRIS"] = mpris.editText | ||||||
|         awConfig.writeDataEngineConfiguration(cfg_dataengine) |         awConfig.writeDataEngineConfiguration(cfg_dataengine) | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -16,18 +16,17 @@ | |||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
| import QtQuick 2.15 | import QtQuick 2.15 | ||||||
| import QtQuick.Controls |  | ||||||
| import QtQuick.Dialogs |  | ||||||
| import QtQuick.Layouts | import QtQuick.Layouts | ||||||
| import org.kde.plasma.core as PlasmaCore | import org.kde.plasma.core as PlasmaCore | ||||||
| import org.kde.plasma.plasmoid 2.0 | import org.kde.plasma.plasmoid 2.0 | ||||||
|  |  | ||||||
| import org.kde.plasma.private.awesomewidget 1.0 | import org.kde.plasma.awesomewidgets | ||||||
| import "." | import org.kde.plasma.private.awesomewidget | ||||||
|  |  | ||||||
|  |  | ||||||
| PlasmoidItem { | PlasmoidItem { | ||||||
|     id: main |     id: main | ||||||
|  |  | ||||||
|     // backend |     // backend | ||||||
|     AWKeys { |     AWKeys { | ||||||
|         id: awKeys |         id: awKeys | ||||||
| @ -38,11 +37,7 @@ PlasmoidItem { | |||||||
|     AWTelemetryHandler { |     AWTelemetryHandler { | ||||||
|         id: awTelemetryHandler |         id: awTelemetryHandler | ||||||
|     } |     } | ||||||
|     BugReport { |  | ||||||
|         id: bugReport |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     property bool debug: awActions.isDebugEnabled() |  | ||||||
|     property variant tooltipSettings: { |     property variant tooltipSettings: { | ||||||
|         "tooltipNumber": plasmoid.configuration.tooltipNumber, |         "tooltipNumber": plasmoid.configuration.tooltipNumber, | ||||||
|         "useTooltipBackground": plasmoid.configuration.useTooltipBackground, |         "useTooltipBackground": plasmoid.configuration.useTooltipBackground, | ||||||
| @ -72,15 +67,13 @@ PlasmoidItem { | |||||||
|     signal needToolTipUpdate(string newText) |     signal needToolTipUpdate(string newText) | ||||||
|     signal sizeUpdate |     signal sizeUpdate | ||||||
|  |  | ||||||
|  |     Layout.fillWidth: PlasmoidItem.formFactor !== PlasmaCore.Planar | ||||||
|     Layout.fillWidth: PlasmoidItem.formFactor != PlasmaCore.Planar |     Layout.fillHeight: PlasmoidItem.formFactor !== PlasmaCore.Planar | ||||||
|     Layout.fillHeight: PlasmoidItem.formFactor != PlasmaCore.Planar |  | ||||||
|     Layout.alignment: Qt.AlignVCenter | Qt.AlignHCenter |     Layout.alignment: Qt.AlignVCenter | Qt.AlignHCenter | ||||||
|  |  | ||||||
|     Plasmoid.icon: "utilities-system-monitor" |     Plasmoid.icon: "utilities-system-monitor" | ||||||
|     Plasmoid.backgroundHints: plasmoid.configuration.background ? "DefaultBackground" : "NoBackground" |     Plasmoid.backgroundHints: plasmoid.configuration.background ? "DefaultBackground" : "NoBackground" | ||||||
|  |  | ||||||
|  |  | ||||||
|     // ui |     // ui | ||||||
|     Text { |     Text { | ||||||
|         id: text |         id: text | ||||||
| @ -94,7 +87,7 @@ PlasmoidItem { | |||||||
|  |  | ||||||
|         color: plasmoid.configuration.fontColor |         color: plasmoid.configuration.fontColor | ||||||
|         font.family: plasmoid.configuration.fontFamily |         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.pointSize: plasmoid.configuration.fontSize | ||||||
|         font.weight: General.fontWeight[plasmoid.configuration.fontWeight] |         font.weight: General.fontWeight[plasmoid.configuration.fontWeight] | ||||||
|  |  | ||||||
| @ -113,50 +106,26 @@ PlasmoidItem { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     Dialog { |  | ||||||
|         id: tagSelector |  | ||||||
|         title: i18n("Select tag") |  | ||||||
|  |  | ||||||
|         ComboBox { |  | ||||||
|             id: tagSelectorBox |  | ||||||
|             width: parent.width |  | ||||||
|             editable: 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) |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     Plasmoid.contextualActions: [ |     Plasmoid.contextualActions: [ | ||||||
|         PlasmaCore.Action { |         PlasmaCore.Action { | ||||||
|             text: i18n("Request key") |             text: i18n("Run monitor") | ||||||
|             icon.name: "utilities-system-monitor" |             icon.name: "utilities-system-monitor" | ||||||
|  |             onTriggered: awActions.runCmd("plasma-systemmonitor", []) | ||||||
|         }, |         }, | ||||||
|         PlasmaCore.Action { |         PlasmaCore.Action { | ||||||
|             text: i18n("Show README") |             text: i18n("Show README") | ||||||
|             icon.name: "text-x-readme" |             icon.name: "text-x-readme" | ||||||
|  |             onTriggered: awActions.showReadme() | ||||||
|         }, |         }, | ||||||
|         PlasmaCore.Action { |         PlasmaCore.Action { | ||||||
|             text: i18n("Check updates") |             text: i18n("Check updates") | ||||||
|             icon.name: "system-software-update" |             icon.name: "system-software-update" | ||||||
|         }, |             onTriggered: awActions.checkUpdates(true) | ||||||
|         PlasmaCore.Action { |  | ||||||
|             text: i18n("Report bug") |  | ||||||
|             icon.name: "tools-report-bug" |  | ||||||
|         } |         } | ||||||
|     ] |     ] | ||||||
|  |  | ||||||
|  |  | ||||||
|     Component.onCompleted: { |     Component.onCompleted: { | ||||||
|         if (debug) console.debug() |  | ||||||
|  |  | ||||||
|         // init submodule |         // init submodule | ||||||
|         Plasmoid.userConfiguringChanged(false) |         Plasmoid.userConfiguringChanged(false) | ||||||
|         // connect data |         // connect data | ||||||
| @ -167,31 +136,25 @@ PlasmoidItem { | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     onNeedTextUpdate: newText => { |     onNeedTextUpdate: newText => { | ||||||
|         if (debug) console.debug() |  | ||||||
|  |  | ||||||
|         text.text = newText |         text.text = newText | ||||||
|         sizeUpdate() |         sizeUpdate() | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     onNeedToolTipUpdate: newText => { |     onNeedToolTipUpdate: newText => { | ||||||
|         if (debug) console.debug() |  | ||||||
|  |  | ||||||
|         tooltip.text = newText |         tooltip.text = newText | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     onSizeUpdate: { |     onSizeUpdate: { | ||||||
|         if (debug) console.debug() |  | ||||||
|         // 16 is a magic number |         // 16 is a magic number | ||||||
|         // in other case plasmoid will increase own size on each update |         // 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.minimumHeight = text.contentHeight - 16 | ||||||
|             Layout.maximumHeight = -1 |             Layout.maximumHeight = -1 | ||||||
|         } else { |         } else { | ||||||
|             Layout.minimumHeight = plasmoid.configuration.height |             Layout.minimumHeight = plasmoid.configuration.height | ||||||
|             Layout.maximumHeight = plasmoid.configuration.height |             Layout.maximumHeight = plasmoid.configuration.height | ||||||
|         } |         } | ||||||
|         if (plasmoid.configuration.width == 0) { |         if (plasmoid.configuration.width === 0) { | ||||||
|             Layout.minimumWidth = text.contentWidth - 16 |             Layout.minimumWidth = text.contentWidth - 16 | ||||||
|             Layout.maximumWidth = -1 |             Layout.maximumWidth = -1 | ||||||
|         } else { |         } else { | ||||||
| @ -202,12 +165,10 @@ PlasmoidItem { | |||||||
|  |  | ||||||
|     Plasmoid.onUserConfiguringChanged: { |     Plasmoid.onUserConfiguringChanged: { | ||||||
|         if (plasmoid.userConfiguring) return |         if (plasmoid.userConfiguring) return | ||||||
|         if (debug) console.debug() |  | ||||||
|  |  | ||||||
|         // init submodule |         // init submodule | ||||||
|         awKeys.initDataAggregator(tooltipSettings) |         awKeys.initDataAggregator(tooltipSettings) | ||||||
|         awKeys.initKeys(plasmoid.configuration.text, plasmoid.configuration.interval, |         awKeys.initKeys(plasmoid.configuration.text, plasmoid.configuration.interval, plasmoid.configuration.optimize) | ||||||
|                         plasmoid.configuration.queueLimit, plasmoid.configuration.optimize) |  | ||||||
|         awKeys.setWrapNewLines(plasmoid.configuration.wrapNewLines) |         awKeys.setWrapNewLines(plasmoid.configuration.wrapNewLines) | ||||||
|         // configure aggregator |         // configure aggregator | ||||||
|         awKeys.setAggregatorProperty("acOffline", plasmoid.configuration.acOffline) |         awKeys.setAggregatorProperty("acOffline", plasmoid.configuration.acOffline) | ||||||
| @ -216,49 +177,8 @@ PlasmoidItem { | |||||||
|         awKeys.setAggregatorProperty("customUptime", plasmoid.configuration.customUptime) |         awKeys.setAggregatorProperty("customUptime", plasmoid.configuration.customUptime) | ||||||
|         awKeys.setAggregatorProperty("tempUnits", plasmoid.configuration.tempUnits) |         awKeys.setAggregatorProperty("tempUnits", plasmoid.configuration.tempUnits) | ||||||
|         awKeys.setAggregatorProperty("translate", plasmoid.configuration.translateStrings) |         awKeys.setAggregatorProperty("translate", plasmoid.configuration.translateStrings) | ||||||
|         // update telemetry ID |  | ||||||
|         if (plasmoid.configuration.telemetryId.length == 0) |  | ||||||
|             plasmoid.configuration.telemetryId = generateUuid() |  | ||||||
|         // save telemetry |         // save telemetry | ||||||
|         awTelemetryHandler.init(plasmoid.configuration.telemetryCount, |         awTelemetryHandler.init(plasmoid.configuration.historyCount) | ||||||
|                                 plasmoid.configuration.telemetryRemote, |         awTelemetryHandler.put("awwidgetconfig", plasmoid.configuration.text) | ||||||
|                                 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); |  | ||||||
|         }); |  | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
| @ -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 |  | ||||||
| @ -17,23 +17,14 @@ | |||||||
|  |  | ||||||
| import QtQuick 2.15 | import QtQuick 2.15 | ||||||
| import QtQuick.Controls | 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 |     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_tooltipNumber: tooltipNumber.value | ||||||
|     property alias cfg_useTooltipBackground: useTooltipBackground.checked |     property alias cfg_useTooltipBackground: useTooltipBackground.checked | ||||||
| @ -53,9 +44,7 @@ Item { | |||||||
|     property alias cfg_batTooltipColor: batTooltipColor.value |     property alias cfg_batTooltipColor: batTooltipColor.value | ||||||
|     property alias cfg_batInTooltipColor: batInTooltipColor.value |     property alias cfg_batInTooltipColor: batInTooltipColor.value | ||||||
|  |  | ||||||
|  |  | ||||||
|     Column { |     Column { | ||||||
|         id: pageColumn |  | ||||||
|         anchors.fill: parent |         anchors.fill: parent | ||||||
|  |  | ||||||
|         Label { |         Label { | ||||||
| @ -178,11 +167,13 @@ Item { | |||||||
|             Column { |             Column { | ||||||
|                 width: parent.width |                 width: parent.width | ||||||
|                 enabled: networkTooltipLabel.checked |                 enabled: networkTooltipLabel.checked | ||||||
|  |  | ||||||
|                 ColorSelector { |                 ColorSelector { | ||||||
|                     id: downkbTooltipColor |                     id: downkbTooltipColor | ||||||
|                     text: i18n("Download speed color") |                     text: i18n("Download speed color") | ||||||
|                     value: plasmoid.configuration.downkbTooltipColor |                     value: plasmoid.configuration.downkbTooltipColor | ||||||
|                 } |                 } | ||||||
|  |  | ||||||
|                 ColorSelector { |                 ColorSelector { | ||||||
|                     id: upkbTooltipColor |                     id: upkbTooltipColor | ||||||
|                     text: i18n("Upload speed color") |                     text: i18n("Upload speed color") | ||||||
| @ -204,11 +195,13 @@ Item { | |||||||
|             Column { |             Column { | ||||||
|                 width: parent.width |                 width: parent.width | ||||||
|                 enabled: batteryTooltipLabel.checked |                 enabled: batteryTooltipLabel.checked | ||||||
|  |  | ||||||
|                 ColorSelector { |                 ColorSelector { | ||||||
|                     id: batTooltipColor |                     id: batTooltipColor | ||||||
|                     text: i18n("Battery active color") |                     text: i18n("Battery active color") | ||||||
|                     value: plasmoid.configuration.batTooltipColor |                     value: plasmoid.configuration.batTooltipColor | ||||||
|                 } |                 } | ||||||
|  |  | ||||||
|                 ColorSelector { |                 ColorSelector { | ||||||
|                     id: batInTooltipColor |                     id: batInTooltipColor | ||||||
|                     text: i18n("Battery inactive color") |                     text: i18n("Battery inactive color") | ||||||
| @ -217,9 +210,4 @@ Item { | |||||||
|             } |             } | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|     Component.onCompleted: { |  | ||||||
|         if (debug) console.debug() |  | ||||||
|     } |  | ||||||
| } | } | ||||||
|  | |||||||
| @ -16,13 +16,16 @@ | |||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
| import QtQuick 2.15 | 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 "." | import org.kde.plasma.private.awesomewidget | ||||||
|  |  | ||||||
|  |  | ||||||
| Item { | KCM.SimpleKCM { | ||||||
|     id: widgetPage |     id: widgetPage | ||||||
|  |  | ||||||
|     // backend |     // backend | ||||||
|     AWKeys { |     AWKeys { | ||||||
|         id: awKeys |         id: awKeys | ||||||
| @ -31,21 +34,12 @@ Item { | |||||||
|         id: awActions |         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 alias cfg_text: textPattern.text | ||||||
|     property bool lock: true |     property bool lock: true | ||||||
|  |  | ||||||
|     signal needTextUpdate(string newText) |     signal needTextUpdate(string newText) | ||||||
|  |  | ||||||
|  |  | ||||||
|     Column { |     Column { | ||||||
|         id: pageColumn |  | ||||||
|         anchors.fill: parent |         anchors.fill: parent | ||||||
|  |  | ||||||
|         AWInfoLabel {} |         AWInfoLabel {} | ||||||
| @ -74,10 +68,7 @@ Item { | |||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |  | ||||||
|     Component.onCompleted: { |     Component.onCompleted: { | ||||||
|         if (debug) console.debug() |  | ||||||
|  |  | ||||||
|         awKeys.needTextToBeUpdated.connect(needTextUpdate) |         awKeys.needTextToBeUpdated.connect(needTextUpdate) | ||||||
|         // init submodule |         // init submodule | ||||||
|         awKeys.initKeys(plasmoid.configuration.text, plasmoid.configuration.interval, |         awKeys.initKeys(plasmoid.configuration.text, plasmoid.configuration.interval, | ||||||
| @ -92,7 +83,6 @@ Item { | |||||||
|  |  | ||||||
|     onNeedTextUpdate: newText => { |     onNeedTextUpdate: newText => { | ||||||
|         if (lock) return |         if (lock) return | ||||||
|         if (debug) console.debug() |  | ||||||
|  |  | ||||||
|         extensions.showMessage(newText) |         extensions.showMessage(newText) | ||||||
|         lock = true |         lock = true | ||||||
|  | |||||||
| @ -19,7 +19,7 @@ | |||||||
|         "Id": "org.kde.plasma.awesomewidget", |         "Id": "org.kde.plasma.awesomewidget", | ||||||
|         "License": "GPLv3", |         "License": "GPLv3", | ||||||
|         "Name": "Awesome Widget", |         "Name": "Awesome Widget", | ||||||
|         "Version": "3.5.1", |         "Version": "4.0.0", | ||||||
|         "Website": "https://arcanis.me/projects/awesome-widgets/" |         "Website": "https://arcanis.me/projects/awesome-widgets/" | ||||||
|     }, |     }, | ||||||
|     "X-Plasma-API-Minimum-Version": "6.0" |     "X-Plasma-API-Minimum-Version": "6.0" | ||||||
|  | |||||||
| @ -37,13 +37,13 @@ AWAbstractPairConfig::AWAbstractPairConfig(QWidget *_parent, const bool _hasEdit | |||||||
|  |  | ||||||
|     ui->setupUi(this); |     ui->setupUi(this); | ||||||
|  |  | ||||||
|     connect(ui->buttonBox, SIGNAL(accepted()), this, SLOT(accept())); |     connect(ui->buttonBox, &QDialogButtonBox::accepted, this, &AWAbstractPairConfig::accept); | ||||||
|     connect(ui->buttonBox, SIGNAL(rejected()), this, SLOT(reject())); |     connect(ui->buttonBox, &QDialogButtonBox::rejected, this, &AWAbstractPairConfig::reject); | ||||||
|  |  | ||||||
|     // edit feature |     // edit feature | ||||||
|     if (m_hasEdit) { |     if (m_hasEdit) { | ||||||
|         m_editButton = ui->buttonBox->addButton(i18n("Edit"), QDialogButtonBox::ActionRole); |         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() | void AWAbstractPairConfig::showDialog() | ||||||
| { | { | ||||||
|     // update dialog |     // update dialog | ||||||
| @ -84,14 +90,14 @@ void AWAbstractPairConfig::edit() | |||||||
|  |  | ||||||
| void AWAbstractPairConfig::updateUi() | void AWAbstractPairConfig::updateUi() | ||||||
| { | { | ||||||
|     QPair<QString, QString> current = dynamic_cast<AWAbstractSelector *>(sender())->current(); |     auto current = dynamic_cast<AWAbstractSelector *>(sender())->current(); | ||||||
|     int index = m_selectors.indexOf(dynamic_cast<AWAbstractSelector *>(sender())); |     auto index = m_selectors.indexOf(dynamic_cast<AWAbstractSelector *>(sender())); | ||||||
|  |  | ||||||
|     if ((current.first.isEmpty()) && (current.second.isEmpty())) { |     if ((current.first.isEmpty()) && (current.second.isEmpty())) { | ||||||
|         // remove current selector if it is empty and does not last |         // remove current selector if it is empty and does not last | ||||||
|         if (sender() == m_selectors.last()) |         if (sender() == m_selectors.last()) | ||||||
|             return; |             return; | ||||||
|         AWAbstractSelector *selector = m_selectors.takeAt(index); |         auto selector = m_selectors.takeAt(index); | ||||||
|         ui->verticalLayout->removeWidget(selector); |         ui->verticalLayout->removeWidget(selector); | ||||||
|         selector->deleteLater(); |         selector->deleteLater(); | ||||||
|     } else { |     } 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; |     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); |     selector->init(_keys, _values, _current); | ||||||
|     ui->verticalLayout->insertWidget(ui->verticalLayout->count() - 1, selector); |     ui->verticalLayout->insertWidget(ui->verticalLayout->count() - 1, selector); | ||||||
|     connect(selector, SIGNAL(selectionChanged()), this, SLOT(updateUi())); |     connect(selector, &AWAbstractSelector::selectionChanged, this, &AWAbstractPairConfig::updateUi); | ||||||
|     m_selectors.append(selector); |     m_selectors.append(selector); | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| void AWAbstractPairConfig::clearSelectors() | void AWAbstractPairConfig::clearSelectors() | ||||||
| { | { | ||||||
|     for (auto &selector : m_selectors) { |     for (auto selector : m_selectors) { | ||||||
|         disconnect(selector, SIGNAL(selectionChanged()), this, SLOT(updateUi())); |         disconnect(selector, &AWAbstractSelector::selectionChanged, this, &AWAbstractPairConfig::updateUi); | ||||||
|         ui->verticalLayout->removeWidget(selector); |         ui->verticalLayout->removeWidget(selector); | ||||||
|         selector->deleteLater(); |         selector->deleteLater(); | ||||||
|     } |     } | ||||||
| @ -130,10 +136,10 @@ void AWAbstractPairConfig::clearSelectors() | |||||||
|  |  | ||||||
| void AWAbstractPairConfig::execDialog() | void AWAbstractPairConfig::execDialog() | ||||||
| { | { | ||||||
|     int ret = exec(); |     auto ret = exec(); | ||||||
|     QHash<QString, QString> data; |     QHash<QString, QString> data; | ||||||
|     for (auto &selector : m_selectors) { |     for (auto selector : m_selectors) { | ||||||
|         QPair<QString, QString> select = selector->current(); |         auto select = selector->current(); | ||||||
|         if (select.first.isEmpty()) |         if (select.first.isEmpty()) | ||||||
|             continue; |             continue; | ||||||
|         data[select.first] = select.second; |         data[select.first] = select.second; | ||||||
| @ -160,11 +166,12 @@ QPair<QStringList, QStringList> AWAbstractPairConfig::initKeys() const | |||||||
|     QStringList left = {""}; |     QStringList left = {""}; | ||||||
|     left.append(m_helper->leftKeys().isEmpty() ? m_keys : m_helper->leftKeys()); |     left.append(m_helper->leftKeys().isEmpty() ? m_keys : m_helper->leftKeys()); | ||||||
|     left.sort(); |     left.sort(); | ||||||
|  |  | ||||||
|     QStringList right = {""}; |     QStringList right = {""}; | ||||||
|     right.append(m_helper->rightKeys().isEmpty() ? m_keys : m_helper->rightKeys()); |     right.append(m_helper->rightKeys().isEmpty() ? m_keys : m_helper->rightKeys()); | ||||||
|     right.sort(); |     right.sort(); | ||||||
|  |  | ||||||
|     return QPair<QStringList, QStringList>(left, right); |     return {left, right}; | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -175,7 +182,7 @@ void AWAbstractPairConfig::updateDialog() | |||||||
|     auto keys = initKeys(); |     auto keys = initKeys(); | ||||||
|  |  | ||||||
|     for (auto &key : m_helper->keys()) |     for (auto &key : m_helper->keys()) | ||||||
|         addSelector(keys.first, keys.second, QPair<QString, QString>(key, m_helper->pairs()[key])); |         addSelector(keys.first, keys.second, {key, pairs[key]}); | ||||||
|     // empty one |     // 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/  * |  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
|  | #pragma once | ||||||
| #ifndef AWABSTRACTPAIRCONFIG_H |  | ||||||
| #define AWABSTRACTPAIRCONFIG_H |  | ||||||
|  |  | ||||||
| #include <QDialog> | #include <QDialog> | ||||||
|  |  | ||||||
| @ -35,14 +33,9 @@ class AWAbstractPairConfig : public QDialog | |||||||
|     Q_OBJECT |     Q_OBJECT | ||||||
|  |  | ||||||
| public: | public: | ||||||
|     explicit AWAbstractPairConfig(QWidget *_parent = nullptr, bool _hasEdit = false, QStringList _keys = QStringList()); |     explicit AWAbstractPairConfig(QWidget *_parent = nullptr, bool _hasEdit = false, QStringList _keys = {}); | ||||||
|     ~AWAbstractPairConfig() override; |     ~AWAbstractPairConfig() override; | ||||||
|     template <class T> void initHelper() |     void setHelper(std::unique_ptr<AWAbstractPairHelper> _helper); | ||||||
|     { |  | ||||||
|  |  | ||||||
|         delete m_helper; |  | ||||||
|         m_helper = new T(this); |  | ||||||
|     } |  | ||||||
|     void showDialog(); |     void showDialog(); | ||||||
|     // properties |     // properties | ||||||
|     void setEditable(bool _first, bool _second); |     void setEditable(bool _first, bool _second); | ||||||
| @ -54,7 +47,7 @@ private slots: | |||||||
| private: | private: | ||||||
|     QPushButton *m_editButton = nullptr; |     QPushButton *m_editButton = nullptr; | ||||||
|     Ui::AWAbstractPairConfig *ui = nullptr; |     Ui::AWAbstractPairConfig *ui = nullptr; | ||||||
|     AWAbstractPairHelper *m_helper = nullptr; |     std::unique_ptr<AWAbstractPairHelper> m_helper; | ||||||
|     QList<AWAbstractSelector *> m_selectors; |     QList<AWAbstractSelector *> m_selectors; | ||||||
|     // properties |     // properties | ||||||
|     QPair<bool, bool> m_editable = {false, false}; |     QPair<bool, bool> m_editable = {false, false}; | ||||||
| @ -67,6 +60,3 @@ private: | |||||||
|     [[nodiscard]] QPair<QStringList, QStringList> initKeys() const; |     [[nodiscard]] QPair<QStringList, QStringList> initKeys() const; | ||||||
|     void updateDialog(); |     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 | QStringList AWAbstractPairHelper::keys() const | ||||||
| { | { | ||||||
|     return m_pairs.keys(); |     return m_pairs.keys(); | ||||||
| @ -69,16 +63,16 @@ void AWAbstractPairHelper::initItems() | |||||||
| { | { | ||||||
|     m_pairs.clear(); |     m_pairs.clear(); | ||||||
|  |  | ||||||
|     QStringList configs = QStandardPaths::locateAll(QStandardPaths::GenericDataLocation, m_filePath); |     auto configs = QStandardPaths::locateAll(QStandardPaths::GenericDataLocation, m_filePath); | ||||||
|  |  | ||||||
|     for (auto &fileName : configs) { |     for (auto &fileName : configs) { | ||||||
|         QSettings settings(fileName, QSettings::IniFormat); |         QSettings settings(fileName, QSettings::IniFormat); | ||||||
|         qCInfo(LOG_AW) << "Configuration file" << settings.fileName(); |         qCInfo(LOG_AW) << "Configuration file" << settings.fileName(); | ||||||
|  |  | ||||||
|         settings.beginGroup(m_section); |         settings.beginGroup(m_section); | ||||||
|         QStringList keys = settings.childKeys(); |         auto keys = settings.childKeys(); | ||||||
|         for (auto &key : keys) { |         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(); |             qCInfo(LOG_AW) << "Found key" << key << "for value" << value << "in" << settings.fileName(); | ||||||
|             if (value.isEmpty()) { |             if (value.isEmpty()) { | ||||||
|                 qCInfo(LOG_AW) << "Skip empty value for" << key; |                 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; |     qCDebug(LOG_AW) << "Write configuration" << _configuration; | ||||||
|  |  | ||||||
|     QString fileName |     auto fileName | ||||||
|         = QString("%1/%2").arg(QStandardPaths::writableLocation(QStandardPaths::GenericDataLocation)).arg(m_filePath); |         = QString("%1/%2").arg(QStandardPaths::writableLocation(QStandardPaths::GenericDataLocation), m_filePath); | ||||||
|     QSettings settings(fileName, QSettings::IniFormat); |     QSettings settings(fileName, QSettings::IniFormat); | ||||||
|     qCInfo(LOG_AW) << "Configuration file" << fileName; |     qCInfo(LOG_AW) << "Configuration file" << fileName; | ||||||
|  |  | ||||||
| @ -107,7 +101,7 @@ bool AWAbstractPairHelper::writeItems(const QHash<QString, QString> &_configurat | |||||||
|  |  | ||||||
|     settings.sync(); |     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; |     qCDebug(LOG_AW) << "Remove keys" << _keys; | ||||||
|  |  | ||||||
|     QString fileName |     auto fileName | ||||||
|         = QString("%1/%2").arg(QStandardPaths::writableLocation(QStandardPaths::GenericDataLocation)).arg(m_filePath); |         = QString("%1/%2").arg(QStandardPaths::writableLocation(QStandardPaths::GenericDataLocation), m_filePath); | ||||||
|     QSettings settings(fileName, QSettings::IniFormat); |     QSettings settings(fileName, QSettings::IniFormat); | ||||||
|     qCInfo(LOG_AW) << "Configuration file" << fileName; |     qCInfo(LOG_AW) << "Configuration file" << fileName; | ||||||
|  |  | ||||||
|     settings.beginGroup(m_section); |     settings.beginGroup(m_section); | ||||||
|     QStringList foundKeys = settings.childKeys(); |     for (auto &key : settings.childKeys()) { | ||||||
|     for (auto &key : foundKeys) { |  | ||||||
|         if (_keys.contains(key)) |         if (_keys.contains(key)) | ||||||
|             continue; |             continue; | ||||||
|         settings.remove(key); |         settings.remove(key); | ||||||
| @ -131,5 +124,5 @@ bool AWAbstractPairHelper::removeUnusedKeys(const QStringList &_keys) const | |||||||
|  |  | ||||||
|     settings.sync(); |     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/  * |  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
|  | #pragma once | ||||||
| #ifndef AWABSTRACTPAIRHELPER_H |  | ||||||
| #define AWABSTRACTPAIRHELPER_H |  | ||||||
|  |  | ||||||
| #include <QHash> | #include <QHash> | ||||||
|  |  | ||||||
| @ -26,7 +24,7 @@ class AWAbstractPairHelper | |||||||
| { | { | ||||||
| public: | public: | ||||||
|     explicit AWAbstractPairHelper(QString _filePath = "", QString _section = ""); |     explicit AWAbstractPairHelper(QString _filePath = "", QString _section = ""); | ||||||
|     virtual ~AWAbstractPairHelper(); |     virtual ~AWAbstractPairHelper() = default; | ||||||
|     [[nodiscard]] QStringList keys() const; |     [[nodiscard]] QStringList keys() const; | ||||||
|     [[nodiscard]] QHash<QString, QString> pairs() const; |     [[nodiscard]] QHash<QString, QString> pairs() const; | ||||||
|     [[nodiscard]] QStringList values() const; |     [[nodiscard]] QStringList values() const; | ||||||
| @ -46,6 +44,3 @@ private: | |||||||
|     QString m_filePath; |     QString m_filePath; | ||||||
|     QString m_section; |     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_key->setEditable(_editable.first); | ||||||
|     ui->comboBox_value->setEditable(_editable.second); |     ui->comboBox_value->setEditable(_editable.second); | ||||||
|  |  | ||||||
|     connect(ui->comboBox_key, SIGNAL(currentIndexChanged(int)), this, SIGNAL(selectionChanged())); |     connect(ui->comboBox_key, &QComboBox::currentIndexChanged, this, &AWAbstractSelector::selectionChanged); | ||||||
|     connect(ui->comboBox_value, SIGNAL(currentIndexChanged(int)), this, SIGNAL(selectionChanged())); |     connect(ui->comboBox_value, &QComboBox::currentIndexChanged, this, &AWAbstractSelector::selectionChanged); | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -46,10 +46,10 @@ AWAbstractSelector::~AWAbstractSelector() | |||||||
|  |  | ||||||
| QPair<QString, QString> AWAbstractSelector::current() const | QPair<QString, QString> AWAbstractSelector::current() const | ||||||
| { | { | ||||||
|     QString key = ui->comboBox_key->currentText(); |     auto key = ui->comboBox_key->currentText(); | ||||||
|     QString value = ui->comboBox_value->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/  * |  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
|  | #pragma once | ||||||
| #ifndef AWABSTRACTSELECTOR_H |  | ||||||
| #define AWABSTRACTSELECTOR_H |  | ||||||
|  |  | ||||||
| #include <QWidget> | #include <QWidget> | ||||||
|  |  | ||||||
| @ -43,6 +41,3 @@ signals: | |||||||
| private: | private: | ||||||
|     Ui::AWAbstractSelector *ui = nullptr; |     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) | void AWActions::checkUpdates(const bool _showAnyway) | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Show anyway" << _showAnyway; |     qCDebug(LOG_AW) << "Show anyway" << _showAnyway; | ||||||
| @ -65,24 +59,17 @@ QString AWActions::getFileContent(const QString &_path) | |||||||
|         return ""; |         return ""; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     QString output = inputFile.readAll(); |     auto output = inputFile.readAll(); | ||||||
|     inputFile.close(); |     inputFile.close(); | ||||||
|     return output; |     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) | bool AWActions::runCmd(const QString &_cmd, const QStringList &_args) | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Cmd" << _cmd << "args" << _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); |     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 | // HACK: this method uses variables from version.h | ||||||
| QString AWActions::getAboutText(const QString &_type) | QString AWActions::getAboutText(const QString &_type) | ||||||
| { | { | ||||||
| @ -123,10 +96,10 @@ QVariantMap AWActions::getFont(const QVariantMap &_defaultFont) | |||||||
|     qCDebug(LOG_AW) << "Default font is" << _defaultFont; |     qCDebug(LOG_AW) << "Default font is" << _defaultFont; | ||||||
|  |  | ||||||
|     QVariantMap fontMap; |     QVariantMap fontMap; | ||||||
|     int ret = 0; |     auto ret = 0; | ||||||
|     CFont defaultCFont = CFont(_defaultFont["family"].toString(), _defaultFont["size"].toInt(), 400, false, |     auto defaultCFont = CFont(_defaultFont["family"].toString(), _defaultFont["size"].toInt(), 400, false, | ||||||
|                               _defaultFont["color"].toString()); |                               _defaultFont["color"].toString()); | ||||||
|     CFont font = CFontDialog::getFont(i18n("Select font"), defaultCFont, false, false, &ret); |     auto font = CFontDialog::getFont(i18n("Select font"), defaultCFont, false, false, &ret); | ||||||
|  |  | ||||||
|     fontMap["applied"] = ret; |     fontMap["applied"] = ret; | ||||||
|     fontMap["color"] = font.color().name(); |     fontMap["color"] = font.color().name(); | ||||||
| @ -142,7 +115,6 @@ void AWActions::sendNotification(const QString &_eventId, const QString &_messag | |||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Event" << _eventId << "with message" << _message; |     qCDebug(LOG_AW) << "Event" << _eventId << "with message" << _message; | ||||||
|  |  | ||||||
|     KNotification *notification |     auto event = KNotification::event(_eventId, QString("Awesome Widget ::: %1").arg(_eventId), _message); | ||||||
|         = KNotification::event(_eventId, QString("Awesome Widget ::: %1").arg(_eventId), _message); |     event->setComponentName("plasma-applet-org.kde.plasma.awesome-widget"); | ||||||
|     notification->setComponentName("plasma-applet-org.kde.plasma.awesome-widget"); |  | ||||||
| } | } | ||||||
|  | |||||||
| @ -15,9 +15,7 @@ | |||||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * |  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
|  | #pragma once | ||||||
| #ifndef AWACTIONS_H |  | ||||||
| #define AWACTIONS_H |  | ||||||
|  |  | ||||||
| #include <QMap> | #include <QMap> | ||||||
| #include <QObject> | #include <QObject> | ||||||
| @ -31,12 +29,10 @@ class AWActions : public QObject | |||||||
|  |  | ||||||
| public: | public: | ||||||
|     explicit AWActions(QObject *_parent = nullptr); |     explicit AWActions(QObject *_parent = nullptr); | ||||||
|     ~AWActions() override; |     ~AWActions() override = default; | ||||||
|     Q_INVOKABLE void checkUpdates(bool _showAnyway = false); |     Q_INVOKABLE void checkUpdates(bool _showAnyway = false); | ||||||
|     Q_INVOKABLE static QString getFileContent(const QString &_path); |     Q_INVOKABLE static QString getFileContent(const QString &_path); | ||||||
|     Q_INVOKABLE static bool isDebugEnabled(); |  | ||||||
|     Q_INVOKABLE static bool runCmd(const QString &_cmd, const QStringList &_args); |     Q_INVOKABLE static bool runCmd(const QString &_cmd, const QStringList &_args); | ||||||
|     Q_INVOKABLE static void showLegacyInfo(); |  | ||||||
|     Q_INVOKABLE static void showReadme(); |     Q_INVOKABLE static void showReadme(); | ||||||
|     // configuration slots |     // configuration slots | ||||||
|     Q_INVOKABLE static QString getAboutText(const QString &_type); |     Q_INVOKABLE static QString getAboutText(const QString &_type); | ||||||
| @ -48,6 +44,3 @@ public slots: | |||||||
| private: | private: | ||||||
|     AWUpdateHelper *m_updateHelper = nullptr; |     AWUpdateHelper *m_updateHelper = nullptr; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| #endif /* AWACTIONS_H */ |  | ||||||
|  | |||||||
| @ -18,6 +18,7 @@ | |||||||
| #include "awbugreporter.h" | #include "awbugreporter.h" | ||||||
|  |  | ||||||
| #include <KI18n/KLocalizedString> | #include <KI18n/KLocalizedString> | ||||||
|  | #include <KNotifications/KNotification> | ||||||
|  |  | ||||||
| #include <QDesktopServices> | #include <QDesktopServices> | ||||||
| #include <QJsonDocument> | #include <QJsonDocument> | ||||||
| @ -32,19 +33,24 @@ AWBugReporter::AWBugReporter(QObject *_parent) | |||||||
|     : QObject(_parent) |     : QObject(_parent) | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; |     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; | ||||||
|  |  | ||||||
|  |     m_manager = new QNetworkAccessManager(nullptr); | ||||||
|  |     connect(m_manager, &QNetworkAccessManager::finished, this, &AWBugReporter::issueReplyReceived); | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| AWBugReporter::~AWBugReporter() | AWBugReporter::~AWBugReporter() | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; |     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; | ||||||
|  |  | ||||||
|  |     m_manager->deleteLater(); | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| void AWBugReporter::doConnect() | void AWBugReporter::doConnect() const | ||||||
| { | { | ||||||
|     // additional method for testing needs |     // 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; |     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"); |     request.setHeader(QNetworkRequest::ContentTypeHeader, "application/json"); | ||||||
|  |  | ||||||
|     // generate payload |     // generate payload | ||||||
|     QVariantMap payload; |     QVariantMap payload; | ||||||
|     payload["title"] = _title; |     payload["title"] = _title; | ||||||
|     payload["body"] = _body; |     payload["body"] = _body; | ||||||
|     payload["labels"] = QStringList() << "from application"; |     payload["labels"] = QStringList({"from application"}); | ||||||
|     // convert to QByteArray to send request |     // convert to QByteArray to send request | ||||||
|     QByteArray data = 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(); |     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) { |     if (_reply->error() != QNetworkReply::NoError) { | ||||||
|         qCWarning(LOG_AW) << "An error occurs" << _reply->error() << "with message" << _reply->errorString(); |         qCWarning(LOG_AW) << "An error occurs" << _reply->error() << "with message" << _reply->errorString(); | ||||||
| @ -98,7 +102,7 @@ void AWBugReporter::issueReplyRecieved(QNetworkReply *_reply) | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     QJsonParseError error{}; |     QJsonParseError error{}; | ||||||
|     QJsonDocument jsonDoc = QJsonDocument::fromJson(_reply->readAll(), &error); |     auto jsonDoc = QJsonDocument::fromJson(_reply->readAll(), &error); | ||||||
|     if (error.error != QJsonParseError::NoError) { |     if (error.error != QJsonParseError::NoError) { | ||||||
|         qCWarning(LOG_AW) << "Parse error" << error.errorString(); |         qCWarning(LOG_AW) << "Parse error" << error.errorString(); | ||||||
|         return emit(replyReceived(0, "")); |         return emit(replyReceived(0, "")); | ||||||
| @ -106,14 +110,20 @@ void AWBugReporter::issueReplyRecieved(QNetworkReply *_reply) | |||||||
|     _reply->deleteLater(); |     _reply->deleteLater(); | ||||||
|  |  | ||||||
|     // convert to map |     // convert to map | ||||||
|     QVariantMap response = jsonDoc.toVariant().toMap(); |     auto response = jsonDoc.toVariant().toMap(); | ||||||
|     QString url = response["html_url"].toString(); |     auto url = response["html_url"].toString(); | ||||||
|     int number = response["number"].toInt(); |     auto number = response["number"].toInt(); | ||||||
|  |  | ||||||
|     return emit(replyReceived(number, url)); |     return emit(replyReceived(number, url)); | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | void AWBugReporter::openBugReport() | ||||||
|  | { | ||||||
|  |     QDesktopServices::openUrl(m_lastBugUrl); | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
| void AWBugReporter::showInformation(const int _number, const QString &_url) | void AWBugReporter::showInformation(const int _number, const QString &_url) | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Created issue with number" << _number << "and url" << _url; |     qCDebug(LOG_AW) << "Created issue with number" << _number << "and url" << _url; | ||||||
| @ -121,29 +131,9 @@ void AWBugReporter::showInformation(const int _number, const QString &_url) | |||||||
|     // cache url first |     // cache url first | ||||||
|     m_lastBugUrl = _url; |     m_lastBugUrl = _url; | ||||||
|  |  | ||||||
|     auto *msgBox = new QMessageBox(nullptr); |     auto event = KNotification::event("system", i18n("Issue created"), i18n("Issue %1 has been created", _number)); | ||||||
|     msgBox->setAttribute(Qt::WA_DeleteOnClose); |     event->setComponentName("plasma-applet-org.kde.plasma.awesome-widget"); | ||||||
|     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); |  | ||||||
|  |  | ||||||
|     msgBox->open(this, SLOT(userReplyOnBugReport(QAbstractButton *))); |     auto action = event->addAction(i18n("Details")); | ||||||
| } |     connect(action, &KNotificationAction::activated, this, &AWBugReporter::openBugReport); | ||||||
|  |  | ||||||
|  |  | ||||||
| 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; |  | ||||||
|     } |  | ||||||
| } | } | ||||||
|  | |||||||
| @ -15,14 +15,12 @@ | |||||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * |  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
|  | #pragma once | ||||||
| #ifndef AWBUGREPORTER_H |  | ||||||
| #define AWBUGREPORTER_H |  | ||||||
|  |  | ||||||
| #include <QObject> | #include <QObject> | ||||||
|  |  | ||||||
|  |  | ||||||
| class QAbstractButton; | class QNetworkAccessManager; | ||||||
| class QNetworkReply; | class QNetworkReply; | ||||||
|  |  | ||||||
| class AWBugReporter : public QObject | class AWBugReporter : public QObject | ||||||
| @ -32,7 +30,7 @@ class AWBugReporter : public QObject | |||||||
| public: | public: | ||||||
|     explicit AWBugReporter(QObject *_parent = nullptr); |     explicit AWBugReporter(QObject *_parent = nullptr); | ||||||
|     ~AWBugReporter() override; |     ~AWBugReporter() override; | ||||||
|     Q_INVOKABLE void doConnect(); |     Q_INVOKABLE void doConnect() const; | ||||||
|     Q_INVOKABLE static QString generateText(const QString &_description, const QString &_reproduce, |     Q_INVOKABLE static QString generateText(const QString &_description, const QString &_reproduce, | ||||||
|                                             const QString &_expected, const QString &_logs); |                                             const QString &_expected, const QString &_logs); | ||||||
|     Q_INVOKABLE void sendBugReport(const QString &_title, const QString &_body); |     Q_INVOKABLE void sendBugReport(const QString &_title, const QString &_body); | ||||||
| @ -41,13 +39,11 @@ signals: | |||||||
|     void replyReceived(int _number, const QString &_url); |     void replyReceived(int _number, const QString &_url); | ||||||
|  |  | ||||||
| private slots: | private slots: | ||||||
|     void issueReplyRecieved(QNetworkReply *_reply); |     void issueReplyReceived(QNetworkReply *_reply); | ||||||
|  |     void openBugReport(); | ||||||
|     void showInformation(int _number, const QString &_url); |     void showInformation(int _number, const QString &_url); | ||||||
|     void userReplyOnBugReport(QAbstractButton *_button); |  | ||||||
|  |  | ||||||
| private: | private: | ||||||
|     QString m_lastBugUrl; |     QString m_lastBugUrl; | ||||||
|  |     QNetworkAccessManager *m_manager = nullptr; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| #endif /* AWBUGREPORTER_H */ |  | ||||||
|  | |||||||
| @ -34,16 +34,10 @@ AWConfigHelper::AWConfigHelper(QObject *_parent) | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| AWConfigHelper::~AWConfigHelper() |  | ||||||
| { |  | ||||||
|     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| QString AWConfigHelper::configurationDirectory() | QString AWConfigHelper::configurationDirectory() | ||||||
| { | { | ||||||
|     // get readable directory |     // get readable directory | ||||||
|     QString localDir = QString("%1/awesomewidgets/configs") |     auto localDir = QString("%1/awesomewidgets/configs") | ||||||
|                         .arg(QStandardPaths::writableLocation(QStandardPaths::GenericDataLocation)); |                         .arg(QStandardPaths::writableLocation(QStandardPaths::GenericDataLocation)); | ||||||
|  |  | ||||||
|     // create directory and copy files from default settings |     // create directory and copy files from default settings | ||||||
| @ -59,7 +53,7 @@ QString AWConfigHelper::configurationDirectory() | |||||||
|  |  | ||||||
| bool AWConfigHelper::dropCache() | bool AWConfigHelper::dropCache() | ||||||
| { | { | ||||||
|     QString fileName |     auto fileName | ||||||
|         = QString("%1/awesomewidgets.ndx").arg(QStandardPaths::writableLocation(QStandardPaths::GenericCacheLocation)); |         = QString("%1/awesomewidgets.ndx").arg(QStandardPaths::writableLocation(QStandardPaths::GenericCacheLocation)); | ||||||
|  |  | ||||||
|     return QFile(fileName).remove(); |     return QFile(fileName).remove(); | ||||||
| @ -72,10 +66,10 @@ bool AWConfigHelper::exportConfiguration(QObject *_nativeConfig, const QString & | |||||||
|  |  | ||||||
|     QSettings settings(_fileName, QSettings::IniFormat); |     QSettings settings(_fileName, QSettings::IniFormat); | ||||||
|     // plasmoid configuration |     // plasmoid configuration | ||||||
|     const auto *configuration = dynamic_cast<const QQmlPropertyMap *>(_nativeConfig); |     auto configuration = dynamic_cast<const QQmlPropertyMap *>(_nativeConfig); | ||||||
|     settings.beginGroup("plasmoid"); |     settings.beginGroup("plasmoid"); | ||||||
|     for (auto &key : configuration->keys()) { |     for (auto &key : configuration->keys()) { | ||||||
|         QVariant value = configuration->value(key); |         auto value = configuration->value(key); | ||||||
|         if (!value.isValid()) |         if (!value.isValid()) | ||||||
|             continue; |             continue; | ||||||
|         settings.setValue(key, value); |         settings.setValue(key, value); | ||||||
| @ -84,8 +78,7 @@ bool AWConfigHelper::exportConfiguration(QObject *_nativeConfig, const QString & | |||||||
|  |  | ||||||
|     // extensions |     // extensions | ||||||
|     for (auto &item : m_dirs) { |     for (auto &item : m_dirs) { | ||||||
|         QStringList items |         auto items = QDir(QString("%1/%2").arg(m_baseDir, item)).entryList({"*.desktop"}, QDir::Files); | ||||||
|             = QDir(QString("%1/%2").arg(m_baseDir).arg(item)).entryList(QStringList() << "*.desktop", QDir::Files); |  | ||||||
|         settings.beginGroup(item); |         settings.beginGroup(item); | ||||||
|         for (auto &it : items) |         for (auto &it : items) | ||||||
|             copyExtensions(it, item, settings, false); |             copyExtensions(it, item, settings, false); | ||||||
| @ -163,16 +156,13 @@ QVariantMap AWConfigHelper::importConfiguration(const QString &_fileName, const | |||||||
|  |  | ||||||
| QVariantMap AWConfigHelper::readDataEngineConfiguration() | 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; |     qCInfo(LOG_AW) << "Configuration file" << fileName; | ||||||
|     QSettings settings(fileName, QSettings::IniFormat); |     QSettings settings(fileName, QSettings::IniFormat); | ||||||
|     QVariantMap configuration; |     QVariantMap configuration; | ||||||
|  |  | ||||||
|     settings.beginGroup("Configuration"); |     settings.beginGroup("Configuration"); | ||||||
|     configuration["ACPIPATH"] = settings.value("ACPIPATH", "/sys/class/power_supply/"); |     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["MPDADDRESS"] = settings.value("MPDADDRESS", "localhost"); | ||||||
|     configuration["MPDPORT"] = settings.value("MPDPORT", "6600"); |     configuration["MPDPORT"] = settings.value("MPDPORT", "6600"); | ||||||
|     configuration["MPRIS"] = settings.value("MPRIS", "auto"); |     configuration["MPRIS"] = settings.value("MPRIS", "auto"); | ||||||
| @ -190,16 +180,13 @@ bool AWConfigHelper::writeDataEngineConfiguration(const QVariantMap &_configurat | |||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Configuration" << _configuration; |     qCDebug(LOG_AW) << "Configuration" << _configuration; | ||||||
|  |  | ||||||
|     QString fileName = QString("%1/plasma-dataengine-extsysmon.conf") |     auto fileName = QString("%1/plasma-dataengine-extsysmon.conf") | ||||||
|                         .arg(QStandardPaths::writableLocation(QStandardPaths::ConfigLocation)); |                         .arg(QStandardPaths::writableLocation(QStandardPaths::ConfigLocation)); | ||||||
|     QSettings settings(fileName, QSettings::IniFormat); |     QSettings settings(fileName, QSettings::IniFormat); | ||||||
|     qCInfo(LOG_AW) << "Configuration file" << settings.fileName(); |     qCInfo(LOG_AW) << "Configuration file" << settings.fileName(); | ||||||
|  |  | ||||||
|     settings.beginGroup("Configuration"); |     settings.beginGroup("Configuration"); | ||||||
|     settings.setValue("ACPIPATH", _configuration["ACPIPATH"]); |     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("MPDADDRESS", _configuration["MPDADDRESS"]); | ||||||
|     settings.setValue("MPDPORT", _configuration["MPDPORT"]); |     settings.setValue("MPDPORT", _configuration["MPDPORT"]); | ||||||
|     settings.setValue("MPRIS", _configuration["MPRIS"]); |     settings.setValue("MPRIS", _configuration["MPRIS"]); | ||||||
| @ -217,15 +204,15 @@ void AWConfigHelper::copyConfigs(const QString &_localDir) | |||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Local directory" << _localDir; |     qCDebug(LOG_AW) << "Local directory" << _localDir; | ||||||
|  |  | ||||||
|     QStringList dirs = QStandardPaths::locateAll(QStandardPaths::GenericDataLocation, "awesomewidgets/configs", |     auto dirs = QStandardPaths::locateAll(QStandardPaths::GenericDataLocation, "awesomewidgets/configs", | ||||||
|                                           QStandardPaths::LocateDirectory); |                                           QStandardPaths::LocateDirectory); | ||||||
|     for (auto &dir : dirs) { |     for (auto &dir : dirs) { | ||||||
|         if (dir == _localDir) |         if (dir == _localDir) | ||||||
|             continue; |             continue; | ||||||
|         QStringList files = QDir(dir).entryList(QDir::Files); |         auto files = QDir(dir).entryList(QDir::Files); | ||||||
|         for (auto &source : files) { |         for (auto &source : files) { | ||||||
|             QString destination = QString("%1/%2").arg(_localDir).arg(source); |             auto destination = QString("%1/%2").arg(_localDir, source); | ||||||
|             bool status = QFile::copy(QString("%1/%2").arg(dir).arg(source), destination); |             auto status = QFile::copy(QString("%1/%2").arg(dir, source), destination); | ||||||
|             qCInfo(LOG_AW) << "File" << source << "has been copied to" << destination << "with status" << status; |             qCInfo(LOG_AW) << "File" << source << "has been copied to" << destination << "with status" << status; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| @ -238,7 +225,7 @@ void AWConfigHelper::copyExtensions(const QString &_item, const QString &_type, | |||||||
|     qCDebug(LOG_AW) << "Extension" << _item << "has type" << _type << "inverse copying" << _inverse; |     qCDebug(LOG_AW) << "Extension" << _item << "has type" << _type << "inverse copying" << _inverse; | ||||||
|  |  | ||||||
|     _settings.beginGroup(_item); |     _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"); |     itemSettings.beginGroup("Desktop Entry"); | ||||||
|     if (_inverse) |     if (_inverse) | ||||||
|         copySettings(_settings, itemSettings); |         copySettings(_settings, itemSettings); | ||||||
| @ -265,7 +252,7 @@ void AWConfigHelper::readFile(QSettings &_settings, const QString &_key, const Q | |||||||
|  |  | ||||||
|     QFile file(_fileName); |     QFile file(_fileName); | ||||||
|     if (file.open(QIODevice::ReadOnly | QIODevice::Text)) { |     if (file.open(QIODevice::ReadOnly | QIODevice::Text)) { | ||||||
|         QString text = QString::fromUtf8(file.readAll()); |         auto text = QString::fromUtf8(file.readAll()); | ||||||
|         file.close(); |         file.close(); | ||||||
|         _settings.setValue(_key, text); |         _settings.setValue(_key, text); | ||||||
|     } else { |     } else { | ||||||
|  | |||||||
| @ -15,9 +15,7 @@ | |||||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * |  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
|  | #pragma once | ||||||
| #ifndef AWCONFIGHELPER_H |  | ||||||
| #define AWCONFIGHELPER_H |  | ||||||
|  |  | ||||||
| #include <QObject> | #include <QObject> | ||||||
| #include <QVariant> | #include <QVariant> | ||||||
| @ -31,7 +29,7 @@ class AWConfigHelper : public QObject | |||||||
|  |  | ||||||
| public: | public: | ||||||
|     explicit AWConfigHelper(QObject *_parent = nullptr); |     explicit AWConfigHelper(QObject *_parent = nullptr); | ||||||
|     ~AWConfigHelper() override; |     ~AWConfigHelper() override = default; | ||||||
|     Q_INVOKABLE [[nodiscard]] static QString configurationDirectory(); |     Q_INVOKABLE [[nodiscard]] static QString configurationDirectory(); | ||||||
|     Q_INVOKABLE static bool dropCache(); |     Q_INVOKABLE static bool dropCache(); | ||||||
|     Q_INVOKABLE bool exportConfiguration(QObject *_nativeConfig, const QString &_fileName) const; |     Q_INVOKABLE bool exportConfiguration(QObject *_nativeConfig, const QString &_fileName) const; | ||||||
| @ -52,6 +50,3 @@ private: | |||||||
|     QString m_baseDir; |     QString m_baseDir; | ||||||
|     QStringList m_dirs = {"desktops", "quotes", "scripts", "upgrade", "weather", "formatters"}; |     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__; |     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; | ||||||
|  |  | ||||||
|     setEditable(true, false); |     setEditable(true, false); | ||||||
|     initHelper<AWCustomKeysHelper>(); |     setHelper(std::make_unique<AWCustomKeysHelper>()); | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| AWCustomKeysConfig::~AWCustomKeysConfig() |  | ||||||
| { |  | ||||||
|     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; |  | ||||||
| } | } | ||||||
|  | |||||||
| @ -15,9 +15,7 @@ | |||||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * |  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
|  | #pragma once | ||||||
| #ifndef AWCUSTOMKEYSCONFIG_H |  | ||||||
| #define AWCUSTOMKEYSCONFIG_H |  | ||||||
|  |  | ||||||
| #include "awabstractpairconfig.h" | #include "awabstractpairconfig.h" | ||||||
|  |  | ||||||
| @ -28,8 +26,5 @@ class AWCustomKeysConfig : public AWAbstractPairConfig | |||||||
|  |  | ||||||
| public: | public: | ||||||
|     explicit AWCustomKeysConfig(QWidget *_parent = nullptr, const QStringList &_keys = QStringList()); |     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 | QString AWCustomKeysHelper::source(const QString &_key) const | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Get source by key" << _key; |     qCDebug(LOG_AW) << "Get source by key" << _key; | ||||||
|  | |||||||
| @ -15,9 +15,7 @@ | |||||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * |  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
|  | #pragma once | ||||||
| #ifndef AWCUSTOMKEYSHELPER_H |  | ||||||
| #define AWCUSTOMKEYSHELPER_H |  | ||||||
|  |  | ||||||
| #include <QObject> | #include <QObject> | ||||||
|  |  | ||||||
| @ -30,7 +28,7 @@ class AWCustomKeysHelper : public QObject, public AWAbstractPairHelper | |||||||
|  |  | ||||||
| public: | public: | ||||||
|     explicit AWCustomKeysHelper(QObject *_parent = nullptr); |     explicit AWCustomKeysHelper(QObject *_parent = nullptr); | ||||||
|     ~AWCustomKeysHelper() override; |     ~AWCustomKeysHelper() override = default; | ||||||
|     // get |     // get | ||||||
|     [[nodiscard]] QString source(const QString &_key) const; |     [[nodiscard]] QString source(const QString &_key) const; | ||||||
|     [[nodiscard]] QStringList sources() const; |     [[nodiscard]] QStringList sources() const; | ||||||
| @ -39,9 +37,4 @@ public: | |||||||
|     void editPairs() override{}; |     void editPairs() override{}; | ||||||
|     QStringList leftKeys() override; |     QStringList leftKeys() override; | ||||||
|     QStringList rightKeys() override; |     QStringList rightKeys() override; | ||||||
|  |  | ||||||
| private: |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| #endif /* AWCUSTOMKEYSHELPER_H */ |  | ||||||
|  | |||||||
| @ -50,7 +50,8 @@ AWDataAggregator::~AWDataAggregator() | |||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; |     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 |     // resize tooltip image | ||||||
|     m_toolTipView->resize(100 * m_counts, 105); |     m_toolTipView->resize(100 * m_counts, 105); | ||||||
|  |  | ||||||
|     requiredKeys.clear(); |     m_requiredKeys.clear(); | ||||||
|     if (m_configuration["cpuTooltip"].toBool()) |     if (m_configuration["cpuTooltip"].toBool()) | ||||||
|         requiredKeys.append("cpuTooltip"); |         m_requiredKeys.append("cpuTooltip"); | ||||||
|     if (m_configuration["cpuclTooltip"].toBool()) |     if (m_configuration["cpuclTooltip"].toBool()) | ||||||
|         requiredKeys.append("cpuclTooltip"); |         m_requiredKeys.append("cpuclTooltip"); | ||||||
|     if (m_configuration["memTooltip"].toBool()) |     if (m_configuration["memTooltip"].toBool()) | ||||||
|         requiredKeys.append("memTooltip"); |         m_requiredKeys.append("memTooltip"); | ||||||
|     if (m_configuration["swapTooltip"].toBool()) |     if (m_configuration["swapTooltip"].toBool()) | ||||||
|         requiredKeys.append("swapTooltip"); |         m_requiredKeys.append("swapTooltip"); | ||||||
|     if (m_configuration["downkbTooltip"].toBool()) |     if (m_configuration["downkbTooltip"].toBool()) | ||||||
|         requiredKeys.append("downkbTooltip"); |         m_requiredKeys.append("downkbTooltip"); | ||||||
|     if (m_configuration["upkbTooltip"].toBool()) |     if (m_configuration["upkbTooltip"].toBool()) | ||||||
|         requiredKeys.append("upkbTooltip"); |         m_requiredKeys.append("upkbTooltip"); | ||||||
|     if (m_configuration["batTooltip"].toBool()) |     if (m_configuration["batTooltip"].toBool()) | ||||||
|         requiredKeys.append("batTooltip"); |         m_requiredKeys.append("batTooltip"); | ||||||
|  |  | ||||||
|     // background |     // background | ||||||
|     m_toolTipScene->setBackgroundBrush(m_configuration["useTooltipBackground"].toBool() |     m_toolTipScene->setBackgroundBrush(m_configuration["useTooltipBackground"].toBool() | ||||||
|                                            ? QBrush(QColor(m_configuration["tooltipBackground"].toString())) |                                            ? QColor(m_configuration["tooltipBackground"].toString()) | ||||||
|                                            : QBrush(Qt::NoBrush)); |                                            : Qt::NoBrush); | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -112,34 +113,42 @@ QPixmap AWDataAggregator::tooltipImage() | |||||||
|     // create image |     // create image | ||||||
|     m_toolTipScene->clear(); |     m_toolTipScene->clear(); | ||||||
|     QPen pen; |     QPen pen; | ||||||
|     bool down = false; |     auto shift = 0.0; | ||||||
|     for (auto &key : requiredKeys) { |  | ||||||
|  |     for (auto i = 0; i < m_requiredKeys.count(); ++i) { | ||||||
|  |         auto key = m_requiredKeys[i]; | ||||||
|  |  | ||||||
|         // create frame |         // create frame | ||||||
|         float normX = 100.0f / static_cast<float>(m_values[key].count()); |         auto normX = 100.0 / static_cast<float>(m_values[key].count()); | ||||||
|         float normY = 100.0f / (1.5f * m_boundaries[key]); |         auto normY = 100.0 / (1.5 * m_boundaries[key]); | ||||||
|         float shift = static_cast<float>(requiredKeys.indexOf(key)) * 100.0f; |  | ||||||
|         if (down) |  | ||||||
|             shift -= 100.0; |  | ||||||
|         // apply pen color |         // apply pen color | ||||||
|         if (key != "batTooltip") |         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 |         // paint data inside frame | ||||||
|         for (int j = 0; j < m_values[key].count() - 1; j++) { |         for (int j = 0; j < m_values[key].count() - 1; j++) { | ||||||
|             // some magic here |             // some magic here | ||||||
|             float x1 = j * normX + shift; |             auto x1 = j * normX + shift; | ||||||
|             float y1 = -std::fabs(m_values[key].at(j)) * normY + 5.0f; |             auto y1 = -std::fabs(m_values[key].at(j)) * normY + 5.0; | ||||||
|             float x2 = (j + 1) * normX + shift; |             auto x2 = (j + 1) * normX + shift; | ||||||
|             float y2 = -std::fabs(m_values[key].at(j + 1)) * normY + 5.0f; |             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 (key == "batTooltip") { | ||||||
|                 if (m_values[key].at(j + 1) > 0) |                 if (m_values[key].at(j + 1) > 0) | ||||||
|                     pen.setColor(QColor(m_configuration["batTooltipColor"].toString())); |                     pen.setColor(QColor(m_configuration["batTooltipColor"].toString())); | ||||||
|                 else |                 else | ||||||
|                     pen.setColor(QColor(m_configuration["batInTooltipColor"].toString())); |                     pen.setColor(QColor(m_configuration["batInTooltipColor"].toString())); | ||||||
|             } |             } | ||||||
|  |  | ||||||
|             m_toolTipScene->addLine(x1, y1, x2, y2, pen); |             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(); |     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" |     qCDebug(LOG_AW) << "Notification source" << _source << "with value" << _value << "called with extremum" | ||||||
|                     << _extremum; |                     << _extremum; | ||||||
| @ -227,25 +236,27 @@ void AWDataAggregator::setData(const QVariantHash &_values) | |||||||
| { | { | ||||||
|     // do not log these arguments |     // do not log these arguments | ||||||
|     // battery update requires info is AC online or not |     // battery update requires info is AC online or not | ||||||
|     setData(_values["ac"].toString() == m_configuration["acOnline"], "batTooltip", _values["bat"].toFloat()); |     setData(_values["ac"].toString() == m_configuration["acOnline"], "batTooltip", _values["bat"].toDouble()); | ||||||
|  |  | ||||||
|     // usual case |     // usual case | ||||||
|     setData("cpuTooltip", _values["cpu"].toFloat(), 90.0); |     setData("cpuTooltip", _values["cpu"].toDouble(), 90.0); | ||||||
|     setData("cpuclTooltip", _values["cpucl"].toFloat()); |     setData("cpuclTooltip", _values["cpucl"].toDouble()); | ||||||
|     setData("memTooltip", _values["mem"].toFloat(), 80.0); |     setData("memTooltip", _values["mem"].toDouble(), 80.0); | ||||||
|     setData("swapTooltip", _values["swap"].toFloat(), 0.0); |     setData("swapTooltip", _values["swap"].toDouble(), 0.0); | ||||||
|     setData("downkbTooltip", _values["downkb"].toFloat()); |     setData("downkbTooltip", _values["downkb"].toDouble()); | ||||||
|     setData("upkbTooltip", _values["upkb"].toFloat()); |     setData("upkbTooltip", _values["upkb"].toDouble()); | ||||||
|  |  | ||||||
|     // additional check for network device |     // additional check for network device | ||||||
|     [this](const QString &value) { |     auto currentNetworkDevice = _values["netdev"].toString(); | ||||||
|         checkValue("netdev", m_currentNetworkDevice, value); |     checkValue("netdev", m_currentNetworkDevice, currentNetworkDevice); | ||||||
|         m_currentNetworkDevice = value; |     m_currentNetworkDevice = currentNetworkDevice; | ||||||
|     }(_values["netdev"].toString()); |  | ||||||
|     // additional check for GPU load |     // 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; |     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); |     m_values[_source].append(_value); | ||||||
|     if (_source == "downkbTooltip") { |     if (_source == "downkbTooltip") { | ||||||
|         QList<float> netValues = m_values["downkbTooltip"] + m_values["upkbTooltip"]; |         // to avoid copying of objects to another list we find max elements in each sequence and compare them | ||||||
|         // to avoid inf value of normY |         auto downMax = m_values["downkbTooltip"].empty() | ||||||
|         netValues << 1.0; |                            ? 1.0 | ||||||
|         m_boundaries["downkbTooltip"] = 1.2f * *std::max_element(netValues.cbegin(), netValues.cend()); |                            : *std::max_element(m_values["downkbTooltip"].cbegin(), m_values["downkbTooltip"].cend()); | ||||||
|         m_boundaries["upkbTooltip"] = m_boundaries["downkbTooltip"]; |         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; |     qCDebug(LOG_AW) << "Do not invert" << _dontInvert << "value" << _value << "for source" << _source; | ||||||
|  |  | ||||||
|  | |||||||
| @ -15,9 +15,7 @@ | |||||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * |  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
|  | #pragma once | ||||||
| #ifndef AWTOOLTIP_H |  | ||||||
| #define AWTOOLTIP_H |  | ||||||
|  |  | ||||||
| #include <QObject> | #include <QObject> | ||||||
| #include <QVariant> | #include <QVariant> | ||||||
| @ -26,7 +24,6 @@ | |||||||
| class QGraphicsScene; | class QGraphicsScene; | ||||||
| class QGraphicsView; | class QGraphicsView; | ||||||
| class QPixmap; | class QPixmap; | ||||||
| class QThreadPool; |  | ||||||
|  |  | ||||||
| class AWDataAggregator : public QObject | class AWDataAggregator : public QObject | ||||||
| { | { | ||||||
| @ -49,25 +46,22 @@ private: | |||||||
|     // ui |     // ui | ||||||
|     QGraphicsScene *m_toolTipScene = nullptr; |     QGraphicsScene *m_toolTipScene = nullptr; | ||||||
|     QGraphicsView *m_toolTipView = 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 checkValue(const QString &_source, const QString &_current, const QString &_received) const; | ||||||
|     void initScene(); |     void initScene(); | ||||||
|     static QString notificationText(const QString &_source, float _value); |     static QString notificationText(const QString &_source, float _value); | ||||||
|     static QString notificationText(const QString &_source, const QString &_value); |     static QString notificationText(const QString &_source, const QString &_value); | ||||||
|     // main method |     // main method | ||||||
|     void setData(const QVariantHash &_values); |     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 |     // different signature for battery device | ||||||
|     void setData(bool _dontInvert, const QString &_source, float _value); |     void setData(bool _dontInvert, const QString &_source, double _value); | ||||||
|     // variables |     // variables | ||||||
|     int m_counts = 0; |     int m_counts = 0; | ||||||
|     QVariantHash m_configuration; |     QVariantHash m_configuration; | ||||||
|     QString m_currentNetworkDevice = "lo"; |     QString m_currentNetworkDevice = "lo"; | ||||||
|     QHash<QString, float> m_boundaries; |     QHash<QString, double> m_boundaries; | ||||||
|     QHash<QString, QList<float>> m_values; |     QHash<QString, QList<double>> m_values; | ||||||
|     bool m_enablePopup = false; |     bool m_enablePopup = false; | ||||||
|     QStringList requiredKeys; |     QStringList m_requiredKeys; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| #endif /* AWTOOLTIP_H */ |  | ||||||
|  | |||||||
| @ -89,6 +89,9 @@ void AWDataEngineAggregator::loadSources() | |||||||
|     auto sensors = response.value(); |     auto sensors = response.value(); | ||||||
|     updateSensors(sensors); |     updateSensors(sensors); | ||||||
|     connectSources(); |     connectSources(); | ||||||
|  |  | ||||||
|  |     for (auto &sensor : m_sensors.keys()) | ||||||
|  |         emit(deviceAdded(sensor)); | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -121,6 +124,9 @@ void AWDataEngineAggregator::sensorAdded(const QString &_sensor) | |||||||
|         m_interface->subscribe({_sensor}).waitForFinished(); |         m_interface->subscribe({_sensor}).waitForFinished(); | ||||||
|         m_subscribed.insert(_sensor); |         m_subscribed.insert(_sensor); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|  |     // notify about new device | ||||||
|  |     emit(deviceAdded(_sensor)); | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -133,7 +139,7 @@ void AWDataEngineAggregator::sensorRemoved(const QString &_sensor) | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| void AWDataEngineAggregator::updateData(KSysGuard::SensorDataList _data) | void AWDataEngineAggregator::updateData(const KSysGuard::SensorDataList &_data) | ||||||
| { | { | ||||||
|     emit(dataUpdated(m_sensors, _data)); |     emit(dataUpdated(m_sensors, _data)); | ||||||
| } | } | ||||||
| @ -141,9 +147,9 @@ void AWDataEngineAggregator::updateData(KSysGuard::SensorDataList _data) | |||||||
|  |  | ||||||
| void AWDataEngineAggregator::updateSensors(const QHash<QString, KSysGuard::SensorInfo> &_sensors) | void AWDataEngineAggregator::updateSensors(const QHash<QString, KSysGuard::SensorInfo> &_sensors) | ||||||
| { | { | ||||||
|     for (auto sensor = _sensors.cbegin(); sensor != _sensors.cend(); ++sensor) { |     for (auto [source, sensor] : _sensors.asKeyValueRange()) { | ||||||
|         if (!isValidSensor(sensor.value())) |         if (!isValidSensor(sensor)) | ||||||
|             continue; |             continue; | ||||||
|         m_sensors.insert(sensor.key(), sensor.value()); |         m_sensors.insert(source, sensor); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  | |||||||
| @ -49,7 +49,7 @@ public slots: | |||||||
|     void dropSource(const QString &_source); |     void dropSource(const QString &_source); | ||||||
|     void sensorAdded(const QString &_sensor); |     void sensorAdded(const QString &_sensor); | ||||||
|     void sensorRemoved(const QString &_sensor); |     void sensorRemoved(const QString &_sensor); | ||||||
|     void updateData(KSysGuard::SensorDataList _data); |     void updateData(const KSysGuard::SensorDataList &_data); | ||||||
|     void updateSensors(const QHash<QString, KSysGuard::SensorInfo> &_sensors); |     void updateSensors(const QHash<QString, KSysGuard::SensorInfo> &_sensors); | ||||||
|  |  | ||||||
| private: | private: | ||||||
|  | |||||||
| @ -52,12 +52,6 @@ AWDataEngineMapper::AWDataEngineMapper(QObject *_parent, AWFormatterHelper *_cus | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| AWDataEngineMapper::~AWDataEngineMapper() |  | ||||||
| { |  | ||||||
|     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| AWKeysAggregator::FormatterType AWDataEngineMapper::formatter(const QString &_key) const | AWKeysAggregator::FormatterType AWDataEngineMapper::formatter(const QString &_key) const | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Get formatter for key" << _key; |     qCDebug(LOG_AW) << "Get formatter for key" << _key; | ||||||
| @ -82,16 +76,18 @@ QStringList AWDataEngineMapper::registerSource(const QString &_source, const KSy | |||||||
|     qCDebug(LOG_AW) << "Source" << _source << "with units" << _units; |     qCDebug(LOG_AW) << "Source" << _source << "with units" << _units; | ||||||
|  |  | ||||||
|     // regular expressions |     // regular expressions | ||||||
|     auto cpuRegExp = QRegularExpression("^cpu/cpu.*/usage$"); |     static auto cpuRegExp = QRegularExpression("^cpu/cpu.*/usage$"); | ||||||
|     auto cpuclRegExp = QRegularExpression("^cpu/cpu.*/frequency$"); |     static auto cpuclRegExp = QRegularExpression("^cpu/cpu.*/frequency$"); | ||||||
|     auto cpuTempRegExp = QRegularExpression("^cpu/cpu.*/temperature$"); |     static auto cpuTempRegExp = QRegularExpression("^cpu/cpu.*/temperature$"); | ||||||
|     auto hddrRegExp = QRegularExpression("^disk/.*/read$"); |     static auto gpuRegExp = QRegularExpression("^gpu/gpu.*/usage$"); | ||||||
|     auto hddwRegExp = QRegularExpression("^disk/.*/write$"); |     static auto gpuTempRegExp = QRegularExpression("^gpu/gpu.*/temperature$"); | ||||||
|     auto mountFillRegExp = QRegularExpression("^disk/.*/usedPercent$"); |     static auto hddrRegExp = QRegularExpression("^disk/.*/read$"); | ||||||
|     auto mountFreeRegExp = QRegularExpression("^disk/.*/free$"); |     static auto hddwRegExp = QRegularExpression("^disk/.*/write$"); | ||||||
|     auto mountUsedRegExp = QRegularExpression("^disk/.*/used$"); |     static auto mountFillRegExp = QRegularExpression("^disk/.*/usedPercent$"); | ||||||
|     auto netRegExp = QRegularExpression("^network/.*/(download|upload)$"); |     static auto mountFreeRegExp = QRegularExpression("^disk/.*/free$"); | ||||||
|     auto netTotalRegExp = QRegularExpression("^network/.*/(totalDownload|totalUpload)$"); |     static auto mountUsedRegExp = QRegularExpression("^disk/.*/used$"); | ||||||
|  |     static auto netRegExp = QRegularExpression("^network/.*/(download|upload)$"); | ||||||
|  |     static auto netTotalRegExp = QRegularExpression("^network/.*/(totalDownload|totalUpload)$"); | ||||||
|  |  | ||||||
|     if (_source == "extsysmon/battery/ac") { |     if (_source == "extsysmon/battery/ac") { | ||||||
|         // AC |         // AC | ||||||
| @ -99,7 +95,7 @@ QStringList AWDataEngineMapper::registerSource(const QString &_source, const KSy | |||||||
|         m_formatter["ac"] = AWKeysAggregator::FormatterType::ACFormat; |         m_formatter["ac"] = AWKeysAggregator::FormatterType::ACFormat; | ||||||
|     } else if (_source.startsWith("extsysmon/battery/")) { |     } else if (_source.startsWith("extsysmon/battery/")) { | ||||||
|         // battery stats |         // battery stats | ||||||
|         QString key = _source; |         auto key = _source; | ||||||
|         key.remove("extsysmon/battery/"); |         key.remove("extsysmon/battery/"); | ||||||
|         m_map.insert(_source, key); |         m_map.insert(_source, key); | ||||||
|         m_formatter[key] = _source.contains("rate") ? AWKeysAggregator::FormatterType::Float |         m_formatter[key] = _source.contains("rate") ? AWKeysAggregator::FormatterType::Float | ||||||
| @ -110,7 +106,7 @@ QStringList AWDataEngineMapper::registerSource(const QString &_source, const KSy | |||||||
|         m_formatter["cpu"] = AWKeysAggregator::FormatterType::Float; |         m_formatter["cpu"] = AWKeysAggregator::FormatterType::Float; | ||||||
|     } else if (_source.contains(cpuRegExp)) { |     } else if (_source.contains(cpuRegExp)) { | ||||||
|         // cpus |         // cpus | ||||||
|         QString key = _source; |         auto key = _source; | ||||||
|         key.remove("cpu/").remove("/usage"); |         key.remove("cpu/").remove("/usage"); | ||||||
|         m_map.insert(_source, key); |         m_map.insert(_source, key); | ||||||
|         m_formatter[key] = AWKeysAggregator::FormatterType::Float; |         m_formatter[key] = AWKeysAggregator::FormatterType::Float; | ||||||
| @ -120,14 +116,14 @@ QStringList AWDataEngineMapper::registerSource(const QString &_source, const KSy | |||||||
|         m_formatter["cpucl"] = AWKeysAggregator::FormatterType::Integer; |         m_formatter["cpucl"] = AWKeysAggregator::FormatterType::Integer; | ||||||
|     } else if (_source.contains(cpuclRegExp)) { |     } else if (_source.contains(cpuclRegExp)) { | ||||||
|         // cpucls |         // cpucls | ||||||
|         QString key = _source; |         auto key = _source; | ||||||
|         key.remove("cpu/cpu").remove("/frequency"); |         key.remove("cpu/cpu").remove("/frequency"); | ||||||
|         key = QString("cpucl%1").arg(key); |         key = QString("cpucl%1").arg(key); | ||||||
|         m_map.insert(_source, key); |         m_map.insert(_source, key); | ||||||
|         m_formatter[key] = AWKeysAggregator::FormatterType::Integer; |         m_formatter[key] = AWKeysAggregator::FormatterType::Integer; | ||||||
|     } else if (_source.startsWith("extsysmon/custom")) { |     } else if (_source.startsWith("extsysmon/custom")) { | ||||||
|         // custom |         // custom | ||||||
|         QString key = _source; |         auto key = _source; | ||||||
|         key.remove("extsysmon/custom/"); |         key.remove("extsysmon/custom/"); | ||||||
|         m_map.insert(_source, key); |         m_map.insert(_source, key); | ||||||
|         m_formatter[key] = AWKeysAggregator::FormatterType::NoFormat; |         m_formatter[key] = AWKeysAggregator::FormatterType::NoFormat; | ||||||
| @ -145,39 +141,55 @@ QStringList AWDataEngineMapper::registerSource(const QString &_source, const KSy | |||||||
|         m_formatter["tdesktops"] = AWKeysAggregator::FormatterType::NoFormat; |         m_formatter["tdesktops"] = AWKeysAggregator::FormatterType::NoFormat; | ||||||
|     } else if (_source.contains(hddrRegExp)) { |     } else if (_source.contains(hddrRegExp)) { | ||||||
|         // read speed |         // read speed | ||||||
|         QString device = _source; |         auto device = _source; | ||||||
|         device.remove("disk/").remove("/read"); |         device.remove("disk/").remove("/read"); | ||||||
|         int index = m_devices["disk"].indexOf(device); |         auto index = m_devices["disk"].indexOf(device); | ||||||
|         if (index > -1) { |         if (index > -1) { | ||||||
|             QString key = QString("hddr%1").arg(index); |             QString key = QString("hddr%1").arg(index); | ||||||
|             m_map.insert(_source, key); |             m_map.insert(_source, key); | ||||||
|             m_formatter[key] = AWKeysAggregator::FormatterType::Integer; |             m_formatter[key] = AWKeysAggregator::FormatterType::MemKBFormat; | ||||||
|         } |         } | ||||||
|     } else if (_source.contains(hddwRegExp)) { |     } else if (_source.contains(hddwRegExp)) { | ||||||
|         // write speed |         // write speed | ||||||
|         QString device = _source; |         auto device = _source; | ||||||
|         device.remove("disk/").remove("/write"); |         device.remove("disk/").remove("/write"); | ||||||
|         int index = m_devices["disk"].indexOf(device); |         auto index = m_devices["disk"].indexOf(device); | ||||||
|         if (index > -1) { |         if (index > -1) { | ||||||
|             QString key = QString("hddw%1").arg(index); |             QString key = QString("hddw%1").arg(index); | ||||||
|             m_map.insert(_source, key); |             m_map.insert(_source, key); | ||||||
|             m_formatter[key] = AWKeysAggregator::FormatterType::Integer; |             m_formatter[key] = AWKeysAggregator::FormatterType::MemKBFormat; | ||||||
|         } |         } | ||||||
|     } else if (_source == "extsysmon/gpuload/load") { |     } else if (_source == "gpu/all/usage") { | ||||||
|         // gpu load |         // gpu load | ||||||
|         m_map.insert(_source, "gpu"); |         m_map.insert(_source, "gpu"); | ||||||
|         m_formatter["gpu"] = AWKeysAggregator::FormatterType::Float; |         m_formatter["gpu"] = AWKeysAggregator::FormatterType::Float; | ||||||
|     } else if (_source == "extsysmon/gputemp/temperature") { |     } else if (_source.contains(gpuRegExp)) { | ||||||
|         // gpu temperature |         // gpus | ||||||
|         m_map.insert(_source, "gputemp"); |         auto device = _source; | ||||||
|         m_formatter["gputemp"] = AWKeysAggregator::FormatterType::Temperature; |         device.remove("gpu/").remove("/usage"); | ||||||
|  |         auto index = m_devices["gpu"].indexOf(device); | ||||||
|  |         if (index > -1) { | ||||||
|  |             auto key = QString("gpu%1").arg(index); | ||||||
|  |             m_map.insert(_source, key); | ||||||
|  |             m_formatter[key] = AWKeysAggregator::FormatterType::Float; | ||||||
|  |         } | ||||||
|  |     } else if (_source.contains(gpuTempRegExp)) { | ||||||
|  |         // gpus temps | ||||||
|  |         auto device = _source; | ||||||
|  |         device.remove("gpu/").remove("/temperature"); | ||||||
|  |         auto index = m_devices["gpu"].indexOf(device); | ||||||
|  |         if (index > -1) { | ||||||
|  |             auto key = QString("gputemp%1").arg(index); | ||||||
|  |             m_map.insert(_source, key); | ||||||
|  |             m_formatter[key] = AWKeysAggregator::FormatterType::Temperature; | ||||||
|  |         } | ||||||
|     } else if (_source.contains(mountFillRegExp)) { |     } else if (_source.contains(mountFillRegExp)) { | ||||||
|         // fill level |         // fill level | ||||||
|         QString device = _source; |         auto device = _source; | ||||||
|         device.remove("disk/").remove("/usedPercent"); |         device.remove("disk/").remove("/usedPercent"); | ||||||
|         int index = m_devices["mount"].indexOf(device); |         auto index = m_devices["mount"].indexOf(device); | ||||||
|         if (index > -1) { |         if (index > -1) { | ||||||
|             QString key = QString("hdd%1").arg(index); |             auto key = QString("hdd%1").arg(index); | ||||||
|             m_map.insert(_source, key); |             m_map.insert(_source, key); | ||||||
|             m_formatter[key] = AWKeysAggregator::FormatterType::Float; |             m_formatter[key] = AWKeysAggregator::FormatterType::Float; | ||||||
|             // additional keys |             // additional keys | ||||||
| @ -186,12 +198,12 @@ QStringList AWDataEngineMapper::registerSource(const QString &_source, const KSy | |||||||
|         } |         } | ||||||
|     } else if (_source.contains(mountFreeRegExp)) { |     } else if (_source.contains(mountFreeRegExp)) { | ||||||
|         // free space |         // free space | ||||||
|         QString device = _source; |         auto device = _source; | ||||||
|         device.remove("disk/").remove("/free"); |         device.remove("disk/").remove("/free"); | ||||||
|         int index = m_devices["mount"].indexOf(device); |         auto index = m_devices["mount"].indexOf(device); | ||||||
|         if (index > -1) { |         if (index > -1) { | ||||||
|             // mb |             // mb | ||||||
|             QString key = QString("hddfreemb%1").arg(index); |             auto key = QString("hddfreemb%1").arg(index); | ||||||
|             m_map.insert(_source, key); |             m_map.insert(_source, key); | ||||||
|             m_formatter[key] = AWKeysAggregator::FormatterType::MemMBFormat; |             m_formatter[key] = AWKeysAggregator::FormatterType::MemMBFormat; | ||||||
|             // gb |             // gb | ||||||
| @ -201,12 +213,12 @@ QStringList AWDataEngineMapper::registerSource(const QString &_source, const KSy | |||||||
|         } |         } | ||||||
|     } else if (_source.contains(mountUsedRegExp)) { |     } else if (_source.contains(mountUsedRegExp)) { | ||||||
|         // used |         // used | ||||||
|         QString device = _source; |         auto device = _source; | ||||||
|         device.remove("disk/").remove("/used"); |         device.remove("disk/").remove("/used"); | ||||||
|         int index = m_devices["mount"].indexOf(device); |         auto index = m_devices["mount"].indexOf(device); | ||||||
|         if (index > -1) { |         if (index > -1) { | ||||||
|             // mb |             // mb | ||||||
|             QString key = QString("hddmb%1").arg(index); |             auto key = QString("hddmb%1").arg(index); | ||||||
|             m_map.insert(_source, key); |             m_map.insert(_source, key); | ||||||
|             m_formatter[key] = AWKeysAggregator::FormatterType::MemMBFormat; |             m_formatter[key] = AWKeysAggregator::FormatterType::MemMBFormat; | ||||||
|             // gb |             // gb | ||||||
| @ -214,21 +226,11 @@ QStringList AWDataEngineMapper::registerSource(const QString &_source, const KSy | |||||||
|             m_map.insert(_source, key); |             m_map.insert(_source, key); | ||||||
|             m_formatter[key] = AWKeysAggregator::FormatterType::MemGBFormat; |             m_formatter[key] = AWKeysAggregator::FormatterType::MemGBFormat; | ||||||
|         } |         } | ||||||
|     } else if (_source.startsWith("extsysmon/hdd/temperature")) { |  | ||||||
|         // hdd temperature |  | ||||||
|         QString device = _source; |  | ||||||
|         device.remove("extsysmon/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/loadaverages/loadaverage")) { |     } else if (_source.startsWith("cpu/loadaverages/loadaverage")) { | ||||||
|         // load average |         // load average | ||||||
|         QString time = _source; |         auto time = _source; | ||||||
|         time.remove("cpu/loadaverages/loadaverage"); |         time.remove("cpu/loadaverages/loadaverage"); | ||||||
|         QString key = QString("la%1").arg(time); |         auto key = QString("la%1").arg(time); | ||||||
|         m_map.insert(_source, key); |         m_map.insert(_source, key); | ||||||
|         m_formatter[key] = AWKeysAggregator::FormatterType::FloatTwoSymbols; |         m_formatter[key] = AWKeysAggregator::FormatterType::FloatTwoSymbols; | ||||||
|     } else if (_source == "memory/physical/application") { |     } else if (_source == "memory/physical/application") { | ||||||
| @ -265,19 +267,19 @@ QStringList AWDataEngineMapper::registerSource(const QString &_source, const KSy | |||||||
|         m_formatter["ssid"] = AWKeysAggregator::FormatterType::NoFormat; |         m_formatter["ssid"] = AWKeysAggregator::FormatterType::NoFormat; | ||||||
|     } else if (_source.startsWith("extsysmon/requests/response")) { |     } else if (_source.startsWith("extsysmon/requests/response")) { | ||||||
|         // network response |         // network response | ||||||
|         QString key = _source; |         auto key = _source; | ||||||
|         key.remove("extsysmon/requests/"); |         key.remove("extsysmon/requests/"); | ||||||
|         m_map.insert(_source, key); |         m_map.insert(_source, key); | ||||||
|         m_formatter[key] = AWKeysAggregator::FormatterType::NoFormat; |         m_formatter[key] = AWKeysAggregator::FormatterType::NoFormat; | ||||||
|     } else if (_source.contains(netRegExp)) { |     } else if (_source.contains(netRegExp)) { | ||||||
|         // network speed |         // network speed | ||||||
|         QString type = _source.contains("download") ? "down" : "up"; |         auto type = _source.endsWith("download") ? "down" : "up"; | ||||||
|         int index = m_devices["net"].indexOf(_source.split('/')[2]); |         auto index = m_devices["net"].indexOf(_source.split('/')[1]); | ||||||
|         if (index > -1) { |         if (index > -1) { | ||||||
|             // kb |             // kb | ||||||
|             QString key = QString("%1kb%2").arg(type).arg(index); |             auto key = QString("%1kb%2").arg(type).arg(index); | ||||||
|             m_map.insert(_source, key); |             m_map.insert(_source, key); | ||||||
|             m_formatter[key] = AWKeysAggregator::FormatterType::Integer; |             m_formatter[key] = AWKeysAggregator::FormatterType::MemKBFormat; | ||||||
|             // smart |             // smart | ||||||
|             key = QString("%1%2").arg(type).arg(index); |             key = QString("%1%2").arg(type).arg(index); | ||||||
|             m_map.insert(_source, key); |             m_map.insert(_source, key); | ||||||
| @ -289,13 +291,13 @@ QStringList AWDataEngineMapper::registerSource(const QString &_source, const KSy | |||||||
|         } |         } | ||||||
|     } else if (_source.contains(netTotalRegExp)) { |     } else if (_source.contains(netTotalRegExp)) { | ||||||
|         // network data total |         // network data total | ||||||
|         QString type = _source.contains("download") ? "down" : "up"; |         auto type = _source.endsWith("Download") ? "down" : "up"; | ||||||
|         int index = m_devices["net"].indexOf(_source.split('/')[2]); |         auto index = m_devices["net"].indexOf(_source.split('/')[1]); | ||||||
|         if (index > -1) { |         if (index > -1) { | ||||||
|             // kb |             // kb | ||||||
|             QString key = QString("%1totkb%2").arg(type).arg(index); |             auto key = QString("%1totkb%2").arg(type).arg(index); | ||||||
|             m_map.insert(_source, key); |             m_map.insert(_source, key); | ||||||
|             m_formatter[key] = AWKeysAggregator::FormatterType::Integer; |             m_formatter[key] = AWKeysAggregator::FormatterType::MemKBFormat; | ||||||
|             // mb |             // mb | ||||||
|             key = QString("%1tot%2").arg(type).arg(index); |             key = QString("%1tot%2").arg(type).arg(index); | ||||||
|             m_map.insert(_source, key); |             m_map.insert(_source, key); | ||||||
| @ -303,13 +305,13 @@ QStringList AWDataEngineMapper::registerSource(const QString &_source, const KSy | |||||||
|         } |         } | ||||||
|     } else if (_source.startsWith("extsysmon/upgrade")) { |     } else if (_source.startsWith("extsysmon/upgrade")) { | ||||||
|         // package manager |         // package manager | ||||||
|         QString key = _source; |         auto key = _source; | ||||||
|         key.remove("extsysmon/upgrade/"); |         key.remove("extsysmon/upgrade/"); | ||||||
|         m_map.insert(_source, key); |         m_map.insert(_source, key); | ||||||
|         m_formatter[key] = AWKeysAggregator::FormatterType::IntegerThree; |         m_formatter[key] = AWKeysAggregator::FormatterType::IntegerThree; | ||||||
|     } else if (_source.startsWith("extsysmon/player")) { |     } else if (_source.startsWith("extsysmon/player")) { | ||||||
|         // player |         // player | ||||||
|         QString key = _source; |         auto key = _source; | ||||||
|         key.remove("extsysmon/player/"); |         key.remove("extsysmon/player/"); | ||||||
|         m_map.insert(_source, key); |         m_map.insert(_source, key); | ||||||
|         m_formatter[key] = AWKeysAggregator::FormatterType::NoFormat; |         m_formatter[key] = AWKeysAggregator::FormatterType::NoFormat; | ||||||
| @ -327,7 +329,7 @@ QStringList AWDataEngineMapper::registerSource(const QString &_source, const KSy | |||||||
|         m_formatter["pstot"] = AWKeysAggregator::FormatterType::NoFormat; |         m_formatter["pstot"] = AWKeysAggregator::FormatterType::NoFormat; | ||||||
|     } else if (_source.startsWith("extsysmon/quotes")) { |     } else if (_source.startsWith("extsysmon/quotes")) { | ||||||
|         // quotes |         // quotes | ||||||
|         QString key = _source; |         auto key = _source; | ||||||
|         key.remove("extsysmon/quotes/"); |         key.remove("extsysmon/quotes/"); | ||||||
|         m_map.insert(_source, key); |         m_map.insert(_source, key); | ||||||
|         m_formatter[key] = AWKeysAggregator::FormatterType::Quotes; |         m_formatter[key] = AWKeysAggregator::FormatterType::Quotes; | ||||||
| @ -355,7 +357,7 @@ QStringList AWDataEngineMapper::registerSource(const QString &_source, const KSy | |||||||
|         if (_units == KSysGuard::UnitInvalid) |         if (_units == KSysGuard::UnitInvalid) | ||||||
|             return QStringList({QString("temp%1").arg(index)}); |             return QStringList({QString("temp%1").arg(index)}); | ||||||
|         if (index > -1) { |         if (index > -1) { | ||||||
|             QString key = QString("temp%1").arg(index); |             auto key = QString("temp%1").arg(index); | ||||||
|             m_map.insert(_source, key); |             m_map.insert(_source, key); | ||||||
|             m_formatter[key] = _units == KSysGuard::UnitCelsius ? AWKeysAggregator::FormatterType::Temperature |             m_formatter[key] = _units == KSysGuard::UnitCelsius ? AWKeysAggregator::FormatterType::Temperature | ||||||
|                                                                 : AWKeysAggregator::FormatterType::Integer; |                                                                 : AWKeysAggregator::FormatterType::Integer; | ||||||
| @ -394,19 +396,19 @@ QStringList AWDataEngineMapper::registerSource(const QString &_source, const KSy | |||||||
|         m_formatter["cuptime"] = AWKeysAggregator::FormatterType::UptimeCustom; |         m_formatter["cuptime"] = AWKeysAggregator::FormatterType::UptimeCustom; | ||||||
|     } else if (_source.startsWith("extsysmon/weather/temperature")) { |     } else if (_source.startsWith("extsysmon/weather/temperature")) { | ||||||
|         // temperature |         // temperature | ||||||
|         QString key = _source; |         auto key = _source; | ||||||
|         key.remove("extsysmon/weather/"); |         key.remove("extsysmon/weather/"); | ||||||
|         m_map.insert(_source, key); |         m_map.insert(_source, key); | ||||||
|         m_formatter[key] = AWKeysAggregator::FormatterType::Temperature; |         m_formatter[key] = AWKeysAggregator::FormatterType::Temperature; | ||||||
|     } else if (_source.startsWith("extsysmon/weather/")) { |     } else if (_source.startsWith("extsysmon/weather/")) { | ||||||
|         // other weather |         // other weather | ||||||
|         QString key = _source; |         auto key = _source; | ||||||
|         key.remove("extsysmon/weather/"); |         key.remove("extsysmon/weather/"); | ||||||
|         m_map.insert(_source, key); |         m_map.insert(_source, key); | ||||||
|         m_formatter[key] = AWKeysAggregator::FormatterType::NoFormat; |         m_formatter[key] = AWKeysAggregator::FormatterType::NoFormat; | ||||||
|     } else if (_source.startsWith("extsysmon/load/load")) { |     } else if (_source.startsWith("extsysmon/load/load")) { | ||||||
|         // load source |         // load source | ||||||
|         QString key = _source; |         auto key = _source; | ||||||
|         key.remove("extsysmon/load/"); |         key.remove("extsysmon/load/"); | ||||||
|         m_map.insert(_source, key); |         m_map.insert(_source, key); | ||||||
|         m_formatter[key] = AWKeysAggregator::FormatterType::Temperature; |         m_formatter[key] = AWKeysAggregator::FormatterType::Temperature; | ||||||
| @ -427,7 +429,7 @@ QStringList AWDataEngineMapper::registerSource(const QString &_source, const KSy | |||||||
|  |  | ||||||
|     // drop key from dictionary if no one user requested key required it |     // drop key from dictionary if no one user requested key required it | ||||||
|     qCInfo(LOG_AW) << "Looking for keys" << foundKeys << "in" << _keys; |     qCInfo(LOG_AW) << "Looking for keys" << foundKeys << "in" << _keys; | ||||||
|     auto required = _keys.isEmpty() || std::any_of(foundKeys.cbegin(), foundKeys.cend(), [&_keys](const QString &key) { |     auto required = _keys.isEmpty() || std::any_of(foundKeys.cbegin(), foundKeys.cend(), [&_keys](auto &key) { | ||||||
|                         return _keys.contains(key); |                         return _keys.contains(key); | ||||||
|                     }); |                     }); | ||||||
|     if (!required) { |     if (!required) { | ||||||
|  | |||||||
| @ -15,9 +15,7 @@ | |||||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * |  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
|  | #pragma once | ||||||
| #ifndef AWDATAENGINEMAPPER_H |  | ||||||
| #define AWDATAENGINEMAPPER_H |  | ||||||
|  |  | ||||||
| #include <ksysguard/formatter/Unit.h> | #include <ksysguard/formatter/Unit.h> | ||||||
|  |  | ||||||
| @ -35,12 +33,12 @@ class AWDataEngineMapper : public QObject | |||||||
|  |  | ||||||
| public: | public: | ||||||
|     explicit AWDataEngineMapper(QObject *_parent = nullptr, AWFormatterHelper *_custom = nullptr); |     explicit AWDataEngineMapper(QObject *_parent = nullptr, AWFormatterHelper *_custom = nullptr); | ||||||
|     ~AWDataEngineMapper() override; |     ~AWDataEngineMapper() override = default; | ||||||
|     // get methods |     // get methods | ||||||
|     [[nodiscard]] AWKeysAggregator::FormatterType formatter(const QString &_key) const; |     [[nodiscard]] AWKeysAggregator::FormatterType formatter(const QString &_key) const; | ||||||
|     [[nodiscard]] QStringList keysFromSource(const QString &_source) const; |     [[nodiscard]] QStringList keysFromSource(const QString &_source) const; | ||||||
|     // set methods |     // set methods | ||||||
|     QStringList registerSource(const QString &_source, const KSysGuard::Unit _units, const QStringList &_keys); |     QStringList registerSource(const QString &_source, KSysGuard::Unit _units, const QStringList &_keys); | ||||||
|     void setDevices(const QHash<QString, QStringList> &_devices); |     void setDevices(const QHash<QString, QStringList> &_devices); | ||||||
|  |  | ||||||
| private: | private: | ||||||
| @ -50,6 +48,3 @@ private: | |||||||
|     QHash<QString, AWKeysAggregator::FormatterType> m_formatter; |     QHash<QString, AWKeysAggregator::FormatterType> m_formatter; | ||||||
|     QMultiHash<QString, QString> m_map; |     QMultiHash<QString, QString> m_map; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| #endif /* AWDATAENGINEMAPPER_H */ |  | ||||||
|  | |||||||
| @ -32,23 +32,16 @@ AWDBusAdaptor::AWDBusAdaptor(AWKeys *_parent) | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| AWDBusAdaptor::~AWDBusAdaptor() |  | ||||||
| { |  | ||||||
|     qCDebug(LOG_DBUS) << __PRETTY_FUNCTION__; |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| QStringList AWDBusAdaptor::ActiveServices() | 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()) { |     if (listServices.arguments().isEmpty()) { | ||||||
|         qCWarning(LOG_DBUS) << "Could not find any DBus service"; |         qCWarning(LOG_DBUS) << "Could not find any DBus service"; | ||||||
|         return {}; |         return {}; | ||||||
|     } |     } | ||||||
|     QStringList arguments = listServices.arguments().first().toStringList(); |     auto arguments = listServices.arguments().first().toStringList(); | ||||||
|  |  | ||||||
|     return std::accumulate(arguments.cbegin(), arguments.cend(), QStringList(), |     return std::accumulate(arguments.cbegin(), arguments.cend(), QStringList(), [](auto source, auto &service) { | ||||||
|                            [](QStringList source, const QString &service) { |  | ||||||
|         if (service.startsWith(AWDBUS_SERVICE)) |         if (service.startsWith(AWDBUS_SERVICE)) | ||||||
|             source.append(service); |             source.append(service); | ||||||
|         return source; |         return source; | ||||||
| @ -103,6 +96,6 @@ void AWDBusAdaptor::SetLogLevel(const QString &what, const QString &level, const | |||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     QString state = enabled ? "true" : "false"; |     auto state = enabled ? "true" : "false"; | ||||||
|     QLoggingCategory::setFilterRules(QString("%1.%2=%3").arg(what).arg(level).arg(state)); |     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/  * |  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
|  | #pragma once | ||||||
| #ifndef AWDBUSADAPTOR_H |  | ||||||
| #define AWDBUSADAPTOR_H |  | ||||||
|  |  | ||||||
| #include <QDBusAbstractAdaptor> | #include <QDBusAbstractAdaptor> | ||||||
|  |  | ||||||
| @ -33,7 +31,7 @@ class AWDBusAdaptor : public QDBusAbstractAdaptor | |||||||
|  |  | ||||||
| public: | public: | ||||||
|     explicit AWDBusAdaptor(AWKeys *_parent = nullptr); |     explicit AWDBusAdaptor(AWKeys *_parent = nullptr); | ||||||
|     ~AWDBusAdaptor() override; |     ~AWDBusAdaptor() override = default; | ||||||
|  |  | ||||||
| public slots: | public slots: | ||||||
|     // get methods |     // get methods | ||||||
| @ -50,6 +48,3 @@ private: | |||||||
|     AWKeys *m_plugin = nullptr; |     AWKeys *m_plugin = nullptr; | ||||||
|     QStringList m_logLevels = {"debug", "info", "warning", "critical"}; |     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/  * |  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
|  | #pragma once | ||||||
| #ifndef AWPLUGIN_H |  | ||||||
| #define AWPLUGIN_H |  | ||||||
|  |  | ||||||
| #include <QQmlExtensionPlugin> | #include <QQmlExtensionPlugin> | ||||||
|  |  | ||||||
| @ -30,6 +28,3 @@ class AWPlugin : public QQmlExtensionPlugin | |||||||
| public: | public: | ||||||
|     void registerTypes(const char *uri) override; |     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__; |     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; | ||||||
|  |  | ||||||
|     setEditable(false, false); |     setEditable(false, false); | ||||||
|     initHelper<AWFormatterHelper>(); |     setHelper(std::make_unique<AWFormatterHelper>()); | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| AWFormatterConfig::~AWFormatterConfig() |  | ||||||
| { |  | ||||||
|     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; |  | ||||||
| } | } | ||||||
|  | |||||||
| @ -15,9 +15,7 @@ | |||||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * |  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
|  | #pragma once | ||||||
| #ifndef AWFORMATTERCONFIG_H |  | ||||||
| #define AWFORMATTERCONFIG_H |  | ||||||
|  |  | ||||||
| #include "awabstractpairconfig.h" | #include "awabstractpairconfig.h" | ||||||
|  |  | ||||||
| @ -28,8 +26,5 @@ class AWFormatterConfig : public AWAbstractPairConfig | |||||||
|  |  | ||||||
| public: | public: | ||||||
|     explicit AWFormatterConfig(QWidget *_parent = nullptr, const QStringList &_keys = QStringList()); |     explicit AWFormatterConfig(QWidget *_parent = nullptr, const QStringList &_keys = QStringList()); | ||||||
|     ~AWFormatterConfig() override; |     ~AWFormatterConfig() override = default; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| #endif /* AWFORMATTERCONFIG_H */ |  | ||||||
|  | |||||||
| @ -33,7 +33,7 @@ | |||||||
| #include "awstringformatter.h" | #include "awstringformatter.h" | ||||||
|  |  | ||||||
|  |  | ||||||
| AWFormatterHelper::AWFormatterHelper(QWidget *_parent) | AWFormatterHelper::AWFormatterHelper(QObject *_parent) | ||||||
|     : AbstractExtItemAggregator(_parent, "formatters") |     : AbstractExtItemAggregator(_parent, "formatters") | ||||||
|     , AWAbstractPairHelper("awesomewidgets/formatters/formatters.ini", "Formatters") |     , AWAbstractPairHelper("awesomewidgets/formatters/formatters.ini", "Formatters") | ||||||
| { | { | ||||||
| @ -58,8 +58,7 @@ void AWFormatterHelper::initItems() | |||||||
|  |  | ||||||
|     // assign internal storage |     // assign internal storage | ||||||
|     m_formatters.clear(); |     m_formatters.clear(); | ||||||
|     for (auto &key : pairs().keys()) { |     for (auto [key, name] : pairs().asKeyValueRange()) { | ||||||
|         auto name = pairs()[key]; |  | ||||||
|         if (!m_formattersClasses.contains(name)) { |         if (!m_formattersClasses.contains(name)) { | ||||||
|             qCWarning(LOG_AW) << "Invalid formatter" << name << "found in" << key; |             qCWarning(LOG_AW) << "Invalid formatter" << name << "found in" << key; | ||||||
|             continue; |             continue; | ||||||
| @ -87,7 +86,7 @@ QStringList AWFormatterHelper::definedFormatters() const | |||||||
| QList<AbstractExtItem *> AWFormatterHelper::items() const | QList<AbstractExtItem *> AWFormatterHelper::items() const | ||||||
| { | { | ||||||
|     QList<AbstractExtItem *> converted; |     QList<AbstractExtItem *> converted; | ||||||
|     for (auto &item : m_formattersClasses.values()) |     for (auto item : m_formattersClasses.values()) | ||||||
|         converted.append(item); |         converted.append(item); | ||||||
|  |  | ||||||
|     return converted; |     return converted; | ||||||
| @ -123,7 +122,7 @@ AWAbstractFormatter::FormatterClass AWFormatterHelper::defineFormatterClass(cons | |||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Define formatter class for" << _stringType; |     qCDebug(LOG_AW) << "Define formatter class for" << _stringType; | ||||||
|  |  | ||||||
|     AWAbstractFormatter::FormatterClass formatter = AWAbstractFormatter::FormatterClass::NoFormat; |     auto formatter = AWAbstractFormatter::FormatterClass::NoFormat; | ||||||
|     if (_stringType == "DateTime") |     if (_stringType == "DateTime") | ||||||
|         formatter = AWAbstractFormatter::FormatterClass::DateTime; |         formatter = AWAbstractFormatter::FormatterClass::DateTime; | ||||||
|     else if (_stringType == "Float") |     else if (_stringType == "Float") | ||||||
| @ -151,17 +150,17 @@ void AWFormatterHelper::initFormatters() | |||||||
|  |  | ||||||
|     auto dirs = directories(); |     auto dirs = directories(); | ||||||
|     for (auto &dir : dirs) { |     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) { |         for (auto &file : files) { | ||||||
|             // check filename |             // check filename | ||||||
|             if (!file.endsWith(".desktop")) |             if (!file.endsWith(".desktop")) | ||||||
|                 continue; |                 continue; | ||||||
|             qCInfo(LOG_AW) << "Found file" << file << "in" << dir; |             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 |             // check if already exists | ||||||
|             auto values = m_formattersClasses.values(); |             auto values = m_formattersClasses.values(); | ||||||
|             if (std::any_of(values.cbegin(), values.cend(), |             if (std::any_of(values.cbegin(), values.cend(), | ||||||
|                             [&filePath](const AWAbstractFormatter *item) { return (item->fileName() == filePath); })) |                             [&filePath](auto item) { return (item->filePath() == filePath); })) | ||||||
|                 continue; |                 continue; | ||||||
|  |  | ||||||
|             auto metadata = readMetadata(filePath); |             auto metadata = readMetadata(filePath); | ||||||
| @ -198,13 +197,14 @@ QPair<QString, AWAbstractFormatter::FormatterClass> AWFormatterHelper::readMetad | |||||||
|     qCDebug(LOG_AW) << "Read initial parameters from" << _filePath; |     qCDebug(LOG_AW) << "Read initial parameters from" << _filePath; | ||||||
|  |  | ||||||
|     QSettings settings(_filePath, QSettings::IniFormat); |     QSettings settings(_filePath, QSettings::IniFormat); | ||||||
|  |  | ||||||
|     settings.beginGroup("Desktop Entry"); |     settings.beginGroup("Desktop Entry"); | ||||||
|     auto name = settings.value("Name", _filePath).toString(); |     auto name = settings.value("Name", _filePath).toString(); | ||||||
|     auto type = settings.value("X-AW-Type", "NoFormat").toString(); |     auto type = settings.value("X-AW-Type", "NoFormat").toString(); | ||||||
|     auto formatter = defineFormatterClass(type); |     auto formatter = defineFormatterClass(type); | ||||||
|     settings.endGroup(); |     settings.endGroup(); | ||||||
|  |  | ||||||
|     return QPair<QString, AWAbstractFormatter::FormatterClass>(name, formatter); |     return {name, formatter}; | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -219,7 +219,7 @@ void AWFormatterHelper::doCreateItem(QListWidget *_widget) | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     qCInfo(LOG_AW) << "Selected type" << select; |     qCInfo(LOG_AW) << "Selected type" << select; | ||||||
|     AWAbstractFormatter::FormatterClass formatter = defineFormatterClass(select); |     auto formatter = defineFormatterClass(select); | ||||||
|     switch (formatter) { |     switch (formatter) { | ||||||
|     case AWAbstractFormatter::FormatterClass::DateTime: |     case AWAbstractFormatter::FormatterClass::DateTime: | ||||||
|         return createItem<AWDateTimeFormatter>(_widget); |         return createItem<AWDateTimeFormatter>(_widget); | ||||||
|  | |||||||
| @ -15,9 +15,7 @@ | |||||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * |  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
|  | #pragma once | ||||||
| #ifndef AWFORMATTERHELPER_H |  | ||||||
| #define AWFORMATTERHELPER_H |  | ||||||
|  |  | ||||||
| #include "abstractextitemaggregator.h" | #include "abstractextitemaggregator.h" | ||||||
| #include "awabstractformatter.h" | #include "awabstractformatter.h" | ||||||
| @ -29,7 +27,7 @@ class AWFormatterHelper : public AbstractExtItemAggregator, public AWAbstractPai | |||||||
|     Q_OBJECT |     Q_OBJECT | ||||||
|  |  | ||||||
| public: | public: | ||||||
|     explicit AWFormatterHelper(QWidget *_parent = nullptr); |     explicit AWFormatterHelper(QObject *_parent = nullptr); | ||||||
|     ~AWFormatterHelper() override; |     ~AWFormatterHelper() override; | ||||||
|     // read-write methods |     // read-write methods | ||||||
|     void initItems() override; |     void initItems() override; | ||||||
| @ -56,6 +54,3 @@ private: | |||||||
|     QHash<QString, AWAbstractFormatter *> m_formatters; |     QHash<QString, AWAbstractFormatter *> m_formatters; | ||||||
|     QHash<QString, AWAbstractFormatter *> m_formattersClasses; |     QHash<QString, AWAbstractFormatter *> m_formattersClasses; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| #endif /* AWFORMATTERHELPER_H */ |  | ||||||
|  | |||||||
| @ -31,7 +31,7 @@ bool AWKeyCache::addKeyToCache(const QString &_type, const QString &_key) | |||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Key" << _key << "with type" << _type; |     qCDebug(LOG_AW) << "Key" << _key << "with type" << _type; | ||||||
|  |  | ||||||
|     QString fileName |     auto fileName | ||||||
|         = QString("%1/awesomewidgets.ndx").arg(QStandardPaths::writableLocation(QStandardPaths::GenericCacheLocation)); |         = QString("%1/awesomewidgets.ndx").arg(QStandardPaths::writableLocation(QStandardPaths::GenericCacheLocation)); | ||||||
|     qCInfo(LOG_AW) << "Cache file" << fileName; |     qCInfo(LOG_AW) << "Cache file" << fileName; | ||||||
|     QSettings cache(fileName, QSettings::IniFormat); |     QSettings cache(fileName, QSettings::IniFormat); | ||||||
| @ -41,21 +41,10 @@ bool AWKeyCache::addKeyToCache(const QString &_type, const QString &_key) | |||||||
|     for (auto &number : cache.allKeys()) |     for (auto &number : cache.allKeys()) | ||||||
|         cachedValues.append(cache.value(number).toString()); |         cachedValues.append(cache.value(number).toString()); | ||||||
|  |  | ||||||
|     if (_type == "hdd") { |     if (_type == "net") { | ||||||
|         QStringList allDevices = QDir("/dev").entryList(QDir::System, QDir::Name); |         auto rawInterfaceList = QNetworkInterface::allInterfaces(); | ||||||
|         QStringList devices = allDevices.filter(QRegularExpression("^[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(); |  | ||||||
|         for (auto &interface : rawInterfaceList) { |         for (auto &interface : rawInterfaceList) { | ||||||
|             QString device = interface.name(); |             auto device = interface.name(); | ||||||
|             if (cachedValues.contains(device)) |             if (cachedValues.contains(device)) | ||||||
|                 continue; |                 continue; | ||||||
|             qCInfo(LOG_AW) << "Found new key" << device << "for type" << _type; |             qCInfo(LOG_AW) << "Found new key" << device << "for type" << _type; | ||||||
| @ -85,10 +74,11 @@ QStringList AWKeyCache::getRequiredKeys(const QStringList &_keys, const QStringL | |||||||
|     used.unite(QSet(_bars.cbegin(), _bars.cend())); |     used.unite(QSet(_bars.cbegin(), _bars.cend())); | ||||||
|     used.unite(QSet(_userKeys.cbegin(), _userKeys.cend())); |     used.unite(QSet(_userKeys.cbegin(), _userKeys.cend())); | ||||||
|     // insert keys from tooltip |     // insert keys from tooltip | ||||||
|     for (auto &key : _tooltip.keys()) { |     for (auto [key, value] : _tooltip.asKeyValueRange()) { | ||||||
|         if ((key.endsWith("Tooltip")) && (_tooltip[key].toBool())) { |         if ((key.endsWith("Tooltip")) && value.toBool()) { | ||||||
|             key.remove("Tooltip"); |             auto local = key; | ||||||
|             used << key; |             local.remove("Tooltip"); | ||||||
|  |             used << local; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @ -98,7 +88,7 @@ QStringList AWKeyCache::getRequiredKeys(const QStringList &_keys, const QStringL | |||||||
|         if (!used.contains(key)) |         if (!used.contains(key)) | ||||||
|             continue; |             continue; | ||||||
|         key.remove("hddtotmb"); |         key.remove("hddtotmb"); | ||||||
|         int index = key.toInt(); |         auto index = key.toInt(); | ||||||
|         used << QString("hddfreemb%1").arg(index) << QString("hddmb%1").arg(index); |         used << QString("hddfreemb%1").arg(index) << QString("hddmb%1").arg(index); | ||||||
|     } |     } | ||||||
|     // hddtotgb* |     // hddtotgb* | ||||||
| @ -106,7 +96,7 @@ QStringList AWKeyCache::getRequiredKeys(const QStringList &_keys, const QStringL | |||||||
|         if (!used.contains(key)) |         if (!used.contains(key)) | ||||||
|             continue; |             continue; | ||||||
|         key.remove("hddtotgb"); |         key.remove("hddtotgb"); | ||||||
|         int index = key.toInt(); |         auto index = key.toInt(); | ||||||
|         used << QString("hddfreegb%1").arg(index) << QString("hddgb%1").arg(index); |         used << QString("hddfreegb%1").arg(index) << QString("hddgb%1").arg(index); | ||||||
|     } |     } | ||||||
|     // mem |     // mem | ||||||
| @ -139,12 +129,12 @@ QStringList AWKeyCache::getRequiredKeys(const QStringList &_keys, const QStringL | |||||||
|     for (auto &key : netKeys) { |     for (auto &key : netKeys) { | ||||||
|         if (!used.contains(key)) |         if (!used.contains(key)) | ||||||
|             continue; |             continue; | ||||||
|         QStringList filt = _allKeys.filter(QRegularExpression(QString("^%1[0-9]{1,}").arg(key))); |         auto filt = _allKeys.filter(QRegularExpression(QString("^%1[0-9]{1,}").arg(key))); | ||||||
|         for (auto &filtered : filt) |         for (auto &filtered : filt) | ||||||
|             used << filtered; |             used << filtered; | ||||||
|     } |     } | ||||||
|     // netdev key |     // 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"; |         used << "netdev"; | ||||||
|  |  | ||||||
|     // HACK append dummy if there are no other keys. This hack is required |     // HACK append dummy if there are no other keys. This hack is required | ||||||
| @ -158,7 +148,7 @@ QStringList AWKeyCache::getRequiredKeys(const QStringList &_keys, const QStringL | |||||||
|  |  | ||||||
| QHash<QString, QStringList> AWKeyCache::loadKeysFromCache() | QHash<QString, QStringList> AWKeyCache::loadKeysFromCache() | ||||||
| { | { | ||||||
|     QString fileName |     auto fileName | ||||||
|         = QString("%1/awesomewidgets.ndx").arg(QStandardPaths::writableLocation(QStandardPaths::GenericCacheLocation)); |         = QString("%1/awesomewidgets.ndx").arg(QStandardPaths::writableLocation(QStandardPaths::GenericCacheLocation)); | ||||||
|     qCInfo(LOG_AW) << "Cache file" << fileName; |     qCInfo(LOG_AW) << "Cache file" << fileName; | ||||||
|     QSettings cache(fileName, QSettings::IniFormat); |     QSettings cache(fileName, QSettings::IniFormat); | ||||||
|  | |||||||
| @ -15,9 +15,7 @@ | |||||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * |  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
|  | #pragma once | ||||||
| #ifndef AWKEYCACHE_H |  | ||||||
| #define AWKEYCACHE_H |  | ||||||
|  |  | ||||||
| #include <QHash> | #include <QHash> | ||||||
| #include <QString> | #include <QString> | ||||||
| @ -31,6 +29,3 @@ QStringList getRequiredKeys(const QStringList &_keys, const QStringList &_bars, | |||||||
|                             const QStringList &_userKeys, const QStringList &_allKeys); |                             const QStringList &_userKeys, const QStringList &_allKeys); | ||||||
| QHash<QString, QStringList> loadKeysFromCache(); | QHash<QString, QStringList> loadKeysFromCache(); | ||||||
| } // namespace AWKeyCache | } // namespace AWKeyCache | ||||||
|  |  | ||||||
|  |  | ||||||
| #endif /* AWKEYCACHE_H */ |  | ||||||
|  | |||||||
| @ -40,18 +40,12 @@ AWKeyOperations::AWKeyOperations(QObject *_parent) | |||||||
|     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; |     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; | ||||||
|  |  | ||||||
|     m_customKeys = new AWCustomKeysHelper(this); |     m_customKeys = new AWCustomKeysHelper(this); | ||||||
|     m_graphicalItems = new ExtItemAggregator<GraphicalItem>(nullptr, "desktops"); |     m_graphicalItems = new ExtItemAggregator<GraphicalItem>(this, "desktops"); | ||||||
|     m_extNetRequest = new ExtItemAggregator<ExtNetworkRequest>(nullptr, "requests"); |     m_extNetRequest = new ExtItemAggregator<ExtNetworkRequest>(this, "requests"); | ||||||
|     m_extQuotes = new ExtItemAggregator<ExtQuotes>(nullptr, "quotes"); |     m_extQuotes = new ExtItemAggregator<ExtQuotes>(this, "quotes"); | ||||||
|     m_extScripts = new ExtItemAggregator<ExtScript>(nullptr, "scripts"); |     m_extScripts = new ExtItemAggregator<ExtScript>(this, "scripts"); | ||||||
|     m_extUpgrade = new ExtItemAggregator<ExtUpgrade>(nullptr, "upgrade"); |     m_extUpgrade = new ExtItemAggregator<ExtUpgrade>(this, "upgrade"); | ||||||
|     m_extWeather = new ExtItemAggregator<ExtWeather>(nullptr, "weather"); |     m_extWeather = new ExtItemAggregator<ExtWeather>(this, "weather"); | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| AWKeyOperations::~AWKeyOperations() |  | ||||||
| { |  | ||||||
|     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -72,7 +66,6 @@ QHash<QString, QStringList> AWKeyOperations::devices() const | |||||||
| void AWKeyOperations::updateCache() | void AWKeyOperations::updateCache() | ||||||
| { | { | ||||||
|     // update network and hdd list |     // update network and hdd list | ||||||
|     addKeyToCache("hdd"); |  | ||||||
|     addKeyToCache("net"); |     addKeyToCache("net"); | ||||||
| } | } | ||||||
|  |  | ||||||
| @ -81,7 +74,7 @@ QStringList AWKeyOperations::dictKeys() const | |||||||
| { | { | ||||||
|     QStringList allKeys; |     QStringList allKeys; | ||||||
|     // weather |     // weather | ||||||
|     for (auto &item : m_extWeather->activeItems()) { |     for (auto item : m_extWeather->activeItems()) { | ||||||
|         allKeys.append(item->tag("weatherId")); |         allKeys.append(item->tag("weatherId")); | ||||||
|         allKeys.append(item->tag("weather")); |         allKeys.append(item->tag("weather")); | ||||||
|         allKeys.append(item->tag("humidity")); |         allKeys.append(item->tag("humidity")); | ||||||
| @ -90,15 +83,20 @@ QStringList AWKeyOperations::dictKeys() const | |||||||
|         allKeys.append(item->tag("timestamp")); |         allKeys.append(item->tag("timestamp")); | ||||||
|     } |     } | ||||||
|     // cpuclock & cpu |     // 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("cpucl%1").arg(i)); | ||||||
|         allKeys.append(QString("cpu%1").arg(i)); |         allKeys.append(QString("cpu%1").arg(i)); | ||||||
|     } |     } | ||||||
|     // temperature |     // temperature | ||||||
|     for (int i = 0; i < m_devices["temp"].count(); i++) |     for (auto i = 0; i < m_devices["temp"].count(); ++i) | ||||||
|         allKeys.append(QString("temp%1").arg(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 |     // 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("hddmb%1").arg(i)); | ||||||
|         allKeys.append(QString("hddgb%1").arg(i)); |         allKeys.append(QString("hddgb%1").arg(i)); | ||||||
|         allKeys.append(QString("hddfreemb%1").arg(i)); |         allKeys.append(QString("hddfreemb%1").arg(i)); | ||||||
| @ -108,15 +106,12 @@ QStringList AWKeyOperations::dictKeys() const | |||||||
|         allKeys.append(QString("hdd%1").arg(i)); |         allKeys.append(QString("hdd%1").arg(i)); | ||||||
|     } |     } | ||||||
|     // hdd speed |     // 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("hddr%1").arg(i)); | ||||||
|         allKeys.append(QString("hddw%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 |     // network | ||||||
|     for (int i = 0; i < m_devices["net"].count(); i++) { |     for (auto i = 0; i < m_devices["net"].count(); ++i) { | ||||||
|         allKeys.append(QString("downunits%1").arg(i)); |         allKeys.append(QString("downunits%1").arg(i)); | ||||||
|         allKeys.append(QString("upunits%1").arg(i)); |         allKeys.append(QString("upunits%1").arg(i)); | ||||||
|         allKeys.append(QString("downtotkb%1").arg(i)); |         allKeys.append(QString("downtotkb%1").arg(i)); | ||||||
| @ -129,10 +124,9 @@ QStringList AWKeyOperations::dictKeys() const | |||||||
|         allKeys.append(QString("up%1").arg(i)); |         allKeys.append(QString("up%1").arg(i)); | ||||||
|     } |     } | ||||||
|     // battery |     // battery | ||||||
|     QStringList allBatteryDevices |     auto allBatteryDevices = QDir("/sys/class/power_supply") | ||||||
|         = QDir("/sys/class/power_supply") |  | ||||||
|                                  .entryList(QStringList({"BAT*"}), QDir::Dirs | QDir::NoDotAndDotDot, QDir::Name); |                                  .entryList(QStringList({"BAT*"}), QDir::Dirs | QDir::NoDotAndDotDot, QDir::Name); | ||||||
|     for (int i = 0; i < allBatteryDevices.count(); i++) { |     for (int i = 0; i < allBatteryDevices.count(); ++i) { | ||||||
|         allKeys.append(QString("bat%1").arg(i)); |         allKeys.append(QString("bat%1").arg(i)); | ||||||
|         allKeys.append(QString("batleft%1").arg(i)); |         allKeys.append(QString("batleft%1").arg(i)); | ||||||
|         allKeys.append(QString("batnow%1").arg(i)); |         allKeys.append(QString("batnow%1").arg(i)); | ||||||
| @ -140,10 +134,10 @@ QStringList AWKeyOperations::dictKeys() const | |||||||
|         allKeys.append(QString("battotal%1").arg(i)); |         allKeys.append(QString("battotal%1").arg(i)); | ||||||
|     } |     } | ||||||
|     // package manager |     // package manager | ||||||
|     for (auto &item : m_extUpgrade->activeItems()) |     for (auto item : m_extUpgrade->activeItems()) | ||||||
|         allKeys.append(item->tag("pkgcount")); |         allKeys.append(item->tag("pkgcount")); | ||||||
|     // quotes |     // quotes | ||||||
|     for (auto &item : m_extQuotes->activeItems()) { |     for (auto item : m_extQuotes->activeItems()) { | ||||||
|         allKeys.append(item->tag("price")); |         allKeys.append(item->tag("price")); | ||||||
|         allKeys.append(item->tag("pricechg")); |         allKeys.append(item->tag("pricechg")); | ||||||
|         allKeys.append(item->tag("percpricechg")); |         allKeys.append(item->tag("percpricechg")); | ||||||
| @ -152,13 +146,13 @@ QStringList AWKeyOperations::dictKeys() const | |||||||
|         allKeys.append(item->tag("percvolumechg")); |         allKeys.append(item->tag("percvolumechg")); | ||||||
|     } |     } | ||||||
|     // custom |     // custom | ||||||
|     for (auto &item : m_extScripts->activeItems()) |     for (auto item : m_extScripts->activeItems()) | ||||||
|         allKeys.append(item->tag("custom")); |         allKeys.append(item->tag("custom")); | ||||||
|     // network requests |     // network requests | ||||||
|     for (auto &item : m_extNetRequest->activeItems()) |     for (auto item : m_extNetRequest->activeItems()) | ||||||
|         allKeys.append(item->tag("response")); |         allKeys.append(item->tag("response")); | ||||||
|     // bars |     // bars | ||||||
|     for (auto &item : m_graphicalItems->activeItems()) |     for (auto item : m_graphicalItems->activeItems()) | ||||||
|         allKeys.append(item->tag("bar")); |         allKeys.append(item->tag("bar")); | ||||||
|     // user defined keys |     // user defined keys | ||||||
|     allKeys.append(m_customKeys->keys()); |     allKeys.append(m_customKeys->keys()); | ||||||
| @ -205,52 +199,58 @@ QString AWKeyOperations::infoByKey(const QString &_key) const | |||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Requested key" << _key; |     qCDebug(LOG_AW) << "Requested key" << _key; | ||||||
|  |  | ||||||
|     QString stripped = _key; |     static auto numberRegExp = QRegularExpression("\\d+"); | ||||||
|     stripped.remove(QRegularExpression("\\d+")); |  | ||||||
|  |     auto stripped = _key; | ||||||
|  |     stripped.remove(numberRegExp); | ||||||
|     QString output; |     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")) { |     if (_key.startsWith("bar")) { | ||||||
|         AbstractExtItem *item = m_graphicalItems->itemByTag(_key, stripped); |         auto item = m_graphicalItems->itemByTag(_key, stripped); | ||||||
|         if (item) |         if (item) | ||||||
|             output = item->uniq(); |             output = item->uniq(); | ||||||
|     } else if (_key.startsWith("custom")) { |     } else if (_key.startsWith("custom")) { | ||||||
|         AbstractExtItem *item = m_extScripts->itemByTag(_key, stripped); |         auto item = m_extScripts->itemByTag(_key, stripped); | ||||||
|         if (item) |         if (item) | ||||||
|             output = item->uniq(); |             output = item->uniq(); | ||||||
|     } else if (_key.contains(QRegularExpression("^hdd[rw]"))) { |     } else if (_key.contains(hddrwRegExp)) { | ||||||
|         QString index = _key; |         auto index = _key; | ||||||
|         index.remove(QRegularExpression("hdd[rw]")); |         index.remove(hddrwRegExp); | ||||||
|         output = m_devices["disk"][index.toInt()]; |         output = m_devices["disk"][index.toInt()]; | ||||||
|     } else if (_key.contains(QRegularExpression("^hdd([0-9]|mb|gb|freemb|freegb|totmb|totgb)"))) { |     } else if (_key.contains(hddMatchRegExp)) { | ||||||
|         QString index = _key; |         auto index = _key; | ||||||
|         index.remove(QRegularExpression("^hdd(|mb|gb|freemb|freegb|totmb|totgb)")); |         index.remove(hddRegExp); | ||||||
|         output = m_devices["mount"][index.toInt()]; |         output = m_devices["mount"][index.toInt()]; | ||||||
|     } else if (_key.startsWith("hddtemp")) { |     } else if (_key.contains(netMatchRegExp)) { | ||||||
|         QString index = _key; |         auto index = _key; | ||||||
|         index.remove("hddtemp"); |         index.remove(netRegExp); | ||||||
|         output = m_devices["hdd"][index.toInt()]; |  | ||||||
|     } else if (_key.contains(QRegularExpression("^(down|up)[0-9]"))) { |  | ||||||
|         QString index = _key; |  | ||||||
|         index.remove(QRegularExpression("^(down|up)")); |  | ||||||
|         output = m_devices["net"][index.toInt()]; |         output = m_devices["net"][index.toInt()]; | ||||||
|     } else if (_key.startsWith("pkgcount")) { |     } else if (_key.startsWith("pkgcount")) { | ||||||
|         AbstractExtItem *item = m_extUpgrade->itemByTag(_key, stripped); |         auto item = m_extUpgrade->itemByTag(_key, stripped); | ||||||
|         if (item) |         if (item) | ||||||
|             output = item->uniq(); |             output = item->uniq(); | ||||||
|     } else if (_key.contains(QRegularExpression("(^|perc)(ask|bid|price)(chg|)"))) { |     } else if (_key.contains(quotesRegExp)) { | ||||||
|         AbstractExtItem *item = m_extQuotes->itemByTag(_key, stripped); |         auto item = m_extQuotes->itemByTag(_key, stripped); | ||||||
|         if (item) |         if (item) | ||||||
|             output = item->uniq(); |             output = item->uniq(); | ||||||
|     } else if (_key.contains(QRegularExpression("(weather|weatherId|humidity|pressure|temperature)"))) { |     } else if (_key.contains(weatherRegExp)) { | ||||||
|         AbstractExtItem *item = m_extWeather->itemByTag(_key, stripped); |         auto item = m_extWeather->itemByTag(_key, stripped); | ||||||
|         if (item) |         if (item) | ||||||
|             output = item->uniq(); |             output = item->uniq(); | ||||||
|     } else if (_key.startsWith("temp")) { |     } else if (_key.startsWith("temp")) { | ||||||
|         QString index = _key; |         auto index = _key; | ||||||
|         index.remove("temp"); |         index.remove("temp"); | ||||||
|         output = m_devices["temp"][index.toInt()]; |         output = m_devices["temp"][index.toInt()]; | ||||||
|     } else if (_key.startsWith("response")) { |     } else if (_key.startsWith("response")) { | ||||||
|         AbstractExtItem *item = m_extNetRequest->itemByTag(_key, stripped); |         auto item = m_extNetRequest->itemByTag(_key, stripped); | ||||||
|         if (item) |         if (item) | ||||||
|             output = item->uniq(); |             output = item->uniq(); | ||||||
|     } else { |     } else { | ||||||
| @ -279,8 +279,10 @@ void AWKeyOperations::editItem(const QString &_type) | |||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Item type" << _type; |     qCDebug(LOG_AW) << "Item type" << _type; | ||||||
|  |  | ||||||
|  |     static auto supportsGraphicalRegExp = QRegularExpression("^(cpu(?!cl).*|gpu$|mem$|swap$|hdd[0-9].*|bat.*)"); | ||||||
|  |  | ||||||
|     if (_type == "graphicalitem") { |     if (_type == "graphicalitem") { | ||||||
|         QStringList keys = dictKeys().filter(QRegularExpression("^(cpu(?!cl).*|gpu$|mem$|swap$|hdd[0-9].*|bat.*)")); |         auto keys = dictKeys().filter(supportsGraphicalRegExp); | ||||||
|         keys.sort(); |         keys.sort(); | ||||||
|         m_graphicalItems->setConfigArgs(keys); |         m_graphicalItems->setConfigArgs(keys); | ||||||
|         return m_graphicalItems->editItems(); |         return m_graphicalItems->editItems(); | ||||||
| @ -302,9 +304,10 @@ void AWKeyOperations::addDevice(const QString &_source) | |||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Source" << _source; |     qCDebug(LOG_AW) << "Source" << _source; | ||||||
|  |  | ||||||
|     auto diskRegexp = QRegularExpression("disk/.*/read"); |     static auto diskRegexp = QRegularExpression("^disk/.*/read$"); | ||||||
|     auto mountRegexp = QRegularExpression("disk/.*/usedPercent"); |     static auto mountRegexp = QRegularExpression("^disk/.*/usedPercent$"); | ||||||
|     auto cpuTempRegExp = QRegularExpression("^cpu/cpu.*/temperature$"); |     static auto cpuTempRegExp = QRegularExpression("^cpu/cpu.*/temperature$"); | ||||||
|  |     static auto gpuRegExp = QRegularExpression("^gpu/gpu.*/usage$"); | ||||||
|  |  | ||||||
|     if (_source.contains(diskRegexp)) { |     if (_source.contains(diskRegexp)) { | ||||||
|         auto device = _source; |         auto device = _source; | ||||||
| @ -317,6 +320,10 @@ void AWKeyOperations::addDevice(const QString &_source) | |||||||
|     } else if (_source.startsWith("lmsensors") || _source.contains(cpuTempRegExp) |     } else if (_source.startsWith("lmsensors") || _source.contains(cpuTempRegExp) | ||||||
|                || _source == "cpu/all/averageTemperature") { |                || _source == "cpu/all/averageTemperature") { | ||||||
|         addKeyToCache("temp", _source); |         addKeyToCache("temp", _source); | ||||||
|  |     } else if (_source.contains(gpuRegExp)) { | ||||||
|  |         auto device = _source; | ||||||
|  |         device.remove("gpu/").remove("/usage"); | ||||||
|  |         addKeyToCache("gpu", device); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| @ -343,7 +350,7 @@ void AWKeyOperations::reinitKeys() | |||||||
|     m_extWeather->initItems(); |     m_extWeather->initItems(); | ||||||
|  |  | ||||||
|     // init |     // init | ||||||
|     QStringList allKeys = dictKeys(); |     auto allKeys = dictKeys(); | ||||||
|  |  | ||||||
|     // apply aw_* functions |     // apply aw_* functions | ||||||
|     m_pattern = AWPatternFunctions::insertAllKeys(m_pattern, allKeys); |     m_pattern = AWPatternFunctions::insertAllKeys(m_pattern, allKeys); | ||||||
|  | |||||||
| @ -15,9 +15,7 @@ | |||||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * |  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
|  | #pragma once | ||||||
| #ifndef AWKEYOPERATIONS_H |  | ||||||
| #define AWKEYOPERATIONS_H |  | ||||||
|  |  | ||||||
| #include <QObject> | #include <QObject> | ||||||
|  |  | ||||||
| @ -39,7 +37,7 @@ class AWKeyOperations : public QObject | |||||||
|  |  | ||||||
| public: | public: | ||||||
|     explicit AWKeyOperations(QObject *_parent = nullptr); |     explicit AWKeyOperations(QObject *_parent = nullptr); | ||||||
|     ~AWKeyOperations() override; |     ~AWKeyOperations() override = default; | ||||||
|     [[nodiscard]] QStringList devices(const QString &_type) const; |     [[nodiscard]] QStringList devices(const QString &_type) const; | ||||||
|     [[nodiscard]] QHash<QString, QStringList> devices() const; |     [[nodiscard]] QHash<QString, QStringList> devices() const; | ||||||
|     void updateCache(); |     void updateCache(); | ||||||
| @ -78,6 +76,3 @@ private: | |||||||
|     QHash<QString, QStringList> m_devices; |     QHash<QString, QStringList> m_devices; | ||||||
|     QString m_pattern; |     QString m_pattern; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| #endif /* AWKEYOPERATIONS_H */ |  | ||||||
|  | |||||||
| @ -19,9 +19,8 @@ | |||||||
|  |  | ||||||
| #include <QDBusConnection> | #include <QDBusConnection> | ||||||
| #include <QDBusError> | #include <QDBusError> | ||||||
| #include <QThread> | #include <QRegularExpression> | ||||||
| #include <QTimer> | #include <QTimer> | ||||||
| #include <QtConcurrent/QtConcurrent> |  | ||||||
|  |  | ||||||
| #include "awdataaggregator.h" | #include "awdataaggregator.h" | ||||||
| #include "awdataengineaggregator.h" | #include "awdataengineaggregator.h" | ||||||
| @ -42,9 +41,6 @@ AWKeys::AWKeys(QObject *_parent) | |||||||
|     for (auto &metadata : AWDebug::getBuildData()) |     for (auto &metadata : AWDebug::getBuildData()) | ||||||
|         qCDebug(LOG_AW) << metadata; |         qCDebug(LOG_AW) << metadata; | ||||||
|  |  | ||||||
|     // thread pool |  | ||||||
|     m_threadPool = new QThreadPool(this); |  | ||||||
|  |  | ||||||
|     m_aggregator = new AWKeysAggregator(this); |     m_aggregator = new AWKeysAggregator(this); | ||||||
|     m_dataAggregator = new AWDataAggregator(this); |     m_dataAggregator = new AWDataAggregator(this); | ||||||
|     m_dataEngineAggregator = new AWDataEngineAggregator(this); |     m_dataEngineAggregator = new AWDataEngineAggregator(this); | ||||||
| @ -91,18 +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 |     qCDebug(LOG_AW) << "Pattern" << _currentPattern << "with interval" << _interval << "with optimization" << _optimize; | ||||||
|                     << "with optimization" << _optimize; |  | ||||||
|  |  | ||||||
|     // init |     // init | ||||||
|     m_optimize = _optimize; |     m_optimize = _optimize; | ||||||
|     m_threadPool->setMaxThreadCount(_limit == 0 ? QThread::idealThreadCount() : _limit); |  | ||||||
|     // child objects |     // child objects | ||||||
|     m_aggregator->initFormatters(); |     m_aggregator->initFormatters(); | ||||||
|     m_keyOperator->setPattern(_currentPattern); |     m_keyOperator->setPattern(_currentPattern); | ||||||
|     m_keyOperator->updateCache(); |     m_keyOperator->updateCache(); | ||||||
|  |     m_dataEngineAggregator->loadSources(); | ||||||
|  |  | ||||||
|     // timer |     // timer | ||||||
|     m_timer->setInterval(_interval); |     m_timer->setInterval(_interval); | ||||||
| @ -152,26 +147,6 @@ QStringList AWKeys::dictKeys(const bool _sorted, const QString &_regexp) const | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| 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; |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| QString AWKeys::infoByKey(const QString &_key) const | QString AWKeys::infoByKey(const QString &_key) const | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Requested info for key" << _key; |     qCDebug(LOG_AW) << "Requested info for key" << _key; | ||||||
| @ -201,12 +176,13 @@ void AWKeys::editItem(const QString &_type) | |||||||
|  |  | ||||||
| void AWKeys::dataUpdated(const QHash<QString, KSysGuard::SensorInfo> &_sensors, const KSysGuard::SensorDataList &_data) | void AWKeys::dataUpdated(const QHash<QString, KSysGuard::SensorInfo> &_sensors, const KSysGuard::SensorDataList &_data) | ||||||
| { | { | ||||||
|     for (auto &single : _data) { |     qCDebug(LOG_AW) << "Update data for" << _data.count() << "items"; | ||||||
|         if (_sensors.contains(single.sensorProperty)) { |  | ||||||
|             setDataBySource(single.sensorProperty, _sensors.value(single.sensorProperty), single); |     for (auto &data : _data) { | ||||||
|         } |         if (!_sensors.contains(data.sensorProperty)) | ||||||
|         // TODO use QtConcurrent::map or something like that |             continue; | ||||||
|         //        QtConcurrent::run(m_threadPool, this, &AWKeys::setDataBySource, "ss", sensor); |         auto sensor = _sensors[data.sensorProperty]; | ||||||
|  |         setDataBySource(data.sensorProperty, sensor, data.payload); | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| @ -222,7 +198,7 @@ void AWKeys::reinitKeys(const QStringList &_currentKeys) | |||||||
|     // generate list of required keys for bars |     // generate list of required keys for bars | ||||||
|     QStringList barKeys; |     QStringList barKeys; | ||||||
|     for (auto &bar : m_foundBars) { |     for (auto &bar : m_foundBars) { | ||||||
|         GraphicalItem *item = m_keyOperator->giByKey(bar); |         auto item = m_keyOperator->giByKey(bar); | ||||||
|         if (item->isCustom()) |         if (item->isCustom()) | ||||||
|             item->setUsedKeys(AWPatternFunctions::findKeys(item->bar(), _currentKeys, false)); |             item->setUsedKeys(AWPatternFunctions::findKeys(item->bar(), _currentKeys, false)); | ||||||
|         else |         else | ||||||
| @ -242,12 +218,10 @@ void AWKeys::reinitKeys(const QStringList &_currentKeys) | |||||||
| void AWKeys::updateTextData() | void AWKeys::updateTextData() | ||||||
| { | { | ||||||
|     // do not do it in parallel to avoid race condition |     // do not do it in parallel to avoid race condition | ||||||
|     m_mutex.lock(); |  | ||||||
|     calculateValues(); |     calculateValues(); | ||||||
|     auto text = parsePattern(m_keyOperator->pattern()); |     auto text = parsePattern(m_keyOperator->pattern()); | ||||||
|     // update tooltip values under lock |     // update tooltip values under lock | ||||||
|     m_dataAggregator->dataUpdate(m_values); |     m_dataAggregator->dataUpdate(m_values); | ||||||
|     m_mutex.unlock(); |  | ||||||
|  |  | ||||||
|     emit(needTextToBeUpdated(text)); |     emit(needTextToBeUpdated(text)); | ||||||
| } | } | ||||||
| @ -258,9 +232,9 @@ void AWKeys::updateTextData() | |||||||
| void AWKeys::calculateValues() | void AWKeys::calculateValues() | ||||||
| { | { | ||||||
|     // hddtot* |     // hddtot* | ||||||
|     QStringList mountDevices = m_keyOperator->devices("mount"); |     auto mountDevices = m_keyOperator->devices("mount"); | ||||||
|     for (auto &device : mountDevices) { |     for (auto &device : mountDevices) { | ||||||
|         int index = mountDevices.indexOf(device); |         auto index = mountDevices.indexOf(device); | ||||||
|         m_values[QString("hddtotmb%1").arg(index)] = m_values[QString("hddfreemb%1").arg(index)].toDouble() |         m_values[QString("hddtotmb%1").arg(index)] = m_values[QString("hddfreemb%1").arg(index)].toDouble() | ||||||
|                                                      + m_values[QString("hddmb%1").arg(index)].toDouble(); |                                                      + m_values[QString("hddmb%1").arg(index)].toDouble(); | ||||||
|         m_values[QString("hddtotgb%1").arg(index)] = m_values[QString("hddfreegb%1").arg(index)].toDouble() |         m_values[QString("hddtotgb%1").arg(index)] = m_values[QString("hddfreegb%1").arg(index)].toDouble() | ||||||
| @ -271,10 +245,10 @@ void AWKeys::calculateValues() | |||||||
|     m_values["memtotmb"] = m_values["memusedmb"].toLongLong() + m_values["memfreemb"].toLongLong(); |     m_values["memtotmb"] = m_values["memusedmb"].toLongLong() + m_values["memfreemb"].toLongLong(); | ||||||
|     m_values["memtotgb"] = m_values["memusedgb"].toDouble() + m_values["memfreegb"].toDouble(); |     m_values["memtotgb"] = m_values["memusedgb"].toDouble() + m_values["memfreegb"].toDouble(); | ||||||
|     // mem |     // mem | ||||||
|     m_values["mem"] = 100.0f * m_values["memmb"].toDouble() / m_values["memtotmb"].toDouble(); |     m_values["mem"] = 100.0 * m_values["memmb"].toDouble() / m_values["memtotmb"].toDouble(); | ||||||
|  |  | ||||||
|     // up, down, upkb, downkb, upunits, downunits |     // up, down, upkb, downkb, upunits, downunits | ||||||
|     int netIndex = m_keyOperator->devices("net").indexOf(m_values["netdev"].toString()); |     auto netIndex = m_keyOperator->devices("net").indexOf(m_values["netdev"].toString()); | ||||||
|     m_values["down"] = m_values[QString("down%1").arg(netIndex)]; |     m_values["down"] = m_values[QString("down%1").arg(netIndex)]; | ||||||
|     m_values["downkb"] = m_values[QString("downkb%1").arg(netIndex)]; |     m_values["downkb"] = m_values[QString("downkb%1").arg(netIndex)]; | ||||||
|     m_values["downtot"] = m_values[QString("downtot%1").arg(netIndex)]; |     m_values["downtot"] = m_values[QString("downtot%1").arg(netIndex)]; | ||||||
| @ -290,7 +264,7 @@ void AWKeys::calculateValues() | |||||||
|     m_values["swaptotmb"] = m_values["swapmb"].toLongLong() + m_values["swapfreemb"].toLongLong(); |     m_values["swaptotmb"] = m_values["swapmb"].toLongLong() + m_values["swapfreemb"].toLongLong(); | ||||||
|     m_values["swaptotgb"] = m_values["swapgb"].toDouble() + m_values["swapfreegb"].toDouble(); |     m_values["swaptotgb"] = m_values["swapgb"].toDouble() + m_values["swapfreegb"].toDouble(); | ||||||
|     // swap |     // swap | ||||||
|     m_values["swap"] = 100.0f * m_values["swapmb"].toDouble() / m_values["swaptotmb"].toDouble(); |     m_values["swap"] = 100.0 * m_values["swapmb"].toDouble() / m_values["swaptotmb"].toDouble(); | ||||||
|  |  | ||||||
|     // user defined keys |     // user defined keys | ||||||
|     for (auto &key : m_keyOperator->userKeys()) |     for (auto &key : m_keyOperator->userKeys()) | ||||||
| @ -308,7 +282,7 @@ void AWKeys::createDBusInterface() | |||||||
|     auto id = reinterpret_cast<qlonglong>(this); |     auto id = reinterpret_cast<qlonglong>(this); | ||||||
|  |  | ||||||
|     // create session |     // create session | ||||||
|     QDBusConnection instanceBus = QDBusConnection::sessionBus(); |     auto instanceBus = QDBusConnection::sessionBus(); | ||||||
|     // HACK we are going to use different services because it binds to |     // HACK we are going to use different services because it binds to | ||||||
|     // application |     // application | ||||||
|     if (instanceBus.registerService(QString("%1.i%2").arg(AWDBUS_SERVICE).arg(id))) { |     if (instanceBus.registerService(QString("%1.i%2").arg(AWDBUS_SERVICE).arg(id))) { | ||||||
| @ -319,7 +293,7 @@ void AWKeys::createDBusInterface() | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     // and same instance but for id independent service |     // and same instance but for id independent service | ||||||
|     QDBusConnection commonBus = QDBusConnection::sessionBus(); |     auto commonBus = QDBusConnection::sessionBus(); | ||||||
|     if (commonBus.registerService(AWDBUS_SERVICE)) |     if (commonBus.registerService(AWDBUS_SERVICE)) | ||||||
|         commonBus.registerObject(AWDBUS_PATH, new AWDBusAdaptor(this), QDBusConnection::ExportAllContents); |         commonBus.registerObject(AWDBUS_PATH, new AWDBusAdaptor(this), QDBusConnection::ExportAllContents); | ||||||
| } | } | ||||||
| @ -340,8 +314,8 @@ QString AWKeys::parsePattern(QString _pattern) const | |||||||
|  |  | ||||||
|     // bars |     // bars | ||||||
|     for (auto &bar : m_foundBars) { |     for (auto &bar : m_foundBars) { | ||||||
|         GraphicalItem *item = m_keyOperator->giByKey(bar); |         auto item = m_keyOperator->giByKey(bar); | ||||||
|         QString image = item->isCustom() ? item->image( |         auto image = item->isCustom() ? item->image( | ||||||
|                          AWPatternFunctions::expandLambdas(item->bar(), m_aggregator, m_values, item->usedKeys())) |                          AWPatternFunctions::expandLambdas(item->bar(), m_aggregator, m_values, item->usedKeys())) | ||||||
|                                       : item->image(m_values[item->bar()]); |                                       : item->image(m_values[item->bar()]); | ||||||
|         _pattern.replace(QString("$%1").arg(bar), image); |         _pattern.replace(QString("$%1").arg(bar), image); | ||||||
| @ -356,10 +330,9 @@ QString AWKeys::parsePattern(QString _pattern) const | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| void AWKeys::setDataBySource(const QString &_source, const KSysGuard::SensorInfo &_sensor, | void AWKeys::setDataBySource(const QString &_source, const KSysGuard::SensorInfo &_sensor, const QVariant &_value) | ||||||
|                              const KSysGuard::SensorData &_data) |  | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Source" << _source << _sensor.name << "with data" << _data.payload; |     qCDebug(LOG_AW) << "Source" << _source << _sensor.name << "with data" << _value; | ||||||
|  |  | ||||||
|     // first list init |     // first list init | ||||||
|     auto tags = m_aggregator->keysFromSource(_source); |     auto tags = m_aggregator->keysFromSource(_source); | ||||||
| @ -372,7 +345,5 @@ void AWKeys::setDataBySource(const QString &_source, const KSysGuard::SensorInfo | |||||||
|         return emit(dropSourceFromDataengine(_source)); |         return emit(dropSourceFromDataengine(_source)); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     m_mutex.lock(); |     std::for_each(tags.cbegin(), tags.cend(), [this, _value](const QString &tag) { m_values[tag] = _value; }); | ||||||
|     std::for_each(tags.cbegin(), tags.cend(), [this, &_data](const QString &tag) { m_values[tag] = _data.payload; }); |  | ||||||
|     m_mutex.unlock(); |  | ||||||
| } | } | ||||||
|  | |||||||
| @ -15,11 +15,8 @@ | |||||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * |  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
|  | #pragma once | ||||||
|  |  | ||||||
| #ifndef AWKEYS_H |  | ||||||
| #define AWKEYS_H |  | ||||||
|  |  | ||||||
| #include <QMutex> |  | ||||||
| #include <QObject> | #include <QObject> | ||||||
|  |  | ||||||
| #include <ksysguard/systemstats/SensorInfo.h> | #include <ksysguard/systemstats/SensorInfo.h> | ||||||
| @ -29,7 +26,6 @@ class AWDataAggregator; | |||||||
| class AWDataEngineAggregator; | class AWDataEngineAggregator; | ||||||
| class AWKeyOperations; | class AWKeyOperations; | ||||||
| class AWKeysAggregator; | class AWKeysAggregator; | ||||||
| class QThreadPool; |  | ||||||
| class QTimer; | class QTimer; | ||||||
|  |  | ||||||
| class AWKeys : public QObject | class AWKeys : public QObject | ||||||
| @ -40,7 +36,7 @@ public: | |||||||
|     explicit AWKeys(QObject *_parent = nullptr); |     explicit AWKeys(QObject *_parent = nullptr); | ||||||
|     ~AWKeys() override; |     ~AWKeys() override; | ||||||
|     Q_INVOKABLE void initDataAggregator(const QVariantMap &_tooltipParams); |     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 setAggregatorProperty(const QString &_key, const QVariant &_value); | ||||||
|     Q_INVOKABLE void setWrapNewLines(bool _wrap); |     Q_INVOKABLE void setWrapNewLines(bool _wrap); | ||||||
|     // additional method to force load keys from Qml UI. Used in some |     // additional method to force load keys from Qml UI. Used in some | ||||||
| @ -48,22 +44,19 @@ public: | |||||||
|     Q_INVOKABLE void updateCache(); |     Q_INVOKABLE void updateCache(); | ||||||
|     // keys |     // keys | ||||||
|     Q_INVOKABLE [[nodiscard]] QStringList dictKeys(bool _sorted = false, const QString &_regexp = "") const; |     Q_INVOKABLE [[nodiscard]] QStringList dictKeys(bool _sorted = false, const QString &_regexp = "") const; | ||||||
|     Q_INVOKABLE [[nodiscard]] QVariantList getHddDevices() const; |  | ||||||
|     // values |     // values | ||||||
|     Q_INVOKABLE [[nodiscard]] QString infoByKey(const QString &_key) const; |     Q_INVOKABLE [[nodiscard]] QString infoByKey(const QString &_key) const; | ||||||
|     Q_INVOKABLE [[nodiscard]] QString valueByKey(const QString &_key) const; |     Q_INVOKABLE [[nodiscard]] QString valueByKey(const QString &_key) const; | ||||||
|     // configuration |     // configuration | ||||||
|     Q_INVOKABLE void editItem(const QString &_type); |     Q_INVOKABLE void editItem(const QString &_type); | ||||||
|  |  | ||||||
| public slots: |  | ||||||
|     void dataUpdated(const QHash<QString, KSysGuard::SensorInfo> &_sensors, const KSysGuard::SensorDataList &_data); |  | ||||||
|  |  | ||||||
| signals: | signals: | ||||||
|     void dropSourceFromDataengine(const QString &_source); |     void dropSourceFromDataengine(const QString &_source); | ||||||
|     void needTextToBeUpdated(const QString &_newText) const; |     void needTextToBeUpdated(const QString &_newText) const; | ||||||
|     void needToolTipToBeUpdated(const QString &_newText) const; |     void needToolTipToBeUpdated(const QString &_newText) const; | ||||||
|  |  | ||||||
| private slots: | private slots: | ||||||
|  |     void dataUpdated(const QHash<QString, KSysGuard::SensorInfo> &_sensors, const KSysGuard::SensorDataList &_data); | ||||||
|     void reinitKeys(const QStringList &_currentKeys); |     void reinitKeys(const QStringList &_currentKeys); | ||||||
|     void updateTextData(); |     void updateTextData(); | ||||||
|  |  | ||||||
| @ -72,8 +65,7 @@ private: | |||||||
|     void calculateValues(); |     void calculateValues(); | ||||||
|     void createDBusInterface(); |     void createDBusInterface(); | ||||||
|     [[nodiscard]] QString parsePattern(QString _pattern) const; |     [[nodiscard]] QString parsePattern(QString _pattern) const; | ||||||
|     void setDataBySource(const QString &_source, const KSysGuard::SensorInfo &_sensor, |     void setDataBySource(const QString &_source, const KSysGuard::SensorInfo &_sensor, const QVariant &_value); | ||||||
|                          const KSysGuard::SensorData &_data); |  | ||||||
|     // objects |     // objects | ||||||
|     AWDataAggregator *m_dataAggregator = nullptr; |     AWDataAggregator *m_dataAggregator = nullptr; | ||||||
|     AWDataEngineAggregator *m_dataEngineAggregator = nullptr; |     AWDataEngineAggregator *m_dataEngineAggregator = nullptr; | ||||||
| @ -86,10 +78,4 @@ private: | |||||||
|     QVariantHash m_values; |     QVariantHash m_values; | ||||||
|     bool m_optimize = false; |     bool m_optimize = false; | ||||||
|     bool m_wrapNewLines = false; |     bool m_wrapNewLines = false; | ||||||
|     // multithread features |  | ||||||
|     QThreadPool *m_threadPool = nullptr; |  | ||||||
|     QMutex m_mutex; |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| #endif /* AWKEYS_H */ |  | ||||||
|  | |||||||
| @ -33,7 +33,7 @@ AWKeysAggregator::AWKeysAggregator(QObject *_parent) | |||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; |     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; | ||||||
|  |  | ||||||
|     m_customFormatters = new AWFormatterHelper(nullptr); |     m_customFormatters = new AWFormatterHelper(this); | ||||||
|     m_mapper = new AWDataEngineMapper(this, m_customFormatters); |     m_mapper = new AWDataEngineMapper(this, m_customFormatters); | ||||||
|  |  | ||||||
|     // sort time keys |     // sort time keys | ||||||
| @ -43,12 +43,6 @@ AWKeysAggregator::AWKeysAggregator(QObject *_parent) | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| AWKeysAggregator::~AWKeysAggregator() |  | ||||||
| { |  | ||||||
|     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| void AWKeysAggregator::initFormatters() | void AWKeysAggregator::initFormatters() | ||||||
| { | { | ||||||
|     m_customFormatters->initItems(); |     m_customFormatters->initItems(); | ||||||
| @ -85,21 +79,24 @@ QString AWKeysAggregator::formatter(const QVariant &_data, const QString &_key, | |||||||
|         output = _data.toBool() ? m_acOnline : m_acOffline; |         output = _data.toBool() ? m_acOnline : m_acOffline; | ||||||
|         break; |         break; | ||||||
|     case FormatterType::MemGBFormat: |     case FormatterType::MemGBFormat: | ||||||
|         output = QString("%1").arg(_data.toDouble() / (1024.0 * 1024.0), 5, 'f', 1); |         output = QString("%1").arg(_data.toDouble() / GBinBytes, 5, 'f', 1); | ||||||
|         break; |         break; | ||||||
|     case FormatterType::MemMBFormat: |     case FormatterType::MemMBFormat: | ||||||
|         output = QString("%1").arg(_data.toDouble() / 1024.0, 5, 'f', 0); |         output = QString("%1").arg(_data.toDouble() / MBinBytes, 5, 'f', 0); | ||||||
|  |         break; | ||||||
|  |     case FormatterType::MemKBFormat: | ||||||
|  |         output = QString("%1").arg(_data.toDouble() / KBinBytes, 5, 'f', 0); | ||||||
|         break; |         break; | ||||||
|     case FormatterType::NetSmartFormat: |     case FormatterType::NetSmartFormat: | ||||||
|         output = [](const float value) { |         output = [](const double value) { | ||||||
|             if (value > 1024.0) |             if (value > MBinBytes) | ||||||
|                 return QString("%1").arg(value / 1024.0, 4, 'f', 1); |                 return QString("%1").arg(value / MBinBytes, 4, 'f', 1); | ||||||
|             else |             else | ||||||
|                 return QString("%1").arg(value, 4, 'f', 0); |                 return QString("%1").arg(value / KBinBytes, 4, 'f', 0); | ||||||
|         }(_data.toDouble()); |         }(_data.toDouble()); | ||||||
|         break; |         break; | ||||||
|     case FormatterType::NetSmartUnits: |     case FormatterType::NetSmartUnits: | ||||||
|         if (_data.toDouble() > 1024.0) |         if (_data.toDouble() > MBinBytes) | ||||||
|             output = m_translate ? i18n("MB/s") : "MB/s"; |             output = m_translate ? i18n("MB/s") : "MB/s"; | ||||||
|         else |         else | ||||||
|             output = m_translate ? i18n("KB/s") : "KB/s"; |             output = m_translate ? i18n("KB/s") : "KB/s"; | ||||||
| @ -137,17 +134,19 @@ QString AWKeysAggregator::formatter(const QVariant &_data, const QString &_key, | |||||||
|     case FormatterType::Uptime: |     case FormatterType::Uptime: | ||||||
|     case FormatterType::UptimeCustom: |     case FormatterType::UptimeCustom: | ||||||
|         output = |         output = | ||||||
|             [](QString source, const int uptime) { |             [](auto source, auto uptime) { | ||||||
|                 int seconds = uptime - uptime % 60; |                 auto seconds = uptime - uptime % 60; | ||||||
|                 int minutes = seconds / 60 % 60; |                 auto minutes = seconds / 60 % 60; | ||||||
|                 int hours = ((seconds / 60) - minutes) / 60 % 24; |                 auto hours = ((seconds / 60) - minutes) / 60 % 24; | ||||||
|                 int days = (((seconds / 60) - minutes) / 60 - hours) / 24; |                 auto days = (((seconds / 60) - minutes) / 60 - hours) / 24; | ||||||
|  |  | ||||||
|                 source.replace("$dd", QString("%1").arg(days, 3, 10, QChar('0'))); |                 source.replace("$dd", QString("%1").arg(days, 3, 10, QChar('0'))); | ||||||
|                 source.replace("$d", QString("%1").arg(days)); |                 source.replace("$d", QString("%1").arg(days)); | ||||||
|                 source.replace("$hh", QString("%1").arg(hours, 2, 10, QChar('0'))); |                 source.replace("$hh", QString("%1").arg(hours, 2, 10, QChar('0'))); | ||||||
|                 source.replace("$h", QString("%1").arg(hours)); |                 source.replace("$h", QString("%1").arg(hours)); | ||||||
|                 source.replace("$mm", QString("%1").arg(minutes, 2, 10, QChar('0'))); |                 source.replace("$mm", QString("%1").arg(minutes, 2, 10, QChar('0'))); | ||||||
|                 source.replace("$m", QString("%1").arg(minutes)); |                 source.replace("$m", QString("%1").arg(minutes)); | ||||||
|  |  | ||||||
|                 return source; |                 return source; | ||||||
|             }(m_mapper->formatter(_key) == FormatterType::Uptime ? "$ddd$hhh$mmm" : m_customUptime, |             }(m_mapper->formatter(_key) == FormatterType::Uptime ? "$ddd$hhh$mmm" : m_customUptime, | ||||||
|               static_cast<int>(_data.toDouble())); |               static_cast<int>(_data.toDouble())); | ||||||
| @ -234,7 +233,7 @@ void AWKeysAggregator::setTranslate(const bool _translate) | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| QStringList AWKeysAggregator::registerSource(const QString &_source, const KSysGuard::Unit &_units, | QStringList AWKeysAggregator::registerSource(const QString &_source, const KSysGuard::Unit _units, | ||||||
|                                              const QStringList &_keys) |                                              const QStringList &_keys) | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Source" << _source << "with units" << _units; |     qCDebug(LOG_AW) << "Source" << _source << "with units" << _units; | ||||||
| @ -243,24 +242,24 @@ QStringList AWKeysAggregator::registerSource(const QString &_source, const KSysG | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| float AWKeysAggregator::temperature(const float temp) const | double AWKeysAggregator::temperature(const double temp) const | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Temperature value" << temp; |     qCDebug(LOG_AW) << "Temperature value" << temp; | ||||||
|  |  | ||||||
|     float converted = temp; |     auto converted = temp; | ||||||
|     if (m_tempUnits == "Celsius") { |     if (m_tempUnits == "Celsius") { | ||||||
|     } else if (m_tempUnits == "Fahrenheit") { |     } else if (m_tempUnits == "Fahrenheit") { | ||||||
|         converted = temp * 9.0f / 5.0f + 32.0f; |         converted = temp * 9.0f / 5.0 + 32.0; | ||||||
|     } else if (m_tempUnits == "Kelvin") { |     } else if (m_tempUnits == "Kelvin") { | ||||||
|         converted = temp + 273.15f; |         converted = temp + 273.15; | ||||||
|     } else if (m_tempUnits == "Reaumur") { |     } else if (m_tempUnits == "Reaumur") { | ||||||
|         converted = temp * 0.8f; |         converted = temp * 0.8; | ||||||
|     } else if (m_tempUnits == "cm^-1") { |     } else if (m_tempUnits == "cm^-1") { | ||||||
|         converted = (temp + 273.15f) * 0.695f; |         converted = (temp + 273.15) * 0.695; | ||||||
|     } else if (m_tempUnits == "kJ/mol") { |     } else if (m_tempUnits == "kJ/mol") { | ||||||
|         converted = (temp + 273.15f) * 8.31f; |         converted = (temp + 273.15) * 8.31; | ||||||
|     } else if (m_tempUnits == "kcal/mol") { |     } else if (m_tempUnits == "kcal/mol") { | ||||||
|         converted = (temp + 273.15f) * 1.98f; |         converted = (temp + 273.15) * 1.98; | ||||||
|     } else { |     } else { | ||||||
|         qCWarning(LOG_AW) << "Invalid units" << m_tempUnits; |         qCWarning(LOG_AW) << "Invalid units" << m_tempUnits; | ||||||
|     } |     } | ||||||
|  | |||||||
| @ -15,9 +15,7 @@ | |||||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * |  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
|  | #pragma once | ||||||
| #ifndef AWKEYSAGGREGATOR_H |  | ||||||
| #define AWKEYSAGGREGATOR_H |  | ||||||
|  |  | ||||||
| #include <ksysguard/formatter/Unit.h> | #include <ksysguard/formatter/Unit.h> | ||||||
|  |  | ||||||
| @ -53,6 +51,7 @@ public: | |||||||
|         ACFormat, |         ACFormat, | ||||||
|         MemGBFormat, |         MemGBFormat, | ||||||
|         MemMBFormat, |         MemMBFormat, | ||||||
|  |         MemKBFormat, | ||||||
|         NetSmartFormat, |         NetSmartFormat, | ||||||
|         NetSmartUnits, |         NetSmartUnits, | ||||||
|         Quotes, |         Quotes, | ||||||
| @ -67,8 +66,12 @@ public: | |||||||
|         UptimeCustom |         UptimeCustom | ||||||
|     }; |     }; | ||||||
|  |  | ||||||
|  |     static constexpr double KBinBytes = 1024.0; | ||||||
|  |     static constexpr double MBinBytes = 1024.0 * KBinBytes; | ||||||
|  |     static constexpr double GBinBytes = 1024.0 * MBinBytes; | ||||||
|  |  | ||||||
|     explicit AWKeysAggregator(QObject *_parent = nullptr); |     explicit AWKeysAggregator(QObject *_parent = nullptr); | ||||||
|     ~AWKeysAggregator() override; |     ~AWKeysAggregator() override = default; | ||||||
|     void initFormatters(); |     void initFormatters(); | ||||||
|     // get methods |     // get methods | ||||||
|     [[nodiscard]] QString formatter(const QVariant &_data, const QString &_key, bool replaceSpace) const; |     [[nodiscard]] QString formatter(const QVariant &_data, const QString &_key, bool replaceSpace) const; | ||||||
| @ -83,10 +86,10 @@ public: | |||||||
|     void setTranslate(bool _translate); |     void setTranslate(bool _translate); | ||||||
|  |  | ||||||
| public slots: | public slots: | ||||||
|     QStringList registerSource(const QString &_source, const KSysGuard::Unit &_units, const QStringList &_keys); |     QStringList registerSource(const QString &_source, KSysGuard::Unit _units, const QStringList &_keys); | ||||||
|  |  | ||||||
| private: | private: | ||||||
|     [[nodiscard]] float temperature(float temp) const; |     [[nodiscard]] double temperature(double temp) const; | ||||||
|     AWFormatterHelper *m_customFormatters = nullptr; |     AWFormatterHelper *m_customFormatters = nullptr; | ||||||
|     AWDataEngineMapper *m_mapper = nullptr; |     AWDataEngineMapper *m_mapper = nullptr; | ||||||
|     QStringList m_timeKeys; |     QStringList m_timeKeys; | ||||||
| @ -98,6 +101,3 @@ private: | |||||||
|     QString m_tempUnits; |     QString m_tempUnits; | ||||||
|     bool m_translate = false; |     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) | void AWPairConfigFactory::showFormatterDialog(const QStringList &_keys) | ||||||
| { | { | ||||||
|     auto *config = new AWFormatterConfig(nullptr, _keys); |     auto config = new AWFormatterConfig(nullptr, _keys); | ||||||
|     config->showDialog(); |     config->showDialog(); | ||||||
|     config->deleteLater(); |     config->deleteLater(); | ||||||
| } | } | ||||||
| @ -45,7 +39,7 @@ void AWPairConfigFactory::showFormatterDialog(const QStringList &_keys) | |||||||
|  |  | ||||||
| void AWPairConfigFactory::showKeysDialog(const QStringList &_keys) | void AWPairConfigFactory::showKeysDialog(const QStringList &_keys) | ||||||
| { | { | ||||||
|     auto *config = new AWCustomKeysConfig(nullptr, _keys); |     auto config = new AWCustomKeysConfig(nullptr, _keys); | ||||||
|     config->showDialog(); |     config->showDialog(); | ||||||
|     config->deleteLater(); |     config->deleteLater(); | ||||||
| } | } | ||||||
|  | |||||||
| @ -15,9 +15,7 @@ | |||||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * |  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
|  | #pragma once | ||||||
| #ifndef AWPAIRCONFIGFACTORY_H |  | ||||||
| #define AWPAIRCONFIGFACTORY_H |  | ||||||
|  |  | ||||||
| #include <QObject> | #include <QObject> | ||||||
|  |  | ||||||
| @ -28,12 +26,9 @@ class AWPairConfigFactory : public QObject | |||||||
|  |  | ||||||
| public: | public: | ||||||
|     explicit AWPairConfigFactory(QObject *_parent = nullptr); |     explicit AWPairConfigFactory(QObject *_parent = nullptr); | ||||||
|     ~AWPairConfigFactory() override; |     ~AWPairConfigFactory() override = default; | ||||||
|     Q_INVOKABLE static void showFormatterDialog(const QStringList &_keys); |     Q_INVOKABLE static void showFormatterDialog(const QStringList &_keys); | ||||||
|     Q_INVOKABLE static void showKeysDialog(const QStringList &_keys); |     Q_INVOKABLE static void showKeysDialog(const QStringList &_keys); | ||||||
|  |  | ||||||
| private: | private: | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| #endif /* AWPAIRCONFIGFACTORY_H */ |  | ||||||
|  | |||||||
| @ -36,7 +36,7 @@ QString AWPatternFunctions::expandLambdas(QString _code, AWKeysAggregator *_aggr | |||||||
|     for (auto &lambdaKey : _usedKeys) |     for (auto &lambdaKey : _usedKeys) | ||||||
|         _code.replace(QString("$%1").arg(lambdaKey), _aggregator->formatter(_metadata[lambdaKey], lambdaKey, false)); |         _code.replace(QString("$%1").arg(lambdaKey), _aggregator->formatter(_metadata[lambdaKey], lambdaKey, false)); | ||||||
|     qCInfo(LOG_AW) << "Expression" << _code; |     qCInfo(LOG_AW) << "Expression" << _code; | ||||||
|     QJSValue result = engine.evaluate(_code); |     auto result = engine.evaluate(_code); | ||||||
|     if (result.isError()) { |     if (result.isError()) { | ||||||
|         qCWarning(LOG_AW) << "Uncaught exception at line" << result.property("lineNumber").toInt() << ":" |         qCWarning(LOG_AW) << "Uncaught exception at line" << result.property("lineNumber").toInt() << ":" | ||||||
|                           << result.toString(); |                           << result.toString(); | ||||||
| @ -52,17 +52,17 @@ QString AWPatternFunctions::expandTemplates(QString _code) | |||||||
|     qCDebug(LOG_AW) << "Expand templates in" << _code; |     qCDebug(LOG_AW) << "Expand templates in" << _code; | ||||||
|  |  | ||||||
|     // match the following construction $template{{some code here}} |     // match the following construction $template{{some code here}} | ||||||
|     QRegularExpression templatesRegexp(R"(\$template\{\{(?<body>.*?)\}\})"); |     static QRegularExpression templatesRegexp(R"(\$template\{\{(?<body>.*?)\}\})"); | ||||||
|     templatesRegexp.setPatternOptions(QRegularExpression::DotMatchesEverythingOption); |     templatesRegexp.setPatternOptions(QRegularExpression::DotMatchesEverythingOption); | ||||||
|  |  | ||||||
|     QRegularExpressionMatchIterator it = templatesRegexp.globalMatch(_code); |     auto it = templatesRegexp.globalMatch(_code); | ||||||
|     while (it.hasNext()) { |     while (it.hasNext()) { | ||||||
|         QRegularExpressionMatch match = it.next(); |         auto match = it.next(); | ||||||
|         QString body = match.captured("body"); |         auto body = match.captured("body"); | ||||||
|  |  | ||||||
|         QJSEngine engine; |         QJSEngine engine; | ||||||
|         qCInfo(LOG_AW) << "Expression" << body; |         qCInfo(LOG_AW) << "Expression" << body; | ||||||
|         QJSValue result = engine.evaluate(body); |         auto result = engine.evaluate(body); | ||||||
|         QString templateResult = ""; |         QString templateResult = ""; | ||||||
|         if (result.isError()) { |         if (result.isError()) { | ||||||
|             qCWarning(LOG_AW) << "Uncaught exception at line" << result.property("lineNumber").toInt() << ":" |             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); |     regex.setPatternOptions(QRegularExpression::DotMatchesEverythingOption); | ||||||
|  |  | ||||||
|     QList<AWPatternFunctions::AWFunction> foundFunctions; |     QList<AWPatternFunctions::AWFunction> foundFunctions; | ||||||
|     QRegularExpressionMatchIterator it = regex.globalMatch(_code); |     auto it = regex.globalMatch(_code); | ||||||
|     while (it.hasNext()) { |     while (it.hasNext()) { | ||||||
|         QRegularExpressionMatch match = it.next(); |         auto match = it.next(); | ||||||
|  |  | ||||||
|         AWPatternFunctions::AWFunction metadata; |         AWPatternFunctions::AWFunction metadata; | ||||||
|         // work with args |         // work with args | ||||||
|         QString argsString = match.captured("args"); |         auto argsString = match.captured("args"); | ||||||
|         if (argsString.isEmpty()) { |         if (argsString.isEmpty()) { | ||||||
|             metadata.args = QStringList(); |             metadata.args = QStringList(); | ||||||
|         } else { |         } else { | ||||||
|             // replace '$,' to 0x1d |             // replace '$,' to 0x1d | ||||||
|             argsString.replace("$,", QChar(0x1d)); |             argsString.replace("$,", QChar(0x1d)); | ||||||
|             QStringList args = argsString.split(','); |             auto args = argsString.split(','); | ||||||
|             std::for_each(args.begin(), args.end(), [](QString &arg) { arg.replace(QChar(0x1d), ","); }); |             std::for_each(args.begin(), args.end(), [](auto &arg) { arg.replace(QChar(0x1d), ","); }); | ||||||
|             metadata.args = args; |             metadata.args = args; | ||||||
|         } |         } | ||||||
|         // other variables |         // 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; |     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) { |     for (auto &function : found) { | ||||||
|         QString separator = function.args.isEmpty() ? "," : function.args.at(0); |         auto separator = function.args.isEmpty() ? "," : function.args.at(0); | ||||||
|         QStringList required = _keys.filter(QRegularExpression(function.body)); |         auto required = _keys.filter(QRegularExpression(function.body)); | ||||||
|         std::for_each(required.begin(), required.end(), [](QString &value) { value = QString("%1: $%1").arg(value); }); |         std::for_each(required.begin(), required.end(), [](auto &value) { value = QString("%1: $%1").arg(value); }); | ||||||
|  |  | ||||||
|         _code.replace(function.what, required.join(separator)); |         _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; |     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) { |     for (auto &function : found) { | ||||||
|         int count = _keys.filter(QRegularExpression(function.body)).count(); |         auto count = _keys.filter(QRegularExpression(function.body)).count(); | ||||||
|  |  | ||||||
|         _code.replace(function.what, QString::number(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; |     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) { |     for (auto &function : found) { | ||||||
|         QString separator = function.args.isEmpty() ? "," : function.args.at(0); |         auto separator = function.args.isEmpty() ? "," : function.args.at(0); | ||||||
|         QStringList required = _keys.filter(QRegularExpression(function.body)); |         auto required = _keys.filter(QRegularExpression(function.body)); | ||||||
|  |  | ||||||
|         _code.replace(function.what, required.join(separator)); |         _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; |     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) { |     for (auto &function : found) { | ||||||
|         QString separator = function.args.isEmpty() ? "," : function.args.at(0); |         auto separator = function.args.isEmpty() ? "," : function.args.at(0); | ||||||
|         QStringList required = _keys.filter(QRegularExpression(function.body)); |         auto required = _keys.filter(QRegularExpression(function.body)); | ||||||
|         std::for_each(required.begin(), required.end(), [](QString &value) { value = QString("$%1").arg(value); }); |         std::for_each(required.begin(), required.end(), [](auto &value) { value = QString("$%1").arg(value); }); | ||||||
|  |  | ||||||
|         _code.replace(function.what, required.join(separator)); |         _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; |     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) { |     for (auto ¯o : found) { | ||||||
|         // get macro params |         // get macro params | ||||||
|         if (macro.args.isEmpty()) { |         if (macro.args.isEmpty()) { | ||||||
|             qCWarning(LOG_AW) << "No macro name found for" << macro.what; |             qCWarning(LOG_AW) << "No macro name found for" << macro.what; | ||||||
|             continue; |             continue; | ||||||
|         } |         } | ||||||
|         QString name = macro.args.takeFirst(); |         auto name = macro.args.takeFirst(); | ||||||
|         // find macro usage |         // find macro usage | ||||||
|         QList<AWPatternFunctions::AWFunction> macroUsage |         auto macroUsage = AWPatternFunctions::findFunctionCalls(QString("aw_macro_%1").arg(name), _code); | ||||||
|             = AWPatternFunctions::findFunctionCalls(QString("aw_macro_%1").arg(name), _code); |  | ||||||
|         for (auto &function : macroUsage) { |         for (auto &function : macroUsage) { | ||||||
|             if (function.args.count() != macro.args.count()) { |             if (function.args.count() != macro.args.count()) { | ||||||
|                 qCWarning(LOG_AW) << "Invalid args count found for call" << function.what << "with macro" << macro.what; |                 qCWarning(LOG_AW) << "Invalid args count found for call" << function.what << "with macro" << macro.what; | ||||||
|                 continue; |                 continue; | ||||||
|             } |             } | ||||||
|             // generate body to replace |             // generate body to replace | ||||||
|             QString result = macro.body; |             auto result = macro.body; | ||||||
|             std::for_each(macro.args.cbegin(), macro.args.cend(), [&result, macro, function](const QString &arg) { |             std::for_each(macro.args.cbegin(), macro.args.cend(), [&result, macro, function](auto &arg) { | ||||||
|                 int index = macro.args.indexOf(arg); |                 auto index = macro.args.indexOf(arg); | ||||||
|                 result.replace(QString("$%1").arg(arg), function.args.at(index)); |                 result.replace(QString("$%1").arg(arg), function.args.at(index)); | ||||||
|             }); |             }); | ||||||
|             // do replace |             // 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; |     qCDebug(LOG_AW) << "Looking for keys in code" << _code << "using list" << _keys; | ||||||
|  |  | ||||||
|     QStringList selectedKeys; |     QStringList selectedKeys; | ||||||
|     QString replacedCode = _code; |     auto replacedCode = _code; | ||||||
|     for (auto &key : _keys) |     for (auto &key : _keys) | ||||||
|         if ((key.startsWith("bar") == _isBars) && (replacedCode.contains(QString("$%1").arg(key)))) { |         if ((key.startsWith("bar") == _isBars) && (replacedCode.contains(QString("$%1").arg(key)))) { | ||||||
|             qCInfo(LOG_AW) << "Found key" << key << "with bar enabled" << _isBars; |             qCInfo(LOG_AW) << "Found key" << key << "with bar enabled" << _isBars; | ||||||
| @ -251,13 +250,13 @@ QStringList AWPatternFunctions::findLambdas(const QString &_code) | |||||||
|  |  | ||||||
|     QStringList selectedKeys; |     QStringList selectedKeys; | ||||||
|     // match the following construction ${{some code here}} |     // match the following construction ${{some code here}} | ||||||
|     QRegularExpression lambdaRegexp(R"(\$\{\{(?<body>.*?)\}\})"); |     static QRegularExpression lambdaRegexp(R"(\$\{\{(?<body>.*?)\}\})"); | ||||||
|     lambdaRegexp.setPatternOptions(QRegularExpression::DotMatchesEverythingOption); |     lambdaRegexp.setPatternOptions(QRegularExpression::DotMatchesEverythingOption); | ||||||
|  |  | ||||||
|     QRegularExpressionMatchIterator it = lambdaRegexp.globalMatch(_code); |     auto it = lambdaRegexp.globalMatch(_code); | ||||||
|     while (it.hasNext()) { |     while (it.hasNext()) { | ||||||
|         QRegularExpressionMatch match = it.next(); |         auto match = it.next(); | ||||||
|         QString lambda = match.captured("body"); |         auto lambda = match.captured("body"); | ||||||
|  |  | ||||||
|         // append |         // append | ||||||
|         qCInfo(LOG_AW) << "Found lambda" << lambda; |         qCInfo(LOG_AW) << "Found lambda" << lambda; | ||||||
|  | |||||||
| @ -15,9 +15,7 @@ | |||||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * |  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
|  | #pragma once | ||||||
| #ifndef AWPATTERNFUNCTIONS_H |  | ||||||
| #define AWPATTERNFUNCTIONS_H |  | ||||||
|  |  | ||||||
| #include <QString> | #include <QString> | ||||||
| #include <QVariant> | #include <QVariant> | ||||||
| @ -47,6 +45,3 @@ QString insertMacros(QString _code); | |||||||
| QStringList findKeys(const QString &_code, const QStringList &_keys, bool _isBars); | QStringList findKeys(const QString &_code, const QStringList &_keys, bool _isBars); | ||||||
| QStringList findLambdas(const QString &_code); | QStringList findLambdas(const QString &_code); | ||||||
| } // namespace AWPatternFunctions | } // namespace AWPatternFunctions | ||||||
|  |  | ||||||
|  |  | ||||||
| #endif /* AWPATTERNFUNCTIONS_H */ |  | ||||||
|  | |||||||
| @ -18,8 +18,6 @@ | |||||||
| #include "awtelemetryhandler.h" | #include "awtelemetryhandler.h" | ||||||
|  |  | ||||||
| #include <QJsonDocument> | #include <QJsonDocument> | ||||||
| #include <QNetworkAccessManager> |  | ||||||
| #include <QNetworkReply> |  | ||||||
| #include <QSettings> | #include <QSettings> | ||||||
| #include <QStandardPaths> | #include <QStandardPaths> | ||||||
| #include <QUuid> | #include <QUuid> | ||||||
| @ -27,23 +25,13 @@ | |||||||
| #include "awdebug.h" | #include "awdebug.h" | ||||||
|  |  | ||||||
|  |  | ||||||
| AWTelemetryHandler::AWTelemetryHandler(QObject *_parent, const QString &_clientId) | AWTelemetryHandler::AWTelemetryHandler(QObject *_parent) | ||||||
|     : QObject(_parent) |     : QObject(_parent) | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; |     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; | ||||||
|  |  | ||||||
|     m_localFile = QString("%1/awesomewidgets/telemetry.ini") |     m_localFile = QString("%1/awesomewidgets/telemetry.ini") | ||||||
|                       .arg(QStandardPaths::writableLocation(QStandardPaths::GenericDataLocation)); |                       .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" |     qCDebug(LOG_AW) << "Init telemetry with count" << _count; | ||||||
|                     << _clientId; |  | ||||||
|  |  | ||||||
|     m_storeCount = _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(""); |     settings.remove(""); | ||||||
|     // and save now |     // and save now | ||||||
|     for (auto &val : saved) { |     for (auto &val : saved) { | ||||||
|         QString key = getKey(settings.childKeys().count()); |         auto key = getKey(settings.childKeys().count()); | ||||||
|         settings.setValue(key, val); |         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) | QString AWTelemetryHandler::getKey(const int _count) | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Get key for keys count" << _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/  * |  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
|  | #pragma once | ||||||
| #ifndef AWTELEMETRYHANDLER_H |  | ||||||
| #define AWTELEMETRYHANDLER_H |  | ||||||
|  |  | ||||||
| #include <QObject> | #include <QObject> | ||||||
|  |  | ||||||
|  |  | ||||||
| class QNetworkReply; |  | ||||||
|  |  | ||||||
| class AWTelemetryHandler : public QObject | class AWTelemetryHandler : public QObject | ||||||
| { | { | ||||||
|     Q_OBJECT |     Q_OBJECT | ||||||
|  |  | ||||||
| public: | public: | ||||||
|     const char *REMOTE_TELEMETRY_URL = "https://arcanis.me/telemetry"; |     explicit AWTelemetryHandler(QObject *_parent = nullptr); | ||||||
|  |     ~AWTelemetryHandler() override = default; | ||||||
|     explicit AWTelemetryHandler(QObject *_parent = nullptr, const QString &_clientId = ""); |  | ||||||
|     ~AWTelemetryHandler() override; |  | ||||||
|     Q_INVOKABLE [[nodiscard]] QStringList get(const QString &_group) const; |     Q_INVOKABLE [[nodiscard]] QStringList get(const QString &_group) const; | ||||||
|     Q_INVOKABLE [[nodiscard]] QString getLast(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 [[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: | private: | ||||||
|     static QString getKey(int _count); |     static QString getKey(int _count); | ||||||
|     QString m_clientId; |  | ||||||
|     QString m_localFile; |     QString m_localFile; | ||||||
|     int m_storeCount = 0; |     int m_storeCount = 0; | ||||||
|     bool m_uploadEnabled = false; |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| #endif /* AWTELEMETRYHANDLER_H */ |  | ||||||
|  | |||||||
| @ -18,6 +18,7 @@ | |||||||
| #include "awupdatehelper.h" | #include "awupdatehelper.h" | ||||||
|  |  | ||||||
| #include <KI18n/KLocalizedString> | #include <KI18n/KLocalizedString> | ||||||
|  | #include <KNotifications/KNotification> | ||||||
|  |  | ||||||
| #include <QDesktopServices> | #include <QDesktopServices> | ||||||
| #include <QJsonDocument> | #include <QJsonDocument> | ||||||
| @ -40,21 +41,15 @@ AWUpdateHelper::AWUpdateHelper(QObject *_parent) | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| AWUpdateHelper::~AWUpdateHelper() |  | ||||||
| { |  | ||||||
|     qCDebug(LOG_AW) << __PRETTY_FUNCTION__; |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| void AWUpdateHelper::checkUpdates(const bool _showAnyway) | void AWUpdateHelper::checkUpdates(const bool _showAnyway) | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Show anyway" << _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 |     // 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, |     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))); |     manager->get(QNetworkRequest(QUrl(VERSION_API))); | ||||||
| } | } | ||||||
| @ -63,15 +58,14 @@ void AWUpdateHelper::checkUpdates(const bool _showAnyway) | |||||||
| bool AWUpdateHelper::checkVersion() | bool AWUpdateHelper::checkVersion() | ||||||
| { | { | ||||||
|     QSettings settings(m_genericConfig, QSettings::IniFormat); |     QSettings settings(m_genericConfig, QSettings::IniFormat); | ||||||
|     QVersionNumber version = QVersionNumber::fromString(settings.value("Version", QString(VERSION)).toString()); |     auto version = QVersionNumber::fromString(settings.value("Version", QString(VERSION)).toString()); | ||||||
|     // update version |     // update version | ||||||
|     settings.setValue("Version", QString(VERSION)); |     settings.setValue("Version", QString(VERSION)); | ||||||
|     settings.sync(); |     settings.sync(); | ||||||
|     qCInfo(LOG_AW) << "Found version" << version << "actual one is" << m_foundVersion; |     qCInfo(LOG_AW) << "Found version" << version << "actual one is" << m_foundVersion; | ||||||
|  |  | ||||||
|     if ((version != m_foundVersion) && (!QString(CHANGELOG).isEmpty())) { |     if ((version != m_foundVersion) && (!QString(CHANGELOG).isEmpty())) { | ||||||
|         genMessageBox(i18nc("Changelog of %1", VERSION), QString(CHANGELOG).replace('@', '\n'), QMessageBox::Ok) |         sendNotification(i18n("Changelog of %1", VERSION), QString(CHANGELOG).replace('@', '\n')); | ||||||
|             ->open(); |  | ||||||
|         return true; |         return true; | ||||||
|     } else if (version != m_foundVersion) { |     } else if (version != m_foundVersion) { | ||||||
|         qCWarning(LOG_AW) << "No changelog information provided"; |         qCWarning(LOG_AW) << "No changelog information provided"; | ||||||
| @ -84,49 +78,40 @@ bool AWUpdateHelper::checkVersion() | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | void AWUpdateHelper::openReleasesPage() | ||||||
|  | { | ||||||
|  |     QDesktopServices::openUrl(QString(RELEASES) + m_foundVersion.toString()); | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
| void AWUpdateHelper::showInfo(const QVersionNumber &_version) | void AWUpdateHelper::showInfo(const QVersionNumber &_version) | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Version" << _version; |     qCDebug(LOG_AW) << "Version" << _version; | ||||||
|  |  | ||||||
|     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()) |     if (!QString(COMMIT_SHA).isEmpty()) | ||||||
|         text += QString(" (%1)").arg(QString(COMMIT_SHA)); |         text += QString(" (%1)").arg(QString(COMMIT_SHA)); | ||||||
|     return genMessageBox(i18n("No new version found"), text, QMessageBox::Ok)->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; |     qCDebug(LOG_AW) << "Version" << _version; | ||||||
|  |  | ||||||
|     QString text; |     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 += QString(COMMIT_SHA).isEmpty() ? "\n" : QString(" (%1)\n").arg(QString(COMMIT_SHA)); | ||||||
|     text += i18n("New version : %1", _version.toString()) + "\n\n"; |     text += i18n("New version : %1", _version.toString()) + "\n\n"; | ||||||
|     text += i18n("Click \"Ok\" to download"); |     text += i18n("Click \"Ok\" to download"); | ||||||
|  |  | ||||||
|     genMessageBox(i18n("There are updates"), text, QMessageBox::Ok | QMessageBox::Cancel) |     auto event = sendNotification(i18n("There are updates"), text); | ||||||
|         ->open(this, SLOT(userReplyOnUpdates(QAbstractButton *))); |     auto action = event->addAction(i18n("Details")); | ||||||
|  |     connect(action, &KNotificationAction::activated, this, &AWUpdateHelper::openReleasesPage); | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| void AWUpdateHelper::userReplyOnUpdates(QAbstractButton *_button) | void AWUpdateHelper::versionReplyReceived(QNetworkReply *_reply, const bool _showAnyway) | ||||||
| { |  | ||||||
|     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) |  | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Show message anyway" << _showAnyway; |     qCDebug(LOG_AW) << "Show message anyway" << _showAnyway; | ||||||
|     if (_reply->error() != QNetworkReply::NoError) { |     if (_reply->error() != QNetworkReply::NoError) { | ||||||
| @ -134,22 +119,23 @@ void AWUpdateHelper::versionReplyRecieved(QNetworkReply *_reply, const bool _sho | |||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     QJsonParseError error = QJsonParseError(); |     auto error = QJsonParseError(); | ||||||
|     QJsonDocument jsonDoc = QJsonDocument::fromJson(_reply->readAll(), &error); |     auto jsonDoc = QJsonDocument::fromJson(_reply->readAll(), &error); | ||||||
|     if (error.error != QJsonParseError::NoError) { |     if (error.error != QJsonParseError::NoError) { | ||||||
|         qCWarning(LOG_AW) << "Parse error" << error.errorString(); |         qCWarning(LOG_AW) << "Parse error" << error.errorString(); | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|     _reply->deleteLater(); |     _reply->deleteLater(); | ||||||
|  |     _reply->manager()->deleteLater(); // remember to delete manager too | ||||||
|  |  | ||||||
|     // convert to map |     // convert to map | ||||||
|     QVariantMap firstRelease = jsonDoc.toVariant().toList().first().toMap(); |     auto firstRelease = jsonDoc.toVariant().toList().first().toMap(); | ||||||
|     QString version = firstRelease["tag_name"].toString(); |     auto version = firstRelease["tag_name"].toString(); | ||||||
|     version.remove("V."); |     version.remove("V."); | ||||||
|     m_foundVersion = QVersionNumber::fromString(version); |     m_foundVersion = QVersionNumber::fromString(version); | ||||||
|     qCInfo(LOG_AW) << "Update found version to" << m_foundVersion; |     qCInfo(LOG_AW) << "Update found version to" << m_foundVersion; | ||||||
|  |  | ||||||
|     QVersionNumber oldVersion = QVersionNumber::fromString(VERSION); |     auto oldVersion = QVersionNumber::fromString(VERSION); | ||||||
|     if (oldVersion < m_foundVersion) |     if (oldVersion < m_foundVersion) | ||||||
|         return showUpdates(m_foundVersion); |         return showUpdates(m_foundVersion); | ||||||
|     else if (_showAnyway) |     else if (_showAnyway) | ||||||
| @ -158,18 +144,12 @@ void AWUpdateHelper::versionReplyRecieved(QNetworkReply *_reply, const bool _sho | |||||||
|  |  | ||||||
|  |  | ||||||
| // additional method which is used to show message box which does not block UI | // additional method which is used to show message box which does not block UI | ||||||
| QMessageBox *AWUpdateHelper::genMessageBox(const QString &_title, const QString &_body, | KNotification *AWUpdateHelper::sendNotification(const QString &_title, const QString &_body) | ||||||
|                                            const QMessageBox::StandardButtons _buttons) |  | ||||||
| { | { | ||||||
|     qCDebug(LOG_AW) << "Construct message box with title" << _title << "and body" << _body; |     qCDebug(LOG_AW) << "Construct message box with title" << _title << "and body" << _body; | ||||||
|  |  | ||||||
|     auto *msgBox = new QMessageBox(nullptr); |     auto event = KNotification::event("system", _title, _body); | ||||||
|     msgBox->setAttribute(Qt::WA_DeleteOnClose); |     event->setComponentName("plasma-applet-org.kde.plasma.awesome-widget"); | ||||||
|     msgBox->setModal(false); |  | ||||||
|     msgBox->setWindowTitle(_title); |  | ||||||
|     msgBox->setText(_body); |  | ||||||
|     msgBox->setStandardButtons(_buttons); |  | ||||||
|     msgBox->setIcon(QMessageBox::Information); |  | ||||||
|  |  | ||||||
|     return msgBox; |     return event; | ||||||
| } | } | ||||||
|  | |||||||
| @ -15,15 +15,13 @@ | |||||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * |  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
|  | #pragma once | ||||||
|  |  | ||||||
| #ifndef AWUPDATEHELPER_H |  | ||||||
| #define AWUPDATEHELPER_H |  | ||||||
|  |  | ||||||
| #include <QMessageBox> |  | ||||||
| #include <QObject> | #include <QObject> | ||||||
| #include <QVersionNumber> | #include <QVersionNumber> | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class KNotification; | ||||||
| class QNetworkReply; | class QNetworkReply; | ||||||
|  |  | ||||||
| class AWUpdateHelper : public QObject | class AWUpdateHelper : public QObject | ||||||
| @ -32,22 +30,18 @@ class AWUpdateHelper : public QObject | |||||||
|  |  | ||||||
| public: | public: | ||||||
|     explicit AWUpdateHelper(QObject *_parent = nullptr); |     explicit AWUpdateHelper(QObject *_parent = nullptr); | ||||||
|     ~AWUpdateHelper() override; |     ~AWUpdateHelper() override = default; | ||||||
|     void checkUpdates(bool _showAnyway = false); |     void checkUpdates(bool _showAnyway = false); | ||||||
|     bool checkVersion(); |     bool checkVersion(); | ||||||
|  |  | ||||||
| private slots: | private slots: | ||||||
|  |     void openReleasesPage(); | ||||||
|     static void showInfo(const QVersionNumber &_version); |     static void showInfo(const QVersionNumber &_version); | ||||||
|     void showUpdates(const QVersionNumber &_version); |     void showUpdates(const QVersionNumber &_version) const; | ||||||
|     void userReplyOnUpdates(QAbstractButton *_button); |     void versionReplyReceived(QNetworkReply *_reply, bool _showAnyway); | ||||||
|     void versionReplyRecieved(QNetworkReply *_reply, bool _showAnyway); |  | ||||||
|  |  | ||||||
| private: | private: | ||||||
|     static QMessageBox *genMessageBox(const QString &_title, const QString &_body, |     static KNotification *sendNotification(const QString &_title, const QString &_body); | ||||||
|                                       QMessageBox::StandardButtons _buttons); |  | ||||||
|     QVersionNumber m_foundVersion; |     QVersionNumber m_foundVersion; | ||||||
|     QString m_genericConfig; |     QString m_genericConfig; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| #endif /* AWUPDATEHELPER_H */ |  | ||||||
|  | |||||||
| @ -29,13 +29,19 @@ | |||||||
|  |  | ||||||
| AbstractExtItem::AbstractExtItem(QObject *_parent, const QString &_filePath) | AbstractExtItem::AbstractExtItem(QObject *_parent, const QString &_filePath) | ||||||
|     : QObject(_parent) |     : QObject(_parent) | ||||||
|     , m_fileName(_filePath) |     , m_filePath(_filePath) | ||||||
| { | { | ||||||
|     qCDebug(LOG_LIB) << __PRETTY_FUNCTION__; |     qCDebug(LOG_LIB) << __PRETTY_FUNCTION__; | ||||||
|  |  | ||||||
|     qCDebug(LOG_LIB) << "Desktop name" << _filePath; |     qCDebug(LOG_LIB) << "Desktop name" << _filePath; | ||||||
|  |  | ||||||
|     m_name = m_fileName; |     m_name = m_filePath; | ||||||
|  |  | ||||||
|  |     m_scheduler = new QCronScheduler(this); | ||||||
|  |     connect(m_scheduler, &QCronScheduler::activated, this, &AbstractExtItem::requestDataUpdate); | ||||||
|  |  | ||||||
|  |     m_socket = new QLocalServer(this); | ||||||
|  |     connect(m_socket, &QLocalServer::newConnection, this, &AbstractExtItem::requestDataUpdate); | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -43,11 +49,11 @@ AbstractExtItem::~AbstractExtItem() | |||||||
| { | { | ||||||
|     qCDebug(LOG_LIB) << __PRETTY_FUNCTION__; |     qCDebug(LOG_LIB) << __PRETTY_FUNCTION__; | ||||||
|  |  | ||||||
|     if (m_socket) { |     m_scheduler->stop(); | ||||||
|  |     m_scheduler->deleteLater(); | ||||||
|  |  | ||||||
|     m_socket->close(); |     m_socket->close(); | ||||||
|         QLocalServer::removeServer(socket()); |  | ||||||
|     m_socket->deleteLater(); |     m_socket->deleteLater(); | ||||||
|     } |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -95,10 +101,11 @@ void AbstractExtItem::startTimer() | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| QString AbstractExtItem::writtableConfig() const | QString AbstractExtItem::writableConfig() const | ||||||
| { | { | ||||||
|     auto path = m_fileName; |     auto path = m_filePath; | ||||||
|     auto name = QFileInfo(path).fileName(); |     auto name = fileName(); | ||||||
|  |     // extract subdirectory | ||||||
|     path.remove(path.length() - name.length() - 1, name.length() + 1); |     path.remove(path.length() - name.length() - 1, name.length() + 1); | ||||||
|     auto dir = QFileInfo(path).fileName(); |     auto dir = QFileInfo(path).fileName(); | ||||||
|  |  | ||||||
| @ -127,7 +134,13 @@ QString AbstractExtItem::cron() const | |||||||
|  |  | ||||||
| QString AbstractExtItem::fileName() const | QString AbstractExtItem::fileName() const | ||||||
| { | { | ||||||
|     return m_fileName; |     return QFileInfo(filePath()).fileName(); | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | QString AbstractExtItem::filePath() const | ||||||
|  | { | ||||||
|  |     return m_filePath; | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -196,20 +209,14 @@ void AbstractExtItem::setComment(const QString &_comment) | |||||||
| void AbstractExtItem::setCron(const QString &_cron) | void AbstractExtItem::setCron(const QString &_cron) | ||||||
| { | { | ||||||
|     qCDebug(LOG_LIB) << "Cron string" << _cron; |     qCDebug(LOG_LIB) << "Cron string" << _cron; | ||||||
|     // deinit module first |  | ||||||
|     if (m_scheduler) { |  | ||||||
|         disconnect(m_scheduler, SIGNAL(activated()), this, SIGNAL(requestDataUpdate())); |  | ||||||
|         delete m_scheduler; |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     m_cron = _cron; |     m_cron = _cron; | ||||||
|     if (cron().isEmpty()) |     if (m_cron.isEmpty()) { // disable cron timer | ||||||
|         return; |         m_scheduler->stop(); | ||||||
|  |     } else { | ||||||
|     // init scheduler |         m_scheduler->parse(m_cron); | ||||||
|     m_scheduler = new QCronScheduler(this); |         m_scheduler->start(); | ||||||
|     m_scheduler->parse(cron()); |     } | ||||||
|     connect(m_scheduler, SIGNAL(activated()), this, SIGNAL(requestDataUpdate())); |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -234,11 +241,11 @@ void AbstractExtItem::setName(const QString &_name) | |||||||
| void AbstractExtItem::setNumber(int _number) | void AbstractExtItem::setNumber(int _number) | ||||||
| { | { | ||||||
|     qCDebug(LOG_LIB) << "Number" << _number; |     qCDebug(LOG_LIB) << "Number" << _number; | ||||||
|     bool generateNumber = (_number == -1); |     auto generateNumber = (_number == -1); | ||||||
|     if (generateNumber) { |     if (generateNumber) { | ||||||
|         _number = []() { |         _number = []() { | ||||||
|             qCWarning(LOG_LIB) << "Number is empty, generate new one"; |             qCWarning(LOG_LIB) << "Number is empty, generate new one"; | ||||||
|             auto n = QRandomGenerator::global()->generate() % 1000; |             auto n = QRandomGenerator::global()->bounded(1000); | ||||||
|             qCInfo(LOG_LIB) << "Generated number is" << n; |             qCInfo(LOG_LIB) << "Generated number is" << n; | ||||||
|             return n; |             return n; | ||||||
|         }(); |         }(); | ||||||
| @ -253,40 +260,24 @@ void AbstractExtItem::setNumber(int _number) | |||||||
| void AbstractExtItem::setSocket(const QString &_socket) | void AbstractExtItem::setSocket(const QString &_socket) | ||||||
| { | { | ||||||
|     qCDebug(LOG_LIB) << "Socket" << _socket; |     qCDebug(LOG_LIB) << "Socket" << _socket; | ||||||
|     // remove old socket first |  | ||||||
|     deinitSocket(); |  | ||||||
|  |  | ||||||
|     m_socketFile = _socket; |     m_socketFile = _socket; | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| void AbstractExtItem::deinitSocket() |  | ||||||
| { |  | ||||||
|     if (!m_socket) |  | ||||||
|         return; |  | ||||||
|  |  | ||||||
|     m_socket->close(); |  | ||||||
|     QLocalServer::removeServer(socket()); |  | ||||||
|     disconnect(m_socket, SIGNAL(newConnection()), this, SLOT(newConnectionReceived())); |  | ||||||
|     delete m_socket; |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| void AbstractExtItem::initSocket() | void AbstractExtItem::initSocket() | ||||||
| { | { | ||||||
|     // remove old socket first |     // reload local socket | ||||||
|     deinitSocket(); |     m_socket->close(); | ||||||
|  |  | ||||||
|     m_socket = new QLocalServer(this); |     auto listening = m_socket->listen(m_socketFile); | ||||||
|     bool listening = m_socket->listen(socket()); |     qCInfo(LOG_LIB) << "Server listening on" << m_socketFile << listening; | ||||||
|     qCInfo(LOG_LIB) << "Server listening on" << socket() << listening; |  | ||||||
|     connect(m_socket, SIGNAL(newConnection()), this, SLOT(newConnectionReceived())); |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| void AbstractExtItem::readConfiguration() | void AbstractExtItem::readConfiguration() | ||||||
| { | { | ||||||
|     QSettings settings(m_fileName, QSettings::IniFormat); |     QSettings settings(m_filePath, QSettings::IniFormat); | ||||||
|  |  | ||||||
|     settings.beginGroup("Desktop Entry"); |     settings.beginGroup("Desktop Entry"); | ||||||
|     setName(settings.value("Name", name()).toString()); |     setName(settings.value("Name", name()).toString()); | ||||||
| @ -303,8 +294,8 @@ void AbstractExtItem::readConfiguration() | |||||||
|  |  | ||||||
| bool AbstractExtItem::tryDelete() const | bool AbstractExtItem::tryDelete() const | ||||||
| { | { | ||||||
|     bool status = QFile::remove(m_fileName); |     auto status = QFile::remove(m_filePath); | ||||||
|     qCInfo(LOG_LIB) << "Remove file" << m_fileName << status; |     qCInfo(LOG_LIB) << "Remove file" << m_filePath << status; | ||||||
|  |  | ||||||
|     return status; |     return status; | ||||||
| } | } | ||||||
| @ -312,7 +303,7 @@ bool AbstractExtItem::tryDelete() const | |||||||
|  |  | ||||||
| void AbstractExtItem::writeConfiguration() const | void AbstractExtItem::writeConfiguration() const | ||||||
| { | { | ||||||
|     QSettings settings(writtableConfig(), QSettings::IniFormat); |     QSettings settings(writableConfig(), QSettings::IniFormat); | ||||||
|     qCInfo(LOG_LIB) << "Configuration file" << settings.fileName(); |     qCInfo(LOG_LIB) << "Configuration file" << settings.fileName(); | ||||||
|  |  | ||||||
|     settings.beginGroup("Desktop Entry"); |     settings.beginGroup("Desktop Entry"); | ||||||
| @ -329,9 +320,3 @@ void AbstractExtItem::writeConfiguration() const | |||||||
|  |  | ||||||
|     settings.sync(); |     settings.sync(); | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| void AbstractExtItem::newConnectionReceived() |  | ||||||
| { |  | ||||||
|     emit(requestDataUpdate()); |  | ||||||
| } |  | ||||||
|  | |||||||
| @ -15,8 +15,7 @@ | |||||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * |  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
| #ifndef ABSTRACTEXTITEM_H | #pragma once | ||||||
| #define ABSTRACTEXTITEM_H |  | ||||||
|  |  | ||||||
| #include <QVariant> | #include <QVariant> | ||||||
|  |  | ||||||
| @ -33,6 +32,7 @@ class AbstractExtItem : public QObject | |||||||
|     Q_PROPERTY(QString comment READ comment WRITE setComment) |     Q_PROPERTY(QString comment READ comment WRITE setComment) | ||||||
|     Q_PROPERTY(QString cron READ cron WRITE setCron) |     Q_PROPERTY(QString cron READ cron WRITE setCron) | ||||||
|     Q_PROPERTY(QString fileName READ fileName) |     Q_PROPERTY(QString fileName READ fileName) | ||||||
|  |     Q_PROPERTY(QString filePath READ filePath) | ||||||
|     Q_PROPERTY(int interval READ interval WRITE setInterval) |     Q_PROPERTY(int interval READ interval WRITE setInterval) | ||||||
|     Q_PROPERTY(QString name READ name WRITE setName) |     Q_PROPERTY(QString name READ name WRITE setName) | ||||||
|     Q_PROPERTY(int number READ number WRITE setNumber) |     Q_PROPERTY(int number READ number WRITE setNumber) | ||||||
| @ -46,12 +46,13 @@ public: | |||||||
|     virtual AbstractExtItem *copy(const QString &_fileName, int _number) = 0; |     virtual AbstractExtItem *copy(const QString &_fileName, int _number) = 0; | ||||||
|     virtual void copyDefaults(AbstractExtItem *_other) const; |     virtual void copyDefaults(AbstractExtItem *_other) const; | ||||||
|     virtual void startTimer(); |     virtual void startTimer(); | ||||||
|     [[nodiscard]] QString writtableConfig() const; |     [[nodiscard]] QString writableConfig() const; | ||||||
|     // get methods |     // get methods | ||||||
|     [[nodiscard]] int apiVersion() const; |     [[nodiscard]] int apiVersion() const; | ||||||
|     [[nodiscard]] QString comment() const; |     [[nodiscard]] QString comment() const; | ||||||
|     [[nodiscard]] QString cron() const; |     [[nodiscard]] QString cron() const; | ||||||
|     [[nodiscard]] QString fileName() const; |     [[nodiscard]] QString fileName() const; | ||||||
|  |     [[nodiscard]] QString filePath() const; | ||||||
|     [[nodiscard]] int interval() const; |     [[nodiscard]] int interval() const; | ||||||
|     [[nodiscard]] bool isActive() const; |     [[nodiscard]] bool isActive() const; | ||||||
|     [[nodiscard]] QString name() const; |     [[nodiscard]] QString name() const; | ||||||
| @ -74,7 +75,6 @@ signals: | |||||||
|     void requestDataUpdate(); |     void requestDataUpdate(); | ||||||
|  |  | ||||||
| public slots: | public slots: | ||||||
|     virtual void deinitSocket(); |  | ||||||
|     virtual void initSocket(); |     virtual void initSocket(); | ||||||
|     virtual void readConfiguration(); |     virtual void readConfiguration(); | ||||||
|     virtual QVariantHash run() = 0; |     virtual QVariantHash run() = 0; | ||||||
| @ -82,12 +82,9 @@ public slots: | |||||||
|     [[nodiscard]] virtual bool tryDelete() const; |     [[nodiscard]] virtual bool tryDelete() const; | ||||||
|     virtual void writeConfiguration() const; |     virtual void writeConfiguration() const; | ||||||
|  |  | ||||||
| private slots: |  | ||||||
|     void newConnectionReceived(); |  | ||||||
|  |  | ||||||
| private: | private: | ||||||
|     QCronScheduler *m_scheduler = nullptr; |     QCronScheduler *m_scheduler = nullptr; | ||||||
|     QString m_fileName = "/dev/null"; |     QString m_filePath = ""; | ||||||
|     int m_times = 0; |     int m_times = 0; | ||||||
|     // FIXME find a better way to do it |     // FIXME find a better way to do it | ||||||
|     virtual void translate(void *_ui) = 0; |     virtual void translate(void *_ui) = 0; | ||||||
| @ -102,6 +99,3 @@ private: | |||||||
|     QLocalServer *m_socket = nullptr; |     QLocalServer *m_socket = nullptr; | ||||||
|     QString m_socketFile = ""; |     QString m_socketFile = ""; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| #endif /* ABSTRACTEXTITEM_H */ |  | ||||||
|  | |||||||
| @ -35,8 +35,7 @@ AbstractExtItemAggregator::AbstractExtItemAggregator(QObject *_parent, QString _ | |||||||
|     // create directory at $HOME |     // create directory at $HOME | ||||||
|     auto localDir = QString("%1/awesomewidgets/%2") |     auto localDir = QString("%1/awesomewidgets/%2") | ||||||
|                         .arg(QStandardPaths::writableLocation(QStandardPaths::GenericDataLocation), type()); |                         .arg(QStandardPaths::writableLocation(QStandardPaths::GenericDataLocation), type()); | ||||||
|     QDir localDirectory; |     if (QDir().mkpath(localDir)) | ||||||
|     if (localDirectory.mkpath(localDir)) |  | ||||||
|         qCInfo(LOG_LIB) << "Created directory" << localDir; |         qCInfo(LOG_LIB) << "Created directory" << localDir; | ||||||
| } | } | ||||||
|  |  | ||||||
| @ -102,18 +101,13 @@ int AbstractExtItemAggregator::exec() | |||||||
|     auto createButton = ui->buttonBox->addButton(i18n("Create"), QDialogButtonBox::ActionRole); |     auto createButton = ui->buttonBox->addButton(i18n("Create"), QDialogButtonBox::ActionRole); | ||||||
|     auto deleteButton = ui->buttonBox->addButton(i18n("Remove"), QDialogButtonBox::ActionRole); |     auto deleteButton = ui->buttonBox->addButton(i18n("Remove"), QDialogButtonBox::ActionRole); | ||||||
|  |  | ||||||
|     connect(ui->buttonBox, &QDialogButtonBox::clicked, [&](QAbstractButton *_button) { |     connect(copyButton, &QPushButton::clicked, [this, ui]() { copyItem(ui->listWidget); }); | ||||||
|         if (dynamic_cast<QPushButton *>(_button) == copyButton) |     connect(createButton, &QPushButton::clicked, [this, ui]() { doCreateItem(ui->listWidget); }); | ||||||
|             copyItem(ui->listWidget); |     connect(deleteButton, &QPushButton::clicked, [this, ui]() { deleteItem(ui->listWidget); }); | ||||||
|         else if (dynamic_cast<QPushButton *>(_button) == createButton) |     connect(ui->buttonBox, &QDialogButtonBox::accepted, [this, ui]() { editItem(ui->listWidget); }); | ||||||
|             doCreateItem(ui->listWidget); |  | ||||||
|         else if (dynamic_cast<QPushButton *>(_button) == deleteButton) |  | ||||||
|             deleteItem(ui->listWidget); |  | ||||||
|         else if (ui->buttonBox->buttonRole(_button) == QDialogButtonBox::AcceptRole) |  | ||||||
|             editItem(ui->listWidget); |  | ||||||
|     }); |  | ||||||
|     connect(ui->buttonBox, &QDialogButtonBox::rejected, [dialog]() { dialog->reject(); }); |     connect(ui->buttonBox, &QDialogButtonBox::rejected, [dialog]() { dialog->reject(); }); | ||||||
|     connect(ui->listWidget, &QListWidget::itemActivated, [&](QListWidgetItem *) { editItem(ui->listWidget); }); |     connect(ui->listWidget, &QListWidget::itemActivated, [this, ui](QListWidgetItem *) { editItem(ui->listWidget); }); | ||||||
|  |  | ||||||
|     repaintList(ui->listWidget); |     repaintList(ui->listWidget); | ||||||
|     auto ret = dialog->exec(); |     auto ret = dialog->exec(); | ||||||
| @ -145,8 +139,8 @@ AbstractExtItem *AbstractExtItemAggregator::itemFromWidget(QListWidget *_widget) | |||||||
|         return nullptr; |         return nullptr; | ||||||
|  |  | ||||||
|     AbstractExtItem *found = nullptr; |     AbstractExtItem *found = nullptr; | ||||||
|     for (auto &item : items()) { |     for (auto item : items()) { | ||||||
|         auto fileName = QFileInfo(item->fileName()).fileName(); |         auto fileName = item->fileName(); | ||||||
|         if (fileName != widgetItem->text()) |         if (fileName != widgetItem->text()) | ||||||
|             continue; |             continue; | ||||||
|         found = item; |         found = item; | ||||||
| @ -162,8 +156,8 @@ AbstractExtItem *AbstractExtItemAggregator::itemFromWidget(QListWidget *_widget) | |||||||
| void AbstractExtItemAggregator::repaintList(QListWidget *_widget) const | void AbstractExtItemAggregator::repaintList(QListWidget *_widget) const | ||||||
| { | { | ||||||
|     _widget->clear(); |     _widget->clear(); | ||||||
|     for (auto &_item : items()) { |     for (auto _item : items()) { | ||||||
|         QString fileName = QFileInfo(_item->fileName()).fileName(); |         QString fileName = _item->fileName(); | ||||||
|         auto item = new QListWidgetItem(fileName, _widget); |         auto item = new QListWidgetItem(fileName, _widget); | ||||||
|         QStringList tooltip; |         QStringList tooltip; | ||||||
|         tooltip.append(i18n("Name: %1", _item->name())); |         tooltip.append(i18n("Name: %1", _item->name())); | ||||||
| @ -178,9 +172,10 @@ void AbstractExtItemAggregator::repaintList(QListWidget *_widget) const | |||||||
| int AbstractExtItemAggregator::uniqNumber() const | int AbstractExtItemAggregator::uniqNumber() const | ||||||
| { | { | ||||||
|     QList<int> tagList; |     QList<int> tagList; | ||||||
|     for (auto &item : items()) |     for (auto item : items()) | ||||||
|         tagList.append(item->number()); |         tagList.append(item->number()); | ||||||
|     int number = 0; |  | ||||||
|  |     auto number = 0; | ||||||
|     while (tagList.contains(number)) |     while (tagList.contains(number)) | ||||||
|         number++; |         number++; | ||||||
|  |  | ||||||
| @ -196,10 +191,8 @@ QVariant AbstractExtItemAggregator::configArgs() const | |||||||
|  |  | ||||||
| QStringList AbstractExtItemAggregator::directories() const | QStringList AbstractExtItemAggregator::directories() const | ||||||
| { | { | ||||||
|     auto dirs = QStandardPaths::locateAll(QStandardPaths::GenericDataLocation, QString("awesomewidgets/%1").arg(type()), |     return QStandardPaths::locateAll(QStandardPaths::GenericDataLocation, QString("awesomewidgets/%1").arg(type()), | ||||||
|                                      QStandardPaths::LocateDirectory); |                                      QStandardPaths::LocateDirectory); | ||||||
|  |  | ||||||
|     return dirs; |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | |||||||
| @ -15,8 +15,7 @@ | |||||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * |  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
| #ifndef ABSTRACTEXTITEMAGGREGATOR_H | #pragma once | ||||||
| #define ABSTRACTEXTITEMAGGREGATOR_H |  | ||||||
|  |  | ||||||
| #include <QStandardPaths> | #include <QStandardPaths> | ||||||
|  |  | ||||||
| @ -24,7 +23,6 @@ | |||||||
| #include "awdebug.h" | #include "awdebug.h" | ||||||
|  |  | ||||||
|  |  | ||||||
| class QAbstractButton; |  | ||||||
| class QListWidget; | class QListWidget; | ||||||
| class QListWidgetItem; | class QListWidgetItem; | ||||||
|  |  | ||||||
| @ -60,7 +58,7 @@ public: | |||||||
|     void deleteItem(QListWidget *_widget); |     void deleteItem(QListWidget *_widget); | ||||||
|     void editItem(QListWidget *_widget); |     void editItem(QListWidget *_widget); | ||||||
|     [[nodiscard]] int exec(); |     [[nodiscard]] int exec(); | ||||||
|     QString getName(); |     [[nodiscard]] static QString getName(); | ||||||
|     virtual void initItems() = 0; |     virtual void initItems() = 0; | ||||||
|     [[nodiscard]] AbstractExtItem *itemFromWidget(QListWidget *_widget) const; |     [[nodiscard]] AbstractExtItem *itemFromWidget(QListWidget *_widget) const; | ||||||
|     void repaintList(QListWidget *_widget) const; |     void repaintList(QListWidget *_widget) const; | ||||||
| @ -80,6 +78,3 @@ private: | |||||||
|     // ui methods |     // ui methods | ||||||
|     virtual void doCreateItem(QListWidget *_widget) = 0; |     virtual void doCreateItem(QListWidget *_widget) = 0; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| #endif /* ABSTRACTEXTITEMAGGREGATOR_H */ |  | ||||||
|  | |||||||
| @ -15,31 +15,17 @@ | |||||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * |  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
| #ifndef ABSTRACTQUOTESPROVIDER_H | #pragma once | ||||||
| #define ABSTRACTQUOTESPROVIDER_H |  | ||||||
|  |  | ||||||
| #include <QObject> |  | ||||||
| #include <QUrl> | #include <QUrl> | ||||||
|  | #include <QVariant> | ||||||
| #include "abstractextitem.h" |  | ||||||
|  |  | ||||||
|  |  | ||||||
| class AbstractQuotesProvider : public QObject | class AbstractQuotesProvider | ||||||
| { | { | ||||||
|     Q_OBJECT |  | ||||||
|  |  | ||||||
| public: | public: | ||||||
|     explicit AbstractQuotesProvider(QObject *_parent) |     virtual ~AbstractQuotesProvider() = default; | ||||||
|         : QObject(_parent){}; |  | ||||||
|     ~AbstractQuotesProvider() override = default; |  | ||||||
|     virtual void initUrl(const QString &_asset) = 0; |     virtual void initUrl(const QString &_asset) = 0; | ||||||
|     [[nodiscard]] virtual QVariantHash parse(const QByteArray &_source, const QVariantHash &_oldValues) const = 0; |     [[nodiscard]] virtual QVariantHash parse(const QByteArray &_source) = 0; | ||||||
|     [[nodiscard]] QString tag(const QString &_type) const |  | ||||||
|     { |  | ||||||
|         return dynamic_cast<AbstractExtItem *>(parent())->tag(_type); |  | ||||||
|     }; |  | ||||||
|     [[nodiscard]] virtual QUrl url() const = 0; |     [[nodiscard]] virtual QUrl url() const = 0; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| #endif /* ABSTRACTQUOTESPROVIDER_H */ |  | ||||||
|  | |||||||
| @ -15,31 +15,17 @@ | |||||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * |  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
| #ifndef ABSTRACTWEATHERPROVIDER_H | #pragma once | ||||||
| #define ABSTRACTWEATHERPROVIDER_H |  | ||||||
|  |  | ||||||
| #include <QObject> |  | ||||||
| #include <QUrl> | #include <QUrl> | ||||||
|  | #include <QVariant> | ||||||
| #include "abstractextitem.h" |  | ||||||
|  |  | ||||||
|  |  | ||||||
| class AbstractWeatherProvider : public QObject | class AbstractWeatherProvider | ||||||
| { | { | ||||||
|     Q_OBJECT |  | ||||||
|  |  | ||||||
| public: | public: | ||||||
|     explicit AbstractWeatherProvider(QObject *_parent) |     virtual ~AbstractWeatherProvider() = default; | ||||||
|         : QObject(_parent){}; |  | ||||||
|     ~AbstractWeatherProvider() override = default; |  | ||||||
|     virtual void initUrl(const QString &_city, const QString &_country, int _ts) = 0; |     virtual void initUrl(const QString &_city, const QString &_country, int _ts) = 0; | ||||||
|     [[nodiscard]] virtual QVariantHash parse(const QVariantMap &_json) const = 0; |     [[nodiscard]] virtual QVariantHash parse(const QVariantMap &_json) const = 0; | ||||||
|     [[nodiscard]] QString tag(const QString &_type) const |  | ||||||
|     { |  | ||||||
|         return dynamic_cast<AbstractExtItem *>(parent())->tag(_type); |  | ||||||
|     }; |  | ||||||
|     [[nodiscard]] virtual QUrl url() const = 0; |     [[nodiscard]] virtual QUrl url() const = 0; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| #endif /* ABSTRACTWEATHERPROVIDER_H */ |  | ||||||
|  | |||||||
| @ -113,7 +113,7 @@ void AWAbstractFormatter::readConfiguration() | |||||||
| { | { | ||||||
|     AbstractExtItem::readConfiguration(); |     AbstractExtItem::readConfiguration(); | ||||||
|  |  | ||||||
|     QSettings settings(fileName(), QSettings::IniFormat); |     QSettings settings(filePath(), QSettings::IniFormat); | ||||||
|  |  | ||||||
|     settings.beginGroup("Desktop Entry"); |     settings.beginGroup("Desktop Entry"); | ||||||
|     setStrType(settings.value("X-AW-Type", strType()).toString()); |     setStrType(settings.value("X-AW-Type", strType()).toString()); | ||||||
| @ -125,7 +125,7 @@ void AWAbstractFormatter::writeConfiguration() const | |||||||
| { | { | ||||||
|     AbstractExtItem::writeConfiguration(); |     AbstractExtItem::writeConfiguration(); | ||||||
|  |  | ||||||
|     QSettings settings(writtableConfig(), QSettings::IniFormat); |     QSettings settings(writableConfig(), QSettings::IniFormat); | ||||||
|     qCInfo(LOG_LIB) << "Configuration file" << settings.fileName(); |     qCInfo(LOG_LIB) << "Configuration file" << settings.fileName(); | ||||||
|  |  | ||||||
|     settings.beginGroup("Desktop Entry"); |     settings.beginGroup("Desktop Entry"); | ||||||
|  | |||||||
| @ -15,8 +15,7 @@ | |||||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * |  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
| #ifndef AWABSTRACTFORMATTER_H | #pragma once | ||||||
| #define AWABSTRACTFORMATTER_H |  | ||||||
|  |  | ||||||
| #include <QRegularExpression> | #include <QRegularExpression> | ||||||
|  |  | ||||||
| @ -52,6 +51,3 @@ private: | |||||||
|     // properties |     // properties | ||||||
|     FormatterClass m_type = FormatterClass::NoFormat; |     FormatterClass m_type = FormatterClass::NoFormat; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| #endif /* AWABSTRACTFORMATTER_H */ |  | ||||||
|  | |||||||
| @ -50,6 +50,7 @@ AWDateTimeFormatter *AWDateTimeFormatter::copy(const QString &_fileName, const i | |||||||
|  |  | ||||||
|     auto item = new AWDateTimeFormatter(parent(), _fileName); |     auto item = new AWDateTimeFormatter(parent(), _fileName); | ||||||
|     AWAbstractFormatter::copyDefaults(item); |     AWAbstractFormatter::copyDefaults(item); | ||||||
|  |  | ||||||
|     item->setFormat(format()); |     item->setFormat(format()); | ||||||
|     item->setTranslateString(translateString()); |     item->setTranslateString(translateString()); | ||||||
|     item->setNumber(_number); |     item->setNumber(_number); | ||||||
| @ -91,7 +92,7 @@ void AWDateTimeFormatter::readConfiguration() | |||||||
| { | { | ||||||
|     AWAbstractFormatter::readConfiguration(); |     AWAbstractFormatter::readConfiguration(); | ||||||
|  |  | ||||||
|     QSettings settings(fileName(), QSettings::IniFormat); |     QSettings settings(filePath(), QSettings::IniFormat); | ||||||
|  |  | ||||||
|     settings.beginGroup("Desktop Entry"); |     settings.beginGroup("Desktop Entry"); | ||||||
|     setFormat(settings.value("X-AW-Format", format()).toString()); |     setFormat(settings.value("X-AW-Format", format()).toString()); | ||||||
| @ -140,7 +141,7 @@ void AWDateTimeFormatter::writeConfiguration() const | |||||||
| { | { | ||||||
|     AWAbstractFormatter::writeConfiguration(); |     AWAbstractFormatter::writeConfiguration(); | ||||||
|  |  | ||||||
|     QSettings settings(writtableConfig(), QSettings::IniFormat); |     QSettings settings(writableConfig(), QSettings::IniFormat); | ||||||
|     qCInfo(LOG_LIB) << "Configuration file" << settings.fileName(); |     qCInfo(LOG_LIB) << "Configuration file" << settings.fileName(); | ||||||
|  |  | ||||||
|     settings.beginGroup("Desktop Entry"); |     settings.beginGroup("Desktop Entry"); | ||||||
|  | |||||||
| @ -15,8 +15,7 @@ | |||||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * |  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
| #ifndef AWDATETIMEFORMATTER_H | #pragma once | ||||||
| #define AWDATETIMEFORMATTER_H |  | ||||||
|  |  | ||||||
| #include <QLocale> | #include <QLocale> | ||||||
|  |  | ||||||
| @ -52,6 +51,3 @@ private: | |||||||
|     QString m_format = ""; |     QString m_format = ""; | ||||||
|     bool m_translate = true; |     bool m_translate = true; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| #endif /* AWDATETIMEFORMATTER_H */ |  | ||||||
|  | |||||||
| @ -54,6 +54,7 @@ AWFloatFormatter *AWFloatFormatter::copy(const QString &_fileName, const int _nu | |||||||
|  |  | ||||||
|     auto item = new AWFloatFormatter(parent(), _fileName); |     auto item = new AWFloatFormatter(parent(), _fileName); | ||||||
|     AWAbstractFormatter::copyDefaults(item); |     AWAbstractFormatter::copyDefaults(item); | ||||||
|  |  | ||||||
|     item->setCount(count()); |     item->setCount(count()); | ||||||
|     item->setFormat(format()); |     item->setFormat(format()); | ||||||
|     item->setFillChar(fillChar()); |     item->setFillChar(fillChar()); | ||||||
| @ -174,7 +175,7 @@ void AWFloatFormatter::readConfiguration() | |||||||
| { | { | ||||||
|     AWAbstractFormatter::readConfiguration(); |     AWAbstractFormatter::readConfiguration(); | ||||||
|  |  | ||||||
|     QSettings settings(fileName(), QSettings::IniFormat); |     QSettings settings(filePath(), QSettings::IniFormat); | ||||||
|  |  | ||||||
|     settings.beginGroup("Desktop Entry"); |     settings.beginGroup("Desktop Entry"); | ||||||
|     setCount(settings.value("X-AW-Width", count()).toInt()); |     setCount(settings.value("X-AW-Width", count()).toInt()); | ||||||
| @ -238,7 +239,7 @@ void AWFloatFormatter::writeConfiguration() const | |||||||
| { | { | ||||||
|     AWAbstractFormatter::writeConfiguration(); |     AWAbstractFormatter::writeConfiguration(); | ||||||
|  |  | ||||||
|     QSettings settings(writtableConfig(), QSettings::IniFormat); |     QSettings settings(writableConfig(), QSettings::IniFormat); | ||||||
|     qCInfo(LOG_LIB) << "Configuration file" << settings.fileName(); |     qCInfo(LOG_LIB) << "Configuration file" << settings.fileName(); | ||||||
|  |  | ||||||
|     settings.beginGroup("Desktop Entry"); |     settings.beginGroup("Desktop Entry"); | ||||||
|  | |||||||
| @ -15,8 +15,7 @@ | |||||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * |  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
| #ifndef AWFLOATFORMATTER_H | #pragma once | ||||||
| #define AWFLOATFORMATTER_H |  | ||||||
|  |  | ||||||
| #include "awabstractformatter.h" | #include "awabstractformatter.h" | ||||||
|  |  | ||||||
| @ -68,6 +67,3 @@ private: | |||||||
|     int m_precision = -1; |     int m_precision = -1; | ||||||
|     double m_summand = 0.0; |     double m_summand = 0.0; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| #endif /* AWFLOATFORMATTER_H */ |  | ||||||
|  | |||||||
| @ -41,10 +41,10 @@ QString AWJsonFormatter::convert(const QVariant &_value) const | |||||||
|     qCDebug(LOG_LIB) << "Convert value" << _value; |     qCDebug(LOG_LIB) << "Convert value" << _value; | ||||||
|  |  | ||||||
|     // check if _value is string and parse first if required |     // check if _value is string and parse first if required | ||||||
|     QJsonDocument json = _value.userType() == QMetaType::QString ? QJsonDocument::fromJson(_value.toString().toUtf8()) |     auto json = _value.userType() == QMetaType::QString ? QJsonDocument::fromJson(_value.toString().toUtf8()) | ||||||
|                                                         : QJsonDocument::fromVariant(_value); |                                                         : QJsonDocument::fromVariant(_value); | ||||||
|     QVariant converted = json.toVariant(); |     auto converted = json.toVariant(); | ||||||
|     for (auto &element : m_splittedPath) |     for (auto &element : m_path) | ||||||
|         converted = getFromJson(converted, element); |         converted = getFromJson(converted, element); | ||||||
|  |  | ||||||
|     return converted.toString(); |     return converted.toString(); | ||||||
| @ -57,6 +57,7 @@ AWJsonFormatter *AWJsonFormatter::copy(const QString &_fileName, const int _numb | |||||||
|  |  | ||||||
|     auto item = new AWJsonFormatter(parent(), _fileName); |     auto item = new AWJsonFormatter(parent(), _fileName); | ||||||
|     AWAbstractFormatter::copyDefaults(item); |     AWAbstractFormatter::copyDefaults(item); | ||||||
|  |  | ||||||
|     item->setNumber(_number); |     item->setNumber(_number); | ||||||
|     item->setPath(path()); |     item->setPath(path()); | ||||||
|  |  | ||||||
| @ -66,7 +67,8 @@ AWJsonFormatter *AWJsonFormatter::copy(const QString &_fileName, const int _numb | |||||||
|  |  | ||||||
| QString AWJsonFormatter::path() const | QString AWJsonFormatter::path() const | ||||||
| { | { | ||||||
|     return m_path; |     return std::accumulate(m_path.cbegin(), m_path.cend(), QString(""), | ||||||
|  |                            [](auto acc, auto &value) { return QString("%1.%2").arg(acc, value.toString()); }); | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -74,8 +76,14 @@ void AWJsonFormatter::setPath(const QString &_path) | |||||||
| { | { | ||||||
|     qCDebug(LOG_LIB) << "Path" << _path; |     qCDebug(LOG_LIB) << "Path" << _path; | ||||||
|  |  | ||||||
|     m_path = _path; |     m_path.clear(); | ||||||
|     initPath(); |     auto elements = _path.split('.', Qt::SkipEmptyParts); | ||||||
|  |  | ||||||
|  |     for (auto &element : elements) { | ||||||
|  |         bool ok; | ||||||
|  |         auto number = element.toInt(&ok); | ||||||
|  |         m_path.append(ok ? QVariant(number) : QVariant(element)); | ||||||
|  |     } | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -83,7 +91,7 @@ void AWJsonFormatter::readConfiguration() | |||||||
| { | { | ||||||
|     AWAbstractFormatter::readConfiguration(); |     AWAbstractFormatter::readConfiguration(); | ||||||
|  |  | ||||||
|     QSettings settings(fileName(), QSettings::IniFormat); |     QSettings settings(filePath(), QSettings::IniFormat); | ||||||
|  |  | ||||||
|     settings.beginGroup("Desktop Entry"); |     settings.beginGroup("Desktop Entry"); | ||||||
|     setPath(settings.value("X-AW-Path", path()).toString()); |     setPath(settings.value("X-AW-Path", path()).toString()); | ||||||
| @ -129,7 +137,7 @@ void AWJsonFormatter::writeConfiguration() const | |||||||
| { | { | ||||||
|     AWAbstractFormatter::writeConfiguration(); |     AWAbstractFormatter::writeConfiguration(); | ||||||
|  |  | ||||||
|     QSettings settings(writtableConfig(), QSettings::IniFormat); |     QSettings settings(writableConfig(), QSettings::IniFormat); | ||||||
|     qCInfo(LOG_LIB) << "Configuration file" << settings.fileName(); |     qCInfo(LOG_LIB) << "Configuration file" << settings.fileName(); | ||||||
|  |  | ||||||
|     settings.beginGroup("Desktop Entry"); |     settings.beginGroup("Desktop Entry"); | ||||||
| @ -171,19 +179,6 @@ QVariant AWJsonFormatter::getFromMap(const QVariant &_value, const QString &_key | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| void AWJsonFormatter::initPath() |  | ||||||
| { |  | ||||||
|     m_splittedPath.clear(); |  | ||||||
|     QStringList splittedByDot = m_path.split('.', Qt::SkipEmptyParts); |  | ||||||
|  |  | ||||||
|     for (auto &element : splittedByDot) { |  | ||||||
|         bool ok; |  | ||||||
|         int number = element.toInt(&ok); |  | ||||||
|         m_splittedPath.append(ok ? QVariant(number) : QVariant(element)); |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| void AWJsonFormatter::translate(void *_ui) | void AWJsonFormatter::translate(void *_ui) | ||||||
| { | { | ||||||
|     auto ui = reinterpret_cast<Ui::AWJsonFormatter *>(_ui); |     auto ui = reinterpret_cast<Ui::AWJsonFormatter *>(_ui); | ||||||
|  | |||||||
| @ -15,8 +15,7 @@ | |||||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * |  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
| #ifndef AWJSONFORMATTER_H | #pragma once | ||||||
| #define AWJSONFORMATTER_H |  | ||||||
|  |  | ||||||
| #include "awabstractformatter.h" | #include "awabstractformatter.h" | ||||||
|  |  | ||||||
| @ -43,12 +42,7 @@ private: | |||||||
|     static QVariant getFromJson(const QVariant &_value, const QVariant &_element); |     static QVariant getFromJson(const QVariant &_value, const QVariant &_element); | ||||||
|     static QVariant getFromList(const QVariant &_value, int _index); |     static QVariant getFromList(const QVariant &_value, int _index); | ||||||
|     static QVariant getFromMap(const QVariant &_value, const QString &_key); |     static QVariant getFromMap(const QVariant &_value, const QString &_key); | ||||||
|     void initPath(); |  | ||||||
|     void translate(void *_ui) override; |     void translate(void *_ui) override; | ||||||
|     // properties |     // properties | ||||||
|     QString m_path; |     QVariantList m_path; | ||||||
|     QVariantList m_splittedPath; |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| #endif /* AWJSONFORMATTER_H */ |  | ||||||
|  | |||||||
| @ -53,6 +53,7 @@ AWListFormatter *AWListFormatter::copy(const QString &_fileName, const int _numb | |||||||
|  |  | ||||||
|     auto item = new AWListFormatter(parent(), _fileName); |     auto item = new AWListFormatter(parent(), _fileName); | ||||||
|     AWAbstractFormatter::copyDefaults(item); |     AWAbstractFormatter::copyDefaults(item); | ||||||
|  |  | ||||||
|     item->setFilter(filter()); |     item->setFilter(filter()); | ||||||
|     item->setSeparator(separator()); |     item->setSeparator(separator()); | ||||||
|     item->setSorted(isSorted()); |     item->setSorted(isSorted()); | ||||||
| @ -91,7 +92,7 @@ void AWListFormatter::setFilter(const QString &_filter) | |||||||
|  |  | ||||||
| void AWListFormatter::setSeparator(const QString &_separator) | void AWListFormatter::setSeparator(const QString &_separator) | ||||||
| { | { | ||||||
|     qCDebug(LOG_LIB) << "Separtor" << _separator; |     qCDebug(LOG_LIB) << "Separator" << _separator; | ||||||
|  |  | ||||||
|     m_separator = _separator; |     m_separator = _separator; | ||||||
| } | } | ||||||
| @ -109,7 +110,7 @@ void AWListFormatter::readConfiguration() | |||||||
| { | { | ||||||
|     AWAbstractFormatter::readConfiguration(); |     AWAbstractFormatter::readConfiguration(); | ||||||
|  |  | ||||||
|     QSettings settings(fileName(), QSettings::IniFormat); |     QSettings settings(filePath(), QSettings::IniFormat); | ||||||
|  |  | ||||||
|     settings.beginGroup("Desktop Entry"); |     settings.beginGroup("Desktop Entry"); | ||||||
|     setFilter(settings.value("X-AW-Filter", filter()).toString()); |     setFilter(settings.value("X-AW-Filter", filter()).toString()); | ||||||
| @ -161,7 +162,7 @@ void AWListFormatter::writeConfiguration() const | |||||||
| { | { | ||||||
|     AWAbstractFormatter::writeConfiguration(); |     AWAbstractFormatter::writeConfiguration(); | ||||||
|  |  | ||||||
|     QSettings settings(writtableConfig(), QSettings::IniFormat); |     QSettings settings(writableConfig(), QSettings::IniFormat); | ||||||
|     qCInfo(LOG_LIB) << "Configuration file" << settings.fileName(); |     qCInfo(LOG_LIB) << "Configuration file" << settings.fileName(); | ||||||
|  |  | ||||||
|     settings.beginGroup("Desktop Entry"); |     settings.beginGroup("Desktop Entry"); | ||||||
|  | |||||||
| @ -15,8 +15,7 @@ | |||||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * |  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
| #ifndef AWLISTFORMATTER_H | #pragma once | ||||||
| #define AWLISTFORMATTER_H |  | ||||||
|  |  | ||||||
| #include "awabstractformatter.h" | #include "awabstractformatter.h" | ||||||
|  |  | ||||||
| @ -53,6 +52,3 @@ private: | |||||||
|     bool m_sorted = false; |     bool m_sorted = false; | ||||||
|     QRegularExpression m_regex; |     QRegularExpression m_regex; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| #endif /* AWLISTFORMATTER_H */ |  | ||||||
|  | |||||||
| @ -47,6 +47,7 @@ AWNoFormatter *AWNoFormatter::copy(const QString &_fileName, const int _number) | |||||||
|  |  | ||||||
|     auto item = new AWNoFormatter(parent(), _fileName); |     auto item = new AWNoFormatter(parent(), _fileName); | ||||||
|     AWAbstractFormatter::copyDefaults(item); |     AWAbstractFormatter::copyDefaults(item); | ||||||
|  |  | ||||||
|     item->setNumber(_number); |     item->setNumber(_number); | ||||||
|  |  | ||||||
|     return item; |     return item; | ||||||
|  | |||||||
| @ -15,8 +15,7 @@ | |||||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * |  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
| #ifndef AWNOFORMATTER_H | #pragma once | ||||||
| #define AWNOFORMATTER_H |  | ||||||
|  |  | ||||||
| #include "awabstractformatter.h" | #include "awabstractformatter.h" | ||||||
|  |  | ||||||
| @ -35,8 +34,4 @@ public slots: | |||||||
|  |  | ||||||
| private: | private: | ||||||
|     void translate(void *_ui) override; |     void translate(void *_ui) override; | ||||||
|     // properties |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| #endif /* AWNOFORMATTER_H */ |  | ||||||
|  | |||||||
| @ -61,6 +61,7 @@ AWScriptFormatter *AWScriptFormatter::copy(const QString &_fileName, const int _ | |||||||
|  |  | ||||||
|     auto item = new AWScriptFormatter(parent(), _fileName); |     auto item = new AWScriptFormatter(parent(), _fileName); | ||||||
|     AWAbstractFormatter::copyDefaults(item); |     AWAbstractFormatter::copyDefaults(item); | ||||||
|  |  | ||||||
|     item->setAppendCode(appendCode()); |     item->setAppendCode(appendCode()); | ||||||
|     item->setCode(code()); |     item->setCode(code()); | ||||||
|     item->setHasReturn(hasReturn()); |     item->setHasReturn(hasReturn()); | ||||||
| @ -125,7 +126,7 @@ void AWScriptFormatter::readConfiguration() | |||||||
| { | { | ||||||
|     AWAbstractFormatter::readConfiguration(); |     AWAbstractFormatter::readConfiguration(); | ||||||
|  |  | ||||||
|     QSettings settings(fileName(), QSettings::IniFormat); |     QSettings settings(filePath(), QSettings::IniFormat); | ||||||
|  |  | ||||||
|     settings.beginGroup("Desktop Entry"); |     settings.beginGroup("Desktop Entry"); | ||||||
|     setAppendCode(settings.value("X-AW-AppendCode", appendCode()).toBool()); |     setAppendCode(settings.value("X-AW-AppendCode", appendCode()).toBool()); | ||||||
| @ -178,7 +179,7 @@ void AWScriptFormatter::writeConfiguration() const | |||||||
| { | { | ||||||
|     AWAbstractFormatter::writeConfiguration(); |     AWAbstractFormatter::writeConfiguration(); | ||||||
|  |  | ||||||
|     QSettings settings(writtableConfig(), QSettings::IniFormat); |     QSettings settings(writableConfig(), QSettings::IniFormat); | ||||||
|     qCInfo(LOG_LIB) << "Configuration file" << settings.fileName(); |     qCInfo(LOG_LIB) << "Configuration file" << settings.fileName(); | ||||||
|  |  | ||||||
|     settings.beginGroup("Desktop Entry"); |     settings.beginGroup("Desktop Entry"); | ||||||
|  | |||||||
| @ -15,8 +15,7 @@ | |||||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * |  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
| #ifndef AWSCRIPTFORMATTER_H | #pragma once | ||||||
| #define AWSCRIPTFORMATTER_H |  | ||||||
|  |  | ||||||
| #include "awabstractformatter.h" | #include "awabstractformatter.h" | ||||||
|  |  | ||||||
| @ -56,6 +55,3 @@ private: | |||||||
|     bool m_hasReturn = false; |     bool m_hasReturn = false; | ||||||
|     QString m_program; |     QString m_program; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| #endif /* AWSCRIPTFORMATTER_H */ |  | ||||||
|  | |||||||
| @ -53,6 +53,7 @@ AWStringFormatter *AWStringFormatter::copy(const QString &_fileName, const int _ | |||||||
|  |  | ||||||
|     auto item = new AWStringFormatter(parent(), _fileName); |     auto item = new AWStringFormatter(parent(), _fileName); | ||||||
|     AWAbstractFormatter::copyDefaults(item); |     AWAbstractFormatter::copyDefaults(item); | ||||||
|  |  | ||||||
|     item->setCount(count()); |     item->setCount(count()); | ||||||
|     item->setFillChar(fillChar()); |     item->setFillChar(fillChar()); | ||||||
|     item->setForceWidth(forceWidth()); |     item->setForceWidth(forceWidth()); | ||||||
| @ -108,7 +109,7 @@ void AWStringFormatter::readConfiguration() | |||||||
| { | { | ||||||
|     AWAbstractFormatter::readConfiguration(); |     AWAbstractFormatter::readConfiguration(); | ||||||
|  |  | ||||||
|     QSettings settings(fileName(), QSettings::IniFormat); |     QSettings settings(filePath(), QSettings::IniFormat); | ||||||
|  |  | ||||||
|     settings.beginGroup("Desktop Entry"); |     settings.beginGroup("Desktop Entry"); | ||||||
|     setCount(settings.value("X-AW-Width", count()).toInt()); |     setCount(settings.value("X-AW-Width", count()).toInt()); | ||||||
| @ -160,7 +161,7 @@ void AWStringFormatter::writeConfiguration() const | |||||||
| { | { | ||||||
|     AWAbstractFormatter::writeConfiguration(); |     AWAbstractFormatter::writeConfiguration(); | ||||||
|  |  | ||||||
|     QSettings settings(writtableConfig(), QSettings::IniFormat); |     QSettings settings(writableConfig(), QSettings::IniFormat); | ||||||
|     qCInfo(LOG_LIB) << "Configuration file" << settings.fileName(); |     qCInfo(LOG_LIB) << "Configuration file" << settings.fileName(); | ||||||
|  |  | ||||||
|     settings.beginGroup("Desktop Entry"); |     settings.beginGroup("Desktop Entry"); | ||||||
|  | |||||||
| @ -15,8 +15,7 @@ | |||||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * |  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
| #ifndef AWSTRINGFORMATTER_H | #pragma once | ||||||
| #define AWSTRINGFORMATTER_H |  | ||||||
|  |  | ||||||
| #include "awabstractformatter.h" | #include "awabstractformatter.h" | ||||||
|  |  | ||||||
| @ -52,6 +51,3 @@ private: | |||||||
|     QChar m_fillChar = QChar(); |     QChar m_fillChar = QChar(); | ||||||
|     bool m_forceWidth = false; |     bool m_forceWidth = false; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| #endif /* AWSTRINGFORMATTER_H */ |  | ||||||
|  | |||||||
| @ -15,8 +15,7 @@ | |||||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * |  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
| #ifndef EXTITEMAGGREGATOR_H | #pragma once | ||||||
| #define EXTITEMAGGREGATOR_H |  | ||||||
|  |  | ||||||
| #include <KI18n/KLocalizedString> | #include <KI18n/KLocalizedString> | ||||||
|  |  | ||||||
| @ -24,6 +23,8 @@ | |||||||
| #include <QSettings> | #include <QSettings> | ||||||
| #include <QStandardPaths> | #include <QStandardPaths> | ||||||
|  |  | ||||||
|  | #include <ranges> | ||||||
|  |  | ||||||
| #include "abstractextitemaggregator.h" | #include "abstractextitemaggregator.h" | ||||||
| #include "awdebug.h" | #include "awdebug.h" | ||||||
|  |  | ||||||
| @ -49,10 +50,12 @@ public: | |||||||
|         qCDebug(LOG_LIB) << __PRETTY_FUNCTION__; |         qCDebug(LOG_LIB) << __PRETTY_FUNCTION__; | ||||||
|  |  | ||||||
|         m_items.clear(); |         m_items.clear(); | ||||||
|         m_activeItems.clear(); |  | ||||||
|     }; |     }; | ||||||
|  |  | ||||||
|     QList<T *> activeItems() { return m_activeItems; }; |     auto activeItems() | ||||||
|  |     { | ||||||
|  |         return m_items | std::ranges::views::filter([](auto item) { return item->isActive(); }); | ||||||
|  |     }; | ||||||
|  |  | ||||||
|     void editItems() |     void editItems() | ||||||
|     { |     { | ||||||
| @ -63,14 +66,7 @@ public: | |||||||
|     void initItems() override |     void initItems() override | ||||||
|     { |     { | ||||||
|         m_items.clear(); |         m_items.clear(); | ||||||
|         m_activeItems.clear(); |  | ||||||
|  |  | ||||||
|         m_items = getItems(); |         m_items = getItems(); | ||||||
|         for (auto &item : m_items) { |  | ||||||
|             if (!item->isActive()) |  | ||||||
|                 continue; |  | ||||||
|             m_activeItems.append(static_cast<T *>(item)); |  | ||||||
|         } |  | ||||||
|     }; |     }; | ||||||
|  |  | ||||||
|     void initSockets() |     void initSockets() | ||||||
| @ -78,7 +74,7 @@ public: | |||||||
|         // HACK as soon as per one widget instance we have two objects each of |         // HACK as soon as per one widget instance we have two objects each of | ||||||
|         // them will try to control socket, whereas actually only one of them |         // them will try to control socket, whereas actually only one of them | ||||||
|         // should be owner of the socket |         // should be owner of the socket | ||||||
|         for (auto &item : m_items) |         for (auto item : m_items) | ||||||
|             item->initSocket(); |             item->initSocket(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @ -86,41 +82,34 @@ public: | |||||||
|     { |     { | ||||||
|         qCDebug(LOG_LIB) << "Tag" << _tag << "with used type" << _type; |         qCDebug(LOG_LIB) << "Tag" << _tag << "with used type" << _type; | ||||||
|  |  | ||||||
|         T *found = nullptr; |         auto found = std::find_if(m_items.cbegin(), m_items.cend(), | ||||||
|         for (auto &item : m_items) { |                                   [&_tag, &_type](auto item) { return item->tag(_type) == _tag; }); | ||||||
|             if (item->tag(_type) != _tag) |  | ||||||
|                 continue; |  | ||||||
|             found = static_cast<T *>(item); |  | ||||||
|             break; |  | ||||||
|         } |  | ||||||
|         if (found == nullptr) |  | ||||||
|             qCWarning(LOG_LIB) << "Could not find item by tag" << _tag; |  | ||||||
|  |  | ||||||
|         return found; |         if (found == std::end(m_items)) { | ||||||
|  |             qCWarning(LOG_LIB) << "Could not find item by tag" << _tag; | ||||||
|  |             return nullptr; | ||||||
|  |         } | ||||||
|  |         return static_cast<T *>(*found); | ||||||
|     }; |     }; | ||||||
|  |  | ||||||
|     T *itemByTagNumber(const int _number) const |     T *itemByTagNumber(const int _number) const | ||||||
|     { |     { | ||||||
|         qCDebug(LOG_LIB) << "Number" << _number; |         qCDebug(LOG_LIB) << "Number" << _number; | ||||||
|  |  | ||||||
|         T *found = nullptr; |         auto found = std::find_if(m_items.cbegin(), m_items.cend(), | ||||||
|         for (auto &item : m_items) { |                                   [_number](auto item) { return item->number() == _number; }); | ||||||
|             if (item->number() != _number) |  | ||||||
|                 continue; |  | ||||||
|             found = static_cast<T *>(item); |  | ||||||
|             break; |  | ||||||
|         } |  | ||||||
|         if (found == nullptr) |  | ||||||
|             qCWarning(LOG_LIB) << "Could not find item by number" << _number; |  | ||||||
|  |  | ||||||
|         return found; |         if (found == std::end(m_items)) { | ||||||
|  |             qCWarning(LOG_LIB) << "Could not find item by number" << _number; | ||||||
|  |             return nullptr; | ||||||
|  |         } | ||||||
|  |         return static_cast<T *>(*found); | ||||||
|     }; |     }; | ||||||
|  |  | ||||||
|     [[nodiscard]] QList<AbstractExtItem *> items() const override { return m_items; }; |     [[nodiscard]] QList<AbstractExtItem *> items() const override { return m_items; }; | ||||||
|  |  | ||||||
| private: | private: | ||||||
|     QList<AbstractExtItem *> m_items; |     QList<AbstractExtItem *> m_items; | ||||||
|     QList<T *> m_activeItems; |  | ||||||
|  |  | ||||||
|     void doCreateItem(QListWidget *_widget) override { return createItem<T>(_widget); } |     void doCreateItem(QListWidget *_widget) override { return createItem<T>(_widget); } | ||||||
|  |  | ||||||
| @ -128,9 +117,8 @@ private: | |||||||
|     { |     { | ||||||
|         QList<AbstractExtItem *> items; |         QList<AbstractExtItem *> items; | ||||||
|  |  | ||||||
|         auto dirs = directories(); |         for (auto &dir : directories()) { | ||||||
|         for (auto &dir : dirs) { |             auto files = QDir(dir).entryList(QDir::Files, QDir::Name); | ||||||
|             QStringList files = QDir(dir).entryList(QDir::Files, QDir::Name); |  | ||||||
|             for (auto &file : files) { |             for (auto &file : files) { | ||||||
|                 // check filename |                 // check filename | ||||||
|                 if (!file.endsWith(".desktop")) |                 if (!file.endsWith(".desktop")) | ||||||
| @ -138,18 +126,14 @@ private: | |||||||
|                 qCInfo(LOG_LIB) << "Found file" << file << "in" << dir; |                 qCInfo(LOG_LIB) << "Found file" << file << "in" << dir; | ||||||
|                 auto filePath = QString("%1/%2").arg(dir, file); |                 auto filePath = QString("%1/%2").arg(dir, file); | ||||||
|                 // check if already exists |                 // check if already exists | ||||||
|                 if (std::any_of(items.cbegin(), items.cend(), |                 if (std::any_of(items.cbegin(), items.cend(), [&file](auto item) { return item->fileName() == file; })) | ||||||
|                                 [&filePath](AbstractExtItem *item) { return (item->fileName() == filePath); })) |  | ||||||
|                     continue; |                     continue; | ||||||
|                 items.append(new T(this, filePath)); |                 items.append(new T(this, filePath)); | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|  |  | ||||||
|         // sort items |         // sort items | ||||||
|         std::sort(items.begin(), items.end(), [](auto *lhs, auto *rhs) { return lhs->number() < rhs->number(); }); |         std::sort(items.begin(), items.end(), [](auto lhs, auto rhs) { return lhs->number() < rhs->number(); }); | ||||||
|         return items; |         return items; | ||||||
|     }; |     }; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| #endif /* EXTITEMAGGREGATOR_H */ |  | ||||||
|  | |||||||
| @ -40,9 +40,8 @@ ExtNetworkRequest::ExtNetworkRequest(QObject *_parent, const QString &_filePath) | |||||||
|     // HACK declare as child of nullptr to avoid crash with plasmawindowed |     // HACK declare as child of nullptr to avoid crash with plasmawindowed | ||||||
|     // in the destructor |     // in the destructor | ||||||
|     m_manager = new QNetworkAccessManager(nullptr); |     m_manager = new QNetworkAccessManager(nullptr); | ||||||
|     connect(m_manager, SIGNAL(finished(QNetworkReply *)), this, SLOT(networkReplyReceived(QNetworkReply *))); |     connect(m_manager, &QNetworkAccessManager::finished, this, &ExtNetworkRequest::networkReplyReceived); | ||||||
|  |     connect(this, &ExtNetworkRequest::requestDataUpdate, this, &ExtNetworkRequest::sendRequest); | ||||||
|     connect(this, SIGNAL(requestDataUpdate()), this, SLOT(sendRequest())); |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -50,9 +49,6 @@ ExtNetworkRequest::~ExtNetworkRequest() | |||||||
| { | { | ||||||
|     qCDebug(LOG_LIB) << __PRETTY_FUNCTION__; |     qCDebug(LOG_LIB) << __PRETTY_FUNCTION__; | ||||||
|  |  | ||||||
|     disconnect(m_manager, SIGNAL(finished(QNetworkReply *)), this, SLOT(networkReplyReceived(QNetworkReply *))); |  | ||||||
|     disconnect(this, SIGNAL(requestDataUpdate()), this, SLOT(sendRequest())); |  | ||||||
|  |  | ||||||
|     m_manager->deleteLater(); |     m_manager->deleteLater(); | ||||||
| } | } | ||||||
|  |  | ||||||
| @ -63,31 +59,31 @@ ExtNetworkRequest *ExtNetworkRequest::copy(const QString &_fileName, const int _ | |||||||
|  |  | ||||||
|     auto item = new ExtNetworkRequest(parent(), _fileName); |     auto item = new ExtNetworkRequest(parent(), _fileName); | ||||||
|     copyDefaults(item); |     copyDefaults(item); | ||||||
|  |  | ||||||
|     item->setNumber(_number); |     item->setNumber(_number); | ||||||
|     item->setStringUrl(stringUrl()); |     item->setUrl(url()); | ||||||
|  |  | ||||||
|     return item; |     return item; | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| QString ExtNetworkRequest::stringUrl() const | QString ExtNetworkRequest::url() const | ||||||
| { |  | ||||||
|     return m_stringUrl; |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| QString ExtNetworkRequest::uniq() const |  | ||||||
| { | { | ||||||
|     return m_url.toString(); |     return m_url.toString(); | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| void ExtNetworkRequest::setStringUrl(const QString &_url) | QString ExtNetworkRequest::uniq() const | ||||||
|  | { | ||||||
|  |     return url(); | ||||||
|  | } | ||||||
|  |  | ||||||
|  |  | ||||||
|  | void ExtNetworkRequest::setUrl(const QString &_url) | ||||||
| { | { | ||||||
|     qCDebug(LOG_LIB) << "Url" << _url; |     qCDebug(LOG_LIB) << "Url" << _url; | ||||||
|  |  | ||||||
|     m_stringUrl = _url; |     m_url = QUrl(_url); | ||||||
|     initUrl(); |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -95,10 +91,10 @@ void ExtNetworkRequest::readConfiguration() | |||||||
| { | { | ||||||
|     AbstractExtItem::readConfiguration(); |     AbstractExtItem::readConfiguration(); | ||||||
|  |  | ||||||
|     QSettings settings(fileName(), QSettings::IniFormat); |     QSettings settings(filePath(), QSettings::IniFormat); | ||||||
|  |  | ||||||
|     settings.beginGroup("Desktop Entry"); |     settings.beginGroup("Desktop Entry"); | ||||||
|     setStringUrl(settings.value("X-AW-Url", stringUrl()).toString()); |     setUrl(settings.value("X-AW-Url", url()).toString()); | ||||||
|     settings.endGroup(); |     settings.endGroup(); | ||||||
|  |  | ||||||
|     bumpApi(AW_EXTNETREQUEST_API); |     bumpApi(AW_EXTNETREQUEST_API); | ||||||
| @ -127,7 +123,7 @@ int ExtNetworkRequest::showConfiguration(QWidget *_parent, const QVariant &_args | |||||||
|     ui->lineEdit_name->setText(name()); |     ui->lineEdit_name->setText(name()); | ||||||
|     ui->lineEdit_comment->setText(comment()); |     ui->lineEdit_comment->setText(comment()); | ||||||
|     ui->label_numberValue->setText(QString("%1").arg(number())); |     ui->label_numberValue->setText(QString("%1").arg(number())); | ||||||
|     ui->lineEdit_url->setText(stringUrl()); |     ui->lineEdit_url->setText(url()); | ||||||
|     ui->checkBox_active->setCheckState(isActive() ? Qt::Checked : Qt::Unchecked); |     ui->checkBox_active->setCheckState(isActive() ? Qt::Checked : Qt::Unchecked); | ||||||
|     ui->lineEdit_schedule->setText(cron()); |     ui->lineEdit_schedule->setText(cron()); | ||||||
|     ui->lineEdit_socket->setText(socket()); |     ui->lineEdit_socket->setText(socket()); | ||||||
| @ -139,7 +135,7 @@ int ExtNetworkRequest::showConfiguration(QWidget *_parent, const QVariant &_args | |||||||
|         setComment(ui->lineEdit_comment->text()); |         setComment(ui->lineEdit_comment->text()); | ||||||
|         setNumber(ui->label_numberValue->text().toInt()); |         setNumber(ui->label_numberValue->text().toInt()); | ||||||
|         setApiVersion(AW_EXTNETREQUEST_API); |         setApiVersion(AW_EXTNETREQUEST_API); | ||||||
|         setStringUrl(ui->lineEdit_url->text()); |         setUrl(ui->lineEdit_url->text()); | ||||||
|         setActive(ui->checkBox_active->checkState() == Qt::Checked); |         setActive(ui->checkBox_active->checkState() == Qt::Checked); | ||||||
|         setCron(ui->lineEdit_schedule->text()); |         setCron(ui->lineEdit_schedule->text()); | ||||||
|         setSocket(ui->lineEdit_socket->text()); |         setSocket(ui->lineEdit_socket->text()); | ||||||
| @ -159,11 +155,11 @@ void ExtNetworkRequest::writeConfiguration() const | |||||||
| { | { | ||||||
|     AbstractExtItem::writeConfiguration(); |     AbstractExtItem::writeConfiguration(); | ||||||
|  |  | ||||||
|     QSettings settings(writtableConfig(), QSettings::IniFormat); |     QSettings settings(writableConfig(), QSettings::IniFormat); | ||||||
|     qCInfo(LOG_LIB) << "Configuration file" << settings.fileName(); |     qCInfo(LOG_LIB) << "Configuration file" << settings.fileName(); | ||||||
|  |  | ||||||
|     settings.beginGroup("Desktop Entry"); |     settings.beginGroup("Desktop Entry"); | ||||||
|     settings.setValue("X-AW-Url", stringUrl()); |     settings.setValue("X-AW-Url", url()); | ||||||
|     settings.endGroup(); |     settings.endGroup(); | ||||||
|  |  | ||||||
|     settings.sync(); |     settings.sync(); | ||||||
| @ -191,12 +187,6 @@ void ExtNetworkRequest::sendRequest() | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| void ExtNetworkRequest::initUrl() |  | ||||||
| { |  | ||||||
|     m_url = QUrl(m_stringUrl); |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| void ExtNetworkRequest::translate(void *_ui) | void ExtNetworkRequest::translate(void *_ui) | ||||||
| { | { | ||||||
|     auto ui = reinterpret_cast<Ui::ExtNetworkRequest *>(_ui); |     auto ui = reinterpret_cast<Ui::ExtNetworkRequest *>(_ui); | ||||||
|  | |||||||
| @ -15,8 +15,7 @@ | |||||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * |  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
| #ifndef EXTNETWORKREQUEST_H | #pragma once | ||||||
| #define EXTNETWORKREQUEST_H |  | ||||||
|  |  | ||||||
| #include <QNetworkReply> | #include <QNetworkReply> | ||||||
|  |  | ||||||
| @ -26,17 +25,17 @@ | |||||||
| class ExtNetworkRequest : public AbstractExtItem | class ExtNetworkRequest : public AbstractExtItem | ||||||
| { | { | ||||||
|     Q_OBJECT |     Q_OBJECT | ||||||
|     Q_PROPERTY(QString stringUrl READ stringUrl WRITE setStringUrl) |     Q_PROPERTY(QString url READ url WRITE setUrl) | ||||||
|  |  | ||||||
| public: | public: | ||||||
|     explicit ExtNetworkRequest(QObject *_parent = nullptr, const QString &_filePath = ""); |     explicit ExtNetworkRequest(QObject *_parent = nullptr, const QString &_filePath = ""); | ||||||
|     ~ExtNetworkRequest() override; |     ~ExtNetworkRequest() override; | ||||||
|     ExtNetworkRequest *copy(const QString &_fileName, int _number) override; |     ExtNetworkRequest *copy(const QString &_fileName, int _number) override; | ||||||
|     // get methods |     // get methods | ||||||
|     [[nodiscard]] QString stringUrl() const; |     [[nodiscard]] QString url() const; | ||||||
|     [[nodiscard]] QString uniq() const override; |     [[nodiscard]] QString uniq() const override; | ||||||
|     // set methods |     // set methods | ||||||
|     void setStringUrl(const QString &_url); |     void setUrl(const QString &_url); | ||||||
|  |  | ||||||
| public slots: | public slots: | ||||||
|     void readConfiguration() override; |     void readConfiguration() override; | ||||||
| @ -52,13 +51,9 @@ private: | |||||||
|     QNetworkAccessManager *m_manager = nullptr; |     QNetworkAccessManager *m_manager = nullptr; | ||||||
|     QUrl m_url; |     QUrl m_url; | ||||||
|     bool m_isRunning = false; |     bool m_isRunning = false; | ||||||
|     void initUrl(); |  | ||||||
|     void translate(void *_ui) override; |     void translate(void *_ui) override; | ||||||
|     // properties |     // properties | ||||||
|     QString m_stringUrl = "https://httpbin.org/get"; |     QString m_stringUrl = "https://httpbin.org/get"; | ||||||
|     // values |     // values | ||||||
|     QVariantHash m_values; |     QVariantHash m_values; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| #endif /* EXTNETWORKREQUEST_H */ |  | ||||||
|  | |||||||
| @ -46,9 +46,8 @@ ExtQuotes::ExtQuotes(QObject *_parent, const QString &_filePath) | |||||||
|     // HACK declare as child of nullptr to avoid crash with plasmawindowed |     // HACK declare as child of nullptr to avoid crash with plasmawindowed | ||||||
|     // in the destructor |     // in the destructor | ||||||
|     m_manager = new QNetworkAccessManager(nullptr); |     m_manager = new QNetworkAccessManager(nullptr); | ||||||
|     connect(m_manager, SIGNAL(finished(QNetworkReply *)), this, SLOT(quotesReplyReceived(QNetworkReply *))); |     connect(m_manager, &QNetworkAccessManager::finished, this, &ExtQuotes::quotesReplyReceived); | ||||||
|  |     connect(this, &ExtQuotes::requestDataUpdate, this, &ExtQuotes::sendRequest); | ||||||
|     connect(this, SIGNAL(requestDataUpdate()), this, SLOT(sendRequest())); |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -56,9 +55,6 @@ ExtQuotes::~ExtQuotes() | |||||||
| { | { | ||||||
|     qCDebug(LOG_LIB) << __PRETTY_FUNCTION__; |     qCDebug(LOG_LIB) << __PRETTY_FUNCTION__; | ||||||
|  |  | ||||||
|     disconnect(m_manager, SIGNAL(finished(QNetworkReply *)), this, SLOT(quotesReplyReceived(QNetworkReply *))); |  | ||||||
|     disconnect(this, SIGNAL(requestDataUpdate()), this, SLOT(sendRequest())); |  | ||||||
|  |  | ||||||
|     m_manager->deleteLater(); |     m_manager->deleteLater(); | ||||||
| } | } | ||||||
|  |  | ||||||
| @ -69,6 +65,7 @@ ExtQuotes *ExtQuotes::copy(const QString &_fileName, const int _number) | |||||||
|  |  | ||||||
|     auto item = new ExtQuotes(parent(), _fileName); |     auto item = new ExtQuotes(parent(), _fileName); | ||||||
|     copyDefaults(item); |     copyDefaults(item); | ||||||
|  |  | ||||||
|     item->setNumber(_number); |     item->setNumber(_number); | ||||||
|     item->setTicker(ticker()); |     item->setTicker(ticker()); | ||||||
|  |  | ||||||
| @ -101,7 +98,7 @@ void ExtQuotes::readConfiguration() | |||||||
| { | { | ||||||
|     AbstractExtItem::readConfiguration(); |     AbstractExtItem::readConfiguration(); | ||||||
|  |  | ||||||
|     QSettings settings(fileName(), QSettings::IniFormat); |     QSettings settings(filePath(), QSettings::IniFormat); | ||||||
|  |  | ||||||
|     settings.beginGroup("Desktop Entry"); |     settings.beginGroup("Desktop Entry"); | ||||||
|     setTicker(settings.value("X-AW-Ticker", ticker()).toString()); |     setTicker(settings.value("X-AW-Ticker", ticker()).toString()); | ||||||
| @ -165,7 +162,7 @@ void ExtQuotes::writeConfiguration() const | |||||||
| { | { | ||||||
|     AbstractExtItem::writeConfiguration(); |     AbstractExtItem::writeConfiguration(); | ||||||
|  |  | ||||||
|     QSettings settings(writtableConfig(), QSettings::IniFormat); |     QSettings settings(writableConfig(), QSettings::IniFormat); | ||||||
|     qCInfo(LOG_LIB) << "Configuration file" << settings.fileName(); |     qCInfo(LOG_LIB) << "Configuration file" << settings.fileName(); | ||||||
|  |  | ||||||
|     settings.beginGroup("Desktop Entry"); |     settings.beginGroup("Desktop Entry"); | ||||||
| @ -186,10 +183,10 @@ void ExtQuotes::quotesReplyReceived(QNetworkReply *_reply) | |||||||
|     auto text = _reply->readAll(); |     auto text = _reply->readAll(); | ||||||
|     _reply->deleteLater(); |     _reply->deleteLater(); | ||||||
|  |  | ||||||
|     auto data = m_providerObject->parse(text, m_values); |     auto data = m_providerObject->parse(text); | ||||||
|     if (data.isEmpty()) |     for (auto [key, value] : data.asKeyValueRange()) { | ||||||
|         return; |         m_values[tag(key)] = value; | ||||||
|     m_values = data; |     } | ||||||
|  |  | ||||||
|     emit(dataReceived(m_values)); |     emit(dataReceived(m_values)); | ||||||
| } | } | ||||||
| @ -205,10 +202,8 @@ void ExtQuotes::sendRequest() | |||||||
|  |  | ||||||
| void ExtQuotes::initProvider() | void ExtQuotes::initProvider() | ||||||
| { | { | ||||||
|     delete m_providerObject; |  | ||||||
|  |  | ||||||
|     // in the future release it is possible to change provider here |     // in the future release it is possible to change provider here | ||||||
|     m_providerObject = new StooqQuotesProvider(this); |     m_providerObject = std::make_unique<StooqQuotesProvider>(); | ||||||
|  |  | ||||||
|     return m_providerObject->initUrl(ticker()); |     return m_providerObject->initUrl(ticker()); | ||||||
| } | } | ||||||
|  | |||||||
| @ -15,8 +15,7 @@ | |||||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * |  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
| #ifndef EXTQUOTES_H | #pragma once | ||||||
| #define EXTQUOTES_H |  | ||||||
|  |  | ||||||
| #include <QNetworkReply> | #include <QNetworkReply> | ||||||
|  |  | ||||||
| @ -51,7 +50,7 @@ private slots: | |||||||
|     void sendRequest(); |     void sendRequest(); | ||||||
|  |  | ||||||
| private: | private: | ||||||
|     AbstractQuotesProvider *m_providerObject = nullptr; |     std::unique_ptr<AbstractQuotesProvider> m_providerObject; | ||||||
|     QNetworkAccessManager *m_manager = nullptr; |     QNetworkAccessManager *m_manager = nullptr; | ||||||
|     bool m_isRunning = false; |     bool m_isRunning = false; | ||||||
|     void initProvider(); |     void initProvider(); | ||||||
| @ -61,6 +60,3 @@ private: | |||||||
|     // values |     // values | ||||||
|     QVariantHash m_values; |     QVariantHash m_values; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| #endif /* EXTQUOTES_H */ |  | ||||||
|  | |||||||
| @ -40,10 +40,10 @@ ExtScript::ExtScript(QObject *_parent, const QString &_filePath) | |||||||
|     m_values[tag("custom")] = ""; |     m_values[tag("custom")] = ""; | ||||||
|  |  | ||||||
|     m_process = new QProcess(nullptr); |     m_process = new QProcess(nullptr); | ||||||
|     connect(m_process, SIGNAL(finished(int, QProcess::ExitStatus)), this, SLOT(updateValue())); |     connect(m_process, &QProcess::finished, [this]() { return updateValue(); }); | ||||||
|     m_process->waitForFinished(0); |     m_process->waitForFinished(0); | ||||||
|  |  | ||||||
|     connect(this, SIGNAL(requestDataUpdate()), this, SLOT(startProcess())); |     connect(this, &ExtScript::requestDataUpdate, this, &ExtScript::startProcess); | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -51,10 +51,8 @@ ExtScript::~ExtScript() | |||||||
| { | { | ||||||
|     qCDebug(LOG_LIB) << __PRETTY_FUNCTION__; |     qCDebug(LOG_LIB) << __PRETTY_FUNCTION__; | ||||||
|  |  | ||||||
|     disconnect(m_process, SIGNAL(finished(int, QProcess::ExitStatus)), this, SLOT(updateValue())); |  | ||||||
|     m_process->kill(); |     m_process->kill(); | ||||||
|     m_process->deleteLater(); |     m_process->deleteLater(); | ||||||
|     disconnect(this, SIGNAL(requestDataUpdate()), this, SLOT(startProcess())); |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -64,6 +62,7 @@ ExtScript *ExtScript::copy(const QString &_fileName, const int _number) | |||||||
|  |  | ||||||
|     auto item = new ExtScript(parent(), _fileName); |     auto item = new ExtScript(parent(), _fileName); | ||||||
|     copyDefaults(item); |     copyDefaults(item); | ||||||
|  |  | ||||||
|     item->setExecutable(executable()); |     item->setExecutable(executable()); | ||||||
|     item->setNumber(_number); |     item->setNumber(_number); | ||||||
|     item->setRedirect(redirect()); |     item->setRedirect(redirect()); | ||||||
| @ -180,8 +179,8 @@ QString ExtScript::applyFilters(QString _value) const | |||||||
|             qCWarning(LOG_LIB) << "Could not find filter" << _value << "in the json"; |             qCWarning(LOG_LIB) << "Could not find filter" << _value << "in the json"; | ||||||
|             continue; |             continue; | ||||||
|         } |         } | ||||||
|         for (auto &f : filter.keys()) |         for (auto [key, value] : filter.asKeyValueRange()) | ||||||
|             _value.replace(f, filter[f].toString()); |             _value.replace(key, value.toString()); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     return _value; |     return _value; | ||||||
| @ -206,7 +205,7 @@ void ExtScript::readConfiguration() | |||||||
| { | { | ||||||
|     AbstractExtItem::readConfiguration(); |     AbstractExtItem::readConfiguration(); | ||||||
|  |  | ||||||
|     QSettings settings(fileName(), QSettings::IniFormat); |     QSettings settings(filePath(), QSettings::IniFormat); | ||||||
|  |  | ||||||
|     settings.beginGroup("Desktop Entry"); |     settings.beginGroup("Desktop Entry"); | ||||||
|     setExecutable(settings.value("Exec", executable()).toString()); |     setExecutable(settings.value("Exec", executable()).toString()); | ||||||
| @ -227,11 +226,11 @@ void ExtScript::readJsonFilters() | |||||||
|         qCWarning(LOG_LIB) << "Could not open" << fileName; |         qCWarning(LOG_LIB) << "Could not open" << fileName; | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|     QString jsonText = jsonFile.readAll(); |     auto jsonText = jsonFile.readAll(); | ||||||
|     jsonFile.close(); |     jsonFile.close(); | ||||||
|  |  | ||||||
|     QJsonParseError error{}; |     QJsonParseError error{}; | ||||||
|     auto jsonDoc = QJsonDocument::fromJson(jsonText.toUtf8(), &error); |     auto jsonDoc = QJsonDocument::fromJson(jsonText, &error); | ||||||
|     if (error.error != QJsonParseError::NoError) { |     if (error.error != QJsonParseError::NoError) { | ||||||
|         qCWarning(LOG_LIB) << "Parse error" << error.errorString(); |         qCWarning(LOG_LIB) << "Parse error" << error.errorString(); | ||||||
|         return; |         return; | ||||||
| @ -306,7 +305,7 @@ void ExtScript::writeConfiguration() const | |||||||
| { | { | ||||||
|     AbstractExtItem::writeConfiguration(); |     AbstractExtItem::writeConfiguration(); | ||||||
|  |  | ||||||
|     QSettings settings(writtableConfig(), QSettings::IniFormat); |     QSettings settings(writableConfig(), QSettings::IniFormat); | ||||||
|     qCInfo(LOG_LIB) << "Configuration file" << settings.fileName(); |     qCInfo(LOG_LIB) << "Configuration file" << settings.fileName(); | ||||||
|  |  | ||||||
|     settings.beginGroup("Desktop Entry"); |     settings.beginGroup("Desktop Entry"); | ||||||
| @ -333,24 +332,24 @@ void ExtScript::updateValue() | |||||||
|     qCInfo(LOG_LIB) << "Error" << qdebug; |     qCInfo(LOG_LIB) << "Error" << qdebug; | ||||||
|     auto qoutput = QString::fromUtf8(m_process->readAllStandardOutput()).trimmed(); |     auto qoutput = QString::fromUtf8(m_process->readAllStandardOutput()).trimmed(); | ||||||
|     qCInfo(LOG_LIB) << "Output" << qoutput; |     qCInfo(LOG_LIB) << "Output" << qoutput; | ||||||
|     QString strValue; |  | ||||||
|  |  | ||||||
|  |     QString result; | ||||||
|     switch (redirect()) { |     switch (redirect()) { | ||||||
|     case Redirect::stdout2stderr: |     case Redirect::stdout2stderr: | ||||||
|         break; |         break; | ||||||
|     case Redirect::stderr2stdout: |     case Redirect::stderr2stdout: | ||||||
|         strValue = QString("%1\n%2").arg(qdebug).arg(qoutput); |         result = QString("%1\n%2").arg(qdebug, qoutput); | ||||||
|         break; |         break; | ||||||
|     case Redirect::swap: |     case Redirect::swap: | ||||||
|         strValue = qdebug; |         result = qdebug; | ||||||
|         break; |         break; | ||||||
|     case Redirect::nothing: |     case Redirect::nothing: | ||||||
|         strValue = qoutput; |         result = qoutput; | ||||||
|         break; |         break; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     // filters |     // filters | ||||||
|     m_values[tag("custom")] = applyFilters(strValue); |     m_values[tag("custom")] = applyFilters(result); | ||||||
|     emit(dataReceived(m_values)); |     emit(dataReceived(m_values)); | ||||||
| } | } | ||||||
|  |  | ||||||
|  | |||||||
| @ -15,8 +15,7 @@ | |||||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * |  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
| #ifndef EXTSCRIPT_H | #pragma once | ||||||
| #define EXTSCRIPT_H |  | ||||||
|  |  | ||||||
| #include <QProcess> | #include <QProcess> | ||||||
|  |  | ||||||
| @ -76,6 +75,3 @@ private: | |||||||
|     QVariantMap m_jsonFilters; |     QVariantMap m_jsonFilters; | ||||||
|     QVariantHash m_values; |     QVariantHash m_values; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| #endif /* EXTSCRIPT_H */ |  | ||||||
|  | |||||||
| @ -36,10 +36,10 @@ ExtUpgrade::ExtUpgrade(QObject *_parent, const QString &_filePath) | |||||||
|     m_values[tag("pkgcount")] = 0; |     m_values[tag("pkgcount")] = 0; | ||||||
|  |  | ||||||
|     m_process = new QProcess(nullptr); |     m_process = new QProcess(nullptr); | ||||||
|     connect(m_process, SIGNAL(finished(int)), this, SLOT(updateValue())); |     connect(m_process, &QProcess::finished, this, &ExtUpgrade::updateValue); | ||||||
|     m_process->waitForFinished(0); |     m_process->waitForFinished(0); | ||||||
|  |  | ||||||
|     connect(this, SIGNAL(requestDataUpdate()), this, SLOT(startProcess())); |     connect(this, &ExtUpgrade::requestDataUpdate, this, &ExtUpgrade::startProcess); | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -49,7 +49,6 @@ ExtUpgrade::~ExtUpgrade() | |||||||
|  |  | ||||||
|     m_process->kill(); |     m_process->kill(); | ||||||
|     m_process->deleteLater(); |     m_process->deleteLater(); | ||||||
|     disconnect(this, SIGNAL(requestDataUpdate()), this, SLOT(startProcess())); |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -59,6 +58,7 @@ ExtUpgrade *ExtUpgrade::copy(const QString &_fileName, const int _number) | |||||||
|  |  | ||||||
|     auto item = new ExtUpgrade(parent(), _fileName); |     auto item = new ExtUpgrade(parent(), _fileName); | ||||||
|     copyDefaults(item); |     copyDefaults(item); | ||||||
|  |  | ||||||
|     item->setExecutable(executable()); |     item->setExecutable(executable()); | ||||||
|     item->setFilter(filter()); |     item->setFilter(filter()); | ||||||
|     item->setNumber(_number); |     item->setNumber(_number); | ||||||
| @ -122,7 +122,7 @@ void ExtUpgrade::readConfiguration() | |||||||
| { | { | ||||||
|     AbstractExtItem::readConfiguration(); |     AbstractExtItem::readConfiguration(); | ||||||
|  |  | ||||||
|     QSettings settings(fileName(), QSettings::IniFormat); |     QSettings settings(filePath(), QSettings::IniFormat); | ||||||
|  |  | ||||||
|     settings.beginGroup("Desktop Entry"); |     settings.beginGroup("Desktop Entry"); | ||||||
|     setExecutable(settings.value("Exec", executable()).toString()); |     setExecutable(settings.value("Exec", executable()).toString()); | ||||||
| @ -193,7 +193,7 @@ void ExtUpgrade::writeConfiguration() const | |||||||
| { | { | ||||||
|     AbstractExtItem::writeConfiguration(); |     AbstractExtItem::writeConfiguration(); | ||||||
|  |  | ||||||
|     QSettings settings(writtableConfig(), QSettings::IniFormat); |     QSettings settings(writableConfig(), QSettings::IniFormat); | ||||||
|     qCInfo(LOG_LIB) << "Configuration file" << settings.fileName(); |     qCInfo(LOG_LIB) << "Configuration file" << settings.fileName(); | ||||||
|  |  | ||||||
|     settings.beginGroup("Desktop Entry"); |     settings.beginGroup("Desktop Entry"); | ||||||
|  | |||||||
| @ -15,8 +15,7 @@ | |||||||
|  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * |  *   along with awesome-widgets. If not, see http://www.gnu.org/licenses/  * | ||||||
|  ***************************************************************************/ |  ***************************************************************************/ | ||||||
|  |  | ||||||
| #ifndef EXTUPGRADE_H | #pragma once | ||||||
| #define EXTUPGRADE_H |  | ||||||
|  |  | ||||||
| #include <QProcess> | #include <QProcess> | ||||||
|  |  | ||||||
| @ -64,6 +63,3 @@ private: | |||||||
|     // internal properties |     // internal properties | ||||||
|     QVariantHash m_values; |     QVariantHash m_values; | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| #endif /* EXTUPGRADE_H */ |  | ||||||
|  | |||||||
| @ -49,9 +49,8 @@ ExtWeather::ExtWeather(QObject *_parent, const QString &_filePath) | |||||||
|     // HACK declare as child of nullptr to avoid crash with plasmawindowed |     // HACK declare as child of nullptr to avoid crash with plasmawindowed | ||||||
|     // in the destructor |     // in the destructor | ||||||
|     m_manager = new QNetworkAccessManager(nullptr); |     m_manager = new QNetworkAccessManager(nullptr); | ||||||
|     connect(m_manager, SIGNAL(finished(QNetworkReply *)), this, SLOT(weatherReplyReceived(QNetworkReply *))); |     connect(m_manager, &QNetworkAccessManager::finished, this, &ExtWeather::weatherReplyReceived); | ||||||
|  |     connect(this, &ExtWeather::requestDataUpdate, this, &ExtWeather::sendRequest); | ||||||
|     connect(this, SIGNAL(requestDataUpdate()), this, SLOT(sendRequest())); |  | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -59,9 +58,6 @@ ExtWeather::~ExtWeather() | |||||||
| { | { | ||||||
|     qCDebug(LOG_LIB) << __PRETTY_FUNCTION__; |     qCDebug(LOG_LIB) << __PRETTY_FUNCTION__; | ||||||
|  |  | ||||||
|     disconnect(m_manager, SIGNAL(finished(QNetworkReply *)), this, SLOT(weatherReplyReceived(QNetworkReply *))); |  | ||||||
|     disconnect(this, SIGNAL(requestDataUpdate()), this, SLOT(sendRequest())); |  | ||||||
|  |  | ||||||
|     m_manager->deleteLater(); |     m_manager->deleteLater(); | ||||||
| } | } | ||||||
|  |  | ||||||
| @ -72,6 +68,7 @@ ExtWeather *ExtWeather::copy(const QString &_fileName, const int _number) | |||||||
|  |  | ||||||
|     auto item = new ExtWeather(parent(), _fileName); |     auto item = new ExtWeather(parent(), _fileName); | ||||||
|     copyDefaults(item); |     copyDefaults(item); | ||||||
|  |  | ||||||
|     item->setCity(city()); |     item->setCity(city()); | ||||||
|     item->setCountry(country()); |     item->setCountry(country()); | ||||||
|     item->setImage(image()); |     item->setImage(image()); | ||||||
| @ -150,7 +147,7 @@ int ExtWeather::ts() const | |||||||
|  |  | ||||||
| QString ExtWeather::uniq() const | QString ExtWeather::uniq() const | ||||||
| { | { | ||||||
|     return QString("%1 (%2) at %3").arg(city()).arg(country()).arg(ts()); |     return QString("%1 (%2) at %3").arg(city(), country()).arg(ts()); | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| @ -213,7 +210,7 @@ void ExtWeather::readConfiguration() | |||||||
| { | { | ||||||
|     AbstractExtItem::readConfiguration(); |     AbstractExtItem::readConfiguration(); | ||||||
|  |  | ||||||
|     QSettings settings(fileName(), QSettings::IniFormat); |     QSettings settings(filePath(), QSettings::IniFormat); | ||||||
|  |  | ||||||
|     settings.beginGroup("Desktop Entry"); |     settings.beginGroup("Desktop Entry"); | ||||||
|     setCity(settings.value("X-AW-City", city()).toString()); |     setCity(settings.value("X-AW-City", city()).toString()); | ||||||
| @ -237,11 +234,11 @@ void ExtWeather::readJsonMap() | |||||||
|         qCWarning(LOG_LIB) << "Could not open" << fileName; |         qCWarning(LOG_LIB) << "Could not open" << fileName; | ||||||
|         return; |         return; | ||||||
|     } |     } | ||||||
|     QString jsonText = jsonFile.readAll(); |     auto jsonText = jsonFile.readAll(); | ||||||
|     jsonFile.close(); |     jsonFile.close(); | ||||||
|  |  | ||||||
|     QJsonParseError error{}; |     QJsonParseError error{}; | ||||||
|     auto jsonDoc = QJsonDocument::fromJson(jsonText.toUtf8(), &error); |     auto jsonDoc = QJsonDocument::fromJson(jsonText, &error); | ||||||
|     if (error.error != QJsonParseError::NoError) { |     if (error.error != QJsonParseError::NoError) { | ||||||
|         qCWarning(LOG_LIB) << "Parse error" << error.errorString(); |         qCWarning(LOG_LIB) << "Parse error" << error.errorString(); | ||||||
|         return; |         return; | ||||||
| @ -314,7 +311,7 @@ void ExtWeather::writeConfiguration() const | |||||||
| { | { | ||||||
|     AbstractExtItem::writeConfiguration(); |     AbstractExtItem::writeConfiguration(); | ||||||
|  |  | ||||||
|     QSettings settings(writtableConfig(), QSettings::IniFormat); |     QSettings settings(writableConfig(), QSettings::IniFormat); | ||||||
|     qCInfo(LOG_LIB) << "Configuration file" << settings.fileName(); |     qCInfo(LOG_LIB) << "Configuration file" << settings.fileName(); | ||||||
|  |  | ||||||
|     settings.beginGroup("Desktop Entry"); |     settings.beginGroup("Desktop Entry"); | ||||||
| @ -354,9 +351,8 @@ void ExtWeather::weatherReplyReceived(QNetworkReply *_reply) | |||||||
|     } |     } | ||||||
|  |  | ||||||
|     auto data = m_providerObject->parse(jsonDoc.toVariant().toMap()); |     auto data = m_providerObject->parse(jsonDoc.toVariant().toMap()); | ||||||
|     if (data.isEmpty()) |     for (auto [key, value] : data.asKeyValueRange()) | ||||||
|         return; |         m_values[tag(key)] = value; | ||||||
|     m_values = data; |  | ||||||
|     m_values[tag("weather")] = weatherFromInt(m_values[tag("weatherId")].toInt()); |     m_values[tag("weather")] = weatherFromInt(m_values[tag("weatherId")].toInt()); | ||||||
|  |  | ||||||
|     emit(dataReceived(m_values)); |     emit(dataReceived(m_values)); | ||||||
| @ -365,10 +361,8 @@ void ExtWeather::weatherReplyReceived(QNetworkReply *_reply) | |||||||
|  |  | ||||||
| void ExtWeather::initProvider() | void ExtWeather::initProvider() | ||||||
| { | { | ||||||
|     delete m_providerObject; |  | ||||||
|  |  | ||||||
|     // in the future release it is possible to change provider here |     // in the future release it is possible to change provider here | ||||||
|     m_providerObject = new OWMWeatherProvider(this); |     m_providerObject = std::make_unique<OWMWeatherProvider>(); | ||||||
|  |  | ||||||
|     return m_providerObject->initUrl(city(), country(), ts()); |     return m_providerObject->initUrl(city(), country(), ts()); | ||||||
| } | } | ||||||
|  | |||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user