xmonad.hs 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. import XMonad
  2. import XMonad.Config.Desktop
  3. import XMonad.Hooks.DynamicLog
  4. import XMonad.Hooks.ManageDocks
  5. import XMonad.Util.Run(spawnPipe, hPutStrLn, runProcessWithInput)
  6. -- Layouts
  7. import XMonad.Layout.Spacing(smartSpacing)
  8. import XMonad.Layout.Tabbed
  9. import XMonad.Layout.NoBorders
  10. -- Shutdown commands and keys
  11. import Data.Map(fromList)
  12. import XMonad.Prompt
  13. import XMonad.Prompt.XMonad
  14. import System.Exit(ExitCode(ExitSuccess), exitWith)
  15. import XMonad.Util.EZConfig(additionalKeys)
  16. -- Brightness and audio keys
  17. import Graphics.X11.ExtraTypes.XF86
  18. main = do
  19. xmproc <- spawnPipe "xmobar"
  20. xmonad $ docks defaultConfig
  21. { manageHook = manageDocks <+> manageHook defaultConfig
  22. , layoutHook = smartBorders $ avoidStruts $
  23. (smartSpacing 5 $ withBorder 2 $ Tall 1 (3/100) (1/2)) |||
  24. (smartSpacing 5 $ withBorder 2 $ Mirror (Tall 1 (3/100) (1/2))) |||
  25. Full |||
  26. tabbed shrinkText def
  27. , logHook = dynamicLogWithPP xmobarPP
  28. { ppOutput = hPutStrLn xmproc
  29. , ppTitle = xmobarColor "green" "" . shorten 50
  30. }
  31. , startupHook = startup
  32. , terminal = "gnome-terminal"
  33. , modMask = mod4Mask
  34. } `additionalKeys` myKeys
  35. startup :: X ()
  36. startup = do
  37. spawn "feh --bg-scale ~/Owncloud/Backgrounds/Xmbindings.png"
  38. spawn "owncloud"
  39. spawn "trayer --edge top --align right --SetDockType true --SetPartialStrut true --expand true --width 10 --transparent true --alpha 0 --tint 0x000000 --height 22"
  40. -- spawn "trayer --transparent true --alpha 0 --tint 0x00000000 --SetDockType true --expand true --edge top --align right --width 15 --height 18"
  41. -- spawn "stalonetray -geometry 1x1+1900 -bg '#000000' --kludges use_icons_hints --grow-gravity NE --icon-gravity NE -i 20 -t false"
  42. spawn "xfce4-clipman"
  43. spawn "xbacklight -set 12"
  44. spawn "compton"
  45. spawn "xscreensaver -nosplash"
  46. myKeys = [
  47. -- scrot
  48. ((controlMask, xK_Print), spawn "sleep 0.2; scrot -s")
  49. , ((0, xK_Print), spawn "scrot")
  50. -- rofi
  51. , ((mod4Mask, xK_p ), spawn "rofi -show run")
  52. -- shutdown
  53. , ((mod4Mask .|. shiftMask, xK_q),
  54. xmonadPrompt defaultXPConfig
  55. { promptKeymap = fromList
  56. [ ((0, xK_r), do
  57. spawn "emacsclient -e '(kill emacs)'"
  58. spawn "systemctl reboot")
  59. , ((0 , xK_s), do
  60. spawn "emacsclient -e '(kill emacs)'"
  61. spawn "sudo poweroff")
  62. , ((0, xK_e), do
  63. spawn "emacsclient -e '(kill emacs)'"
  64. io $ exitWith ExitSuccess)
  65. , ((0, xK_l), do
  66. spawn "xscreensaver-command -lock"
  67. quit)
  68. , ((0, xK_z), do
  69. spawn "xscreensaver-command -lock"
  70. spawn "systemctl suspend"
  71. quit)
  72. , ((0, xK_Escape), quit)
  73. ]
  74. , defaultText = "(r) Reboot, (s) Shutdown, (e) Exit, (l) Lock, (z) Sleep"
  75. })
  76. -- pulseaudio
  77. , ((0, xF86XK_AudioRaiseVolume),
  78. spawn "pactl set-sink-volume alsa_output.pci-0000_00_1f.3.analog-stereo +5%")
  79. , ((0, xF86XK_AudioLowerVolume),
  80. spawn "pactl set-sink-volume alsa_output.pci-0000_00_1f.3.analog-stereo -XF86AudioMute exec --no-startup-id pactl set-sink-mute alsa_output.pci-0000_00_1f.3.analog-stereo toggle5%")
  81. , ((0, xF86XK_AudioMute),
  82. spawn "pactl set-sink-mute alsa_output.pci-0000_00_1f.3.analog-stereo toggle")
  83. -- brightness
  84. , ((0, xF86XK_MonBrightnessUp),
  85. let
  86. returnValM = fmap init $ runProcessWithInput "xbacklight" [] ""
  87. in do
  88. currentBrightness <- returnValM
  89. if (read currentBrightness :: Double) == 0 then
  90. spawn "xbacklight -set 2"
  91. else
  92. spawn "xbacklight -inc 5")
  93. , ((0, xF86XK_MonBrightnessDown), spawn "xbacklight -dec 5")
  94. -- Another option for brightness configuration: never let it reach 0.
  95. {-|
  96. let
  97. returnValM = fmap init $ runProcessWithInput "xbacklight" [] ""
  98. in do
  99. currentBrightness <- returnValM
  100. if (read currentBrightness :: Double) - 5 >= 0 then
  101. spawn "xbacklight -dec 5"
  102. else return ())
  103. -}
  104. ]