Updated Xmonad look
This commit is contained in:
parent
bbe4eda1d2
commit
912b77c295
8 changed files with 231 additions and 23 deletions
|
@ -40,6 +40,7 @@ SETUVAR fish_color_status:e78284
|
||||||
SETUVAR fish_color_user:81c8be
|
SETUVAR fish_color_user:81c8be
|
||||||
SETUVAR fish_color_valid_path:\x2d\x2dunderline
|
SETUVAR fish_color_valid_path:\x2d\x2dunderline
|
||||||
SETUVAR fish_greeting:Welcome\x20to\x20fish\x2c\x20the\x20friendly\x20interactive\x20shell
|
SETUVAR fish_greeting:Welcome\x20to\x20fish\x2c\x20the\x20friendly\x20interactive\x20shell
|
||||||
|
SETUVAR fish_key_bindings:fish_default_key_bindings
|
||||||
SETUVAR fish_pager_color_background:\x1d
|
SETUVAR fish_pager_color_background:\x1d
|
||||||
SETUVAR fish_pager_color_completion:c6d0f5
|
SETUVAR fish_pager_color_completion:c6d0f5
|
||||||
SETUVAR fish_pager_color_description:737994
|
SETUVAR fish_pager_color_description:737994
|
||||||
|
|
|
@ -68,12 +68,12 @@ lazy.setup({
|
||||||
})
|
})
|
||||||
end
|
end
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
'laytan/tailwind-sorter.nvim',
|
'laytan/tailwind-sorter.nvim',
|
||||||
dependencies = {'nvim-treesitter/nvim-treesitter', 'nvim-lua/plenary.nvim'},
|
dependencies = { 'nvim-treesitter/nvim-treesitter', 'nvim-lua/plenary.nvim' },
|
||||||
build = 'cd formatter && bun i && bun run build',
|
build = 'cd formatter && bun i && bun run build',
|
||||||
config = true,
|
config = true,
|
||||||
},
|
},
|
||||||
--Database integration
|
--Database integration
|
||||||
-- 'tpope/vim-dadbod',
|
-- 'tpope/vim-dadbod',
|
||||||
-- {
|
-- {
|
||||||
|
@ -246,13 +246,15 @@ lazy.setup({
|
||||||
{
|
{
|
||||||
"nvim-neorg/neorg",
|
"nvim-neorg/neorg",
|
||||||
build = ":Neorg sync-parsers",
|
build = ":Neorg sync-parsers",
|
||||||
opts = {
|
config = function()
|
||||||
load = {
|
require("neorg").setup {
|
||||||
["core.defaults"] = {}, -- Loads default behaviour
|
load = {
|
||||||
["core.concealer"] = {} -- Adds pretty icons to your documents
|
["core.defaults"] = {}, -- Loads default behaviour
|
||||||
},
|
["core.concealer"] = {} -- Adds pretty icons to your documents
|
||||||
},
|
},
|
||||||
dependencies = { { "nvim-lua/plenary.nvim" } },
|
}
|
||||||
|
end,
|
||||||
|
dependencies = { "nvim-lua/plenary.nvim" },
|
||||||
},
|
},
|
||||||
|
|
||||||
-- 'kmonad/kmonad-vim',
|
-- 'kmonad/kmonad-vim',
|
||||||
|
|
|
@ -15,11 +15,12 @@ size-transition = true
|
||||||
# Corners #
|
# Corners #
|
||||||
#################################
|
#################################
|
||||||
# requires: https://github.com/sdhand/compton or https://github.com/jonaburg/picom
|
# requires: https://github.com/sdhand/compton or https://github.com/jonaburg/picom
|
||||||
corner-radius = 4.0;
|
corner-radius = 16.0;
|
||||||
rounded-corners-exclude = [
|
rounded-corners-exclude = [
|
||||||
#"window_type = 'normal'",
|
#"window_type = 'normal'",
|
||||||
"class_g = 'Rofi'",
|
"class_g = 'Rofi'",
|
||||||
"class_g = 'TelegramDesktop'",
|
"class_g = 'TelegramDesktop'",
|
||||||
|
"class_g = 'Dunst'"
|
||||||
];
|
];
|
||||||
round-borders = 1;
|
round-borders = 1;
|
||||||
round-borders-exclude = [
|
round-borders-exclude = [
|
||||||
|
@ -200,7 +201,7 @@ opacity-rule = [
|
||||||
"100:class_g = 'slop'", # maim
|
"100:class_g = 'slop'", # maim
|
||||||
"100:class_g = 'XTerm'",
|
"100:class_g = 'XTerm'",
|
||||||
"100:class_g = 'URxvt'",
|
"100:class_g = 'URxvt'",
|
||||||
"100:class_g = 'kitty'",
|
"85:class_g = 'kitty'",
|
||||||
"100:class_g = 'Alacritty'",
|
"100:class_g = 'Alacritty'",
|
||||||
"80:class_g = 'Polybar'",
|
"80:class_g = 'Polybar'",
|
||||||
"100:class_g = 'code-oss'",
|
"100:class_g = 'code-oss'",
|
||||||
|
|
|
@ -15,7 +15,7 @@ Config {font = "Ubuntu bold 10"
|
||||||
-- an integer for the percentage width, so 100 would be 100%.
|
-- an integer for the percentage width, so 100 would be 100%.
|
||||||
-- an integer for the minimum pixel height for xmobar, so 24 would force a height of at least 24 pixels.
|
-- an integer for the minimum pixel height for xmobar, so 24 would force a height of at least 24 pixels.
|
||||||
-- NOTE: The height should be the same as the trayer (system tray) height.
|
-- NOTE: The height should be the same as the trayer (system tray) height.
|
||||||
, position = TopSize L 100 36
|
, position = TopHM 36 4 4 4 0
|
||||||
, lowerOnStart = True
|
, lowerOnStart = True
|
||||||
, hideOnStart = False
|
, hideOnStart = False
|
||||||
, allDesktops = True
|
, allDesktops = True
|
||||||
|
|
Binary file not shown.
Binary file not shown.
207
.config/xmonad/xmonad.hs
Normal file
207
.config/xmonad/xmonad.hs
Normal file
|
@ -0,0 +1,207 @@
|
||||||
|
{-# OPTIONS_GHC -Wno-deprecations #-}
|
||||||
|
|
||||||
|
|
||||||
|
import XMonad
|
||||||
|
|
||||||
|
--Utils
|
||||||
|
import XMonad.Util.EZConfig (additionalKeysP,removeKeysP)
|
||||||
|
import XMonad.Util.Loggers (logLayoutOnScreen, logTitleOnScreen, shortenL, wrapL, xmobarColorL)
|
||||||
|
import XMonad.Util.Run
|
||||||
|
import XMonad.Util.SpawnOnce
|
||||||
|
|
||||||
|
--Hooks
|
||||||
|
import XMonad.Hooks.DynamicLog
|
||||||
|
import XMonad.Hooks.SetWMName
|
||||||
|
import XMonad.Hooks.StatusBar
|
||||||
|
import XMonad.Hooks.EwmhDesktops
|
||||||
|
import XMonad.Hooks.ManageDocks
|
||||||
|
import XMonad.Hooks.ManageHelpers
|
||||||
|
import XMonad.Hooks.WindowSwallowing
|
||||||
|
|
||||||
|
--Actions
|
||||||
|
import XMonad.Actions.SpawnOn
|
||||||
|
import XMonad.Actions.UpdateFocus (focusUnderPointer)
|
||||||
|
|
||||||
|
--Layouts
|
||||||
|
import XMonad.Layout.NoBorders
|
||||||
|
import XMonad.Layout.Spacing
|
||||||
|
|
||||||
|
|
||||||
|
-- MultiMonitorFocusHook
|
||||||
|
import Control.Monad (when)
|
||||||
|
import Data.Foldable (find)
|
||||||
|
import Foreign.C (CInt)
|
||||||
|
import Data.Maybe (fromMaybe)
|
||||||
|
import Data.Monoid (All (All))
|
||||||
|
|
||||||
|
--Miscellaneous
|
||||||
|
import qualified XMonad.StackSet as W
|
||||||
|
import qualified Data.Map as M
|
||||||
|
import System.Exit
|
||||||
|
|
||||||
|
--Color Scheme
|
||||||
|
import Colors.Teal
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
myTerminal = "kitty"
|
||||||
|
myTerminalTmux = myTerminal ++ " -e tmux a"
|
||||||
|
myTextEditor = "nvim"
|
||||||
|
myWebBrowser = "firefox"
|
||||||
|
myModMask = mod4Mask
|
||||||
|
|
||||||
|
myFocusFollowsMouse :: Bool
|
||||||
|
myFocusFollowsMouse = True
|
||||||
|
|
||||||
|
myClickJustFocuses :: Bool
|
||||||
|
myClickJustFocuses = False
|
||||||
|
|
||||||
|
windowCount :: X (Maybe String)
|
||||||
|
windowCount = gets $ Just . show . length . W.integrate' . W.stack . W.workspace . W.current . windowset
|
||||||
|
|
||||||
|
myNormalBorderColor = "#008080"
|
||||||
|
myFocusedBorderColor = "#01F9C6"
|
||||||
|
|
||||||
|
myBorderWidth = 2
|
||||||
|
|
||||||
|
myWorkspaces = ["main","web","text","code","social","monitoring"]
|
||||||
|
myWorkspaceIndices = zip myWorkspaces [1..]
|
||||||
|
|
||||||
|
|
||||||
|
myKeys :: [(String, X ())]
|
||||||
|
myKeys =
|
||||||
|
[ ("M-x" ,spawn myTerminalTmux )
|
||||||
|
, ("M-p", spawn "rofi -show drun -show-icons")
|
||||||
|
, ("M-S-p", spawn "rofi -show p -modi p:rofi-power-menu")
|
||||||
|
, ("M-s", spawn "selected=$(ls ~/scripts/|rofi -dmenu -p \"Run: \") && bash ~/.config/rofi/scripts/$selected")
|
||||||
|
, ("M-b", spawn myWebBrowser)
|
||||||
|
, ("<Print>", spawn "flameshot gui")
|
||||||
|
, ("<XF86AudioMute>", spawn "pamixer set --toggle-mute")
|
||||||
|
, ("<XF86AudioLowerVolume>", spawn "pamixer -d 5")
|
||||||
|
, ("<XF86AudioRaiseVolume>", spawn "pamixer -i 5")
|
||||||
|
, ("<XF86MonBrightnessUp>", spawn "lux -a 10%")
|
||||||
|
, ("<XF86MonBrightnessDown>", spawn "lux -s 10%")
|
||||||
|
, ("M-n", spawn $ myTerminal ++ " -e nmtui")
|
||||||
|
, ("M-q", kill)
|
||||||
|
, ("M-S-<Space>", sendMessage NextLayout)
|
||||||
|
, ("M-<Down>", windows W.focusDown)
|
||||||
|
, ("M-<Up>", windows W.focusUp )
|
||||||
|
, ("M-m", windows W.focusMaster )
|
||||||
|
, ("M-<Return>", windows W.swapMaster)
|
||||||
|
, ("M-h", sendMessage Shrink)
|
||||||
|
, ("M-l", sendMessage Expand)
|
||||||
|
, ("M-t", withFocused $ windows . W.sink)
|
||||||
|
, ("M-S-u", io (exitWith ExitSuccess))
|
||||||
|
, ("M-u", spawn "xmonad --recompile; xmonad --restart")
|
||||||
|
]
|
||||||
|
++
|
||||||
|
[("M-" ++ m ++ (show k), windows $ f i)
|
||||||
|
| (i, k) <- myWorkspaceIndices
|
||||||
|
, (f, m) <- [(W.greedyView, "0"), (W.shift, "S-")]]
|
||||||
|
++
|
||||||
|
[("M-" ++ m ++ key, screenWorkspace sc >>= flip whenJust (windows . f))
|
||||||
|
| (key, sc) <- zip ["w", "e", "r"] [0..]
|
||||||
|
, (f, m) <- [(W.view, "0"), (W.shift, "S-")]]
|
||||||
|
|
||||||
|
myRemoveKeys = ["M-S-<Return>","M-S-p","M-S-c","M-<Space>","M-n","M-S-q"]
|
||||||
|
|
||||||
|
myMouseBindings (XConfig {XMonad.modMask = modm}) = M.fromList $
|
||||||
|
[ ((modm, button1), (\w -> focus w >> mouseMoveWindow w
|
||||||
|
>> windows W.shiftMaster))
|
||||||
|
, ((modm, button2), (\w -> focus w >> windows W.shiftMaster))
|
||||||
|
, ((modm, button3), (\w -> focus w >> mouseResizeWindow w
|
||||||
|
>> windows W.shiftMaster))]
|
||||||
|
|
||||||
|
myLayout = avoidStruts(tiled ||| Mirror tiled ||| Full)
|
||||||
|
where
|
||||||
|
tiled = Tall nmaster delta ratio
|
||||||
|
nmaster = 1
|
||||||
|
ratio = 1/2
|
||||||
|
delta = 3/100
|
||||||
|
|
||||||
|
myManageHook = composeAll
|
||||||
|
[ className =? "MPlayer" --> doFloat
|
||||||
|
, className =? "Gimp" --> doFloat
|
||||||
|
, resource =? "desktop_window" --> doIgnore
|
||||||
|
, className =? "QjackCtl" --> doFloat
|
||||||
|
, resource =? "kdesktop" --> doIgnore
|
||||||
|
, className =? "firefox" --> doShift (myWorkspaces !! 1)
|
||||||
|
, className =? "Code" --> doShift (myWorkspaces !! 3)
|
||||||
|
, className =? "discord" --> doShift (myWorkspaces !! 4)
|
||||||
|
, title =? "JetBrains Toolbox" --> doShift (myWorkspaces !! 3)
|
||||||
|
, className =? "main" --> doFloat
|
||||||
|
, className =? "Mailspring" --> doShift (myWorkspaces !! 5)
|
||||||
|
, className =? "Xmessage" --> doFloat
|
||||||
|
, title =? "Steam - News" --> doFloat
|
||||||
|
, title =? "Friends List" --> doFloat
|
||||||
|
, isFullscreen --> doFullFloat]
|
||||||
|
|
||||||
|
|
||||||
|
myEventHook = ewmhDesktopsEventHook
|
||||||
|
|
||||||
|
myStartupHook = do
|
||||||
|
spawnOnce "pasystray"
|
||||||
|
spawnOnce "nitrogen --restore &"
|
||||||
|
spawnOnce "playerctld"
|
||||||
|
spawnOnce "picom &"
|
||||||
|
setWMName "LG3D"
|
||||||
|
spawnOnce "nm-applet"
|
||||||
|
spawnOnce("xsetroot -cursor_name left_ptr")
|
||||||
|
spawnOnce ("killall trayer ;sleep 1 && trayer --monitor 0 --edge top --align right --margin 4 --widthtype request --padding 8 --iconspacing 12 --SetDockType true --SetPartialStrut true --expand true --transparent true --alpha 0 --tint 0x2B2E37 --height 30 --distance 5 &")
|
||||||
|
spawnOnOnce "web" myWebBrowser
|
||||||
|
spawnOnOnce "main" myTerminalTmux
|
||||||
|
|
||||||
|
|
||||||
|
myStatusBarSpawner :: Applicative f => ScreenId -> f StatusBarConfig
|
||||||
|
myStatusBarSpawner (S s) = do
|
||||||
|
pure $ statusBarPropTo ("_XMONAD_LOG_" ++ show s)
|
||||||
|
("xmobar -x " ++ show s ++ " ~/.config/xmobar/xmobarrc" ++ show s)
|
||||||
|
(pure $ myXmobarPP (S s))
|
||||||
|
|
||||||
|
|
||||||
|
myXmobarPP :: ScreenId -> PP
|
||||||
|
myXmobarPP s = def
|
||||||
|
{ ppSep = ""
|
||||||
|
, ppWsSep = ""
|
||||||
|
, ppCurrent = xmobarColor cyan "" . const wsIconFull
|
||||||
|
, ppVisible = xmobarColor grey4 "" . const wsIconFull
|
||||||
|
, ppVisibleNoWindows = Just (xmobarColor grey4 "" . const wsIconFull)
|
||||||
|
, ppHidden = xmobarColor grey2 "" . const wsIconHidden
|
||||||
|
, ppHiddenNoWindows = xmobarColor grey2 "" . const wsIconEmpty
|
||||||
|
, ppUrgent = xmobarColor orange "" . const wsIconFull
|
||||||
|
, ppOrder = \(ws : _ : _ : extras) -> ws : extras
|
||||||
|
, ppExtras = [ wrapL " " " " $ layoutColorIsActive s (logLayoutOnScreen s)
|
||||||
|
,titleColorIsActive s (shortenL 81 $ logTitleOnScreen s)
|
||||||
|
]
|
||||||
|
}
|
||||||
|
where
|
||||||
|
wsIconFull = " <fn=2>\xf111</fn> "
|
||||||
|
wsIconHidden = " <fn=2>\xf111</fn> "
|
||||||
|
wsIconEmpty = " <fn=2>\xf10c</fn> "
|
||||||
|
titleColorIsActive n l = do
|
||||||
|
c <- withWindowSet $ return . W.screen . W.current
|
||||||
|
if n == c then xmobarColorL cyan "" l else xmobarColorL grey3 "" l
|
||||||
|
layoutColorIsActive n l = do
|
||||||
|
c <- withWindowSet $ return . W.screen . W.current
|
||||||
|
if n == c then wrapL "<icon=/home/afonso/.config/xmobar/xpm/" "_selected.xpm/>" l else wrapL "<icon=/home/afonso/.config/xmobar/xpm/" ".xpm/>" l
|
||||||
|
|
||||||
|
|
||||||
|
myConfig = def
|
||||||
|
{
|
||||||
|
terminal = myTerminal,
|
||||||
|
focusFollowsMouse = myFocusFollowsMouse,
|
||||||
|
clickJustFocuses = myClickJustFocuses,
|
||||||
|
borderWidth = myBorderWidth,
|
||||||
|
modMask = myModMask,
|
||||||
|
workspaces = myWorkspaces,
|
||||||
|
normalBorderColor = myNormalBorderColor,
|
||||||
|
focusedBorderColor = myFocusedBorderColor,
|
||||||
|
layoutHook = smartBorders . spacingWithEdge 15 $ myLayout,
|
||||||
|
manageHook = manageSpawn <+> myManageHook <+> manageHook def,
|
||||||
|
handleEventHook = myEventHook <+> fullscreenEventHook <+> swallowEventHook (className=?"Alacritty") (return True),
|
||||||
|
startupHook = myStartupHook
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
main :: IO ()
|
||||||
|
main = xmonad . ewmh . ewmhFullscreen . dynamicSBs myStatusBarSpawner . docks $ additionalKeysP (removeKeysP myConfig myRemoveKeys) myKeys
|
|
@ -164,15 +164,12 @@ myStartupHook = do
|
||||||
spawnOnce "nitrogen --restore &"
|
spawnOnce "nitrogen --restore &"
|
||||||
spawnOnce "playerctld"
|
spawnOnce "playerctld"
|
||||||
spawnOnce "picom &"
|
spawnOnce "picom &"
|
||||||
spawnOnce "optimus-manager-qt"
|
|
||||||
setWMName "LG3D"
|
setWMName "LG3D"
|
||||||
spawnOnce "nm-applet"
|
spawnOnce "nm-applet"
|
||||||
spawnOnce "mailspring"
|
|
||||||
spawnOnce("xsetroot -cursor_name left_ptr")
|
spawnOnce("xsetroot -cursor_name left_ptr")
|
||||||
spawn ("killall trayer ;sleep 1 && trayer --monitor 0 --edge top --align right --widthtype request --padding 7 --iconspacing 12 --SetDockType true --SetPartialStrut true --expand true --transparent true --alpha 0 --tint 0x2B2E37 --height 26 --distance 5 &")
|
spawnOnce ("killall trayer ;sleep 1 && trayer --monitor 0 --edge top --align right --margin 4 --widthtype request --padding 8 --iconspacing 12 --SetDockType true --SetPartialStrut true --expand true --transparent true --alpha 0 --tint 0x2B2E37 --height 30 --distance 5 &")
|
||||||
spawnOn "web" myWebBrowser
|
spawnOnOnce "web" myWebBrowser
|
||||||
spawnOn "main" myTerminalTmux
|
spawnOnOnce "main" myTerminalTmux
|
||||||
spawnOn "monitoring" (myTerminal ++ " -e btop")
|
|
||||||
@end
|
@end
|
||||||
* XMobar Config
|
* XMobar Config
|
||||||
@code haskell
|
@code haskell
|
||||||
|
@ -223,7 +220,7 @@ myConfig = def
|
||||||
workspaces = myWorkspaces,
|
workspaces = myWorkspaces,
|
||||||
normalBorderColor = myNormalBorderColor,
|
normalBorderColor = myNormalBorderColor,
|
||||||
focusedBorderColor = myFocusedBorderColor,
|
focusedBorderColor = myFocusedBorderColor,
|
||||||
layoutHook = smartBorders . spacingWithEdge 5 $ myLayout,
|
layoutHook = smartBorders . spacingWithEdge 15 $ myLayout,
|
||||||
manageHook = manageSpawn <+> myManageHook <+> manageHook def,
|
manageHook = manageSpawn <+> myManageHook <+> manageHook def,
|
||||||
handleEventHook = myEventHook <+> fullscreenEventHook <+> swallowEventHook (className=?"Alacritty") (return True),
|
handleEventHook = myEventHook <+> fullscreenEventHook <+> swallowEventHook (className=?"Alacritty") (return True),
|
||||||
startupHook = myStartupHook
|
startupHook = myStartupHook
|
||||||
|
|
Loading…
Reference in a new issue