Compare commits

..

62 commits

Author SHA1 Message Date
Samae
8fe9b3bb4d Update flake 2024-09-13 17:51:00 +03:00
Samae
91926d5975 Update 2024-08-25 12:43:11 +03:00
Samae
2d0db0063a Flake update 2024-08-06 08:27:53 +03:00
Samae
1f14f27da7 No incognito 2024-08-06 07:59:03 +03:00
Samae
0b4d60b948 New projects 2024-05-09 15:11:40 +03:00
Samae
7dbaaaf3d2 Add bindings for dunstctl set-paused 2023-10-24 10:02:31 +03:00
Samae
4701c62ce3 Update 2023-10-20 23:06:03 +03:00
Samae
f1a42476a2 Switch to neovide 2023-08-12 15:02:24 +03:00
Samae
2aafb06e25 Gooddbye patchage 2023-08-02 20:00:17 +03:00
Samae
57782266e2 Enable FuzzyMatch 2023-08-01 12:21:23 +03:00
Samae
591521b585 Add sähköpoika project 2023-07-06 19:15:14 +03:00
Samae
b9bd40efbe Move away from logseq 2023-04-02 10:57:15 +03:00
Samae
1d76815c13 back to element 2023-01-17 19:21:40 +02:00
EEva
d30047585b Remove easy-hls 2023-01-11 22:43:32 +02:00
EEva
6335946eeb Add flake support 2022-12-04 18:52:49 +02:00
EEva
2de387233c fix cinny 2022-10-01 13:43:06 +03:00
EEva
4393aafc87 Changes to chat tools 2022-10-01 13:40:56 +03:00
EEva
ea3951d543 Bump version 2022-04-17 08:32:44 +03:00
EEva
e660118219 Changes 2022-02-19 17:24:39 +02:00
EEva
964e01a3fa Moving back to vim 2021-12-09 23:09:00 +02:00
EEva
1eaae43e46 Add youtube project 2021-11-13 21:47:36 +02:00
EEva
a2faa356ab Add dunst 2021-11-04 20:41:24 +02:00
EEva
37c58fbd2c some fixes 2021-10-05 23:40:55 +03:00
EEva
11fb80639d Update Iosevka statement 2021-08-25 20:09:31 +03:00
EEva
96fcfeee3f Some changes 2021-08-25 04:51:46 +03:00
EEva
33ae468829 some cleanup 2021-08-23 00:02:59 +03:00
EEva
a39a26509e Add m8c projects 2021-07-23 22:54:29 +03:00
EEva
fe08cd4141 Move to emacs(client) 2021-07-15 19:20:30 +03:00
EEva (JPotier)
381753c2a0 New projects 2021-05-30 13:07:01 +03:00
EEva (JPotier)
a9cf599139 Add a few more projects 2021-05-06 17:23:24 +03:00
EEva (JPotier)
1d3c55f3e9 Fix pass 2021-05-06 17:23:07 +03:00
EEva (JPotier)
e206492ae9 Add new project 2021-04-18 15:50:37 +03:00
EEva (JPotier)
9fd4e4c1a5 Add LSP support 2021-04-18 15:50:27 +03:00
EEva (JPotier)
2cf1863ef3 Shorten the list of return passes shown when searching 2021-04-02 09:44:53 +03:00
EEva (JPotier)
b6b5e0d467 Project shuffle 2021-03-30 18:46:00 +03:00
EEva (JPotier)
c2aca9ce98 Add new shortcut to center the currently focused window 2021-01-06 10:51:39 +02:00
EEva (JPotier)
b04bc2b679 More apps 2021-01-03 22:13:55 +02:00
EEva (JPotier)
f990027814 Add a few projects 2020-12-26 11:05:29 +02:00
EEva (JPotier)
c768c1ac7c Move to alacritty 2020-12-14 21:49:03 +02:00
EEva (JPotier)
412957c518 Jailbreak base 2020-11-24 20:43:42 +02:00
EEva (JPotier)
368de76deb Add singleApp helper 2020-11-07 09:04:05 +02:00
EEva (JPotier)
3a5d170fe9 move to mlterm 2020-10-17 11:59:18 +03:00
EEva (JPotier)
1cc3ddd9f3 Add ewmh 2020-10-16 19:28:13 +03:00
EEva (JPotier)
e383427104 Prepare EWMH hints 2020-07-25 18:01:23 +03:00
EEva (JPotier)
281accb59c Add notes workspace 2020-03-28 17:41:16 +02:00
EEva (JPotier)
257b473ae1 Shift anoying floating windows 2020-03-21 10:50:12 +02:00
EEva (JPotier)
77a9fd5c11 Update smartspacing 2020-03-10 15:51:05 +02:00
EEva (JPotier)
c5b4569491 Declare other modules 2020-03-10 15:42:24 +02:00
EEva (JPotier)
e8a3d89468 Nord colors 2020-03-08 09:51:14 +02:00
EEva (JPotier)
cc119c89d5 Moar fufture? 2020-03-07 19:51:21 +02:00
EEva (JPotier)
34ebd77a58 Future is coming 2020-03-07 19:14:17 +02:00
EEva (JPotier)
c578bf77d2 Some changes 2020-03-07 17:53:04 +02:00
EEva (JPotier)
037d8df111 Several updates bundle 2019-09-28 15:55:07 +03:00
EEva (JPotier)
c2226d9e19 Projects for home, not work 2019-05-19 20:33:16 +03:00
EEva (JPotier)
3d82dd30c7 This computer does not have copy 2019-05-16 21:17:22 +03:00
afacb0eac5 Adding password manager for my own good 2019-05-16 09:06:31 +03:00
1600ae6e77 Merge branch 'master' of framagit.org:mpo/xmonad-config 2019-05-16 09:05:44 +03:00
eeva
b5b91cdd8d Changes 2019-01-27 21:20:08 +02:00
eeva
82ae92f620 yt-app 2018-06-23 18:28:05 +03:00
eeva
02ef1ead52 Add Project firefox 2018-06-09 10:44:40 +03:00
eeva
a3c2e1680d Add project steam (autostart) 2018-06-08 08:42:44 +03:00
eeva
c41263a44e Default project 2018-06-03 19:11:02 +03:00
18 changed files with 476 additions and 399 deletions

7
.gitignore vendored
View file

@ -1,8 +1,11 @@
.*.swp .*.swp
artwork artwork/
*.hi *.hi
*.o *.o
.direnv/
prompt-history prompt-history
xmonad-*-linux xmonad-x86_64-linux
xmonad.errors xmonad.errors
xmonad.state xmonad.state
dist-newstyle
result*

5
CHANGELOG.md Normal file
View file

@ -0,0 +1,5 @@
# Revision history for xmonad-config
## 0.1.0.0 -- YYYY-mm-dd
* First version. Released on an unsuspecting world.

2
Setup.hs Normal file
View file

@ -0,0 +1,2 @@
import Distribution.Simple
main = defaultMain

View file

@ -1,27 +1,12 @@
{ {
"nodes": { "nodes": {
"flake-utils": {
"locked": {
"lastModified": 1667395993,
"narHash": "sha256-nuEHfE/LcWyuSWnS8t12N1wc105Qtau+/OdUAjtQ0rA=",
"owner": "numtide",
"repo": "flake-utils",
"rev": "5aed5285a952e0b949eb3ba02c12fa4fcfef535f",
"type": "github"
},
"original": {
"owner": "numtide",
"repo": "flake-utils",
"type": "github"
}
},
"nixpkgs": { "nixpkgs": {
"locked": { "locked": {
"lastModified": 1670242877, "lastModified": 1725983898,
"narHash": "sha256-jBLh7dRHnbfvPPA9znOC6oQfKrCPJ0El8Zoe0BqnCjQ=", "narHash": "sha256-4b3A9zPpxAxLnkF9MawJNHDtOOl6ruL0r6Og1TEDGCE=",
"owner": "NixOS", "owner": "NixOS",
"repo": "nixpkgs", "repo": "nixpkgs",
"rev": "6e51c97f1c849efdfd4f3b78a4870e6aa2da4198", "rev": "1355a0cbfeac61d785b7183c0caaec1f97361b43",
"type": "github" "type": "github"
}, },
"original": { "original": {
@ -33,7 +18,6 @@
}, },
"root": { "root": {
"inputs": { "inputs": {
"flake-utils": "flake-utils",
"nixpkgs": "nixpkgs" "nixpkgs": "nixpkgs"
} }
} }

View file

@ -2,18 +2,56 @@
description = "Build my xmonad config"; description = "Build my xmonad config";
inputs.nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable"; inputs.nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable";
inputs.flake-utils.url = "github:numtide/flake-utils";
outputs = { self, nixpkgs, flake-utils }: outputs = {
self,
flake-utils.lib.eachDefaultSystem (system: nixpkgs,
let pkgs = nixpkgs.legacyPackages.${system}; in }: let
{ forAllSystems = function:
devShells.default = import ./shell.nix { inherit pkgs; }; nixpkgs.lib.genAttrs ["x86_64-linux" "aarch64-linux"] (system:
}) // { function rec {
packages.aarch64-linux.default = inherit system;
# Notice the reference to nixpkgs here. compilerVersion = "ghc966";
with import nixpkgs { system = "aarch64-linux"; }; pkgs = nixpkgs.legacyPackages.${system};
haskellPackages.callCabal2nix "xmonad-config" ./. {}; hsPkgs = pkgs.haskell.packages.${compilerVersion}.override {
overrides = hfinal: hprev: {
# Internal Packages
xmonad-config = hfinal.callCabal2nix "xmonad-config" ./. {};
xmonad-contrib = pkgs.haskell.lib.compose.doJailbreak (pkgs.haskell.lib.compose.overrideCabal (drv: {
version = "0.18.1";
sha256 = "sha256-BXOdIErNhNNS3slNBhiskH/zljVREjx0fu836BOGZDI=";
})
hprev.xmonad-contrib);
xmonad-extras = pkgs.haskell.lib.compose.doJailbreak (pkgs.haskell.lib.compose.overrideCabal (drv: {
version = "0.17.2";
sha256 = "sha256-KAqC6sDbvd79lhyByfbA0cYwSINJ+JkivsieUE2rm2U=";
})
hprev.xmonad-extras);
};
};
});
in {
formatter = forAllSystems ({pkgs, ...}: pkgs.alejandra);
packages = forAllSystems ({hsPkgs, ...}: ({
default = hsPkgs.xmonad-config;
}));
devShells = forAllSystems ({
hsPkgs,
pkgs,
...
}: {
default = hsPkgs.shellFor {
name = "xmonad-config";
packages = p: [
p.xmonad-config
];
buildInputs = with pkgs; [
hsPkgs.haskell-language-server
hsPkgs.cabal-install
cabal2nix
haskellPackages.ghcid
];
};
});
}; };
} }

View file

@ -1,82 +0,0 @@
module Catppuccin
( base
, blue
, crust
, flamingo
, green
, lavender
, mantle
, maroon
, mauve
, overlay0
, overlay1
, overlay2
, peach
, pink
, red
, rosewater
, sapphire
, sky
, subtext0
, subtext1
, surface0
, surface1
, surface2
, teal
, text
, yellow
, theme
) where
import XMonad.Layout.Decoration (Theme(..))
theme :: Theme
theme =
Theme { activeColor = mauve
, inactiveColor = surface0
, urgentColor = red
, activeBorderColor = mauve
, inactiveBorderColor = surface0
, urgentBorderColor = red
, activeBorderWidth = 1
, inactiveBorderWidth = 1
, urgentBorderWidth = 1
, activeTextColor = surface0
, inactiveTextColor = surface1
, urgentTextColor = red
, fontName = "-misc-fixed-*-*-*-*-10-*-*-*-*-*-*-*"
, decoWidth = 200
, decoHeight = 15
, windowTitleAddons = []
, windowTitleIcons = []
}
-- Colors for the Mocha variant
-- https://raw.githubusercontent.com/catppuccin/palette/main/palette.json
-- cat palette.json|jq -rc '.mocha.colors|map ({(.name):.hex})|.[]'
base = "#1e1e2e"
blue = "#89b4fa"
crust = "#11111b"
flamingo = "#f2cdcd"
green = "#a6e3a1"
lavender = "#b4befe"
mantle = "#181825"
maroon = "#eba0ac"
mauve = "#cba6f7"
overlay0 = "#6c7086"
overlay1 = "#7f849c"
overlay2 = "#9399b2"
peach = "#fab387"
pink = "#f5c2e7"
red = "#f38ba8"
rosewater = "#f5e0dc"
sapphire = "#74c7ec"
sky = "#89dceb"
subtext0 = "#a6adc8"
subtext1 = "#bac2de"
surface0 = "#313244"
surface1 = "#45475a"
surface2 = "#585b70"
teal = "#94e2d5"
text = "#cdd6f4"
yellow = "#f9e2af"

View file

@ -11,7 +11,6 @@ import Graphics.X11.Types
import System.Exit import System.Exit
-- import Text.EditDistance -- import Text.EditDistance
import XMonad import XMonad
import XMonad.Actions.CopyWindow (kill1,copy)
import XMonad.Actions.CycleWS import XMonad.Actions.CycleWS
import XMonad.Actions.DynamicProjects import XMonad.Actions.DynamicProjects
import XMonad.Core import XMonad.Core
@ -21,19 +20,16 @@ import XMonad.Prompt
import XMonad.Prompt.ConfirmPrompt import XMonad.Prompt.ConfirmPrompt
import XMonad.Prompt.FuzzyMatch import XMonad.Prompt.FuzzyMatch
import XMonad.Prompt.Shell import XMonad.Prompt.Shell
import XMonad.Prompt.Workspace (workspacePrompt)
import XMonad.Util.EZConfig import XMonad.Util.EZConfig
import XMonad.Util.NamedScratchpad import XMonad.Util.NamedScratchpad
import qualified Catppuccin as C import qualified Nord as N
import qualified Scratchpad as R import qualified Scratchpad as R
import qualified XMonad.StackSet as W import qualified XMonad.StackSet as W
-- Custom (in libs) -- Custom (in libs)
import Password (passPrompt) import Password (passPrompt)
lockScreenCmd =
spawn "/etc/profiles/per-user/e/bin/mpc pause; /run/current-system/sw/bin/xset s activate"
modify :: XConfig l -> XConfig l modify :: XConfig l -> XConfig l
modify conf = conf modify conf = conf
{ modMask = mod4Mask -- Use the "Win" key for the mod key { modMask = mod4Mask -- Use the "Win" key for the mod key
@ -41,20 +37,12 @@ modify conf = conf
`additionalKeysP` -- Add some extra key bindings: `additionalKeysP` -- Add some extra key bindings:
[ ("M-S-q", confirmPrompt promptConfig "exit" (io exitSuccess)) [ ("M-S-q", confirmPrompt promptConfig "exit" (io exitSuccess))
, ("<XF86MonBrightnessDown>", spawn "/run/current-system/sw/bin/light -U 10") , ("<XF86MonBrightnessDown>", spawn "/run/current-system/sw/bin/xbacklight -10")
, ("<XF86MonBrightnessUp>", spawn "/run/current-system/sw/bin/light -A 10") , ("<XF86MonBrightnessUp>", spawn "/run/current-system/sw/bin/xbacklight +10")
, ("<XF86AudioPlay>", spawn "/etc/profiles/per-user/e/bin/mpc toggle") , ("<XF86AudioPlay>", spawn "/run/current-system/sw/bin/mpc toggle")
, ("<XF86AudioNext>", spawn "/etc/profiles/per-user/e/bin/mpc next") , ("<XF86AudioNext>", spawn "/run/current-system/sw/bin/mpc next")
, ("<XF86AudioPrev>", spawn "/etc/profiles/per-user/e/bin/mpc prev") , ("<XF86AudioPrev>", spawn "/run/current-system/sw/bin/mpc prev")
-- KP_1 -> KP_6 macros , ("M-<Delete>", kill)
, ("<XF86Tools>", viewProject "sound")
, ("<XF86Launch5>", viewProject "frs")
, ("<XF86Launch6>", viewProject "chat")
, ("<XF86Launch7>", viewProject "isengard")
, ("<XF86Launch8>", viewProject "moria")
, ("<XF86Launch9>", viewProject "fre")
-- KP_Delete
, ("Cancel", lockScreenCmd)
, ("M-<Down>", windows W.focusDown) , ("M-<Down>", windows W.focusDown)
, ("M-<Esc>", sendMessage (Toggle "Full")) , ("M-<Esc>", sendMessage (Toggle "Full"))
, ("M-$", sendMessage (Toggle "Full")) , ("M-$", sendMessage (Toggle "Full"))
@ -64,37 +52,31 @@ modify conf = conf
, ("M-<Right>", nextWS) , ("M-<Right>", nextWS)
, ("M-<Tab>", toggleWS' ["NSP"]) , ("M-<Tab>", toggleWS' ["NSP"])
, ("M-<Up>", windows W.focusUp) , ("M-<Up>", windows W.focusUp)
, ("M-S-<Delete>", lockScreenCmd) , ("M-S-<Delete>", spawn "/run/current-system/sw/bin/mpc pause; /run/current-system/sw/bin/xset s activate")
, ("M-S-<Left>", shiftToPrev >> prevWS) , ("M-S-<Left>", shiftToPrev >> prevWS)
, ("M-S-<Right>", shiftToNext >> nextWS) , ("M-S-<Right>", shiftToNext >> nextWS)
, ("M-s s", spawn "/etc/profiles/per-user/e/bin/flameshot gui") , ("M-s s", spawn "flameshot gui")
, ("M-s t", spawn "/run/current-system/sw/bin/scrot /tmp/screen.png") , ("M-s t", spawn "/run/current-system/sw/bin/scrot /tmp/screen.png")
-- Workspace and tasks -- Workspace and tasks
, ("M-b", switchProjectPrompt promptConfig) , ("M-b", switchProjectPrompt promptConfig)
, ("M-p c", withFocused centerWindow)
, ("M-p m", shiftToProjectPrompt promptConfig) , ("M-p m", shiftToProjectPrompt promptConfig)
, ("M-p n", switchProjectPrompt promptConfig) , ("M-p n", switchProjectPrompt promptConfig)
, ("M-p r", renameProjectPrompt promptConfig) , ("M-p r", renameProjectPrompt promptConfig)
, ("M-p s", shellPrompt promptConfig) , ("M-p s", shellPrompt promptConfig)
, ("M-p c", withFocused centerWindow)
, ("M-d", passPrompt promptConfig) , ("M-d", passPrompt promptConfig)
-- Scratchpads -- Scratchpads
, ("M-p p", namedScratchpadAction R.pads "htop") , ("M-p p", namedScratchpadAction R.pads "htop")
-- Copy windows to workspaces -- Dunst
, ("M-<Delete>", kill1) , ("C-<Space>", spawn "dunstctl close")
, ("M-c", workspacePrompt promptConfig (\name -> windows $ copy name))
-- Mouse stuff
, ("<F9>", spawn "find-cursor")
-- , ("M-$ $", spawn "xdotool click 3")
-- , ("M-$ M-$", spawn "xdotool click 3") -- helpfull to combine M + right click
-- resizing the master/slave ratio
, ("M-h", sendMessage Shrink) -- Shrink the master area
, ("M-l", sendMessage Expand) -- Expand the master area
-- dunstctl calls
-- , ("C-<Space>", spawn "dunstctl close")
, ("C-S-<Space>", spawn "dunstctl close-all") , ("C-S-<Space>", spawn "dunstctl close-all")
, ("M-n p", spawn "dunstctl set-paused toggle") , ("M-n p", spawn "dunstctl set-paused toggle")
] ]
viewProject :: WorkspaceId -> X ()
viewProject id = do
project <- lookupProject id
forM_ project switchProject
-- Borrowed from https://www.reddit.com/r/xmonad/comments/gzq316/how_can_i_centre_a_floating_window_without/fthtx29/ -- Borrowed from https://www.reddit.com/r/xmonad/comments/gzq316/how_can_i_centre_a_floating_window_without/fthtx29/
centerWindow :: Window -> X () centerWindow :: Window -> X ()
@ -103,23 +85,19 @@ centerWindow win = do
windows $ W.float win (W.RationalRect ((1 - w) / 2) ((1 - h) / 2) w h) windows $ W.float win (W.RationalRect ((1 - w) / 2) ((1 - h) / 2) w h)
return () return ()
viewProject :: WorkspaceId -> X ()
viewProject id = do
project <- lookupProject id
case project of
Just p -> switchProject p
Nothing -> return ()
promptConfig = def promptConfig = def
{ position = Bottom { position = Bottom
, alwaysHighlight = True , alwaysHighlight = True
, bgColor = C.lavender , borderColor = N.nord9
, bgHLight = C.surface0 -- Normal
, borderColor = C.lavender , bgColor = N.nord9
, fgColor = N.background
-- Selection
, bgHLight = N.nord6
, fgHLight = N.background
--
, defaultText = "" , defaultText = ""
, fgColor = C.surface2 , font = "xft:Iosevka Samae:style=Regular:size=8:charwidth=5"
, fgHLight = C.text
, font = "xft:Iosevka Samae:style=Regular:size=10:charwidth=6.5"
, height = 24 , height = 24
, promptBorderWidth = 5 , promptBorderWidth = 5
-- Fuzzysearch by default -- Fuzzysearch by default

View file

@ -9,4 +9,3 @@ modify :: XConfig l -> XConfig l
modify conf = conf modify conf = conf
{ logHook = logHook conf >> updatePointer (0.5,0.5) (0,0) { logHook = logHook conf >> updatePointer (0.5,0.5) (0,0)
} }

91
lib/Nord.hs Normal file
View file

@ -0,0 +1,91 @@
module Nord
( nord0
, nord1
, nord2
, nord3
, nord4
, nord5
, nord6
, nord7
, nord8
, nord9
, nord10
, nord11
, nord12
, nord13
, nord14
, nord15
, yellow
, orange
, red
, purple
, green
, background
, backgroundhl
, foreground
, foregroundhl
, foregroundll
) where
-- POLAR NIGHT
-- The origin color or the Polar Night palette.
nord0 = "#2E3440";
-- A brighter shade color based on nord0.
nord1 = "#3B4252";
-- An even more brighter shade color of nord0.
nord2 = "#434C5E";
-- The brightest shade color based on nord0.
nord3 = "#4C566A";
-- SNOW STORM
-- The origin color or the Snow Storm palette.
nord4 = "#D8DEE9";
-- A brighter shade color of nord4.
nord5 = "#E5E9F0";
-- The brightest shade color based on nord4.
nord6 = "#ECEFF4";
-- FROST
-- A calm and highly contrasted color reminiscent of frozen polar water.
nord7 = "#8FBCBB";
-- The bright and shiny primary accent color reminiscent of pure and clear ice.
nord8 = "#88C0D0";
-- A more darkened and less saturated color reminiscent of arctic waters.
nord9 = "#81A1C1";
-- A dark and intensive color reminiscent of the deep arctic ocean.
nord10 = "#5E81AC";
-- AURORA
-- RED
nord11 = "#BF616A";
-- ORANGE
nord12 = "#D08770";
-- YELLOW
nord13 = "#EBCB8B";
-- GREEN
nord14 = "#A3BE8C";
-- PURPLE
nord15 = "#B48EAD";
foregroundhl = nord6
foreground = nord5
foregroundll = nord4
backgroundhl = nord1
background = nord0
red = nord11
orange = nord12
yellow = nord13
green = nord14
purple = nord15

View file

@ -33,23 +33,36 @@ passGeneratePrompt :: XPConfig -> X ()
passGeneratePrompt _ = return () -- Not implemented passGeneratePrompt _ = return () -- Not implemented
passPrompt :: XPConfig -> X () passPrompt :: XPConfig -> X ()
passPrompt = mkPassPrompt "Select password" copyPassword passPrompt = mkPassPrompt "Select password" selectPassword
mkPassPrompt :: String -> (String -> X ()) -> XPConfig -> X () mkPassPrompt :: String -> (String -> X ()) -> XPConfig -> X ()
mkPassPrompt label f conf = do mkPassPrompt label f conf = do
-- I'm just sorting here, but could use some kind of fuzzy matching instead, but it requires a bit more effort -- I'm just sorting here, but could use some kind of fuzzy matching instead,
-- but it requires a bit more effort
passwords <- sort <$> liftIO getPasswords passwords <- sort <$> liftIO getPasswords
-- Other change, use infixof instead of prefixof mkXPrompt (Pass label) conf (passComplFun passwords) f
mkXPrompt (Pass label) conf (\input -> pure (sortBy (compare `on` levenshtein input) . take 5 . filter (consumes input) $ passwords)) f where
getPasswords = do
passwordStoreDir <- (</> "pass") <$> getHomeDirectory
files <- runProcessWithInput "find"
[ passwordStoreDir, "-type", "f", "-name", "*.gpg", "-printf"
, "%p\n"] []
return . lines $ files
-- | Find all entries (`allPasses`) matching `input`
passComplFun :: [String] -> String -> IO [String]
passComplFun allPasses input = pure $
sortBy (compare `on` levenshtein input)
. take 10
. filter (consumes input)
$ allPasses
where where
consumes [] _ = True -- everything consumed consumes [] _ = True -- everything consumed
consumes (_:_) [] = False -- all not consumed consumes (_:_) [] = False -- all not consumed
consumes (a:xs) (a':ys) | a == a' = consumes xs ys consumes (a:xs) (a':ys) | a == a' = consumes xs ys
| otherwise = consumes (a:xs) ys | otherwise = consumes (a:xs) ys
getPasswords = do
passwordStoreDir <- (</> "pass") <$> getHomeDirectory
files <- runProcessWithInput "find" [ passwordStoreDir, "-type", "f", "-name", "*.gpg", "-printf", "%p\n"] []
return . lines $ files
copyPassword :: String -> X () selectPassword :: String -> X ()
copyPassword pass = spawn $ "gpg --decrypt " ++ pass ++ " | copy" selectPassword pass = spawn $ "gpg --decrypt " ++ pass ++ " | copy"
-- “copy” comes with the xmonad module in the nix configuration

View file

@ -6,135 +6,135 @@ import XMonad
import XMonad.Actions.DynamicProjects import XMonad.Actions.DynamicProjects
import XMonad.Util.Run import XMonad.Util.Run
spinTextEditorAndTerm :: String -> String -> Project term = "kitty"
spinTextEditorAndTerm dir name =
Project { projectName = name
, projectDirectory = dir <> name
, projectStartHook = Just
$ safeSpawn "rio" ["-e","tmux","new","-A","-s",name]
}
spinChat :: String -> Project spawnGuiTextEditor :: X ()
spinChat name = spawnGuiTextEditor = safeSpawn "neovide" []
Project { projectName = name
singleTermAppWithName :: String -> String -> Project
singleTermAppWithName name app = Project
{ projectName = name
, projectDirectory = "/tmp" , projectDirectory = "/tmp"
, projectStartHook = Just $ do safeSpawnProg (name <> "-desktop") , projectStartHook = Just $ do safeSpawn term ["zsh","-c",app]
} }
spinInTermWithName :: String -> String -> Project singleAppWithName :: String -> String -> Project
spinInTermWithName projectName cmd = singleAppWithName name app = Project
Project { projectName = projectName { projectName = name
, projectDirectory = "/tmp" , projectDirectory = "/tmp"
, projectStartHook = Just $ do safeSpawn "rio" ["-e",cmd] , projectStartHook = Just $ do spawn app
} }
spinInTerm :: String -> Project singleApp :: String -> Project
spinInTerm name = spinInTermWithName name name singleApp app = singleAppWithName app app
justStart :: String -> Project
justStart name = justStartWithName name name
justStartWithName :: String -> String -> Project
justStartWithName name pgm =
Project { projectName = name
, projectDirectory = "/tmp"
, projectStartHook = Just $ do safeSpawnProg pgm
}
spinNotes :: Project
spinNotes =
Project { projectName = "notes"
, projectDirectory = "~/zk/org-roam/"
, projectStartHook = Just $ do safeSpawn "emacs" ["~/zk/org-roam/20240202124747-index.org"]
}
adminProject = spinTextEditorAndTerm "~/admin/"
candyProject = spinTextEditorAndTerm "~/candy/"
workProject = spinTextEditorAndTerm "~/relex/"
workAnsibleProject = spinTextEditorAndTerm "~/relex/ansible-roles/"
projects :: [Project] projects :: [Project]
projects = [ adminProject "wrk-config" projects =
, adminProject "cdc-config" [ singleApp "carla"
, adminProject "overlays-personal" , singleApp "obs"
, candyProject "adventofcode" , singleApp "reaper"
, candyProject "dhall-packages" , singleApp "renoise"
, candyProject "hfdb" , singleApp "mixxx"
, justStartWithName "fre" "ff-perso" , singleAppWithName "Books" "calibre"
, justStartWithName "frs" "ff-relex" , singleAppWithName "discord" "Discord"
, justStartWithName "chat" "slack" , singleAppWithName "matrix" "element-desktop"
, justStartWithName "meet" "chromium" , singleAppWithName "signal" "signal-desktop"
, spinNotes , singleAppWithName "vcv" "Rack"
, spinInTermWithName "VPN" "vpn-run" , singleTermAppWithName "email" "neomutt"
, spinChat "element" , Project { projectName = "admin"
, spinChat "signal" , projectDirectory = "~/admin/nixos-config"
, spinInTerm "k9s" , projectStartHook = Just $ do spawnGuiTextEditor
, spinInTermWithName "email" "neomutt" safeSpawnProg term
, spinTextEditorAndTerm "~/." "xmonad" -- Dark magic!
, workProject "azure-kube-platform"
, workProject "azure-kube-platform-environments"
, workProject "azure-management"
, workProject "calculation-node-playbook"
, workProject "communication-nix-101"
, workProject "communication-nix-102"
, workProject "communication-nix-103"
, workProject "cooper"
, workProject "crebain"
, workProject "customer-configs"
, workProject "customer-modules"
, workProject "docker-images"
, workProject "fangorn"
, workProject "gitlab-runners"
, workProject "gitlab-self-manage"
, workProject "infra-inventory"
, workProject "isengard"
, workProject "isengard-2"
, workProject "isengard-3"
, workProject "jirawiz"
, workAnsibleProject "java"
, workProject "morannon"
, workProject "mordor-ca"
, workProject "mordor-deploy"
, workProject "mordor-interview"
, workProject "mordor-nixpkgs"
, workProject "mordor-ops"
, workProject "mordor-the-repo"
, workProject "mordorbooks"
, workProject "moria"
, workProject "muir"
, workProject "nix"
, workProject "nix-ansible-role"
, workProject "nixos-modules"
, workProject "nixpkgs"
, workProject "one-off-scripts"
, workProject "pck-access"
, workProject "planning-cloud"
, workProject "rfcs"
, workProject "runner-tests"
, workProject "slog-agent"
, workProject "sm-terraform"
, workProject "tech-radar"
, workProject "time-tracking"
, workProject "ugluk-ansible-role"
, workProject "unified-application-gateway"
, Project { projectName = "minecraft"
, projectDirectory = "/tmp"
, projectStartHook = Just $ do safeSpawnProg "minecraft-launcher"
safeSpawnProg "mumble"
} }
, Project { projectName = "status" , Project { projectName = "nixpkgs"
, projectDirectory = "~/admin/nixpkgs"
, projectStartHook = Just $ do spawnGuiTextEditor
safeSpawnProg term
}
, Project { projectName = "overlays-personal"
, projectDirectory = "~/admin/overlays-personal"
, projectStartHook = Just $ do spawnGuiTextEditor
safeSpawnProg term
}
, Project { projectName = "steam"
, projectDirectory = "/tmp" , projectDirectory = "/tmp"
, projectStartHook = Just $ safeSpawn "steam" ["-pipewire"]
}
, Project { projectName = "youtube"
, projectDirectory = "/tmp"
, projectStartHook = Just $ safeSpawn "chromium"
["--app=youtube.com"]
}
, Project { projectName = "cdc-config"
, projectDirectory = "~/admin/cdc-config"
, projectStartHook = Just $ do spawnGuiTextEditor
safeSpawnProg term
}
, Project { projectName = "saehkoepoika-config"
, projectDirectory = "~/admin/saehkoepoika-configuration-nix"
, projectStartHook = Just $ do spawnGuiTextEditor
safeSpawnProg term
}
, Project { projectName = "cdc-documentation"
, projectDirectory = "~/admin/cdc-documentation"
, projectStartHook = Just $ do , projectStartHook = Just $ do
safeSpawn "rio" ["-e","btop"] safeSpawnProg term
spawnGuiTextEditor
}
, Project { projectName = "adventOfCode"
, projectDirectory = "~/candy/adventofcode"
, projectStartHook = Just $ do
safeSpawnProg term
spawnGuiTextEditor
}
, Project { projectName = "rukokuoppa"
, projectDirectory = "~/candy/rukokuoppa"
, projectStartHook = Just $ do spawnGuiTextEditor
safeSpawnProg term
}
, Project { projectName = "notes"
, projectDirectory = "~/zk/org-roam-private"
, projectStartHook = Just $ safeSpawn "emacs" ["~/zk/org-roam-private"]
}
, Project { projectName = "groceries"
, projectDirectory = "/tmp"
, projectStartHook = Just $ safeSpawnProg "obsidian"
}
, Project { projectName = "xmonad"
, projectDirectory = "~/.xmonad"
, projectStartHook = Just $ do spawnGuiTextEditor
safeSpawnProg term
}
, Project { projectName = "waymonad"
, projectDirectory = "~/candy/waymonad"
, projectStartHook = Just $ do spawnGuiTextEditor
safeSpawnProg term
}
, Project { projectName = "accounting"
, projectDirectory = "~/accounting"
, projectStartHook = Just $ do safeSpawnProg term
}
, Project { projectName = "arrangements"
, projectDirectory = "~/candy/Arrangements"
, projectStartHook = Just $ do spawnGuiTextEditor
safeSpawnProg term
}
, Project { projectName = "flim"
, projectDirectory = "/flims/rtorrent/download"
, projectStartHook = Just $ do safeSpawnProg term
} }
, Project { projectName = "sound" , Project { projectName = "sound"
, projectDirectory = "/tmp" , projectDirectory = "/tmp"
, projectStartHook = Just $ do , projectStartHook = Just $ do safeSpawnProg "pavucontrol"
safeSpawn "pw-jack" ["patchage"]
safeSpawnProg "easyeffects" safeSpawnProg "easyeffects"
} }
, Project { projectName = "web"
, projectDirectory = "/tmp"
, projectStartHook = Just $ do spawn "firefox"
}
] ]
modify :: XConfig l -> XConfig l modify :: XConfig l -> XConfig l
modify conf = dynamicProjects projects conf modify conf = dynamicProjects projects conf
{ workspaces = [] } { workspaces = [] }

View file

@ -16,7 +16,7 @@ modify conf = conf
} }
pads = pads =
[ NS "htop" "rio -e tmux" (title =? "htop") [ NS "htop" "kitty --title htop tmux" (title =? "htop")
(customFloating $ W.RationalRect (1/3) (1/3) (1/3) (1/3)) (customFloating $ W.RationalRect (1/3) (1/3) (1/3) (1/3))
-- , NS "stardict" "stardict" (className =? "Stardict") -- , NS "stardict" "stardict" (className =? "Stardict")
-- (customFloating $ W.RationalRect (1/6) (1/6) (2/3) (2/3)) -- (customFloating $ W.RationalRect (1/6) (1/6) (2/3) (2/3))

View file

@ -1,22 +0,0 @@
module ScreenEvents (
ScreenEvents.modify
) where
import XMonad
import Data.Monoid (All(..))
import XMonad.Hooks.Rescreen
-- screenChangeHandler :: Event -> X All
-- screenChangeHandler (RRScreenChangeNotifyEvent _ _ _ _ _ _ _ _ _ _ _ _ _ _ _) = do
-- spawn "touch /tmp/xmonad-WAAAAAT"
-- spawn "/home/e/.fehbg"
-- return (All True)
-- screenChangeHandler _ = return (All True)
modify :: XConfig l -> XConfig l
modify = addAfterRescreenHook afterRescreen
afterRescreen :: X ()
afterRescreen = do
spawn "xrandr --dpi 96"
spawn "/home/e/.fehbg"

View file

@ -20,33 +20,8 @@ module Solarized
, foreground , foreground
, foregroundhl , foregroundhl
, foregroundll , foregroundll
, theme
) where ) where
import XMonad.Layout.Decoration (Theme(..))
theme :: Theme
theme =
Theme { activeColor = violet
, inactiveColor = base03
, urgentColor = red
, activeBorderColor = violet
, inactiveBorderColor = base03
, urgentBorderColor = red
, activeBorderWidth = 1
, inactiveBorderWidth = 1
, urgentBorderWidth = 1
, activeTextColor = base03
, inactiveTextColor = base02
, urgentTextColor = red
, fontName = "-misc-fixed-*-*-*-*-10-*-*-*-*-*-*-*"
, decoWidth = 200
, decoHeight = 15
, windowTitleAddons = []
, windowTitleIcons = []
}
base03 = "#002b36" base03 = "#002b36"
base02 = "#073642" base02 = "#073642"
base01 = "#586e75" base01 = "#586e75"

69
lib/StatusBar.hs Normal file
View file

@ -0,0 +1,69 @@
{-# LANGUAGE FlexibleContexts #-}
module StatusBar (
StatusBar.modify
) where
import Data.List
import Data.Monoid
import Nord as N
import XMonad.Core
import XMonad.Hooks.DynamicBars (dynStatusBarStartup,dynStatusBarEventHook,multiPP)
import XMonad.Hooks.DynamicLog
import XMonad.ManageHook
import XMonad.Util.Run
-- Type constructors
import GHC.IO.Handle (Handle)
modify :: XConfig l -> XConfig l
modify conf = conf
{ startupHook = do
startupHook conf
dynStatusBarStartup runXmobar killXmobar
, handleEventHook = handleEventHook conf <+> dynStatusBarEventHook runXmobar killXmobar
, logHook = do
logHook conf
multiPP currentPP otherPP
}
runXmobar :: ScreenId -> IO Handle
runXmobar (S id) = spawnPipe
$ "/run/current-system/sw/bin/xmobar --screen="
<> show id
<> " /home/eeva/.xmonad/xmobarrc"
killXmobar :: IO ()
-- killXmobar = spawn "/run/current-system/sw/bin/pkill xmobar"
killXmobar = return ()
otherPP = currentPP
{ ppCurrent = xmobarColor N.foreground N.background
, ppVisible = xmobarColor N.foreground N.background
, ppHidden = xmobarColor N.foreground N.background
, ppHiddenNoWindows = xmobarColor N.backgroundhl N.background
}
currentPP = def
{ ppCurrent = xmobarColor' N.orange
, ppVisible = xmobarColor' N.yellow -- other screen
, ppHidden = xmobarColor' N.foreground -- other workspaces with windows
, ppHiddenNoWindows = xmobarColor' N.foregroundll -- other workspaces
, ppSep = " "
, ppWsSep = " "
, ppLayout = printLayout
, ppTitle = printTitle
}
where xmobarColor' fg = xmobarColor fg S.base03
printLayout s | "Mirror ResizableTall" `isSuffixOf` s = "[ — ]"
printLayout s | "ResizableTall" `isSuffixOf` s = "[ | ]"
printLayout "Full" = "[ F ]"
printLayout l = "[" ++ l ++ "]"
printTitle t = let t' = shorten 120 t
in xmobarColor' S.foregroundll "« "
++ xmobarColor' S.foregroundhl t'
++ xmobarColor' S.foregroundll " »"

View file

@ -1,5 +1,4 @@
{ pkgs }: {pkgs}: let
let
inherit (pkgs) callPackage fetchFromGitHub mkShell; inherit (pkgs) callPackage fetchFromGitHub mkShell;
easy-hls-src = fetchFromGitHub { easy-hls-src = fetchFromGitHub {
owner = "jkachmar"; owner = "jkachmar";
@ -9,7 +8,8 @@ let
}; };
easy-hls = callPackage easy-hls-src {}; easy-hls = callPackage easy-hls-src {};
in in
mkShell {
mkShell { buildInputs = [
buildInputs = [ easy-hls ]; easy-hls
} ];
}

36
xmonad-config.cabal Normal file
View file

@ -0,0 +1,36 @@
cabal-version: >=1.10
name: xmonad-config
version: 0.13.0.0
-- synopsis:
-- description:
-- bug-reports:
license: AGPL-3.0-or-later
author: EEva (JPotier)
maintainer: jpo.contributes.to.nixos@marvid.fr
-- copyright:
-- category:
build-type: Simple
extra-source-files: CHANGELOG.md
executable xmonad
main-is: xmonad.hs
other-modules: KeyBindings
, MouseBindings
, Nord
, Password
, Projects
, Scratchpad
-- other-extensions:
build-depends: base
, X11
, directory
, filepath
, mtl
, unix
, xmonad
, xmonad-contrib >= 0.18.1
, xmonad-extras
hs-source-dirs: .
, lib
default-language: Haskell2010

View file

@ -9,76 +9,64 @@ import XMonad.Actions.DynamicProjects
import XMonad.Config.Desktop import XMonad.Config.Desktop
import XMonad.Hooks.DynamicLog import XMonad.Hooks.DynamicLog
import XMonad.Hooks.ManageHelpers import XMonad.Hooks.ManageHelpers
import XMonad.Layout.NoBorders (noBorders, smartBorders, hasBorder, BorderMessage (HasBorder))
import XMonad.Layout.NoBorders (noBorders, smartBorders)
import XMonad.Layout.NoFrillsDecoration
import XMonad.Layout.PerScreen
import XMonad.Layout.Reflect
import XMonad.Layout.ResizableTile (ResizableTall(..)) import XMonad.Layout.ResizableTile (ResizableTall(..))
import XMonad.Layout.Spacing import XMonad.Layout.Spacing
import XMonad.Layout.ThreeColumns (ThreeCol(..))
import XMonad.Layout.ToggleLayouts (toggleLayouts) import XMonad.Layout.ToggleLayouts (toggleLayouts)
import XMonad.StackSet (sink)
import XMonad.Util.EZConfig import XMonad.Util.EZConfig
import XMonad.Util.SpawnOnce import XMonad.Util.Hacks (fixSteamFlicker)
import qualified Solarized as S import qualified Nord as N
import qualified Catppuccin as C import qualified XMonad.Layout.Spacing as SS (Border(..))
-- Tidy modules -- Tidy modules
import KeyBindings as Keys (modify) import KeyBindings as Keys (modify)
import MouseBindings as Mouse (modify) import MouseBindings as Mouse (modify)
import Projects (modify) import Projects (modify)
import Scratchpad (modify) import Scratchpad (modify)
import ScreenEvents (modify)
-------------------- toggle btw vvvvvvvvvv or vvvvv --------- toggle btw vvvvvvvvvv or vvvvv
--layouts = titleBar $ toggleLayouts fullscreen tiled
layouts = toggleLayouts fullscreen tiled layouts = toggleLayouts fullscreen tiled
where where
fullscreen = (noBorders Full) smallBorder = SS.Border 5 5 5 5
tiled = smarts $ ifWider (1920 + 1) wideScreen normalScreen fullscreen = noBorders Full
wideScreen = ThreeColMid 1 (5/100) (1/2) tiled = smarts $ resizableTall ||| Mirror resizableTall
normalScreen = ResizableTall 1 (5/100) (1/2) [] smarts = spacingRaw True smallBorder True smallBorder True . smartBorders
smarts = (smartSpacingWithEdge 5) . smartBorders resizableTall = ResizableTall 1 (5/100) (1/2) []
--titleBar = noFrillsDeco shrinkText S.theme
-- Use the `xprop' tool to get the info you need for these matches. -- Use the `xprop' tool to get the info you need for these matches.
-- For className, use the second value that xprop gives you. -- For className, use the second value that xprop gives you.
-------------- Here be the law of windows -------------- Here be the law of windows
myManageHook = composeOne myManageHook = composeAll
[ className =? "Gcr-prompter" -?> doCenterFloat [ className =? "Patchage" --> doShift "patchage"
, className =? "Pavucontrol" -?> doShift "music" , className =? "Pavucontrol" --> doShift "music"
, className =? "Pinentry" -?> doFloat , className =? "Pinentry" --> doCenterFloat
, className =? "VirtualBox" -?> doFloat , className =? "REAPER" --> hasBorder False
, className =? "gpclient" -?> doTile <+> (doShift "VPN") , className =? "Renoise" --> hasBorder False
, className =? "mpv" -?> doFullFloat <+> (doShift "flims") , className =? "steam" --> doShift "steam"
, className =? "qemu-system-x86_64" -?> doFloat , className =? "steamwebhelper" --> doShift "steam"
, className =? "qutebrowser" -?> doShift "web" , className =? "cs2" --> doShift "steam"
, isDialog -?> doCenterFloat , isDialog --> doCenterFloat
-- Move transient windows to their parent: -- Move transient windows to their parent:
, transience , transience'
] ]
doTile :: ManageHook fixSteam :: XConfig l -> XConfig l
doTile = ask >>= doF . sink fixSteam c = c { handleEventHook = fixSteamFlicker <+> handleEventHook c }
------------ build the full config ------------ build the full config
withConfig = withConfig =
Projects.modify -- Apply projects config fixSteam -- And workaround steam bug
$ Projects.modify -- Apply projects config
$ Keys.modify -- Apply keybindings config $ Keys.modify -- Apply keybindings config
$ Mouse.modify -- Apply mouse bindings config $ Mouse.modify -- Apply mouse bindings config
$ Scratchpad.modify -- Apply scratchpad managehook config $ Scratchpad.modify -- Apply scratchpad managehook config
$ ScreenEvents.modify -- Apply screen event hook config
$ desktopConfig -- on a default desktop config $ desktopConfig -- on a default desktop config
{ manageHook = myManageHook <+> manageHook desktopConfig { manageHook = myManageHook
, layoutHook = desktopLayoutModifiers layouts , layoutHook = desktopLayoutModifiers layouts
, startupHook = spawnOnce "sh /home/e/.fehbg" , terminal = "kitty"
, terminal = "rio" , normalBorderColor = N.backgroundhl
, normalBorderColor = C.surface0 , focusedBorderColor = N.nord9
, focusedBorderColor = C.mauve
, borderWidth = 5 , borderWidth = 5
} }