1

Hyprland config update

This commit is contained in:
2023-04-23 16:01:35 +02:00
parent 345fe4a238
commit bed565f350
3 changed files with 72 additions and 186 deletions

View File

@ -31,7 +31,7 @@ wsbind = 10, HDMI-A-2
# See https://wiki.hyprland.org/Configuring/Keywords/ for more
# Execute your favorite apps at launch
exec-once = waybar
# exec-once = waybar
exec-once = dunst
exec-once = hyprpaper
exec-once = kdeconnect-indicator # TODO: Only shows sometimes?
@ -47,6 +47,7 @@ exec-once = hyprctl setcursor Bibata-Modern-Classic 16
# Source a file (multi-file configs)
# source = ~/.config/hypr/myColors.conf
source = ~/.config/hypr/polkit.conf # NOTE: This needs to be sourced, because NixOS fills in the polkit executable path
source = ~/.config/hypr/waybar-reload.conf
# Some default env vars.
env = XCURSOR_SIZE,24
@ -164,11 +165,13 @@ $mainMod = SUPER
bind = $mainMod, Q, killactive
bind = $mainMod, V, togglefloating
bind = $mainMod, F, fullscreen
bind = $mainMod, C, exec, clipman pick -t rofi # TODO: Generate this in a include file from nixos, depending on the menu option
bind = $mainMod, C, exec, clipman pick -t rofi # TODO: Theme + Generate this in a include file from nixos, depending on the menu option
# Launch apps
bind = $mainMod, A, exec, rofi -show drun -theme ~/NixFlake/config/rofi/launcher.rasi
bind = $mainMod, T, exec, kitty
bind = $mainMod, E, exec, kitty fish -c "nnncd -a -P p"
bind = $mainMod, P, exec, hyprpicker -a
# bind = $mainMod, E, exec, dolphin
# Move windows in/out of groups

View File

@ -304,6 +304,8 @@ rec {
nil # nix language server
parted # partition manager
libnotify
procps # pgrep, pkill
inotifyTools # inotifywait etc.
# Xooooorg/Desktop environment stuff
# xclip
@ -349,6 +351,7 @@ rec {
digital # Digital circuit simulator
okteta # hex editor
kdiff3 # diff/patch tool
font-manager
# Office
# sioyek # Scientific pdf reader # HM program
@ -549,6 +552,7 @@ rec {
];
bookmarks = {
c = "~/.config";
d = "~/Documents";
D = "~/Downloads";
n = "~/Notes";

View File

@ -19,7 +19,35 @@ in {
};
};
config = mkIf cfg.enable {
config = let
# Taken from https://github.com/Ruixi-rebirth/flakes/blob/main/modules/programs/wayland/waybar/workspace-patch.nix
hyprctl = "${pkgs.hyprland}/bin/hyprctl";
workspaces-patch = pkgs.writeTextFile {
name = "waybar-hyprctl.diff";
text = ''
diff --git a/src/modules/wlr/workspace_manager.cpp b/src/modules/wlr/workspace_manager.cpp
index 6a496e6..a689be0 100644
--- a/src/modules/wlr/workspace_manager.cpp
+++ b/src/modules/wlr/workspace_manager.cpp
@@ -511,7 +511,9 @@ auto Workspace::handle_clicked(GdkEventButton *bt) -> bool {
if (action.empty())
return true;
else if (action == "activate") {
- zext_workspace_handle_v1_activate(workspace_handle_);
+ // zext_workspace_handle_v1_activate(workspace_handle_);
+ const std::string command = "${hyprctl} dispatch workspace " + name_;
+ system(command.c_str());
} else if (action == "close") {
zext_workspace_handle_v1_remove(workspace_handle_);
} else {
'';
};
waybar-hyprland = pkgs.waybar.overrideAttrs (oldAttrs: {
mesonFlags = oldAttrs.mesonFlags ++ [ "-Dexperimental=true" ];
patches = (oldAttrs.patches or [ ]) ++ [ workspaces-patch ];
});
in mkIf cfg.enable {
assertions = [
{
assertion = nixosConfig.programs.hyprland.enable;
@ -48,6 +76,22 @@ in {
# Polkit
home.file.".config/hypr/polkit.conf".text = ''exec-once = ${pkgs.libsForQt5.polkit-kde-agent}/libexec/polkit-kde-agent-1 &'';
home.file.".config/hypr/waybar-reload.conf".text = let
waybar-reload = pkgs.writeScript "waybar-reload" ''
#! ${pkgs.bash}/bin/bash
trap "${pkgs.procps}/bin/pkill waybar" EXIT
while true; do
${waybar-hyprland}/bin/waybar -c $HOME/NixFlake/config/waybar/config -s $HOME/NixFlake/config/waybar/style.css &
${pkgs.inotifyTools}/bin/inotifywait -e create,modify $HOME/NixFlake/config/waybar/config $HOME/NixFlake/config/waybar/style.css
${pkgs.procps}/bin/pkill waybar
done
'';
in ''
exec-once = ${waybar-reload}
'';
home.file.".config/hypr/hyprpaper.conf".text = ''
preload = ~/NixFlake/wallpapers/${cfg.theme}.png
wallpaper = HDMI-A-1, ~/NixFlake/wallpapers/${cfg.theme}.png
@ -55,25 +99,33 @@ in {
'';
home.activation = {
# NOTE: Keep the hyprland config symlinked, to allow easy changes with hotreload
# TODO: Can I simplify mkLink to include the hm.dag.entryAfter and the name?
# Like mkLink linkHyprlandConfig "source" "target"
linkHyprlandConfig = hm.dag.entryAfter ["writeBoundary"] (mkLink "~/NixFlake/config/hyprland/hyprland.conf" "~/.config/hypr/hyprland.conf");
# NOTE: Keep the hyprland/waybar config symlinked, to allow easy changes with hotreload
# TODO: Don't symlink at all, why not just tell Hyprland where the config is? Much easier
# TODO: Use this approach for every program that supports it, makes things much easier,
# as everything can just stay in ~/NixFlake/config
linkHyprlandConfig = hm.dag.entryAfter ["writeBoundary"]
(mkLink "~/NixFlake/config/hyprland/hyprland.conf" "~/.config/hypr/hyprland.conf");
# linkWaybarConfig = hm.dag.entryAfter ["writeBoundary"]
# (mkLink "~/NixFlake/config/waybar/config" "~/.config/waybar/config");
# linkWaybarStyle = hm.dag.entryAfter ["writeBoundary"]
# (mkLink "~/NixFlake/config/waybar/style.css" "~/.config/waybar/style.css");
# linkWaybarColors = hm.dag.entryAfter ["writeBoundary"]
# (mkLink "~/NixFlake/config/waybar/colors" "~/.config/waybar/colors");
};
home.packages = with pkgs; [
# TODO: Check which of these belong in the global config
hyprpaper # Wallpaper setter
hyprpicker # Color picker
wl-clipboard
clipman # Clipboard manager (wl-paste)
imv # Image viewer
slurp # Region selector for screensharing
grim # Grab images from compositor
ncpamixer # ncurses pavucontrol
# wofi
cava # TODO: Hyprland cava module
font-manager
xfce.thunar
libsForQt5.polkit-kde-agent
];
@ -99,186 +151,13 @@ in {
# extraConfig = '''';
};
waybar = let
# Taken from https://github.com/Ruixi-rebirth/flakes/blob/main/modules/programs/wayland/waybar/workspace-patch.nix
hyprctl = "${pkgs.hyprland}/bin/hyprctl";
workspaces-patch = pkgs.writeTextFile {
name = "waybar-hyprctl.diff";
text = ''
diff --git a/src/modules/wlr/workspace_manager.cpp b/src/modules/wlr/workspace_manager.cpp
index da83cb7..4c33ac3 100644
--- a/src/modules/wlr/workspace_manager.cpp
+++ b/src/modules/wlr/workspace_manager.cpp
@@ -450,7 +450,8 @@ auto Workspace::handle_clicked(GdkEventButton *bt) -> bool {
if (action.empty())
return true;
else if (action == "activate") {
- zext_workspace_handle_v1_activate(workspace_handle_);
+ const std::string command = "${hyprctl} dispatch workspace " + name_;
+ system(command.c_str());
} else if (action == "close") {
zext_workspace_handle_v1_remove(workspace_handle_);
} else {
'';
};
wrapico = icon: "<span font=\"FontAwesome\">${icon}</span> ";
in {
waybar = {
enable = true;
package = pkgs.waybar.overrideAttrs (oldAttrs: {
mesonFlags = oldAttrs.mesonFlags ++ [ "-Dexperimental=true" ];
patches = (oldAttrs.patches or [ ]) ++ [ workspaces-patch ];
});
package = waybar-hyprland;
systemd = {
enable = false; # Gets started by hyprland
};
# TODO: These icons do not fit at all, need to use a different icon font.
settings = [{
"output" = "HDMI-A-1"; # Only bar on main monitor, multiple wireplumber widgets result in crash
"layer" = "top";
"position" = "top";
"height" = 34; # 34 fits with VictorMono Nerd Font size 15
"spacing" = 4;
"modules-left" = [
# TODO: Launcher (opens wofi), with NixOS icon
"custom/launcher"
"user"
"hyprland/window"
];
"modules-center" = [
"wlr/workspaces"
];
"modules-right" = [
# "cava" # Unknown? Maybe needs git version
# "wireplumber"
"pulseaudio"
"network"
"cpu"
"memory"
"temperature"
"clock"
"tray"
];
"custom/launcher" = {
"interval" = "once";
"format" = (wrapico "");
"on-click" = "wofi --show drun --columns 2 -I"; # TODO: Wofi Theme
"tooltip" = false;
};
"wlr/workspaces" = {
"format" = "{name}"; # TODO: "{icon}""
"on-click" = "activate";
"sort-by-coordinates" = false;
"sort-by-name" = true;
"sort-by-number" = false;
"all-outputs" = false;
# TODO: This doesn't work? But I think I like it more without this anyway
# "persistent_workspaces" = {
# # In [] the output can be specified, by I only use one bar, so not required
# "1" = ["HDMI-A-1"];
# "2" = ["HDMI-A-1"];
# "3" = ["HDMI-A-1"];
# "4" = ["HDMI-A-1"];
# "5" = ["HDMI-A-1"];
# "6" = ["HDMI-A-1"];
# "7" = ["HDMI-A-1"];
# "8" = ["HDMI-A-1"];
# "9" = ["HDMI-A-1"];
# # "0" = [];
# };
};
# NOTE: This was wireplumber originally, but that is really unstable
"pulseaudio" = {
"format" = (wrapico "") + "{volume}%";
"format-muted" = (wrapico "");
"on-click" = "kitty ncpamixer";
};
"network" = {
"interface" = "enp0s31f6";
"format" = (wrapico "") + "{ipaddr}"; # Other Icon: 
"format-disconnected" = (wrapico ""); # Other Icon: 
"tooltip-format" = "{ifname} via {gwaddr}"; # TODO: gwaddr does not show?
};
"cpu" = {
"format" = (wrapico "") + "{load}%";
};
"memory" = {
"format" = (wrapico "") + "{percentage}%";
};
"temperature" = {
"thermal-zone" = 3; # Zone 3 is "x86_pkg_temp"
"format" = (wrapico "") + "{temperatureC}°C";
};
"clock" = {
"format" = (wrapico "") + "{:%H:%M}";
"timezone" = "Europe/Berlin";
"tooltip-format" = "<tt><small>{calendar}</small></tt>";
};
"tray" = {
"icon-size" = 20;
"spacing" = 5;
"show-passive-items" = true;
};
}];
# Taken from https://github.com/MathisP75/hyppuccin/blob/main/waybar/desktop-bar/style.css
style = ''
window#waybar {
border-radius: 0px;
margin: 16px 16px;
}
window#waybar.hidden {
opacity: 0.2;
}
#workspaces button {
border-radius: 8px;
padding: 0px 10px 0px 10px;
margin: 7px 5px 10px 5px;
}
#custom-launcher,
#clock,
#cpu,
#temperature,
#network,
#wireplumber,
#memory {
padding: 0px 20px;
margin: 7px 0px 10px 0px;
border-radius: 8px;
}
#window,
#custom-launcher {
padding: 0px 25px 0px 20px;
margin: 7px 0px 10px 20px;
}
#wireplumber {
padding: 0px 20px 0px 17px;
}
#network {
padding: 0px 15px 0px 20px;
}
'';
};
};
};