mirror of
https://github.com/bgrolleman/dotfiles.git
synced 2025-12-06 05:45:24 +01:00
Compare commits
9 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 841f5af000 | |||
| df6c213cfd | |||
| 0f939f03a8 | |||
| 3575d4c0c1 | |||
| 97e4275dc4 | |||
| 999411251c | |||
| 4c06d7ccd4 | |||
| 02bdf43a40 | |||
| 8f0d75f685 |
196
aerospace.toml
196
aerospace.toml
@@ -1,196 +0,0 @@
|
|||||||
after-startup-command = ['exec-and-forget sketchybar']
|
|
||||||
|
|
||||||
# Notify Sketchybar about workspace change
|
|
||||||
exec-on-workspace-change = ['/bin/bash', '-c',
|
|
||||||
'sketchybar --trigger aerospace_workspace_change FOCUSED_WORKSPACE=$AEROSPACE_FOCUSED_WORKSPACE',
|
|
||||||
# 'exec-and-forget borders active_color=0xffe1e3e4 inactive_color=0xff494d64 width=5.0'
|
|
||||||
]
|
|
||||||
|
|
||||||
# Start AeroSpace at login
|
|
||||||
start-at-login = true
|
|
||||||
|
|
||||||
# Normalizations. See: https://nikitabobko.github.io/AeroSpace/guide#normalization
|
|
||||||
enable-normalization-flatten-containers = true
|
|
||||||
enable-normalization-opposite-orientation-for-nested-containers = true
|
|
||||||
|
|
||||||
# See: https://nikitabobko.github.io/AeroSpace/guide#layouts
|
|
||||||
# The 'accordion-padding' specifies the size of accordion padding
|
|
||||||
# You can set 0 to disable the padding feature
|
|
||||||
accordion-padding = 40
|
|
||||||
|
|
||||||
# Possible values: tiles|accordion
|
|
||||||
default-root-container-layout = 'tiles'
|
|
||||||
|
|
||||||
# Possible values: horizontal|vertical|auto
|
|
||||||
# 'auto' means: wide monitor (anything wider than high) gets horizontal orientation,
|
|
||||||
# tall monitor (anything higher than wide) gets vertical orientation
|
|
||||||
default-root-container-orientation = 'auto'
|
|
||||||
|
|
||||||
# Mouse follows focus when focused monitor changes
|
|
||||||
# Drop it from your config, if you don't like this behavior
|
|
||||||
# See https://nikitabobko.github.io/AeroSpace/guide#on-focus-changed-callbacks
|
|
||||||
# See https://nikitabobko.github.io/AeroSpace/commands#move-mouse
|
|
||||||
# Fallback value (if you omit the key): on-focused-monitor-changed = []
|
|
||||||
on-focused-monitor-changed = ['move-mouse monitor-lazy-center']
|
|
||||||
|
|
||||||
# You can effectively turn off macOS "Hide application" (cmd-h) feature by toggling this flag
|
|
||||||
# Useful if you don't use this macOS feature, but accidentally hit cmd-h or cmd-alt-h key
|
|
||||||
# Also see: https://nikitabobko.github.io/AeroSpace/goodness#disable-hide-app
|
|
||||||
automatically-unhide-macos-hidden-apps = false
|
|
||||||
|
|
||||||
# [[on-window-detected]]
|
|
||||||
# if.app-id = 'com.apple.systempreferences'
|
|
||||||
# if.app-name-regex-substring = 'settings'
|
|
||||||
# if.window-title-regex-substring = 'substring'
|
|
||||||
# if.workspace = 'workspace-name'
|
|
||||||
# if.during-aerospace-startup = true
|
|
||||||
# check-further-callbacks = true
|
|
||||||
# run = ['layout floating', 'move-node-to-workspace S'] # The callback itself
|
|
||||||
[[on-window-detected]]
|
|
||||||
if.app-name-regex-substring = 'finder'
|
|
||||||
run = 'layout floating'
|
|
||||||
#if.app-name-regex-substring = 'teams'
|
|
||||||
#run = ['layout floating','move-node-to-workspace 3']
|
|
||||||
#if.app-name-regex-substring = 'outlook'
|
|
||||||
#run = ['move-node-to-workspace 4']
|
|
||||||
|
|
||||||
|
|
||||||
# Possible values: (qwerty|dvorak)
|
|
||||||
# See https://nikitabobko.github.io/AeroSpace/guide#key-mapping
|
|
||||||
[key-mapping]
|
|
||||||
preset = 'qwerty'
|
|
||||||
|
|
||||||
# Gaps between windows (inner-*) and between monitor edges (outer-*).
|
|
||||||
# Possible values:
|
|
||||||
# - Constant: gaps.outer.top = 8
|
|
||||||
# - Per monitor: gaps.outer.top = [{ monitor.main = 16 }, { monitor."some-pattern" = 32 }, 24]
|
|
||||||
# In this example, 24 is a default value when there is no match.
|
|
||||||
# Monitor pattern is the same as for 'workspace-to-monitor-force-assignment'.
|
|
||||||
# See: https://nikitabobko.github.io/AeroSpace/guide#assign-workspaces-to-monitors
|
|
||||||
[gaps]
|
|
||||||
inner.horizontal = 5
|
|
||||||
inner.vertical = 5
|
|
||||||
outer.left = 5
|
|
||||||
outer.bottom = 5
|
|
||||||
outer.top = 5
|
|
||||||
outer.right = 5
|
|
||||||
|
|
||||||
# 'main' binding mode declaration
|
|
||||||
# See: https://nikitabobko.github.io/AeroSpace/guide#binding-modes
|
|
||||||
# 'main' binding mode must be always presented
|
|
||||||
# Fallback value (if you omit the key): mode.main.binding = {}
|
|
||||||
[mode.main.binding]
|
|
||||||
|
|
||||||
# All possible keys:
|
|
||||||
# - Letters. a, b, c, ..., z
|
|
||||||
# - Numbers. 0, 1, 2, ..., 9
|
|
||||||
# - Keypad numbers. keypad0, keypad1, keypad2, ..., keypad9
|
|
||||||
# - F-keys. f1, f2, ..., f20
|
|
||||||
# - Special keys. minus, equal, period, comma, slash, backslash, quote, semicolon, backtick,
|
|
||||||
# leftSquareBracket, rightSquareBracket, space, enter, esc, backspace, tab
|
|
||||||
# - Keypad special. keypadClear, keypadDecimalMark, keypadDivide, keypadEnter, keypadEqual,
|
|
||||||
# keypadMinus, keypadMultiply, keypadPlus
|
|
||||||
# - Arrows. left, down, up, right
|
|
||||||
|
|
||||||
# All possible modifiers: cmd, alt, ctrl, shift
|
|
||||||
|
|
||||||
# All possible commands: https://nikitabobko.github.io/AeroSpace/commands
|
|
||||||
|
|
||||||
# See: https://nikitabobko.github.io/AeroSpace/commands#exec-and-forget
|
|
||||||
# You can uncomment the following lines to open up terminal with alt + enter shortcut (like in i3)
|
|
||||||
alt-enter = '''exec-and-forget open -na iTerm'''
|
|
||||||
alt-space = ['layout floating tiling', 'mode main'] # Toggle between floating and tiling layout
|
|
||||||
# alt-enter = '''exec-and-forget osascript -e '
|
|
||||||
# tell application "Terminal"
|
|
||||||
# do script
|
|
||||||
# activate
|
|
||||||
# end tell'
|
|
||||||
# '''
|
|
||||||
|
|
||||||
alt-ctrl-shift-f = 'fullscreen'
|
|
||||||
alt-ctrl-f = 'layout floating'
|
|
||||||
|
|
||||||
#alt-shift-left = 'join-with left'
|
|
||||||
#alt-shift-down = 'join-with down'
|
|
||||||
#alt-shift-up = 'join-with up'
|
|
||||||
#alt-shift-right = 'join-with right'
|
|
||||||
|
|
||||||
# See: https://nikitabobko.github.io/AeroSpace/commands#layout
|
|
||||||
cmd-alt-slash = 'layout tiles horizontal vertical'
|
|
||||||
cmd-alt-shift-slash = 'layout accordion horizontal vertical'
|
|
||||||
|
|
||||||
# See: https://nikitabobko.github.io/AeroSpace/commands#focus
|
|
||||||
alt-h = 'focus left'
|
|
||||||
alt-j = 'focus down'
|
|
||||||
alt-k = 'focus up'
|
|
||||||
alt-l = 'focus right'
|
|
||||||
|
|
||||||
# See: https://nikitabobko.github.io/AeroSpace/commands#move
|
|
||||||
alt-shift-h = 'move left'
|
|
||||||
alt-shift-j = 'move down'
|
|
||||||
alt-shift-k = 'move up'
|
|
||||||
alt-shift-l = 'move right'
|
|
||||||
|
|
||||||
# See: https://nikitabobko.github.io/AeroSpace/commands#resize
|
|
||||||
cmd-shift-minus = 'resize smart -200'
|
|
||||||
cmd-shift-equal = 'resize smart +200'
|
|
||||||
|
|
||||||
# See: https://nikitabobko.github.io/AeroSpace/commands#workspace
|
|
||||||
alt-1 = 'workspace 1'
|
|
||||||
alt-2 = 'workspace 2'
|
|
||||||
alt-3 = 'workspace 3'
|
|
||||||
alt-4 = 'workspace 4'
|
|
||||||
alt-5 = 'workspace 5'
|
|
||||||
alt-6 = 'workspace 6'
|
|
||||||
alt-7 = 'workspace 7'
|
|
||||||
alt-8 = 'workspace 8'
|
|
||||||
# Allow switching to extra screen
|
|
||||||
alt-0 = 'workspace 10'
|
|
||||||
|
|
||||||
# See: https://nikitabobko.github.io/AeroSpace/commands#move-node-to-workspace
|
|
||||||
# Removing --focus-follows-window
|
|
||||||
alt-shift-1 = 'move-node-to-workspace 1'
|
|
||||||
alt-shift-2 = 'move-node-to-workspace 2'
|
|
||||||
alt-shift-3 = 'move-node-to-workspace 3'
|
|
||||||
alt-shift-4 = 'move-node-to-workspace 4'
|
|
||||||
alt-shift-5 = 'move-node-to-workspace 5'
|
|
||||||
alt-shift-6 = 'move-node-to-workspace 6'
|
|
||||||
alt-shift-7 = 'move-node-to-workspace 7'
|
|
||||||
alt-shift-8 = 'move-node-to-workspace 8'
|
|
||||||
|
|
||||||
# See: https://nikitabobko.github.io/AeroSpace/commands#mode
|
|
||||||
alt-shift-semicolon = 'mode service'
|
|
||||||
alt-r = 'mode resize'
|
|
||||||
|
|
||||||
# 'service' binding mode declaration.
|
|
||||||
# See: https://nikitabobko.github.io/AeroSpace/guide#binding-modes
|
|
||||||
[mode.service.binding]
|
|
||||||
esc = ['reload-config', 'mode main']
|
|
||||||
r = ['flatten-workspace-tree', 'mode main'] # reset layout
|
|
||||||
f = ['layout floating tiling', 'mode main'] # Toggle between floating and tiling layout
|
|
||||||
m = ['workspace 1','layout accordion horizontal vertical','workspace 2','layout accordion horizontal vertical','workspace 3','layout accordion horizontal vertical','workspace 4','layout accordion horizontal vertical','workspace 5','layout accordion horizontal vertical','workspace 6','layout accordion horizontal vertical']
|
|
||||||
d = ['workspace 1','layout tiles horizontal vertical','workspace 2','layout tiles horizontal vertical','workspace 3','layout tiles horizontal vertical','workspace 4','layout tiles horizontal vertical','workspace 5','layout tiles horizontal vertical','workspace 6','layout tiles horizontal vertical']
|
|
||||||
backspace = ['close-all-windows-but-current', 'mode main']
|
|
||||||
|
|
||||||
[mode.resize.binding]
|
|
||||||
1 = ['resize width 250','mode main']
|
|
||||||
2 = ['resize width 1000','mode main']
|
|
||||||
3 = ['resize width 2000','mode main']
|
|
||||||
4 = ['resize width 4000','mode main']
|
|
||||||
h = 'resize width -100'
|
|
||||||
j = 'resize height +100'
|
|
||||||
k = 'resize height -100'
|
|
||||||
l = 'resize width +100'
|
|
||||||
enter = 'mode main'
|
|
||||||
esc = 'mode main'
|
|
||||||
|
|
||||||
[workspace-to-monitor-force-assignment]
|
|
||||||
1 = 'main'
|
|
||||||
2 = 'main'
|
|
||||||
3 = 'main'
|
|
||||||
4 = 'main'
|
|
||||||
5 = 'main'
|
|
||||||
6 = 'secondary'
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@@ -8,6 +8,7 @@
|
|||||||
- git
|
- git
|
||||||
- tmux
|
- tmux
|
||||||
- kitty
|
- kitty
|
||||||
|
- zoxide
|
||||||
|
|
||||||
- name: Install i3 packages
|
- name: Install i3 packages
|
||||||
become: true
|
become: true
|
||||||
@@ -21,6 +22,7 @@
|
|||||||
- playerctl
|
- playerctl
|
||||||
- blueman
|
- blueman
|
||||||
- pavucontrol
|
- pavucontrol
|
||||||
|
- picom
|
||||||
|
|
||||||
- name: Development Environment
|
- name: Development Environment
|
||||||
become: true
|
become: true
|
||||||
@@ -44,3 +46,8 @@
|
|||||||
args:
|
args:
|
||||||
creates: /usr/bin/brave-browser
|
creates: /usr/bin/brave-browser
|
||||||
|
|
||||||
|
- name: Streamdeck
|
||||||
|
community.general.flatpak:
|
||||||
|
name: com.core447.StreamController
|
||||||
|
state: present
|
||||||
|
method: user
|
||||||
|
|||||||
105
i3/config
105
i3/config
@@ -1,26 +1,21 @@
|
|||||||
# This file has been auto-generated by i3-config-wizard(1).
|
# Personal i3 Configuration
|
||||||
# It will not be overwritten, so edit it as you like.
|
# Bas Grolleman
|
||||||
#
|
|
||||||
# Should you change your keyboard layout some time, delete
|
|
||||||
# this file and re-run i3-config-wizard(1).
|
|
||||||
#
|
|
||||||
|
|
||||||
# i3 config file (v4)
|
# Some reason system boots wrong resolution
|
||||||
#
|
exec --no-startup-id ~/bin/set_display_ultrawide
|
||||||
# Please see https://i3wm.org/docs/userguide.html for a complete reference!
|
|
||||||
|
|
||||||
# Alt
|
# t
|
||||||
set $mod Mod1
|
set $mod Mod1
|
||||||
# Win
|
# Win
|
||||||
set $win Mod4
|
set $win Mod4
|
||||||
|
|
||||||
# Font for window titles. Will also be used by the bar unless a different font
|
# Font for window titles. Will also be used by the bar unless a different font
|
||||||
# is used in the bar {} block below.
|
# is used in the bar {} block below.
|
||||||
font pango:monospace 8
|
#font pango:monospace 8
|
||||||
|
|
||||||
# This font is widely installed, provides lots of unicode glyphs, right-to-left
|
# This font is widely installed, provides lots of unicode glyphs, right-to-left
|
||||||
# text rendering and scalability on retina/hidpi displays (thanks to pango).
|
# text rendering and scalability on retina/hidpi displays (thanks to pango).
|
||||||
#font pango:DejaVu Sans Mono 8
|
font pango:DejaVu Sans Mono 8
|
||||||
|
|
||||||
# Start XDG autostart .desktop files using dex. See also
|
# Start XDG autostart .desktop files using dex. See also
|
||||||
# https://wiki.archlinux.org/index.php/XDG_Autostart
|
# https://wiki.archlinux.org/index.php/XDG_Autostart
|
||||||
@@ -31,7 +26,7 @@ exec --no-startup-id dex --autostart --environment i3
|
|||||||
|
|
||||||
# xss-lock grabs a logind suspend inhibit lock and will use i3lock to lock the
|
# xss-lock grabs a logind suspend inhibit lock and will use i3lock to lock the
|
||||||
# screen before suspend. Use loginctl lock-session to lock your screen.
|
# screen before suspend. Use loginctl lock-session to lock your screen.
|
||||||
exec --no-startup-id xss-lock --transfer-sleep-lock -- i3lock --nofork
|
#exec --no-startup-id xss-lock --transfer-sleep-lock -- i3lock --nofork -i ~/Documents/Resources/Backgrounds/51202139522_fbf4788f42_o.png
|
||||||
|
|
||||||
# NetworkManager is the most popular way to manage wireless networks on Linux,
|
# NetworkManager is the most popular way to manage wireless networks on Linux,
|
||||||
# and nm-applet is a desktop environment-independent system tray GUI for it.
|
# and nm-applet is a desktop environment-independent system tray GUI for it.
|
||||||
@@ -54,6 +49,8 @@ floating_modifier $mod
|
|||||||
|
|
||||||
# start a terminal
|
# start a terminal
|
||||||
bindsym $mod+Return exec kitty
|
bindsym $mod+Return exec kitty
|
||||||
|
bindsym $win+e exec /usr/bin/nautilus /home/bgrolleman
|
||||||
|
bindsym $win+b exec /opt/helium/helium
|
||||||
|
|
||||||
# kill focused window
|
# kill focused window
|
||||||
bindsym $mod+Shift+q kill
|
bindsym $mod+Shift+q kill
|
||||||
@@ -62,62 +59,45 @@ bindsym $mod+Shift+q kill
|
|||||||
#bindsym $mod+d exec --no-startup-id dmenu_run
|
#bindsym $mod+d exec --no-startup-id dmenu_run
|
||||||
# A more modern dmenu replacement is rofi:
|
# A more modern dmenu replacement is rofi:
|
||||||
bindcode $win+65 exec "rofi -modi drun,run -show drun"
|
bindcode $win+65 exec "rofi -modi drun,run -show drun"
|
||||||
bindcode $mod+65 exec "rofi -show window"
|
#bindcode $mod+65 exec "rofi -show window"
|
||||||
|
#bindcode $win+v exec 'rofi -modi "clipboard:greenclip print" -show clipboard -run-command "{cmd}"'
|
||||||
# There also is i3-dmenu-desktop which only displays applications shipping a
|
# There also is i3-dmenu-desktop which only displays applications shipping a
|
||||||
# .desktop file. It is a wrapper around dmenu, so you need that installed.
|
# .desktop file. It is a wrapper around dmenu, so you need that installed.
|
||||||
# bindcode $mod+40 exec --no-startup-id i3-dmenu-desktop
|
# bindcode $mod+40 exec --no-startup-id i3-dmenu-desktop
|
||||||
bindsym $win+l exec "i3lock -i ~/Documents/Resources/Backgrounds/51202139522_fbf4788f42_o.png"
|
#bindsym $win+l exec "i3lock -i ~/Documents/Resources/Backgrounds/51202139522_fbf4788f42_o.png"
|
||||||
|
#bindsym $win+l exec "/usr/bin/gdmflexiserver"
|
||||||
|
bindsym $win+$mod+q exec "/usr/bin/gdmflexiserver"
|
||||||
|
|
||||||
# change focus
|
# change focus
|
||||||
bindsym $mod+j focus left
|
bindsym $mod+h focus left
|
||||||
bindsym $mod+k focus down
|
bindsym $mod+j focus down
|
||||||
bindsym $mod+l focus up
|
bindsym $mod+k focus up
|
||||||
bindsym $mod+semicolon focus right
|
bindsym $mod+l focus right
|
||||||
|
|
||||||
# alternatively, you can use the cursor keys:
|
|
||||||
bindsym $mod+Left focus left
|
|
||||||
bindsym $mod+Down focus down
|
|
||||||
bindsym $mod+Up focus up
|
|
||||||
bindsym $mod+Right focus right
|
|
||||||
|
|
||||||
# move focused window
|
# move focused window
|
||||||
bindsym $mod+Shift+j move left
|
bindsym $mod+Shift+h move left
|
||||||
bindsym $mod+Shift+k move down
|
bindsym $mod+Shift+j move down
|
||||||
bindsym $mod+Shift+l move up
|
bindsym $mod+Shift+k move up
|
||||||
bindsym $mod+Shift+semicolon move right
|
bindsym $mod+Shift+l move right
|
||||||
|
|
||||||
# alternatively, you can use the cursor keys:
|
|
||||||
bindsym $mod+Shift+Left move left
|
|
||||||
bindsym $mod+Shift+Down move down
|
|
||||||
bindsym $mod+Shift+Up move up
|
|
||||||
bindsym $mod+Shift+Right move right
|
|
||||||
|
|
||||||
# split in horizontal orientation
|
# split in horizontal orientation
|
||||||
bindsym $mod+h split h
|
bindsym $mod+semicolon split h
|
||||||
|
|
||||||
# split in vertical orientation
|
|
||||||
bindsym $mod+v split v
|
|
||||||
|
|
||||||
# enter fullscreen mode for the focused container
|
# enter fullscreen mode for the focused container
|
||||||
bindsym $mod+f fullscreen toggle
|
bindsym $mod+f fullscreen toggle
|
||||||
|
bindsym $mod+y floating enable; resize set 55ppt 95ppt; move position center
|
||||||
|
|
||||||
# change container layout (stacked, tabbed, toggle split)
|
# change container layout (stacked, tabbed, toggle split)
|
||||||
bindsym $mod+s layout stacking
|
#bindsym $mod+s layout stacking
|
||||||
bindsym $mod+w layout tabbed
|
#bindsym $mod+w layout tabbed
|
||||||
bindsym $mod+e layout toggle split
|
#bindsym $mod+e layout toggle split
|
||||||
|
|
||||||
# toggle tiling / floating
|
# toggle tiling / floating
|
||||||
bindsym $mod+Shift+space floating toggle
|
bindsym $mod+space floating toggle
|
||||||
|
|
||||||
# change focus between tiling / floating windows
|
# change focus between tiling / floating windows
|
||||||
#bindsym $mod+space focus mode_toggle
|
#bindsym $mod+space focus mode_toggle
|
||||||
|
|
||||||
# focus the parent container
|
|
||||||
bindsym $mod+a focus parent
|
|
||||||
|
|
||||||
# focus the child container
|
|
||||||
#bindsym $mod+d focus child
|
|
||||||
|
|
||||||
# Define names for default workspaces for which we configure key bindings later on.
|
# Define names for default workspaces for which we configure key bindings later on.
|
||||||
# We use variables to avoid repeating the names in multiple places.
|
# We use variables to avoid repeating the names in multiple places.
|
||||||
set $ws1 "1"
|
set $ws1 "1"
|
||||||
@@ -170,10 +150,10 @@ mode "resize" {
|
|||||||
# Pressing right will grow the window’s width.
|
# Pressing right will grow the window’s width.
|
||||||
# Pressing up will shrink the window’s height.
|
# Pressing up will shrink the window’s height.
|
||||||
# Pressing down will grow the window’s height.
|
# Pressing down will grow the window’s height.
|
||||||
bindsym j resize shrink width 10 px or 10 ppt
|
bindsym h resize shrink width 10 px or 10 ppt
|
||||||
bindsym k resize grow height 10 px or 10 ppt
|
bindsym j resize grow height 10 px or 10 ppt
|
||||||
bindsym l resize shrink height 10 px or 10 ppt
|
bindsym k resize shrink height 10 px or 10 ppt
|
||||||
bindsym semicolon resize grow width 10 px or 10 ppt
|
bindsym l resize grow width 10 px or 10 ppt
|
||||||
|
|
||||||
# same bindings, but for the arrow keys
|
# same bindings, but for the arrow keys
|
||||||
bindsym Left resize shrink width 10 px or 10 ppt
|
bindsym Left resize shrink width 10 px or 10 ppt
|
||||||
@@ -188,16 +168,29 @@ mode "resize" {
|
|||||||
}
|
}
|
||||||
|
|
||||||
bindsym $mod+r mode "resize"
|
bindsym $mod+r mode "resize"
|
||||||
|
bindsym $mod+Right resize grow width 30px
|
||||||
|
bindsym $mod+Left resize shrink width 30px
|
||||||
|
|
||||||
|
|
||||||
exec_always --no-startup-id $HOME/.config/polybar/launch.sh
|
exec_always --no-startup-id $HOME/.config/polybar/launch.sh
|
||||||
|
|
||||||
default_border normal 5px
|
default_border pixel 3px
|
||||||
|
smart_borders on
|
||||||
# This needs a newer verison of i3 then I have on my desktop right now
|
# This needs a newer verison of i3 then I have on my desktop right now
|
||||||
#gaps inner 5px
|
gaps inner 5px
|
||||||
|
|
||||||
# Turn off my screen after 10 min of in-activity
|
# Turn off my screen after 10 min of in-activity
|
||||||
exec --no-startup-id xset dpms 600
|
exec --no-startup-id xset dpms 600
|
||||||
exec --no-startup-id /usr/bin/blueman-applet
|
exec --no-startup-id /usr/bin/blueman-applet
|
||||||
exec --no-startup-id nitrogen --restore
|
exec --no-startup-id nitrogen --restore
|
||||||
|
exec --no-startup-id greenclip deamon
|
||||||
|
exec --no-startup-id flatpak run com.core447.StreamController -b
|
||||||
|
exec --no-startup-id picom
|
||||||
|
exec --no-startup-id ~/bin/stack-v5.3.1-20240731-x86_64.AppImage
|
||||||
|
|
||||||
|
bindsym $win+period exec flatpak run it.mijorus.smile
|
||||||
|
|
||||||
|
#exec --no-startup-id i3-msg "workspace 6; append_layout ~/.config/i3/workspace-6.json"
|
||||||
|
|
||||||
|
client.focused #ffff00 #ffff00 #000000 #ffff00 #ffff00
|
||||||
|
|
||||||
bindcode $win+. exec flatpak run it.mijorus.smile
|
|
||||||
|
|||||||
@@ -1,48 +1,49 @@
|
|||||||
// vim:ts=4:sw=4:et
|
// vim:ts=4:sw=4:et
|
||||||
{
|
{
|
||||||
// splith split container with 3 children
|
"name": "Todoist",
|
||||||
"border": "normal",
|
"percent": 0.15,
|
||||||
"floating": "auto_off",
|
|
||||||
"layout": "splith",
|
|
||||||
"marks": [],
|
|
||||||
"percent": 1,
|
|
||||||
"type": "con",
|
|
||||||
"nodes": [
|
|
||||||
{
|
|
||||||
"border": "none",
|
|
||||||
"current_border_width": 5,
|
|
||||||
"floating": "user_off",
|
|
||||||
"marks": [],
|
|
||||||
"name": "Todoist - Today – Todoist",
|
|
||||||
"percent": 0.20,
|
|
||||||
"swallows": [
|
"swallows": [
|
||||||
{
|
{
|
||||||
"instance": "^crx_knaiokfnmjjldlfhlioejgcompgenfhb$"
|
"instance": "^crx_knaiokfnmjjldlfhlioejgcompgenfhb$"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"type": "con"
|
"type": "con"
|
||||||
},
|
}
|
||||||
{
|
|
||||||
"border": "normal",
|
{
|
||||||
"current_border_width": 2,
|
"name": "Brave",
|
||||||
"floating": "user_off",
|
|
||||||
"marks": [],
|
|
||||||
"name": "i3: Layout saving in i3 - Brave",
|
|
||||||
"percent": 0.60,
|
"percent": 0.60,
|
||||||
"swallows": [
|
"swallows": [
|
||||||
{
|
{
|
||||||
"instance": "^brave\\-browser$"
|
"class": "^Brave\\-browser$",
|
||||||
|
"instance": "^brave\\-browser$",
|
||||||
|
"window_role": "^browser$"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"type": "con"
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
// splitv split container with 2 children
|
||||||
|
"border": "pixel",
|
||||||
|
"floating": "auto_off",
|
||||||
|
"layout": "splitv",
|
||||||
|
"percent": 0.35,
|
||||||
|
"type": "con",
|
||||||
|
"nodes": [
|
||||||
|
{
|
||||||
|
"name": "Logseq",
|
||||||
|
"percent": 0.5,
|
||||||
|
"swallows": [
|
||||||
|
{
|
||||||
|
"class": "^Logseq$"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"type": "con"
|
"type": "con"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"border": "normal",
|
"name": "Terminal",
|
||||||
"current_border_width": 5,
|
"percent": 0.5,
|
||||||
"floating": "auto_off",
|
|
||||||
"marks": [],
|
|
||||||
"name": "bgrolleman@laura: ~",
|
|
||||||
"percent": 0.20,
|
|
||||||
"swallows": [
|
"swallows": [
|
||||||
{
|
{
|
||||||
"class": "^kitty$"
|
"class": "^kitty$"
|
||||||
|
|||||||
53
i3/workspace-6.json
Normal file
53
i3/workspace-6.json
Normal file
@@ -0,0 +1,53 @@
|
|||||||
|
// vim:ts=4:sw=4:et
|
||||||
|
{
|
||||||
|
"marks": [],
|
||||||
|
"name": "YouTube Music",
|
||||||
|
"percent": 0.25,
|
||||||
|
"swallows": [
|
||||||
|
{
|
||||||
|
"class": "^Brave\\-browser$",
|
||||||
|
"instance": "^crx_cinhimbnkkaeohfgghhklpknlkffjgod$",
|
||||||
|
"title": "^YouTube\\ Music$"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"type": "con"
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
"marks": [],
|
||||||
|
"name": "WhatsApp Web",
|
||||||
|
"percent": 0.25,
|
||||||
|
"swallows": [
|
||||||
|
{
|
||||||
|
"class": "^Brave\\-browser$",
|
||||||
|
"instance": "^crx_hnpfjngllnobngcgfapefoaidbinmjnm$",
|
||||||
|
"title": "^WhatsApp\\ Web$"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"type": "con"
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
"marks": [],
|
||||||
|
"name": "WhatsApp Web",
|
||||||
|
"percent": 0.25,
|
||||||
|
"swallows": [
|
||||||
|
{
|
||||||
|
"class": "^Brave\\-browser$",
|
||||||
|
"instance": "^crx_hnpfjngllnobngcgfapefoaidbinmjnm$"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"type": "con"
|
||||||
|
}
|
||||||
|
|
||||||
|
{
|
||||||
|
"marks": [],
|
||||||
|
"name": "Friends - Discord",
|
||||||
|
"percent": 0.25,
|
||||||
|
"swallows": [
|
||||||
|
{
|
||||||
|
"class": "^discord$"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"type": "con"
|
||||||
|
}
|
||||||
10
i3/workspace1.sh
Executable file
10
i3/workspace1.sh
Executable file
@@ -0,0 +1,10 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
i3-msg "workspace 1; append_layout ~/.config/i3/workspace-1.json"
|
||||||
|
sleep 0.5
|
||||||
|
/usr/bin/brave-browser &
|
||||||
|
sleep 0.5
|
||||||
|
/usr/bin/kitty &
|
||||||
|
sleep 0.5
|
||||||
|
flatpak run com.logseq.Logseq &
|
||||||
|
sleep 0.5
|
||||||
|
gtk-launch "brave-knaiokfnmjjldlfhlioejgcompgenfhb-Default.desktop" &
|
||||||
1
.gitignore → nvim/.gitignore
vendored
1
.gitignore → nvim/.gitignore
vendored
@@ -1,2 +1 @@
|
|||||||
.DS_Store
|
|
||||||
lazy-lock.json
|
lazy-lock.json
|
||||||
@@ -11,6 +11,7 @@
|
|||||||
"lazyvim.plugins.extras.editor.mini-move",
|
"lazyvim.plugins.extras.editor.mini-move",
|
||||||
"lazyvim.plugins.extras.editor.neo-tree",
|
"lazyvim.plugins.extras.editor.neo-tree",
|
||||||
"lazyvim.plugins.extras.editor.outline",
|
"lazyvim.plugins.extras.editor.outline",
|
||||||
|
"lazyvim.plugins.extras.editor.snacks_explorer",
|
||||||
"lazyvim.plugins.extras.editor.telescope",
|
"lazyvim.plugins.extras.editor.telescope",
|
||||||
"lazyvim.plugins.extras.lang.ansible",
|
"lazyvim.plugins.extras.lang.ansible",
|
||||||
"lazyvim.plugins.extras.lang.clojure",
|
"lazyvim.plugins.extras.lang.clojure",
|
||||||
@@ -30,7 +31,7 @@
|
|||||||
],
|
],
|
||||||
"install_version": 8,
|
"install_version": 8,
|
||||||
"news": {
|
"news": {
|
||||||
"NEWS.md": "11866"
|
"NEWS.md": "10960"
|
||||||
},
|
},
|
||||||
"version": 8
|
"version": 8
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -9,18 +9,4 @@ local wk = require("which-key")
|
|||||||
wk.add({
|
wk.add({
|
||||||
{ "<leader>N", group = "Notes" },
|
{ "<leader>N", group = "Notes" },
|
||||||
{ "<leader>Nt", ":Journal<CR>", desc = "Today" },
|
{ "<leader>Nt", ":Journal<CR>", desc = "Today" },
|
||||||
{ "<leader>C", group = "ChatGPT" },
|
|
||||||
{ "<leader>CC", ":ChatGPT<CR>", desc = "ChatGPT" },
|
|
||||||
{ "<leader>Ce", "<cmd>ChatGPTEditWithInstruction<CR>", desc = "Edit with instruction", mode = { "n", "v" } },
|
|
||||||
{ "<leader>Cg", "<cmd>ChatGPTRun grammar_correction<CR>", desc = "Grammar Correction", mode = { "n", "v" } },
|
|
||||||
-- t = { "<cmd>ChatGPTRun translate<CR>", "Translate", mode = { "n", "v" } },
|
|
||||||
-- k = { "<cmd>ChatGPTRun keywords<CR>", "Keywords", mode = { "n", "v" } },
|
|
||||||
-- d = { "<cmd>ChatGPTRun docstring<CR>", "Docstring", mode = { "n", "v" } },
|
|
||||||
-- a = { "<cmd>ChatGPTRun add_tests<CR>", "Add Tests", mode = { "n", "v" } },
|
|
||||||
{ "<leader>Co", "<cmd>ChatGPTRun optimize_code<CR>", desc = "Optimize Code", mode = { "n", "v" } },
|
|
||||||
-- s = { "<cmd>ChatGPTRun summarize<CR>", "Summarize", mode = { "n", "v" } },
|
|
||||||
{ "<leader>Cf", "<cmd>ChatGPTRun fix_bugs<CR>", desc = "Fix Bugs", mode = { "n", "v" } },
|
|
||||||
-- x = { "<cmd>ChatGPTRun explain_code<CR>", "Explain Code", mode = { "n", "v" } },
|
|
||||||
-- r = { "<cmd>ChatGPTRun roxygen_edit<CR>", "Roxygen Edit", mode = { "n", "v" } },
|
|
||||||
-- l = { "<cmd>ChatGPTRun code_readability_analysis<CR>", "Code Readability Analysis", mode = { "n", "v" } },
|
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -38,7 +38,7 @@ require("lazy").setup({
|
|||||||
version = false, -- always use the latest git commit
|
version = false, -- always use the latest git commit
|
||||||
-- version = "*", -- try installing the latest stable version for plugins that support semver
|
-- version = "*", -- try installing the latest stable version for plugins that support semver
|
||||||
},
|
},
|
||||||
install = { colorscheme = { "catppuccin" } },
|
install = { colorscheme = { "tokyonight", "habamax" } },
|
||||||
checker = {
|
checker = {
|
||||||
enabled = true, -- check for plugin updates periodically
|
enabled = true, -- check for plugin updates periodically
|
||||||
notify = false, -- notify on update
|
notify = false, -- notify on update
|
||||||
|
|||||||
17
nvim/lua/plugins.disable/chatgpt.lua
Normal file
17
nvim/lua/plugins.disable/chatgpt.lua
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
return {
|
||||||
|
"jackMort/ChatGPT.nvim",
|
||||||
|
event = "VeryLazy",
|
||||||
|
config = function()
|
||||||
|
require("chatgpt").setup({
|
||||||
|
openai_params = {
|
||||||
|
model = "gpt-4.1"
|
||||||
|
}
|
||||||
|
})
|
||||||
|
end,
|
||||||
|
dependencies = {
|
||||||
|
"MunifTanjim/nui.nvim",
|
||||||
|
"nvim-lua/plenary.nvim",
|
||||||
|
"folke/trouble.nvim", -- optional
|
||||||
|
"nvim-telescope/telescope.nvim"
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,58 +0,0 @@
|
|||||||
return {
|
|
||||||
{
|
|
||||||
"yetone/avante.nvim",
|
|
||||||
build = "make",
|
|
||||||
event = "VeryLazy",
|
|
||||||
version = false, -- Never set this value to "*"! Never!
|
|
||||||
---@module 'avante'
|
|
||||||
---@type avante.Config
|
|
||||||
opts = {
|
|
||||||
provider = "gpt-5-codex",
|
|
||||||
providers = {
|
|
||||||
["gpt-5-codex"] = {
|
|
||||||
__inherited_from = "openai",
|
|
||||||
model = "gpt-5-codex",
|
|
||||||
temperature = 1,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
dependencies = {
|
|
||||||
"nvim-lua/plenary.nvim",
|
|
||||||
"MunifTanjim/nui.nvim",
|
|
||||||
--- The below dependencies are optional,
|
|
||||||
"nvim-mini/mini.pick", -- for file_selector provider mini.pick
|
|
||||||
"nvim-telescope/telescope.nvim", -- for file_selector provider telescope
|
|
||||||
"hrsh7th/nvim-cmp", -- autocompletion for avante commands and mentions
|
|
||||||
"ibhagwan/fzf-lua", -- for file_selector provider fzf
|
|
||||||
"stevearc/dressing.nvim", -- for input provider dressing
|
|
||||||
"folke/snacks.nvim", -- for input provider snacks
|
|
||||||
"nvim-tree/nvim-web-devicons", -- or echasnovski/mini.icons
|
|
||||||
"zbirenbaum/copilot.lua", -- for providers='copilot'
|
|
||||||
{
|
|
||||||
-- support for image pasting
|
|
||||||
"HakonHarnes/img-clip.nvim",
|
|
||||||
event = "VeryLazy",
|
|
||||||
opts = {
|
|
||||||
-- recommended settings
|
|
||||||
default = {
|
|
||||||
embed_image_as_base64 = false,
|
|
||||||
prompt_for_file_name = false,
|
|
||||||
drag_and_drop = {
|
|
||||||
insert_mode = true,
|
|
||||||
},
|
|
||||||
-- required for Windows users
|
|
||||||
use_absolute_path = true,
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
{
|
|
||||||
-- Make sure to set this up properly if you have lazy=true
|
|
||||||
"MeanderingProgrammer/render-markdown.nvim",
|
|
||||||
opts = {
|
|
||||||
file_types = { "markdown", "Avante" },
|
|
||||||
},
|
|
||||||
ft = { "markdown", "Avante" },
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
}
|
|
||||||
@@ -1,9 +1,6 @@
|
|||||||
return {
|
return {
|
||||||
{
|
{
|
||||||
"saghen/blink.cmp",
|
"saghen/blink.cmp",
|
||||||
dependencies = {
|
|
||||||
"Kaiser-Yang/blink-cmp-avante",
|
|
||||||
},
|
|
||||||
opts = {
|
opts = {
|
||||||
completion = {
|
completion = {
|
||||||
ghost_text = {
|
ghost_text = {
|
||||||
@@ -19,20 +16,6 @@ return {
|
|||||||
auto_show = true,
|
auto_show = true,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
file_selector = {
|
|
||||||
provider = "telescope",
|
|
||||||
provider_opts = {},
|
|
||||||
},
|
|
||||||
sources = {
|
|
||||||
default = { "avante", "lsp", "path", "buffer" },
|
|
||||||
providers = {
|
|
||||||
avante = {
|
|
||||||
module = "blink-cmp-avante",
|
|
||||||
name = "Avante",
|
|
||||||
opts = {},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,6 +0,0 @@
|
|||||||
return {
|
|
||||||
{ "catppuccin/nvim" },
|
|
||||||
{ "LazyVim/LazyVim", opts = {
|
|
||||||
colorscheme = "catppuccin",
|
|
||||||
} },
|
|
||||||
}
|
|
||||||
@@ -1,18 +0,0 @@
|
|||||||
return {
|
|
||||||
"jackMort/ChatGPT.nvim",
|
|
||||||
event = "VeryLazy",
|
|
||||||
config = function()
|
|
||||||
require("chatgpt").setup({
|
|
||||||
openai_params = {
|
|
||||||
model = "gpt-4.1",
|
|
||||||
max_tokens = 4095,
|
|
||||||
},
|
|
||||||
})
|
|
||||||
end,
|
|
||||||
dependencies = {
|
|
||||||
"MunifTanjim/nui.nvim",
|
|
||||||
"nvim-lua/plenary.nvim",
|
|
||||||
"folke/trouble.nvim", -- optional
|
|
||||||
"nvim-telescope/telescope.nvim",
|
|
||||||
},
|
|
||||||
}
|
|
||||||
3
nvim/lua/plugins/interim-ls.lua
Normal file
3
nvim/lua/plugins/interim-ls.lua
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
return {
|
||||||
|
"benlubas/neorg-interim-ls",
|
||||||
|
}
|
||||||
@@ -3,21 +3,21 @@ return {
|
|||||||
config = function()
|
config = function()
|
||||||
require("journal").setup({
|
require("journal").setup({
|
||||||
filetype = "md", -- Filetype to use for new journal entries
|
filetype = "md", -- Filetype to use for new journal entries
|
||||||
root = "~/Notes/Journal", -- Root directory for journal entries
|
root = "~/Notes/Personal/journals", -- Root directory for journal entries
|
||||||
date_format = "%Y%m%d", -- Date format for `:Journal <date-modifier>`
|
date_format = "%Y-%m-%d", -- Date format for `:Journal <date-modifier>`
|
||||||
autocomplete_date_modifier = "always", -- "always"|"never"|"end". Enable date modifier autocompletion
|
autocomplete_date_modifier = "end", -- "always"|"never"|"end". Enable date modifier autocompletion
|
||||||
|
|
||||||
-- Configuration for journal entries
|
-- Configuration for journal entries
|
||||||
journal = {
|
journal = {
|
||||||
-- Default configuration for `:Journal <date-modifier>`
|
-- Default configuration for `:Journal <date-modifier>`
|
||||||
format = "%Y%m%d",
|
format = "%Y_%m_%d",
|
||||||
template = "# %A %B %d %Y\n",
|
template = "# %A %B %d %Y\n",
|
||||||
frequency = { day = 1 },
|
frequency = { day = 1 },
|
||||||
|
|
||||||
-- Nested configurations for `:Journal <type> <type> ... <date-modifier>`
|
-- Nested configurations for `:Journal <type> <type> ... <date-modifier>`
|
||||||
entries = {
|
entries = {
|
||||||
day = {
|
day = {
|
||||||
format = "%Y%m%d", -- Format of the journal entry in the filesystem.
|
format = "%Y_%m_%d", -- Format of the journal entry in the filesystem.
|
||||||
template = "# %A %B %d %Y\n", -- Optional. Template used when creating a new journal entry
|
template = "# %A %B %d %Y\n", -- Optional. Template used when creating a new journal entry
|
||||||
frequency = { day = 1 }, -- Optional. The frequency of the journal entry. Used for `:Journal next`, `:Journal -2` etc
|
frequency = { day = 1 }, -- Optional. The frequency of the journal entry. Used for `:Journal next`, `:Journal -2` etc
|
||||||
},
|
},
|
||||||
|
|||||||
@@ -1,13 +0,0 @@
|
|||||||
return {
|
|
||||||
"serenevoid/kiwi.nvim",
|
|
||||||
opts = {
|
|
||||||
{
|
|
||||||
name = "notes",
|
|
||||||
path = "Notes",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
keys = {
|
|
||||||
{ "T", ':lua require("kiwi").todo.toggle()<cr>', desc = "Toggle Markdown Task" },
|
|
||||||
},
|
|
||||||
lazy = true,
|
|
||||||
}
|
|
||||||
@@ -1,6 +1,6 @@
|
|||||||
return {
|
return {
|
||||||
"MeanderingProgrammer/render-markdown.nvim",
|
"MeanderingProgrammer/render-markdown.nvim",
|
||||||
dependencies = { "nvim-treesitter/nvim-treesitter", "nvim-mini/mini.nvim" }, -- if you use the mini.nvim suite
|
dependencies = { "nvim-treesitter/nvim-treesitter", "echasnovski/mini.nvim" }, -- if you use the mini.nvim suite
|
||||||
---@module 'render-markdown'
|
---@module 'render-markdown'
|
||||||
---@type render.md.UserConfig
|
---@type render.md.UserConfig
|
||||||
opts = {},
|
opts = {},
|
||||||
|
|||||||
@@ -1,11 +0,0 @@
|
|||||||
return {
|
|
||||||
"lucidph3nx/nvim-sops",
|
|
||||||
event = { "BufEnter" },
|
|
||||||
opts = {
|
|
||||||
debug = true,
|
|
||||||
defaults = {
|
|
||||||
-- Faking awsProfile since the variable has spaces
|
|
||||||
awsProfile = "Fake",
|
|
||||||
},
|
|
||||||
},
|
|
||||||
}
|
|
||||||
65
picom.conf
Normal file
65
picom.conf
Normal file
@@ -0,0 +1,65 @@
|
|||||||
|
shadow = false;
|
||||||
|
shadow-radius = 7;
|
||||||
|
shadow-offset-x = -7;
|
||||||
|
shadow-offset-y = -7;
|
||||||
|
shadow-exclude = [ "name = 'Notification'", "class_g = 'Conky'", "class_g ?= 'Notify-osd'", "class_g = 'Cairo-clock'", "_GTK_FRAME_EXTENTS@:c" ];
|
||||||
|
fading = true;
|
||||||
|
fade-in-step = 0.03;
|
||||||
|
fade-out-step = 0.03;
|
||||||
|
inactive-opacity = 0.95;
|
||||||
|
frame-opacity = 0.7;
|
||||||
|
inactive-opacity-override = false;
|
||||||
|
focus-exclude = [ "class_g = 'Cairo-clock'" ];
|
||||||
|
corner-radius = 10.0;
|
||||||
|
rounded-corners-exclude = [ "window_type = 'dock'", "window_type = 'desktop'" ];
|
||||||
|
blur-kern = "3x3box";
|
||||||
|
blur-background-exclude = [ "window_type = 'dock'", "window_type = 'desktop'", "_GTK_FRAME_EXTENTS@:c" ];
|
||||||
|
backend = "glx";
|
||||||
|
vsync = true;
|
||||||
|
mark-wmwin-focused = true;
|
||||||
|
mark-ovredir-focused = true;
|
||||||
|
detect-rounded-corners = true;
|
||||||
|
detect-client-opacity = true;
|
||||||
|
detect-transient = true;
|
||||||
|
use-damage = true;
|
||||||
|
log-level = "warn";
|
||||||
|
wintypes :
|
||||||
|
{
|
||||||
|
tooltip :
|
||||||
|
{
|
||||||
|
fade = true;
|
||||||
|
shadow = true;
|
||||||
|
opacity = 0.75;
|
||||||
|
focus = true;
|
||||||
|
full-shadow = false;
|
||||||
|
};
|
||||||
|
dock :
|
||||||
|
{
|
||||||
|
shadow = false;
|
||||||
|
clip-shadow-above = false;
|
||||||
|
full-shadow = false;
|
||||||
|
opacity = 1.0;
|
||||||
|
focus = true;
|
||||||
|
};
|
||||||
|
dnd :
|
||||||
|
{
|
||||||
|
shadow = false;
|
||||||
|
};
|
||||||
|
popup_menu :
|
||||||
|
{
|
||||||
|
opacity = 0.8;
|
||||||
|
};
|
||||||
|
dropdown_menu :
|
||||||
|
{
|
||||||
|
opacity = 0.8;
|
||||||
|
};
|
||||||
|
menu :
|
||||||
|
{
|
||||||
|
shadow = false;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
blur-background = true;
|
||||||
|
shadow-opacity = 0.1;
|
||||||
|
blur-background-frame = false;
|
||||||
|
inactive-dim = 0.2;
|
||||||
|
|
||||||
@@ -3,7 +3,7 @@ monitor = DP-0
|
|||||||
width = 100%
|
width = 100%
|
||||||
height = 34
|
height = 34
|
||||||
|
|
||||||
background = #00000000
|
background = #cc000000
|
||||||
foreground = #ccffffff
|
foreground = #ccffffff
|
||||||
|
|
||||||
line-color = ${bar/bottom.background}
|
line-color = ${bar/bottom.background}
|
||||||
@@ -241,6 +241,8 @@ label-connected = WIFI %essid% %local_ip%
|
|||||||
label-disconnected = WIFI DISCONNECTED
|
label-disconnected = WIFI DISCONNECTED
|
||||||
label-disconnected-foreground = #66
|
label-disconnected-foreground = #66
|
||||||
|
|
||||||
|
click-left = nm-connection-editor
|
||||||
|
|
||||||
[module/wired-network]
|
[module/wired-network]
|
||||||
type = internal/network
|
type = internal/network
|
||||||
interface = eno2
|
interface = eno2
|
||||||
|
|||||||
2
setup.sh
2
setup.sh
@@ -26,3 +26,5 @@ link ~/.config/i3 ~/dotfiles/i3
|
|||||||
configlink tmux
|
configlink tmux
|
||||||
configlink nvim
|
configlink nvim
|
||||||
configlink kitty
|
configlink kitty
|
||||||
|
configlink polybar
|
||||||
|
configlink picom.conf
|
||||||
|
|||||||
@@ -1,8 +1,8 @@
|
|||||||
# Load catppuccin
|
|
||||||
run ~/.config/tmux/plugins/catppuccin/tmux/catppuccin.tmux
|
run ~/.config/tmux/plugins/catppuccin/tmux/catppuccin.tmux
|
||||||
|
|
||||||
|
|
||||||
# Options to make tmux more pleasant
|
# Options to make tmux more pleasant
|
||||||
#set -g mouse on
|
set -g mouse on
|
||||||
set -g default-terminal "tmux-256color"
|
set -g default-terminal "tmux-256color"
|
||||||
set -g base-index 1
|
set -g base-index 1
|
||||||
set -g renumber-windows on
|
set -g renumber-windows on
|
||||||
@@ -10,9 +10,9 @@ set -g renumber-windows on
|
|||||||
# Configure the catppuccin plugin
|
# Configure the catppuccin plugin
|
||||||
set -g @catppuccin_flavor "mocha"
|
set -g @catppuccin_flavor "mocha"
|
||||||
set -g @catppuccin_window_status_style "slanted"
|
set -g @catppuccin_window_status_style "slanted"
|
||||||
set -g @catppuccin_window_current_text " #{window_name} #{b:pane_current_path}"
|
|
||||||
set -g @catppuccin_window_text " #{window_name} #{b:pane_current_path}"
|
|
||||||
|
|
||||||
|
# Load catppuccin
|
||||||
|
run ~/.config/tmux/plugins/catppuccin/tmux/catppuccin.tmux
|
||||||
|
|
||||||
# Make the status line pretty and add some modules
|
# Make the status line pretty and add some modules
|
||||||
set-option -g status-position top
|
set-option -g status-position top
|
||||||
@@ -23,8 +23,10 @@ set -g status-left "#[fg=#{@thm_teal},bg=#{@thm_crust}]#[fg=#{@thm_crust},bg=
|
|||||||
|
|
||||||
#set -g status-left "#[fg=$thm_green,bg=$thm_bg,nobold,nounderscore,noitalics]#[fg=$thm_bg,bg=$thm_green,nobold,nounderscore,noitalics] #[fg=$thm_fg,bg=$thm_bg]#(hostname -s) "
|
#set -g status-left "#[fg=$thm_green,bg=$thm_bg,nobold,nounderscore,noitalics]#[fg=$thm_bg,bg=$thm_green,nobold,nounderscore,noitalics] #[fg=$thm_fg,bg=$thm_bg]#(hostname -s) "
|
||||||
set -g status-right "#{E:@catppuccin_status_application}"
|
set -g status-right "#{E:@catppuccin_status_application}"
|
||||||
|
#set -agF status-right "#{E:@catppuccin_status_cpu}"
|
||||||
set -ag status-right "#{E:@catppuccin_status_session}"
|
set -ag status-right "#{E:@catppuccin_status_session}"
|
||||||
|
#set -ag status-right "#{E:@catppuccin_status_uptime}"
|
||||||
|
#set -agF status-right "#{E:@catppuccin_status_battery}"
|
||||||
|
|
||||||
#
|
#run ~/.config/tmux/plugins/tmux-plugins/tmux-cpu/cpu.tmux
|
||||||
#set -g pane-border-status top
|
#run ~/.config/tmux/plugins/tmux-plugins/tmux-battery/battery.tmux
|
||||||
#set -g pane-border-format "#{pane_index} #{pane_current_command}"
|
|
||||||
|
|||||||
148
zshrc
148
zshrc
@@ -1,148 +0,0 @@
|
|||||||
# ~~~ Minh Config
|
|
||||||
# Optimized .zshrc for improved startup time
|
|
||||||
# Enable profiling when needed: zmodload zsh/zprof
|
|
||||||
|
|
||||||
# ~~~~~~~~~~~~~~~~~~~~~~ Environment Setup ~~~~~~~~~~~~~~~~~~~~~~
|
|
||||||
# XDG Base Directory Specification
|
|
||||||
export XDG_CONFIG_HOME="$HOME/.config"
|
|
||||||
export XDG_CACHE_HOME="$HOME/.cache"
|
|
||||||
export XDG_DATA_HOME="$HOME/.local/share"
|
|
||||||
|
|
||||||
# Language and compilation
|
|
||||||
export LANG=en_US.UTF-8
|
|
||||||
|
|
||||||
# ~~~~~~~~~~~~~~~~~~~~~~ Homebrew Setup ~~~~~~~~~~~~~~~~~~~~~~
|
|
||||||
if [[ -f "/opt/homebrew/bin/brew" ]]; then
|
|
||||||
eval "$(/opt/homebrew/bin/brew shellenv)"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# ~~~~~~~~~~~~~~~~~~~~~~ Core Zsh Configuration ~~~~~~~~~~~~~~~~~~~~~~
|
|
||||||
# Enable completion system (call compinit only once)
|
|
||||||
autoload -Uz compinit
|
|
||||||
|
|
||||||
# Check if compinit needs to be run (once per day for performance)
|
|
||||||
for dump in ~/.zcompdump(N.mh+24); do
|
|
||||||
compinit
|
|
||||||
break
|
|
||||||
done
|
|
||||||
[[ -z "$dump" ]] && compinit -C
|
|
||||||
|
|
||||||
# Enhanced completion styling for better UX
|
|
||||||
zstyle ':completion:*' menu select
|
|
||||||
zstyle ':completion:*' matcher-list 'm:{a-zA-Z}={A-Za-z}' 'r:|[._-]=* r:|=* l:|=*'
|
|
||||||
zstyle ':completion:*' list-colors ${(s.:.)LS_COLORS}
|
|
||||||
zstyle ':completion:*' completer _complete _match _approximate
|
|
||||||
zstyle ':completion:*:match:*' original only
|
|
||||||
zstyle ':completion:*:approximate:*' max-errors 1 numeric
|
|
||||||
zstyle ':completion:*' use-cache on
|
|
||||||
zstyle ':completion:*' cache-path ~/.zsh/cache
|
|
||||||
|
|
||||||
# Ensure cache directory exists
|
|
||||||
[[ ! -d ~/.zsh/cache ]] && mkdir -p ~/.zsh/cache
|
|
||||||
|
|
||||||
# Group completions by category
|
|
||||||
zstyle ':completion:*' group-name ''
|
|
||||||
zstyle ':completion:*:descriptions' format '%B%d%b'
|
|
||||||
zstyle ':completion:*:messages' format '%d'
|
|
||||||
zstyle ':completion:*:warnings' format 'No matches for: %d'
|
|
||||||
|
|
||||||
# Process completion improvements
|
|
||||||
zstyle ':completion:*:*:kill:*:processes' list-colors '=(#b) #([0-9]#) ([0-9a-z-]#)*=01;34=0=01'
|
|
||||||
zstyle ':completion:*:*:*:*:processes' command "ps -u $USER -o pid,user,comm -w -w"
|
|
||||||
|
|
||||||
# ~~~~~~~~~~~~~~~~~~~~~~ Plugin Loading (Conditional) ~~~~~~~~~~~~~~~~~~~~~~
|
|
||||||
# Function to load plugins if they exist
|
|
||||||
load_plugin() {
|
|
||||||
[[ -f "$1" ]] && source "$1"
|
|
||||||
}
|
|
||||||
|
|
||||||
# Load zsh plugins
|
|
||||||
load_plugin "$HOMEBREW_PREFIX/share/zsh-autosuggestions/zsh-autosuggestions.zsh"
|
|
||||||
load_plugin "$HOMEBREW_PREFIX/share/zsh-syntax-highlighting/zsh-syntax-highlighting.zsh"
|
|
||||||
load_plugin "$HOMEBREW_PREFIX/share/zsh-history-substring-search/zsh-history-substring-search.zsh"
|
|
||||||
load_plugin "$XDG_CONFIG_HOME/zsh-z/zsh-z.plugin.zsh"
|
|
||||||
|
|
||||||
# ~~~~~~~~~~~~~~~~~~~~~~ Zsh-Autosuggestions Configuration ~~~~~~~~~~~~~~~~~~~~~~
|
|
||||||
# Configure autosuggestions for seamless history integration
|
|
||||||
ZSH_AUTOSUGGEST_HIGHLIGHT_STYLE="fg=#555555,bold"
|
|
||||||
ZSH_AUTOSUGGEST_STRATEGY=(history completion)
|
|
||||||
ZSH_AUTOSUGGEST_BUFFER_MAX_SIZE=20
|
|
||||||
ZSH_AUTOSUGGEST_USE_ASYNC=true
|
|
||||||
ZSH_AUTOSUGGEST_MANUAL_REBIND=1
|
|
||||||
|
|
||||||
# History-based suggestions prioritization
|
|
||||||
ZSH_AUTOSUGGEST_HISTORY_IGNORE="(ls|cd|pwd|exit|clear)"
|
|
||||||
|
|
||||||
# ~~~~~~~~~~~~~~~~~~~~~~ Completion Setup ~~~~~~~~~~~~~~~~~~~~~~
|
|
||||||
# Add homebrew completions if available
|
|
||||||
if command -v brew &>/dev/null; then
|
|
||||||
fpath+="$HOMEBREW_PREFIX/share/zsh-completions"
|
|
||||||
fpath+="$HOMEBREW_PREFIX/share/zsh/site-functions"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# ~~~~~~~~~~~~~~~~~~~~~~ Editor & Shell Configuration ~~~~~~~~~~~~~~~~~~~~~~
|
|
||||||
if [[ -n $SSH_CONNECTION ]]; then
|
|
||||||
export EDITOR='vim'
|
|
||||||
else
|
|
||||||
export EDITOR='nvim'
|
|
||||||
fi
|
|
||||||
|
|
||||||
# ~~~~~~~~~~~~~~~~~~~~~ History Configuration ~~~~~~~~~~~~~~~~~~~~~~
|
|
||||||
HISTFILE=~/.zsh_history
|
|
||||||
HISTSIZE=100000
|
|
||||||
SAVEHIST=100000
|
|
||||||
|
|
||||||
# Enhanced history options for better autosuggestions
|
|
||||||
setopt HIST_IGNORE_SPACE
|
|
||||||
setopt HIST_IGNORE_DUPS
|
|
||||||
setopt HIST_IGNORE_ALL_DUPS
|
|
||||||
setopt HIST_SAVE_NO_DUPS
|
|
||||||
setopt HIST_REDUCE_BLANKS
|
|
||||||
setopt HIST_VERIFY
|
|
||||||
|
|
||||||
# ~~~ Bas Config
|
|
||||||
|
|
||||||
|
|
||||||
export PATH="${KREW_ROOT:-$HOME/.krew}/bin:$PATH"
|
|
||||||
export PATH="${HOME}/Library/Python/3.9/bin:${PATH}"
|
|
||||||
export PATH="${HOME}/bin:${HOMEBREW_PREFIX}/opt/openssl/bin:$PATH"
|
|
||||||
|
|
||||||
eval "$(direnv hook zsh)"
|
|
||||||
|
|
||||||
# Disable auto tmux for now, my tiling window manager is enough
|
|
||||||
#[[ -v PS1 ]] && [[ ! -v TMUX ]] && tmux
|
|
||||||
|
|
||||||
# Function to get the current Git branch and remote
|
|
||||||
git_info() {
|
|
||||||
local branch
|
|
||||||
local remote
|
|
||||||
|
|
||||||
# Get the current branch
|
|
||||||
branch=$(git rev-parse --abbrev-ref HEAD 2>/dev/null)
|
|
||||||
|
|
||||||
# Get the current remote
|
|
||||||
remote=$(git config --get remote.origin.url 2>/dev/null)
|
|
||||||
|
|
||||||
# Format the output
|
|
||||||
if [[ -n $branch ]]; then
|
|
||||||
#echo "[$branch] $(basename "$remote")"
|
|
||||||
echo "[$branch]"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
setopt PROMPT_SUBST
|
|
||||||
PROMPT='%F{green}%n@%m %F{blue}%~ %F{yellow}$(git_info)%f %# '
|
|
||||||
export OPENAI_API_KEY=$(cat ~/.openai.key)
|
|
||||||
export KAGI_API_KEY=$(cat ~/.kagi.key)
|
|
||||||
|
|
||||||
eval "$(zoxide init zsh)"
|
|
||||||
alias cd=z
|
|
||||||
|
|
||||||
cat <<EOF
|
|
||||||
Reminders:
|
|
||||||
|
|
||||||
Use z
|
|
||||||
EOF
|
|
||||||
|
|
||||||
export SSH_AUTH_SOCK=~/Library/Group\ Containers/2BUA8C4S2C.com.1password/t/agent.sock
|
|
||||||
source ~/.zsh/zsh-vim-mode/zsh-vim-mode.plugin.zsh
|
|
||||||
alias k=kubectl
|
|
||||||
Reference in New Issue
Block a user