1
Fork 0
satellite/modules/applications/xmonad/Main.hs

117 lines
3.1 KiB
Haskell

{-# LANGUAGE BlockArguments #-}
import Control.Monad (forM_, join)
import Data.Function ((&))
import System.Environment
import System.Process
import XMonad
import XMonad.Actions.SpawnOn
import XMonad.Config
import XMonad.Config.Kde
import XMonad.Hooks.EwmhDesktops (ewmh, fullscreenEventHook)
import XMonad.Hooks.ManageDocks
import XMonad.Layout.NoBorders
import XMonad.Layout.Spacing
import XMonad.Layout.ThreeColumns
import XMonad.Operations
import XMonad.Util.EZConfig
kdeOn :: Bool
kdeOn = False
-- startingConfig = if kdeOn then kdeConfig else defaultConfig
main =
xmonad $
ewmh $
docks $
def
{ modMask = mod4Mask,
layoutHook = myLayoutHook,
startupHook = startup,
manageHook = manageDocks <+> manageSpawn <+> myManagerHook <+> manageHook kdeConfig,
handleEventHook = handleEventHook kdeConfig <+> fullscreenEventHook,
terminal = myTerminal,
workspaces = myWorkspaces,
borderWidth = 5,
focusedBorderColor = "#4c4f69",
normalBorderColor = "#4c4f69"
}
`additionalKeysP` keymap
where
myWorkspaces =
["1:dev", "2:browser", "3:chat", "4:reading", "5", "6"]
appWorkspaceConfig =
[ (3, "Discord"),
(4, "alacritty"),
(2, "google-chrome-stable")
]
manageWorkspaces =
appWorkspaceConfig
& fmap \(workspaceId, name) -> do
let workspaceName = myWorkspaces !! (workspaceId - 1)
className =? name --> doShift workspaceName
kdeFloats =
[ "yakuake",
"Yakuake",
"Kmix",
"kmix",
"plasma",
"Plasma",
"plasma-desktop",
"Plasma-desktop",
"krunner",
"ksplashsimple",
"ksplashqml",
"ksplashx"
]
floatKdeStuff = [className =? name --> doFloat | name <- kdeFloats]
myManagerHook =
composeAll $
concat
[ if kdeOn then floatKdeStuff else [],
manageWorkspaces
]
myTerminal = "alacritty"
myBrowser = "google-chrome-stable"
-- TODO: find a way to bind all the program-opening-keybindings to a single sub-map
keymap =
[ ("M-p", spawn "rofi -show drun"),
("M-w", spawn "rofi -show window"),
("M-g", spawn myBrowser),
("M-d", spawn "Discord"),
("M-v", spawn "alacritty -e vimclip"),
("M-s", spawn "spectacle -rcb"),
("M-S-s", spawn "spectacle -mcb"),
("M-C-s", spawn "spectacle -ucb"),
("M-c", kill)
]
uniformBorder = join $ join $ join Border
border = uniformBorder 0
spacingHook = spacingRaw False border False border True
tall = Tall 1 (3 / 100) (1 / 2)
threeCols = ThreeCol 1 (3 / 100) (1 / 2)
layouts = tall ||| threeCols ||| Full
myLayoutHook = desktopLayoutModifiers $ spacingHook layouts
startupApps =
[ (0, "alacritty"),
(1, "google-chrome-stable"),
(2, "Discord")
]
startup :: X ()
startup = do
forM_ startupApps \(index, app) -> do
spawnOn (myWorkspaces !! index) app