dotfiles/xmonad/xmonad.hs

130 lines
4.3 KiB
Haskell
Raw Normal View History

2023-10-13 16:15:12 -06:00
import XMonad
2023-10-23 11:24:12 -06:00
import qualified XMonad.StackSet as W
2023-10-23 11:24:12 -06:00
import XMonad.Actions.UpdatePointer
import XMonad.Actions.CycleWS
import XMonad.Actions.DwmPromote
2023-10-13 16:15:12 -06:00
import XMonad.Hooks.DynamicLog
import XMonad.Hooks.ManageHelpers
import XMonad.Hooks.StatusBar
import XMonad.Hooks.EwmhDesktops
2023-10-23 11:24:12 -06:00
import XMonad.Hooks.ManageDocks
import XMonad.Hooks.WindowSwallowing
2023-10-13 16:15:12 -06:00
2023-10-23 11:24:12 -06:00
import XMonad.Layout.ThreeColumns
import XMonad.Layout.Spacing
import XMonad.Layout.NoBorders
import XMonad.Layout.Renamed
import XMonad.Layout.Accordion
import XMonad.Layout.Grid
import XMonad.Util.Cursor
2023-10-13 16:15:12 -06:00
import XMonad.Util.EZConfig
import XMonad.Util.Loggers
2023-10-23 11:24:12 -06:00
import System.Exit (exitSuccess)
2023-10-13 16:15:12 -06:00
dmenuFormatting :: String -> String
dmenuFormatting command = command ++ " -fn 'JetBrains Mono NF:style=medium:size=11' -nb '#282828' -nf '#ebdbb2' -sb '#d3869b' -sf '#282828'"
2023-10-13 16:15:12 -06:00
main :: IO ()
main = xmonad
. ewmh
. ewmhFullscreen
. withEasySB (statusBarProp "xmobar" (pure myXmobarPP)) defToggleStrutsKey
$ myConfig
myConfig = def
{ modMask = mod4Mask -- Rebind Mod to the Super key
2023-10-23 11:24:12 -06:00
, layoutHook = lessBorders OnlyFloat $ avoidStruts $ myLayout -- layouts
, manageHook = myManageHook -- float/swallow rules
, startupHook = setDefaultCursor xC_left_ptr -- sets the cursor
, handleEventHook = swallowEventHook (className =? "Alacritty") (return True) -- make alacritty swallowable
, workspaces = myWorkspaces -- workspace names
-- , logHook = dynamicLogWithPP myXmobarPP {
-- ppOutput = hPutStrLn description
-- } >> historyHook
2023-10-13 16:15:12 -06:00
, borderWidth = 2
, normalBorderColor = "#282828"
, focusedBorderColor = "#fe8019"
2023-10-13 16:15:12 -06:00
}
`additionalKeysP`
2023-10-23 11:24:12 -06:00
[ -- executables
("M-S-<Escape>", spawn "slock")
, ("M-S-f", spawn "librewolf-bin")
, ("M-S-k", spawn "keepassxc")
2023-10-13 16:15:12 -06:00
, ("M-<F1>", spawn "volmute")
, ("M-<F2>", spawn "voldown")
, ("M-<F3>", spawn "volup")
, ("M-<F7>", spawn "brightness-down")
, ("M-<F8>", spawn "brightness-up")
, ("M-<F11>", spawn "screenshot")
, ("M-p", spawn (dmenuFormatting "dmenu_run_history"))
2023-10-23 11:24:12 -06:00
, ("M-S-<Return>", spawn "spawn-alacritty")
, ("M-S-e", spawn "emac")
2023-10-23 11:24:12 -06:00
-- XMonad calls
2023-10-13 16:15:12 -06:00
, ("M-<Tab>", toggleWS)
2023-10-23 11:24:12 -06:00
, ("M-<Return>", dwmpromote)
-- layout jumps
, ("M-S-t", sendMessage $ JumpToLayout "Normal")
, ("M-a", sendMessage $ JumpToLayout "Accrdin")
2023-10-23 11:24:12 -06:00
-- rebound quit call
2023-10-13 16:15:12 -06:00
, ("M-S-<Backspace>", io exitSuccess)
2023-10-23 11:24:12 -06:00
]
`removeKeysP`
[ -- default quit keybind, as moved to M-S-<Backspace>
("M-S-q")
2023-10-13 16:15:12 -06:00
]
2023-10-23 11:24:12 -06:00
myWorkspaces :: [String]
2023-10-13 16:15:12 -06:00
myWorkspaces = [ "!", "@", "#", "$", "%", "^", "&", "*", "(" ]
2023-10-23 11:24:12 -06:00
myLayout = tiled ||| full ||| threeCol ||| accordion ||| grid
2023-10-13 16:15:12 -06:00
where
tiled = renamed [Replace "Normal"] $ Tall nmaster delta ratio
full = renamed [Replace "Full"] $ Full
threeCol = renamed [Replace "ThreeCol"] $ ThreeColMid nmaster delta ratio
accordion = renamed [Replace "Accrdin"] $ Accordion
grid = renamed [Replace "Grid"] $ Grid
2023-10-23 11:24:12 -06:00
nmaster = 1 -- Default number of windows in the master pane
ratio = 6/10 -- Default proportion of screen occupied by master pane
delta = 2/100 -- Percent of screen to increment by when resizing panes
-- spaced = spacing 0
2023-10-13 16:15:12 -06:00
myManageHook :: ManageHook
myManageHook = composeAll
[
-- className =? "Gimp" --> doFloat
isDialog --> doFloat
2023-10-23 11:24:12 -06:00
]
2023-10-13 16:15:12 -06:00
myXmobarPP :: PP
myXmobarPP = def
{ ppSep = magenta ""
, ppTitleSanitize = xmobarStrip
, ppCurrent = wrap "" "" . xmobarBorder "Top" "#83a598" 2
2023-10-13 16:15:12 -06:00
, ppUrgent = red . wrap (yellow "!") (yellow "!")
, ppOrder = \[ws, l, _, wins] -> [ws, l, wins]
, ppExtras = [logTitles formatFocused formatUnfocused]
}
where
formatFocused = wrap (blue "{ ") (blue " }") . aqua . ppWindow . shorten 80
2023-10-23 11:24:12 -06:00
formatUnfocused = wrap (lowWhite "<") (lowWhite ">") . lowWhite . ppWindow . shorten 40
2023-10-13 16:15:12 -06:00
-- | Windows should have *some* title, which should not not exceed a
-- sane length.
ppWindow :: String -> String
2023-10-23 11:24:12 -06:00
ppWindow = xmobarRaw . (\w -> if null w then "untitled" else w)
2023-10-13 16:15:12 -06:00
blue, lowWhite, magenta, red, white, yellow :: String -> String
magenta = xmobarColor "#d3869b" ""
blue = xmobarColor "#83a598" ""
white = xmobarColor "#ebdbb2" ""
yellow = xmobarColor "#fabd2f" ""
red = xmobarColor "#fb4934" ""
green = xmobarColor "#b8bb26" ""
2023-10-23 11:24:12 -06:00
lowWhite = xmobarColor "#a89984" ""
aqua = xmobarColor "#8ec07c" ""