#!/bin/sh # See the river(1), riverctl(1), and rivertile(1) man pages for complete # documentation. # Focus follows mouse riverctl focus-follows-cursor normal # Let the cursor follow focused screen riverctl set-cursor-warp on-focus-change # Atatch new windows at the bottom of the stack riverctl attach-mode bottom # Hide cursor riverctl hide-cursor timeout 5000 riverctl hide-cursor when-typing enabled # Setup keyboard riverctl keyboard-layout -options "grp:ctrl_space_toggle" "us,gb" # Note: the "Super" modifier is also known as Logo, GUI, Windows, Mod4, etc. # Super+Shift+Return to start an instance of foot (https://codeberg.org/dnkl/foot) riverctl map normal Super Return spawn foot # Super+Q to close the focused view riverctl map normal Super Q close # Super+Shift+E to exit river riverctl map normal Super+Shift E exit # Launcher riverctl map normal Super D spawn "fuzzel" # Toggle waybar riverctl map normal Super B spawn "killall yambar || ~/.config/yambar/scripts/yambar-start.sh" # Power Menu riverctl map normal Control+Super P spawn "~/.local/bin/powermenu" # Super+J and Super+K to focus the next/previous view in the layout stack riverctl map normal Super J focus-view next riverctl map normal Super K focus-view previous # Super+Shift+J and Super+Shift+K to swap the focused view with the next/previous # view in the layout stack riverctl map normal Super+Shift J swap next riverctl map normal Super+Shift K swap previous # Super+Period and Super+Comma to focus the next/previous output riverctl map normal Super Period focus-output next riverctl map normal Super Comma focus-output previous # Super+Shift+{Period,Comma} to send the focused view to the next/previous output riverctl map normal Super+Shift Period send-to-output next riverctl map normal Super+Shift Comma send-to-output previous # Super+Return to bump the focused view to the top of the layout stack # riverctl map normal Super Return zoom # Super+H and Super+L to decrease/increase the main ratio of rivertile(1) riverctl map normal Super H send-layout-cmd rivertile "main-ratio -0.05" riverctl map normal Super L send-layout-cmd rivertile "main-ratio +0.05" # Super+Shift+H and Super+Shift+L to increment/decrement the main count of rivertile(1) riverctl map normal Super+Shift H send-layout-cmd rivertile "main-count +1" riverctl map normal Super+Shift L send-layout-cmd rivertile "main-count -1" # Super+Alt+{H,J,K,L} to move views riverctl map normal Super+Alt H move left 100 riverctl map normal Super+Alt J move down 100 riverctl map normal Super+Alt K move up 100 riverctl map normal Super+Alt L move right 100 # Super+Alt+Control+{H,J,K,L} to snap views to screen edges riverctl map normal Super+Alt+Control H snap left riverctl map normal Super+Alt+Control J snap down riverctl map normal Super+Alt+Control K snap up riverctl map normal Super+Alt+Control L snap right # Super+Alt+Shift+{H,J,K,L} to resize views riverctl map normal Super+Alt+Shift H resize horizontal -100 riverctl map normal Super+Alt+Shift J resize vertical 100 riverctl map normal Super+Alt+Shift K resize vertical -100 riverctl map normal Super+Alt+Shift L resize horizontal 100 # Super + Left Mouse Button to move views riverctl map-pointer normal Super BTN_LEFT move-view # Super + Right Mouse Button to resize views riverctl map-pointer normal Super BTN_RIGHT resize-view # Super + Middle Mouse Button to toggle float riverctl map-pointer normal Super BTN_MIDDLE 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 # Super+0 to focus all tags # Super+Shift+0 to tag focused view with all tags all_tags=$(((1 << 32) - 1)) riverctl map normal Super 0 set-focused-tags $all_tags riverctl map normal Super+Shift 0 set-view-tags $all_tags # Super+Space to toggle float riverctl map normal Super Space toggle-float # Super+F to toggle fullscreen riverctl map normal Super F toggle-fullscreen # Super+{Up,Right,Down,Left} to change layout orientation riverctl map normal Super Up send-layout-cmd rivertile "main-location top" riverctl map normal Super Right send-layout-cmd rivertile "main-location right" riverctl map normal Super Down send-layout-cmd rivertile "main-location bottom" riverctl map normal Super Left send-layout-cmd rivertile "main-location left" # Declare a passthrough mode. This mode has only a single mapping to return to # normal mode. This makes it useful for testing a nested wayland compositor riverctl declare-mode passthrough # Super+F11 to enter passthrough mode riverctl map normal Super F11 enter-mode passthrough # Super+F11 to return to normal mode riverctl map passthrough Super F11 enter-mode normal # Take a screenshot of the active output riverctl map normal None Print spawn "grim -o $(lswt -j | jq -c '.[] | select(.activated) | .outputs' | awk -F'"' '{print $2}') -t jpeg ~/Pictures/Screenshots/$(date +%Y-%m-%d_%H-%m-%s).jpg" # Take a screenshot of the selected region riverctl map normal Super Print spawn 'grim -t jpeg -g "$(slurp)" ~/Pictures/Screenshots/$(date +%Y-%m-%d_%H-%m-%s).jpg' # Take a screenshot and save it to the clipboard riverctl map normal Super+Shift Print spawn 'grim -g "$(slurp)" -| wl-copy && notify-send "Screenshot Clipped"' # The scratchpad will live on an unused tag. Which tags are used depends on your # config, but rivers default uses the first 9 tags. scratch_tag=$((1 << 20 )) # Toggle the scratchpad with Super+P riverctl map normal Super P toggle-focused-tags ${scratch_tag} # Send windows to the scratchpad with Super+Shift+P riverctl map normal Super+Shift P set-view-tags ${scratch_tag} # Set spawn tagmask to ensure new windows don't have the scratchpad tag unless # explicitly set. all_but_scratch_tag=$(( ((1 << 32) - 1) ^ $scratch_tag )) riverctl spawn-tagmask ${all_but_scratch_tag} # Various media key mapping examples for both normal and locked mode which do # not have a modifier for mode in normal locked do # Control volume riverctl map $mode None XF86AudioRaiseVolume spawn 'amixer sset Master 2%+' riverctl map $mode None XF86AudioLowerVolume spawn 'amixer sset Master 2%-' riverctl map $mode None XF86AudioMute spawn 'amixer set Master 1+ toggle' # Control MPRIS aware media players with playerctl (https://github.com/altdesktop/playerctl) riverctl map $mode None XF86AudioMedia spawn 'playerctl play-pause' riverctl map $mode None XF86AudioPlay spawn 'playerctl play-pause' riverctl map $mode None XF86AudioPrev spawn 'playerctl previous' riverctl map $mode None XF86AudioNext spawn 'playerctl next' # Control screen backlight brightness with light (https://github.com/haikarainen/light) riverctl map $mode None XF86MonBrightnessUp spawn 'light -A 5; light -O' riverctl map $mode None XF86MonBrightnessDown spawn 'light -U 5; light -O' done # Set background and border color riverctl background-color 0x002b36 riverctl border-color-focused 0x33ccff riverctl border-color-unfocused 0x595959 # Set keyboard repeat rate riverctl set-repeat 50 300 # auto starting apps bash $HOME/.config/river/autostart.sh # Make all views with an app-id that starts with "float" and title "foo" start floating. riverctl rule-add float -app-id 'float*' -title 'foo' # Make all views with app-id "bar" and any title use client-side decorations riverctl rule-add csd -app-id "bar" # Float mpv when it's started riverctl rule-add float -app-id 'mpv' riverctl rule-add csd -app-id 'libreoffice*' # Set the default layout generator to be rivertile and start it. # River will send the process group of the init executable SIGTERM on exit. riverctl default-layout rivertile rivertile -view-padding 5 -outer-padding 5 -main-ratio 0.5 &