Xmonad/Config archive/gray hemp's xmonad.hs
From HaskellWiki
< Xmonad | Config archive(Difference between revisions)
| Line 15: | Line 15: | ||
import XMonad.Hooks.DynamicLog | import XMonad.Hooks.DynamicLog | ||
import XMonad.Hooks.ManageDocks | import XMonad.Hooks.ManageDocks | ||
| + | import XMonad.Hooks.ManageHelpers | ||
import XMonad.Hooks.UrgencyHook | import XMonad.Hooks.UrgencyHook | ||
| + | import XMonad.Hooks.FadeInactive | ||
import qualified Data.Map as M | import qualified Data.Map as M | ||
| Line 23: | Line 25: | ||
main = do | main = do | ||
myStatusBarPipe <- spawnPipe myStatusBar | myStatusBarPipe <- spawnPipe myStatusBar | ||
| + | spawn "hsetroot && xcompmgr" | ||
spawn myCPUBar | spawn myCPUBar | ||
spawn myBatteryBar | spawn myBatteryBar | ||
spawn myTimeBar | spawn myTimeBar | ||
spawn myXxkbBar | spawn myXxkbBar | ||
| + | spawn myXsetRate | ||
xmonad $ myUrgencyHook $ defaultConfig { | xmonad $ myUrgencyHook $ defaultConfig { | ||
terminal = myTerminal, | terminal = myTerminal, | ||
| Line 36: | Line 40: | ||
manageHook = myManageHook <+> manageDocks <+> manageHook defaultConfig, | manageHook = myManageHook <+> manageDocks <+> manageHook defaultConfig, | ||
layoutHook = avoidStruts $ myLayoutHook, | layoutHook = avoidStruts $ myLayoutHook, | ||
| - | logHook = dynamicLogWithPP $ myDzenPP myStatusBarPipe | + | logHook = do dynamicLogWithPP $ myDzenPP myStatusBarPipe |
| + | myFadingHook | ||
} | } | ||
| Line 54: | Line 59: | ||
myHighlightedBgColor = "gray40" | myHighlightedBgColor = "gray40" | ||
| - | myActiveBorderColor = " | + | myActiveBorderColor = "gray20" |
myInactiveBorderColor = "gray20" | myInactiveBorderColor = "gray20" | ||
| Line 70: | Line 75: | ||
-- Bars | -- Bars | ||
| - | myDzenBarGeneralOptions = "-fn '" ++ myFont ++ "' -fg '" ++ myFgColor ++ "' -bg '" ++ myBgColor ++ "'" | + | myDzenBarGeneralOptions = "-h 15 -fn '" ++ myFont ++ "' -fg '" ++ myFgColor ++ |
| + | "' -bg '" ++ myBgColor ++ "'" | ||
| - | myStatusBar = "dzen2 -w | + | myStatusBar = "dzen2 -w 956 -ta l " ++ myDzenBarGeneralOptions |
| - | myCPUBar = "conky -c ~/.conky_cpu | sh | dzen2 -x | + | myCPUBar = "conky -c ~/.conky_cpu | sh | dzen2 -x 956 -w 90 -ta l " ++ |
| - | myBatteryBar = "conky -c ~/.conky_battery | sh | dzen2 -x | + | myDzenBarGeneralOptions |
| - | myTimeBar = "conky -c ~/.conky_time | dzen2 -x | + | myBatteryBar = "conky -c ~/.conky_battery | sh | dzen2 -x 1046 -w 63 -ta l " ++ |
| + | myDzenBarGeneralOptions | ||
| + | myTimeBar = "conky -c ~/.conky_time | dzen2 -x 1109 -w 156 -ta c " ++ | ||
| + | myDzenBarGeneralOptions | ||
myXxkbBar = "xxkb" -- configuration in ~/.xxkbrc | myXxkbBar = "xxkb" -- configuration in ~/.xxkbrc | ||
| + | myXsetRate = "xset r rate 250 30" | ||
-- Prefered terminal | -- Prefered terminal | ||
| Line 104: | Line 114: | ||
((modm, xK_p), shellPrompt myXPConfig), | ((modm, xK_p), shellPrompt myXPConfig), | ||
-- Do not leave useless conky, dzen and xxkb after restart | -- Do not leave useless conky, dzen and xxkb after restart | ||
| - | ((modm, xK_q), spawn "killall conky dzen2 xxkb; xmonad --recompile; xmonad --restart"), | + | ((modm, xK_q), spawn "killall conky dzen2 xxkb xcompmgr; xmonad --recompile; xmonad --restart"), |
-- ResizableTall key bindings | -- ResizableTall key bindings | ||
((modm, xK_a), sendMessage MirrorShrink), | ((modm, xK_a), sendMessage MirrorShrink), | ||
| Line 113: | Line 123: | ||
-- Make a screeshot | -- Make a screeshot | ||
((0, xK_Print), spawn "scrot -e 'mv $f ~/tmp/'"), | ((0, xK_Print), spawn "scrot -e 'mv $f ~/tmp/'"), | ||
| - | ((controlMask, xK_Print), spawn "sleep 0.2; scrot -s -e 'mv $f ~/tmp/'") | + | ((controlMask, xK_Print), spawn "sleep 0.2; scrot -s -e 'mv $f ~/tmp/'") |
] | ] | ||
| Line 122: | Line 132: | ||
supWsNum "3" "tr", | supWsNum "3" "tr", | ||
supWsNum "4" "ms", | supWsNum "4" "ms", | ||
| - | supWsNum "5" " | + | supWsNum "5" "mn", |
| - | supWsNum "6" " | + | supWsNum "6" "dc", |
supWsNum "7" "tm", | supWsNum "7" "tm", | ||
supWsNum "8" "", | supWsNum "8" "", | ||
| Line 134: | Line 144: | ||
myDzenPP h = defaultPP { | myDzenPP h = defaultPP { | ||
ppOutput = hPutStrLn h, | ppOutput = hPutStrLn h, | ||
| - | ppSep = " | + | ppSep = "", |
ppWsSep = "", | ppWsSep = "", | ||
ppCurrent = wrapFgBg myCurrentWsFgColor myCurrentWsBgColor, | ppCurrent = wrapFgBg myCurrentWsFgColor myCurrentWsBgColor, | ||
| Line 154: | Line 164: | ||
wrapBg color content = wrap ("^bg(" ++ color ++ ")") "^bg()" content | wrapBg color content = wrap ("^bg(" ++ color ++ ")") "^bg()" content | ||
wrapBitmap bitmap = "^p(5)^i(" ++ myBitmapsPath ++ bitmap ++ ")^p(5)" | wrapBitmap bitmap = "^p(5)^i(" ++ myBitmapsPath ++ bitmap ++ ")^p(5)" | ||
| + | |||
| + | -- Fading hook | ||
| + | myFadingHook = fadeInactiveLogHook fadeAmount | ||
| + | where fadeAmount = 0.85 | ||
-- Define a combination of layouts | -- Define a combination of layouts | ||
| - | myLayoutHook = smartBorders $ (tiled ||| Mirror tiled ||| Full) -- The only window w/o borders | + | myLayoutHook = smartBorders $ (tiled ||| Mirror tiled ||| Full) |
| + | -- The only window w/o borders | ||
where | where | ||
tiled = ResizableTall nmaster delta ratio [] | tiled = ResizableTall nmaster delta ratio [] | ||
| Line 176: | Line 191: | ||
} | } | ||
| - | myManageHook = composeAll [ | + | -- Window rules |
| - | resource | + | myManageHook = composeAll . concat $ [ |
| + | [isDialog --> doFloat], | ||
| + | [className =? c --> doFloat | c <- myCFloats], | ||
| + | [title =? t --> doFloat | t <- myTFloats], | ||
| + | [resource =? r --> doFloat | r <- myRFloats], | ||
| + | [resource =? i --> doIgnore | i <- myIgnores] | ||
] | ] | ||
| + | where | ||
| + | myCFloats = ["Xmessage"] | ||
| + | myTFloats = ["Save As...", "Save File", "Options"] | ||
| + | myRFloats = [] | ||
| + | myIgnores = ["XXkb"] | ||
</haskell> | </haskell> | ||
Current revision
-- dzen2 plus conky config with urgency for xmonad-0.9* -- uses icons from dzen.geekmode.org import XMonad import XMonad.Core import XMonad.Prompt import XMonad.Prompt.Shell import XMonad.Prompt.Man import XMonad.Layout import XMonad.Layout.NoBorders import XMonad.Layout.ResizableTile import XMonad.Hooks.DynamicLog import XMonad.Hooks.ManageDocks import XMonad.Hooks.ManageHelpers import XMonad.Hooks.UrgencyHook import XMonad.Hooks.FadeInactive import qualified Data.Map as M import Graphics.X11.Xlib import XMonad.Util.Run main = do myStatusBarPipe <- spawnPipe myStatusBar spawn "hsetroot && xcompmgr" spawn myCPUBar spawn myBatteryBar spawn myTimeBar spawn myXxkbBar spawn myXsetRate xmonad $ myUrgencyHook $ defaultConfig { terminal = myTerminal, normalBorderColor = myInactiveBorderColor, focusedBorderColor = myActiveBorderColor, workspaces = myWorkspaces, modMask = myModMask, keys = myKeys, manageHook = myManageHook <+> manageDocks <+> manageHook defaultConfig, layoutHook = avoidStruts $ myLayoutHook, logHook = do dynamicLogWithPP $ myDzenPP myStatusBarPipe myFadingHook } -- Fonts myFont = "xft:monospace:size=8" mySmallFont = "xft:monospace:size=5" -- Paths myBitmapsPath = "/home/gray/.dzen/bitmaps/" -- Colors myBgBgColor = "black" myFgColor = "gray80" myBgColor = "gray20" myHighlightedFgColor = "white" myHighlightedBgColor = "gray40" myActiveBorderColor = "gray20" myInactiveBorderColor = "gray20" myCurrentWsFgColor = "white" myCurrentWsBgColor = "gray40" myVisibleWsFgColor = "gray80" myVisibleWsBgColor = "gray20" myHiddenWsFgColor = "gray80" myHiddenEmptyWsFgColor = "gray50" myUrgentWsBgColor = "brown" myTitleFgColor = "white" myUrgencyHintFgColor = "white" myUrgencyHintBgColor = "brown" -- Bars myDzenBarGeneralOptions = "-h 15 -fn '" ++ myFont ++ "' -fg '" ++ myFgColor ++ "' -bg '" ++ myBgColor ++ "'" myStatusBar = "dzen2 -w 956 -ta l " ++ myDzenBarGeneralOptions myCPUBar = "conky -c ~/.conky_cpu | sh | dzen2 -x 956 -w 90 -ta l " ++ myDzenBarGeneralOptions myBatteryBar = "conky -c ~/.conky_battery | sh | dzen2 -x 1046 -w 63 -ta l " ++ myDzenBarGeneralOptions myTimeBar = "conky -c ~/.conky_time | dzen2 -x 1109 -w 156 -ta c " ++ myDzenBarGeneralOptions myXxkbBar = "xxkb" -- configuration in ~/.xxkbrc myXsetRate = "xset r rate 250 30" -- Prefered terminal myTerminal = "urxvt" -- Rebind Mod to Windows key myModMask = mod4Mask -- Prompt config myXPConfig = defaultXPConfig { position = Bottom, promptBorderWidth = 0, font = myFont, height = 15, bgColor = myBgColor, fgColor = myFgColor, fgHLight = myHighlightedFgColor, bgHLight = myHighlightedBgColor } -- Union default and new key bindings myKeys x = M.union (M.fromList (newKeys x)) (keys defaultConfig x) -- Add new and/or redefine key bindings newKeys conf@(XConfig {XMonad.modMask = modm}) = [ -- Use shellPrompt instead of default dmenu ((modm, xK_p), shellPrompt myXPConfig), -- Do not leave useless conky, dzen and xxkb after restart ((modm, xK_q), spawn "killall conky dzen2 xxkb xcompmgr; xmonad --recompile; xmonad --restart"), -- ResizableTall key bindings ((modm, xK_a), sendMessage MirrorShrink), ((modm, xK_z), sendMessage MirrorExpand), -- Manual page prompt ((modm, xK_o), manPrompt myXPConfig), ((modm, xK_u), focusUrgent), -- Make a screeshot ((0, xK_Print), spawn "scrot -e 'mv $f ~/tmp/'"), ((controlMask, xK_Print), spawn "sleep 0.2; scrot -s -e 'mv $f ~/tmp/'") ] -- Workspaces names myWorkspaces = [ supWsNum "1" "dv", supWsNum "2" "wb", supWsNum "3" "tr", supWsNum "4" "ms", supWsNum "5" "mn", supWsNum "6" "dc", supWsNum "7" "tm", supWsNum "8" "", supWsNum "9" "" ] where supWsNum wsName wsNum =" " ++ wsName ++ "^p(;_TOP)^fn(" ++ mySmallFont ++ ")" ++ wsNum ++ " ^fn()^p()" -- Dzen config myDzenPP h = defaultPP { ppOutput = hPutStrLn h, ppSep = "", ppWsSep = "", ppCurrent = wrapFgBg myCurrentWsFgColor myCurrentWsBgColor, ppVisible = wrapFgBg myVisibleWsFgColor myVisibleWsBgColor, ppHidden = wrapFg myHiddenWsFgColor, ppHiddenNoWindows = wrapFg myHiddenEmptyWsFgColor, ppUrgent = wrapBg myUrgentWsBgColor, ppTitle = (\x -> " " ++ wrapFg myTitleFgColor x), ppLayout = dzenColor myFgColor"" . (\x -> case x of "ResizableTall" -> wrapBitmap "rob/tall.xbm" "Mirror ResizableTall" -> wrapBitmap "rob/mtall.xbm" "Full" -> wrapBitmap "rob/full.xbm" ) } where wrapFgBg fgColor bgColor content= wrap ("^fg(" ++ fgColor ++ ")^bg(" ++ bgColor ++ ")") "^fg()^bg()" content wrapFg color content = wrap ("^fg(" ++ color ++ ")") "^fg()" content wrapBg color content = wrap ("^bg(" ++ color ++ ")") "^bg()" content wrapBitmap bitmap = "^p(5)^i(" ++ myBitmapsPath ++ bitmap ++ ")^p(5)" -- Fading hook myFadingHook = fadeInactiveLogHook fadeAmount where fadeAmount = 0.85 -- Define a combination of layouts myLayoutHook = smartBorders $ (tiled ||| Mirror tiled ||| Full) -- The only window w/o borders where tiled = ResizableTall nmaster delta ratio [] nmaster = 1 delta = 3/100 ratio = 1/2 -- Urgency hint configuration myUrgencyHook = withUrgencyHook dzenUrgencyHook { args = [ "-x", "0", "-y", "785", "-h", "15", "-w", "1280", "-ta", "r", "-expand", "l", "-fg", "" ++ myUrgencyHintFgColor ++ "", "-bg", "" ++ myUrgencyHintBgColor ++ "", "-fn", "" ++ myFont ++ "" ], duration = (7 `seconds`) } -- Window rules myManageHook = composeAll . concat $ [ [isDialog --> doFloat], [className =? c --> doFloat | c <- myCFloats], [title =? t --> doFloat | t <- myTFloats], [resource =? r --> doFloat | r <- myRFloats], [resource =? i --> doIgnore | i <- myIgnores] ] where myCFloats = ["Xmessage"] myTFloats = ["Save As...", "Save File", "Options"] myRFloats = [] myIgnores = ["XXkb"]
