mirror of
https://github.com/NaomiAmethyst/dots.git
synced 2025-04-13 09:30:06 +00:00
49 lines
1.4 KiB
Haskell
49 lines
1.4 KiB
Haskell
import XMonad
|
|
|
|
import XMonad.Layout.Grid
|
|
import XMonad.Layout.NoBorders(smartBorders)
|
|
|
|
import XMonad.Hooks.DynamicLog
|
|
import XMonad.Hooks.ManageDocks
|
|
|
|
import XMonad.Util.Run(spawnPipe)
|
|
import XMonad.Util.EZConfig(additionalKeysP)
|
|
|
|
import XMonad.Prompt
|
|
import XMonad.Prompt.Shell(shellPrompt)
|
|
import XMonad.Prompt.Window
|
|
|
|
import System.IO(hPutStrLn)
|
|
|
|
myLayoutHook = tiled ||| Mirror tiled ||| Grid ||| Full
|
|
where
|
|
-- default tiling algorithm partitions the screen into two panes
|
|
tiled = Tall nmaster delta ratio
|
|
|
|
-- The default number of windows in the master pane
|
|
nmaster = 1
|
|
|
|
-- Default proportion of screen occupied by master pane
|
|
ratio = 1/2
|
|
|
|
-- Percent of screen to increment by when resizing panes
|
|
delta = 3/100
|
|
|
|
main = do
|
|
xmproc <- spawnPipe "~/.cabal/bin/xmobar"
|
|
xmonad $ defaultConfig
|
|
{ manageHook = manageDocks <+> manageHook defaultConfig
|
|
, layoutHook = avoidStruts $ smartBorders $ myLayoutHook
|
|
, logHook = dynamicLogWithPP $ xmobarPP
|
|
{ ppOutput = hPutStrLn xmproc
|
|
, ppTitle = xmobarColor "green" ""
|
|
}
|
|
, terminal = "uxterm /bin/zsh"
|
|
}
|
|
`additionalKeysP`
|
|
[ ("M-p", shellPrompt defaultXPConfig { position = Top })
|
|
, ("M-S-a", windowPromptGoto defaultXPConfig { position = Top })
|
|
, ("M-a", windowPromptBring defaultXPConfig { position = Top })
|
|
, ("M-b", sendMessage ToggleStruts)
|
|
, ("M-S-l", spawn "~/bin/lock")
|
|
]
|