aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAdrian Kummerlaender2018-05-01 12:21:10 +0200
committerAdrian Kummerlaender2018-05-01 12:21:10 +0200
commitc00aecf24261ca501c6d0944e79b8655a18cc54e (patch)
tree9671315c0e4aac05cdf4238a017e47e28b79d9d3
parent7c4ae27d2895cc5e840b32774761c8349232a65a (diff)
downloadnixos_home-c00aecf24261ca501c6d0944e79b8655a18cc54e.tar
nixos_home-c00aecf24261ca501c6d0944e79b8655a18cc54e.tar.gz
nixos_home-c00aecf24261ca501c6d0944e79b8655a18cc54e.tar.bz2
nixos_home-c00aecf24261ca501c6d0944e79b8655a18cc54e.tar.lz
nixos_home-c00aecf24261ca501c6d0944e79b8655a18cc54e.tar.xz
nixos_home-c00aecf24261ca501c6d0944e79b8655a18cc54e.tar.zst
nixos_home-c00aecf24261ca501c6d0944e79b8655a18cc54e.zip
Restructure XMonad keybindings
-rw-r--r--conf/xmonad/xmonad.hs81
1 files changed, 46 insertions, 35 deletions
diff --git a/conf/xmonad/xmonad.hs b/conf/xmonad/xmonad.hs
index 90897ce..6286177 100644
--- a/conf/xmonad/xmonad.hs
+++ b/conf/xmonad/xmonad.hs
@@ -19,6 +19,9 @@ import XMonad.Actions.GroupNavigation
import System.Exit
import Data.Maybe
+workspaces :: [WorkspaceId]
+workspaces = map show [1 .. 9 :: Int]
+
customTabTheme = (theme xmonadTheme)
{ fontName = "xft:Iosevka Medium-12"
, decoHeight = 20
@@ -53,63 +56,71 @@ scratchpads = [ NS "terminal" "kitty --class=scratchterm" (className =? "scratch
(customFloating floatRectCenter)
, NS "browser" "firefox" (className =? "Firefox")
(customFloating floatRectTop)
- , NS "zeal" "zeal" (className =? "Zeal")
+ , NS "documentation" "zeal" (className =? "Zeal")
(customFloating floatRectFull)
- , NS "telegram" "telegram-desktop" (className =? "TelegramDesktop")
+ , NS "messaging" "telegram-desktop" (className =? "TelegramDesktop")
(customFloating floatRectCenter) ]
-main = xmonad $ ewmh
- $ defaultConfig
- { modMask = mod4Mask -- super key as modifier
- , borderWidth = 3
- , normalBorderColor = "#161616"
- , focusedBorderColor = "#909737"
- , terminal = "kitty"
- , handleEventHook = handleEventHook defaultConfig <+> fullscreenEventHook
- , layoutHook = availableLayouts
- , manageHook = namedScratchpadManageHook scratchpads
- , logHook = historyHook }
- `removeKeysP`
- [ "M-S-<Return>", "M-q", "M-S-q", "M-S-c", "M-<Space>" ]
- `additionalKeysP`
+keybindings =
-- xmonad session control
[ ("C-M1-<Escape>" , io (exitWith ExitSuccess))
, ("C-M1-<Backspace>" , spawn "xmonad --restart")
-- application launchers
- , ("M-p" , spawn "rofi -show combi")
+ , ("M-<Space>" , spawn "rofi -show combi")
, ("M-<Return>" , spawn "kitty")
, ("M-S-<Return>" , spawn "vim -g")
-- window management
, ("M-q" , windows $ shift "NSP")
, ("M-S-q" , kill)
- , ("M-S-m" , windows swapMaster)
+ , ("M-j" , windows focusDown)
+ , ("M-k" , windows focusUp)
+ , ("M-S-j" , windows swapDown)
+ , ("M-S-k" , windows swapUp)
+ , ("M-h" , sendMessage Shrink)
+ , ("M-l" , sendMessage Expand)
, ("M-<Backspace>" , nextMatch History (return True))
-- window bringer
, ("M-a" , gotoMenuConfig windowBringerDmenuConfig)
, ("M-S-a" , bringMenuConfig windowBringerDmenuConfig)
--- workspace management
- , ("M-w l" , sendMessage NextLayout)
- , ("M-w p" , toggleWS' ["NSP"])
- , ("M-w j" , moveTo Next nonEmptyWS)
- , ("M-w k" , moveTo Prev nonEmptyWS)
- , ("M-S-w j" , shiftTo Next nonEmptyWS >> moveTo Next nonEmptyWS)
- , ("M-S-w k" , shiftTo Prev nonEmptyWS >> moveTo Prev nonEmptyWS)
-- scratchpads
- , ("M-s t" , namedScratchpadAction scratchpads "terminal")
- , ("M-s b" , namedScratchpadAction scratchpads "browser")
- , ("M-s h" , namedScratchpadAction scratchpads "zeal")
- , ("M-s m" , namedScratchpadAction scratchpads "telegram")
+ , ("M-b" , namedScratchpadAction scratchpads "browser")
+ , ("M-d" , namedScratchpadAction scratchpads "documentation")
+ , ("M-m" , namedScratchpadAction scratchpads "messaging") ] ++
+-- workspace selection
+ [ (p ++ [k] , windows $ f i) | (i, k) <- zip Main.workspaces ['1' .. '9']
+ , (p, f) <- [ ("M-", greedyView), ("M-S-", shift) ] ] ++
+-- workspace management
+ [ ("M-s l" , sendMessage NextLayout)
+ , ("M-s p" , toggleWS' ["NSP"])
+ , ("M-s j" , moveTo Next nonEmptyWS)
+ , ("M-s k" , moveTo Prev nonEmptyWS)
+ , ("M-S-s j" , shiftTo Next nonEmptyWS >> moveTo Next nonEmptyWS)
+ , ("M-S-s k" , shiftTo Prev nonEmptyWS >> moveTo Prev nonEmptyWS)
-- floating placement
- , ("M-f f" , withFocused $ placeFloating floatRectFull)
- , ("M-f c" , withFocused $ placeFloating floatRectCenter)
- , ("M-f j" , withFocused $ placeFloating floatRectBottom)
- , ("M-f k" , withFocused $ placeFloating floatRectTop)
- , ("M-f h" , withFocused $ placeFloating floatRectLeft)
- , ("M-f l" , withFocused $ placeFloating floatRectRight)
+ , ("M-w t" , withFocused $ windows . sink)
+ , ("M-w f" , withFocused $ placeFloating floatRectFull)
+ , ("M-w c" , withFocused $ placeFloating floatRectCenter)
+ , ("M-w j" , withFocused $ placeFloating floatRectBottom)
+ , ("M-w k" , withFocused $ placeFloating floatRectTop)
+ , ("M-w h" , withFocused $ placeFloating floatRectLeft)
+ , ("M-w l" , withFocused $ placeFloating floatRectRight)
-- system control
, ("M-c <Up>" , spawn "amixer sset Master 10%+")
, ("M-c <Down>" , spawn "amixer sset Master 10%-")
, ("M-c m" , spawn "amixer sset Master toggle") ]
+
+main = xmonad $ ewmh
+ $ defaultConfig
+ { modMask = mod4Mask -- super key as modifier
+ , borderWidth = 3
+ , normalBorderColor = "#161616"
+ , focusedBorderColor = "#909737"
+ , keys = \c -> mkKeymap c keybindings
+ , startupHook = return () >> checkKeymap defaultConfig keybindings
+ , handleEventHook = handleEventHook defaultConfig <+> fullscreenEventHook
+ , layoutHook = availableLayouts
+ , manageHook = namedScratchpadManageHook scratchpads
+ , logHook = historyHook }
`additionalKeys`
[ ((noModMask, xK_Menu) , namedScratchpadAction scratchpads "terminal") ]