Skip to content

Latest commit

 

History

History
355 lines (234 loc) · 15.6 KB

README.md

File metadata and controls

355 lines (234 loc) · 15.6 KB

Panel Colorizer

AUR version Dynamic JSON Badge nixpkgs unstable package Matrix

Fully-featured widget to bring Latte-Dock and WM status bar customization features to the default Plasma panel.

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.

Demo

Demo

Configuration window

tooltip

Features

Presets

Panel/Widget/System Tray elements

  • Color modes
    • Static
    • Animated removed 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)

Installing

KDE Store

  1. Install these runtime dependencies or the equivalents for your distribution

    python python-dbus python-gobject
  2. Right click on the Panel > Add or manage widgets > Add new... > Download new...

  3. Search for "Panel Colorizer", install and add it to a Panel.

Manually

  1. 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

  2. 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

Arch Linux

aur/plasma6-applets-panel-colorizer use your preferred AUR helper e.g:

yay -S plasma6-applets-panel-colorizer

Nix package

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-manager

    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

How to use

  1. Put the widget on any of your panels
  2. Go to the widget settings to change the current panel appearance (right click > Configure...)
  3. Widget can set to only show in panel Edit Mode (right click > Hide widget or from the widget settings)

Creating and managing presets

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

  1. 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.
  2. Go to the other tabs and configure them however you like.
  3. 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.

Advanced commandline usage with D-Bus (version 2.0.0 or later)

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.

Switching presets with D-Bus

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'

Changing specific configuration options with D-Bus

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}'

Adding or improving the built-in presets

See Adding or updating built-in presets

FAQ

Are changes permanent?

Changes to the panel are not permanent and can be removed by disabling or removing the widget

How to restore the default appearance?

  • 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

Updated to v1.0.0 or later, where are my presets?

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

Updated to v1.0.0 or later, how to blacklist widgets

See How do I blacklist widgets like before?

Will you add support to drag/close/maximize/minimize... windows like latte had?

Not in this project, use Panel Spacer Extended instead

How does it work?

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.

Bug reporting / Feature requests / Contributing

Please read the Contributing guidelines in this repository

Support the development

Acknowledgements & useful resources