{-# OPTIONS_GHC -fno-warn-missing-signatures #-}
{-# LANGUAGE MultiParamTypeClasses, Rank2Types, TypeFamilies #-}
module XMonad.Layout.Groups.Examples (
rowOfColumns
, zoomColumnIn
, zoomColumnOut
, zoomColumnReset
, toggleColumnFull
, zoomWindowIn
, zoomWindowOut
, zoomWindowReset
, toggleWindowFull
, tallTabs
, mirrorTallTabs
, fullTabs
, TiledTabsConfig(..)
, def
, increaseNMasterGroups
, decreaseNMasterGroups
, shrinkMasterGroups
, expandMasterGroups
, nextOuterLayout
, module XMonad.Layout.Groups.Helpers
, shrinkText
, GroupEQ(..)
, zoomRowG
) where
import XMonad
import qualified XMonad.Layout.Groups as G
import XMonad.Layout.Groups.Helpers
import XMonad.Layout.ZoomRow
import XMonad.Layout.Tabbed
import XMonad.Layout.Named
import XMonad.Layout.Renamed
import XMonad.Layout.Decoration
import XMonad.Layout.Simplest
data GroupEQ a = GroupEQ
deriving (Int -> GroupEQ a -> ShowS
[GroupEQ a] -> ShowS
GroupEQ a -> String
(Int -> GroupEQ a -> ShowS)
-> (GroupEQ a -> String)
-> ([GroupEQ a] -> ShowS)
-> Show (GroupEQ a)
forall a. Int -> GroupEQ a -> ShowS
forall a. [GroupEQ a] -> ShowS
forall a. GroupEQ a -> String
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
showList :: [GroupEQ a] -> ShowS
$cshowList :: forall a. [GroupEQ a] -> ShowS
show :: GroupEQ a -> String
$cshow :: forall a. GroupEQ a -> String
showsPrec :: Int -> GroupEQ a -> ShowS
$cshowsPrec :: forall a. Int -> GroupEQ a -> ShowS
Show, ReadPrec [GroupEQ a]
ReadPrec (GroupEQ a)
Int -> ReadS (GroupEQ a)
ReadS [GroupEQ a]
(Int -> ReadS (GroupEQ a))
-> ReadS [GroupEQ a]
-> ReadPrec (GroupEQ a)
-> ReadPrec [GroupEQ a]
-> Read (GroupEQ a)
forall a. ReadPrec [GroupEQ a]
forall a. ReadPrec (GroupEQ a)
forall a. Int -> ReadS (GroupEQ a)
forall a. ReadS [GroupEQ a]
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
readListPrec :: ReadPrec [GroupEQ a]
$creadListPrec :: forall a. ReadPrec [GroupEQ a]
readPrec :: ReadPrec (GroupEQ a)
$creadPrec :: forall a. ReadPrec (GroupEQ a)
readList :: ReadS [GroupEQ a]
$creadList :: forall a. ReadS [GroupEQ a]
readsPrec :: Int -> ReadS (GroupEQ a)
$creadsPrec :: forall a. Int -> ReadS (GroupEQ a)
Read)
instance Eq a => EQF GroupEQ (G.Group l a) where
eq :: GroupEQ (Group l a) -> Group l a -> Group l a -> Bool
eq GroupEQ (Group l a)
_ (G.G WithID l a
l1 Zipper a
_) (G.G WithID l a
l2 Zipper a
_) = WithID l a -> WithID l a -> Bool
forall (l :: * -> *) a. WithID l a -> WithID l a -> Bool
G.sameID WithID l a
l1 WithID l a
l2
zoomRowG :: (Eq a, Show a, Read a, Show (l a), Read (l a))
=> ZoomRow GroupEQ (G.Group l a)
zoomRowG :: ZoomRow GroupEQ (Group l a)
zoomRowG = GroupEQ (Group l a) -> ZoomRow GroupEQ (Group l a)
forall (f :: * -> *) a.
(EQF f a, Show (f a), Read (f a), Show a, Read a) =>
f a -> ZoomRow f a
zoomRowWith GroupEQ (Group l a)
forall a. GroupEQ a
GroupEQ
rowOfColumns :: Groups
(ModifiedLayout Rename (Mirror (ZoomRow ClassEQ)))
(ZoomRow GroupEQ)
Window
rowOfColumns = ModifiedLayout Rename (Mirror (ZoomRow ClassEQ)) Window
-> ZoomRow
GroupEQ
(Group (ModifiedLayout Rename (Mirror (ZoomRow ClassEQ))) Window)
-> Groups
(ModifiedLayout Rename (Mirror (ZoomRow ClassEQ)))
(ZoomRow GroupEQ)
Window
forall (l :: * -> *) (l2 :: * -> *).
l Window -> l2 (Group l Window) -> Groups l l2 Window
G.group ModifiedLayout Rename (Mirror (ZoomRow ClassEQ)) Window
column ZoomRow
GroupEQ
(Group (ModifiedLayout Rename (Mirror (ZoomRow ClassEQ))) Window)
forall a (l :: * -> *).
(Eq a, Show a, Read a, Show (l a), Read (l a)) =>
ZoomRow GroupEQ (Group l a)
zoomRowG
where column :: ModifiedLayout Rename (Mirror (ZoomRow ClassEQ)) Window
column = [Rename Window]
-> Mirror (ZoomRow ClassEQ) Window
-> ModifiedLayout Rename (Mirror (ZoomRow ClassEQ)) Window
forall a (l :: * -> *).
[Rename a] -> l a -> ModifiedLayout Rename l a
renamed [Int -> Rename Window
forall a. Int -> Rename a
CutWordsLeft Int
2, String -> Rename Window
forall a. String -> Rename a
PrependWords String
"ZoomColumn"] (Mirror (ZoomRow ClassEQ) Window
-> ModifiedLayout Rename (Mirror (ZoomRow ClassEQ)) Window)
-> Mirror (ZoomRow ClassEQ) Window
-> ModifiedLayout Rename (Mirror (ZoomRow ClassEQ)) Window
forall a b. (a -> b) -> a -> b
$ ZoomRow ClassEQ Window -> Mirror (ZoomRow ClassEQ) Window
forall (l :: * -> *) a. l a -> Mirror l a
Mirror ZoomRow ClassEQ Window
forall a. (Eq a, Show a, Read a) => ZoomRow ClassEQ a
zoomRow
zoomColumnIn :: X ()
zoomColumnIn :: X ()
zoomColumnIn = GroupsMessage -> X ()
forall a. Message a => a -> X ()
sendMessage (GroupsMessage -> X ()) -> GroupsMessage -> X ()
forall a b. (a -> b) -> a -> b
$ SomeMessage -> GroupsMessage
G.ToEnclosing (SomeMessage -> GroupsMessage) -> SomeMessage -> GroupsMessage
forall a b. (a -> b) -> a -> b
$ ZoomMessage -> SomeMessage
forall a. Message a => a -> SomeMessage
SomeMessage ZoomMessage
zoomIn
zoomColumnOut :: X ()
zoomColumnOut :: X ()
zoomColumnOut = GroupsMessage -> X ()
forall a. Message a => a -> X ()
sendMessage (GroupsMessage -> X ()) -> GroupsMessage -> X ()
forall a b. (a -> b) -> a -> b
$ SomeMessage -> GroupsMessage
G.ToEnclosing (SomeMessage -> GroupsMessage) -> SomeMessage -> GroupsMessage
forall a b. (a -> b) -> a -> b
$ ZoomMessage -> SomeMessage
forall a. Message a => a -> SomeMessage
SomeMessage ZoomMessage
zoomOut
zoomColumnReset :: X ()
zoomColumnReset :: X ()
zoomColumnReset = GroupsMessage -> X ()
forall a. Message a => a -> X ()
sendMessage (GroupsMessage -> X ()) -> GroupsMessage -> X ()
forall a b. (a -> b) -> a -> b
$ SomeMessage -> GroupsMessage
G.ToEnclosing (SomeMessage -> GroupsMessage) -> SomeMessage -> GroupsMessage
forall a b. (a -> b) -> a -> b
$ ZoomMessage -> SomeMessage
forall a. Message a => a -> SomeMessage
SomeMessage ZoomMessage
zoomReset
toggleColumnFull :: X ()
toggleColumnFull :: X ()
toggleColumnFull = GroupsMessage -> X ()
forall a. Message a => a -> X ()
sendMessage (GroupsMessage -> X ()) -> GroupsMessage -> X ()
forall a b. (a -> b) -> a -> b
$ SomeMessage -> GroupsMessage
G.ToEnclosing (SomeMessage -> GroupsMessage) -> SomeMessage -> GroupsMessage
forall a b. (a -> b) -> a -> b
$ ZoomMessage -> SomeMessage
forall a. Message a => a -> SomeMessage
SomeMessage ZoomMessage
ZoomFullToggle
zoomWindowIn :: X ()
zoomWindowIn :: X ()
zoomWindowIn = ZoomMessage -> X ()
forall a. Message a => a -> X ()
sendMessage ZoomMessage
zoomIn
zoomWindowOut :: X ()
zoomWindowOut :: X ()
zoomWindowOut = ZoomMessage -> X ()
forall a. Message a => a -> X ()
sendMessage ZoomMessage
zoomOut
zoomWindowReset :: X ()
zoomWindowReset :: X ()
zoomWindowReset = ZoomMessage -> X ()
forall a. Message a => a -> X ()
sendMessage ZoomMessage
zoomReset
toggleWindowFull :: X ()
toggleWindowFull :: X ()
toggleWindowFull = ZoomMessage -> X ()
forall a. Message a => a -> X ()
sendMessage ZoomMessage
ZoomFullToggle
data TiledTabsConfig s = TTC { TiledTabsConfig s -> Int
vNMaster :: Int
, TiledTabsConfig s -> Rational
vRatio :: Rational
, TiledTabsConfig s -> Rational
vIncrement :: Rational
, TiledTabsConfig s -> Int
hNMaster :: Int
, TiledTabsConfig s -> Rational
hRatio :: Rational
, TiledTabsConfig s -> Rational
hIncrement :: Rational
, TiledTabsConfig s -> s
tabsShrinker :: s
, TiledTabsConfig s -> Theme
tabsTheme :: Theme }
instance s ~ DefaultShrinker => Default (TiledTabsConfig s) where
def :: TiledTabsConfig s
def = Int
-> Rational
-> Rational
-> Int
-> Rational
-> Rational
-> DefaultShrinker
-> Theme
-> TiledTabsConfig DefaultShrinker
forall s.
Int
-> Rational
-> Rational
-> Int
-> Rational
-> Rational
-> s
-> Theme
-> TiledTabsConfig s
TTC Int
1 Rational
0.5 (Rational
3Rational -> Rational -> Rational
forall a. Fractional a => a -> a -> a
/Rational
100) Int
1 Rational
0.5 (Rational
3Rational -> Rational -> Rational
forall a. Fractional a => a -> a -> a
/Rational
100) DefaultShrinker
shrinkText Theme
forall a. Default a => a
def
fullTabs :: TiledTabsConfig s
-> ModifiedLayout
Rename
(ModifiedLayout
(Decoration TabbedDecoration s)
(Groups
(ModifiedLayout Rename Simplest)
(Choose
Full
(Choose
(ModifiedLayout Rename Tall)
(ModifiedLayout Rename (Mirror Tall))))))
Window
fullTabs TiledTabsConfig s
c = TiledTabsConfig s
-> Groups
(ModifiedLayout Rename Simplest)
(Choose
Full
(Choose
(ModifiedLayout Rename Tall)
(ModifiedLayout Rename (Mirror Tall))))
Window
-> ModifiedLayout
Rename
(ModifiedLayout
(Decoration TabbedDecoration s)
(Groups
(ModifiedLayout Rename Simplest)
(Choose
Full
(Choose
(ModifiedLayout Rename Tall)
(ModifiedLayout Rename (Mirror Tall))))))
Window
forall a (l :: * -> *) s.
(Eq a, LayoutClass l a, Shrinker s) =>
TiledTabsConfig s
-> l a
-> ModifiedLayout
Rename (ModifiedLayout (Decoration TabbedDecoration s) l) a
_tab TiledTabsConfig s
c (Groups
(ModifiedLayout Rename Simplest)
(Choose
Full
(Choose
(ModifiedLayout Rename Tall)
(ModifiedLayout Rename (Mirror Tall))))
Window
-> ModifiedLayout
Rename
(ModifiedLayout
(Decoration TabbedDecoration s)
(Groups
(ModifiedLayout Rename Simplest)
(Choose
Full
(Choose
(ModifiedLayout Rename Tall)
(ModifiedLayout Rename (Mirror Tall))))))
Window)
-> Groups
(ModifiedLayout Rename Simplest)
(Choose
Full
(Choose
(ModifiedLayout Rename Tall)
(ModifiedLayout Rename (Mirror Tall))))
Window
-> ModifiedLayout
Rename
(ModifiedLayout
(Decoration TabbedDecoration s)
(Groups
(ModifiedLayout Rename Simplest)
(Choose
Full
(Choose
(ModifiedLayout Rename Tall)
(ModifiedLayout Rename (Mirror Tall))))))
Window
forall a b. (a -> b) -> a -> b
$ ModifiedLayout Rename Simplest Window
-> Choose
Full
(Choose
(ModifiedLayout Rename Tall) (ModifiedLayout Rename (Mirror Tall)))
(Group (ModifiedLayout Rename Simplest) Window)
-> Groups
(ModifiedLayout Rename Simplest)
(Choose
Full
(Choose
(ModifiedLayout Rename Tall)
(ModifiedLayout Rename (Mirror Tall))))
Window
forall (l :: * -> *) (l2 :: * -> *).
l Window -> l2 (Group l Window) -> Groups l l2 Window
G.group ModifiedLayout Rename Simplest Window
forall a. ModifiedLayout Rename Simplest a
_tabs (Choose
Full
(Choose
(ModifiedLayout Rename Tall) (ModifiedLayout Rename (Mirror Tall)))
(Group (ModifiedLayout Rename Simplest) Window)
-> Groups
(ModifiedLayout Rename Simplest)
(Choose
Full
(Choose
(ModifiedLayout Rename Tall)
(ModifiedLayout Rename (Mirror Tall))))
Window)
-> Choose
Full
(Choose
(ModifiedLayout Rename Tall) (ModifiedLayout Rename (Mirror Tall)))
(Group (ModifiedLayout Rename Simplest) Window)
-> Groups
(ModifiedLayout Rename Simplest)
(Choose
Full
(Choose
(ModifiedLayout Rename Tall)
(ModifiedLayout Rename (Mirror Tall))))
Window
forall a b. (a -> b) -> a -> b
$ Full (Group (ModifiedLayout Rename Simplest) Window)
forall a. Full a
Full Full (Group (ModifiedLayout Rename Simplest) Window)
-> Choose
(ModifiedLayout Rename Tall)
(ModifiedLayout Rename (Mirror Tall))
(Group (ModifiedLayout Rename Simplest) Window)
-> Choose
Full
(Choose
(ModifiedLayout Rename Tall) (ModifiedLayout Rename (Mirror Tall)))
(Group (ModifiedLayout Rename Simplest) Window)
forall (l :: * -> *) a (r :: * -> *). l a -> r a -> Choose l r a
||| TiledTabsConfig s
-> ModifiedLayout
Rename Tall (Group (ModifiedLayout Rename Simplest) Window)
forall s a. TiledTabsConfig s -> ModifiedLayout Rename Tall a
_vert TiledTabsConfig s
c ModifiedLayout
Rename Tall (Group (ModifiedLayout Rename Simplest) Window)
-> ModifiedLayout
Rename
(Mirror Tall)
(Group (ModifiedLayout Rename Simplest) Window)
-> Choose
(ModifiedLayout Rename Tall)
(ModifiedLayout Rename (Mirror Tall))
(Group (ModifiedLayout Rename Simplest) Window)
forall (l :: * -> *) a (r :: * -> *). l a -> r a -> Choose l r a
||| TiledTabsConfig s
-> ModifiedLayout
Rename
(Mirror Tall)
(Group (ModifiedLayout Rename Simplest) Window)
forall s a.
TiledTabsConfig s -> ModifiedLayout Rename (Mirror Tall) a
_horiz TiledTabsConfig s
c
tallTabs :: TiledTabsConfig s
-> ModifiedLayout
Rename
(ModifiedLayout
(Decoration TabbedDecoration s)
(Groups
(ModifiedLayout Rename Simplest)
(Choose
(ModifiedLayout Rename Tall)
(Choose (ModifiedLayout Rename (Mirror Tall)) Full))))
Window
tallTabs TiledTabsConfig s
c = TiledTabsConfig s
-> Groups
(ModifiedLayout Rename Simplest)
(Choose
(ModifiedLayout Rename Tall)
(Choose (ModifiedLayout Rename (Mirror Tall)) Full))
Window
-> ModifiedLayout
Rename
(ModifiedLayout
(Decoration TabbedDecoration s)
(Groups
(ModifiedLayout Rename Simplest)
(Choose
(ModifiedLayout Rename Tall)
(Choose (ModifiedLayout Rename (Mirror Tall)) Full))))
Window
forall a (l :: * -> *) s.
(Eq a, LayoutClass l a, Shrinker s) =>
TiledTabsConfig s
-> l a
-> ModifiedLayout
Rename (ModifiedLayout (Decoration TabbedDecoration s) l) a
_tab TiledTabsConfig s
c (Groups
(ModifiedLayout Rename Simplest)
(Choose
(ModifiedLayout Rename Tall)
(Choose (ModifiedLayout Rename (Mirror Tall)) Full))
Window
-> ModifiedLayout
Rename
(ModifiedLayout
(Decoration TabbedDecoration s)
(Groups
(ModifiedLayout Rename Simplest)
(Choose
(ModifiedLayout Rename Tall)
(Choose (ModifiedLayout Rename (Mirror Tall)) Full))))
Window)
-> Groups
(ModifiedLayout Rename Simplest)
(Choose
(ModifiedLayout Rename Tall)
(Choose (ModifiedLayout Rename (Mirror Tall)) Full))
Window
-> ModifiedLayout
Rename
(ModifiedLayout
(Decoration TabbedDecoration s)
(Groups
(ModifiedLayout Rename Simplest)
(Choose
(ModifiedLayout Rename Tall)
(Choose (ModifiedLayout Rename (Mirror Tall)) Full))))
Window
forall a b. (a -> b) -> a -> b
$ ModifiedLayout Rename Simplest Window
-> Choose
(ModifiedLayout Rename Tall)
(Choose (ModifiedLayout Rename (Mirror Tall)) Full)
(Group (ModifiedLayout Rename Simplest) Window)
-> Groups
(ModifiedLayout Rename Simplest)
(Choose
(ModifiedLayout Rename Tall)
(Choose (ModifiedLayout Rename (Mirror Tall)) Full))
Window
forall (l :: * -> *) (l2 :: * -> *).
l Window -> l2 (Group l Window) -> Groups l l2 Window
G.group ModifiedLayout Rename Simplest Window
forall a. ModifiedLayout Rename Simplest a
_tabs (Choose
(ModifiedLayout Rename Tall)
(Choose (ModifiedLayout Rename (Mirror Tall)) Full)
(Group (ModifiedLayout Rename Simplest) Window)
-> Groups
(ModifiedLayout Rename Simplest)
(Choose
(ModifiedLayout Rename Tall)
(Choose (ModifiedLayout Rename (Mirror Tall)) Full))
Window)
-> Choose
(ModifiedLayout Rename Tall)
(Choose (ModifiedLayout Rename (Mirror Tall)) Full)
(Group (ModifiedLayout Rename Simplest) Window)
-> Groups
(ModifiedLayout Rename Simplest)
(Choose
(ModifiedLayout Rename Tall)
(Choose (ModifiedLayout Rename (Mirror Tall)) Full))
Window
forall a b. (a -> b) -> a -> b
$ TiledTabsConfig s
-> ModifiedLayout
Rename Tall (Group (ModifiedLayout Rename Simplest) Window)
forall s a. TiledTabsConfig s -> ModifiedLayout Rename Tall a
_vert TiledTabsConfig s
c ModifiedLayout
Rename Tall (Group (ModifiedLayout Rename Simplest) Window)
-> Choose
(ModifiedLayout Rename (Mirror Tall))
Full
(Group (ModifiedLayout Rename Simplest) Window)
-> Choose
(ModifiedLayout Rename Tall)
(Choose (ModifiedLayout Rename (Mirror Tall)) Full)
(Group (ModifiedLayout Rename Simplest) Window)
forall (l :: * -> *) a (r :: * -> *). l a -> r a -> Choose l r a
||| TiledTabsConfig s
-> ModifiedLayout
Rename
(Mirror Tall)
(Group (ModifiedLayout Rename Simplest) Window)
forall s a.
TiledTabsConfig s -> ModifiedLayout Rename (Mirror Tall) a
_horiz TiledTabsConfig s
c ModifiedLayout
Rename
(Mirror Tall)
(Group (ModifiedLayout Rename Simplest) Window)
-> Full (Group (ModifiedLayout Rename Simplest) Window)
-> Choose
(ModifiedLayout Rename (Mirror Tall))
Full
(Group (ModifiedLayout Rename Simplest) Window)
forall (l :: * -> *) a (r :: * -> *). l a -> r a -> Choose l r a
||| Full (Group (ModifiedLayout Rename Simplest) Window)
forall a. Full a
Full
mirrorTallTabs :: TiledTabsConfig s
-> ModifiedLayout
Rename
(ModifiedLayout
(Decoration TabbedDecoration s)
(Groups
(ModifiedLayout Rename Simplest)
(Choose
(ModifiedLayout Rename (Mirror Tall))
(Choose Full (ModifiedLayout Rename Tall)))))
Window
mirrorTallTabs TiledTabsConfig s
c = TiledTabsConfig s
-> Groups
(ModifiedLayout Rename Simplest)
(Choose
(ModifiedLayout Rename (Mirror Tall))
(Choose Full (ModifiedLayout Rename Tall)))
Window
-> ModifiedLayout
Rename
(ModifiedLayout
(Decoration TabbedDecoration s)
(Groups
(ModifiedLayout Rename Simplest)
(Choose
(ModifiedLayout Rename (Mirror Tall))
(Choose Full (ModifiedLayout Rename Tall)))))
Window
forall a (l :: * -> *) s.
(Eq a, LayoutClass l a, Shrinker s) =>
TiledTabsConfig s
-> l a
-> ModifiedLayout
Rename (ModifiedLayout (Decoration TabbedDecoration s) l) a
_tab TiledTabsConfig s
c (Groups
(ModifiedLayout Rename Simplest)
(Choose
(ModifiedLayout Rename (Mirror Tall))
(Choose Full (ModifiedLayout Rename Tall)))
Window
-> ModifiedLayout
Rename
(ModifiedLayout
(Decoration TabbedDecoration s)
(Groups
(ModifiedLayout Rename Simplest)
(Choose
(ModifiedLayout Rename (Mirror Tall))
(Choose Full (ModifiedLayout Rename Tall)))))
Window)
-> Groups
(ModifiedLayout Rename Simplest)
(Choose
(ModifiedLayout Rename (Mirror Tall))
(Choose Full (ModifiedLayout Rename Tall)))
Window
-> ModifiedLayout
Rename
(ModifiedLayout
(Decoration TabbedDecoration s)
(Groups
(ModifiedLayout Rename Simplest)
(Choose
(ModifiedLayout Rename (Mirror Tall))
(Choose Full (ModifiedLayout Rename Tall)))))
Window
forall a b. (a -> b) -> a -> b
$ ModifiedLayout Rename Simplest Window
-> Choose
(ModifiedLayout Rename (Mirror Tall))
(Choose Full (ModifiedLayout Rename Tall))
(Group (ModifiedLayout Rename Simplest) Window)
-> Groups
(ModifiedLayout Rename Simplest)
(Choose
(ModifiedLayout Rename (Mirror Tall))
(Choose Full (ModifiedLayout Rename Tall)))
Window
forall (l :: * -> *) (l2 :: * -> *).
l Window -> l2 (Group l Window) -> Groups l l2 Window
G.group ModifiedLayout Rename Simplest Window
forall a. ModifiedLayout Rename Simplest a
_tabs (Choose
(ModifiedLayout Rename (Mirror Tall))
(Choose Full (ModifiedLayout Rename Tall))
(Group (ModifiedLayout Rename Simplest) Window)
-> Groups
(ModifiedLayout Rename Simplest)
(Choose
(ModifiedLayout Rename (Mirror Tall))
(Choose Full (ModifiedLayout Rename Tall)))
Window)
-> Choose
(ModifiedLayout Rename (Mirror Tall))
(Choose Full (ModifiedLayout Rename Tall))
(Group (ModifiedLayout Rename Simplest) Window)
-> Groups
(ModifiedLayout Rename Simplest)
(Choose
(ModifiedLayout Rename (Mirror Tall))
(Choose Full (ModifiedLayout Rename Tall)))
Window
forall a b. (a -> b) -> a -> b
$ TiledTabsConfig s
-> ModifiedLayout
Rename
(Mirror Tall)
(Group (ModifiedLayout Rename Simplest) Window)
forall s a.
TiledTabsConfig s -> ModifiedLayout Rename (Mirror Tall) a
_horiz TiledTabsConfig s
c ModifiedLayout
Rename
(Mirror Tall)
(Group (ModifiedLayout Rename Simplest) Window)
-> Choose
Full
(ModifiedLayout Rename Tall)
(Group (ModifiedLayout Rename Simplest) Window)
-> Choose
(ModifiedLayout Rename (Mirror Tall))
(Choose Full (ModifiedLayout Rename Tall))
(Group (ModifiedLayout Rename Simplest) Window)
forall (l :: * -> *) a (r :: * -> *). l a -> r a -> Choose l r a
||| Full (Group (ModifiedLayout Rename Simplest) Window)
forall a. Full a
Full Full (Group (ModifiedLayout Rename Simplest) Window)
-> ModifiedLayout
Rename Tall (Group (ModifiedLayout Rename Simplest) Window)
-> Choose
Full
(ModifiedLayout Rename Tall)
(Group (ModifiedLayout Rename Simplest) Window)
forall (l :: * -> *) a (r :: * -> *). l a -> r a -> Choose l r a
||| TiledTabsConfig s
-> ModifiedLayout
Rename Tall (Group (ModifiedLayout Rename Simplest) Window)
forall s a. TiledTabsConfig s -> ModifiedLayout Rename Tall a
_vert TiledTabsConfig s
c
_tabs :: ModifiedLayout Rename Simplest a
_tabs = String -> Simplest a -> ModifiedLayout Rename Simplest a
forall (l :: * -> *) a. String -> l a -> ModifiedLayout Rename l a
named String
"Tabs" Simplest a
forall a. Simplest a
Simplest
_tab :: TiledTabsConfig s
-> l a
-> ModifiedLayout
Rename (ModifiedLayout (Decoration TabbedDecoration s) l) a
_tab TiledTabsConfig s
c l a
l = [Rename a]
-> ModifiedLayout (Decoration TabbedDecoration s) l a
-> ModifiedLayout
Rename (ModifiedLayout (Decoration TabbedDecoration s) l) a
forall a (l :: * -> *).
[Rename a] -> l a -> ModifiedLayout Rename l a
renamed [Int -> Rename a
forall a. Int -> Rename a
CutWordsLeft Int
1] (ModifiedLayout (Decoration TabbedDecoration s) l a
-> ModifiedLayout
Rename (ModifiedLayout (Decoration TabbedDecoration s) l) a)
-> ModifiedLayout (Decoration TabbedDecoration s) l a
-> ModifiedLayout
Rename (ModifiedLayout (Decoration TabbedDecoration s) l) a
forall a b. (a -> b) -> a -> b
$ s
-> Theme
-> l a
-> ModifiedLayout (Decoration TabbedDecoration s) l a
forall a (l :: * -> *) s.
(Eq a, LayoutClass l a, Shrinker s) =>
s
-> Theme
-> l a
-> ModifiedLayout (Decoration TabbedDecoration s) l a
addTabs (TiledTabsConfig s -> s
forall s. TiledTabsConfig s -> s
tabsShrinker TiledTabsConfig s
c) (TiledTabsConfig s -> Theme
forall s. TiledTabsConfig s -> Theme
tabsTheme TiledTabsConfig s
c) l a
l
_vert :: TiledTabsConfig s -> ModifiedLayout Rename Tall a
_vert TiledTabsConfig s
c = String -> Tall a -> ModifiedLayout Rename Tall a
forall (l :: * -> *) a. String -> l a -> ModifiedLayout Rename l a
named String
"Vertical" (Tall a -> ModifiedLayout Rename Tall a)
-> Tall a -> ModifiedLayout Rename Tall a
forall a b. (a -> b) -> a -> b
$ Int -> Rational -> Rational -> Tall a
forall a. Int -> Rational -> Rational -> Tall a
Tall (TiledTabsConfig s -> Int
forall s. TiledTabsConfig s -> Int
vNMaster TiledTabsConfig s
c) (TiledTabsConfig s -> Rational
forall s. TiledTabsConfig s -> Rational
vIncrement TiledTabsConfig s
c) (TiledTabsConfig s -> Rational
forall s. TiledTabsConfig s -> Rational
vRatio TiledTabsConfig s
c)
_horiz :: TiledTabsConfig s -> ModifiedLayout Rename (Mirror Tall) a
_horiz TiledTabsConfig s
c = String -> Mirror Tall a -> ModifiedLayout Rename (Mirror Tall) a
forall (l :: * -> *) a. String -> l a -> ModifiedLayout Rename l a
named String
"Horizontal" (Mirror Tall a -> ModifiedLayout Rename (Mirror Tall) a)
-> Mirror Tall a -> ModifiedLayout Rename (Mirror Tall) a
forall a b. (a -> b) -> a -> b
$ Tall a -> Mirror Tall a
forall (l :: * -> *) a. l a -> Mirror l a
Mirror (Tall a -> Mirror Tall a) -> Tall a -> Mirror Tall a
forall a b. (a -> b) -> a -> b
$ Int -> Rational -> Rational -> Tall a
forall a. Int -> Rational -> Rational -> Tall a
Tall (TiledTabsConfig s -> Int
forall s. TiledTabsConfig s -> Int
hNMaster TiledTabsConfig s
c) (TiledTabsConfig s -> Rational
forall s. TiledTabsConfig s -> Rational
hIncrement TiledTabsConfig s
c) (TiledTabsConfig s -> Rational
forall s. TiledTabsConfig s -> Rational
hRatio TiledTabsConfig s
c)
increaseNMasterGroups :: X ()
increaseNMasterGroups :: X ()
increaseNMasterGroups = GroupsMessage -> X ()
forall a. Message a => a -> X ()
sendMessage (GroupsMessage -> X ()) -> GroupsMessage -> X ()
forall a b. (a -> b) -> a -> b
$ SomeMessage -> GroupsMessage
G.ToEnclosing (SomeMessage -> GroupsMessage) -> SomeMessage -> GroupsMessage
forall a b. (a -> b) -> a -> b
$ IncMasterN -> SomeMessage
forall a. Message a => a -> SomeMessage
SomeMessage (IncMasterN -> SomeMessage) -> IncMasterN -> SomeMessage
forall a b. (a -> b) -> a -> b
$ Int -> IncMasterN
IncMasterN Int
1
decreaseNMasterGroups :: X ()
decreaseNMasterGroups :: X ()
decreaseNMasterGroups = GroupsMessage -> X ()
forall a. Message a => a -> X ()
sendMessage (GroupsMessage -> X ()) -> GroupsMessage -> X ()
forall a b. (a -> b) -> a -> b
$ SomeMessage -> GroupsMessage
G.ToEnclosing (SomeMessage -> GroupsMessage) -> SomeMessage -> GroupsMessage
forall a b. (a -> b) -> a -> b
$ IncMasterN -> SomeMessage
forall a. Message a => a -> SomeMessage
SomeMessage (IncMasterN -> SomeMessage) -> IncMasterN -> SomeMessage
forall a b. (a -> b) -> a -> b
$ Int -> IncMasterN
IncMasterN (-Int
1)
shrinkMasterGroups :: X ()
shrinkMasterGroups :: X ()
shrinkMasterGroups = GroupsMessage -> X ()
forall a. Message a => a -> X ()
sendMessage (GroupsMessage -> X ()) -> GroupsMessage -> X ()
forall a b. (a -> b) -> a -> b
$ SomeMessage -> GroupsMessage
G.ToEnclosing (SomeMessage -> GroupsMessage) -> SomeMessage -> GroupsMessage
forall a b. (a -> b) -> a -> b
$ Resize -> SomeMessage
forall a. Message a => a -> SomeMessage
SomeMessage Resize
Shrink
expandMasterGroups :: X ()
expandMasterGroups :: X ()
expandMasterGroups = GroupsMessage -> X ()
forall a. Message a => a -> X ()
sendMessage (GroupsMessage -> X ()) -> GroupsMessage -> X ()
forall a b. (a -> b) -> a -> b
$ SomeMessage -> GroupsMessage
G.ToEnclosing (SomeMessage -> GroupsMessage) -> SomeMessage -> GroupsMessage
forall a b. (a -> b) -> a -> b
$ Resize -> SomeMessage
forall a. Message a => a -> SomeMessage
SomeMessage Resize
Expand
nextOuterLayout :: X ()
nextOuterLayout :: X ()
nextOuterLayout = GroupsMessage -> X ()
forall a. Message a => a -> X ()
sendMessage (GroupsMessage -> X ()) -> GroupsMessage -> X ()
forall a b. (a -> b) -> a -> b
$ SomeMessage -> GroupsMessage
G.ToEnclosing (SomeMessage -> GroupsMessage) -> SomeMessage -> GroupsMessage
forall a b. (a -> b) -> a -> b
$ ChangeLayout -> SomeMessage
forall a. Message a => a -> SomeMessage
SomeMessage ChangeLayout
NextLayout