From 9686bee77e1ecbd2245733732ce4f67061053c7c Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Geoffrey=20=E2=80=9CFrogeye=E2=80=9D=20Preud=27homme?= Date: Fri, 3 Nov 2023 18:18:38 +0100 Subject: [PATCH] nix: i3: few modes --- config/i3/config.j2 | 98 ++-------- config/i3/lock | 24 --- config/i3/lock.png | Bin 266 -> 0 bytes config/i3/lock.svg | 1 - config/nix/hm/desktop.nix | 395 ++++++++++++++++++++++---------------- 5 files changed, 249 insertions(+), 269 deletions(-) delete mode 100755 config/i3/lock delete mode 100644 config/i3/lock.png delete mode 100644 config/i3/lock.svg diff --git a/config/i3/config.j2 b/config/i3/config.j2 index a8bb732..2f2ac69 100644 --- a/config/i3/config.j2 +++ b/config/i3/config.j2 @@ -62,105 +62,37 @@ for_window [ title="^pdfpc.*" window_role="presentation" ] move to output right, # switch to workspace with urgent window automatically for_window [urgent=latest] focus -# Set shut down, restart and locking features -set $mode_kblock Keyboard lock -mode "$mode_kblock" { - bindsym $mod+Shift+Escape mode "$mode_kblock" -} - "$mod+Shift+Escape" = "mode "$mode_kblock""; - # Set shut down, restart and locking features set $locker $HOME/.config/i3/lock -set $mode_system [L] Vérouillage [E] Déconnexion [S] Veille [H] Hibernation [R] Redémarrage [P] Extinction -mode "$mode_system" { - bindsym l exec --no-startup-id $locker, mode "default" - bindsym e exit, mode "default" - bindsym s exec --no-startup-id $locker & systemctl suspend, mode "default" - bindsym h exec --no-startup-id $locker & systemctl hibernate, mode "default" - bindsym r exec --no-startup-id systemctl reboot, mode "default" - bindsym p exec --no-startup-id systemctl poweroff -i, mode "default" - - # back to normal: Enter or Escape - bindsym Return mode "default" - bindsym Escape mode "default" -} - "$mod+Escape" = "mode "$mode_system""; - -# resize window (you can also use the mouse for that) -mode "Resize" { - # These bindings trigger as soon as you enter the resize mode - - # Pressing left will shrink the window’s width. - # Pressing right will grow the window’s width. - # Pressing up will shrink the window’s height. - # Pressing down will grow the window’s height. - bindsym h resize shrink width 10 px or 10 ppt; exec ~/.config/i3/focus_windows - bindsym j resize grow height 10 px or 10 ppt; exec ~/.config/i3/focus_windows - bindsym k resize shrink height 10 px or 10 ppt; exec ~/.config/i3/focus_windows - bindsym l resize grow width 10 px or 10 ppt; exec ~/.config/i3/focus_windows - - ## same bindings, but for the arrow keys - #bindsym Left resize shrink width 10 px or 10 ppt - #bindsym Down resize grow height 10 px or 10 ppt - #bindsym Up resize shrink height 10 px or 10 ppt - #bindsym Right resize grow width 10 px or 10 ppt - - # back to normal: Enter or Escape - bindsym Return mode "default" - bindsym Escape mode "default" -} - - "$mod+r" = "mode "Resize""; - -set $mode_pres_main "Presentation (main display)" -mode $mode_pres_main { - bindsym b workspace $WS3, workspace $WS4, mode $mode_pres_sec - - # back to normal: Enter or Escape - bindsym q mode "default" - # bindsym Escape mode "default" - bindsym Return mode "default" -} -set $mode_pres_sec "Presentation (secondary display)" -mode $mode_pres_sec { - bindsym b workspace $WS2, workspace $WS1, mode $mode_pres_main - - # back to normal: Enter or Escape - bindsym q mode "default" - # bindsym Escape mode "default" - bindsym Return mode "default" -} - - "$mod+Shift+p" = "mode $mode_pres_main"; set $mode_screen Screen setup [A] Auto [L] Load [S] Save [R] Remove [D] Default "$mod+t" = "mode "$mode_screen""; mode "$mode_screen" { - bindsym a exec autorandr --change --force, mode "default" - bindsym l exec ~/.config/i3/autorandrloadmenu, mode "default" - bindsym s exec ~/.config/i3/autorandrsavemenu, mode "default" - bindsym r exec ~/.config/i3/autorandrremovemenu, mode "default" - bindsym d exec ~/.config/i3/autorandrdefaultmenu, mode "default" + "a" = "exec autorandr --change --force, mode "default""; + "l" = "exec ~/.config/i3/autorandrloadmenu, mode "default""; + "s" = "exec ~/.config/i3/autorandrsavemenu, mode "default""; + "r" = "exec ~/.config/i3/autorandrremovemenu, mode "default""; + "d" = "exec ~/.config/i3/autorandrdefaultmenu, mode "default""; # back to normal: Enter or Escape - bindsym Return mode "default" - bindsym Escape mode "default" + "Return" = "mode "default""; + "Escape" = "mode "default""; } # Screen temperature ("redness") setting "$mod+y" = "mode "$mode_temp""; set $mode_temp Temperature [R] Red [D] Dust storm [C] Campfire [O] Normal [A] All nighter [B] Blue mode "$mode_temp" { - bindsym r exec sct 1000 - bindsym d exec sct 2000 - bindsym c exec sct 4500 - bindsym o exec sct - bindsym a exec sct 8000 - bindsym b exec sct 10000 + "r" = "exec sct 1000"; + "d" = "exec sct 2000"; + "c" = "exec sct 4500"; + "o" = "exec sct"; + "a" = "exec sct 8000"; + "b" = "exec sct 10000"; # back to normal: Enter or Escape - bindsym Return mode "default" - bindsym Escape mode "default" + "Return" = "mode "default""; + "Escape" = "mode "default""; } diff --git a/config/i3/lock b/config/i3/lock deleted file mode 100755 index 5ca0609..0000000 --- a/config/i3/lock +++ /dev/null @@ -1,24 +0,0 @@ -#!/usr/bin/env bash - -# Remove SSH and GPG keys from keystores -ssh-add -D -echo RELOADAGENT | gpg-connect-agent -rm -rf "/tmp/cached_pass_$UID" - - -dm-tool lock -if [ $? -ne 0 ]; then - if [ -d ~/.cache/lockpatterns ] - then - pattern=$(find ~/.cache/lockpatterns/ | sort -R | head -1) - else - pattern=$HOME/.config/i3/lock.png - fi - revert() { - xset dpms 0 0 0 - } - trap revert SIGHUP SIGINT SIGTERM - xset dpms 5 5 5 - i3lock --nofork --color 648901 --image=$pattern --tiling --ignore-empty-password - revert -fi diff --git a/config/i3/lock.png b/config/i3/lock.png deleted file mode 100644 index 70cc80b9e4849ec73eb585040a3730f890fbd254..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 266 zcmeAS@N?(olHy`uVBq!ia0vp^#vshX3?xtV>q-JCi2$Dv*Q9pFrX`Hk^BDa~7~OIh zeTx}WIvA?wGP=lyfi$i4ba4!^I9+;aqu?P20hWV_UW^PIA8<2&Qc-qlkO1EZoZP0-Ceu`lxo5Y=TK0HS}H zr-3Ny)`n?jYnGU5XP(W9GW?zzr)^!W|2g#L*>~E{-&OBkKj+u`UbrEsMxye5Gu-^t V*ybRuSqOAEgQu&X%Q~loCIHu=XZ!#F diff --git a/config/i3/lock.svg b/config/i3/lock.svg deleted file mode 100644 index 8eac69f..0000000 --- a/config/i3/lock.svg +++ /dev/null @@ -1 +0,0 @@ - \ No newline at end of file diff --git a/config/nix/hm/desktop.nix b/config/nix/hm/desktop.nix index 505b2f7..132f85f 100644 --- a/config/nix/hm/desktop.nix +++ b/config/nix/hm/desktop.nix @@ -2,168 +2,242 @@ { xsession.windowManager.i3 = { enable = true; - config = { - terminal = "alacritty"; - # bars = []; # FIXME lemonbar - colors = let ignore = "#ff00ff"; in - with config.lib.stylix.colors.withHashtag; lib.mkForce { - focused = { border = base0B; background = base0B; text = base00; indicator = base00; childBorder = base0B; }; - focusedInactive = { border = base02; background = base02; text = base05; indicator = base02; childBorder = base02; }; - unfocused = { border = base05; background = base04; text = base00; indicator = base04; childBorder = base00; }; - urgent = { border = base0F; background = base08; text = base00; indicator = base08; childBorder = base0F; }; - placeholder = { border = ignore; background = base00; text = base05; indicator = ignore; childBorder = base00; }; - background = base07; - # I set the color of the active tab as the the background color of the terminal so they merge together. - }; - focus.followMouse = false; - keybindings = - let - mod = config.xsession.windowManager.i3.config.modifier; - rofi = "exec --no-startup-id ${config.programs.rofi.package}/bin/rofi"; - focus = "exec ${ pkgs.writeShellScript "i3-focus-window" - '' - WINDOW=`${pkgs.xdotool}/bin/xdotool getwindowfocus` - eval `${pkgs.xdotool}/bin/xdotool getwindowgeometry --shell $WINDOW` # this brings in variables WIDTH and HEIGHT - TX=`${pkgs.coreutils}/bin/expr $WIDTH / 2` - TY=`${pkgs.coreutils}/bin/expr $HEIGHT / 2` - ${pkgs.xdotool}/bin/xdotool mousemove -window $WINDOW $TX $TY - '' - }"; - pactl = "exec ${pkgs.pulseaudio}/bin/pactl"; # TODO Use NixOS package if using NixOS - scrot = "${pkgs.scrot}/bin/scrot --exec '${pkgs.coreutils}/bin/mv $f ~/Screenshots/ && ${pkgs.optipng}/bin/optipng ~/Screenshots/$f'"; - # TODO nix path and create directory? - in - { - # Compatibility layer for people coming from other backgrounds - # "Mod1+Tab" = "${rofi} -modi window -show window"; # FIXME When no longer using a VM - "Mod1+F2" = "${rofi} -modi drun -show drun"; - "Mod1+F4" = "kill"; - # kill focused window - "${mod}+z" = "kill"; - button2 = "kill"; - # Rofi - "${mod}+c" = "exec --no-startup-id ${pkgs.rofi-pass}/bin/rofi-pass --last-used"; - # TODO Try autopass.cr - # 23.11 config.programs.rofi.pass.package - "${mod}+i" = "exec --no-startup-id ${pkgs.rofimoji}/bin/rofimoji"; - "${mod}+plus" = "${rofi} -modi ssh -show ssh"; - "${mod}+ù" = "${rofi} -modi ssh -show ssh -ssh-command '{terminal} -e {ssh-client} {host} -t \"sudo -s -E\"'"; - # TODO In which keyboard layout? - "${mod}+Tab" = "${rofi} -modi window -show window"; - # start program launcher - "${mod}+d" = "${rofi} -modi run -show run"; - "${mod}+Shift+d" = "${rofi} -modi drun -show drun"; - # Start Applications - "${mod}+Return" = "exec ${ + config = + let + # lockColors = with config.lib.stylix.colors.withHashtag; { a = base00; b = base01; d = base00; }; # Black or White, depending on current theme + # lockColors = with config.lib.stylix.colors.withHashtag; { a = base0A; b = base0B; d = base00; }; # Green + Yellow + lockColors = { a = "#82a401"; b = "#466c01"; d = "#648901"; }; # Old + lockSvg = pkgs.writeText "lock.svg" ""; + lockPng = pkgs.runCommand "lock.png" { } "${pkgs.imagemagick}/bin/convert ${lockSvg} $out"; + locker = "exec ${ pkgs.writeShellScript "i3-locker" + '' + # Remove SSH and GPG keys from keystores + ${pkgs.openssh}/bin/ssh-add -D + echo RELOADAGENT | ${pkgs.gnupg}/bin/gpg-connect-agent + ${pkgs.coreutils}/bin/rm -rf "/tmp/cached_pass_$UID" + + ${pkgs.lightdm}/bin/dm-tool lock + # TODO Does that work for all DMs? + if [ $? -ne 0 ]; then + if [ -d ${config.xdg.cacheHome}/lockpatterns ] + then + pattern=$(${pkgs.findutils} ${config.xdg.cacheHome}/lockpatterns | sort -R | head -1) + else + pattern=${lockPng} + fi + revert() { + ${pkgs.xorg.xset} dpms 0 0 0 + } + trap revert SIGHUP SIGINT SIGTERM + ${pkgs.xorg.xset} dpms 5 5 5 + ${pkgs.i3lock}/bin/i3lock --nofork --color ${builtins.substring 1 6 lockColors.d} --image=$pattern --tiling --ignore-empty-password + revert + fi + '' + }"; + focus = "exec ${ pkgs.writeShellScript "i3-focus-window" + '' + WINDOW=`${pkgs.xdotool}/bin/xdotool getwindowfocus` + eval `${pkgs.xdotool}/bin/xdotool getwindowgeometry --shell $WINDOW` # this brings in variables WIDTH and HEIGHT + TX=`${pkgs.coreutils}/bin/expr $WIDTH / 2` + TY=`${pkgs.coreutils}/bin/expr $HEIGHT / 2` + ${pkgs.xdotool}/bin/xdotool mousemove -window $WINDOW $TX $TY + '' + }"; + mode_system = "[L] Vérouillage [E] Déconnexion [S] Veille [H] Hibernation [R] Redémarrage [P] Extinction"; + mode_resize = "Resize"; + mode_pres_main = "Presentation (main display)"; + mode_pres_sec = "Presentation (secondary display)"; + in + { + terminal = "alacritty"; + # bars = []; # FIXME lemonbar + colors = let ignore = "#ff00ff"; in + with config.lib.stylix.colors.withHashtag; lib.mkForce { + focused = { border = base0B; background = base0B; text = base00; indicator = base00; childBorder = base0B; }; + focusedInactive = { border = base02; background = base02; text = base05; indicator = base02; childBorder = base02; }; + unfocused = { border = base05; background = base04; text = base00; indicator = base04; childBorder = base00; }; + urgent = { border = base0F; background = base08; text = base00; indicator = base08; childBorder = base0F; }; + placeholder = { border = ignore; background = base00; text = base05; indicator = ignore; childBorder = base00; }; + background = base07; + # I set the color of the active tab as the the background color of the terminal so they merge together. + }; + focus.followMouse = false; + keybindings = + let + mod = config.xsession.windowManager.i3.config.modifier; + rofi = "exec --no-startup-id ${config.programs.rofi.package}/bin/rofi"; + pactl = "exec ${pkgs.pulseaudio}/bin/pactl"; # TODO Use NixOS package if using NixOS + scrot = "${pkgs.scrot}/bin/scrot --exec '${pkgs.coreutils}/bin/mv $f ~/Screenshots/ && ${pkgs.optipng}/bin/optipng ~/Screenshots/$f'"; + # TODO nix path and create directory? + in + { + # Compatibility layer for people coming from other backgrounds + # "Mod1+Tab" = "${rofi} -modi window -show window"; # FIXME When no longer using a VM + "Mod1+F2" = "${rofi} -modi drun -show drun"; + "Mod1+F4" = "kill"; + # kill focused window + "${mod}+z" = "kill"; + button2 = "kill"; + # Rofi + "${mod}+c" = "exec --no-startup-id ${pkgs.rofi-pass}/bin/rofi-pass --last-used"; + # TODO Try autopass.cr + # 23.11 config.programs.rofi.pass.package + "${mod}+i" = "exec --no-startup-id ${pkgs.rofimoji}/bin/rofimoji"; + "${mod}+plus" = "${rofi} -modi ssh -show ssh"; + "${mod}+ù" = "${rofi} -modi ssh -show ssh -ssh-command '{terminal} -e {ssh-client} {host} -t \"sudo -s -E\"'"; + # TODO In which keyboard layout? + "${mod}+Tab" = "${rofi} -modi window -show window"; + # start program launcher + "${mod}+d" = "${rofi} -modi run -show run"; + "${mod}+Shift+d" = "${rofi} -modi drun -show drun"; + # Start Applications + "${mod}+Return" = "exec ${ pkgs.writeShellScript "terminal" "${config.programs.alacritty.package}/bin/alacritty msg create-window || exec ${config.programs.alacritty.package}/bin/alacritty -e zsh" - # TODO Is -e zsh required? + # -e zsh is for systems where I can't configure my user's shell + # TODO Is a shell script even required? }"; - "${mod}+Shift+Return" = "exec ${config.programs.urxvt.package}/bin/urxvt"; - "${mod}+p" = "exec ${pkgs.xfce.thunar}/bin/tunar"; - "${mod}+m" = "exec ${config.programs.qutebrowser.package}/bin/qutebrowser --override-restore --backend=webengine"; - # TODO --backend not useful anymore - # Volume control - "XF86AudioRaiseVolume" = "${pactl} set-sink-mute @DEFAULT_SINK@ false; ${pactl} set-sink-volume @DEFAULT_SINK@ +5%"; - "XF86AudioLowerVolume" = "${pactl} set-sink-mute @DEFAULT_SINK@ false; ${pactl} set-sink-volume @DEFAULT_SINK@ -5%"; - "XF86AudioMute" = "${pactl} set-sink-mute @DEFAULT_SINK@ true"; - "${mod}+F7" = "${pactl} suspend-sink @DEFAULT_SINK@ 1; ${pactl} suspend-sink @DEFAULT_SINK@ 0"; # Re-synchronize bluetooth headset - "${mod}+F11" = "exec ${pkgs.pavucontrol}/bin/pavucontrol"; - "${mod}+F12" = "exec ${pkgs.pavucontrol}/bin/pavucontrol"; - # TODO Find pacmixer? - # Media control - "XF86AudioPrev" = "exec ${pkgs.mpc-cli}/bin/mpc prev"; - "XF86AudioPlay" = "exec ${pkgs.mpc-cli}/bin/mpc toggle"; - "XF86AudioNext" = "exec ${pkgs.mpc-cli}/bin/mpc next"; - # Misc - "${mod}+F10" = "exec ${ pkgs.writeShellScript "show-keyboard-layout" - '' - layout=`${pkgs.xorg.setxkbmap}/bin/setxkbmap -query | ${pkgs.gnugrep}/bin/grep ^layout: | ${pkgs.gawk}/bin/awk '{ print $2 }'` - ${pkgs.libgnomekbd}/bin/gkbd-keyboard-display -l $layout - '' - }"; - # Screenshots - "Print" = "exec ${scrot} --focused"; - "${mod}+Print" = "exec ${scrot}"; # FIXME Doesn't work at least in the VM - "Ctrl+Print" = "exec ${pkgs.coreutils}/bin/sleep 1 && ${scrot} --select"; - # change focus - "${mod}+h" = "focus left; ${focus}"; - "${mod}+j" = "focus down; ${focus}"; - "${mod}+k" = "focus up; ${focus}"; - "${mod}+l" = "focus right; ${focus}"; - # move focused window - "${mod}+Shift+h" = "move left; ${focus}"; - "${mod}+Shift+j" = "move down; ${focus}"; - "${mod}+Shift+k" = "move up; ${focus}"; - "${mod}+Shift+l" = "move right; ${focus}"; - # workspace back and forth (with/without active container) - "${mod}+b" = "workspace back_and_forth; ${focus}"; - "${mod}+Shift+b" = "move container to workspace back_and_forth; workspace back_and_forth; ${focus}"; - # Change container layout - "${mod}+g" = "split h; ${focus}"; - "${mod}+v" = "split v; ${focus}"; - "${mod}+f" = "fullscreen toggle; ${focus}"; - "${mod}+s" = "layout stacking; ${focus}"; - "${mod}+w" = "layout tabbed; ${focus}"; - "${mod}+e" = "layout toggle split; ${focus}"; - "${mod}+Shift+space" = "floating toggle; ${focus}"; - # Focus container - "${mod}+space" = "focus mode_toggle; ${focus}"; - "${mod}+a" = "focus parent; ${focus}"; - "${mod}+q" = "focus child; ${focus}"; - # Switch to workspace - "${mod}+1" = "workspace 1; ${focus}"; - "${mod}+2" = "workspace 2; ${focus}"; - "${mod}+3" = "workspace 3; ${focus}"; - "${mod}+4" = "workspace 4; ${focus}"; - "${mod}+5" = "workspace 5; ${focus}"; - "${mod}+6" = "workspace 6; ${focus}"; - "${mod}+7" = "workspace 7; ${focus}"; - "${mod}+8" = "workspace 8; ${focus}"; - "${mod}+9" = "workspace 9; ${focus}"; - "${mod}+0" = "workspace 10; ${focus}"; - #navigate workspaces next / previous - "${mod}+Ctrl+h" = "workspace prev_on_output; ${focus}"; - "${mod}+Ctrl+l" = "workspace next_on_output; ${focus}"; - "${mod}+Ctrl+j" = "workspace prev; ${focus}"; - "${mod}+Ctrl+k" = "workspace next; ${focus}"; - # Move to workspace next / previous with focused container - "${mod}+Ctrl+Shift+h" = "move container to workspace prev_on_output; workspace prev_on_output; ${focus}"; - "${mod}+Ctrl+Shift+l" = "move container to workspace next_on_output; workspace next_on_output; ${focus}"; - "${mod}+Ctrl+Shift+j" = "move container to workspace prev; workspace prev; ${focus}"; - "${mod}+Ctrl+Shift+k" = "move container to workspace next; workspace next; ${focus}"; - # move focused container to workspace - "${mod}+ctrl+1" = "move container to workspace 1; ${focus}"; - "${mod}+ctrl+2" = "move container to workspace 2; ${focus}"; - "${mod}+ctrl+3" = "move container to workspace 3; ${focus}"; - "${mod}+ctrl+4" = "move container to workspace 4; ${focus}"; - "${mod}+ctrl+5" = "move container to workspace 5; ${focus}"; - "${mod}+ctrl+6" = "move container to workspace 6; ${focus}"; - "${mod}+ctrl+7" = "move container to workspace 7; ${focus}"; - "${mod}+ctrl+8" = "move container to workspace 8; ${focus}"; - "${mod}+ctrl+9" = "move container to workspace 9; ${focus}"; - "${mod}+ctrl+0" = "move container to workspace 10; ${focus}"; - # move to workspace with focused container - "${mod}+shift+1" = "move container to workspace 1; workspace 1; ${focus}"; - "${mod}+shift+2" = "move container to workspace 2; workspace 2; ${focus}"; - "${mod}+shift+3" = "move container to workspace 3; workspace 3; ${focus}"; - "${mod}+shift+4" = "move container to workspace 4; workspace 4; ${focus}"; - "${mod}+shift+5" = "move container to workspace 5; workspace 5; ${focus}"; - "${mod}+shift+6" = "move container to workspace 6; workspace 6; ${focus}"; - "${mod}+shift+7" = "move container to workspace 7; workspace 7; ${focus}"; - "${mod}+shift+8" = "move container to workspace 8; workspace 8; ${focus}"; - "${mod}+shift+9" = "move container to workspace 9; workspace 9; ${focus}"; - "${mod}+shift+0" = "move container to workspace 10; workspace 10; ${focus}"; - # move workspaces to screen (arrow keys) - "${mod}+ctrl+shift+Right" = "move workspace to output right; ${focus}"; - "${mod}+ctrl+shift+Left" = "move workspace to output left; ${focus}"; - "${mod}+Ctrl+Shift+Up" = "move workspace to output above; ${focus}"; - "${mod}+Ctrl+Shift+Down" = "move workspace to output below; ${focus}"; - # i3 control - "${mod}+Shift+c" = "reload"; - "${mod}+Shift+r" = "restart"; - "${mod}+Shift+e" = "exit"; - }; - }; + "${mod}+Shift+Return" = "exec ${config.programs.urxvt.package}/bin/urxvt"; + "${mod}+p" = "exec ${pkgs.xfce.thunar}/bin/tunar"; + "${mod}+m" = "exec ${config.programs.qutebrowser.package}/bin/qutebrowser --override-restore --backend=webengine"; + # TODO --backend not useful anymore + # Volume control + "XF86AudioRaiseVolume" = "${pactl} set-sink-mute @DEFAULT_SINK@ false; ${pactl} set-sink-volume @DEFAULT_SINK@ +5%"; + "XF86AudioLowerVolume" = "${pactl} set-sink-mute @DEFAULT_SINK@ false; ${pactl} set-sink-volume @DEFAULT_SINK@ -5%"; + "XF86AudioMute" = "${pactl} set-sink-mute @DEFAULT_SINK@ true"; + "${mod}+F7" = "${pactl} suspend-sink @DEFAULT_SINK@ 1; ${pactl} suspend-sink @DEFAULT_SINK@ 0"; # Re-synchronize bluetooth headset + "${mod}+F11" = "exec ${pkgs.pavucontrol}/bin/pavucontrol"; + "${mod}+F12" = "exec ${pkgs.pavucontrol}/bin/pavucontrol"; + # TODO Find pacmixer? + # Media control + "XF86AudioPrev" = "exec ${pkgs.mpc-cli}/bin/mpc prev"; + "XF86AudioPlay" = "exec ${pkgs.mpc-cli}/bin/mpc toggle"; + "XF86AudioNext" = "exec ${pkgs.mpc-cli}/bin/mpc next"; + # Misc + "${mod}+F10" = "exec ${ pkgs.writeShellScript "show-keyboard-layout" + '' + layout=`${pkgs.xorg.setxkbmap}/bin/setxkbmap -query | ${pkgs.gnugrep}/bin/grep ^layout: | ${pkgs.gawk}/bin/awk '{ print $2 }'` + ${pkgs.libgnomekbd}/bin/gkbd-keyboard-display -l $layout + '' + }"; + # Screenshots + "Print" = "exec ${scrot} --focused"; + "${mod}+Print" = "exec ${scrot}"; # FIXME Doesn't work at least in the VM + "Ctrl+Print" = "exec ${pkgs.coreutils}/bin/sleep 1 && ${scrot} --select"; + # TODO Try using bindsym --release instead of sleep + # change focus + "${mod}+h" = "focus left; ${focus}"; + "${mod}+j" = "focus down; ${focus}"; + "${mod}+k" = "focus up; ${focus}"; + "${mod}+l" = "focus right; ${focus}"; + # move focused window + "${mod}+Shift+h" = "move left; ${focus}"; + "${mod}+Shift+j" = "move down; ${focus}"; + "${mod}+Shift+k" = "move up; ${focus}"; + "${mod}+Shift+l" = "move right; ${focus}"; + # workspace back and forth (with/without active container) + "${mod}+b" = "workspace back_and_forth; ${focus}"; + "${mod}+Shift+b" = "move container to workspace back_and_forth; workspace back_and_forth; ${focus}"; + # Change container layout + "${mod}+g" = "split h; ${focus}"; + "${mod}+v" = "split v; ${focus}"; + "${mod}+f" = "fullscreen toggle; ${focus}"; + "${mod}+s" = "layout stacking; ${focus}"; + "${mod}+w" = "layout tabbed; ${focus}"; + "${mod}+e" = "layout toggle split; ${focus}"; + "${mod}+Shift+space" = "floating toggle; ${focus}"; + # Focus container + "${mod}+space" = "focus mode_toggle; ${focus}"; + "${mod}+a" = "focus parent; ${focus}"; + "${mod}+q" = "focus child; ${focus}"; + # Switch to workspace + "${mod}+1" = "workspace 1; ${focus}"; + "${mod}+2" = "workspace 2; ${focus}"; + "${mod}+3" = "workspace 3; ${focus}"; + "${mod}+4" = "workspace 4; ${focus}"; + "${mod}+5" = "workspace 5; ${focus}"; + "${mod}+6" = "workspace 6; ${focus}"; + "${mod}+7" = "workspace 7; ${focus}"; + "${mod}+8" = "workspace 8; ${focus}"; + "${mod}+9" = "workspace 9; ${focus}"; + "${mod}+0" = "workspace 10; ${focus}"; + #navigate workspaces next / previous + "${mod}+Ctrl+h" = "workspace prev_on_output; ${focus}"; + "${mod}+Ctrl+l" = "workspace next_on_output; ${focus}"; + "${mod}+Ctrl+j" = "workspace prev; ${focus}"; + "${mod}+Ctrl+k" = "workspace next; ${focus}"; + # Move to workspace next / previous with focused container + "${mod}+Ctrl+Shift+h" = "move container to workspace prev_on_output; workspace prev_on_output; ${focus}"; + "${mod}+Ctrl+Shift+l" = "move container to workspace next_on_output; workspace next_on_output; ${focus}"; + "${mod}+Ctrl+Shift+j" = "move container to workspace prev; workspace prev; ${focus}"; + "${mod}+Ctrl+Shift+k" = "move container to workspace next; workspace next; ${focus}"; + # move focused container to workspace + "${mod}+ctrl+1" = "move container to workspace 1; ${focus}"; + "${mod}+ctrl+2" = "move container to workspace 2; ${focus}"; + "${mod}+ctrl+3" = "move container to workspace 3; ${focus}"; + "${mod}+ctrl+4" = "move container to workspace 4; ${focus}"; + "${mod}+ctrl+5" = "move container to workspace 5; ${focus}"; + "${mod}+ctrl+6" = "move container to workspace 6; ${focus}"; + "${mod}+ctrl+7" = "move container to workspace 7; ${focus}"; + "${mod}+ctrl+8" = "move container to workspace 8; ${focus}"; + "${mod}+ctrl+9" = "move container to workspace 9; ${focus}"; + "${mod}+ctrl+0" = "move container to workspace 10; ${focus}"; + # move to workspace with focused container + "${mod}+shift+1" = "move container to workspace 1; workspace 1; ${focus}"; + "${mod}+shift+2" = "move container to workspace 2; workspace 2; ${focus}"; + "${mod}+shift+3" = "move container to workspace 3; workspace 3; ${focus}"; + "${mod}+shift+4" = "move container to workspace 4; workspace 4; ${focus}"; + "${mod}+shift+5" = "move container to workspace 5; workspace 5; ${focus}"; + "${mod}+shift+6" = "move container to workspace 6; workspace 6; ${focus}"; + "${mod}+shift+7" = "move container to workspace 7; workspace 7; ${focus}"; + "${mod}+shift+8" = "move container to workspace 8; workspace 8; ${focus}"; + "${mod}+shift+9" = "move container to workspace 9; workspace 9; ${focus}"; + "${mod}+shift+0" = "move container to workspace 10; workspace 10; ${focus}"; + # move workspaces to screen (arrow keys) + "${mod}+ctrl+shift+Right" = "move workspace to output right; ${focus}"; + "${mod}+ctrl+shift+Left" = "move workspace to output left; ${focus}"; + "${mod}+Ctrl+Shift+Up" = "move workspace to output above; ${focus}"; + "${mod}+Ctrl+Shift+Down" = "move workspace to output below; ${focus}"; + # i3 control + "${mod}+Shift+c" = "reload"; + "${mod}+Shift+r" = "restart"; + "${mod}+Shift+e" = "exit"; + # Modes + "${mod}+Escape" = "mode ${mode_system}"; + "${mod}+r" = "mode ${mode_resize}"; + "${mod}+Shift+p" = "mode ${mode_pres_main}"; + }; + modes = let return_bindings = { + "Return" = "mode default"; + "Escape" = "mode default"; + }; in + { + "${mode_system}" = { + "l" = "exec --no-startup-id ${locker}, mode default"; + "e" = "exit, mode default"; + "s" = "exec --no-startup-id ${locker} & ${pkgs.systemd}/bin/systemctl suspend, mode default"; + "h" = "exec --no-startup-id ${locker} & ${pkgs.systemd}/bin/systemctl hibernate, mode default"; + "r" = "exec --no-startup-id ${pkgs.systemd}/bin/systemctl reboot, mode default"; + "p" = "exec --no-startup-id ${pkgs.systemd}/bin/systemctl poweroff -i, mode default"; + } // return_bindings; + "${mode_resize}" = { + "h" = "resize shrink width 10 px or 10 ppt; ${focus}"; + "j" = "resize grow height 10 px or 10 ppt; ${focus}"; + "k" = "resize shrink height 10 px or 10 ppt; ${focus}"; + "l" = "resize grow width 10 px or 10 ppt; ${focus}"; + } // return_bindings; + "${mode_pres_main}" = { + "b" = "workspace 3, workspace 4, mode $mode_pres_sec"; + "q" = "mode default"; + "Return" = "mode default"; + }; + "${mode_pres_sec}" = { + "b" = "workspace 1, workspace 2, mode $mode_pres_main"; + "q" = "mode default"; + "Return" = "mode default"; + }; + }; + }; }; programs = { @@ -257,7 +331,6 @@ # x11-exclusive dunst - i3lock numlockx # TODO urxvt-resize-font-git simplescreenrecorder