KDE: Difference between revisions
imported>Lumarius The example for installing a Qt theme using Kvantum uses Home Manager. |
→Tips and tricks: Show user option to add a profile picture for their sddm login screen. |
||
(30 intermediate revisions by 9 users not shown) | |||
Line 3: | Line 3: | ||
== Installation == | == Installation == | ||
=== Plasma 6 === | |||
{{file|/etc/nixos/configuration.nix|nix|<nowiki> | |||
{ | |||
services.xserver.enable = true; // optional | |||
services.displayManager.sddm.enable = true; | |||
services.displayManager.sddm.wayland.enable = true; | |||
services.desktopManager.plasma6.enable = true; | |||
} | |||
</nowiki>}} | |||
=== Plasma 5 === | |||
{{file|/etc/nixos/configuration.nix|nix|<nowiki> | |||
{ | |||
services.xserver.enable = true; | |||
services.displayManager.sddm.enable = true; | |||
services.xserver.desktopManager.plasma5.enable = true; | |||
} | |||
</nowiki>}} | |||
== Configuration == | |||
=== Rootless X11 === | |||
{{ic|sddm}} launches X11 as a root user by default. For better security, X11 can be run as a non-root user, but using Wayland is better tested and thus preferred: | |||
<syntaxHighlight lang=nix> | <syntaxHighlight lang=nix> | ||
services.xserver.displayManager.sddm.settings.General.DisplayServer = "x11-user"; | |||
services.xserver.displayManager.sddm. | |||
</syntaxHighlight> | </syntaxHighlight> | ||
=== Excluding | === Excluding applications from the default install === | ||
Some optional packages can be excluded if they are not needed at the cost of functionality. | |||
==== Plasma | ==== Plasma 6 ==== | ||
Optional packages: [https://github.com/NixOS/nixpkgs/blob/nixos-unstable/nixos/modules/services/desktop-managers/plasma6.nix#L136-L149 plasma6.nix] | |||
<syntaxHighlight lang=nix> | <syntaxHighlight lang=nix> | ||
environment. | environment.plasma6.excludePackages = with pkgs.kdePackages; [ | ||
plasma-browser-integration | plasma-browser-integration | ||
konsole | konsole | ||
elisa | |||
]; | ]; | ||
</syntaxHighlight> | </syntaxHighlight> | ||
==== Plasma | ==== Plasma 5 ==== | ||
Optional packages: [https://github.com/NixOS/nixpkgs/blob/nixos-24.05/nixos/modules/services/x11/desktop-managers/plasma5.nix#L278-L282 plasma5.nix] | |||
<syntaxHighlight lang=nix> | <syntaxHighlight lang=nix> | ||
environment. | environment.plasma5.excludePackages = with pkgs.libsForQt5; [ | ||
plasma-browser-integration | plasma-browser-integration | ||
konsole | konsole | ||
Line 36: | Line 61: | ||
]; | ]; | ||
</syntaxHighlight> | </syntaxHighlight> | ||
=== GNOME desktop integration === | === GNOME desktop integration === | ||
Line 43: | Line 66: | ||
Using the following example configuration, QT applications will have a look similar to the [[GNOME]] desktop, using a dark theme. | Using the following example configuration, QT applications will have a look similar to the [[GNOME]] desktop, using a dark theme. | ||
< | <syntaxhighlight lang="nix"> | ||
qt = { | qt = { | ||
enable = true; | enable = true; | ||
platformTheme = "gnome"; | platformTheme = "gnome"; | ||
style = "adwaita-dark"; | style.name = "adwaita-dark"; | ||
}; | }; | ||
</ | </syntaxhighlight> | ||
For other themes, you may need the packages <code>libsForQt5.qt5ct</code> and <code>libsForQt5.qtstyleplugin-kvantum</code> and a symlink from <code>~/.config/Kvantum/</code> to your theme package. Here is an example using Arc-Dark and [[Home Manager]]. In the Home Manager configuration: | For other themes, you may need the packages <code>libsForQt5.qt5ct</code> and <code>libsForQt5.qtstyleplugin-kvantum</code> and a symlink from <code>~/.config/Kvantum/</code> to your theme package. Here is an example using Arc-Dark and [[Home Manager]]. In the Home Manager configuration: | ||
Line 68: | Line 91: | ||
For more details, see [https://discourse.nixos.org/t/guide-to-installing-qt-theme/35523/2 this] forum post. | For more details, see [https://discourse.nixos.org/t/guide-to-installing-qt-theme/35523/2 this] forum post. | ||
== | === Default Wayland/X11 session === | ||
=== | ==== Plasma 6 ==== | ||
Plasma 6 runs on Wayland by default. To launch an X11 session by default: | |||
<syntaxHighlight lang= | <syntaxHighlight lang=nix> | ||
services.xserver.displayManager.defaultSession = "plasmax11"; | |||
</syntaxHighlight> | </syntaxHighlight> | ||
=== | ==== SDDM on Wayland ==== | ||
<syntaxHighlight lang=nix> | <syntaxHighlight lang=nix> | ||
services.xserver.displayManager.sddm.wayland.enable = true; | |||
</syntaxHighlight> | </syntaxHighlight> | ||
==== Plasma 5 ==== | |||
=== | |||
Plasma 5 runs on X11 by default and it is recommended to use Wayland with Plasma 6 instead. To launch a Wayland session by default anyway: | |||
<syntaxHighlight lang=nix> | <syntaxHighlight lang=nix> | ||
services.xserver.displayManager.defaultSession = "plasmawayland"; | |||
</syntaxHighlight> | </syntaxHighlight> | ||
== Troubleshooting == | |||
=== | === Qt/KDE applications segfault on start === | ||
This is caused by a stale QML cache [https://github.com/NixOS/nixpkgs/issues/177720 (see this issue)]. A dirty way to fix this is by running on a terminal the following command: | |||
<syntaxHighlight lang= | <syntaxHighlight lang=sh> | ||
find ${XDG_CACHE_HOME:-$HOME/.cache}/**/qmlcache -type f -delete | |||
</syntaxHighlight> | </syntaxHighlight> | ||
=== | === GTK themes are not applied in Wayland applications / Window Decorations missing / Cursor looks different === | ||
This affects GTK applications including Firefox and Thunderbird. | |||
You may need to set a GTK theme ''Breeze'' imitating the KDE theme with the same name in ''System Settings -> Application Style -->Configure GNOME/GTK Application Style''. | |||
[https://github.com/NixOS/nixpkgs/issues/180720 (See this issue)] | |||
== Tips and tricks == | |||
=== Plasma-Manager === | === Plasma-Manager === | ||
{{note| [https://github.com/pjones/plasma-manager Plasma-Manager] is not | {{note| [https://github.com/pjones/plasma-manager Plasma-Manager] is an unofficial community project and is not yet mature}} | ||
By default, the Plasma configuration can be handled like on [https://wiki.archlinux.org/title/KDE traditional systems]. | By default, the Plasma configuration can be handled like on [https://wiki.archlinux.org/title/KDE traditional systems]. | ||
With [https://github.com/pjones/plasma-manager plasma-manager], it is possible to make Plasma configurations via nix by providing [https://github.com/nix-community/home-manager home-manager] modules. | With [https://github.com/pjones/plasma-manager plasma-manager], it is possible to make Plasma configurations via nix by providing [https://github.com/nix-community/home-manager home-manager] modules. | ||
=== User icon (avatar) === | |||
You can add a profile picture to your user by using a png file in <code>~/.face.icon</code>. | |||
[[Category:Desktop environment]] | [[Category:Desktop environment]] | ||
[[Category:Applications]] | [[Category:Applications]] | ||
[[Category:KDE]] |