Compare commits

..

10 Commits

28 changed files with 1142 additions and 207 deletions

42
.bashrc
View File

@@ -120,10 +120,35 @@ function genpasswd() {
## Download m3u8 stream ## Download m3u8 stream
m3u8-download() { m3u8-download() {
youtube-dl --list-formats "$1" yt-dlp --list-formats "$1"
echo "enter format code:" echo "enter format code:"
read format_code read format_code
youtube-dl -f $format_code --hls-prefer-native "$1" yt-dlp -f $format_code --hls-prefer-native "$1"
}
md2pdf() {
if [[ -z "$1" ]]; then
echo "Usage: md2pdf input.md [output.pdf]"
return 1
fi
local input="$1"
local output="${2:-${input%.*}.pdf}"
# Adding -V mainfont resolves the empty font fallback error
pandoc "$input" -o "$output" --pdf-engine=typst -V mainfont="DejaVu Sans"
}
typstwatch() {
if [[ -z "$1" ]]; then
echo "Usage: tw <filename>"
return 1
fi
# Strip extension if provided and use the base name
local base="${1%.*}"
(zathura "${base}.pdf" &) && typst watch "${base}.typ"
} }
## GPG functions ## GPG functions
@@ -169,8 +194,9 @@ alias ls="ls --color=auto"
alias ll="ls -lFh" alias ll="ls -lFh"
alias la="ls -alh" alias la="ls -alh"
alias l="ls -CF" alias l="ls -CF"
alias ld="ls -d -F */" #alias ld="ls -d -F */"
alias lda="ls -l -d -p */" alias lda="ls -l -d -p */"
alias tree="tree -C"
export HISTCONTROL=ignoredups # fuckin history identical vole export HISTCONTROL=ignoredups # fuckin history identical vole
## network ## network
@@ -226,6 +252,7 @@ alias whatsmyip="dig +short myip.opendns.com @resolver1.opendns.com"
alias htmlvlna="vlna -s -r -x 266E6273703B" alias htmlvlna="vlna -s -r -x 266E6273703B"
alias fuck='doas $(history -p \!\!)' alias fuck='doas $(history -p \!\!)'
alias sudo="doas" alias sudo="doas"
alias treecat="tail -n +1 **/*"
## void xbps aliases ## void xbps aliases
#alias xi="doas xbps-install" #alias xi="doas xbps-install"
@@ -251,6 +278,15 @@ export PATH="$PATH:$HOME/.local/bin"
export PATH="$PATH:/var/lib/flatpak/exports/bin" export PATH="$PATH:/var/lib/flatpak/exports/bin"
export PATH="$PATH:$HOME/.local/share/flatpak/exports/bin" export PATH="$PATH:$HOME/.local/share/flatpak/exports/bin"
export PATH="$PATH:/home/fr/git/microlab/wpa_tui/dmenu_scripts" export PATH="$PATH:/home/fr/git/microlab/wpa_tui/dmenu_scripts"
export PATH="$PATH:$HOME/.local/bin/flutter/bin"
export PATH="$PATH:$HOME/.local/bin/cmdline-tools/bin"
export PATH="$PATH:$HOME/.config/emacs/bin"
export ANDROID_SDK_ROOT="$HOME/.local/android-sdk"
export ANDROID_HOME="$HOME/.local/android-sdk"
export PATH="$ANDROID_SDK_ROOT/platform-tools:$PATH"
export PATH="$ANDROID_SDK_ROOT/cmdline-tools/latest/bin:$PATH"
# Locales Exports # Locales Exports
export LC_ALL=en_US.UTF-8 export LC_ALL=en_US.UTF-8

View File

@@ -1,5 +1,5 @@
[settings] [settings]
cert-path = /home/fr/ICZUser_251118.pfx cert-path = /home/fr/docs/icz/certs/ICZUser_251118.pfx
stamp-path = stamp-path =
draw-stamp = 1 draw-stamp = 1
ask-dest-path = 0 ask-dest-path = 0

75
.config/doom/config.el Normal file
View File

@@ -0,0 +1,75 @@
;;; $DOOMDIR/config.el -*- lexical-binding: t; -*-
;; Place your private configuration here! Remember, you do not need to run 'doom
;; sync' after modifying this file!
;; Some functionality uses this to identify you, e.g. GPG configuration, email
;; clients, file templates and snippets. It is optional.
;; (setq user-full-name "John Doe"
;; user-mail-address "john@doe.com")
;; Doom exposes five (optional) variables for controlling fonts in Doom:
;;
;; - `doom-font' -- the primary font to use
;; - `doom-variable-pitch-font' -- a non-monospace font (where applicable)
;; - `doom-big-font' -- used for `doom-big-font-mode'; use this for
;; presentations or streaming.
;; - `doom-symbol-font' -- for symbols
;; - `doom-serif-font' -- for the `fixed-pitch-serif' face
;;
;; See 'C-h v doom-font' for documentation and more examples of what they
;; accept. For example:
;;
;;(setq doom-font (font-spec :family "Fira Code" :size 12 :weight 'semi-light)
;; doom-variable-pitch-font (font-spec :family "Fira Sans" :size 13))
;;
;; If you or Emacs can't find your font, use 'M-x describe-font' to look them
;; up, `M-x eval-region' to execute elisp code, and 'M-x doom/reload-font' to
;; refresh your font settings. If Emacs still can't find your font, it likely
;; wasn't installed correctly. Font issues are rarely Doom issues!
;; There are two ways to load a theme. Both assume the theme is installed and
;; available. You can either set `doom-theme' or manually load a theme with the
;; `load-theme' function. This is the default:
(setq doom-theme 'doom-one)
;; This determines the style of line numbers in effect. If set to `nil', line
;; numbers are disabled. For relative line numbers, set this to `relative'.
(setq display-line-numbers-type t)
;; If you use `org' and don't want your org files in the default location below,
;; change `org-directory'. It must be set before org loads!
(setq org-directory "~/org/")
;; Whenever you reconfigure a package, make sure to wrap your config in an
;; `with-eval-after-load' block, otherwise Doom's defaults may override your
;; settings. E.g.
;;
;; (with-eval-after-load 'PACKAGE
;; (setq x y))
;;
;; The exceptions to this rule:
;;
;; - Setting file/directory variables (like `org-directory')
;; - Setting variables which explicitly tell you to set them before their
;; package is loaded (see 'C-h v VARIABLE' to look them up).
;; - Setting doom variables (which start with 'doom-' or '+').
;;
;; Here are some additional functions/macros that will help you configure Doom.
;;
;; - `load!' for loading external *.el files relative to this one
;; - `add-load-path!' for adding directories to the `load-path', relative to
;; this file. Emacs searches the `load-path' when you load packages with
;; `require' or `use-package'.
;; - `map!' for binding new keys
;;
;; To get information about any of these functions/macros, move the cursor over
;; the highlighted symbol at press 'K' (non-evil users must press 'C-c c k').
;; This will open documentation for it, including demos of how they are used.
;; Alternatively, use `C-h o' to look up a symbol (functions, variables, faces,
;; etc).
;;
;; You can also try 'gd' (or 'C-c c d') to jump to their definition and see how
;; they are implemented.

200
.config/doom/init.el Normal file
View File

@@ -0,0 +1,200 @@
;;; init.el -*- lexical-binding: t; -*-
;; This file controls what Doom modules are enabled and what order they load
;; in. Remember to run 'doom sync' after modifying it!
;; NOTE: Press 'SPC h d h' (or 'C-h d h' for non-vim users) to access Doom's
;; documentation. There you'll find a link to Doom's Module Index where all of
;; our modules are listed, including what flags they support.
;; NOTE: Move your cursor over a module's name (or its flags) and press 'K' (or
;; 'C-c c k' for non-vim users) to view its documentation. This works on flags
;; as well (those symbols that start with a plus).
;;
;; Alternatively, press 'gd' (or 'C-c c d') on a module to browse its
;; directory (for easy access to its source code).
(doom! :input
;;bidi ; (tfel ot) thgir etirw uoy gnipleh
;;chinese
;;japanese
;;layout ; auie,ctsrnm is the superior home row
:completion
;;company ; the ultimate code completion backend
(corfu +orderless) ; complete with cap(f), cape and a flying feather!
;;helm ; the *other* search engine for love and life
;;ido ; the other *other* search engine...
;;ivy ; a search engine for love and life
vertico ; the search engine of the future
:ui
;;deft ; notational velocity for Emacs
doom ; what makes DOOM look the way it does
dashboard ; a nifty splash screen for Emacs
;;doom-quit ; DOOM quit-message prompts when you quit Emacs
;;(emoji +unicode) ; 🙂
hl-todo ; highlight TODO/FIXME/NOTE/DEPRECATED/HACK/REVIEW
;;indent-guides ; highlighted indent columns
;;ligatures ; ligatures and symbols to make your code pretty again
;;minimap ; show a map of the code on the side
modeline ; snazzy, Atom-inspired modeline, plus API
nav-flash ; blink cursor line after big motions
;;neotree ; a project drawer, like NERDTree for vim
ophints ; highlight the region an operation acts on
(popup +defaults) ; tame sudden yet inevitable temporary windows
smooth-scroll ; So smooth you won't believe it's not butter
tabs ; a tab bar for Emacs
treemacs ; a project drawer, like neotree but cooler
;;unicode ; extended unicode support for various languages
(vc-gutter +pretty) ; vcs diff in the fringe
vi-tilde-fringe ; fringe tildes to mark beyond EOB
;;window-select ; visually switch windows
workspaces ; tab emulation, persistence & separate workspaces
zen ; distraction-free coding or writing
:editor
(evil +everywhere); come to the dark side, we have cookies
file-templates ; auto-snippets for empty files
fold ; (nigh) universal code folding
;;(format +onsave) ; automated prettiness
;;god ; run Emacs commands without modifier keys
;;lispy ; vim for lisp, for people who don't like vim
;;multiple-cursors ; editing in many places at once
;;objed ; text object editing for the innocent
;;parinfer ; turn lisp into python, sort of
;;rotate-text ; cycle region at point between text candidates
snippets ; my elves. They type so I don't have to
(whitespace +guess +trim) ; a butler for your whitespace
;;word-wrap ; soft wrapping with language-aware indent
:emacs
dired ; making dired pretty [functional]
electric ; smarter, keyword-based electric-indent
;;eww ; the internet is gross
;;ibuffer ; interactive buffer management
tramp ; remote files at your arthritic fingertips
undo ; persistent, smarter undo for your inevitable mistakes
vc ; version-control and Emacs, sitting in a tree
:term
;;eshell ; the elisp shell that works everywhere
;;shell ; simple shell REPL for Emacs
;;term ; basic terminal emulator for Emacs
;;vterm ; the best terminal emulation in Emacs
:checkers
syntax ; tasing you for every semicolon you forget
;;(spell +flyspell) ; tasing you for misspelling mispelling
grammar ; tasing grammar mistake every you make
:tools
ansible
;;biblio ; Writes a PhD for you (citation needed)
;;collab ; buffers with friends
;;debugger ; stepping through code, to help you add bugs
;;direnv
docker
;;editorconfig ; let someone else argue about tabs vs spaces
;;ein ; tame Jupyter notebooks with emacs
(eval +overlay) ; run code, run (also, repls)
lookup ; navigate your code and its documentation
;;llm ; when I said you needed friends, I didn't mean...
;;(lsp +eglot) ; M-x vscode
magit ; a git porcelain for Emacs
;;make ; run make tasks from Emacs
;;pass ; password manager for nerds
;;pdf ; pdf enhancements
;;terraform ; infrastructure as code
;;tmux ; an API for interacting with tmux
;;tree-sitter ; syntax and parsing, sitting in a tree...
;;upload ; map local to remote projects via ssh/ftp
:os
(:if (featurep :system 'macos) macos) ; improve compatibility with macOS
;;tty ; improve the terminal Emacs experience
(tty +osc)
:lang
;;ada ; In strong typing we (blindly) trust
;;(agda +local) ; types of types of types of types...
;;beancount ; mind the GAAP
;;(cc +lsp) ; C > C++ == 1
;;clojure ; java with a lisp
;;common-lisp ; if you've seen one lisp, you've seen them all
;;coq ; proofs-as-programs
;;crystal ; ruby at the speed of c
;;csharp ; unity, .NET, and mono shenanigans
;;data ; config/data formats
;;(dart +flutter) ; paint ui and not much else
;;dhall
;;elixir ; erlang done right
;;elm ; care for a cup of TEA?
emacs-lisp ; drown in parentheses
;;erlang ; an elegant language for a more civilized age
;;ess ; emacs speaks statistics
;;factor
;;faust ; dsp, but you get to keep your soul
;;fortran ; in FORTRAN, GOD is REAL (unless declared INTEGER)
;;fsharp ; ML stands for Microsoft's Language
;;fstar ; (dependent) types and (monadic) effects and Z3
;;gdscript ; the language you waited for
;;(go +lsp) ; the hipster dialect
;;(graphql +lsp) ; Give queries a REST
;;(haskell +lsp) ; a language that's lazier than I am
;;hy ; readability of scheme w/ speed of python
;;idris ; a language you can depend on
json ; At least it ain't XML
;;janet ; Fun fact: Janet is me!
;;(java +lsp) ; the poster child for carpal tunnel syndrome
javascript ; all(hope(abandon(ye(who(enter(here))))))
;;julia ; a better, faster MATLAB
;;kotlin ; a better, slicker Java(Script)
;;latex ; writing papers in Emacs has never been so fun
;;lean ; for folks with too much to prove
;;ledger ; be audit you can be
lua ; one-based indices? one-based indices
markdown ; writing docs for people to ignore
;;nim ; python + lisp at the speed of c
;;nix ; I hereby declare "nix geht mehr!"
;;ocaml ; an objective camel
;;odin ; C, minus its footguns
org ; organize your plain life in plain text
php ; perl's insecure younger brother
;;plantuml ; diagrams for confusing people more
;;graphviz ; diagrams for confusing yourself even more
;;purescript ; javascript, but functional
python ; beautiful is better than ugly
;;qt ; the 'cutest' gui framework ever
;;racket ; a DSL for DSLs
;;raku ; the artist formerly known as perl6
;;rest ; Emacs as a REST client
;;rst ; ReST in peace
;;(ruby +rails) ; 1.step {|i| p "Ruby is #{i.even? ? 'love' : 'life'}"}
(rust +lsp) ; Fe2O3.unwrap().unwrap().unwrap().unwrap()
;;scala ; java, but good
;;(scheme +guile) ; a fully conniving family of lisps
sh ; she sells {ba,z,fi}sh shells on the C xor
;;sml
;;solidity ; do you need a blockchain? No.
;;swift ; who asked for emoji variables?
;;terra ; Earth and Moon in alignment for performance.
web ; the tubes
yaml ; JSON, but readable
;;zig ; C, but simpler
:email
;;(mu4e +org +gmail)
;;notmuch
;;(wanderlust +gmail)
:app
;;calendar
;;emms
;;everywhere ; *leave* Emacs!? You must be joking
;;irc ; how neckbeards socialize
;;(rss +org) ; emacs as an RSS reader
:config
;;literate
(default +bindings +smartparens))

54
.config/doom/packages.el Normal file
View File

@@ -0,0 +1,54 @@
;; -*- no-byte-compile: t; -*-
;;; $DOOMDIR/packages.el
;; To install a package:
;;
;; 1. Declare them here in a `package!' statement,
;; 2. Run 'doom sync' in the shell,
;; 3. Restart Emacs.
;;
;; Use 'C-h f package\!' to look up documentation for the `package!' macro.
;; To install SOME-PACKAGE from MELPA, ELPA or emacsmirror:
;; (package! some-package)
;; To install a package directly from a remote git repo, you must specify a
;; `:recipe'. You'll find documentation on what `:recipe' accepts here:
;; https://github.com/radian-software/straight.el#the-recipe-format
;; (package! another-package
;; :recipe (:host github :repo "username/repo"))
;; If the package you are trying to install does not contain a PACKAGENAME.el
;; file, or is located in a subdirectory of the repo, you'll need to specify
;; `:files' in the `:recipe':
;; (package! this-package
;; :recipe (:host github :repo "username/repo"
;; :files ("some-file.el" "src/lisp/*.el")))
;; If you'd like to disable a package included with Doom, you can do so here
;; with the `:disable' property:
;; (package! builtin-package :disable t)
;; You can override the recipe of a built in package without having to specify
;; all the properties for `:recipe'. These will inherit the rest of its recipe
;; from Doom or MELPA/ELPA/Emacsmirror:
;; (package! builtin-package :recipe (:nonrecursive t))
;; (package! builtin-package-2 :recipe (:repo "myfork/package"))
;; Specify a `:branch' to install a package from a particular branch or tag.
;; This is required for some packages whose default branch isn't 'master' (which
;; our package manager can't deal with; see radian-software/straight.el#279)
;; (package! builtin-package :recipe (:branch "develop"))
;; Use `:pin' to specify a particular commit to install.
;; (package! builtin-package :pin "1a2b3c4d5e")
;; Doom's packages are pinned to a specific commit and updated from release to
;; release. The `unpin!' macro allows you to unpin single packages...
;; (unpin! pinned-package)
;; ...or multiple packages
;; (unpin! pinned-package another-pinned-package)
;; ...Or *all* packages (NOT RECOMMENDED; will likely break things)
;; (unpin! t)

435
.config/mango/config.conf Normal file
View File

@@ -0,0 +1,435 @@
# mango (0.12.9) configuration
# Keybindings mirror the user's river (~/.config/river/init) and dwm
# (~/git/dwm/config.h) setups: MOD1 (Alt) as primary modifier, dwm-style
# tag handling, river-style window movement.
#
# Reference: https://github.com/mangowm/mango/wiki
# ============================================================================
# Window effects (scenefx)
# ============================================================================
blur=0
blur_layer=0
blur_optimized=1
blur_params_num_passes=2
blur_params_radius=5
blur_params_noise=0.02
blur_params_brightness=0.9
blur_params_contrast=0.9
blur_params_saturation=1.2
shadows=0
layer_shadows=0
shadow_only_floating=1
shadows_size=10
shadows_blur=15
shadows_position_x=0
shadows_position_y=0
shadowscolor=0x000000ff
border_radius=0
no_radius_when_single=0
focused_opacity=1.0
unfocused_opacity=1.0
# ============================================================================
# Animations
# ============================================================================
animations=1
layer_animations=0
# I hate animations, this will disable them
layer_animations=0
animations=0
# Theyre gone
animation_type_open=zoom
animation_type_close=slide
layer_animation_type_open=slide
layer_animation_type_close=slide
animation_fade_in=1
animation_fade_out=1
tag_animation_direction=1
zoom_initial_ratio=0.3
zoom_end_ratio=0.8
fadein_begin_opacity=0.5
fadeout_begin_opacity=0.8
animation_duration_move=200
animation_duration_open=100
animation_duration_tag=0
animation_duration_close=200
animation_duration_focus=0
animation_curve_open=0.46,1.0,0.29,1
animation_curve_move=0.46,1.0,0.29,1
animation_curve_tag=0.46,1.0,0.29,1
animation_curve_close=0.08,0.92,0,1
animation_curve_focus=0.46,1.0,0.29,1
animation_curve_opafadeout=0.5,0.5,0.5,0.5
animation_curve_opafadein=0.46,1.0,0.29,1
# ============================================================================
# Layouts
# ============================================================================
# Scroller
scroller_structs=20
scroller_default_proportion=0.8
scroller_focus_center=0
scroller_prefer_center=0
edge_scroller_pointer_focus=1
scroller_default_proportion_single=1.0
scroller_proportion_preset=0.5,0.8,1.0
# Master-Stack (matches river filtile main-ratio 55, main-location left)
new_is_master=1
default_mfact=0.55
default_nmaster=1
smartgaps=1
# ============================================================================
# Overview
# ============================================================================
hotarea_size=10
enable_hotarea=0
hotarea_corner=0
ov_tab_mode=0
overviewgappi=5
overviewgappo=30
# ============================================================================
# Misc behaviour
# ============================================================================
no_border_when_single=1
axis_bind_apply_timeout=100
focus_on_activate=1
idleinhibit_ignore_visible=0
sloppyfocus=1
warpcursor=0
focus_cross_monitor=0
focus_cross_tag=0
enable_floating_snap=0
snap_distance=30
cursor_size=24
drag_tile_to_tile=1
# ============================================================================
# Keyboard (matches river: set-repeat 30 200, layout us,cz(qwerty))
# ============================================================================
repeat_rate=30
repeat_delay=200
numlockon=0
xkb_rules_layout=us,cz(qwerty)
#xkb_rules_options=grp:win_space_toggle
binds=alt,u,spawn,mmsg -s -d switch_keyboard_layout,1
binds=alt,c,spawn,mmsg -s -d switch_keyboard_layout,2
# ============================================================================
# Trackpad
# ============================================================================
disable_trackpad=0
tap_to_click=1
tap_and_drag=1
drag_lock=1
trackpad_natural_scrolling=0
disable_while_typing=1
left_handed=0
middle_button_emulation=0
swipe_min_threshold=1
# ============================================================================
# Mouse
# ============================================================================
mouse_natural_scrolling=0
# ============================================================================
# Appearance / colors (mostly preserved from previous config)
# ============================================================================
gappih=5
gappiv=5
gappoh=10
gappov=10
scratchpad_width_ratio=0.8
scratchpad_height_ratio=0.9
borderpx=1
rootcolor=0x1D1F21ff
bordercolor=0x586e75ff
focuscolor=0x93a1a1ff
maximizescreencolor=0x89aa61ff
urgentcolor=0xad401fff
scratchpadcolor=0x516c93ff
globalcolor=0xb153a7ff
overlaycolor=0x14a57cff
# ============================================================================
# Per-tag layout (default tile, matches dwm and river filtile)
# Layouts available: tile, scroller, grid, deck, monocle, center_tile,
# vertical_tile, vertical_scroller, dwindle
# ============================================================================
tagrule=id:1,layout_name:tile
tagrule=id:2,layout_name:tile
tagrule=id:3,layout_name:tile
tagrule=id:4,layout_name:tile
tagrule=id:5,layout_name:tile
tagrule=id:6,layout_name:tile
tagrule=id:7,layout_name:tile
tagrule=id:8,layout_name:tile
tagrule=id:9,layout_name:tile
# ============================================================================
# Window rules (mirrors river rule-add and dwm rules)
# ============================================================================
# Floating apps (from dwm config)
windowrule=isfloating:1,appid:Arandr
windowrule=isfloating:1,appid:Pavucontrol
windowrule=isfloating:1,appid:mpv
# River rules
windowrule=isfloating:1,appid:float.*
windowrule=isfloating:1,title:yazi
windowrule=isfloating:1,title:river
# ============================================================================
# Key Bindings
#
# Modifier convention follows river/dwm: MOD = ALT (Mod1)
# Format: bind=MODIFIERS,KEY,COMMAND,PARAMETERS
# Flags: bindl = works while screen locked
# ============================================================================
# --- Compositor control --------------------------------------------------
bind=SUPER,r,reload_config
# river: Mod1+Shift E exit
bind=ALT+SHIFT,e,quit
# river/dwm: Mod1+Shift C close
bind=ALT+SHIFT,c,killclient
# --- Launchers -----------------------------------------------------------
# river/dwm: Mod1 p (menu)
#bind=ALT,p,spawn,fuzzel
bind=ALT,p,spawn,wmenu-run -F -il 16 -f 'LiterationMono Nerd Font 12' -n bbbbbbff -N 222222ff -s eeeeeeff -S 444444ff -m eeeeeeff -M 444444ff
# river/dwm: Mod1+Shift Return
bind=ALT+SHIFT,Return,spawn,foot
# Yazi file manager in floating foot (river: Mod1 r)
#bind=ALT,r,spawn,foot -T yazi -W 150x50 -e yazi
bind=ALT,r,spawn,foot -T yazi -W 150x50 -e ranger
# --- Focus ---------------------------------------------------------------
# river: Mod1 J/K focus-view next/previous (dwm: focusstack +1/-1)
bind=ALT,k,focusstack,next
bind=ALT,j,focusstack,prev
# Direction-based focus (mango bonus, useful complement)
bind=ALT,Left,focusdir,left
bind=ALT,Right,focusdir,right
bind=ALT,Up,focusdir,up
bind=ALT,Down,focusdir,down
# --- Swap / move in stack ------------------------------------------------
# river: Mod1+Shift J/K swap next/previous (dwm: movestack)
bind=ALT+SHIFT,j,exchange_stack_client,next
bind=ALT+SHIFT,k,exchange_stack_client,prev
# Direction-based swap
bind=ALT+SHIFT,Left,exchange_client,left
bind=ALT+SHIFT,Right,exchange_client,right
bind=ALT+SHIFT,Up,exchange_client,up
bind=ALT+SHIFT,Down,exchange_client,down
# --- Master / layout tweaks (river filtile ↔ dwm) ------------------------
# river: Mod1 H/L send-layout-cmd filtile main-ratio -/+5
# dwm: MOD1 H/L setmfact -/+0.05
bind=ALT,h,setmfact,-0.05
bind=ALT,l,setmfact,+0.05
# river: Mod1 I/D main-count +/-1 dwm: incnmaster +/-1
bind=ALT,i,incnmaster,+1
bind=ALT,d,incnmaster,-1
# river: Mod1 Return zoom (bump to top of stack)
bind=ALT,Return,zoom
# river: Mod1 Tab focus-previous-tags dwm: MOD1 Tab view (last tags)
bind=ALT,Tab,view,-1
# --- Layout switching (dwm: t=tile, m=monocle; river: M=monocle) ---------
bind=ALT,t,setlayout,tile
bind=ALT,m,setlayout,monocle
# dwm: MOD1 Space cycles layout
bind=ALT,space,switch_layout
# --- Float / fullscreen --------------------------------------------------
# river: Mod1+Shift Space toggle-float dwm: MOD1+Shift Space togglefloating
bind=ALT+SHIFT,space,togglefloating
# river: Mod1 F toggle-fullscreen dwm: MOD1 F (was floating layout)
bind=ALT,f,togglefullscreen
bind=ALT+SHIFT,f,togglefakefullscreen
# --- Tags 1-9 (river/dwm identical scheme) -------------------------------
# Mod1+N : view tag N
# Mod1+Shift+N : send window to tag N
# Mod1+Ctrl+N : toggle view of tag N
# Mod1+Ctrl+Shift+N : toggle tag N on focused window
bind=ALT,1,view,1
bind=ALT,2,view,2
bind=ALT,3,view,3
bind=ALT,4,view,4
bind=ALT,5,view,5
bind=ALT,6,view,6
bind=ALT,7,view,7
bind=ALT,8,view,8
bind=ALT,9,view,9
bind=ALT+SHIFT,1,tag,1
bind=ALT+SHIFT,2,tag,2
bind=ALT+SHIFT,3,tag,3
bind=ALT+SHIFT,4,tag,4
bind=ALT+SHIFT,5,tag,5
bind=ALT+SHIFT,6,tag,6
bind=ALT+SHIFT,7,tag,7
bind=ALT+SHIFT,8,tag,8
bind=ALT+SHIFT,9,tag,9
bind=ALT+CTRL,1,toggleview,1
bind=ALT+CTRL,2,toggleview,2
bind=ALT+CTRL,3,toggleview,3
bind=ALT+CTRL,4,toggleview,4
bind=ALT+CTRL,5,toggleview,5
bind=ALT+CTRL,6,toggleview,6
bind=ALT+CTRL,7,toggleview,7
bind=ALT+CTRL,8,toggleview,8
bind=ALT+CTRL,9,toggleview,9
bind=ALT+CTRL+SHIFT,1,toggletag,1
bind=ALT+CTRL+SHIFT,2,toggletag,2
bind=ALT+CTRL+SHIFT,3,toggletag,3
bind=ALT+CTRL+SHIFT,4,toggletag,4
bind=ALT+CTRL+SHIFT,5,toggletag,5
bind=ALT+CTRL+SHIFT,6,toggletag,6
bind=ALT+CTRL+SHIFT,7,toggletag,7
bind=ALT+CTRL+SHIFT,8,toggletag,8
bind=ALT+CTRL+SHIFT,9,toggletag,9
# All tags (river/dwm: 0)
bind=ALT,0,view,0
bind=ALT+SHIFT,0,toggletag,0
# --- Monitor focus / move (river: Period/Comma; dwm: same) ---------------
bind=ALT,period,focusmon,right
bind=ALT,comma,focusmon,left
bind=ALT+SHIFT,period,tagmon,right
bind=ALT+SHIFT,comma,tagmon,left
# --- Overview (mango bonus) ----------------------------------------------
bind=SUPER,Tab,toggleoverview
# --- Scratchpad ----------------------------------------------------------
bind=ALT,z,toggle_scratchpad
bind=SUPER,i,minimized
bind=SUPER+SHIFT,i,restore_minimized
# --- Window state extras -------------------------------------------------
bind=SUPER,g,toggleglobal
bind=SUPER,o,toggleoverlay
bind=ALT,a,togglemaximizescreen
# --- Gaps ----------------------------------------------------------------
bind=ALT+SHIFT,x,incgaps,1
bind=ALT+SHIFT,z,incgaps,-1
bind=ALT+SHIFT,r,togglegaps
# --- Move / resize floating windows (river-style snap & arrow nudge) -----
# river: Mod1+Super H/J/K/L move 100 here: ctrl+shift arrows nudge 50
bind=CTRL+SHIFT,Up,movewin,+0,-50
bind=CTRL+SHIFT,Down,movewin,+0,+50
bind=CTRL+SHIFT,Left,movewin,-50,+0
bind=CTRL+SHIFT,Right,movewin,+50,+0
# river: Mod1+Super+Shift H/J/K/L resize
bind=CTRL+ALT,Up,resizewin,+0,-50
bind=CTRL+ALT,Down,resizewin,+0,+50
bind=CTRL+ALT,Left,resizewin,-50,+0
bind=CTRL+ALT,Right,resizewin,+50,+0
# --- Lock screen (river: Mod1+Shift L spawn waylock) ---------------------
# Wrapper script: locks immediately, then runs a 10 s idle blanker while
# locked (kanshi paused during blank to avoid Lenovo dock profile flip).
bindl=ALT+SHIFT,l,spawn,~/.config/mango/scripts/lock.sh
# --- Media keys (work in any mode) ---------------------------------------
bindl=NONE,XF86AudioRaiseVolume,spawn,pamixer -i 5
bindl=NONE,XF86AudioLowerVolume,spawn,pamixer -d 5
bindl=NONE,XF86AudioMute,spawn,pamixer --toggle-mute
bindl=NONE,XF86AudioPlay,spawn,playerctl play-pause
bindl=NONE,XF86AudioPrev,spawn,playerctl previous
bindl=NONE,XF86AudioNext,spawn,playerctl next
bindl=NONE,XF86AudioMedia,spawn,playerctl play-pause
# --- Screenshots (grim/slurp, mirrors river) -----------------------------
#bind=NONE,Print,spawn_shell,grim - | tee /home/$USER/scrot/$(date +"%F_%T").png | wl-copy
#bind=ALT,Print,spawn_shell,grim -g "$(slurp -d)" - | tee /home/$USER/scrot/$(date +"%F_%T").png | wl-copy
#bind=ALT+SHIFT,Print,spawn,hyprpicker -anl
bind=None,Print,spawn_shell, file="/home/$USER/Pictures/Screenshots/$(date +%F_%T).png"; grim -g "$(slurp -d)" "$file" && wl-copy -t image/png < "$file"
bind=Alt,Print,spawn_shell, grim - | tee /home/$USER/Pictures/Screenshots/$(date +"%F_%T").png | wl-copy -t image/png
bind=Alt+SHIFT,Print,spawn_shell, grim -g "$(slurp -p)" -t ppm - | convert - -format '%[pixel:p{0,0}]' txt:- | grep -o '#[0-9A-F]\{6\}' | tr -d '\n' | wl-copy -t text/plain
# ============================================================================
# Mouse bindings (river: Mod1 left=move, right=resize, middle=toggle float)
# ============================================================================
mousebind=ALT,btn_left,moveresize,curmove
mousebind=ALT,btn_right,moveresize,curresize
mousebind=ALT,btn_middle,togglefloating
# Maximize/restore on plain middle-click anywhere (overview/title contexts)
mousebind=SUPER,btn_middle,togglemaximizescreen,0
# ============================================================================
# Axis (scroll) bindings — wheel over root cycles tags
# ============================================================================
axisbind=SUPER,UP,viewtoleft_have_client
axisbind=SUPER,DOWN,viewtoright_have_client
# ============================================================================
# Layer rules
# ============================================================================
layerrule=animation_type_open:zoom,layer_name:fuzzel
layerrule=animation_type_close:zoom,layer_name:fuzzel
# ============================================================================
# Autostart (mirrors river spawn ... block)
# ============================================================================
env=XDG_CURRENT_DESKTOP,mango
env=XDG_SESSION_TYPE,wayland
exec-once=dbus-update-activation-environment WAYLAND_DISPLAY XDG_CURRENT_DESKTOP
exec-once=/usr/lib/xdg-desktop-portal-wlr
exec-once=/usr/lib/xdg-desktop-portal
# Audio
exec-once=pipewire
#exec-once=pipewire-pulse
exec-once=pkill waybar_audio_event_bridge
exec-once=/home/fr/.local/bin/waybar_audio_event_bridge
# Services
exec-once=dunst
exec-once=udiskie -ANt
# Color temperature
exec-once=wlsunset -l 50.08 -L 14.42 -t 5000 -T 6500
# Wallpaper
exec-once=swaybg -c 1D1F21
# Status bar (mango-specific waybar config; river bar config is left intact)
exec-once=waybar -c ~/.config/waybar/config-mango.jsonc
# Idle: blank after 20 min when unlocked (no auto-lock). Manual lock
# (Alt+Shift+L) and suspend route through ~/.config/mango/scripts/lock.sh
# which adds a 10 s idle blanker for the locked session. Kanshi is
# STOP/CONT-bracketed around every wlopm cycle to keep the Lenovo
# USB-C dock from re-triggering monitor profile switches when DPMS
# drops the DP-MST link.
exec-once=swayidle -w timeout 1200 'pkill -STOP kanshi 2>/dev/null; wlopm --off "*"' resume 'wlopm --on "*"; sleep 0.5; pkill -CONT kanshi 2>/dev/null' before-sleep '~/.config/mango/scripts/lock.sh &'
# Multi-monitor configuration
exec-once=kanshi

31
.config/mango/scripts/lock.sh Executable file
View File

@@ -0,0 +1,31 @@
#!/usr/bin/env bash
# Manual screen-lock for mango.
# - Locks via waylock (immediate lockscreen).
# - While locked, runs an aggressive 10 s idle blanker.
# - Pauses kanshi during blank to prevent profile flip-flop on the
# Lenovo USB-C dock (DP-MST drops link on DPMS off).
# - Cleans up on unlock.
set -e
# Don't stack lockers if one is already running (re-press, or
# before-sleep firing while already locked).
pgrep -x waylock >/dev/null && exit 0
# Short-timeout idle blanker, only alive while we're locked.
swayidle -w \
timeout 10 'pkill -STOP kanshi 2>/dev/null; wlopm --off "*"' \
resume 'wlopm --on "*"; sleep 0.5; pkill -CONT kanshi 2>/dev/null' \
>/dev/null 2>&1 &
LOCK_IDLE_PID=$!
# Cleanup on unlock: stop the idle watcher, ensure outputs are on,
# and resume kanshi in case the trap fires mid-blank.
trap '
kill "$LOCK_IDLE_PID" 2>/dev/null || true
wlopm --on "*" 2>/dev/null || true
pkill -CONT kanshi 2>/dev/null || true
' EXIT
# Block here until waylock exits on successful auth.
waylock

3
.config/nvim/.luarc.json Normal file
View File

@@ -0,0 +1,3 @@
{
"format.enable": false
}

View File

@@ -1,16 +1,9 @@
# AstroNvim Template # AstroNvim Template
**NOTE:** This is for AstroNvim v4+ **NOTE:** This is for AstroNvim v6+
A template for getting started with [AstroNvim](https://github.com/AstroNvim/AstroNvim) A template for getting started with [AstroNvim](https://github.com/AstroNvim/AstroNvim)
## System dependencies
- `lazygit` for lazygit integration
- `typescript-language-server` and `typescript` installed globally from npm
```bash
npm install -g typescript-language-server typescript
```
## 🛠️ Installation ## 🛠️ Installation
#### Make a backup of your current nvim and shared folder #### Make a backup of your current nvim and shared folder

View File

@@ -1,10 +1,18 @@
-- This file simply bootstraps the installation of Lazy.nvim and then calls other files for execution -- This file simply bootstraps the installation of Lazy.nvim and then calls other files for execution
-- This file doesn't necessarily need to be touched, BE CAUTIOUS editing this file and proceed at your own risk. -- This file doesn't necessarily need to be touched, BE CAUTIOUS editing this file and proceed at your own risk.
local lazypath = vim.env.LAZY or vim.fn.stdpath "data" .. "/lazy/lazy.nvim" local lazypath = vim.env.LAZY or vim.fn.stdpath "data" .. "/lazy/lazy.nvim"
if not (vim.env.LAZY or (vim.uv or vim.loop).fs_stat(lazypath)) then if not (vim.env.LAZY or (vim.uv or vim.loop).fs_stat(lazypath)) then
-- stylua: ignore -- stylua: ignore
vim.fn.system({ "git", "clone", "--filter=blob:none", "https://github.com/folke/lazy.nvim.git", "--branch=stable", lazypath }) local result = vim.fn.system({ "git", "clone", "--filter=blob:none", "https://github.com/folke/lazy.nvim.git", "--branch=stable", lazypath })
if vim.v.shell_error ~= 0 then
-- stylua: ignore
vim.api.nvim_echo({ { ("Error cloning lazy.nvim:\n%s\n"):format(result), "ErrorMsg" }, { "Press any key to exit...", "MoreMsg" } }, true, {})
vim.fn.getchar()
vim.cmd.quit()
end
end end
vim.opt.rtp:prepend(lazypath) vim.opt.rtp:prepend(lazypath)
-- validate that lazy is available -- validate that lazy is available
@@ -17,4 +25,3 @@ end
require "lazy_setup" require "lazy_setup"
require "polish" require "polish"
require "autocmds"

View File

@@ -1,68 +1,45 @@
{ {
"AstroNvim": { "branch": "main", "commit": "c5e610f614e74c9dd9bf11760c4d0ad2c98c0abe" }, "AstroNvim": { "branch": "main", "commit": "bf37390b310fc2e3a1c57b21362b525bbfe6eed4" },
"Comment.nvim": { "branch": "master", "commit": "e30b7f2008e52442154b66f7c519bfd2f1e32acb" }, "LuaSnip": { "branch": "master", "commit": "5a1e39223db9a0498024a77b8441169d260c8c25" },
"LuaSnip": { "branch": "master", "commit": "458560534a73f7f8d7a11a146c801db00b081df0" }, "aerial.nvim": { "branch": "master", "commit": "645d108a5242ec7b378cbe643eb6d04d4223f034" },
"aerial.nvim": { "branch": "master", "commit": "6ab1a0ce4874d21610fc5a67a6c82c7b943c635b" }, "astrocore": { "branch": "main", "commit": "b061e0c185cd5fecbac7489151a98117ce799a47" },
"alpha-nvim": { "branch": "main", "commit": "de72250e054e5e691b9736ee30db72c65d560771" }, "astrolsp": { "branch": "main", "commit": "ebc1676127b3bfbd46e3e26589b104853cac3730" },
"astrocommunity": { "branch": "main", "commit": "d451f1d8e90e21c0cad730add858d8f952c66f01" }, "astrotheme": { "branch": "main", "commit": "cf0e65a7b3ce2f830b052f4da937729eee1e7a7d" },
"astrocore": { "branch": "main", "commit": "44a3dc0bf1591022b2a6bc89dccdfac1be17bec9" }, "astroui": { "branch": "main", "commit": "920dd5df6629a9076a11ea10f0d21f4225203585" },
"astrolsp": { "branch": "main", "commit": "909fbe64f3f87d089ff3777751261544557117cc" }, "better-escape.nvim": { "branch": "master", "commit": "199dcc2643dec5d8dbdab4ec672cf405224dcb3b" },
"astrotheme": { "branch": "main", "commit": "4a2af93815e4e6adfe69c836e46047a9451de858" }, "blink.cmp": { "branch": "main", "commit": "451168851e8e2466bc97ee3e026c3dcb9141ce07" },
"astroui": { "branch": "main", "commit": "e923a84c488d879a260fc9cfb2dc27dd870fb6ac" }, "blink.compat": { "branch": "main", "commit": "2ed6d9a28b07fa6f3bface818470605f8896408c" },
"cmp-buffer": { "branch": "main", "commit": "3022dbc9166796b644a841a02de8dd1cc1d311fa" },
"cmp-dap": { "branch": "master", "commit": "ea92773e84c0ad3288c3bc5e452ac91559669087" }, "cmp-dap": { "branch": "master", "commit": "ea92773e84c0ad3288c3bc5e452ac91559669087" },
"cmp-nvim-lsp": { "branch": "main", "commit": "99290b3ec1322070bcfb9e846450a46f6efa50f0" }, "friendly-snippets": { "branch": "main", "commit": "6cd7280adead7f586db6fccbd15d2cac7e2188b9" },
"cmp-path": { "branch": "main", "commit": "91ff86cd9c29299a64f968ebb45846c485725f23" }, "gitsigns.nvim": { "branch": "main", "commit": "a462f416e2ce4744531c6256252dee99a7d34a83" },
"cmp_luasnip": { "branch": "master", "commit": "98d9cb5c2c38532bd9bdb481067b20fea8f32e90" }, "guess-indent.nvim": { "branch": "main", "commit": "84a4987ff36798c2fc1169cbaff67960aed9776f" },
"dressing.nvim": { "branch": "master", "commit": "3a45525bb182730fe462325c99395529308f431e" },
"flutter-tools.nvim": { "branch": "main", "commit": "6faf2c70bd56f1fe78620591a2bb73f4dc6f4870" },
"friendly-snippets": { "branch": "main", "commit": "efff286dd74c22f731cdec26a70b46e5b203c619" },
"gitsigns.nvim": { "branch": "main", "commit": "7010000889bfb6c26065e0b0f7f1e6aa9163edd9" },
"guess-indent.nvim": { "branch": "main", "commit": "6cd61f7a600bb756e558627cd2e740302c58e32d" },
"heirline.nvim": { "branch": "master", "commit": "fae936abb5e0345b85c3a03ecf38525b0828b992" }, "heirline.nvim": { "branch": "master", "commit": "fae936abb5e0345b85c3a03ecf38525b0828b992" },
"hover.nvim": { "branch": "main", "commit": "3b49066e09e03e63be6d6f43ae2b8bcd58301f63" },
"indent-blankline.nvim": { "branch": "master", "commit": "005b56001b2cb30bfa61b7986bc50657816ba4ba" },
"lazy.nvim": { "branch": "main", "commit": "85c7ff3711b730b4030d03144f6db6375044ae82" }, "lazy.nvim": { "branch": "main", "commit": "85c7ff3711b730b4030d03144f6db6375044ae82" },
"lazydev.nvim": { "branch": "main", "commit": "01bc2aacd51cf9021eb19d048e70ce3dd09f7f93" }, "lazydev.nvim": { "branch": "main", "commit": "ff2cbcba459b637ec3fd165a2be59b7bbaeedf0d" },
"lsp_signature.nvim": { "branch": "master", "commit": "a793d02b6a5e639fa9d3f2a89a839fa688ab2d0a" }, "mason-lspconfig.nvim": { "branch": "main", "commit": "25f609e7fca78af7cede4f9fa3af8a94b1c4950b" },
"lspkind.nvim": { "branch": "master", "commit": "d79a1c3299ad0ef94e255d045bed9fa26025dab6" },
"mason-lspconfig.nvim": { "branch": "main", "commit": "1a31f824b9cd5bc6f342fc29e9a53b60d74af245" },
"mason-null-ls.nvim": { "branch": "main", "commit": "2b8433f76598397fcc97318d410e0c4f7a4bea6a" }, "mason-null-ls.nvim": { "branch": "main", "commit": "2b8433f76598397fcc97318d410e0c4f7a4bea6a" },
"mason-nvim-dap.nvim": { "branch": "main", "commit": "4c2cdc69d69fe00c15ae8648f7e954d99e5de3ea" }, "mason-nvim-dap.nvim": { "branch": "main", "commit": "e51f9b259f066c4347f9a79ffde54c29a0619384" },
"mason.nvim": { "branch": "main", "commit": "fc98833b6da5de5a9c5b1446ac541577059555be" }, "mason-tool-installer.nvim": { "branch": "main", "commit": "443f1ef8b5e6bf47045cb2217b6f748a223cf7dc" },
"mini.animate": { "branch": "main", "commit": "0365de8b69331c25d0d0d7573407a7dc7719e578" }, "mason.nvim": { "branch": "main", "commit": "44d1e90e1f66e077268191e3ee9d2ac97cc18e65" },
"mini.bufremove": { "branch": "main", "commit": "285bdac9596ee7375db50c0f76ed04336dcd2685" }, "mini.icons": { "branch": "main", "commit": "ff2e4f1d29f659cc2bad0f9256f2f6195c6b2428" },
"neo-tree.nvim": { "branch": "main", "commit": "f3df514fff2bdd4318127c40470984137f87b62e" }, "neo-tree.nvim": { "branch": "main", "commit": "84c75e7a7e443586f60508d12fc50f90d9aee14e" },
"neoconf.nvim": { "branch": "main", "commit": "f630568a4d04154803886f21ca60923f12709f0f" }, "none-ls.nvim": { "branch": "main", "commit": "c9317c2a8629d4e39e7cf47be74cb67f3ab37cda" },
"none-ls.nvim": { "branch": "main", "commit": "a117163db44c256d53c3be8717f3e1a2a28e6299" }, "nui.nvim": { "branch": "main", "commit": "f535005e6ad1016383f24e39559833759453564e" },
"nui.nvim": { "branch": "main", "commit": "a0fd35fcbb4cb479366f1dc5f20145fd718a3733" }, "nvim-autopairs": { "branch": "master", "commit": "59bce2eef357189c3305e25bc6dd2d138c1683f5" },
"nvim-autopairs": { "branch": "master", "commit": "68f0e5c3dab23261a945272032ee6700af86227a" }, "nvim-dap": { "branch": "master", "commit": "4f5deb110d9ff8994d96c21df95e2271d11214f9" },
"nvim-cmp": { "branch": "main", "commit": "1e1900b0769324a9675ef85b38f99cca29e203b3" }, "nvim-dap-ui": { "branch": "master", "commit": "f5b6673f374626515401c5bc51b005f784a4f252" },
"nvim-colorizer.lua": { "branch": "master", "commit": "517df88cf2afb36652830df2c655df2da416a0ae" }, "nvim-highlight-colors": { "branch": "main", "commit": "e2cb22089cc2358b2b995c09578224f142de6039" },
"nvim-dap": { "branch": "master", "commit": "6a5bba0ddea5d419a783e170c20988046376090d" }, "nvim-lspconfig": { "branch": "master", "commit": "0203a9608d63eda57679b01e69f33a7b4c34b0d1" },
"nvim-dap-ui": { "branch": "master", "commit": "bc81f8d3440aede116f821114547a476b082b319" },
"nvim-lspconfig": { "branch": "master", "commit": "185b2af444b27d6541c02d662b5b68190e5cf0c4" },
"nvim-nio": { "branch": "master", "commit": "21f5324bfac14e22ba26553caf69ec76ae8a7662" }, "nvim-nio": { "branch": "master", "commit": "21f5324bfac14e22ba26553caf69ec76ae8a7662" },
"nvim-notify": { "branch": "master", "commit": "a3020c2cf4dfc4c4f390c4a21e84e35e46cf5d17" }, "nvim-treesitter": { "branch": "main", "commit": "c82bf96f0a773d85304feeb695e1e23b2207ac35" },
"nvim-treesitter": { "branch": "master", "commit": "f8aaf5ce4e27cd20de917946b2ae5c968a2c2858" }, "nvim-treesitter-textobjects": { "branch": "main", "commit": "93d60a475f0b08a8eceb99255863977d3a25f310" },
"nvim-treesitter-textobjects": { "branch": "master", "commit": "9937e5e356e5b227ec56d83d0a9d0a0f6bc9cad4" }, "nvim-ts-autotag": { "branch": "main", "commit": "8e1c0a389f20bf7f5b0dd0e00306c1247bda2595" },
"nvim-ts-autotag": { "branch": "main", "commit": "a1d526af391f6aebb25a8795cbc05351ed3620b5" },
"nvim-ts-context-commentstring": { "branch": "main", "commit": "1b212c2eee76d787bbea6aa5e92a2b534e7b4f8f" },
"nvim-ufo": { "branch": "main", "commit": "61463090a4f55f5d080236ea62f09d1cd8976ff3" },
"nvim-web-devicons": { "branch": "master", "commit": "4c3a5848ee0b09ecdea73adcd2a689190aeb728c" },
"nvim-window-picker": { "branch": "main", "commit": "6382540b2ae5de6c793d4aa2e3fe6dbb518505ec" }, "nvim-window-picker": { "branch": "main", "commit": "6382540b2ae5de6c793d4aa2e3fe6dbb518505ec" },
"plenary.nvim": { "branch": "master", "commit": "857c5ac632080dba10aae49dba902ce3abf91b35" }, "plenary.nvim": { "branch": "master", "commit": "b9fd5226c2f76c951fc8ed5923d85e4de065e509" },
"presence.nvim": { "branch": "main", "commit": "87c857a56b7703f976d3a5ef15967d80508df6e6" },
"promise-async": { "branch": "main", "commit": "38a4575da9497326badd3995e768b4ccf0bb153e" },
"resession.nvim": { "branch": "master", "commit": "cc819b0489938d03e4f3532a583354f0287c015b" }, "resession.nvim": { "branch": "master", "commit": "cc819b0489938d03e4f3532a583354f0287c015b" },
"schemastore.nvim": { "branch": "main", "commit": "aa25399c48236b77af71d4b64cdf157d2ba4e990" }, "smart-splits.nvim": { "branch": "master", "commit": "12426763591f06b865c20990d8423345ea96d44f" },
"smart-splits.nvim": { "branch": "master", "commit": "ddb23c1a1cf1507bda487cda7f6e4690965ef9f5" }, "snacks.nvim": { "branch": "main", "commit": "e6fd58c82f2f3fcddd3fe81703d47d6d48fc7b9f" },
"telescope-fzf-native.nvim": { "branch": "main", "commit": "1f08ed60cafc8f6168b72b80be2b2ea149813e55" },
"telescope.nvim": { "branch": "master", "commit": "a17d611a0e111836a1db5295f04945df407c5135" },
"todo-comments.nvim": { "branch": "main", "commit": "31e3c38ce9b29781e4422fc0322eb0a21f4e8668" }, "todo-comments.nvim": { "branch": "main", "commit": "31e3c38ce9b29781e4422fc0322eb0a21f4e8668" },
"toggleterm.nvim": { "branch": "main", "commit": "50ea089fc548917cc3cc16b46a8211833b9e3c7c" }, "toggleterm.nvim": { "branch": "main", "commit": "50ea089fc548917cc3cc16b46a8211833b9e3c7c" },
"trouble.nvim": { "branch": "main", "commit": "bd67efe408d4816e25e8491cc5ad4088e708a69a" }, "which-key.nvim": { "branch": "main", "commit": "fcbf4eea17cb299c02557d576f0d568878e354a4" }
"vim-illuminate": { "branch": "master", "commit": "19cb21f513fc2b02f0c66be70107741e837516a1" },
"which-key.nvim": { "branch": "main", "commit": "fcbf4eea17cb299c02557d576f0d568878e354a4" },
"zen-mode.nvim": { "branch": "main", "commit": "863f150ca321b3dd8aa1a2b69b5f411a220e144f" }
} }

View File

@@ -1,21 +0,0 @@
-- Autocommand: trigger Flutter hot reload on save
--
-- This runs whenever you save a *.dart file (BufWritePost).
-- It checks if a tmux session named "flutter" exists.
-- If it does, it sends the keys "r<Enter>" to the "app" window
-- of that session, which tells `flutter run` to hot-reload.
--
-- Workflow:
-- 1. Start tmux: tmux new -s flutter -n app
-- 2. Inside tmux "app" window, run: flutter run
-- 3. Open another window/pane for nvim.
-- 4. Whenever you :w a Dart file in nvim, hot reload will fire.
--
vim.api.nvim_create_autocmd("BufWritePost", {
pattern = "*.dart",
callback = function()
local result = vim.fn.system({ "tmux", "send-keys", "-t", "flutter:app", "r", "Enter" })
vim.notify("Flutter hot reload triggered", vim.log.levels.INFO)
end,
})

View File

@@ -1,3 +1,5 @@
if true then return {} end -- WARN: REMOVE THIS LINE TO ACTIVATE THIS FILE
-- AstroCommunity: import any community modules here -- AstroCommunity: import any community modules here
-- We import this file in `lazy_setup.lua` before the `plugins/` folder. -- We import this file in `lazy_setup.lua` before the `plugins/` folder.
-- This guarantees that the specs are processed before any user plugins. -- This guarantees that the specs are processed before any user plugins.
@@ -7,7 +9,4 @@ return {
"AstroNvim/astrocommunity", "AstroNvim/astrocommunity",
{ import = "astrocommunity.pack.lua" }, { import = "astrocommunity.pack.lua" },
-- import/override with your plugins folder -- import/override with your plugins folder
{ import = "astrocommunity.utility.hover-nvim" },
{ import = "astrocommunity.diagnostics.trouble-nvim" },
{ import = "astrocommunity.scrolling.mini-animate" },
} }

View File

@@ -1,7 +1,7 @@
require("lazy").setup({ require("lazy").setup({
{ {
"AstroNvim/AstroNvim", "AstroNvim/AstroNvim",
version = "^4", -- Remove version tracking to elect for nightly AstroNvim version = "^6", -- Remove version tracking to elect for nightly AstroNvim
import = "astronvim.plugins", import = "astronvim.plugins",
opts = { -- AstroNvim options must be set here with the `import` key opts = { -- AstroNvim options must be set here with the `import` key
mapleader = " ", -- This ensures the leader key must be configured before Lazy is set up mapleader = " ", -- This ensures the leader key must be configured before Lazy is set up

View File

@@ -1,3 +1,5 @@
if true then return {} end -- WARN: REMOVE THIS LINE TO ACTIVATE THIS FILE
-- AstroCore provides a central place to modify mappings, vim options, autocommands, and more! -- AstroCore provides a central place to modify mappings, vim options, autocommands, and more!
-- Configuration documentation can be found with `:h astrocore` -- Configuration documentation can be found with `:h astrocore`
-- NOTE: We highly recommend setting up the Lua Language Server (`:LspInstall lua_ls`) -- NOTE: We highly recommend setting up the Lua Language Server (`:LspInstall lua_ls`)
@@ -13,7 +15,7 @@ return {
large_buf = { size = 1024 * 256, lines = 10000 }, -- set global limits for large files for disabling features like treesitter large_buf = { size = 1024 * 256, lines = 10000 }, -- set global limits for large files for disabling features like treesitter
autopairs = true, -- enable autopairs at start autopairs = true, -- enable autopairs at start
cmp = true, -- enable completion at start cmp = true, -- enable completion at start
diagnostics_mode = 3, -- diagnostic mode on start (0 = off, 1 = no signs/virtual text, 2 = no virtual text, 3 = on) diagnostics = { virtual_text = true, virtual_lines = false }, -- diagnostic settings on startup
highlighturl = true, -- highlight URLs at start highlighturl = true, -- highlight URLs at start
notifications = true, -- enable notifications at start notifications = true, -- enable notifications at start
}, },
@@ -22,6 +24,19 @@ return {
virtual_text = true, virtual_text = true,
underline = true, underline = true,
}, },
-- passed to `vim.filetype.add`
filetypes = {
-- see `:h vim.filetype.add` for usage
extension = {
foo = "fooscript",
},
filename = {
[".foorc"] = "fooscript",
},
pattern = {
[".*/etc/foo/.*"] = "fooscript",
},
},
-- vim options can be configured here -- vim options can be configured here
options = { options = {
opt = { -- vim.opt.<key> opt = { -- vim.opt.<key>
@@ -30,7 +45,6 @@ return {
spell = false, -- sets vim.opt.spell spell = false, -- sets vim.opt.spell
signcolumn = "yes", -- sets vim.opt.signcolumn to yes signcolumn = "yes", -- sets vim.opt.signcolumn to yes
wrap = false, -- sets vim.opt.wrap wrap = false, -- sets vim.opt.wrap
scrolloff = 8,
}, },
g = { -- vim.g.<key> g = { -- vim.g.<key>
-- configure global vim variables (vim.g) -- configure global vim variables (vim.g)

View File

@@ -1,3 +1,5 @@
if true then return {} end -- WARN: REMOVE THIS LINE TO ACTIVATE THIS FILE
-- AstroLSP allows you to customize the features in AstroNvim's LSP configuration engine -- AstroLSP allows you to customize the features in AstroNvim's LSP configuration engine
-- Configuration documentation can be found with `:h astrolsp` -- Configuration documentation can be found with `:h astrolsp`
-- NOTE: We highly recommend setting up the Lua Language Server (`:LspInstall lua_ls`) -- NOTE: We highly recommend setting up the Lua Language Server (`:LspInstall lua_ls`)
@@ -39,20 +41,18 @@ return {
servers = { servers = {
-- "pyright" -- "pyright"
}, },
-- customize language server configuration options passed to `lspconfig` -- customize language server configuration passed to `vim.lsp.config`
---@diagnostic disable: missing-fields -- client specific configuration can also go in `lsp/` in your configuration root (see `:h lsp-config`)
config = { config = {
ts_ls = {}, -- ["*"] = { capabilities = {} }, -- modify default LSP client settings such as capabilities
-- clangd = { capabilities = { offsetEncoding = "utf-8" } },
}, },
-- customize how language servers are attached -- customize how language servers are attached
handlers = { handlers = {
-- a function without a key is simply the default handler, functions take two parameters, the server name and the configured options table for that server -- a function with the key `*` modifies the default handler, functions takes the server name as the parameter
-- function(server, opts) require("lspconfig")[server].setup(opts) end -- ["*"] = function(server) vim.lsp.enable(server) end
-- the key is the server that is being setup with `lspconfig` -- the key is the server that is being setup with `vim.lsp.config`
-- rust_analyzer = false, -- setting a handler to false will disable the set up of that language server -- rust_analyzer = false, -- setting a handler to false will disable the set up of that language server
-- pyright = function(_, opts) require("lspconfig").pyright.setup(opts) end -- or a custom handler function can be passed
}, },
-- Configure buffer local auto commands to add when attaching a language server -- Configure buffer local auto commands to add when attaching a language server
autocmds = { autocmds = {
@@ -95,7 +95,7 @@ return {
}, },
}, },
-- A custom `on_attach` function to be run after the default `on_attach` function -- A custom `on_attach` function to be run after the default `on_attach` function
-- takes two parameters `client` and `bufnr` (`:h lspconfig-setup`) -- takes two parameters `client` and `bufnr` (`:h lsp-attach`)
on_attach = function(client, bufnr) on_attach = function(client, bufnr)
-- this would disable semanticTokensProvider for all clients -- this would disable semanticTokensProvider for all clients
-- client.server_capabilities.semanticTokensProvider = nil -- client.server_capabilities.semanticTokensProvider = nil

View File

@@ -1,11 +0,0 @@
return {
-- Add the community repository of plugin specifications
"AstroNvim/astrocommunity",
{ import = "astrocommunity.pack.dart" },
-- Configure flutter-tools
{ "akinsho/flutter-tools.nvim",
opts = {
...
}
}
}

View File

@@ -1,36 +1,27 @@
-- Customize Mason plugins if true then return {} end -- WARN: REMOVE THIS LINE TO ACTIVATE THIS FILE
-- Customize Mason
---@type LazySpec ---@type LazySpec
return { return {
-- use mason-lspconfig to configure LSP installations -- use mason-tool-installer for automatically installing Mason packages
{ {
"williamboman/mason-lspconfig.nvim", "WhoIsSethDaniel/mason-tool-installer.nvim",
-- overrides `require("mason-lspconfig").setup(...)` -- overrides `require("mason-tool-installer").setup(...)`
opts = {
ensure_installed = {
"lua_ls",
-- add more arguments for adding more language servers
},
},
},
-- use mason-null-ls to configure Formatters/Linter installation for null-ls sources
{
"jay-babu/mason-null-ls.nvim",
-- overrides `require("mason-null-ls").setup(...)`
opts = { opts = {
-- Make sure to use the names found in `:Mason`
ensure_installed = { ensure_installed = {
-- install language servers
"lua-language-server",
-- install formatters
"stylua", "stylua",
-- add more arguments for adding more null-ls sources
}, -- install debuggers
}, "debugpy",
},
{ -- install any other package
"jay-babu/mason-nvim-dap.nvim", "tree-sitter-cli",
-- overrides `require("mason-nvim-dap").setup(...)`
opts = {
ensure_installed = {
"python",
-- add more arguments for adding more debuggers
}, },
}, },
}, },

View File

@@ -0,0 +1,24 @@
if true then return {} end -- WARN: REMOVE THIS LINE TO ACTIVATE THIS FILE
-- Customize None-ls sources
---@type LazySpec
return {
"nvimtools/none-ls.nvim",
opts = function(_, opts)
-- opts variable is the default configuration table for the setup function call
-- local null_ls = require "null-ls"
-- Check supported formatters and linters
-- https://github.com/nvimtools/none-ls.nvim/tree/main/lua/null-ls/builtins/formatting
-- https://github.com/nvimtools/none-ls.nvim/tree/main/lua/null-ls/builtins/diagnostics
-- Only insert new sources, do not replace the existing ones
-- (If you wish to replace, use `opts.sources = {}` instead of the `list_insert_unique` function)
opts.sources = require("astrocore").list_insert_unique(opts.sources, {
-- Set a formatter
-- null_ls.builtins.formatting.stylua,
-- null_ls.builtins.formatting.prettier,
})
end,
}

View File

@@ -1,15 +1,24 @@
if true then return {} end -- WARN: REMOVE THIS LINE TO ACTIVATE THIS FILE if true then return {} end -- WARN: REMOVE THIS LINE TO ACTIVATE THIS FILE
-- Customize Treesitter -- Customize Treesitter
-- --------------------
-- Treesitter customizations are handled with AstroCore
-- as nvim-treesitter simply provides a download utility for parsers
---@type LazySpec ---@type LazySpec
return { return {
"nvim-treesitter/nvim-treesitter", "AstroNvim/astrocore",
---@type AstroCoreOpts
opts = { opts = {
ensure_installed = { treesitter = {
"lua", highlight = true, -- enable/disable treesitter based highlighting
"vim", indent = true, -- enable/disable treesitter based indentation
-- add more arguments for adding more treesitter parsers auto_install = true, -- enable/disable automatic installation of detected languages
ensure_installed = {
"lua",
"vim",
-- add more arguments for adding more treesitter parsers
},
}, },
}, },
} }

View File

@@ -1,4 +1,7 @@
if true then return {} end -- WARN: REMOVE THIS LINE TO ACTIVATE THIS FILE
-- You can also add or configure plugins by creating files in this `plugins/` folder -- You can also add or configure plugins by creating files in this `plugins/` folder
-- PLEASE REMOVE THE EXAMPLES YOU HAVE NO INTEREST IN BEFORE ENABLING THIS FILE
-- Here are some examples: -- Here are some examples:
---@type LazySpec ---@type LazySpec
@@ -15,26 +18,28 @@ return {
-- == Examples of Overriding Plugins == -- == Examples of Overriding Plugins ==
-- customize alpha options -- customize dashboard options
{ {
"goolord/alpha-nvim", "folke/snacks.nvim",
opts = function(_, opts) opts = {
-- customize the dashboard header dashboard = {
opts.section.header.val = { preset = {
" █████ ███████ ████████ ██████ ██████", header = table.concat({
"██ ██ ██ ██ ██ ██ ██ ██", " █████ ███████ ████████ ██████ ██████ ",
"███████ ███████ ██ ██████ ██ ██", "██ ██ ██ ██ ██ ██ ██ ██",
"██ ██ ██ ██ ██ ██ ██ ██", "███████ ███████ ██ ██████ ██ ██",
"██ ██ ███████ ██ ██ ██ ██████", "██ ██ ██ ██ ██ ██ ██ ██",
" ", "██ ██ ███████ ██ ██ ██ ██████ ",
" ███  ██ ██  ██ ██ ███  ███", "",
"███  ██ ██  ██ ██ ███ ███", "███  ██ ██  ██ ██ ███  ███",
" ████  ██ ██  ██ ██ ██ ████ ██", "████  ██ ██  ██ ██ ████  ████",
" ██ ██ ██ ██  ██  ██ ████ ██", "██ ██  ██ ██  ██ ██ ██ ████ ██",
" ██   ████   ████   ██ ██  ██", "██  ████  ██ ██  ██ ██  ██  ██",
} "██   ████   ████   ██ ██  ██",
return opts }, "\n"),
end, },
},
},
}, },
-- You can disable default plugins as follows: -- You can disable default plugins as follows:
@@ -44,10 +49,12 @@ return {
{ {
"L3MON4D3/LuaSnip", "L3MON4D3/LuaSnip",
config = function(plugin, opts) config = function(plugin, opts)
require "astronvim.plugins.configs.luasnip"(plugin, opts) -- include the default astronvim config that calls the setup call
-- add more custom luasnip configuration such as filetype extend or custom snippets -- add more custom luasnip configuration such as filetype extend or custom snippets
local luasnip = require "luasnip" local luasnip = require "luasnip"
luasnip.filetype_extend("javascript", { "javascriptreact" }) luasnip.filetype_extend("javascript", { "javascriptreact" })
-- include the default astronvim config that calls the setup call
require "astronvim.plugins.configs.luasnip"(plugin, opts)
end, end,
}, },

View File

@@ -1,10 +0,0 @@
return {
{
"folke/zen-mode.nvim",
opts = {
-- your configuration comes here
-- or leave it empty to use the default settings
-- refer to the configuration section below
},
},
}

View File

@@ -1,18 +1,5 @@
if true then return end -- WARN: REMOVE THIS LINE TO ACTIVATE THIS FILE if true then return end -- WARN: REMOVE THIS LINE TO ACTIVATE THIS FILE
-- This will run last in the setup process and is a good place to configure -- This will run last in the setup process.
-- things like custom filetypes. This is just pure lua so anything that doesn't -- This is just pure lua so anything that doesn't
-- fit in the normal config locations above can go here -- fit in the normal config locations above can go here
-- Set up custom filetypes
vim.filetype.add {
extension = {
foo = "fooscript",
},
filename = {
["Foofile"] = "fooscript",
},
pattern = {
["~/%.config/foo/.*"] = "fooscript",
},
}

View File

@@ -0,0 +1,119 @@
{
"position": "bottom",
"modules-left": ["dwl/tags", "custom/dwm-window"],
"modules-center": [],
//"modules-right": ["custom/spotify", "tray", "network", "bluetooth", "wireplumber", "battery", "clock", "custom/power"],
"modules-right": ["tray", "network", "custom/audio", "clock"],
"dwl/tags": {
"num-tags": 9,
"tag-labels": ["1", "2", "3", "4", "5", "6", "7", "8", "9"]
},
"dwl/window": {
"format": "[{layout}] {title}",
"max-length": 80
},
"custom/dwm-window": {
"exec": "~/.local/bin/tag_windows.sh",
"max-length": 80
},
"clock": {
//"format": "{:%d.%m. %b, %a %H:%M}",
"format": "{:%b %d (%a) %I:%M:%S %p}",
"timezone": "Europe/Prague",
"locale": "en_US.UTF-8",
"interval": 1,
"tooltip-format": "<tt><small>{calendar}</small></tt>",
"calendar": {
"mode" : "year",
"mode-mon-col" : 3,
"weeks-pos" : "right",
"on-scroll" : 1,
"format": {
"months": "<span color='#ffead3'><b>{}</b></span>",
"days": "<span color='#ecc6d9'><b>{}</b></span>",
"weeks": "<span color='#99ffdd'><b>W{}</b></span>",
"weekdays": "<span color='#ffcc66'><b>{}</b></span>",
"today": "<span color='#ff6699'><b><u>{}</u></b></span>"
}
},
"actions": {
"on-click-right": "mode",
"on-click-forward": "tz_up",
"on-click-backward": "tz_down",
"on-scroll-up": "shift_up",
"on-scroll-down": "shift_down"
}
},
"network": {
"interface": "eth0",
"format-ethernet": "󰈀 {ifname}: {ipaddr}",
"format-disconnected": "󰖪 ",
"tooltip-format-ethernet": "{ifname}: {ipaddr}",
"tooltip-format-disconnected": "Disconnected",
//"on-click": "foot -e nmtui",
//"on-click-right": "~/.scripts/restart_network.sh"
},
//"bluetooth": {
// "on-click": "foot bluetuith",
// "on-click-right": "~/.scripts/toggle_bluetooth.sh",
// "format-on": "󰂯",
// "format-off": "󰂲",
// "format-disabled": "󰂲",
// "format-connected": "󰂱"
//},
//"wireplumber": {
// "format": "{icon} {volume}%",
// "format-muted": "󰖁 muted",
// "on-click": "pavucontrol -t 3",
// "on-click-right": "pamixer --toggle-mute",
// "max-volume": 125,
// "format-icons": ["", "", ""]
//},
"custom/audio": {
"exec": "~/.local/bin/waybar_audio",
"signal": 8,
"return-type": "json",
"format": "{icon} {text}",
"format-icons": {
"speaker": ["", "", " "],
"speaker-muted": "󰖁",
"headphones": "󰋋",
"headphones-muted": "󰟎"
},
//"interval": 2,
"interval": "once",
"on-click": "pamixer --toggle-mute",
"on-click-right": "~/.local/bin/toggle_audio",
"on-scroll-up": "pamixer --increase 5",
"on-scroll-down": "pamixer --decrease 5"
},
//"battery": {
// "states": {
// "good": 95,
// "warning": 30,
// "critical": 15
// },
// "format":"{icon} {capacity}%",
// "format-charging": "󰂄 {capacity}%",
// "format-plugged": "󱐋",
// "format-icons": ["󰁺", "󰁻", "󰁼", "󰁽", "󰁾", "󰁿", "󰂀", "󰂁", "󰂂", "󰁹"],
// "interval": 30,
// "tooltip-format": "{time}",
//},
"tray": {
"spacing": 10
}
}

View File

@@ -1,6 +1,6 @@
{ {
"position": "bottom", "position": "bottom",
"modules-left": ["river/tags", "river/window"], "modules-left": ["river/tags", "river/layout", "river/window"],
"modules-center": [], "modules-center": [],
"modules-right": ["tray", "bluetooth", "network", "custom/audio", "battery", "clock"], "modules-right": ["tray", "bluetooth", "network", "custom/audio", "battery", "clock"],
@@ -12,6 +12,12 @@
"max-length": 80 "max-length": 80
}, },
"river/layout": {
"format": "{}",
"min-length": 4,
"on-click": "riverctl send-layout-cmd next"
},
"clock": { "clock": {
//"format": "{:%d.%m. %b, %a %H:%M}", //"format": "{:%d.%m. %b, %a %H:%M}",
"format": "{:%b %d (%a) %I:%M:%S %p}", "format": "{:%b %d (%a) %I:%M:%S %p}",
@@ -80,7 +86,8 @@
"headphones": "󰋋", "headphones": "󰋋",
"headphones-muted": "󰟎" "headphones-muted": "󰟎"
}, },
"interval": 2, //"interval": 2,
"interval": "once",
"on-click": "pamixer --toggle-mute", "on-click": "pamixer --toggle-mute",
"on-click-right": "~/.local/bin/toggle_audio", "on-click-right": "~/.local/bin/toggle_audio",
"on-scroll-up": "pamixer --increase 5", "on-scroll-up": "pamixer --increase 5",

View File

@@ -9,6 +9,7 @@
window#waybar { window#waybar {
background-color: @bg; background-color: @bg;
padding: 10em;
} }
#tags { #tags {

View File

@@ -6,8 +6,8 @@
[ -f ~/.Xresources ] && xrdb -merge -I$HOME ~/.Xresources [ -f ~/.Xresources ] && xrdb -merge -I$HOME ~/.Xresources
# OPTIMUS SHITS # OPTIMUS SHITS
#xrandr --setprovideroutputsource modesetting NVIDIA-0 xrandr --setprovideroutputsource modesetting NVIDIA-0
#xrandr --auto xrandr --auto
export _JAVA_AWT_WM_NONREPARENTING=1 export _JAVA_AWT_WM_NONREPARENTING=1
@@ -19,18 +19,24 @@ feh --bg-scale "$HOME/Pictures/bg.png" &
xautolock -locker lock-us -secure -time 1 & xautolock -locker lock-us -secure -time 1 &
#pipewire & #pipewire &
dbus-run-session pipewire & dbus-run-session pipewire &
pipewire-pulse & pipewire-pulse &
wireplumber & #wireplumber &
dwmblocks & dwmblocks &
clipmenud & #clipmenud &
mpd --no-daemon & #mpd --no-daemon &
pw-metadata -n settings 0 clock.force-rate 44100 #pw-metadata -n settings 0 clock.force-rate 44100
pw-metadata -n settings 0 clock.force-quantum 1024 #pw-metadata -n settings 0 clock.force-quantum 1024
if [ -x /usr/bin/ssh-agent ]; then
eval $(ssh-agent -s)
fi
dbus-launch --sh-syntax --exit-with-session dwm dbus-launch --sh-syntax --exit-with-session dwm
#exec dwm

View File

@@ -1,12 +1,13 @@
#gentoo-pipewire-launcher & #gentoo-pipewire-launcher &
ssh-agent & ssh-agent &
TPADID=$(xinput | grep "Synaptics" | awk '{print $5}' | awk -F "=" '{print $2}') TPADID=$(xinput | grep "Synaptics" | awk '{print $5}' | awk -F "=" '{print $2}')
xinput disable $TPADID #xinput disable $TPADID
xinput set-prop "TPPS/2 IBM TrackPoint" "libinput Accel Speed" 0.9 $xinput set-prop "TPPS/2 IBM TrackPoint" "libinput Accel Speed" 0.9
xdg-settings set default-web-browser firefox.desktop xdg-settings set default-web-browser firefox.desktop
xdg-mime default mupdf.desktop application/pdf xdg-mime default mupdf.desktop application/pdf
xdg-mime default thunar.desktop inode/directory xdg-mime default thunar.desktop inode/directory
xdg-mime default feh.desktop image/jpeg image/png image/gif image/bmp image/webp image/tiff
#xrandr --output HDMI-0 --mode 2560x1440 --rate 143.91 #xrandr --output HDMI-0 --mode 2560x1440 --rate 143.91
#xrandr --output DP-3 --mode 1920x1080 --pos 0x180 --rotate normal --output HDMI-0 --mode 2560x1440 --rate 143.91 --pos 1920x0 --rotate normal #xrandr --output DP-3 --mode 1920x1080 --pos 0x180 --rotate normal --output HDMI-0 --mode 2560x1440 --rate 143.91 --pos 1920x0 --rotate normal
@@ -14,8 +15,9 @@ xdg-mime default thunar.desktop inode/directory
##nvidia-settings --assign 'CurrentMetaMode=DPY-4: 2560x1440_144 @2560x1440 +1920+0 {ViewPortIn=2560x1440, ViewPortOut=2560x1440+0+0, ForceCompositionPipeline=On}, DPY-3: nvidia-auto-select @1920x1080 +0+180 {ViewPortIn=1920x1080, ViewPortOut=1920x1080+0+0, ForceCompositionPipeline=On}' ##nvidia-settings --assign 'CurrentMetaMode=DPY-4: 2560x1440_144 @2560x1440 +1920+0 {ViewPortIn=2560x1440, ViewPortOut=2560x1440+0+0, ForceCompositionPipeline=On}, DPY-3: nvidia-auto-select @1920x1080 +0+180 {ViewPortIn=1920x1080, ViewPortOut=1920x1080+0+0, ForceCompositionPipeline=On}'
#nvidia-settings --assign 'CurrentMetaMode=DPY-5: 2560x1440_170 @2560x1440 +1920+0 {ViewPortIn=2560x1440, ViewPortOut=2560x1440+0+0, ForceCompositionPipeline=On}, DPY-1: nvidia-auto-select @1920x1080 +0+138 {ViewPortIn=1920x1080, ViewPortOut=1920x1080+0+0, ForceCompositionPipeline=On}' #nvidia-settings --assign 'CurrentMetaMode=DPY-5: 2560x1440_170 @2560x1440 +1920+0 {ViewPortIn=2560x1440, ViewPortOut=2560x1440+0+0, ForceCompositionPipeline=On}, DPY-1: nvidia-auto-select @1920x1080 +0+138 {ViewPortIn=1920x1080, ViewPortOut=1920x1080+0+0, ForceCompositionPipeline=On}'
xrandr --output DisplayPort-0 --off --output DisplayPort-1 --off --output DisplayPort-2 --primary --mode 2560x1440 --pos 1920x0 --rotate normal --output HDMI-A-0 --mode 1920x1080 --pos 0x180 --rotate normal #xrandr --output DisplayPort-0 --off --output DisplayPort-1 --off --output DisplayPort-2 --primary --mode 2560x1440 --pos 1920x0 --rotate normal --output HDMI-A-0 --mode 1920x1080 --pos 0x180 --rotate normal
xrandr --output DisplayPort-2 --set "scaling mode" Full #xrandr --output DisplayPort-2 --set "scaling mode" Full
xrandr --output DP-1-3 --mode 2560x1440 -r 143.97 --output eDP-1 --off --output DP-1-1 --mode 2560x1440 --left-of DP-1-3