import XMonad import XMonad.Hooks.DynamicLog import XMonad.Hooks.ManageDocks import XMonad.Hooks.ManageHelpers import XMonad.Hooks.StatusBar import XMonad.Hooks.StatusBar.PP import XMonad.StackSet as W -- float purposes import XMonad.Actions.MouseResize import XMonad.Util.EZConfig import XMonad.Util.Loggers import XMonad.Util.Ungrab import XMonad.Layout.Magnifier import XMonad.Layout.ThreeColumns import XMonad.Layout.Spacing import XMonad.Hooks.EwmhDesktops import XMonad.Util.SpawnOnce (spawnOnce) -- run or raise import XMonad.Actions.WindowGo (runOrRaise) import XMonad.ManageHook (className) import XMonad.StackSet (RationalRect(..)) -- import XMonad.Layout.Decoration import XMonad.Layout.Simplest import XMonad.Layout.SimplestFloat import XMonad.Layout.Spacing main :: IO () main = xmonad . ewmhFullscreen . ewmh . withEasySB (statusBarProp "xmobar" (pure myXmobarPP)) defToggleStrutsKey $ myConfig myConfig = def { modMask = mod4Mask -- Rebind Mod to the Super key , layoutHook = myLayout -- Use custom layouts , terminal = "alacritty" , focusedBorderColor = "#000000" , manageHook = myManageHook -- Match on certain windows , startupHook = do -- other startup commands spawnOnce "xrandr --output HDMI-A-0 --mode 1366x768" spawnOnce "xrdb /home/berkeley/.Xresources" spawnOnce "feh --bg-fill /home/berkeley/Downloads/Preto.jpg" spawnOnce "picom -b" spawnOnce "polybar top-monitor-1" } `additionalKeysP` [ ("M-d", spawn "rofi -show run") , ("M-s", spawn "bash -c dictpopup") , ("M-x", spawn "bash -c xkill") , ("M-C-s", unGrab *> spawn "scrot -s" ) , ("M-e", runOrRaise "icecat" (className =? "GNU IceCat")) , ("M-p", runOrRaise "nyxt" (className =? "Nyxt")) , ("M-t", withFocused $ windows . W.sink) -- Toggle float for the focused window ] myManageHook :: ManageHook myManageHook = composeAll [ className =? "Gimp" --> doFloat , isDialog --> doFloat ] myTheme :: Theme myTheme = def { decoHeight = 20 -- Add other theme properties as needed } myLayout = mouseResize $ spacingRaw True (Border 10 10 10 10) True (Border 10 10 10 10) True $ Tall 1 (3/100) (1/2) ||| Full myXmobarPP :: PP myXmobarPP = def { ppSep = cyan " • " , ppTitleSanitize = xmobarStrip , ppCurrent = wrap " " "" . xmobarBorder "Top" "#8be9fd" 2 , ppHidden = white . wrap " " "" , ppHiddenNoWindows = lowWhite . wrap " " "" , ppUrgent = red . wrap (yellow "!") (yellow "!") , ppOrder = \[ws, l, _, wins] -> [ws, l, wins] , ppExtras = [logTitles formatFocused formatUnfocused] } where formatFocused = wrap (white "[") (white "]") . cyan . ppWindow formatUnfocused = wrap (lowWhite "[") (lowWhite "]") . vividGreen . ppWindow -- | Windows should have *some* title, which should not exceed a -- sane length. ppWindow :: String -> String ppWindow = xmobarRaw . (\w -> if null w then "untitled" else w) . shorten 30 cyan, vividGreen, lowWhite, red, white, yellow :: String -> String cyan = xmobarColor "#8be9fd" "" vividGreen = xmobarColor "#50fa7b" "" white = xmobarColor "#f8f8f2" "" yellow = xmobarColor "#f1fa8c" "" red = xmobarColor "#ff5555" "" lowWhite = xmobarColor "#bbbbbb" ""