Fully-featured widget to bring Latte-Dock and WM status bar customization features to the default Plasma panel.
Important
Project is under active development. Watch out for BREAKING CHANGES in the Release notes.
-
Found a bug while using Panel Colorizer? Please report it here first, only report it to KDE after we conclude is a upstream issue or you removed the widget and can still reproduce the problem.
-
Make sure you're using the latest version of the widget and as close as possible to the latest Plasma to avoid compatibility issues.
Presets
- Built-in presets
- Create your own presets
- Preset auto-loading
- Fullscreen window
- Maximized window
- Window touching the panel
- At least one window is shown on screen
- Panel is floating
- Normal (fall-back when none of the above are meet)
- Advanced commandline usage with D-Bus (version 2.0.0 or later)
Panel/Widget/System Tray elements
- Color modes
- Static
Animatedremoved in v1.0.0, might re-implement in a future version
- Background / Icons and text color
- Custom
- System
- Custom list
- Random
- Follow parent background
- Shape
- Spacing between widgets
- Radius
- Margins
- Border
- Shadow
- Blur behind (requires building and installing the C++ plugin)
Force Text/Icon color
- Force color to icons that don't follow the theme color for specific widgets
- Mask for symbolic icons
- Effect for colorful icons
- Periodic color refresh for widgets that reset colors when they update (e.g Global Menu)
- Recolor applications System Tray icons
Panel background
- Remove native panel background (transparent)
- Native panel background opacity
- Simulate an always floating panel
Panel settings
- Visibility
- Height
- Floating
- Location
- Length mode
- Alignment
- Opacity (Plasma 6.3.0)
- EXPERIMENTAL Sow/hide panel "AKA toggle panel" with D-Bus, stays hidden when hovering on screen edges
Unified background
- Join one or more widgets to make them visually connected
Configuration overrides
Overrides let you give a completely different configuration to one or more widgets
- Preset overrides (saved in the current preset)
- User overrides (sour own overrides that apply over the preset configuration and overrides)
-
Install these runtime dependencies or the equivalents for your distribution
python python-dbus python-gobject
-
Right click on the Panel > Add or manage widgets > Add new... > Download new...
-
Search for "Panel Colorizer", install and add it to a Panel.
-
Plasma 5 version v0.2.0No longer maintained
-
Install these dependencies or the equivalents for your distribution
-
Arch
git gcc cmake extra-cmake-modules libplasma spectacle python python-dbus python-gobject
-
Fedora
git gcc-c++ cmake extra-cmake-modules libplasma-devel spectacle python3 python3-dbus python3-gobject
Spectacle is optional, will be used to create preset previews
-
-
Clone and install
git clone https://github.com/luisbocanegra/plasma-panel-colorizer cd plasma-panel-colorizer
- Install widget + plugin
./install.sh
- Install only the plugin if you already have the widget
./install-plugin.sh
aur/plasma6-applets-panel-colorizer use your preferred AUR helper e.g:
yay -S plasma6-applets-panel-colorizer
For those using NixOS or the Nix package manager, a Nix package is available in nixpkgs-unstable.
To install the widget use one of these methods:
-
NixOS
environment.systemPackages = with pkgs; [ plasma-panel-colorizer ];
-
home.packages = with pkgs; [ plasma-panel-colorizer ];
-
Plasma-manager: If the widget gets added to a panel it will automatically be installed
-
Other distros using Nix package manager
# without flakes: nix-env -iA nixpkgs.plasma-panel-colorizer # with flakes: nix profile install nixpkgs#plasma-panel-colorizer
- Put the widget on any of your panels
- Go to the widget settings to change the current panel appearance (right click > Configure...)
- Widget can set to only show in panel Edit Mode (right click > Hide widget or from the widget settings)
Presets are a way to store the current configuration, it allows to quickly switch between styles and also to use them on other panels.
How to manage presets
- To start creating a new preset you can either load an existing preset you want to edit or start clean by restoring the default appearance first.
- Go to the other tabs and configure them however you like.
- Go back to presets tab and either update the existing preset or create a new one.
When you apply a preset it overrides the currently applied configuration with the one of the preset, you can always save the current configuration as a different preset if you want to preserve it.
After loading a preset and editing any of the settings the new changes are not automatically written to the last loaded preset, instead you should go back to the presets tab and update it.
Preset auto-loading
The same applies to the preset auto-loading feature, if you are making changes to your presets it is recommended to temporary disable this feature so your unsaved edits don't get overwritten when a preset auto-loads.
Each widget instance has its own D-bus name (e.g. luisbocanegra.panel.colorizer.c337.w2346), you can find it on each widget's General settings tab, you can also disable the service from there.
To apply a preset to a specific panel pass the absolute path of a preset folder:
qdbus6 luisbocanegra.panel.colorizer.c337.w2346 /preset preset /path/to/preset/dir/
It's also possible to apply the preset to all the panels at once
dbus-send --session --type=signal /preset luisbocanegra.panel.colorizer.all.preset string:"/path/to/preset dir/"
To quickly preview and switch between presets you can use this handy fzf + qdbus6 + jq
one-liner
find /usr/share/plasma/plasmoids/luisbocanegra.panel.colorizer/contents/ui/presets/ ~/.local/share/plasma/plasmoids/luisbocanegra.panel.colorizer/contents/ui/presets/ ~/.config/panel-colorizer/presets -mindepth 1 -prune -type d 2>/dev/null -mindepth 1 -prune -type d | fzf --bind 'enter:execute(qdbus6 luisbocanegra.panel.colorizer.c337.w2346 /preset preset {})' --preview 'jq --color-output . {}/settings.json'
Or to all panels
find /usr/share/plasma/plasmoids/luisbocanegra.panel.colorizer/contents/ui/presets/ ~/.local/share/plasma/plasmoids/luisbocanegra.panel.colorizer/contents/ui/presets/ ~/.config/panel-colorizer/presets -mindepth 1 -prune -type d 2>/dev/null -mindepth 1 -prune -type d | fzf --bind 'enter:execute(dbus-send --session --type=signal /preset luisbocanegra.panel.colorizer.all.preset string:{})' --preview 'jq --color-output . {}/settings.json'
Caution
There is no validation. Incorrectly formatted input will break the configuration! 💥
To apply a specific configuration option use the property
method or signal with the value in Dot notation + space + value
Example to toggle a panel
# hide
qdbus luisbocanegra.panel.colorizer.c337.w2346 /preset luisbocanegra.panel.colorizer.c337.w2346.property 'stockPanelSettings.visible {"enabled": true, "value": false}'
# to revert:
qdbus luisbocanegra.panel.colorizer.c337.w2346 /preset luisbocanegra.panel.colorizer.c337.w2346.property 'stockPanelSettings.visible {"enabled": false, "value": true}'
Just like with presets it's also possible to set a property on all the panels
# hide all panels
dbus-send --session --type=signal /preset luisbocanegra.panel.colorizer.all.property string:'stockPanelSettings.visible {"enabled": true, "value": false}'
# to revert:
dbus-send --session --type=signal /preset luisbocanegra.panel.colorizer.all.property string:'stockPanelSettings.visible {"enabled": false, "value": true}'
See Adding or updating built-in presets
Changes to the panel are not permanent and can be removed by disabling or removing the widget
- Click on the widget to disable/enable
- Or Widget Settings > Top left > Enabled checkbox
- Or removing the widget from the panel and restarting Plasma/logging out.
If you are troubleshooting an issue please do the third option above and read the notice about reporting bugs at the start of Install section
The location where they are stored has changed, the new locations are:
- Presets:
/home/$USER/.config/panel-colorizer/presets/
- User overrides:
/home/$USER/.config/panel-colorizer/overrides.json
- Text and icon options:
/home/$USER/.config/panel-colorizer/forceForegroundColor.json
The format of the presets has changed, presets from previous version will need to be recreated manually
See How do I blacklist widgets like before?
Not in this project, use Panel Spacer Extended instead
This widget works by inject/managing the background and colors and other properties of other widgets and the panel where it is placed.
Technical
Backgrounds are drawn by creating rectangle areas bellow widgets/panel, text and icons repaint is done by editing some elements color property and overwriting Kirigami.Theme.<something>Color
colors for others, while this works for most widgets, there are some that won't because they draw text and icons differently to what this project matches, if you find a widget that doesn't get colors let me know here and I will try supporting it.
Time has passed and now the widget does a lot more than that, but the principle is basically the same.
Performance
I tried to optimize it so CPU usage only increases around 0.5-1% on my computer, usage may vary depending on your System or how many widgets are in your panels.
Can this widget change the appearance of other parts of Plasma (e.g Desktop view, widget popups/tooltips, overview)
Only the panel for now, the Desktop widgets might be possible, for the others haven't looked into but most likely not.
Please read the Contributing guidelines in this repository
-
If you like the project please consider donating/sponsoring this and my other open source work
-
Rate / leave review in the KDE Store
- Search the actual gridLayout of the panel from Plasma panel spacer that inspired this project.
- Google LLC. / Pictogrammers assets used for panel icon.
- sanjay-kr-commit/panelTransparencyToggleForPlasma6 / psifidotos/paneltransparencybutton for the implementation of panel transparency
- olib14/pinpanel for the hint on how to toggle a panel
- Zren/plasma-applet-lib/kpac to manage translations
- KDE/plasma-desktop/desktoppackage/contents/views/Panel.qml
- KDE/plasma-workspace/master/shell/panelview.cpp
- Plasma scripting API
- Plasma Widget tutorial
Configurations
Built-in presets