From 2036170ce31a838a7df6da635d644cc1d61a585a Mon Sep 17 00:00:00 2001 From: muon Date: Wed, 24 Sep 2025 22:08:02 +0000 Subject: [PATCH 1/2] Add zmenu --- flake.lock | 48 +++---- modules/home/default.nix | 11 +- modules/home/desktop/development.nix | 44 +++++++ modules/home/desktop/i3.nix | 18 +++ modules/home/desktop/media.nix | 9 +- .../desktop/packages/stremio-linux-shell.nix | 122 ++++++++++++++++++ 6 files changed, 223 insertions(+), 29 deletions(-) create mode 100644 modules/home/desktop/packages/stremio-linux-shell.nix diff --git a/flake.lock b/flake.lock index e7b3e18..b34bc04 100644 --- a/flake.lock +++ b/flake.lock @@ -230,11 +230,11 @@ ] }, "locked": { - "lastModified": 1757075491, - "narHash": "sha256-a+NMGl5tcvm+hyfSG2DlVPa8nZLpsumuRj1FfcKb2mQ=", + "lastModified": 1758719930, + "narHash": "sha256-DgHe1026Ob49CPegPMiWj1HNtlMTGQzfSZQQVlHC950=", "owner": "nix-community", "repo": "home-manager", - "rev": "f56bf065f9abedc7bc15e1f2454aa5c8edabaacf", + "rev": "142acd7a7d9eb7f0bb647f053b4ddfd01fdfbf1d", "type": "github" }, "original": { @@ -280,11 +280,11 @@ "nixpkgs": "nixpkgs" }, "locked": { - "lastModified": 1755253391, - "narHash": "sha256-8Muat6VcG9HsVNtyeKblnj28nnPZVPCGKh/kP3uUPeU=", + "lastModified": 1757920634, + "narHash": "sha256-MNxTc+dncIHFGKQRyAqI/Clttp3JICaSUKlMUQ6l9jc=", "owner": "thiagokokada", "repo": "nix-alien", - "rev": "e62b3ad75e8c9a5e505fc78b9b40eed1178634cb", + "rev": "f8a51ef800bc8b7420998415035f9c086eb64d5c", "type": "github" }, "original": { @@ -301,11 +301,11 @@ ] }, "locked": { - "lastModified": 1754800038, - "narHash": "sha256-UbLO8/0pVBXLJuyRizYOJigtzQAj8Z2bTnbKSec/wN0=", + "lastModified": 1757822619, + "narHash": "sha256-3HIpe3P2h1AUPYcAH9cjuX0tZOqJpX01c0iDwoUYNZ8=", "owner": "nix-community", "repo": "nix-index-database", - "rev": "b65f8d80656f9fcbd1fecc4b7f0730f468333142", + "rev": "050a5feb5d1bb5b6e5fc04a7d3d816923a87c9ea", "type": "github" }, "original": { @@ -336,11 +336,11 @@ }, "nixpkgs": { "locked": { - "lastModified": 1755027561, - "narHash": "sha256-IVft239Bc8p8Dtvf7UAACMG5P3ZV+3/aO28gXpGtMXI=", + "lastModified": 1757745802, + "narHash": "sha256-hLEO2TPj55KcUFUU1vgtHE9UEIOjRcH/4QbmfHNF820=", "owner": "NixOS", "repo": "nixpkgs", - "rev": "005433b926e16227259a1843015b5b2b7f7d1fc3", + "rev": "c23193b943c6c689d70ee98ce3128239ed9e32d1", "type": "github" }, "original": { @@ -368,11 +368,11 @@ }, "nixpkgs_3": { "locked": { - "lastModified": 1756787288, - "narHash": "sha256-rw/PHa1cqiePdBxhF66V7R+WAP8WekQ0mCDG4CFqT8Y=", + "lastModified": 1758427187, + "narHash": "sha256-pHpxZ/IyCwoTQPtFIAG2QaxuSm8jWzrzBGjwQZIttJc=", "owner": "nixos", "repo": "nixpkgs", - "rev": "d0fc30899600b9b3466ddb260fd83deb486c32f1", + "rev": "554be6495561ff07b6c724047bdd7e0716aa7b46", "type": "github" }, "original": { @@ -434,11 +434,11 @@ "systems": "systems_2" }, "locked": { - "lastModified": 1757095994, - "narHash": "sha256-AXwM6/7CuQ39iwBqmc6ZNkVcCdFiK4MFRIGQgU6Mkyk=", + "lastModified": 1758271661, + "narHash": "sha256-ENqd2/33uP5vB44ClDjjAV+J78oF8q1er4QUZuT8Z7g=", "owner": "NotAShelf", "repo": "nvf", - "rev": "fb31022b366ad21951f0352f0cc282cc6a8e9e6f", + "rev": "b7571df4d6e9ac08506a738ddceeec0b141751b0", "type": "github" }, "original": { @@ -467,11 +467,11 @@ ] }, "locked": { - "lastModified": 1754988908, - "narHash": "sha256-t+voe2961vCgrzPFtZxha0/kmFSHFobzF00sT8p9h0U=", + "lastModified": 1758425756, + "narHash": "sha256-L3N8zV6wsViXiD8i3WFyrvjDdz76g3tXKEdZ4FkgQ+Y=", "owner": "Mic92", "repo": "sops-nix", - "rev": "3223c7a92724b5d804e9988c6b447a0d09017d48", + "rev": "e0fdaea3c31646e252a60b42d0ed8eafdb289762", "type": "github" }, "original": { @@ -520,11 +520,11 @@ "tinted-zed": "tinted-zed" }, "locked": { - "lastModified": 1757172691, - "narHash": "sha256-VOn/s24rb+iO6auhmGfT5kyr0ixRK6weBsNCKkGo2yY=", + "lastModified": 1758716250, + "narHash": "sha256-PvOo4vSk7WAOhSifgL+rzExihquU9DOIOQPrUVuFHpE=", "owner": "danth", "repo": "stylix", - "rev": "9991299fe9aad330fb6b96bb58def37033271177", + "rev": "526c882800837cce7676f3e11bb3e13e975c6032", "type": "github" }, "original": { diff --git a/modules/home/default.nix b/modules/home/default.nix index e587fc2..847a63b 100644 --- a/modules/home/default.nix +++ b/modules/home/default.nix @@ -1,6 +1,11 @@ -{ pkgs, lib, config, osConfig, ... }: -let cfg = osConfig.mods; - +{ + pkgs, + lib, + config, + osConfig, + ... +}: let + cfg = osConfig.mods; in { imports = [ ./terminal diff --git a/modules/home/desktop/development.nix b/modules/home/desktop/development.nix index 31a4064..cfa91fc 100644 --- a/modules/home/desktop/development.nix +++ b/modules/home/desktop/development.nix @@ -10,6 +10,50 @@ config = lib.mkIf config.mods.desktop.development.enable { # home.packages = with pkgs; [ i3-swallow ]; + programs.nyxt = { + enable = true; + config = '' + (in-package #:nyxt-user) + + (defvar *my-search-engines* + (list + (make-instance 'search-engine + :name "Searx" + :shortcut "s" + #+nyxt-4 :control-url #+nyxt-3 :search-url + ""https://search.muon.host/?q=~a";") + + (make-instance 'search-engine + :name "nixpkgs" + :shortcut "np" + #+nyxt-4 :control-url #+nyxt-3 :search-url + "https://search.nixos.org/packages?channel=unstable&query=~a"))) + + (make-instance 'search-engine + :name "nix options" + :shortcut "np" + #+nyxt-4 :control-url #+nyxt-3 :search-url + "https://search.nixos.org/options?channel=unstable&query=~a"))) + + (make-instance 'search-engine + :name "home-manager" + :shortcut "hm" + #+nyxt-4 :control-url #+nyxt-3 :search-url + "https://home-manager-options.extranix.com/?release=master&query=~a"))) + + + (define-configuration browser + ((restore-session-on-startup-p nil) + (default-new-buffer-url (quri:uri "https://online.bonjourr.fr/")) + (external-editor-program ("alacritty -e hx") + #+nyxt-4 + (search-engine-suggestions-p nil) + #+nyxt-4 + (search-engines (append %slot-default% *my-search-engines*)) + )) + ''; + }; + programs.qutebrowser = { enable = true; diff --git a/modules/home/desktop/i3.nix b/modules/home/desktop/i3.nix index f6bb38a..0c2021a 100644 --- a/modules/home/desktop/i3.nix +++ b/modules/home/desktop/i3.nix @@ -17,6 +17,23 @@ curl -H "authorization: $AUTH" https://share.muon.host/api/upload -F file=@/tmp/ss.png -H "Content-Type: multipart/form-data" -H "Format: date" -H "Image-Compression-Percent: 90" -H "No-JSON: true" | tr -d '\n' | xsel -ib; ''; }; + zmenu = with pkgs; + writeShellApplication { + name = "zmenu"; + runtimeInputs = [zellij zoxide wmctrl i3 rofi alacritty zsh]; + text = '' + ZPATH=$(zoxide query -l | sed -e "s|$HOME||g" | cut -b 2- | rofi -dmenu) + [[ -z "$ZPATH" ]] && exit + ZSESH=$(echo "$ZPATH" | tr / -) + ZWIND=$(wmctrl -l | grep "$ZSESH" || echo "") + cd "$ZPATH" + if [[ -z "$ZWIND" ]]; then + alacritty -T "$ZSESH" -e zsh -c "zellij -s $ZSESH -n compact || zellij a $ZSESH" + else + wmctrl -a "$ZSESH" + fi + ''; + }; in with lib; { options.mods.i3.enable = mkEnableOption "enables i3"; @@ -139,6 +156,7 @@ in "XF86AudioRaiseVolume" = "exec --no-startup-id pactl set-sink-volume 0 +2%"; "XF86AudioLowerVolume" = "exec --no-startup-id pactl set-sink-volume 0 -2%"; "Print" = "exec ${getExe fsss}"; + "${modifier}+z" = "exec ${getExe zmenu}"; "${modifier}+y" = "sticky toggle"; }); diff --git a/modules/home/desktop/media.nix b/modules/home/desktop/media.nix index 4d8cfce..2f4fe79 100644 --- a/modules/home/desktop/media.nix +++ b/modules/home/desktop/media.nix @@ -1,4 +1,9 @@ -{ pkgs, lib, config, ... }: { +{ + pkgs, + lib, + config, + ... +}: { options.mods.desktop.media.enable = lib.mkEnableOption "enables entertainment programs"; @@ -9,7 +14,7 @@ pavucontrol # Video - stremio + (callPackage ./packages/stremio-linux-shell.nix {}) # Podcasts gpodder diff --git a/modules/home/desktop/packages/stremio-linux-shell.nix b/modules/home/desktop/packages/stremio-linux-shell.nix new file mode 100644 index 0000000..79ca2fc --- /dev/null +++ b/modules/home/desktop/packages/stremio-linux-shell.nix @@ -0,0 +1,122 @@ +{ + lib, + stdenv, + rustPlatform, + fetchFromGitHub, + openssl, + pkg-config, + gtk3, + mpv, + libappindicator, + libxkbcommon, + libcef, + makeWrapper, + nodejs, + # fetchurl, + ... +}: let + # cef-rs expects a specific directory layout + # Copied from https://github.com/NixOS/nixpkgs/pull/428206 because im lazy + cef-path = stdenv.mkDerivation { + pname = "cef-path"; + version = libcef.version; + dontUnpack = true; + installPhase = '' + mkdir -p "$out" + find ${libcef}/lib -type f -name "*" -exec cp {} $out/ \; + find ${libcef}/libexec -type f -name "*" -exec cp {} $out/ \; + cp -r ${libcef}/share/cef/* $out/ + mkdir -p "$out/include" + cp -r ${libcef}/include/* "$out/include/" + ''; + postFixup = '' + strip $out/*.so* + ''; + }; + # NOTE stremio downloads server.js into XDG_DATA_DIR. Packaging it is not required. + # I'm patching this because I don't enjoy stremio downloading code at runtime. + # This and the postPatch are not needed if you're okay with stremio downloading server.js at runtime + # Latest server.js version found at https://www.strem.io/updater/server/check + # server = fetchurl rec { + # pname = "stremio-server"; + # version = "4.20.11"; + # url = "https://dl.strem.io/server/v${version}/desktop/server.js"; + # hash = "sha256-2QCwUlusNTGqbOmOGjyKOx0bHaoGmn9vy93qViXx95E="; + # meta.license = lib.licenses.unfree; + # }; +in + rustPlatform.buildRustPackage (finalAttrs: { + name = "stremio-linux-shell"; + version = "1.0.0-beta.11"; + + src = fetchFromGitHub { + owner = "Stremio"; + repo = "stremio-linux-shell"; + tag = "v${finalAttrs.version}"; + hash = "sha256-FNAeur5esDqBoYlmjUO6jdi1eC83ynbLxbjH07QZ++E="; + }; + + cargoHash = "sha256-9/28BCG51jPnKXbbzzNp7KQLMkLEugFQfwszRR9kmUw="; + + # The build scripts tries to download CEF binaries by default. + # Probably overkill since setting CEF_PATH should skip downloading binaries. + buildFeatures = [ + "offline-build" + ]; + + buildInputs = [ + openssl + gtk3 + mpv + libcef + ]; + + nativeBuildInputs = [ + makeWrapper + pkg-config + ]; + + #postPatch = '' + # substituteInPlace ./src/config.rs \ + # --replace-fail \ + # 'let file = data_dir.join(SERVER_FILE);' \ + # 'let file = PathBuf::from(r"${server}");' + + # substituteInPlace ./src/server.rs \ + # --replace-fail \ + # 'let should_download = self.config.version() != Some(latest_version.clone());' \ + # 'let should_download = false;' + #''; + + postInstall = '' + mkdir -p $out/share/applications + mkdir -p $out/share/icons/hicolor/scalable/apps + + mv $out/bin/stremio-linux-shell $out/bin/stremio + cp $src/data/com.stremio.Stremio.desktop $out/share/applications/com.stremio.Stremio.desktop + cp $src/data/icons/com.stremio.Stremio.svg $out/share/icons/hicolor/scalable/apps/com.stremio.Stremio.svg + + + wrapProgram $out/bin/stremio \ + --prefix LD_LIBRARY_PATH : ${lib.makeLibraryPath [libappindicator libxkbcommon]} \ + --prefix PATH : ${lib.makeBinPath [nodejs]}''; + + env.CEF_PATH = cef-path; + + meta = { + mainProgram = "stremio"; + description = "Modern media center that gives you the freedom to watch everything you want"; + homepage = "https://www.stremio.com/"; + # (Server-side) 4.x versions of the web UI are closed-source + license = with lib.licenses; [ + gpl3Only + # server.js is unfree + # unfree + ]; + maintainers = with lib.maintainers; [ + griffi-gh + {name = "nuko";} + ]; + platforms = lib.platforms.linux; + }; + }) From fe2c22214e22aca0d81ed29cf7edad03f24ed550 Mon Sep 17 00:00:00 2001 From: muon Date: Thu, 25 Sep 2025 10:22:54 +0000 Subject: [PATCH 2/2] Add zellij config --- modules/home/desktop/i3.nix | 2 +- modules/home/terminal/development.nix | 87 +++++++++ modules/home/terminal/tools.nix | 5 + modules/home/terminal/zellij.kdl | 244 ++++++++++++++++++++++++++ 4 files changed, 337 insertions(+), 1 deletion(-) create mode 100644 modules/home/terminal/zellij.kdl diff --git a/modules/home/desktop/i3.nix b/modules/home/desktop/i3.nix index 0c2021a..693bb2e 100644 --- a/modules/home/desktop/i3.nix +++ b/modules/home/desktop/i3.nix @@ -28,7 +28,7 @@ ZWIND=$(wmctrl -l | grep "$ZSESH" || echo "") cd "$ZPATH" if [[ -z "$ZWIND" ]]; then - alacritty -T "$ZSESH" -e zsh -c "zellij -s $ZSESH -n compact || zellij a $ZSESH" + alacritty -T "$ZSESH" -e zsh -c "zellij -s $ZSESH -n dev || zellij a $ZSESH" else wmctrl -a "$ZSESH" fi diff --git a/modules/home/terminal/development.nix b/modules/home/terminal/development.nix index 3d3757f..b84b69d 100644 --- a/modules/home/terminal/development.nix +++ b/modules/home/terminal/development.nix @@ -33,6 +33,93 @@ enableZshIntegration = lib.mkIf config.mods.terminal.zsh.enable true; }; + programs.zellij = { + settings = { + default_mode._args = ["locked"]; + show_startup_tips._args = [false]; + show_release_notes._args = [false]; + }; + + extraConfig = builtins.readFile ./zellij.kdl; + + layouts = { + dev = { + layout = { + _children = [ + { + default_tab_template = { + _children = [ + { + pane = { + size = 1; + borderless = true; + plugin = { + location = "zellij:tab-bar"; + }; + }; + } + {"children" = {};} + { + pane = { + size = 2; + borderless = true; + plugin = { + location = "zellij:status-bar"; + }; + }; + } + ]; + }; + } + { + tab = { + _props = { + name = "Project"; + focus = true; + }; + _children = [ + { + pane = { + command = "nvim"; + }; + } + ]; + }; + } + { + tab = { + _props = { + name = "Run"; + }; + _children = [ + { + pane = { + command = "zsh"; + }; + } + ]; + }; + } + { + tab = { + _props = { + name = "Test"; + }; + _children = [ + { + pane = { + command = "zsh"; + }; + } + ]; + }; + } + ]; + }; + }; + }; + }; + home.sessionVariables.EDITOR = "hx"; programs.zsh.sessionVariables.EDITOR = "hx"; diff --git a/modules/home/terminal/tools.nix b/modules/home/terminal/tools.nix index 94f7f79..eb93300 100644 --- a/modules/home/terminal/tools.nix +++ b/modules/home/terminal/tools.nix @@ -56,6 +56,11 @@ in }; }; + services.clipmenu = { + enable = true; + launcher = "rofi"; + }; + home.packages = with pkgs; [ # libraries glow diff --git a/modules/home/terminal/zellij.kdl b/modules/home/terminal/zellij.kdl new file mode 100644 index 0000000..0115cec --- /dev/null +++ b/modules/home/terminal/zellij.kdl @@ -0,0 +1,244 @@ +keybinds clear-defaults=true { + unbind "Ctrl g" + locked { + bind "Alt Space" { SwitchToMode "normal"; } + } + pane { + bind "left" { MoveFocus "left"; } + bind "down" { MoveFocus "down"; } + bind "up" { MoveFocus "up"; } + bind "right" { MoveFocus "right"; } + bind "c" { SwitchToMode "renamepane"; PaneNameInput 0; } + bind "d" { NewPane "down"; SwitchToMode "locked"; } + bind "e" { TogglePaneEmbedOrFloating; SwitchToMode "locked"; } + bind "f" { ToggleFocusFullscreen; SwitchToMode "locked"; } + bind "h" { MoveFocus "left"; } + bind "i" { TogglePanePinned; SwitchToMode "locked"; } + bind "j" { MoveFocus "down"; } + bind "k" { MoveFocus "up"; } + bind "l" { MoveFocus "right"; } + bind "n" { NewPane; SwitchToMode "locked"; } + bind "p" { SwitchToMode "normal"; } + bind "r" { NewPane "right"; SwitchToMode "locked"; } + bind "s" { NewPane "stacked"; SwitchToMode "locked"; } + bind "w" { ToggleFloatingPanes; SwitchToMode "locked"; } + bind "x" { CloseFocus; SwitchToMode "locked"; } + bind "z" { TogglePaneFrames; SwitchToMode "locked"; } + bind "tab" { SwitchFocus; } + } + tab { + bind "left" { GoToPreviousTab; } + bind "down" { GoToNextTab; } + bind "up" { GoToPreviousTab; } + bind "right" { GoToNextTab; } + bind "1" { GoToTab 1; SwitchToMode "locked"; } + bind "2" { GoToTab 2; SwitchToMode "locked"; } + bind "3" { GoToTab 3; SwitchToMode "locked"; } + bind "4" { GoToTab 4; SwitchToMode "locked"; } + bind "5" { GoToTab 5; SwitchToMode "locked"; } + bind "6" { GoToTab 6; SwitchToMode "locked"; } + bind "7" { GoToTab 7; SwitchToMode "locked"; } + bind "8" { GoToTab 8; SwitchToMode "locked"; } + bind "9" { GoToTab 9; SwitchToMode "locked"; } + bind "[" { BreakPaneLeft; SwitchToMode "locked"; } + bind "]" { BreakPaneRight; SwitchToMode "locked"; } + bind "b" { BreakPane; SwitchToMode "locked"; } + bind "h" { GoToPreviousTab; } + bind "j" { GoToNextTab; } + bind "k" { GoToPreviousTab; } + bind "l" { GoToNextTab; } + bind "n" { NewTab; SwitchToMode "locked"; } + bind "r" { SwitchToMode "renametab"; TabNameInput 0; } + bind "s" { ToggleActiveSyncTab; SwitchToMode "locked"; } + bind "t" { SwitchToMode "normal"; } + bind "x" { CloseTab; SwitchToMode "locked"; } + bind "tab" { ToggleTab; } + } + resize { + bind "left" { Resize "Increase left"; } + bind "down" { Resize "Increase down"; } + bind "up" { Resize "Increase up"; } + bind "right" { Resize "Increase right"; } + bind "+" { Resize "Increase"; } + bind "-" { Resize "Decrease"; } + bind "=" { Resize "Increase"; } + bind "H" { Resize "Decrease left"; } + bind "J" { Resize "Decrease down"; } + bind "K" { Resize "Decrease up"; } + bind "L" { Resize "Decrease right"; } + bind "h" { Resize "Increase left"; } + bind "j" { Resize "Increase down"; } + bind "k" { Resize "Increase up"; } + bind "l" { Resize "Increase right"; } + bind "r" { SwitchToMode "normal"; } + } + move { + bind "left" { MovePane "left"; } + bind "down" { MovePane "down"; } + bind "up" { MovePane "up"; } + bind "right" { MovePane "right"; } + bind "h" { MovePane "left"; } + bind "j" { MovePane "down"; } + bind "k" { MovePane "up"; } + bind "l" { MovePane "right"; } + bind "m" { SwitchToMode "normal"; } + bind "n" { MovePane; } + bind "p" { MovePaneBackwards; } + bind "tab" { MovePane; } + } + scroll { + bind "Alt left" { MoveFocusOrTab "left"; SwitchToMode "locked"; } + bind "Alt down" { MoveFocus "down"; SwitchToMode "locked"; } + bind "Alt up" { MoveFocus "up"; SwitchToMode "locked"; } + bind "Alt right" { MoveFocusOrTab "right"; SwitchToMode "locked"; } + bind "e" { EditScrollback; SwitchToMode "locked"; } + bind "f" { SwitchToMode "entersearch"; SearchInput 0; } + bind "Alt h" { MoveFocusOrTab "left"; SwitchToMode "locked"; } + bind "Alt j" { MoveFocus "down"; SwitchToMode "locked"; } + bind "Alt k" { MoveFocus "up"; SwitchToMode "locked"; } + bind "Alt l" { MoveFocusOrTab "right"; SwitchToMode "locked"; } + bind "s" { SwitchToMode "normal"; } + } + search { + bind "c" { SearchToggleOption "CaseSensitivity"; } + bind "n" { Search "down"; } + bind "o" { SearchToggleOption "WholeWord"; } + bind "p" { Search "up"; } + bind "w" { SearchToggleOption "Wrap"; } + } + session { + bind "a" { + LaunchOrFocusPlugin "zellij:about" { + floating true + move_to_focused_tab true + } + SwitchToMode "locked" + } + bind "c" { + LaunchOrFocusPlugin "configuration" { + floating true + move_to_focused_tab true + } + SwitchToMode "locked" + } + bind "d" { Detach; } + bind "o" { SwitchToMode "normal"; } + bind "p" { + LaunchOrFocusPlugin "plugin-manager" { + floating true + move_to_focused_tab true + } + SwitchToMode "locked" + } + bind "s" { + LaunchOrFocusPlugin "zellij:share" { + floating true + move_to_focused_tab true + } + SwitchToMode "locked" + } + bind "w" { + LaunchOrFocusPlugin "session-manager" { + floating true + move_to_focused_tab true + } + SwitchToMode "locked" + } + } + shared_among "normal" "locked" { + bind "Alt left" { MoveFocusOrTab "left"; } + bind "Alt down" { MoveFocus "down"; } + bind "Alt up" { MoveFocus "up"; } + bind "Alt right" { MoveFocusOrTab "right"; } + bind "Alt +" { Resize "Increase"; } + bind "Alt -" { Resize "Decrease"; } + bind "Alt =" { Resize "Increase"; } + bind "Alt [" { PreviousSwapLayout; } + bind "Alt ]" { NextSwapLayout; } + bind "Alt f" { ToggleFloatingPanes; } + bind "Alt h" { MoveFocusOrTab "left"; } + bind "Alt i" { MoveTab "left"; } + bind "Alt j" { MoveFocus "down"; } + bind "Alt k" { MoveFocus "up"; } + bind "Alt l" { MoveFocusOrTab "right"; } + bind "Alt n" { NewPane; } + bind "Alt o" { MoveTab "right"; } + bind "Alt p" { TogglePaneInGroup; } + bind "Alt Shift p" { ToggleGroupMarking; } + } + shared_except "locked" "renametab" "renamepane" { + bind "Alt Space" { SwitchToMode "locked"; } + bind "Alt q" { Quit; } + } + shared_except "locked" "entersearch" { + bind "enter" { SwitchToMode "locked"; } + } + shared_except "locked" "entersearch" "renametab" "renamepane" { + bind "esc" { SwitchToMode "locked"; } + } + shared_except "locked" "entersearch" "renametab" "renamepane" "move" { + bind "m" { SwitchToMode "move"; } + } + shared_except "locked" "entersearch" "search" "renametab" "renamepane" "session" { + bind "o" { SwitchToMode "session"; } + } + shared_except "locked" "tab" "entersearch" "renametab" "renamepane" { + bind "t" { SwitchToMode "tab"; } + } + shared_among "normal" "resize" "tab" "scroll" "prompt" "tmux" { + bind "p" { SwitchToMode "pane"; } + } + shared_among "normal" "resize" "search" "move" "prompt" "tmux" { + bind "s" { SwitchToMode "scroll"; } + } + shared_except "locked" "resize" "pane" "tab" "entersearch" "renametab" "renamepane" { + bind "r" { SwitchToMode "resize"; } + } + shared_among "scroll" "search" { + bind "PageDown" { PageScrollDown; } + bind "PageUp" { PageScrollUp; } + bind "left" { PageScrollUp; } + bind "down" { ScrollDown; } + bind "up" { ScrollUp; } + bind "right" { PageScrollDown; } + bind "Ctrl b" { PageScrollUp; } + bind "Ctrl c" { ScrollToBottom; SwitchToMode "locked"; } + bind "d" { HalfPageScrollDown; } + bind "Ctrl f" { PageScrollDown; } + bind "h" { PageScrollUp; } + bind "j" { ScrollDown; } + bind "k" { ScrollUp; } + bind "l" { PageScrollDown; } + bind "u" { HalfPageScrollUp; } + } + entersearch { + bind "Ctrl c" { SwitchToMode "scroll"; } + bind "esc" { SwitchToMode "scroll"; } + bind "enter" { SwitchToMode "search"; } + } + renametab { + bind "esc" { UndoRenameTab; SwitchToMode "tab"; } + } + shared_among "renametab" "renamepane" { + bind "Ctrl c" { SwitchToMode "locked"; } + } + renamepane { + bind "esc" { UndoRenamePane; SwitchToMode "pane"; } + } +} +plugins { + about location="zellij:about" + compact-bar location="zellij:compact-bar" + configuration location="zellij:configuration" + filepicker location="zellij:strider" { + cwd "/" + } + plugin-manager location="zellij:plugin-manager" + session-manager location="zellij:session-manager" + status-bar location="zellij:status-bar" + strider location="zellij:strider" + tab-bar location="zellij:tab-bar" + welcome-screen location="zellij:session-manager" { + welcome_screen true + } +}