Compare commits
1 Commits
b4102a94da
..
yazi
| Author | SHA1 | Date | |
|---|---|---|---|
|
2d6cb31351
|
@@ -4,3 +4,6 @@
|
|||||||
[submodule "alacritty-theme"]
|
[submodule "alacritty-theme"]
|
||||||
path = alacritty-theme
|
path = alacritty-theme
|
||||||
url = git@github.com:alacritty/alacritty-theme
|
url = git@github.com:alacritty/alacritty-theme
|
||||||
|
[submodule "yazi/flavors"]
|
||||||
|
path = yazi/flavors
|
||||||
|
url = https://github.com/yazi-rs/flavors.git
|
||||||
|
|||||||
@@ -15,12 +15,3 @@ opacity = 0.95
|
|||||||
[window.padding]
|
[window.padding]
|
||||||
x = 16
|
x = 16
|
||||||
y = 16
|
y = 16
|
||||||
|
|
||||||
# Shift+Enter sends a distinct ESC+CR sequence so apps (like Claude Code)
|
|
||||||
# can distinguish it from plain Enter and insert a newline instead of
|
|
||||||
# submitting. Installed by Claude Code/terminal-setup; preserved here
|
|
||||||
# so bombadil renders it persistently across dotfile syncs.
|
|
||||||
[[keyboard.bindings]]
|
|
||||||
key = "Return"
|
|
||||||
mods = "Shift"
|
|
||||||
chars = "\u001B\r"
|
|
||||||
|
|||||||
@@ -1,5 +1,3 @@
|
|||||||
if (( $+commands[helix] )); then
|
if (( $+commands[helix] )); then
|
||||||
alias hx="helix"
|
alias hx="helix"
|
||||||
elif (( $+commands[hx] )); then
|
|
||||||
alias helix="hx"
|
|
||||||
fi
|
fi
|
||||||
|
|||||||
+3
-2
@@ -47,8 +47,9 @@ mimeapps = { source = "mimeapps.list", target = ".config/mimeapps.list" }
|
|||||||
# navi
|
# navi
|
||||||
navi = { source = "navi", target = ".config/navi" }
|
navi = { source = "navi", target = ".config/navi" }
|
||||||
|
|
||||||
# starship
|
# yazi
|
||||||
starship = { source = "starship.toml", target = ".config/starship.toml"}
|
yazi_flavors = { source = "yazi/flavors", target = ".config/yazi/flavors", ignore = [ "*.md", "scripts", "LICENSE", "*.json", "*.yaml", ".git", ".github", ".gitignore" ] }
|
||||||
|
yazi_theme = { source = "yazi/theme.toml", target = ".config/yazi/theme.toml" }
|
||||||
|
|
||||||
# zellij
|
# zellij
|
||||||
zellij = { source = "zellij", target = ".config/zellij" }
|
zellij = { source = "zellij", target = ".config/zellij" }
|
||||||
|
|||||||
@@ -3,3 +3,4 @@ alacritty_theme = "Catppuccin-Macchiato"
|
|||||||
helix_theme = "catppuccin_mocha"
|
helix_theme = "catppuccin_mocha"
|
||||||
zellij_theme = "catppuccin-macchiato"
|
zellij_theme = "catppuccin-macchiato"
|
||||||
bat_theme = "Catppuccin Mocha"
|
bat_theme = "Catppuccin Mocha"
|
||||||
|
yazi_flavor = "catppuccin-mocha"
|
||||||
|
|||||||
@@ -12,4 +12,3 @@ tmp/**/*
|
|||||||
.pryrc
|
.pryrc
|
||||||
.psqlrc
|
.psqlrc
|
||||||
.helix/
|
.helix/
|
||||||
.claude/settings.local.json
|
|
||||||
|
|||||||
+1
-18
@@ -23,25 +23,8 @@ wrap-at-text-width = true
|
|||||||
center = ["version-control"]
|
center = ["version-control"]
|
||||||
|
|
||||||
[keys.normal]
|
[keys.normal]
|
||||||
C-R = ":config-reload"
|
C-r = ":config-reload"
|
||||||
|
|
||||||
_ = { n = ":set whitespace.render none", a = ":set whitespace.render all" }
|
_ = { n = ":set whitespace.render none", a = ":set whitespace.render all" }
|
||||||
|
|
||||||
# Git integration with lazygit
|
|
||||||
A-g = [
|
|
||||||
":write-all",
|
|
||||||
":insert-output lazygit >/dev/tty",
|
|
||||||
":redraw",
|
|
||||||
":reload-all"
|
|
||||||
]
|
|
||||||
|
|
||||||
# Search and replace with scooter
|
|
||||||
C-r = [
|
|
||||||
":write-all",
|
|
||||||
":insert-output scooter >/dev/tty",
|
|
||||||
":redraw",
|
|
||||||
":reload-all"
|
|
||||||
]
|
|
||||||
|
|
||||||
[keys.normal.space]
|
[keys.normal.space]
|
||||||
i = ":toggle lsp.display-inlay-hints"
|
i = ":toggle lsp.display-inlay-hints"
|
||||||
|
|||||||
@@ -3,24 +3,9 @@ name = "env"
|
|||||||
scope = "text.env"
|
scope = "text.env"
|
||||||
file-types = ["test", "local", "development", "staging", "production", "example", "env"]
|
file-types = ["test", "local", "development", "staging", "production", "example", "env"]
|
||||||
|
|
||||||
[[language]]
|
|
||||||
name = "java"
|
|
||||||
file-types = ["java", "jav", "pde", "painless"]
|
|
||||||
|
|
||||||
[language-server.rust-analyzer.config.check]
|
[language-server.rust-analyzer.config.check]
|
||||||
command = "clippy"
|
command = "clippy"
|
||||||
|
|
||||||
[[language]]
|
|
||||||
name = "go"
|
|
||||||
auto-format = true
|
|
||||||
language-servers = [ "gopls", "golangci-lint-lsp" ]
|
|
||||||
|
|
||||||
[language-server.golangci-lint-lsp]
|
|
||||||
command = "golangci-lint-langserver"
|
|
||||||
|
|
||||||
[language-server.golangci-lint-lsp.config]
|
|
||||||
command = ["golangci-lint", "run", "--output.json.path", "stdout", "--show-stats=false", "--issues-exit-code=1"]
|
|
||||||
|
|
||||||
# It is recommended to place the necessary configurations below inside a project's
|
# It is recommended to place the necessary configurations below inside a project's
|
||||||
# .helix/languages.toml directory
|
# .helix/languages.toml directory
|
||||||
#
|
#
|
||||||
|
|||||||
@@ -3,3 +3,4 @@ alacritty_theme = "Catppuccin-Latte"
|
|||||||
helix_theme = "catppuccin_latte"
|
helix_theme = "catppuccin_latte"
|
||||||
zellij_theme = "catppuccin-latte"
|
zellij_theme = "catppuccin-latte"
|
||||||
bat_theme = "Catppuccin Latte"
|
bat_theme = "Catppuccin Latte"
|
||||||
|
yazi_flavor = "catppuccin-latte"
|
||||||
|
|||||||
-285
@@ -1,285 +0,0 @@
|
|||||||
"$schema" = 'https://starship.rs/config-schema.json'
|
|
||||||
|
|
||||||
format = """
|
|
||||||
[](red)\
|
|
||||||
$os\
|
|
||||||
$username\
|
|
||||||
[](bg:peach fg:red)\
|
|
||||||
$directory\
|
|
||||||
[](bg:yellow fg:peach)\
|
|
||||||
$git_branch\
|
|
||||||
$git_status\
|
|
||||||
[](fg:yellow bg:green)\
|
|
||||||
$c\
|
|
||||||
$rust\
|
|
||||||
$golang\
|
|
||||||
$nodejs\
|
|
||||||
$bun\
|
|
||||||
$php\
|
|
||||||
$java\
|
|
||||||
$kotlin\
|
|
||||||
$haskell\
|
|
||||||
$python\
|
|
||||||
[](fg:green bg:sapphire)\
|
|
||||||
$conda\
|
|
||||||
[](fg:sapphire bg:lavender)\
|
|
||||||
$time\
|
|
||||||
[ ](fg:lavender)\
|
|
||||||
$cmd_duration\
|
|
||||||
$line_break\
|
|
||||||
$character"""
|
|
||||||
|
|
||||||
palette = 'catppuccin_mocha'
|
|
||||||
|
|
||||||
[os]
|
|
||||||
disabled = false
|
|
||||||
style = "bg:red fg:crust"
|
|
||||||
|
|
||||||
[os.symbols]
|
|
||||||
Windows = ""
|
|
||||||
Ubuntu = ""
|
|
||||||
SUSE = ""
|
|
||||||
Raspbian = ""
|
|
||||||
Mint = ""
|
|
||||||
Macos = ""
|
|
||||||
Manjaro = ""
|
|
||||||
Linux = ""
|
|
||||||
Gentoo = ""
|
|
||||||
Fedora = ""
|
|
||||||
Alpine = ""
|
|
||||||
Amazon = ""
|
|
||||||
Android = ""
|
|
||||||
AOSC = ""
|
|
||||||
Arch = ""
|
|
||||||
Artix = ""
|
|
||||||
CentOS = ""
|
|
||||||
Debian = ""
|
|
||||||
Redhat = ""
|
|
||||||
RedHatEnterprise = ""
|
|
||||||
|
|
||||||
[username]
|
|
||||||
show_always = true
|
|
||||||
style_user = "bg:red fg:crust"
|
|
||||||
style_root = "bg:red fg:crust"
|
|
||||||
format = '[ $user]($style)'
|
|
||||||
|
|
||||||
[directory]
|
|
||||||
style = "bg:peach fg:crust"
|
|
||||||
format = "[ $path ]($style)"
|
|
||||||
truncation_length = 3
|
|
||||||
truncation_symbol = "…/"
|
|
||||||
|
|
||||||
[directory.substitutions]
|
|
||||||
"Documents" = " "
|
|
||||||
"Downloads" = " "
|
|
||||||
"Music" = " "
|
|
||||||
"Pictures" = " "
|
|
||||||
"Developer" = " "
|
|
||||||
|
|
||||||
[git_branch]
|
|
||||||
symbol = ""
|
|
||||||
style = "bg:yellow"
|
|
||||||
format = '[[ $symbol $branch ](fg:crust bg:yellow)]($style)'
|
|
||||||
|
|
||||||
[git_status]
|
|
||||||
style = "bg:yellow"
|
|
||||||
format = '[[($all_status$ahead_behind )](fg:crust bg:yellow)]($style)'
|
|
||||||
|
|
||||||
[nodejs]
|
|
||||||
symbol = ""
|
|
||||||
style = "bg:green"
|
|
||||||
format = '[[ $symbol( $version) ](fg:crust bg:green)]($style)'
|
|
||||||
|
|
||||||
[bun]
|
|
||||||
symbol = ""
|
|
||||||
style = "bg:green"
|
|
||||||
format = '[[ $symbol( $version) ](fg:crust bg:green)]($style)'
|
|
||||||
|
|
||||||
[c]
|
|
||||||
symbol = " "
|
|
||||||
style = "bg:green"
|
|
||||||
format = '[[ $symbol( $version) ](fg:crust bg:green)]($style)'
|
|
||||||
|
|
||||||
[rust]
|
|
||||||
symbol = ""
|
|
||||||
style = "bg:green"
|
|
||||||
format = '[[ $symbol( $version) ](fg:crust bg:green)]($style)'
|
|
||||||
|
|
||||||
[golang]
|
|
||||||
symbol = ""
|
|
||||||
style = "bg:green"
|
|
||||||
format = '[[ $symbol( $version) ](fg:crust bg:green)]($style)'
|
|
||||||
|
|
||||||
[php]
|
|
||||||
symbol = ""
|
|
||||||
style = "bg:green"
|
|
||||||
format = '[[ $symbol( $version) ](fg:crust bg:green)]($style)'
|
|
||||||
|
|
||||||
[java]
|
|
||||||
symbol = " "
|
|
||||||
style = "bg:green"
|
|
||||||
format = '[[ $symbol( $version) ](fg:crust bg:green)]($style)'
|
|
||||||
|
|
||||||
[kotlin]
|
|
||||||
symbol = ""
|
|
||||||
style = "bg:green"
|
|
||||||
format = '[[ $symbol( $version) ](fg:crust bg:green)]($style)'
|
|
||||||
|
|
||||||
[haskell]
|
|
||||||
symbol = ""
|
|
||||||
style = "bg:green"
|
|
||||||
format = '[[ $symbol( $version) ](fg:crust bg:green)]($style)'
|
|
||||||
|
|
||||||
[python]
|
|
||||||
symbol = ""
|
|
||||||
style = "bg:green"
|
|
||||||
format = '[[ $symbol( $version)(\(#$virtualenv\)) ](fg:crust bg:green)]($style)'
|
|
||||||
|
|
||||||
[docker_context]
|
|
||||||
symbol = ""
|
|
||||||
style = "bg:sapphire"
|
|
||||||
format = '[[ $symbol( $context) ](fg:crust bg:sapphire)]($style)'
|
|
||||||
|
|
||||||
[conda]
|
|
||||||
symbol = " "
|
|
||||||
style = "fg:crust bg:sapphire"
|
|
||||||
format = '[$symbol$environment ]($style)'
|
|
||||||
ignore_base = false
|
|
||||||
|
|
||||||
[time]
|
|
||||||
disabled = false
|
|
||||||
time_format = "%R"
|
|
||||||
style = "bg:lavender"
|
|
||||||
format = '[[ $time ](fg:crust bg:lavender)]($style)'
|
|
||||||
|
|
||||||
[line_break]
|
|
||||||
disabled = true
|
|
||||||
|
|
||||||
[character]
|
|
||||||
disabled = false
|
|
||||||
success_symbol = '[❯](bold fg:green)'
|
|
||||||
error_symbol = '[❯](bold fg:red)'
|
|
||||||
vimcmd_symbol = '[❮](bold fg:green)'
|
|
||||||
vimcmd_replace_one_symbol = '[❮](bold fg:lavender)'
|
|
||||||
vimcmd_replace_symbol = '[❮](bold fg:lavender)'
|
|
||||||
vimcmd_visual_symbol = '[❮](bold fg:yellow)'
|
|
||||||
|
|
||||||
[cmd_duration]
|
|
||||||
show_milliseconds = true
|
|
||||||
format = " in $duration "
|
|
||||||
style = "bg:lavender"
|
|
||||||
disabled = false
|
|
||||||
show_notifications = true
|
|
||||||
min_time_to_notify = 45000
|
|
||||||
|
|
||||||
[palettes.catppuccin_mocha]
|
|
||||||
rosewater = "#f5e0dc"
|
|
||||||
flamingo = "#f2cdcd"
|
|
||||||
pink = "#f5c2e7"
|
|
||||||
mauve = "#cba6f7"
|
|
||||||
red = "#f38ba8"
|
|
||||||
maroon = "#eba0ac"
|
|
||||||
peach = "#fab387"
|
|
||||||
yellow = "#f9e2af"
|
|
||||||
green = "#a6e3a1"
|
|
||||||
teal = "#94e2d5"
|
|
||||||
sky = "#89dceb"
|
|
||||||
sapphire = "#74c7ec"
|
|
||||||
blue = "#89b4fa"
|
|
||||||
lavender = "#b4befe"
|
|
||||||
text = "#cdd6f4"
|
|
||||||
subtext1 = "#bac2de"
|
|
||||||
subtext0 = "#a6adc8"
|
|
||||||
overlay2 = "#9399b2"
|
|
||||||
overlay1 = "#7f849c"
|
|
||||||
overlay0 = "#6c7086"
|
|
||||||
surface2 = "#585b70"
|
|
||||||
surface1 = "#45475a"
|
|
||||||
surface0 = "#313244"
|
|
||||||
base = "#1e1e2e"
|
|
||||||
mantle = "#181825"
|
|
||||||
crust = "#11111b"
|
|
||||||
|
|
||||||
[palettes.catppuccin_frappe]
|
|
||||||
rosewater = "#f2d5cf"
|
|
||||||
flamingo = "#eebebe"
|
|
||||||
pink = "#f4b8e4"
|
|
||||||
mauve = "#ca9ee6"
|
|
||||||
red = "#e78284"
|
|
||||||
maroon = "#ea999c"
|
|
||||||
peach = "#ef9f76"
|
|
||||||
yellow = "#e5c890"
|
|
||||||
green = "#a6d189"
|
|
||||||
teal = "#81c8be"
|
|
||||||
sky = "#99d1db"
|
|
||||||
sapphire = "#85c1dc"
|
|
||||||
blue = "#8caaee"
|
|
||||||
lavender = "#babbf1"
|
|
||||||
text = "#c6d0f5"
|
|
||||||
subtext1 = "#b5bfe2"
|
|
||||||
subtext0 = "#a5adce"
|
|
||||||
overlay2 = "#949cbb"
|
|
||||||
overlay1 = "#838ba7"
|
|
||||||
overlay0 = "#737994"
|
|
||||||
surface2 = "#626880"
|
|
||||||
surface1 = "#51576d"
|
|
||||||
surface0 = "#414559"
|
|
||||||
base = "#303446"
|
|
||||||
mantle = "#292c3c"
|
|
||||||
crust = "#232634"
|
|
||||||
|
|
||||||
[palettes.catppuccin_latte]
|
|
||||||
rosewater = "#dc8a78"
|
|
||||||
flamingo = "#dd7878"
|
|
||||||
pink = "#ea76cb"
|
|
||||||
mauve = "#8839ef"
|
|
||||||
red = "#d20f39"
|
|
||||||
maroon = "#e64553"
|
|
||||||
peach = "#fe640b"
|
|
||||||
yellow = "#df8e1d"
|
|
||||||
green = "#40a02b"
|
|
||||||
teal = "#179299"
|
|
||||||
sky = "#04a5e5"
|
|
||||||
sapphire = "#209fb5"
|
|
||||||
blue = "#1e66f5"
|
|
||||||
lavender = "#7287fd"
|
|
||||||
text = "#4c4f69"
|
|
||||||
subtext1 = "#5c5f77"
|
|
||||||
subtext0 = "#6c6f85"
|
|
||||||
overlay2 = "#7c7f93"
|
|
||||||
overlay1 = "#8c8fa1"
|
|
||||||
overlay0 = "#9ca0b0"
|
|
||||||
surface2 = "#acb0be"
|
|
||||||
surface1 = "#bcc0cc"
|
|
||||||
surface0 = "#ccd0da"
|
|
||||||
base = "#eff1f5"
|
|
||||||
mantle = "#e6e9ef"
|
|
||||||
crust = "#dce0e8"
|
|
||||||
|
|
||||||
[palettes.catppuccin_macchiato]
|
|
||||||
rosewater = "#f4dbd6"
|
|
||||||
flamingo = "#f0c6c6"
|
|
||||||
pink = "#f5bde6"
|
|
||||||
mauve = "#c6a0f6"
|
|
||||||
red = "#ed8796"
|
|
||||||
maroon = "#ee99a0"
|
|
||||||
peach = "#f5a97f"
|
|
||||||
yellow = "#eed49f"
|
|
||||||
green = "#a6da95"
|
|
||||||
teal = "#8bd5ca"
|
|
||||||
sky = "#91d7e3"
|
|
||||||
sapphire = "#7dc4e4"
|
|
||||||
blue = "#8aadf4"
|
|
||||||
lavender = "#b7bdf8"
|
|
||||||
text = "#cad3f5"
|
|
||||||
subtext1 = "#b8c0e0"
|
|
||||||
subtext0 = "#a5adcb"
|
|
||||||
overlay2 = "#939ab7"
|
|
||||||
overlay1 = "#8087a2"
|
|
||||||
overlay0 = "#6e738d"
|
|
||||||
surface2 = "#5b6078"
|
|
||||||
surface1 = "#494d64"
|
|
||||||
surface0 = "#363a4f"
|
|
||||||
base = "#24273a"
|
|
||||||
mantle = "#1e2030"
|
|
||||||
crust = "#181926"
|
|
||||||
Submodule
+1
Submodule yazi/flavors added at 68326b4ca4
@@ -0,0 +1,3 @@
|
|||||||
|
[flavor]
|
||||||
|
dark = "{{yazi_flavor}}"
|
||||||
|
light = "{{yazi_flavor}}"
|
||||||
+303
-7
@@ -1,10 +1,286 @@
|
|||||||
|
// If you'd like to override the default keybindings completely, be sure to change "keybinds" to "keybinds clear-defaults=true"
|
||||||
|
keybinds {
|
||||||
|
normal {
|
||||||
|
// uncomment this and adjust key if using copy_on_select=false
|
||||||
|
// bind "Alt c" { Copy; }
|
||||||
|
}
|
||||||
|
locked {
|
||||||
|
bind "Ctrl g" { SwitchToMode "Normal"; }
|
||||||
|
}
|
||||||
|
resize {
|
||||||
|
bind "Ctrl n" { SwitchToMode "Normal"; }
|
||||||
|
bind "h" "Left" { Resize "Increase Left"; }
|
||||||
|
bind "j" "Down" { Resize "Increase Down"; }
|
||||||
|
bind "k" "Up" { Resize "Increase Up"; }
|
||||||
|
bind "l" "Right" { Resize "Increase Right"; }
|
||||||
|
bind "H" { Resize "Decrease Left"; }
|
||||||
|
bind "J" { Resize "Decrease Down"; }
|
||||||
|
bind "K" { Resize "Decrease Up"; }
|
||||||
|
bind "L" { Resize "Decrease Right"; }
|
||||||
|
bind "=" "+" { Resize "Increase"; }
|
||||||
|
bind "-" { Resize "Decrease"; }
|
||||||
|
}
|
||||||
|
pane {
|
||||||
|
bind "Ctrl p" { SwitchToMode "Normal"; }
|
||||||
|
bind "h" "Left" { MoveFocus "Left"; }
|
||||||
|
bind "l" "Right" { MoveFocus "Right"; }
|
||||||
|
bind "j" "Down" { MoveFocus "Down"; }
|
||||||
|
bind "k" "Up" { MoveFocus "Up"; }
|
||||||
|
bind "p" { SwitchFocus; }
|
||||||
|
bind "n" { NewPane; SwitchToMode "Normal"; }
|
||||||
|
bind "d" { NewPane "Down"; SwitchToMode "Normal"; }
|
||||||
|
bind "r" { NewPane "Right"; SwitchToMode "Normal"; }
|
||||||
|
bind "x" { CloseFocus; SwitchToMode "Normal"; }
|
||||||
|
bind "f" { ToggleFocusFullscreen; SwitchToMode "Normal"; }
|
||||||
|
bind "z" { TogglePaneFrames; SwitchToMode "Normal"; }
|
||||||
|
bind "w" { ToggleFloatingPanes; SwitchToMode "Normal"; }
|
||||||
|
bind "e" { TogglePaneEmbedOrFloating; SwitchToMode "Normal"; }
|
||||||
|
bind "c" { SwitchToMode "RenamePane"; PaneNameInput 0;}
|
||||||
|
}
|
||||||
|
move {
|
||||||
|
bind "Ctrl h" { SwitchToMode "Normal"; }
|
||||||
|
bind "n" "Tab" { MovePane; }
|
||||||
|
bind "h" "Left" { MovePane "Left"; }
|
||||||
|
bind "j" "Down" { MovePane "Down"; }
|
||||||
|
bind "k" "Up" { MovePane "Up"; }
|
||||||
|
bind "l" "Right" { MovePane "Right"; }
|
||||||
|
}
|
||||||
|
tab {
|
||||||
|
bind "Ctrl t" { SwitchToMode "Normal"; }
|
||||||
|
bind "r" { SwitchToMode "RenameTab"; TabNameInput 0; }
|
||||||
|
bind "h" "Left" "Up" "k" { GoToPreviousTab; }
|
||||||
|
bind "l" "Right" "Down" "j" { GoToNextTab; }
|
||||||
|
bind "n" { NewTab; SwitchToMode "Normal"; }
|
||||||
|
bind "x" { CloseTab; SwitchToMode "Normal"; }
|
||||||
|
bind "s" { ToggleActiveSyncTab; SwitchToMode "Normal"; }
|
||||||
|
bind "1" { GoToTab 1; SwitchToMode "Normal"; }
|
||||||
|
bind "2" { GoToTab 2; SwitchToMode "Normal"; }
|
||||||
|
bind "3" { GoToTab 3; SwitchToMode "Normal"; }
|
||||||
|
bind "4" { GoToTab 4; SwitchToMode "Normal"; }
|
||||||
|
bind "5" { GoToTab 5; SwitchToMode "Normal"; }
|
||||||
|
bind "6" { GoToTab 6; SwitchToMode "Normal"; }
|
||||||
|
bind "7" { GoToTab 7; SwitchToMode "Normal"; }
|
||||||
|
bind "8" { GoToTab 8; SwitchToMode "Normal"; }
|
||||||
|
bind "9" { GoToTab 9; SwitchToMode "Normal"; }
|
||||||
|
bind "Tab" { ToggleTab; }
|
||||||
|
}
|
||||||
|
scroll {
|
||||||
|
bind "Ctrl s" { SwitchToMode "Normal"; }
|
||||||
|
bind "e" { EditScrollback; SwitchToMode "Normal"; }
|
||||||
|
bind "s" { SwitchToMode "EnterSearch"; SearchInput 0; }
|
||||||
|
bind "Ctrl c" { ScrollToBottom; SwitchToMode "Normal"; }
|
||||||
|
bind "j" "Down" { ScrollDown; }
|
||||||
|
bind "k" "Up" { ScrollUp; }
|
||||||
|
bind "Ctrl f" "PageDown" "Right" "l" { PageScrollDown; }
|
||||||
|
bind "Ctrl b" "PageUp" "Left" "h" { PageScrollUp; }
|
||||||
|
bind "d" { HalfPageScrollDown; }
|
||||||
|
bind "u" { HalfPageScrollUp; }
|
||||||
|
// uncomment this and adjust key if using copy_on_select=false
|
||||||
|
// bind "Alt c" { Copy; }
|
||||||
|
}
|
||||||
|
search {
|
||||||
|
bind "Ctrl s" { SwitchToMode "Normal"; }
|
||||||
|
bind "Ctrl c" { ScrollToBottom; SwitchToMode "Normal"; }
|
||||||
|
bind "j" "Down" { ScrollDown; }
|
||||||
|
bind "k" "Up" { ScrollUp; }
|
||||||
|
bind "Ctrl f" "PageDown" "Right" "l" { PageScrollDown; }
|
||||||
|
bind "Ctrl b" "PageUp" "Left" "h" { PageScrollUp; }
|
||||||
|
bind "d" { HalfPageScrollDown; }
|
||||||
|
bind "u" { HalfPageScrollUp; }
|
||||||
|
bind "n" { Search "down"; }
|
||||||
|
bind "p" { Search "up"; }
|
||||||
|
bind "c" { SearchToggleOption "CaseSensitivity"; }
|
||||||
|
bind "w" { SearchToggleOption "Wrap"; }
|
||||||
|
bind "o" { SearchToggleOption "WholeWord"; }
|
||||||
|
}
|
||||||
|
entersearch {
|
||||||
|
bind "Ctrl c" "Esc" { SwitchToMode "Scroll"; }
|
||||||
|
bind "Enter" { SwitchToMode "Search"; }
|
||||||
|
}
|
||||||
|
renametab {
|
||||||
|
bind "Ctrl c" { SwitchToMode "Normal"; }
|
||||||
|
bind "Esc" { UndoRenameTab; SwitchToMode "Tab"; }
|
||||||
|
}
|
||||||
|
renamepane {
|
||||||
|
bind "Ctrl c" { SwitchToMode "Normal"; }
|
||||||
|
bind "Esc" { UndoRenamePane; SwitchToMode "Pane"; }
|
||||||
|
}
|
||||||
|
session {
|
||||||
|
bind "Ctrl o" { SwitchToMode "Normal"; }
|
||||||
|
bind "Ctrl s" { SwitchToMode "Scroll"; }
|
||||||
|
bind "d" { Detach; }
|
||||||
|
}
|
||||||
|
tmux {
|
||||||
|
bind "[" { SwitchToMode "Scroll"; }
|
||||||
|
bind "Ctrl b" { Write 2; SwitchToMode "Normal"; }
|
||||||
|
bind "\"" { NewPane "Down"; SwitchToMode "Normal"; }
|
||||||
|
bind "%" { NewPane "Right"; SwitchToMode "Normal"; }
|
||||||
|
bind "z" { ToggleFocusFullscreen; SwitchToMode "Normal"; }
|
||||||
|
bind "c" { NewTab; SwitchToMode "Normal"; }
|
||||||
|
bind "," { SwitchToMode "RenameTab"; }
|
||||||
|
bind "p" { GoToPreviousTab; SwitchToMode "Normal"; }
|
||||||
|
bind "n" { GoToNextTab; SwitchToMode "Normal"; }
|
||||||
|
bind "Left" { MoveFocus "Left"; SwitchToMode "Normal"; }
|
||||||
|
bind "Right" { MoveFocus "Right"; SwitchToMode "Normal"; }
|
||||||
|
bind "Down" { MoveFocus "Down"; SwitchToMode "Normal"; }
|
||||||
|
bind "Up" { MoveFocus "Up"; SwitchToMode "Normal"; }
|
||||||
|
bind "h" { MoveFocus "Left"; SwitchToMode "Normal"; }
|
||||||
|
bind "l" { MoveFocus "Right"; SwitchToMode "Normal"; }
|
||||||
|
bind "j" { MoveFocus "Down"; SwitchToMode "Normal"; }
|
||||||
|
bind "k" { MoveFocus "Up"; SwitchToMode "Normal"; }
|
||||||
|
bind "o" { FocusNextPane; }
|
||||||
|
bind "d" { Detach; }
|
||||||
|
}
|
||||||
|
shared_except "locked" {
|
||||||
|
bind "Ctrl g" { SwitchToMode "Locked"; }
|
||||||
|
bind "Ctrl q" { Quit; }
|
||||||
|
bind "Alt n" { NewPane; }
|
||||||
|
bind "Alt h" "Alt Left" { MoveFocusOrTab "Left"; }
|
||||||
|
bind "Alt l" "Alt Right" { MoveFocusOrTab "Right"; }
|
||||||
|
bind "Alt j" "Alt Down" { MoveFocus "Down"; }
|
||||||
|
bind "Alt k" "Alt Up" { MoveFocus "Up"; }
|
||||||
|
bind "Alt =" "Alt +" { Resize "Increase"; }
|
||||||
|
bind "Alt -" { Resize "Decrease"; }
|
||||||
|
}
|
||||||
|
shared_except "normal" "locked" {
|
||||||
|
bind "Enter" "Esc" { SwitchToMode "Normal"; }
|
||||||
|
}
|
||||||
|
shared_except "pane" "locked" {
|
||||||
|
bind "Ctrl p" { SwitchToMode "Pane"; }
|
||||||
|
}
|
||||||
|
shared_except "resize" "locked" {
|
||||||
|
bind "Ctrl n" { SwitchToMode "Resize"; }
|
||||||
|
}
|
||||||
|
shared_except "scroll" "locked" {
|
||||||
|
bind "Ctrl s" { SwitchToMode "Scroll"; }
|
||||||
|
}
|
||||||
|
shared_except "session" "locked" {
|
||||||
|
bind "Ctrl o" { SwitchToMode "Session"; }
|
||||||
|
}
|
||||||
|
shared_except "tab" "locked" {
|
||||||
|
bind "Ctrl t" { SwitchToMode "Tab"; }
|
||||||
|
}
|
||||||
|
shared_except "move" "locked" {
|
||||||
|
bind "Ctrl h" { SwitchToMode "Move"; }
|
||||||
|
}
|
||||||
|
shared_except "tmux" "locked" {
|
||||||
|
bind "Ctrl b" { SwitchToMode "Tmux"; }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
plugins {
|
||||||
|
tab-bar { path "tab-bar"; }
|
||||||
|
status-bar { path "status-bar"; }
|
||||||
|
strider { path "strider"; }
|
||||||
|
compact-bar { path "compact-bar"; }
|
||||||
|
}
|
||||||
|
|
||||||
|
// Choose what to do when zellij receives SIGTERM, SIGINT, SIGQUIT or SIGHUP
|
||||||
|
// eg. when terminal window with an active zellij session is closed
|
||||||
|
// Options:
|
||||||
|
// - detach (Default)
|
||||||
|
// - quit
|
||||||
|
//
|
||||||
|
// on_force_close "quit"
|
||||||
|
|
||||||
|
// Send a request for a simplified ui (without arrow fonts) to plugins
|
||||||
|
// Options:
|
||||||
|
// - true
|
||||||
|
// - false (Default)
|
||||||
|
//
|
||||||
|
// simplified_ui true
|
||||||
|
|
||||||
|
// Choose the path to the default shell that zellij will use for opening new panes
|
||||||
|
// Default: $SHELL
|
||||||
|
//
|
||||||
|
// default_shell "fish"
|
||||||
|
|
||||||
|
// Toggle between having pane frames around the panes
|
||||||
|
// Options:
|
||||||
|
// - true (default)
|
||||||
|
// - false
|
||||||
|
//
|
||||||
|
// pane_frames true
|
||||||
|
|
||||||
|
// Define color themes for Zellij
|
||||||
|
// For more examples, see: https://github.com/zellij-org/zellij/tree/main/example/themes
|
||||||
|
// Once these themes are defined, one of them should to be selected in the "theme" section of this file
|
||||||
|
//
|
||||||
|
// themes {
|
||||||
|
// dracula {
|
||||||
|
// fg 248 248 242
|
||||||
|
// bg 40 42 54
|
||||||
|
// red 255 85 85
|
||||||
|
// green 80 250 123
|
||||||
|
// yellow 241 250 140
|
||||||
|
// blue 98 114 164
|
||||||
|
// magenta 255 121 198
|
||||||
|
// orange 255 184 108
|
||||||
|
// cyan 139 233 253
|
||||||
|
// black 0 0 0
|
||||||
|
// white 255 255 255
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
|
||||||
|
// themes {
|
||||||
|
// bogster-dark {
|
||||||
|
// bg "#161C23"
|
||||||
|
// fg "#C6B8AD"
|
||||||
|
// black "#161C23"
|
||||||
|
// red "#D32C5D"
|
||||||
|
// green "#57A331"
|
||||||
|
// orange "#DC7759"
|
||||||
|
// yellow "#DCB659"
|
||||||
|
// blue "#36B2D4"
|
||||||
|
// magenta "#B759DC"
|
||||||
|
// cyan "#23A580"
|
||||||
|
// white "#C6B8AD"
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
|
||||||
// Choose the theme that is specified in the themes section.
|
// Choose the theme that is specified in the themes section.
|
||||||
// Default: default
|
// Default: default
|
||||||
|
//
|
||||||
|
// theme "default"
|
||||||
|
|
||||||
theme "{{zellij_theme}}"
|
theme "{{zellij_theme}}"
|
||||||
|
|
||||||
// The name of the default layout to load on startup
|
// The name of the default layout to load on startup
|
||||||
// Default: "default"
|
// Default: "default"
|
||||||
default_layout "compact"
|
//
|
||||||
|
// default_layout "compact"
|
||||||
|
|
||||||
|
// Choose the mode that zellij uses when starting up.
|
||||||
|
// Default: normal
|
||||||
|
//
|
||||||
|
// default_mode "locked"
|
||||||
|
|
||||||
|
// Toggle enabling the mouse mode.
|
||||||
|
// On certain configurations, or terminals this could
|
||||||
|
// potentially interfere with copying text.
|
||||||
|
// Options:
|
||||||
|
// - true (default)
|
||||||
|
// - false
|
||||||
|
//
|
||||||
|
// mouse_mode false
|
||||||
|
|
||||||
|
// Configure the scroll back buffer size
|
||||||
|
// This is the number of lines zellij stores for each pane in the scroll back
|
||||||
|
// buffer. Excess number of lines are discarded in a FIFO fashion.
|
||||||
|
// Valid values: positive integers
|
||||||
|
// Default value: 10000
|
||||||
|
//
|
||||||
|
// scroll_buffer_size 10000
|
||||||
|
|
||||||
|
// Provide a command to execute when copying text. The text will be piped to
|
||||||
|
// the stdin of the program to perform the copy. This can be used with
|
||||||
|
// terminal emulators which do not support the OSC 52 ANSI control sequence
|
||||||
|
// that will be used by default if this option is not set.
|
||||||
|
// Examples:
|
||||||
|
//
|
||||||
|
// copy_command "xclip -selection clipboard" // x11
|
||||||
|
// copy_command "wl-copy" // wayland
|
||||||
|
// copy_command "pbcopy" // osx
|
||||||
|
|
||||||
// Choose the destination for copied text
|
// Choose the destination for copied text
|
||||||
// Allows using the primary selection buffer (on x11/wayland) instead of the system clipboard.
|
// Allows using the primary selection buffer (on x11/wayland) instead of the system clipboard.
|
||||||
@@ -12,10 +288,30 @@ default_layout "compact"
|
|||||||
// Options:
|
// Options:
|
||||||
// - system (default)
|
// - system (default)
|
||||||
// - primary
|
// - primary
|
||||||
copy_clipboard "primary"
|
//
|
||||||
|
// copy_clipboard "primary"
|
||||||
|
|
||||||
// Toggle between having pane frames around the panes
|
// Enable or disable automatic copy (and clear) of selection when releasing mouse
|
||||||
// Options:
|
// Default: true
|
||||||
// - true (default)
|
//
|
||||||
// - false
|
// copy_on_select false
|
||||||
pane_frames false
|
|
||||||
|
// Path to the default editor to use to edit pane scrollbuffer
|
||||||
|
// Default: $EDITOR or $VISUAL
|
||||||
|
//
|
||||||
|
// scrollback_editor "/usr/bin/vim"
|
||||||
|
|
||||||
|
// When attaching to an existing session with other users,
|
||||||
|
// should the session be mirrored (true)
|
||||||
|
// or should each user have their own cursor (false)
|
||||||
|
// Default: false
|
||||||
|
//
|
||||||
|
// mirror_session true
|
||||||
|
|
||||||
|
// The folder in which Zellij will look for layouts
|
||||||
|
//
|
||||||
|
// layout_dir "/path/to/my/layout_dir"
|
||||||
|
|
||||||
|
// The folder in which Zellij will look for themes
|
||||||
|
//
|
||||||
|
// theme_dir "/path/to/my/theme_dir"
|
||||||
|
|||||||
@@ -0,0 +1,87 @@
|
|||||||
|
layout {
|
||||||
|
pane_template name="explorer" {
|
||||||
|
pane split_direction="vertical" {
|
||||||
|
pane size="14%" borderless=true command="zsh" {
|
||||||
|
args "-i" "-c" "exex"
|
||||||
|
}
|
||||||
|
children
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
pane_template name="sidebar-pane" {
|
||||||
|
pane size="24%" split_direction="horizontal" { children; }
|
||||||
|
}
|
||||||
|
|
||||||
|
pane_template name="console-pane" {
|
||||||
|
pane size="28%" split_direction="vertical" { children; }
|
||||||
|
}
|
||||||
|
|
||||||
|
pane_template name="stacked-console-pane" {
|
||||||
|
pane size="28%" stacked=true { children; }
|
||||||
|
}
|
||||||
|
|
||||||
|
tab_template name="project-tab" {
|
||||||
|
pane size=1 borderless=true { plugin location="zellij:compact-bar"; }
|
||||||
|
children
|
||||||
|
}
|
||||||
|
|
||||||
|
default_tab_template {
|
||||||
|
pane size=1 borderless=true { plugin location="zellij:compact-bar"; }
|
||||||
|
explorer { pane focus=true; }
|
||||||
|
}
|
||||||
|
|
||||||
|
swap_tiled_layout name="ide" {
|
||||||
|
project-tab max_panes=3 {
|
||||||
|
explorer { pane; }
|
||||||
|
}
|
||||||
|
project-tab exact_panes=4 {
|
||||||
|
explorer { pane; }
|
||||||
|
console-pane split_direction="vertical" size="28%" { pane; }
|
||||||
|
}
|
||||||
|
project-tab exact_panes=5 {
|
||||||
|
explorer { pane; }
|
||||||
|
console-pane split_direction="vertical" size="28%" {
|
||||||
|
pane
|
||||||
|
pane
|
||||||
|
}
|
||||||
|
}
|
||||||
|
project-tab exact_panes=6 {
|
||||||
|
explorer { pane; }
|
||||||
|
stacked-console-pane stacked=true size="28%" {
|
||||||
|
pane
|
||||||
|
pane
|
||||||
|
pane
|
||||||
|
}
|
||||||
|
}
|
||||||
|
project-tab exact_panes=7 {
|
||||||
|
explorer split_direction="vertical" {
|
||||||
|
pane
|
||||||
|
sidebar-pane size="24%" { pane borderless=true; }
|
||||||
|
}
|
||||||
|
stacked-console-pane stacked=true size="28%" {
|
||||||
|
pane
|
||||||
|
pane
|
||||||
|
pane
|
||||||
|
}
|
||||||
|
}
|
||||||
|
project-tab min_panes=8 {
|
||||||
|
explorer {
|
||||||
|
pane split_direction="vertical" {
|
||||||
|
pane
|
||||||
|
pane
|
||||||
|
pane
|
||||||
|
}
|
||||||
|
pane split_direction="vertical" {
|
||||||
|
pane
|
||||||
|
pane
|
||||||
|
pane
|
||||||
|
}
|
||||||
|
pane split_direction="vertical" {
|
||||||
|
pane
|
||||||
|
pane
|
||||||
|
pane
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,4 +0,0 @@
|
|||||||
# Enable goenv if it is installed
|
|
||||||
# if (( $+commands[goenv] )); then
|
|
||||||
# eval "$(goenv init -)"
|
|
||||||
# fi
|
|
||||||
+6
-5
@@ -1,6 +1,7 @@
|
|||||||
# Enable nvm if it is installed
|
# NVM
|
||||||
if [ -d "$HOME/.nvm" ]; then
|
if [[ -s "$NVM_DIR/nvm.sh" ]]; then
|
||||||
export NVM_DIR="$HOME/.nvm"
|
source "$NVM_DIR/nvm.sh" # This loads nvm
|
||||||
[ -s "$NVM_DIR/nvm.sh" ] && \. "$NVM_DIR/nvm.sh"
|
fi
|
||||||
[ -s "$NVM_DIR/bash_completion" ] && \. "$NVM_DIR/bash_completion"
|
if [[ -s "$NVM_DIR/bash_completion" ]]; then
|
||||||
|
source "$NVM_DIR/bash_completion" # This loads nvm bash_completion
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -1,4 +0,0 @@
|
|||||||
# Enable rbenv if it is installed
|
|
||||||
if (( $+commands[rbenv] )); then
|
|
||||||
eval "$(rbenv init - --no-rehash zsh)"
|
|
||||||
fi
|
|
||||||
@@ -1,9 +0,0 @@
|
|||||||
# Allow Ctrl-z to toggle between suspend and resume
|
|
||||||
function Resume {
|
|
||||||
fg
|
|
||||||
zle push-input
|
|
||||||
BUFFER=""
|
|
||||||
zle accept-line
|
|
||||||
}
|
|
||||||
zle -N Resume
|
|
||||||
bindkey "^Z" Resume
|
|
||||||
+17
-19
@@ -1,34 +1,32 @@
|
|||||||
# zellij
|
# zellij
|
||||||
if (( $+commands[zellij] )); then
|
if (( $+commands[zellij] )); then
|
||||||
# Uncomment to start/exit zellij automatically
|
ZELLIJ_AUTO_ATTACH=true
|
||||||
# ZELLIJ_AUTO_ATTACH=true
|
eval "$(zellij setup --generate-auto-start zsh)"
|
||||||
# ZELLIJ_AUTO_EXIT=true
|
|
||||||
# eval "$(zellij setup --generate-auto-start zsh)"
|
|
||||||
|
|
||||||
if (( $+commands[sk] )); then
|
if (( $+commands[sk] )); then
|
||||||
function za {
|
za() {
|
||||||
local zj_sessions=$(zellij list-sessions -ns)
|
local zj_sessions=$(zellij list-sessions -ns)
|
||||||
local no_sessions=$(echo "${zj_sessions}" | wc -l)
|
local no_sessions=$(echo "${zj_sessions}" | wc -l)
|
||||||
|
|
||||||
if [ "${no_sessions}" -ge 2 ]; then
|
if [ "${no_sessions}" -ge 2 ]; then
|
||||||
zellij attach \
|
zellij attach \
|
||||||
"$(echo "${zj_sessions}" | sk)"
|
"$(echo "${zj_sessions}" | sk)"
|
||||||
else
|
else
|
||||||
zellij attach -c
|
zellij attach -c
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Name tabs after current working directory
|
ide() {
|
||||||
if [[ -v ZELLIJ ]]; then
|
local layout="${ZELLIJ_LAYOUT:-${HOME}/.config/zellij/layouts/project.kdl}"
|
||||||
function zrt {
|
local name="${PROJECT_NAME:-/}"
|
||||||
zellij action rename-tab "${PWD##*/}"
|
|
||||||
}
|
|
||||||
|
|
||||||
function znt {
|
if (( ${+ZELLIJ} )); then
|
||||||
zellij action new-tab
|
# FIXME: https://github.com/zellij-org/zellij/issues/2299
|
||||||
}
|
zellij action new-tab --layout "${layout}" --cwd "${PWD}" --name "${name}"
|
||||||
|
else
|
||||||
chpwd_functions+=( zrt )
|
zellij --layout "${layout}" --session "${name}"
|
||||||
fi
|
fi
|
||||||
|
}
|
||||||
fi
|
fi
|
||||||
|
|||||||
+17
-11
@@ -1,24 +1,30 @@
|
|||||||
# export DOCKER_HOST="unix://$XDG_RUNTIME_DIR/docker.sock"
|
export DOCKER_HOST="unix://$XDG_RUNTIME_DIR/docker.sock"
|
||||||
# export DOCKER_SOCKET="$XDG_RUNTIME_DIR/docker.sock"
|
export DOCKER_SOCKET="$XDG_RUNTIME_DIR/docker.sock"
|
||||||
if (( $+commands[hx] )); then
|
export EDITOR="helix"
|
||||||
export EDITOR="hx"
|
|
||||||
export VISUAL="hx"
|
|
||||||
elif (( $+commands[helix] )); then
|
|
||||||
export EDITOR="helix"
|
|
||||||
export VISUAL="helix"
|
|
||||||
fi
|
|
||||||
|
|
||||||
export FINDER="sk"
|
export FINDER="sk"
|
||||||
export GPG_TTY=$(tty)
|
export GPG_TTY=$(tty)
|
||||||
export HELIX_RUNTIME="/usr/lib/helix/runtime"
|
export HELIX_RUNTIME="$HOME/src/helix/runtime"
|
||||||
export NVM_DIR="$HOME/.nvm"
|
export NVM_DIR="$HOME/.nvm"
|
||||||
export SKIM_DEFAULT_COMMAND="git ls-tree -r --name-only HEAD || rg --files"
|
export SKIM_DEFAULT_COMMAND="git ls-tree -r --name-only HEAD || rg --files"
|
||||||
|
export VISUAL="helix"
|
||||||
|
|
||||||
fpath+=(~/.zsh/completions)
|
fpath+=(~/.zsh/completions)
|
||||||
|
|
||||||
# Setup cargo
|
# Setup cargo
|
||||||
[[ -s ~/.cargo/env ]] && source ~/.cargo/env
|
[[ -s ~/.cargo/env ]] && source ~/.cargo/env
|
||||||
|
|
||||||
|
# Local gems
|
||||||
|
if (( $+commands[ruby] )); then
|
||||||
|
local gem_bin_path="$(ruby -r rubygems -e 'puts Gem.user_dir')/bin"
|
||||||
|
[[ -d "$gem_bin_path" ]] && path+=("$gem_bin_path")
|
||||||
|
fi
|
||||||
|
|
||||||
|
# Setup go paths
|
||||||
|
if (( $+commands[go] )); then
|
||||||
|
local go_bin_path="$(go env GOPATH)/bin"
|
||||||
|
[[ -d "$go_bin_path" ]] && path+=("$go_bin_path")
|
||||||
|
fi
|
||||||
|
|
||||||
if (( $+commands[fd] )); then
|
if (( $+commands[fd] )); then
|
||||||
export FZF_DEFAULT_COMMAND="fd --type f"
|
export FZF_DEFAULT_COMMAND="fd --type f"
|
||||||
export FZF_CTRL_T_COMMAND="$FZF_DEFAULT_COMMAND"
|
export FZF_CTRL_T_COMMAND="$FZF_DEFAULT_COMMAND"
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
# Option adjustments
|
# Option adjustments
|
||||||
unsetopt nomatch
|
unsetopt nomatch
|
||||||
|
|
||||||
# Swap CAPSLOCK and ESC (keyd is a better option)
|
# Swap CAPSLOCK and ESC
|
||||||
setxkbmap -option caps:swapescape
|
setxkbmap -option caps:swapescape
|
||||||
|
|
||||||
# conf.d style configurations
|
# conf.d style configurations
|
||||||
|
|||||||
Reference in New Issue
Block a user