49 lines
1.6 KiB
Haskell
49 lines
1.6 KiB
Haskell
|
--
|
||
|
-- It overrides a few basic settings, reusing all other defaults.
|
||
|
--
|
||
|
|
||
|
import XMonad
|
||
|
import XMonad.Actions.WindowGo
|
||
|
import XMonad.Hooks.FadeInactive
|
||
|
import XMonad.Hooks.ManageDocks
|
||
|
import XMonad.Hooks.ManageHelpers
|
||
|
import XMonad.Util.EZConfig
|
||
|
|
||
|
import qualified XMonad.StackSet as W
|
||
|
|
||
|
myLogHook :: X ()
|
||
|
myLogHook = fadeOutLogHook fadeRules
|
||
|
|
||
|
fadeRules :: Query Rational
|
||
|
fadeRules = do
|
||
|
fullscreen <- isFullscreen
|
||
|
conkeror <- className =? "Conkeror"
|
||
|
return $ case () of _ | fullscreen -> 1
|
||
|
| conkeror -> 0.95
|
||
|
| otherwise -> 0.9
|
||
|
|
||
|
main = xmonad $ defaultConfig
|
||
|
{ terminal = "urxvt"
|
||
|
, focusFollowsMouse = False
|
||
|
, clickJustFocuses = False
|
||
|
, modMask = mod4Mask
|
||
|
, layoutHook = avoidStruts $ layoutHook defaultConfig
|
||
|
, logHook = myLogHook
|
||
|
, manageHook = manageHook defaultConfig <+> manageDocks }
|
||
|
`additionalKeysP`
|
||
|
[
|
||
|
("C-z ,", screenWorkspace 0 >>= flip whenJust (windows . W.view)),
|
||
|
("C-z .", screenWorkspace 1 >>= flip whenJust (windows . W.view)),
|
||
|
("C-z S-c", spawn "urxvt"),
|
||
|
("C-z S-e", spawn "emacsclient -ca emacs"),
|
||
|
("C-z c", runOrRaiseNext "urxvt" (className =? "URxvt")),
|
||
|
("C-z e", runOrRaiseNext "emacsclient -ca emacs" (className =? "Emacs")),
|
||
|
("C-z w", runOrRaiseNext "conkeror" (className =? "Conkeror")),
|
||
|
("M-S-1", spawn "dmenu_run"),
|
||
|
("M-n", windows W.focusDown),
|
||
|
("M-p", windows W.focusUp),
|
||
|
("M1-C-l", spawn "i3lock -c 000000")
|
||
|
]
|
||
|
`removeKeysP`
|
||
|
[ ("M-j"), ("M-k") ]
|