aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--UrgencyHook.hs56
1 files changed, 54 insertions, 2 deletions
diff --git a/UrgencyHook.hs b/UrgencyHook.hs
index 95fef41..eec28f6 100644
--- a/UrgencyHook.hs
+++ b/UrgencyHook.hs
@@ -1,4 +1,24 @@
-module XMonadContrib.UrgencyHook where
+-----------------------------------------------------------------------------
+-- |
+-- Module : XMonadContrib.UrgencyHook
+-- Copyright : Devin Mullins <me@twifkak.com>
+-- License : BSD3-style (see LICENSE)
+--
+-- Maintainer : Devin Mullins <me@twifkak.com>
+-- Stability : unstable
+-- Portability : unportable
+--
+-- UrgencyHook lets you configure an action to occur when a window demands
+-- your attention. (In traditional WMs, this takes the form of "flashing"
+-- on your "taskbar." Blech.)
+--
+-----------------------------------------------------------------------------
+
+module XMonadContrib.UrgencyHook (
+ -- * Usage
+ -- $usage
+ withUrgencyHook
+ ) where
import {-# SOURCE #-} Config (urgencyHook)
import XMonad
@@ -9,7 +29,39 @@ import Data.Bits (testBit, clearBit)
import Graphics.X11.Xlib
import Graphics.X11.Xlib.Extras
--- Oooh, spooky.
+-- $usage
+-- To wire this up, add:
+--
+-- > import XMonadContrib.UrgencyHook
+--
+-- to your import list in Config. Change your defaultLayout such that
+-- withUrgencyHook is applied along the chain. Mine, for example:
+--
+-- > defaultLayout = Layout $ withUrgencyHook $ windowNavigation wnConfig $
+-- > LayoutSelection defaultLayouts
+--
+-- It shouldn't hurt to have the "withUrgencyHook $" at the outermost layer,
+-- as above, as UrgencyHook is a LayoutModifier, and hence passes on any
+-- messages sent to it. Next, add your actual urgencyHook to Config. This
+-- needs to take a Window and return an X () action. Here's an example:
+--
+-- > urgencyHook :: Window -> X ()
+-- > urgencyHook w = do
+-- > name <- getName w
+-- > ws <- gets windowset
+-- > whenJust (W.findIndex w ws) (flash name ws)
+-- > where flash name ws index =
+-- > when (index /= W.tag (W.workspace (W.current ws))) $
+-- > dzen (show name ++ " requests your attention on workspace " ++ show index)
+--
+-- This example stands on the shoulders of the NamedWindows and Dzen modules,
+-- but you can build whatever urgencyHook you like. Finally, in order to make
+-- this compile, open up your Config.hs-boot file and add the following to it:
+--
+-- > urgencyHook :: Window -> X ()
+--
+-- Compile!
+
data WithUrgencyHook a = WithUrgencyHook deriving (Read, Show)
instance LayoutModifier WithUrgencyHook Window where