summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSaumit <justsaumit@protonmail.com>2026-01-31 21:21:10 +0530
committerSaumit <justsaumit@protonmail.com>2026-01-31 21:21:10 +0530
commit07fd93da1f2377d6fdc9e6dd59ea56db9a04bcc4 (patch)
tree736b1914db16942e7065d86d5907b32a87d24377
parent4f3b467b9d33d0da2284da74a484f23750f1ea11 (diff)
stow: Using GNU Stow
-rw-r--r--.gitignore2
-rw-r--r--stow/hyprland/.config/hypr/hyprland-base.conf341
-rw-r--r--stow/hyprland/.config/hypr/hyprland.conf (renamed from .config/hypr/hyprland.conf)122
-rw-r--r--stow/nvim/.config/nvim/init.lua (renamed from .config/nvim/init.lua)0
-rw-r--r--stow/nvim/.config/nvim/lua/justsaumit/bufferline-config.lua (renamed from .config/nvim/lua/justsaumit/bufferline-config.lua)0
-rw-r--r--stow/nvim/.config/nvim/lua/justsaumit/cmp-config.lua (renamed from .config/nvim/lua/justsaumit/cmp-config.lua)0
-rw-r--r--stow/nvim/.config/nvim/lua/justsaumit/colorizer-config.lua (renamed from .config/nvim/lua/justsaumit/colorizer-config.lua)0
-rw-r--r--stow/nvim/.config/nvim/lua/justsaumit/colorscheme.lua (renamed from .config/nvim/lua/justsaumit/colorscheme.lua)0
-rw-r--r--stow/nvim/.config/nvim/lua/justsaumit/keymaps.lua (renamed from .config/nvim/lua/justsaumit/keymaps.lua)0
-rw-r--r--stow/nvim/.config/nvim/lua/justsaumit/lastplace-config.lua (renamed from .config/nvim/lua/justsaumit/lastplace-config.lua)0
-rw-r--r--stow/nvim/.config/nvim/lua/justsaumit/lsp-config.lua (renamed from .config/nvim/lua/justsaumit/lsp-config.lua)0
-rw-r--r--stow/nvim/.config/nvim/lua/justsaumit/lspsaga-config.lua (renamed from .config/nvim/lua/justsaumit/lspsaga-config.lua)0
-rw-r--r--stow/nvim/.config/nvim/lua/justsaumit/lualine-config.lua (renamed from .config/nvim/lua/justsaumit/lualine-config.lua)0
-rw-r--r--stow/nvim/.config/nvim/lua/justsaumit/mason.lua (renamed from .config/nvim/lua/justsaumit/mason.lua)0
-rw-r--r--stow/nvim/.config/nvim/lua/justsaumit/nvim-comment-config.lua (renamed from .config/nvim/lua/justsaumit/nvim-comment-config.lua)0
-rw-r--r--stow/nvim/.config/nvim/lua/justsaumit/nvim-tree-config.lua (renamed from .config/nvim/lua/justsaumit/nvim-tree-config.lua)0
-rw-r--r--stow/nvim/.config/nvim/lua/justsaumit/options.lua (renamed from .config/nvim/lua/justsaumit/options.lua)0
-rw-r--r--stow/nvim/.config/nvim/lua/justsaumit/plugins.lua (renamed from .config/nvim/lua/justsaumit/plugins.lua)0
-rw-r--r--stow/nvim/.config/nvim/lua/justsaumit/telescope-config.lua (renamed from .config/nvim/lua/justsaumit/telescope-config.lua)0
-rw-r--r--stow/nvim/.config/nvim/lua/justsaumit/toggleterm-config.lua (renamed from .config/nvim/lua/justsaumit/toggleterm-config.lua)0
-rw-r--r--stow/nvim/.config/nvim/lua/justsaumit/treesitter-config.lua (renamed from .config/nvim/lua/justsaumit/treesitter-config.lua)0
-rw-r--r--stow/nvim/.config/nvim/lua/justsaumit/which-key-config.lua (renamed from .config/nvim/lua/justsaumit/which-key-config.lua)0
-rw-r--r--stow/nvim/.config/nvim/plugin/packer_compiled.lua (renamed from .config/nvim/plugin/packer_compiled.lua)0
-rw-r--r--stow/vim/.config/vim/vimrc (renamed from .config/vim/vimrc)0
-rw-r--r--stow/vscode/.config/Code/User/keybindings.json7
-rw-r--r--stow/vscode/.config/Code/User/settings.json87
-rw-r--r--stow/zsh/.zshrc (renamed from .config/zsh/.zshrc)28
-rw-r--r--tmux/tmux.conf (renamed from .config/tmux/tmux.conf)0
28 files changed, 566 insertions, 21 deletions
diff --git a/.gitignore b/.gitignore
new file mode 100644
index 0000000..acb92f8
--- /dev/null
+++ b/.gitignore
@@ -0,0 +1,2 @@
+stow/nvim/.config/nvim/lua/secrets.lua
+stow/zsh/.zsh_secrets
diff --git a/stow/hyprland/.config/hypr/hyprland-base.conf b/stow/hyprland/.config/hypr/hyprland-base.conf
new file mode 100644
index 0000000..98ac099
--- /dev/null
+++ b/stow/hyprland/.config/hypr/hyprland-base.conf
@@ -0,0 +1,341 @@
+# This is an example Hyprland config file.
+# Refer to the wiki for more information.
+# https://wiki.hypr.land/Configuring/
+
+# Please note not all available settings / options are set here.
+# For a full list, see the wiki
+
+# You can split this configuration into multiple files
+# Create your files separately and then link them to this file like this:
+# source = ~/.config/hypr/myColors.conf
+
+
+################
+### MONITORS ###
+################
+
+# See https://wiki.hypr.land/Configuring/Monitors/
+monitor=,preferred,auto,auto
+
+
+###################
+### MY PROGRAMS ###
+###################
+
+# See https://wiki.hypr.land/Configuring/Keywords/
+
+# Set programs that you use
+$terminal = kitty
+$fileManager = dolphin
+$menu = hyprlauncher
+
+
+#################
+### AUTOSTART ###
+#################
+
+# Autostart necessary processes (like notifications daemons, status bars, etc.)
+# Or execute your favorite apps at launch like this:
+
+# exec-once = $terminal
+# exec-once = nm-applet &
+# exec-once = waybar & hyprpaper & firefox
+
+
+#############################
+### ENVIRONMENT VARIABLES ###
+#############################
+
+# See https://wiki.hypr.land/Configuring/Environment-variables/
+
+env = XCURSOR_SIZE,24
+env = HYPRCURSOR_SIZE,24
+
+
+###################
+### PERMISSIONS ###
+###################
+
+# See https://wiki.hypr.land/Configuring/Permissions/
+# Please note permission changes here require a Hyprland restart and are not applied on-the-fly
+# for security reasons
+
+# ecosystem {
+# enforce_permissions = 1
+# }
+
+# permission = /usr/(bin|local/bin)/grim, screencopy, allow
+# permission = /usr/(lib|libexec|lib64)/xdg-desktop-portal-hyprland, screencopy, allow
+# permission = /usr/(bin|local/bin)/hyprpm, plugin, allow
+
+
+#####################
+### LOOK AND FEEL ###
+#####################
+
+# Refer to https://wiki.hypr.land/Configuring/Variables/
+
+# https://wiki.hypr.land/Configuring/Variables/#general
+general {
+ gaps_in = 5
+ gaps_out = 20
+
+ border_size = 2
+
+ # https://wiki.hypr.land/Configuring/Variables/#variable-types for info about colors
+ col.active_border = rgba(33ccffee) rgba(00ff99ee) 45deg
+ col.inactive_border = rgba(595959aa)
+
+ # Set to true enable resizing windows by clicking and dragging on borders and gaps
+ resize_on_border = false
+
+ # Please see https://wiki.hypr.land/Configuring/Tearing/ before you turn this on
+ allow_tearing = false
+
+ layout = dwindle
+}
+
+# https://wiki.hypr.land/Configuring/Variables/#decoration
+decoration {
+ rounding = 10
+ rounding_power = 2
+
+ # Change transparency of focused and unfocused windows
+ active_opacity = 1.0
+ inactive_opacity = 1.0
+
+ shadow {
+ enabled = true
+ range = 4
+ render_power = 3
+ color = rgba(1a1a1aee)
+ }
+
+ # https://wiki.hypr.land/Configuring/Variables/#blur
+ blur {
+ enabled = true
+ size = 3
+ passes = 1
+
+ vibrancy = 0.1696
+ }
+}
+
+# https://wiki.hypr.land/Configuring/Variables/#animations
+animations {
+ enabled = yes, please :)
+
+ # Default curves, see https://wiki.hypr.land/Configuring/Animations/#curves
+ # NAME, X0, Y0, X1, Y1
+ bezier = easeOutQuint, 0.23, 1, 0.32, 1
+ bezier = easeInOutCubic, 0.65, 0.05, 0.36, 1
+ bezier = linear, 0, 0, 1, 1
+ bezier = almostLinear, 0.5, 0.5, 0.75, 1
+ bezier = quick, 0.15, 0, 0.1, 1
+
+ # Default animations, see https://wiki.hypr.land/Configuring/Animations/
+ # NAME, ONOFF, SPEED, CURVE, [STYLE]
+ animation = global, 1, 10, default
+ animation = border, 1, 5.39, easeOutQuint
+ animation = windows, 1, 4.79, easeOutQuint
+ animation = windowsIn, 1, 4.1, easeOutQuint, popin 87%
+ animation = windowsOut, 1, 1.49, linear, popin 87%
+ animation = fadeIn, 1, 1.73, almostLinear
+ animation = fadeOut, 1, 1.46, almostLinear
+ animation = fade, 1, 3.03, quick
+ animation = layers, 1, 3.81, easeOutQuint
+ animation = layersIn, 1, 4, easeOutQuint, fade
+ animation = layersOut, 1, 1.5, linear, fade
+ animation = fadeLayersIn, 1, 1.79, almostLinear
+ animation = fadeLayersOut, 1, 1.39, almostLinear
+ animation = workspaces, 1, 1.94, almostLinear, fade
+ animation = workspacesIn, 1, 1.21, almostLinear, fade
+ animation = workspacesOut, 1, 1.94, almostLinear, fade
+ animation = zoomFactor, 1, 7, quick
+}
+
+# Ref https://wiki.hypr.land/Configuring/Workspace-Rules/
+# "Smart gaps" / "No gaps when only"
+# uncomment all if you wish to use that.
+# workspace = w[tv1], gapsout:0, gapsin:0
+# workspace = f[1], gapsout:0, gapsin:0
+# windowrule {
+# name = no-gaps-wtv1
+# match:float = false
+# match:workspace = w[tv1]
+#
+# border_size = 0
+# rounding = 0
+# }
+#
+# windowrule {
+# name = no-gaps-f1
+# match:float = false
+# match:workspace = f[1]
+#
+# border_size = 0
+# rounding = 0
+# }
+
+# See https://wiki.hypr.land/Configuring/Dwindle-Layout/ for more
+dwindle {
+ pseudotile = true # Master switch for pseudotiling. Enabling is bound to mainMod + P in the keybinds section below
+ preserve_split = true # You probably want this
+}
+
+# See https://wiki.hypr.land/Configuring/Master-Layout/ for more
+master {
+ new_status = master
+}
+
+# https://wiki.hypr.land/Configuring/Variables/#misc
+misc {
+ force_default_wallpaper = -1 # Set to 0 or 1 to disable the anime mascot wallpapers
+ disable_hyprland_logo = false # If true disables the random hyprland logo / anime girl background. :(
+}
+
+
+#############
+### INPUT ###
+#############
+
+# https://wiki.hypr.land/Configuring/Variables/#input
+input {
+ kb_layout = us
+ kb_variant =
+ kb_model =
+ kb_options =
+ kb_rules =
+
+ follow_mouse = 1
+
+ sensitivity = 0 # -1.0 - 1.0, 0 means no modification.
+
+ touchpad {
+ natural_scroll = false
+ }
+}
+
+# See https://wiki.hypr.land/Configuring/Gestures
+gesture = 3, horizontal, workspace
+
+# Example per-device config
+# See https://wiki.hypr.land/Configuring/Keywords/#per-device-input-configs for more
+device {
+ name = epic-mouse-v1
+ sensitivity = -0.5
+}
+
+
+###################
+### KEYBINDINGS ###
+###################
+
+# See https://wiki.hypr.land/Configuring/Keywords/
+$mainMod = SUPER # Sets "Windows" key as main modifier
+
+# Example binds, see https://wiki.hypr.land/Configuring/Binds/ for more
+bind = $mainMod, Q, exec, $terminal
+bind = $mainMod, C, killactive,
+bind = $mainMod, M, exec, command -v hyprshutdown >/dev/null 2>&1 && hyprshutdown || hyprctl dispatch exit
+bind = $mainMod, E, exec, $fileManager
+bind = $mainMod, V, togglefloating,
+bind = $mainMod, R, exec, $menu
+bind = $mainMod, P, pseudo, # dwindle
+bind = $mainMod, J, togglesplit, # dwindle
+
+# Move focus with mainMod + arrow keys
+bind = $mainMod, left, movefocus, l
+bind = $mainMod, right, movefocus, r
+bind = $mainMod, up, movefocus, u
+bind = $mainMod, down, movefocus, d
+
+# Switch workspaces with mainMod + [0-9]
+bind = $mainMod, 1, workspace, 1
+bind = $mainMod, 2, workspace, 2
+bind = $mainMod, 3, workspace, 3
+bind = $mainMod, 4, workspace, 4
+bind = $mainMod, 5, workspace, 5
+bind = $mainMod, 6, workspace, 6
+bind = $mainMod, 7, workspace, 7
+bind = $mainMod, 8, workspace, 8
+bind = $mainMod, 9, workspace, 9
+bind = $mainMod, 0, workspace, 10
+
+# Move active window to a workspace with mainMod + SHIFT + [0-9]
+bind = $mainMod SHIFT, 1, movetoworkspace, 1
+bind = $mainMod SHIFT, 2, movetoworkspace, 2
+bind = $mainMod SHIFT, 3, movetoworkspace, 3
+bind = $mainMod SHIFT, 4, movetoworkspace, 4
+bind = $mainMod SHIFT, 5, movetoworkspace, 5
+bind = $mainMod SHIFT, 6, movetoworkspace, 6
+bind = $mainMod SHIFT, 7, movetoworkspace, 7
+bind = $mainMod SHIFT, 8, movetoworkspace, 8
+bind = $mainMod SHIFT, 9, movetoworkspace, 9
+bind = $mainMod SHIFT, 0, movetoworkspace, 10
+
+# Example special workspace (scratchpad)
+bind = $mainMod, S, togglespecialworkspace, magic
+bind = $mainMod SHIFT, S, movetoworkspace, special:magic
+
+# Scroll through existing workspaces with mainMod + scroll
+bind = $mainMod, mouse_down, workspace, e+1
+bind = $mainMod, mouse_up, workspace, e-1
+
+# Move/resize windows with mainMod + LMB/RMB and dragging
+bindm = $mainMod, mouse:272, movewindow
+bindm = $mainMod, mouse:273, resizewindow
+
+# Laptop multimedia keys for volume and LCD brightness
+bindel = ,XF86AudioRaiseVolume, exec, wpctl set-volume -l 1 @DEFAULT_AUDIO_SINK@ 5%+
+bindel = ,XF86AudioLowerVolume, exec, wpctl set-volume @DEFAULT_AUDIO_SINK@ 5%-
+bindel = ,XF86AudioMute, exec, wpctl set-mute @DEFAULT_AUDIO_SINK@ toggle
+bindel = ,XF86AudioMicMute, exec, wpctl set-mute @DEFAULT_AUDIO_SOURCE@ toggle
+bindel = ,XF86MonBrightnessUp, exec, brightnessctl -e4 -n2 set 5%+
+bindel = ,XF86MonBrightnessDown, exec, brightnessctl -e4 -n2 set 5%-
+
+# Requires playerctl
+bindl = , XF86AudioNext, exec, playerctl next
+bindl = , XF86AudioPause, exec, playerctl play-pause
+bindl = , XF86AudioPlay, exec, playerctl play-pause
+bindl = , XF86AudioPrev, exec, playerctl previous
+
+##############################
+### WINDOWS AND WORKSPACES ###
+##############################
+
+# See https://wiki.hypr.land/Configuring/Window-Rules/ for more
+# See https://wiki.hypr.land/Configuring/Workspace-Rules/ for workspace rules
+
+# Example windowrules that are useful
+
+windowrule {
+ # Ignore maximize requests from all apps. You'll probably like this.
+ name = suppress-maximize-events
+ match:class = .*
+
+ suppress_event = maximize
+}
+
+windowrule {
+ # Fix some dragging issues with XWayland
+ name = fix-xwayland-drags
+ match:class = ^$
+ match:title = ^$
+ match:xwayland = true
+ match:float = true
+ match:fullscreen = false
+ match:pin = false
+
+ no_focus = true
+}
+
+# Hyprland-run windowrule
+windowrule {
+ name = move-hyprland-run
+
+ match:class = hyprland-run
+
+ move = 20 monitor_h-120
+ float = yes
+}
diff --git a/.config/hypr/hyprland.conf b/stow/hyprland/.config/hypr/hyprland.conf
index adc9e77..f5c2b61 100644
--- a/.config/hypr/hyprland.conf
+++ b/stow/hyprland/.config/hypr/hyprland.conf
@@ -29,7 +29,7 @@ monitor=HDMI-A-1,1920x1080@144,0x0,1.00,transform,0,mirror,eDP-1
# exec-once = $terminal
# exec-once = nm-applet &
# exec-once = waybar & hyprpaper & firefox
-exec-once = waybar & dunst & wpaperd & suspend.sh & nextcloud & nm-applet & blueman-applet & notion-app & memospot
+exec-once = waybar & dunst & wpaperd & suspend.sh & nm-applet & blueman-applet & notion-app & memospot
#exec-once = dbus-update-activation-environment --systemd DISPLAY WAYLAND_DISPLAY
#exec-once = dbus-update-activation-environment --systemd WAYLAND_DISPLAY && XDG_CURRENT_DESKTOP=Hyprland
exec-once = systemctl --user import-environment DISPLAY WAYLAND_DISPLAY XDG_CURRENT_DESKTOP
@@ -46,11 +46,16 @@ exec-once = xhost +SI:localuser:root
env = XCURSOR_SIZE,24
env = HYPRCURSOR_SIZE,24
+env = XDG_SESSION_TYPE,wayland
+env = WLR_NO_HARDWARE_CURSORS,1
+
#env = LIBVA_DRIVER_NAME,nvidia
env = XDG_SESSION_TYPE,wayland
#env = GBM_BACKEND,nvidia-drm
#env = __GLX_VENDOR_LIBRARY_NAME,nvidia
env = WLR_NO_HARDWARE_CURSORS,1
+env = WLR_DRM_NO_MODIFIERS,1
+env = WLR_RENDERER,vulkan
###################
### PERMISSIONS ###
@@ -101,7 +106,6 @@ master {
new_on_top=false
# no_gaps_when_only=true // config removed add through Workspace rules
orientation=left
- inherit_fullscreen=true
}
# https://wiki.hypr.land/Configuring/Variables/#decoration
@@ -197,10 +201,16 @@ input {
sensitivity = 0 # -1.0 - 1.0, 0 means no modification.
+ scroll_factor = 1.0
+ scroll_method = 2fg
+
touchpad {
natural_scroll = true
+ scroll_factor = 1.0
+ tap-to-click = yes
+ tap-and-drag = yes
disable_while_typing = false
- tap-to-click=yes
+ clickfinger_behavior = yes
}
}
@@ -224,17 +234,34 @@ binds {
# sensitivity = -0.5
#}
-$TOUCHPAD_ENABLED = true
+# $TOUCHPAD_ENABLED = true
+# device {
+# name = pnp0c50:0d-06cb:cebd-touchpad
+# enabled = $TOUCHPAD_ENABLED
+# scroll_factor = 1.0
+# natural_scroll = false
+# }
+
+# $KEYBOARD_ENABLED = true
+# device {
+# name = at-translated-set-2-keyboard
+# enabled = $KEYBOARD_ENABLED
+# }
device {
name = pnp0c50:0d-06cb:cebd-touchpad
- enabled = $TOUCHPAD_ENABLED
+ enabled = true
+ accel_profile = flat
+ tap-to-click = true
+ tap-and-drag = true
+ drag_lock = true
+ middle_button_emulation = false
}
-$KEYBOARD_ENABLED = true
-device {
- name = at-translated-set-2-keyboard
- enabled = $KEYBOARD_ENABLED
-}
+# $KEYBOARD_ENABLED = true
+# device {
+# name = at-translated-set-2-keyboard
+# enabled = $KEYBOARD_ENABLED
+# }
###################
### KEYBINDINGS ###
@@ -278,7 +305,6 @@ bind = $MOD ALT, M, exec, toggle-touchpad-hypr
# Launch Brave
bind = $MOD, Q, exec, brave
bind = $MOD CTRL, Q, exec, brave --incognito
-bind = $MOD ALT, Q, exec, brave --tor
bind = $MOD SHIFT, Z, exec, zen-browser
# Launch wa
bind = $MOD SHIFT, W, exec, whatsapp-nativefier --no-sandbox
@@ -357,6 +383,7 @@ bind = $MOD, F9, exec, blueman-manager
bind = $MOD, Return,layoutmsg, swapwithmaster
#fullscreen layout toggle
+bind = $MOD, H, togglesplit
bind= $MOD, U, fullscreen
# Move focus with MOD + arrow keys
@@ -438,21 +465,65 @@ submap=reset
# Example windowrules that are useful
# Suppress maximize events
-windowrule = suppressevent maximize, class:.*
+windowrule = suppress_event maximize, match:class .*
+
# Fix some dragging issues with XWayland
-windowrule = nofocus, class:^$,title:^$,xwayland:1,floating:1,fullscreen:0,pinned:0
+windowrule = no_focus on, match:class ^$, match:title ^$, match:xwayland 1, match:float 1, match:fullscreen 0, match:pin 0
# Move Hyprland-run
-windowrule = move 20 monitor_h-120,class:hyprland-run
-windowrule = float,class:hyprland-run
+windowrule = move 20 (monitor_h-120), match:class hyprland-run
+windowrule = float on, match:class hyprland-run
+
+# windowrule {
+# # Ignore maximize requests from all apps. You'll probably like this.
+# name = suppress-maximize-events
+# match:class = .*
+# suppress_event = maximize
+# }
+
+# windowrule {
+# # Fix some dragging issues with XWayland
+# name = fix-xwayland-drags
+# match:class = ^$
+# match:title = ^$
+# match:xwayland = true
+# match:float = true
+# match:fullscreen = false
+# match:pin = false
+
+# no_focus = true
+# }
+
+# # Hyprland-run windowrule
+# windowrule {
+# name = move-hyprland-run
+
+# match:class = hyprland-run
+
+# move = 20 monitor_h-120
+# float = yes
+# }
# Spotify to workspace 9
-windowrule = workspace 9,class:^(spotify)$
+windowrule = workspace 9, match:class ^(spotify)$
+
# Obsidian opacity
-windowrule = opacity 1.0 override 1.0 override,class:^(obsidian)$
+windowrule = opacity 1.0 override 1.0 override, match:class ^(obsidian)$
+windowrule = opacity 1.0 override 1.0 override, match:class ^(code)$
+windowrule = opacity 1.0 override 1.0 override, match:class ^(brave)$
+windowrule = opacity 1.0 override 1.0 override, match:class ^(zen)$
+
# MPV player floating -> spawn bottomright
-windowrule = pin,float,move 1232 615,size 687 467,class:mpv
+# windowrule {
+# name = mpv-floating-bottomright
+# match:class = mpv
+
+# pin = on
+# float = on
+# move = 1232 615
+# size = 687 467
+# }
# "Smart gaps" / "No gaps when only"
workspace = w[t1], gapsout:0, gapsin:0
@@ -464,6 +535,17 @@ windowrulev2 = bordersize 0, floating:0, onworkspace:w[tg1]
windowrulev2 = rounding 0, floating:0, onworkspace:w[tg1]
windowrulev2 = bordersize 0, floating:0, onworkspace:f[1]
windowrulev2 = rounding 0, floating:0, onworkspace:f[1]
-
-# Fix some dragging issues with XWayland
+# fix some dragging issues with xwayland
windowrulev2 = nofocus,class:^$,title:^$,xwayland:1,floating:1,fullscreen:0,pinned:0
+
+# See https://wiki.hypr.land/Useful-Utilities/Screen-Sharing/#xwayland
+windowrule {
+ name = xwayland-video-bridge-fixes
+ match:class = xwaylandvideobridge
+ no_initial_focus = on
+ no_focus = on
+ no_anim = on
+ no_blur = on
+ max_size = 1 1
+ opacity = 0.0
+}
diff --git a/.config/nvim/init.lua b/stow/nvim/.config/nvim/init.lua
index 11ab069..11ab069 100644
--- a/.config/nvim/init.lua
+++ b/stow/nvim/.config/nvim/init.lua
diff --git a/.config/nvim/lua/justsaumit/bufferline-config.lua b/stow/nvim/.config/nvim/lua/justsaumit/bufferline-config.lua
index 879c669..879c669 100644
--- a/.config/nvim/lua/justsaumit/bufferline-config.lua
+++ b/stow/nvim/.config/nvim/lua/justsaumit/bufferline-config.lua
diff --git a/.config/nvim/lua/justsaumit/cmp-config.lua b/stow/nvim/.config/nvim/lua/justsaumit/cmp-config.lua
index 7e29155..7e29155 100644
--- a/.config/nvim/lua/justsaumit/cmp-config.lua
+++ b/stow/nvim/.config/nvim/lua/justsaumit/cmp-config.lua
diff --git a/.config/nvim/lua/justsaumit/colorizer-config.lua b/stow/nvim/.config/nvim/lua/justsaumit/colorizer-config.lua
index 569021d..569021d 100644
--- a/.config/nvim/lua/justsaumit/colorizer-config.lua
+++ b/stow/nvim/.config/nvim/lua/justsaumit/colorizer-config.lua
diff --git a/.config/nvim/lua/justsaumit/colorscheme.lua b/stow/nvim/.config/nvim/lua/justsaumit/colorscheme.lua
index 67c166f..67c166f 100644
--- a/.config/nvim/lua/justsaumit/colorscheme.lua
+++ b/stow/nvim/.config/nvim/lua/justsaumit/colorscheme.lua
diff --git a/.config/nvim/lua/justsaumit/keymaps.lua b/stow/nvim/.config/nvim/lua/justsaumit/keymaps.lua
index 582113c..582113c 100644
--- a/.config/nvim/lua/justsaumit/keymaps.lua
+++ b/stow/nvim/.config/nvim/lua/justsaumit/keymaps.lua
diff --git a/.config/nvim/lua/justsaumit/lastplace-config.lua b/stow/nvim/.config/nvim/lua/justsaumit/lastplace-config.lua
index 4fa6a83..4fa6a83 100644
--- a/.config/nvim/lua/justsaumit/lastplace-config.lua
+++ b/stow/nvim/.config/nvim/lua/justsaumit/lastplace-config.lua
diff --git a/.config/nvim/lua/justsaumit/lsp-config.lua b/stow/nvim/.config/nvim/lua/justsaumit/lsp-config.lua
index 2c0d746..2c0d746 100644
--- a/.config/nvim/lua/justsaumit/lsp-config.lua
+++ b/stow/nvim/.config/nvim/lua/justsaumit/lsp-config.lua
diff --git a/.config/nvim/lua/justsaumit/lspsaga-config.lua b/stow/nvim/.config/nvim/lua/justsaumit/lspsaga-config.lua
index 70d3d79..70d3d79 100644
--- a/.config/nvim/lua/justsaumit/lspsaga-config.lua
+++ b/stow/nvim/.config/nvim/lua/justsaumit/lspsaga-config.lua
diff --git a/.config/nvim/lua/justsaumit/lualine-config.lua b/stow/nvim/.config/nvim/lua/justsaumit/lualine-config.lua
index 56c426a..56c426a 100644
--- a/.config/nvim/lua/justsaumit/lualine-config.lua
+++ b/stow/nvim/.config/nvim/lua/justsaumit/lualine-config.lua
diff --git a/.config/nvim/lua/justsaumit/mason.lua b/stow/nvim/.config/nvim/lua/justsaumit/mason.lua
index d651810..d651810 100644
--- a/.config/nvim/lua/justsaumit/mason.lua
+++ b/stow/nvim/.config/nvim/lua/justsaumit/mason.lua
diff --git a/.config/nvim/lua/justsaumit/nvim-comment-config.lua b/stow/nvim/.config/nvim/lua/justsaumit/nvim-comment-config.lua
index d71ce14..d71ce14 100644
--- a/.config/nvim/lua/justsaumit/nvim-comment-config.lua
+++ b/stow/nvim/.config/nvim/lua/justsaumit/nvim-comment-config.lua
diff --git a/.config/nvim/lua/justsaumit/nvim-tree-config.lua b/stow/nvim/.config/nvim/lua/justsaumit/nvim-tree-config.lua
index b499f91..b499f91 100644
--- a/.config/nvim/lua/justsaumit/nvim-tree-config.lua
+++ b/stow/nvim/.config/nvim/lua/justsaumit/nvim-tree-config.lua
diff --git a/.config/nvim/lua/justsaumit/options.lua b/stow/nvim/.config/nvim/lua/justsaumit/options.lua
index 4eae867..4eae867 100644
--- a/.config/nvim/lua/justsaumit/options.lua
+++ b/stow/nvim/.config/nvim/lua/justsaumit/options.lua
diff --git a/.config/nvim/lua/justsaumit/plugins.lua b/stow/nvim/.config/nvim/lua/justsaumit/plugins.lua
index 460d6f3..460d6f3 100644
--- a/.config/nvim/lua/justsaumit/plugins.lua
+++ b/stow/nvim/.config/nvim/lua/justsaumit/plugins.lua
diff --git a/.config/nvim/lua/justsaumit/telescope-config.lua b/stow/nvim/.config/nvim/lua/justsaumit/telescope-config.lua
index 534e663..534e663 100644
--- a/.config/nvim/lua/justsaumit/telescope-config.lua
+++ b/stow/nvim/.config/nvim/lua/justsaumit/telescope-config.lua
diff --git a/.config/nvim/lua/justsaumit/toggleterm-config.lua b/stow/nvim/.config/nvim/lua/justsaumit/toggleterm-config.lua
index b1579cd..b1579cd 100644
--- a/.config/nvim/lua/justsaumit/toggleterm-config.lua
+++ b/stow/nvim/.config/nvim/lua/justsaumit/toggleterm-config.lua
diff --git a/.config/nvim/lua/justsaumit/treesitter-config.lua b/stow/nvim/.config/nvim/lua/justsaumit/treesitter-config.lua
index c64e659..c64e659 100644
--- a/.config/nvim/lua/justsaumit/treesitter-config.lua
+++ b/stow/nvim/.config/nvim/lua/justsaumit/treesitter-config.lua
diff --git a/.config/nvim/lua/justsaumit/which-key-config.lua b/stow/nvim/.config/nvim/lua/justsaumit/which-key-config.lua
index 93a42fa..93a42fa 100644
--- a/.config/nvim/lua/justsaumit/which-key-config.lua
+++ b/stow/nvim/.config/nvim/lua/justsaumit/which-key-config.lua
diff --git a/.config/nvim/plugin/packer_compiled.lua b/stow/nvim/.config/nvim/plugin/packer_compiled.lua
index f5e9107..f5e9107 100644
--- a/.config/nvim/plugin/packer_compiled.lua
+++ b/stow/nvim/.config/nvim/plugin/packer_compiled.lua
diff --git a/.config/vim/vimrc b/stow/vim/.config/vim/vimrc
index 0832263..0832263 100644
--- a/.config/vim/vimrc
+++ b/stow/vim/.config/vim/vimrc
diff --git a/stow/vscode/.config/Code/User/keybindings.json b/stow/vscode/.config/Code/User/keybindings.json
new file mode 100644
index 0000000..ba29206
--- /dev/null
+++ b/stow/vscode/.config/Code/User/keybindings.json
@@ -0,0 +1,7 @@
+// Place your key bindings in this file to override the defaults
+[
+ {
+ "key": "shift+space",
+ "command": "toggleVim"
+ }
+] \ No newline at end of file
diff --git a/stow/vscode/.config/Code/User/settings.json b/stow/vscode/.config/Code/User/settings.json
new file mode 100644
index 0000000..6d67f96
--- /dev/null
+++ b/stow/vscode/.config/Code/User/settings.json
@@ -0,0 +1,87 @@
+{
+ // =========================================================
+ // CORE EDITOR & APPEARANCE
+ // =========================================================
+ "editor.fontSize": 16,
+ "editor.insertSpaces": false,
+ "editor.tabSize": 2,
+ "editor.detectIndentation": false,
+
+ // Visual Guides
+ "editor.guides.bracketPairs": true,
+ "editor.guides.bracketPairsHorizontal": true,
+
+ // Minimap (Small code preview on the right)
+ "editor.minimap.enabled": false,
+ "editor.minimap.autohide": "none", // Redundant if enabled is false, but kept for preference
+
+ // =========================================================
+ // WORKBENCH & UI
+ // =========================================================
+ "workbench.colorTheme": "Tokyo Night Gogh",
+ "workbench.iconTheme": "material-icon-theme",
+ "window.titleBarStyle": "custom",
+ "workbench.settings.applyToAllProfiles": [],
+
+ // =========================================================
+ // FILE SAVING
+ // =========================================================
+ // Replaces the "Auto save while typing" extension
+ "files.autoSave": "afterDelay",
+ "files.autoSaveDelay": 1000, // Saves 1 second after you stop typing
+
+ // =========================================================
+ // VIM CONFIGURATION
+ // =========================================================
+ "vim.useSystemClipboard": true,
+ "vim.handleKeys": {
+ "<C-k>": false // Allows Ctrl+K chords (like language switching) to bypass Vim
+ },
+
+ // =========================================================
+ // KEYBOARD & INPUT
+ // =========================================================
+ // Fixes CapsLock remap issues on Linux/Hyprland
+ "keyboard.dispatch": "keyCode",
+
+ // =========================================================
+ // GIT INTEGRATION
+ // =========================================================
+ "git.confirmSync": false, // Don't ask before syncing
+ "git.enableSmartCommit": true, // Commit all changes if none are staged
+
+ // =========================================================
+ // LANGUAGE SPECIFIC FORMATTERS
+ // =========================================================
+ "[css]": {
+ "editor.defaultFormatter": "vscode.css-language-features"
+ },
+ "[html]": {
+ "editor.defaultFormatter": "vscode.html-language-features"
+ },
+ "[jsonc]": {
+ "editor.defaultFormatter": "vscode.json-language-features"
+ },
+
+ // =========================================================
+ // EXTENSIONS & MISC
+ // =========================================================
+ // Spell Checker
+ "cSpell.userWords": [
+ "Bootcamp",
+ "lmao"
+ ],
+
+ // Live Server
+ "liveServer.settings.donotVerifyTags": true,
+ "liveServer.settings.ChromeDebuggingAttachment": false,
+
+ // Remote SSH
+ "remote.SSH.remotePlatform": {
+ "sandbox.vyxff4.csb": "linux"
+ },
+
+ // Icons & AI
+ "vsicons.dontShowNewVersionMessage": true,
+ "chat.disableAIFeatures": true
+} \ No newline at end of file
diff --git a/.config/zsh/.zshrc b/stow/zsh/.zshrc
index 4231e29..ed171e4 100644
--- a/.config/zsh/.zshrc
+++ b/stow/zsh/.zshrc
@@ -6,7 +6,13 @@ export ZSH="$HOME/.oh-my-zsh"
# to know which specific one was loaded, run: echo $RANDOM_THEME
# See https://github.com/ohmyzsh/ohmyzsh/wiki/Themes
ZSH_THEME="spaceship"
-
+PROMPT='$(kube_ps1)'$PROMPT
+export SPACESHIP_KUBECTL_SHOW=true
+export SPACESHIP_KUBECTL_VERSION_SHOW=false # Hide version if it's too verbose
+export SPACESHIP_KUBECTL_NAMESPACE_SHOW=true # Show current namespace
+export SPACESHIP_KUBECTL_PREFIX=" "
+export SPACESHIP_KUBECTL_SYMBOL="⎈ "
+export SPACESHIP_KUBECTL_COLOR="cyan"
# Set list of themes to pick from when loading at random
# Setting this variable when ZSH_THEME=random will cause zsh to load
@@ -85,6 +91,16 @@ plugins=(
nvm
npm
node
+ kubectl
+ kubectx
+ kube-ps1
+ aws
+ azure
+ helm
+ terraform
+ ansible
+ fzf
+ z
)
source $ZSH/oh-my-zsh.sh
@@ -117,11 +133,19 @@ source $ZSH/oh-my-zsh.sh
# Example aliases
# alias zshconfig="mate ~/.zshrc"
# alias ohmyzsh="mate ~/.oh-my-zsh"
+alias kns="kubens"
+alias kctx="kubectx"
export NVM_DIR="$HOME/.nvm"
export PATH=$PATH:/usr/local/x
export PATH="$PATH:$HOME/.scripts"
+export ANDROID_HOME=/home/justsaumit/Android/Sdk
+export PATH=$PATH:$ANDROID_HOME/tools
+export PATH=$PATH:$ANDROID_HOME/platform-tools
+export PATH="$PATH:$ANDROID_HOME/tools/bin"
+
+
[ -s "$NVM_DIR/nvm.sh" ] && \. "$NVM_DIR/nvm.sh" # This loads nvm
[ -s "$NVM_DIR/bash_completion" ] && \. "$NVM_DIR/bash_completion" # This loads nvm bash_completion
@@ -131,3 +155,5 @@ export PATH="$PATH:$HOME/.scripts"
[ -f "${xdg_config_home:-$home/.config}/shell/shortcutrc" ] && source "${xdg_config_home:-$home/.config}/shell/shortcutrc"
# Load profile
[ -f "${XDG_CONFIG_HOME:-$HOME/.config}/shell/profile" ] && source "${XDG_CONFIG_HOME:-$HOME/.config}/shell/profile"
+# Load secrets
+[ -f "${XDG_CONFIG_HOME:-$HOME}/.zsh_secrets" ] && source "${XDG_CONFIG_HOME:-$HOME}/.zsh_secrets"
diff --git a/.config/tmux/tmux.conf b/tmux/tmux.conf
index 0023540..0023540 100644
--- a/.config/tmux/tmux.conf
+++ b/tmux/tmux.conf