about summary refs log tree commit diff
path: root/src/lib/XMonad/Custom/Manage.hs
blob: fcda9c1d628e7e147c6cd877c753125d42555312 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
-- |
-- Module                  : XMonad.Custom.Manage
-- Description             : Window management hooks and scratchpads
-- Copyright               : (c) Azat Bahawi 2018-2021
-- SPDX-License-Identifier : GPL-3.0-or-later
-- Maintainer              : azat@bahawi.net
-- Stability               : experimental
-- Portability             : non-portable
--

module XMonad.Custom.Manage
  ( ngManageHook
  ) where

import           XMonad                  hiding ( manageHook )
import           XMonad.Custom.Scratchpads
import           XMonad.Hooks.InsertPosition
import           XMonad.Hooks.ManageDocks
import           XMonad.Hooks.ManageHelpers
import           XMonad.Layout.Fullscreen
import           XMonad.Util.NamedScratchpad

ngManageHook :: ManageHook
ngManageHook = mconcat
  [ manageDocks
  , fullscreenManageHook
  , namedScratchpadManageHook scratchpads
  , composeOne composeActions
  ]

composeActions :: [MaybeManageHook]
composeActions =
  [ appName =? "emacs-popup" -?> tileBelowNoFocus
  , appName =? "eterm" -?> tileBelow
  , className =? "Pinentry" -?> doCenterFloat
  , className =? "Steam" <&&> not <$> title =? "Steam" -?> doFloat
  , className =? "Xmessage" -?> doCenterFloat
  , className =? "Zenity" -?> doCenterFloat
  , className =? "explorer.exe" -?> doFullFloat
  , className =? "qemu-system-x86" -?> doCenterFloat
  , className =? "qemu-system-x86_64" -?> doCenterFloat
  , className =? "urxvt" -?> tileBelow
  , className =? "xterm" -?> tileBelow
  , isDialog -?> doCenterFloat
  , isFullscreen -?> doFullFloat
  , pure True -?> tileNormal
  , stringProperty "WM_WINDOW_ROLE" =? "pop-up" -?> doCenterFloat
  , stringProperty "WM_WINDOW_ROLE" =? "GtkFileChooserDialog" -?> doCenterFloat
  , transience
  ]
 where
  tileNormal       = insertPosition Above Newer
  tileBelow        = insertPosition Below Newer
  tileBelowNoFocus = insertPosition Below Older

Consider giving Nix/NixOS a try! <3