misc updated to river session
parent
b21075972c
commit
9d3f4bc4a3
|
@ -17,11 +17,14 @@ let
|
||||||
in {
|
in {
|
||||||
imports = [
|
imports = [
|
||||||
./bemenu.nix
|
./bemenu.nix
|
||||||
./waybar.nix
|
|
||||||
./foot.nix
|
./foot.nix
|
||||||
./mako.nix
|
./init.nix
|
||||||
./swaylock.nix
|
|
||||||
./kanshi.nix
|
./kanshi.nix
|
||||||
|
./kile.nix
|
||||||
|
./mako.nix
|
||||||
|
./swaybg.nix
|
||||||
|
./swaylock.nix
|
||||||
|
./waybar.nix
|
||||||
];
|
];
|
||||||
|
|
||||||
home.packages = with pkgs; [
|
home.packages = with pkgs; [
|
||||||
|
@ -30,7 +33,6 @@ in {
|
||||||
gsettings-desktop-schemas
|
gsettings-desktop-schemas
|
||||||
kile-wl
|
kile-wl
|
||||||
light
|
light
|
||||||
mpdris2
|
|
||||||
pamixer
|
pamixer
|
||||||
playerctl
|
playerctl
|
||||||
river
|
river
|
||||||
|
@ -42,16 +44,20 @@ in {
|
||||||
|
|
||||||
programs.zsh.loginExtra = ''
|
programs.zsh.loginExtra = ''
|
||||||
if [[ -z "''${DISPLAY}" ]] && [[ "''${XDG_VTNR}" -eq 1 ]]; then
|
if [[ -z "''${DISPLAY}" ]] && [[ "''${XDG_VTNR}" -eq 1 ]]; then
|
||||||
export XKB_DEFAULT_LAYOUT="us"
|
|
||||||
export XKB_DEFAULT_VARIANT="altgr-intl"
|
|
||||||
export XKB_DEFAULT_OPTIONS="caps:escape"
|
|
||||||
exec ${pkgs.river}/bin/river
|
exec ${pkgs.river}/bin/river
|
||||||
fi
|
fi
|
||||||
'';
|
'';
|
||||||
|
|
||||||
home.file.river_init = {
|
home.sessionVariables.XKB_DEFAULT_LAYOUT = "us";
|
||||||
executable = true;
|
home.sessionVariables.XKB_DEFAULT_VARIANT = "altgr-intl";
|
||||||
target = "${config.xdg.configHome}/river/init";
|
home.sessionVariables.XKB_DEFAULT_OPTIONS = "caps:escape";
|
||||||
source = ./init;
|
|
||||||
|
systemd.user.targets.river-session = {
|
||||||
|
Unit = {
|
||||||
|
Description = "river window manager session";
|
||||||
|
BindsTo = "graphical-session.target";
|
||||||
|
Wants = "graphical-session-pre.target";
|
||||||
|
After = "graphical-session-pre.target";
|
||||||
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,6 +6,7 @@ let
|
||||||
in {
|
in {
|
||||||
programs.foot = {
|
programs.foot = {
|
||||||
enable = true;
|
enable = true;
|
||||||
|
server.enable = true;
|
||||||
settings = {
|
settings = {
|
||||||
main = {
|
main = {
|
||||||
shell = "${pkgs.tmux}/bin/tmux -u";
|
shell = "${pkgs.tmux}/bin/tmux -u";
|
||||||
|
@ -40,4 +41,5 @@ in {
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,210 +0,0 @@
|
||||||
#!/bin/sh
|
|
||||||
|
|
||||||
WALLPAPERS="$HOME/Images/wallpapers/enabled"
|
|
||||||
|
|
||||||
DEFAULT_MASTER_RATIO="0.6"
|
|
||||||
UP_LAYOUT="Up ((h: v v) 1 $DEFAULT_MASTER_RATIO 0)"
|
|
||||||
DOWN_LAYOUT="Down ((h: v v) 1 $DEFAULT_MASTER_RATIO 1)"
|
|
||||||
LEFT_LAYOUT="Left ((v: h h) 1 $DEFAULT_MASTER_RATIO 0)"
|
|
||||||
RIGHT_LAYOUT="Right ((v: h h) 1 $DEFAULT_MASTER_RATIO 1)"
|
|
||||||
DECK_LAYOUT="Deck deck"
|
|
||||||
FULL_LAYOUT="Full full"
|
|
||||||
WIDE_LAYOUT="Wide ((v: h h h) 1 0.5 1)"
|
|
||||||
|
|
||||||
DEFAULT_LAYOUT=$LEFT_LAYOUT
|
|
||||||
|
|
||||||
# Super+Return to start an instance of foot (https://codeberg.org/dnkl/foot)
|
|
||||||
riverctl map normal Super Return spawn foot
|
|
||||||
|
|
||||||
riverctl map normal Super R spawn bemenu-run
|
|
||||||
riverctl map normal Super P spawn tessen
|
|
||||||
|
|
||||||
# Super+Shift+C to close the focused view
|
|
||||||
riverctl map normal Super+Shift C close
|
|
||||||
|
|
||||||
# Super+Shift+Esc to exit river
|
|
||||||
riverctl map normal Super+Shift Escape exit
|
|
||||||
|
|
||||||
riverctl map normal Super Escape spawn swaylock
|
|
||||||
|
|
||||||
# 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+E and Super+W to focus the next/previous output
|
|
||||||
riverctl map normal Super E focus-output next
|
|
||||||
riverctl map normal Super W focus-output previous
|
|
||||||
|
|
||||||
# Super+Shift+{W,E} to send the focused view to the next/previous output
|
|
||||||
riverctl map normal Super+Shift W send-to-output next
|
|
||||||
riverctl map normal Super+Shift W send-to-output previous
|
|
||||||
|
|
||||||
# Super+Shift+Return to bump the focused view to the top of the layout stack
|
|
||||||
riverctl map normal Super+Shift Return zoom
|
|
||||||
|
|
||||||
# Super+H and Super+L to decrease/increase the main ratio
|
|
||||||
# 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"
|
|
||||||
riverctl map -repeat normal Super H send-layout-cmd kile "mod_main_ratio +0.01"
|
|
||||||
riverctl map -repeat normal Super L send-layout-cmd kile "mod_main_ratio -0.01"
|
|
||||||
|
|
||||||
# Super+Comma and Super+Period. to increment/decrement the main count
|
|
||||||
# riverctl map normal Super Comma send-layout-cmd rivertile "main-count +1"
|
|
||||||
# riverctl map normal Super Period send-layout-cmd rivertile "main-count -1"
|
|
||||||
riverctl map normal Super+Shift H send-layout-cmd kile "mod_main_amount +1"
|
|
||||||
riverctl map normal Super+Shift L send-layout-cmd kile "mod_main_amount -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+Ctrl+[1-9] to toggle focus of tag [0-8]
|
|
||||||
riverctl map normal Super+Control "$i" toggle-focused-tags "$tags"
|
|
||||||
|
|
||||||
# Super+Shift+Ctrl+[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+T to toggle float
|
|
||||||
riverctl map normal Super T toggle-float
|
|
||||||
|
|
||||||
# Super+M to toggle fullscreen
|
|
||||||
riverctl map normal Super M 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"
|
|
||||||
#
|
|
||||||
riverctl map normal Super+Control K send-layout-cmd kile "focused $UP_LAYOUT"
|
|
||||||
riverctl map normal Super+Control J send-layout-cmd kile "focused $DOWN_LAYOUT"
|
|
||||||
riverctl map normal Super+Control H send-layout-cmd kile "focused $LEFT_LAYOUT"
|
|
||||||
riverctl map normal Super+Control L send-layout-cmd kile "focused $RIGHT_LAYOUT"
|
|
||||||
riverctl map normal Super+Control D send-layout-cmd kile "focused $DECK_LAYOUT"
|
|
||||||
riverctl map normal Super+Control F send-layout-cmd kile "focused $FULL_LAYOUT"
|
|
||||||
riverctl map normal Super+Control W send-layout-cmd kile "focused $WIDE_LAYOUT"
|
|
||||||
riverctl map normal Super+Shift Space send-layout-cmd kile "focused $DEFAULT_LAYOUT"
|
|
||||||
|
|
||||||
# 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
|
|
||||||
|
|
||||||
# Various media key mapping examples for both normal and locked mode which do
|
|
||||||
# not have a modifier
|
|
||||||
for mode in normal locked
|
|
||||||
do
|
|
||||||
# Eject the optical drive (well if you still have one that is)
|
|
||||||
riverctl map $mode None XF86Eject spawn 'eject -T'
|
|
||||||
|
|
||||||
# Control pulse audio volume with pamixer (https://github.com/cdemoulins/pamixer)
|
|
||||||
riverctl map $mode None XF86AudioRaiseVolume spawn 'pamixer -i 5'
|
|
||||||
riverctl map $mode None XF86AudioLowerVolume spawn 'pamixer -d 5'
|
|
||||||
riverctl map $mode None XF86AudioMute spawn 'pamixer --toggle-mute'
|
|
||||||
|
|
||||||
# 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'
|
|
||||||
riverctl map $mode None XF86MonBrightnessDown spawn 'light -U 5'
|
|
||||||
done
|
|
||||||
|
|
||||||
# Set background and border color
|
|
||||||
riverctl background-color 0x282828
|
|
||||||
riverctl border-color-focused 0x458588
|
|
||||||
riverctl border-color-unfocused 0x504945
|
|
||||||
riverctl border-width 3
|
|
||||||
|
|
||||||
riverctl focus-follows-cursor normal
|
|
||||||
|
|
||||||
# Set keyboard repeat rate
|
|
||||||
riverctl set-repeat 50 300
|
|
||||||
|
|
||||||
# Make certain views start floating
|
|
||||||
riverctl float-filter-add app-id float
|
|
||||||
riverctl float-filter-add title "popup title with spaces"
|
|
||||||
|
|
||||||
# Set app-ids and titles of views which should use client side decorations
|
|
||||||
riverctl csd-filter-add app-id "gedit"
|
|
||||||
|
|
||||||
riverctl spawn "dbus-update-activation-environment --systemd WAYLAND_DISPLAY XDG_CURRENT_DESKTOP=river"
|
|
||||||
riverctl spawn "systemctl --user import-environment WAYLAND_DISPLAY XDG_CURRENT_DESKTOP=river"
|
|
||||||
riverctl spawn "waybar"
|
|
||||||
riverctl spawn "configure-gtk"
|
|
||||||
|
|
||||||
BG="$(find "$WALLPAPERS" -type f | shuf -n 1)"
|
|
||||||
riverctl spawn "swaybg --image $BG --mode fill"
|
|
||||||
|
|
||||||
trackball_names="pointer-21298-5120-Clearly_Superior_Technologies._CST_Laser_Trackball 21298:5120:Clearly_Superior_Technologies._CST_Laser_Trackball"
|
|
||||||
for name in $trackball_names; do
|
|
||||||
echo "$name"
|
|
||||||
riverctl input "$name" left-handed enabled
|
|
||||||
riverctl input "$name" pointer-accel -0.8
|
|
||||||
done
|
|
||||||
|
|
||||||
# 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 0 -outer-padding 0 &
|
|
||||||
|
|
||||||
riverctl default-layout kile
|
|
||||||
kile --namespace kile --layout "$DEFAULT_LAYOUT" &
|
|
||||||
|
|
||||||
kanshi &
|
|
||||||
gotify-desktop &
|
|
||||||
nm-applet --indicator &
|
|
||||||
mpDris2 &
|
|
|
@ -0,0 +1,182 @@
|
||||||
|
{ config, pkgs, ... }:
|
||||||
|
|
||||||
|
let
|
||||||
|
shell = "${pkgs.dash}/bin/dash";
|
||||||
|
|
||||||
|
riverctl = "${pkgs.river}/bin/riverctl";
|
||||||
|
|
||||||
|
foot = "${pkgs.foot}/bin/footclient";
|
||||||
|
bemenu-run = "${pkgs.bemenu}/bin/bemenu-run";
|
||||||
|
tessen = "${pkgs.tessen}/bin/tessen";
|
||||||
|
swaylock = "${pkgs.swaylock}/bin/swaylock";
|
||||||
|
eject = "${pkgs.util-linux}/bin/eject";
|
||||||
|
pamixer = "${pkgs.pamixer}/bin/pamixer";
|
||||||
|
playerctl = "${pkgs.playerctl}/bin/playerctl";
|
||||||
|
light = "${pkgs.light}/bin/light";
|
||||||
|
|
||||||
|
seq = "${pkgs.coreutils}/bin/seq";
|
||||||
|
|
||||||
|
dbus-update-activation-environment =
|
||||||
|
"${pkgs.dbus}/bin/dbus-update-activation-environment";
|
||||||
|
|
||||||
|
in {
|
||||||
|
xdg.dataFile.river_init = {
|
||||||
|
executable = true;
|
||||||
|
target = "${config.xdg.configHome}/river/init";
|
||||||
|
text = ''
|
||||||
|
#!${shell}
|
||||||
|
|
||||||
|
${riverctl} map normal Super Return spawn ${foot}
|
||||||
|
${riverctl} map normal Super R spawn ${bemenu-run}
|
||||||
|
${riverctl} map normal Super P spawn ${tessen}
|
||||||
|
${riverctl} map normal Super Escape spawn ${swaylock}
|
||||||
|
|
||||||
|
# Super+Shift+C to close the focused view
|
||||||
|
${riverctl} map normal Super+Shift C close
|
||||||
|
|
||||||
|
# Super+Shift+Esc to exit river
|
||||||
|
${riverctl} map normal Super+Shift Escape exit
|
||||||
|
|
||||||
|
|
||||||
|
# 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+E and Super+W to focus the next/previous output
|
||||||
|
${riverctl} map normal Super E focus-output next
|
||||||
|
${riverctl} map normal Super W focus-output previous
|
||||||
|
|
||||||
|
# Super+Shift+{W,E} to send the focused view to the next/previous output
|
||||||
|
${riverctl} map normal Super+Shift W send-to-output next
|
||||||
|
${riverctl} map normal Super+Shift W send-to-output previous
|
||||||
|
|
||||||
|
# Super+Shift+Return to bump the focused view to the top of the layout stack
|
||||||
|
${riverctl} map normal Super+Shift Return zoom
|
||||||
|
|
||||||
|
|
||||||
|
${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+Ctrl+[1-9] to toggle focus of tag [0-8]
|
||||||
|
${riverctl} map normal Super+Control "$i" toggle-focused-tags "$tags"
|
||||||
|
|
||||||
|
# Super+Shift+Ctrl+[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+T to toggle float
|
||||||
|
${riverctl} map normal Super T toggle-float
|
||||||
|
|
||||||
|
# Super+M to toggle fullscreen
|
||||||
|
${riverctl} map normal Super M toggle-fullscreen
|
||||||
|
|
||||||
|
# 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
|
||||||
|
|
||||||
|
# Various media key mapping examples for both normal and locked mode which do
|
||||||
|
# not have a modifier
|
||||||
|
for mode in normal locked
|
||||||
|
do
|
||||||
|
# Eject the optical drive (well if you still have one that is)
|
||||||
|
${riverctl} map $mode None XF86Eject spawn '${eject} -T'
|
||||||
|
|
||||||
|
# Control pulse audio volume with pamixer (https://github.com/cdemoulins/pamixer)
|
||||||
|
${riverctl} map $mode None XF86AudioRaiseVolume spawn '${pamixer} -i 5'
|
||||||
|
${riverctl} map $mode None XF86AudioLowerVolume spawn '${pamixer} -d 5'
|
||||||
|
${riverctl} map $mode None XF86AudioMute spawn '${pamixer} --toggle-mute'
|
||||||
|
|
||||||
|
# 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'
|
||||||
|
${riverctl} map $mode None XF86MonBrightnessDown spawn '${light} -U 5'
|
||||||
|
done
|
||||||
|
|
||||||
|
# Set background and border color
|
||||||
|
${riverctl} background-color 0x282828
|
||||||
|
${riverctl} border-color-focused 0x458588
|
||||||
|
${riverctl} border-color-unfocused 0x504945
|
||||||
|
${riverctl} border-width 3
|
||||||
|
|
||||||
|
${riverctl} focus-follows-cursor normal
|
||||||
|
|
||||||
|
# Set keyboard repeat rate
|
||||||
|
${riverctl} set-repeat 50 300
|
||||||
|
|
||||||
|
# Make certain views start floating
|
||||||
|
${riverctl} float-filter-add app-id float
|
||||||
|
${riverctl} float-filter-add title "popup title with spaces"
|
||||||
|
|
||||||
|
# Set app-ids and titles of views which should use client side decorations
|
||||||
|
${riverctl} csd-filter-add app-id "gedit"
|
||||||
|
|
||||||
|
${riverctl} spawn "${dbus-update-activation-environment} --systemd WAYLAND_DISPLAY XDG_CURRENT_DESKTOP=river"
|
||||||
|
${riverctl} spawn "systemctl --user import-environment WAYLAND_DISPLAY XDG_CURRENT_DESKTOP=river"
|
||||||
|
|
||||||
|
trackball_names="pointer-21298-5120-Clearly_Superior_Technologies._CST_Laser_Trackball 21298:5120:Clearly_Superior_Technologies._CST_Laser_Trackball"
|
||||||
|
for name in $trackball_names; do
|
||||||
|
${riverctl} input "$name" left-handed enabled
|
||||||
|
${riverctl} input "$name" pointer-accel -0.8
|
||||||
|
done
|
||||||
|
|
||||||
|
${config.xdg.configHome}/river/init-kile
|
||||||
|
|
||||||
|
systemctl --user start river-session.target
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
}
|
|
@ -5,6 +5,7 @@
|
||||||
|
|
||||||
services.kanshi = {
|
services.kanshi = {
|
||||||
enable = true;
|
enable = true;
|
||||||
|
systemdTarget = "river-session.target";
|
||||||
profiles = {
|
profiles = {
|
||||||
standalone = {
|
standalone = {
|
||||||
outputs = [{
|
outputs = [{
|
||||||
|
|
|
@ -0,0 +1,62 @@
|
||||||
|
{ config, pkgs, ... }:
|
||||||
|
|
||||||
|
let
|
||||||
|
shell = "${pkgs.dash}/bin/dash";
|
||||||
|
|
||||||
|
default_master_ratio = "0.6";
|
||||||
|
up_layout = "Up ((h: v v) 1 ${default_master_ratio} 0)";
|
||||||
|
down_layout = "Down ((h: v v) 1 ${default_master_ratio} 1)";
|
||||||
|
left_layout = "Left ((v: h h) 1 ${default_master_ratio} 0)";
|
||||||
|
right_layout = "Right ((v: h h) 1 ${default_master_ratio} 1)";
|
||||||
|
deck_layout = "Deck deck";
|
||||||
|
full_layout = "Full full";
|
||||||
|
wide_layout = "Wide ((v: h h h) 1 0.5 1)";
|
||||||
|
default_layout = left_layout;
|
||||||
|
|
||||||
|
riverctl = "${pkgs.river}/bin/riverctl";
|
||||||
|
kile = "${pkgs.kile-wl}/bin/kile";
|
||||||
|
kile_namespace = "kile";
|
||||||
|
|
||||||
|
in {
|
||||||
|
|
||||||
|
systemd.user.services.kile-wl = {
|
||||||
|
Unit = {
|
||||||
|
Description = "kile layout generator";
|
||||||
|
BindsTo = [ "river-session.target" ];
|
||||||
|
};
|
||||||
|
Service = {
|
||||||
|
Type = "simple";
|
||||||
|
ExecStart =
|
||||||
|
"${kile} --namespace ${kile_namespace} --layout '${default_layout}'";
|
||||||
|
};
|
||||||
|
Install = { WantedBy = [ "river-session.target" ]; };
|
||||||
|
};
|
||||||
|
|
||||||
|
xdg.dataFile.init-kile = {
|
||||||
|
executable = true;
|
||||||
|
target = "${config.xdg.configHome}/river/init-kile";
|
||||||
|
text = ''
|
||||||
|
#!${shell}
|
||||||
|
|
||||||
|
# Super+H and Super+L to decrease/increase the main ratio
|
||||||
|
${riverctl} map -repeat normal Super Equal send-layout-cmd ${kile_namespace} "mod_main_ratio +0.01"
|
||||||
|
${riverctl} map -repeat normal Super Minus send-layout-cmd ${kile_namespace} "mod_main_ratio -0.01"
|
||||||
|
|
||||||
|
# Super+Comma and Super+Period. to increment/decrement the main count
|
||||||
|
${riverctl} map normal Super Comma send-layout-cmd ${kile_namespace} "mod_main_amount +1"
|
||||||
|
${riverctl} map normal Super Period send-layout-cmd ${kile_namespace} "mod_main_amount -1"
|
||||||
|
|
||||||
|
# Super+{Up,Right,Down,Left} to change layout orientation
|
||||||
|
${riverctl} map normal Super+Control K send-layout-cmd ${kile_namespace} "focused ${up_layout}"
|
||||||
|
${riverctl} map normal Super+Control J send-layout-cmd ${kile_namespace} "focused ${down_layout}"
|
||||||
|
${riverctl} map normal Super+Control H send-layout-cmd ${kile_namespace} "focused ${left_layout}"
|
||||||
|
${riverctl} map normal Super+Control L send-layout-cmd ${kile_namespace} "focused ${right_layout}"
|
||||||
|
${riverctl} map normal Super+Control D send-layout-cmd ${kile_namespace} "focused ${deck_layout}"
|
||||||
|
${riverctl} map normal Super+Control F send-layout-cmd ${kile_namespace} "focused ${full_layout}"
|
||||||
|
${riverctl} map normal Super+Control W send-layout-cmd ${kile_namespace} "focused ${wide_layout}"
|
||||||
|
${riverctl} map normal Super+Shift Space send-layout-cmd ${kile_namespace} "focused ${default_layout}"
|
||||||
|
|
||||||
|
${riverctl} default-layout ${kile_namespace}
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
}
|
|
@ -0,0 +1,26 @@
|
||||||
|
{ config, pkgs, ... }:
|
||||||
|
|
||||||
|
let
|
||||||
|
shell = "${pkgs.dash}/bin/dash";
|
||||||
|
wallpapers = "${config.home.homeDirectory}/Images/wallpapers/enabled";
|
||||||
|
find = "${pkgs.findutils}/bin/find";
|
||||||
|
shuf = "${pkgs.coreutils}/bin/shuf";
|
||||||
|
swaybg = "${pkgs.swaybg}/bin/swaybg";
|
||||||
|
setbg = pkgs.writeScriptBin "setbg" ''
|
||||||
|
#!/${shell}
|
||||||
|
BG="$(${find} "${wallpapers}" -type f | ${shuf} -n 1)"
|
||||||
|
${swaybg} --image $BG --mode fill
|
||||||
|
'';
|
||||||
|
in {
|
||||||
|
systemd.user.services.setbg = {
|
||||||
|
Unit = {
|
||||||
|
Description = "set background using swaybg";
|
||||||
|
BindsTo = [ "river-session.target" ];
|
||||||
|
};
|
||||||
|
Service = {
|
||||||
|
Type = "simple";
|
||||||
|
ExecStart = "${setbg}/bin/setbg";
|
||||||
|
};
|
||||||
|
Install = { WantedBy = [ "river-session.target" ]; };
|
||||||
|
};
|
||||||
|
}
|
|
@ -153,6 +153,9 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
'';
|
'';
|
||||||
systemd.enable = false;
|
systemd = {
|
||||||
|
enable = true;
|
||||||
|
target = "river-session.target";
|
||||||
|
};
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue