# NOTE(koekeishiya): A list of all built-in modifier and literal keywords can # be found at https://github.com/koekeishiya/skhd/issues/1 # # A hotkey is written according to the following rules: # # hotkey = '<' | # # mode = 'name of mode' | ',' # # action = ':' | '->' ':' # ';' | '->' ';' # # keysym = '-' | # # mod = 'built-in mod keyword' | '+' # # key = | # # literal = 'single letter or built-in keyword' # # keycode = 'apple keyboard kVK_ values (0x3C)' # # -> = keypress is not consumed by skhd # # command = command is executed through '$SHELL -c' and # follows valid shell syntax. if the $SHELL environment # variable is not set, it will default to '/bin/bash'. # when bash is used, the ';' delimeter can be specified # to chain commands. # # to allow a command to extend into multiple lines, # prepend '\' at the end of the previous line. # # an EOL character signifies the end of the bind. # # # NOTE(koekeishiya): A mode is declared according to the following rules: # # mode_decl = '::' '@' ':' | '::' ':' | # '::' '@' | '::' # # name = desired name for this mode, # # @ = capture keypresses regardless of being bound to an action # # command = command is executed through '$SHELL -c' and # follows valid shell syntax. if the $SHELL environment # variable is not set, it will default to '/bin/bash'. # when bash is used, the ';' delimeter can be specified # to chain commands. # # to allow a command to extend into multiple lines, # prepend '\' at the end of the previous line. # # an EOL character signifies the end of the bind. # add an on_enter command to the default mode # :: default : chunkc border::color 0xff775759 # # defines a new mode 'test' with an on_enter command, that captures keypresses # :: test @ : chunkc border::color 0xff24ccaa # # from 'default' mode, activate mode 'test' # cmd - x ; test # # from 'test' mode, activate mode 'default' # test < cmd - x ; default # # launch a new terminal instance when in either 'default' or 'test' mode # default, test < cmd - return : open -na /Applications/Terminal.app rctrl - return : /Applications/Kitty.app/Contents/MacOS/kitty --single-instance\ --directory=$HOME --listen-on=unix:$XDG_CACHE_HOME/kitty/kitty.sock # open qutebrowser rctrl + shift - return : ~/.local/bin/qtb # close focused window rctrl - q : chunkc tiling::window --close # focus window rctrl - j : chunkc tiling::window --focus next rctrl - k : chunkc tiling::window --focus prev cmd - tab : chunkc tiling::window --focus prev cmd + shift - tab : chunkc tiling::window --focus next # equalize size of windows (mod+=) rctrl - 0x18 : chunkc tiling::desktop --equalize # move window rctrl + shift - j : chunkc tiling::window --warp next rctrl + shift - k : chunkc tiling::window --warp prev # make floating window fill screen shift + alt - up : chunkc tiling::window --grid-layout 1:1:0:0:1:1 # make floating window fill left-half of screen shift + alt - left : chunkc tiling::window --grid-layout 1:2:0:0:1:1 # make floating window fill right-half of screen shift + alt - right : chunkc tiling::window --grid-layout 1:2:1:0:1:1 # fast focus desktop rctrl - x : chunkc tiling::desktop --focus $(chunkc get _last_active_desktop) rctrl - z : chunkc tiling::desktop --focus prev rctrl - c : chunkc tiling::desktop --focus next rctrl - 1 : chunkc tiling::desktop --focus 1 rctrl - 2 : chunkc tiling::desktop --focus 2 rctrl - 3 : chunkc tiling::desktop --focus 3 rctrl - 4 : chunkc tiling::desktop --focus 4 rctrl - 5 : chunkc tiling::desktop --focus 5 rctrl - 6 : chunkc tiling::desktop --focus 6 # send window to desktop rctrl + shift - x : chunkc tiling::window --send-to-desktop $(chunkc get _last_active_desktop) rctrl + shift - z : chunkc tiling::window --send-to-desktop prev rctrl + shift - c : chunkc tiling::window --send-to-desktop next rctrl + shift - 1 : chunkc tiling::window --send-to-desktop 1 rctrl + shift - 2 : chunkc tiling::window --send-to-desktop 2 rctrl + shift - 3 : chunkc tiling::window --send-to-desktop 3 rctrl + shift - 4 : chunkc tiling::window --send-to-desktop 4 rctrl + shift - 5 : chunkc tiling::window --send-to-desktop 5 rctrl + shift - 6 : chunkc tiling::window --send-to-desktop 6 # send window to desktop and follow focus # shift + cmd - x : chunkc tiling::window --send-to-desktop $(chunkc get _last_active_desktop); chunkc tiling::desktop --focus $(chunkc get _last_active_desktop) # shift + cmd - z : chunkc tiling::window --send-to-desktop prev; chunkc tiling::desktop --focus prev # shift + cmd - c : chunkc tiling::window --send-to-desktop next; chunkc tiling::desktop --focus next # shift + cmd - 1 : chunkc tiling::window --send-to-desktop 1; chunkc tiling::desktop --focus 1 # shift + cmd - 2 : chunkc tiling::window --send-to-desktop 2; chunkc tiling::desktop --focus 2 # shift + cmd - 3 : chunkc tiling::window --send-to-desktop 3; chunkc tiling::desktop --focus 3 # shift + cmd - 4 : chunkc tiling::window --send-to-desktop 4; chunkc tiling::desktop --focus 4 # shift + cmd - 5 : chunkc tiling::window --send-to-desktop 5; chunkc tiling::desktop --focus 5 # shift + cmd - 6 : chunkc tiling::window --send-to-desktop 6; chunkc tiling::desktop --focus 6 # shift + cmd - 7 : chunkc tiling::window --send-to-desktop 7; chunkc tiling::desktop --focus 7 # focus monitor rctrl - w : chunkc tiling::monitor -f 1 rctrl - e : chunkc tiling::monitor -f 2 # send window to monitor and follow focus rctrl + shift - w : chunkc tiling::window --send-to-monitor 1; chunkc tiling::monitor -f 1 rctrl + shift - e : chunkc tiling::window --send-to-monitor 2; chunkc tiling::monitor -f 2 # set insertion point for focused container # ctrl + alt - f : chunkc tiling::window --use-insertion-point cancel # ctrl + alt - h : chunkc tiling::window --use-insertion-point west # ctrl + alt - j : chunkc tiling::window --use-insertion-point south # ctrl + alt - k : chunkc tiling::window --use-insertion-point north # ctrl + alt - l : chunkc tiling::window --use-insertion-point east # rotate tree rctrl - space : chunkc tiling::desktop --rotate 90 # mirror tree rctrl - m : chunkc tiling::desktop --mirror horizontal rctrl + shift - m : chunkc tiling::desktop --mirror vertical # toggle desktop offset # alt - a : chunkc tiling::desktop --toggle offset # toggle window fullscreen rctrl - f : chunkc tiling::window --toggle fullscreen # toggle window native fullscreen rctrl + shift - f : chunkc tiling::window --toggle native-fullscreen # toggle window parent zoom alt - d : chunkc tiling::window --toggle parent # toggle window split type alt - e : chunkc tiling::window --toggle split # toggle window fade alt - q : chunkc tiling::window --toggle fade # float / unfloat window and center on screen alt - t : chunkc tiling::window --toggle float;\ chunkc tiling::window --grid-layout 4:4:1:1:2:2 # toggle sticky, float and resize to picture-in-picture size alt - s : chunkc tiling::window --toggle sticky;\ chunkc tiling::window --grid-layout 5:5:4:0:1:1 # float next window to be tiled # shift + alt - t : chunkc set window_float_next 1 # change layout of desktop rctrl - a : chunkc tiling::desktop --layout bsp rctrl - s : chunkc tiling::desktop --layout monocle rctrl - d : chunkc tiling::desktop --layout float play : mpc toggle rewind : mpc cdprev fast : mpc next