diff options
author | Daniel Schoepe <asgaroth_@gmx.de> | 2009-03-09 17:00:20 +0100 |
---|---|---|
committer | Daniel Schoepe <asgaroth_@gmx.de> | 2009-03-09 17:00:20 +0100 |
commit | 0a1cecedb7cf41bcd040f721e911bb994365a167 (patch) | |
tree | 87b661903d15dcda768db09adf9ac5f0d95eb58b | |
parent | 9ac9536f1468d063731e01f522d570c5b91c1080 (diff) | |
download | XMonadContrib-0a1cecedb7cf41bcd040f721e911bb994365a167.tar.gz XMonadContrib-0a1cecedb7cf41bcd040f721e911bb994365a167.tar.xz XMonadContrib-0a1cecedb7cf41bcd040f721e911bb994365a167.zip |
More flexibility for H.FadeInactive
Ignore-this: ebfa2eadb439763276b372107cdf8d6c
darcs-hash:20090309160020-cb1c6-28bb80bf52bbf1093862164abe0b5fc0ea3a2041.gz
-rw-r--r-- | XMonad/Hooks/FadeInactive.hs | 31 |
1 files changed, 22 insertions, 9 deletions
diff --git a/XMonad/Hooks/FadeInactive.hs b/XMonad/Hooks/FadeInactive.hs index 4ebc38e..13b2683 100644 --- a/XMonad/Hooks/FadeInactive.hs +++ b/XMonad/Hooks/FadeInactive.hs @@ -16,12 +16,16 @@ module XMonad.Hooks.FadeInactive ( -- * Usage -- $usage setOpacity, - fadeInactiveLogHook + isUnfocused, + fadeIn, + fadeOut, + fadeInactiveLogHook, + fadeOutLogHook ) where import XMonad import qualified XMonad.StackSet as W -import Control.Monad (forM_) +import Control.Monad -- $usage -- You can use this module with the following in your @~\/.xmonad\/xmonad.hs@: @@ -68,10 +72,19 @@ fadeIn = flip setOpacity 0xffffffff -- | -- lowers the opacity of inactive windows to the specified amount fadeInactiveLogHook :: Integer -> X () -fadeInactiveLogHook amt = withWindowSet $ \s -> - forM_ (visibleWins s) (fadeOut amt) >> - withFocused fadeIn - where - visibleWins s = (maybe [] unfocused . W.stack . W.workspace) (W.current s) ++ - concatMap (W.integrate' . W.stack . W.workspace) (W.visible s) - unfocused (W.Stack _ l r) = l ++ r +fadeInactiveLogHook amt = fadeOutLogHook isUnfocused amt + +-- | returns True if the window doesn't have the focus. +isUnfocused :: Window -> X Bool +isUnfocused w = withWindowSet $ \s -> return $ + case W.stack . W.workspace . W.current $ s of + Nothing -> False + Just stack -> W.focus stack /= w + +-- | fades out every window that satisfies a given property. +fadeOutLogHook :: (Window -> X Bool) -> Integer -> X () +fadeOutLogHook p amt = withWindowSet $ \s -> do + let visibleWins = (W.integrate' . W.stack . W.workspace . W.current $ s) ++ + concatMap (W.integrate' . W.stack . W.workspace) (W.visible s) + mapM_ fadeIn =<< filterM (fmap not . p) visibleWins + mapM_ (fadeOut amt) =<< filterM p visibleWins |