aboutsummaryrefslogtreecommitdiffstats
path: root/XMonad/Layout
diff options
context:
space:
mode:
Diffstat (limited to 'XMonad/Layout')
-rw-r--r--XMonad/Layout/ShowWName.hs95
1 files changed, 95 insertions, 0 deletions
diff --git a/XMonad/Layout/ShowWName.hs b/XMonad/Layout/ShowWName.hs
new file mode 100644
index 0000000..7eef687
--- /dev/null
+++ b/XMonad/Layout/ShowWName.hs
@@ -0,0 +1,95 @@
+{-# OPTIONS_GHC -fglasgow-exts #-}
+-----------------------------------------------------------------------------
+-- |
+-- Module : XMonad.Layout.ShowWName
+-- Copyright : (c) Andrea Rossato 2007
+-- License : BSD-style (see xmonad/LICENSE)
+--
+-- Maintainer : andrea.rossato@unibz.it
+-- Stability : unstable
+-- Portability : unportable
+--
+-- This is a layout modifier that will show the workspace name using
+-- dzen.
+--
+-----------------------------------------------------------------------------
+
+module XMonad.Layout.ShowWName
+ ( -- * Usage
+ -- $usage
+ showWName
+ , showWName'
+ , defaultSWNConfig
+ , SWNConfig(..)
+ ) where
+
+import XMonad
+import qualified XMonad.StackSet as S
+import XMonad.Layout.LayoutModifier
+import XMonad.Util.Font
+import XMonad.Util.Dzen
+
+-- $usage
+-- You can use this module with the following in your
+-- @~\/.xmonad\/xmonad.hs@:
+--
+-- > import XMonad.Layout.ShowWName
+-- > myLayout = layoutHook defaultConfig
+-- > main = xmonad defaultConfig { layoutHook = showWName myLayout }
+--
+-- For more detailed instructions on editing the layoutHook see:
+--
+-- "XMonad.Doc.Extending#Editing_the_layout_hook"
+
+-- | XXX
+showWName :: l a -> ModifiedLayout ShowWName l a
+showWName = ModifiedLayout (SWN True defaultSWNConfig)
+
+-- | XXX
+showWName' :: SWNConfig -> l a -> ModifiedLayout ShowWName l a
+showWName' c = ModifiedLayout (SWN True c)
+
+data ShowWName a = SWN Bool SWNConfig deriving (Read, Show)
+
+data SWNConfig =
+ SWNC { swn_font :: String
+ , swn_bgcolor :: String
+ , swn_color :: String
+ , swn_fade :: Rational
+ } deriving (Read, Show)
+
+defaultSWNConfig :: SWNConfig
+defaultSWNConfig =
+ SWNC { swn_font = "-misc-fixed-*-*-*-*-20-*-*-*-*-*-*-*"
+ , swn_bgcolor = "black"
+ , swn_color = "white"
+ , swn_fade = 1
+ }
+
+instance LayoutModifier ShowWName Window where
+ redoLayout (SWN True c) r _ wrs = flashName c r >> return (wrs, Just $ SWN False c)
+ redoLayout (SWN False _) _ _ wrs = return (wrs, Nothing)
+
+ handleMess (SWN _ c) m
+ | Just Hide <- fromMessage m = return . Just $ SWN True c
+ | otherwise = return Nothing
+
+flashName :: SWNConfig -> Rectangle -> X ()
+flashName c (Rectangle _ _ wh ht) = do
+ d <- asks display
+ n <- withWindowSet (return . S.tag . S.workspace . S.current)
+ f <- initXMF (swn_font c)
+ width <- textWidthXMF d f n
+ (_,as,ds,_) <- textExtentsXMF f n
+ releaseXMF f
+ let hight = as + ds + 2
+ y = (fromIntegral ht - hight) `div` 2
+ x = (fromIntegral wh - width) `div` 2
+ args = [ "-fn", swn_font c
+ , "-fg", swn_color c
+ , "-bg", swn_bgcolor c
+ , "-x" , show x
+ , "-y" , show y
+ , "-w" , show $ 3 * (width + 2)
+ ]
+ dzenWithArgs n args ((swn_fade c) `seconds`)