mirror of
https://git.sr.ht/~rouven/nixos-config
synced 2025-01-18 17:11:39 +01:00
river: use home-manager module options
This commit is contained in:
parent
ba3929c399
commit
75ef09ca41
1 changed files with 80 additions and 88 deletions
|
@ -1,95 +1,87 @@
|
||||||
{ pkgs, ... }:
|
{ pkgs, lib, ... }:
|
||||||
{
|
{
|
||||||
home.packages = with pkgs; [
|
wayland.windowManager.river = {
|
||||||
river
|
enable = true;
|
||||||
];
|
systemd.extraCommands = [ "systemctl --user start river-session.target" ];
|
||||||
systemd.user.targets.river-session = {
|
settings = {
|
||||||
Unit = {
|
focus-follows-cursor = "always";
|
||||||
After = "graphical-session-pre.target";
|
set-cursor-warp = "on-focus-change";
|
||||||
BindsTo = "graphical-session.target";
|
attach-mode = "bottom";
|
||||||
Description = "river compositor session";
|
default-layout = "rivertile";
|
||||||
Wants = "graphical-session-pre.target";
|
output-layout = "rivertile";
|
||||||
};
|
|
||||||
};
|
|
||||||
xdg.configFile = {
|
|
||||||
"river/init" = {
|
|
||||||
source =
|
|
||||||
pkgs.writeShellScript "river-init.sh" ''
|
|
||||||
riverctl focus-follows-cursor always
|
|
||||||
riverctl set-cursor-warp on-focus-change
|
|
||||||
riverctl attach-mode bottom
|
|
||||||
riverctl spawn rivertile
|
|
||||||
riverctl default-layout rivertile
|
|
||||||
riverctl output-layout rivertile
|
|
||||||
riverctl keyboard-layout -variant dvorak-alt-intl us
|
|
||||||
riverctl input pointer-2-7-SynPS/2_Synaptics_TouchPad tap enabled
|
|
||||||
riverctl input pointer-2-7-SynPS/2_Synaptics_TouchPad drag enabled
|
|
||||||
riverctl input pointer-2-7-SynPS/2_Synaptics_TouchPad middle-emulation enabled
|
|
||||||
riverctl input pointer-2-7-SynPS/2_Synaptics_TouchPad accel-profile adaptive
|
|
||||||
|
|
||||||
|
keyboard-layout = "-variant dvorak-alt-intl us";
|
||||||
riverctl spawn "${pkgs.swaybg}/bin/swaybg -i ${../../../../images/wallpaper.png} -m fill"
|
input."pointer-2-7-SynPS/2_Synaptics_TouchPad" = {
|
||||||
|
tap = "enabled";
|
||||||
|
drag = "enabled";
|
||||||
|
middle-emulation = "enabled";
|
||||||
|
accel-profile = "adaptive";
|
||||||
|
};
|
||||||
|
|
||||||
riverctl map normal Super Return spawn footclient
|
map.normal = lib.attrsets.zipAttrs [
|
||||||
riverctl map normal Super+Shift Return zoom
|
{
|
||||||
riverctl map normal Super+Shift Q close
|
"Super" = {
|
||||||
riverctl map normal Super F toggle-fullscreen
|
Return = "spawn footclient";
|
||||||
|
Space = "toggle-float";
|
||||||
|
F = "toggle-fullscreen";
|
||||||
|
H = "focus-output previous";
|
||||||
|
J = "focus-view previous";
|
||||||
|
K = "focus-view next";
|
||||||
|
L = "focus-output next";
|
||||||
|
O = "send-to-output next";
|
||||||
|
S = "send-to-output next";
|
||||||
|
};
|
||||||
|
"Super+Shift" = {
|
||||||
|
Return = "zoom";
|
||||||
|
Q = "close";
|
||||||
|
H = ''send-layout-cmd rivertile "main-ratio -0.05"'';
|
||||||
|
J = ''send-layout-cmd rivertile "main-count -1"'';
|
||||||
|
K = ''send-layout-cmd rivertile "main-count +1"'';
|
||||||
|
L = ''send-layout-cmd rivertile "main-ratio +0.05"'';
|
||||||
|
};
|
||||||
|
"Alt" = builtins.mapAttrs (key: bind: "spawn " + bind) {
|
||||||
|
Space = "${pkgs.fuzzel}/bin/fuzzel";
|
||||||
|
A = "${pkgs.wofi-emoji}/bin/wofi-emoji";
|
||||||
|
};
|
||||||
|
"None" = builtins.mapAttrs (key: bind: "spawn \"" + bind + "\"") {
|
||||||
|
Print = "${pkgs.sway-contrib.grimshot}/bin/grimshot copy area";
|
||||||
|
XF86Launch2 = "${pkgs.sway-contrib.grimshot}/bin/grimshot save area - | ${pkgs.swappy}/bin/swappy -f -";
|
||||||
|
XF86MonBrightnessUp = "${pkgs.light}/bin/light -A 10";
|
||||||
|
XF86MonBrightnessDown = "${pkgs.light}/bin/light -U 10";
|
||||||
|
XF86AudioMute = "${pkgs.pulseaudio}/bin/pactl set-sink-mute @DEFAULT_SINK@ toggle";
|
||||||
|
XF86AudioMicMute = "${pkgs.pulseaudio}/bin/pactl set-source-mute @DEFAULT_SOURCE@ toggle";
|
||||||
|
XF86AudioRaiseVolume = "${pkgs.pulseaudio}/bin/pactl set-sink-volume @DEFAULT_SINK@ +5%";
|
||||||
|
XF86AudioLowerVolume = "${pkgs.pulseaudio}/bin/pactl set-sink-volume @DEFAULT_SINK@ -5%";
|
||||||
|
XF86Favorites = "${pkgs.systemd}/bin/loginctl lock-session";
|
||||||
|
XF86Messenger = "${pkgs.swaynotificationcenter}/bin/swaync-client --toggle-panel";
|
||||||
|
Cancel = "${pkgs.swaynotificationcenter}/bin/swaync-client --hide-latest";
|
||||||
|
};
|
||||||
|
"Shift" = builtins.mapAttrs (key: bind: "spawn \"" + bind + "\"") {
|
||||||
|
XF86AudioRaiseVolume = "${pkgs.pulseaudio}/bin/pactl set-source-volume @DEFAULT_SOURCE@ +5%";
|
||||||
|
XF86AudioLowerVolume = "${pkgs.pulseaudio}/bin/pactl set-source-volume @DEFAULT_SOURCE@ -5%";
|
||||||
|
Cancel = "${pkgs.swaynotificationcenter}/bin/swaync-client --cloes-all";
|
||||||
|
};
|
||||||
|
}
|
||||||
|
# fuckery. Encodes https://github.com/riverwm/river/blob/c474be1537c833da35682ef54194c3d6ddf1eee0/example/init#L77 in nix
|
||||||
|
(lib.attrsets.mapAttrs
|
||||||
|
(mod: value: lib.attrsets.genAttrs (lib.lists.forEach (lib.lists.range 1 9) (num: toString num))
|
||||||
|
(tag: value + builtins.replaceStrings [ "TAG" ] [ tag ] " $((1 << (TAG - 1)))"))
|
||||||
|
{
|
||||||
|
"Super" = "set-focused-tags";
|
||||||
|
"Super+Shift" = "set-view-tags";
|
||||||
|
"Super+Control" = "toggle-focused-tags";
|
||||||
|
"Super+Shift+Control" = "toggle-view-tags";
|
||||||
|
})
|
||||||
|
];
|
||||||
|
map-pointer.normal = {
|
||||||
|
"Super BTN_LEFT" = "move-view";
|
||||||
|
"Super BTN_RIGHT" = "resize-view";
|
||||||
|
};
|
||||||
|
|
||||||
riverctl map normal Super S send-to-output next
|
spawn = [
|
||||||
|
"rivertile"
|
||||||
riverctl map normal Super+Shift K send-layout-cmd rivertile "main-count +1"
|
''"${pkgs.swaybg}/bin/swaybg -i ${../../../../images/wallpaper.png} -m fill"''
|
||||||
riverctl map normal Super+Shift J send-layout-cmd rivertile "main-count -1"
|
];
|
||||||
riverctl map normal Super+Shift L send-layout-cmd rivertile "main-ratio +0.05"
|
|
||||||
riverctl map normal Super+Shift H send-layout-cmd rivertile "main-ratio -0.05"
|
|
||||||
|
|
||||||
riverctl map normal Super K focus-view next
|
|
||||||
riverctl map normal Super J focus-view previous
|
|
||||||
riverctl map normal Super L focus-output next
|
|
||||||
riverctl map normal Super H focus-output previous
|
|
||||||
riverctl map normal Super O send-to-output next
|
|
||||||
riverctl map-pointer normal Super BTN_LEFT move-view
|
|
||||||
|
|
||||||
riverctl map-pointer normal Super BTN_RIGHT resize-view
|
|
||||||
|
|
||||||
riverctl map normal Alt Space spawn "${pkgs.fuzzel}/bin/fuzzel"
|
|
||||||
riverctl map normal Alt A spawn "${pkgs.wofi-emoji}/bin/wofi-emoji";
|
|
||||||
riverctl map normal Super Space toggle-float
|
|
||||||
|
|
||||||
for i in $(seq 1 9)
|
|
||||||
do
|
|
||||||
tags=$((1 << ($i - 1)))
|
|
||||||
|
|
||||||
# Super+[1-9] to focus tag [0-8]
|
|
||||||
riverctl map normal Super $i set-focused-tags $tags
|
|
||||||
|
|
||||||
# Super+Shift+[1-9] to tag focused view with tag [0-8]
|
|
||||||
riverctl map normal Super+Shift $i set-view-tags $tags
|
|
||||||
|
|
||||||
# Super+Control+[1-9] to toggle focus of tag [0-8]
|
|
||||||
riverctl map normal Super+Control $i toggle-focused-tags $tags
|
|
||||||
|
|
||||||
# Super+Shift+Control+[1-9] to toggle tag [0-8] of focused view
|
|
||||||
riverctl map normal Super+Shift+Control $i toggle-view-tags $tags
|
|
||||||
done
|
|
||||||
|
|
||||||
riverctl map normal None Print spawn "${pkgs.sway-contrib.grimshot}/bin/grimshot copy area"
|
|
||||||
riverctl map normal None XF86Launch2 spawn "${pkgs.sway-contrib.grimshot}/bin/grimshot save area - | ${pkgs.swappy}/bin/swappy -f -"
|
|
||||||
riverctl map normal None XF86MonBrightnessUp spawn "${pkgs.light}/bin/light -A 10"
|
|
||||||
riverctl map normal None XF86MonBrightnessDown spawn "${pkgs.light}/bin/light -U 10"
|
|
||||||
riverctl map normal None XF86AudioMute spawn "${pkgs.pulseaudio}/bin/pactl set-sink-mute @DEFAULT_SINK@ toggle"
|
|
||||||
riverctl map normal None XF86AudioMicMute spawn "${pkgs.pulseaudio}/bin/pactl set-source-mute @DEFAULT_SOURCE@ toggle"
|
|
||||||
riverctl map normal None XF86AudioRaiseVolume spawn "${pkgs.pulseaudio}/bin/pactl set-sink-volume @DEFAULT_SINK@ +5%"
|
|
||||||
riverctl map normal None XF86AudioLowerVolume spawn "${pkgs.pulseaudio}/bin/pactl set-sink-volume @DEFAULT_SINK@ -5%"
|
|
||||||
riverctl map normal Shift XF86AudioRaiseVolume spawn "${pkgs.pulseaudio}/bin/pactl set-source-volume @DEFAULT_SOURCE@ +5%"
|
|
||||||
riverctl map normal Shift XF86AudioLowerVolume spawn "${pkgs.pulseaudio}/bin/pactl set-source-volume @DEFAULT_SOURCE@ -5%"
|
|
||||||
riverctl map normal None XF86Favorites spawn "${pkgs.systemd}/bin/loginctl lock-session"
|
|
||||||
riverctl map normal None XF86Messenger spawn "${pkgs.swaynotificationcenter}/bin/swaync-client --toggle-panel"
|
|
||||||
riverctl map normal None Cancel spawn "${pkgs.swaynotificationcenter}/bin/swaync-client --hide-latest"
|
|
||||||
riverctl map normal Shift Cancel spawn "${pkgs.swaynotificationcenter}/bin/swaync-client --cloes-all"
|
|
||||||
|
|
||||||
${pkgs.dbus}/bin/dbus-update-activation-environment --systemd DISPLAY WAYLAND_DISPLAY XDG_CURRENT_DESKTOP XDG_SESSION_TYPE NIXOS_OZONE_WL
|
|
||||||
systemctl --user start river-session.target
|
|
||||||
'';
|
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue