feat(hyprland): Add hyprland config

This commit is contained in:
whoami 2024-12-22 07:44:26 +00:00
parent 981dd2170c
commit 4bf9687d72
28 changed files with 540 additions and 80 deletions

View file

@ -8,7 +8,6 @@ mkdir -p $XDG_CONFIG_HOME/conda $XDG_CONFIG_HOME/git $XDG_CONFIG_HOME/ideavim $X
mkdir -p ~/.config/zellij ~/.config/yazi ~/.config/glow mkdir -p ~/.config/zellij ~/.config/yazi ~/.config/glow
# mkdir -p $WAKATIME_HOME # mkdir -p $WAKATIME_HOME
# mkdir -p $XDG_STATE_HOME/vim/undo $XDG_STATE_HOME/vim/backup $XDG_STATE_HOME/vim/swap $XDG_STATE_HOME/vim/view # mkdir -p $XDG_STATE_HOME/vim/undo $XDG_STATE_HOME/vim/backup $XDG_STATE_HOME/vim/swap $XDG_STATE_HOME/vim/view
mkdir -p $HOME/Obsidian
# $DOTFILES/common # $DOTFILES/common
ln -sf $DOTFILES/common/condarc.yaml $XDG_CONFIG_HOME/conda/.condarc ln -sf $DOTFILES/common/condarc.yaml $XDG_CONFIG_HOME/conda/.condarc
# ln -sf $DOTFILES/common/gitconfig $XDG_CONFIG_HOME/git/config # ln -sf $DOTFILES/common/gitconfig $XDG_CONFIG_HOME/git/config
@ -19,7 +18,6 @@ ln -sf $DOTFILES/common/ideavimrc $XDG_CONFIG_HOME/ideavim/ideavimrc
ln -sf $DOTFILES/common/lesskey $XDG_CONFIG_HOME/lesskey ln -sf $DOTFILES/common/lesskey $XDG_CONFIG_HOME/lesskey
ln -sf $DOTFILES/common/npmrc $NPM_CONFIG_USERCONFIG ln -sf $DOTFILES/common/npmrc $NPM_CONFIG_USERCONFIG
ln -sf $DOTFILES/common/NuGet.Config $XDG_CONFIG_HOME/NuGet/NuGet.Config ln -sf $DOTFILES/common/NuGet.Config $XDG_CONFIG_HOME/NuGet/NuGet.Config
ln -sf $DOTFILES/common/obsidian.vimrc $HOME/Obsidian/.obsidian.vimrc
ln -sf $DOTFILES/common/pip.conf $XDG_CONFIG_HOME/pip/pip.conf ln -sf $DOTFILES/common/pip.conf $XDG_CONFIG_HOME/pip/pip.conf
ln -sf $DOTFILES/common/tmux.conf $XDG_CONFIG_HOME/tmux/tmux.conf ln -sf $DOTFILES/common/tmux.conf $XDG_CONFIG_HOME/tmux/tmux.conf
ln -sf $DOTFILES/common/vimrc $XDG_CONFIG_HOME/vim/vimrc ln -sf $DOTFILES/common/vimrc $XDG_CONFIG_HOME/vim/vimrc
@ -32,7 +30,7 @@ ln -sf $DOTFILES/tools/yazi/config/yazi.toml ~/.config/yazi/yazi.toml
ln -sf $DOTFILES/tools/fish ~/.config ln -sf $DOTFILES/tools/fish ~/.config
if [ $(uname) = "Darwin"]; then if [ $(uname) = "Darwin" ]; then
mkdir -p ~/.config/karabiner $XDG_CONFIG_HOME/skhd $XDG_CONFIG_HOME/yabai $XDG_CONFIG_HOME/sketchybar mkdir -p ~/.config/karabiner $XDG_CONFIG_HOME/skhd $XDG_CONFIG_HOME/yabai $XDG_CONFIG_HOME/sketchybar
ln -sf $DOTFILES/platforms/mac/karabiner/karabiner.json ~/.config/karabiner/karabiner.json ln -sf $DOTFILES/platforms/mac/karabiner/karabiner.json ~/.config/karabiner/karabiner.json
ln -sf $DOTFILES/platforms/mac/skhdrc $XDG_CONFIG_HOME/skhd/skhdrc ln -sf $DOTFILES/platforms/mac/skhdrc $XDG_CONFIG_HOME/skhd/skhdrc

View file

@ -1,7 +1,12 @@
# $XDG_CONFIG_HOME/conda/condarc.yaml # $DOTFILES/common/condarc.yaml
# ================================================================== # Date: 2024-12-22
# New-Item -ItemType SymbolicLink -Path $Env:XDG_CONFIG_HOME\conda\.condarc -Target $DOTFILES\.config\conda\condarc.yaml # Author: js0ny
# Location:
# $XDG_CONFIG_HOME/conda/.condarc
# Linking:
# ln -s $DOTFILES/.config/conda/condarc.yaml $XDG_CONFIG_HOME/conda/.condarc # ln -s $DOTFILES/.config/conda/condarc.yaml $XDG_CONFIG_HOME/conda/.condarc
# ================================================================== # ================================================================================
# Reference:
# https://docs.conda.io/projects/conda/en/latest/user-guide/configuration/use-condarc.html # https://docs.conda.io/projects/conda/en/latest/user-guide/configuration/use-condarc.html
auto_activate_base: false auto_activate_base: false

View file

@ -1,14 +1,19 @@
# $XDG_CONFIG_HOME/git/config # $DOTFILES/common/gitconfig.example
# %USERPROFILE%\.gitconfig # No XDG support on Windows # Date: 2024-12-22
# ln -sf $DOTFILES/.config/git/.gitconfig $XDG_CONFIG_HOME/git/config # Author: js0ny
# New-Item -ItemType SymbolicLink -Path "$Env:XDG_CONFIG_HOME\git\config" -Target "$DOTFILES\.config\git\.gitconfig"
[user] # Location:
# Windows: %USERPROFILE%\.gitconfig
# *nix: ~/.config/git/config
# Linking: (Note that this file is an example, only copy this then edit)
# cp $DOTFILES/common/gitconfig.example ~/.config/git/config
[user] # Modify the name and email
name = whoami name = whoami
email = whoami@example.com email = whoami@example.com
[core] [core]
editor = nvim editor = nvim
pager = delta pager = delta
autocrlf = input autocrlf = input # Force End of Line in different platforms
[interactive] [interactive]
diffFilter = delta --color-only diffFilter = delta --color-only
[delta] [delta]
@ -19,5 +24,5 @@
smudge = git-lfs smudge -- %f smudge = git-lfs smudge -- %f
process = git-lfs filter-process process = git-lfs filter-process
required = true required = true
[url "git@github.com:"] # [url "git@github.com:"] # Force ssh
insteadOf = https://github.com/ # insteadOf = https://github.com/

View file

@ -1,5 +1,10 @@
# ~/.config/glow/glow.yaml # $DOTFILES/common/glow.yaml
# ln -sf $DOTFILES/glow/glow.yaml ~/.config/glow/glow.yaml # Date: 2024-12-22
# Author: js0ny
# Location:
# ~/.config/glow/config.yml
# ln -sf $DOTFILES/glow/glow.yaml ~/.config/glow/config.yml
# style name or JSON path (default "auto") # style name or JSON path (default "auto")
style: "auto" style: "auto"
# mouse support (TUI-mode only) # mouse support (TUI-mode only)

View file

@ -1 +1 @@
editMode: Vi editMode: Vi

View file

@ -1,6 +1,12 @@
"$XDG_CONFIG_HOME/ideavim/ideavimrc " $DOTFILES/common/ideavimrc
" New-Item -ItemType SymbolicLink -Path ~\.ideavimrc -Target $DOTFILES\.config\ideavim\ideavimrc.vimrc " Date: 2024-12-22
" ln -sf $DOTFILES/.config/ideavim/ideavimrc.vimrc $XDG_CONFIG_HOME/ideavim/ideavimrc " Author: js0ny
" Location:
" $XDG_CONFIG_HOME/ideavim/ideavimrc
" Linking:
" ln -sf $DOTFILES/common/ideavimrc $XDG_CONFIG_HOME/ideavim/ideavimrc
""" Basic Configs """ """ Basic Configs """
let mapleader = " " " set <leader> to <space> let mapleader = " " " set <leader> to <space>

View file

@ -1,4 +1,13 @@
# $DOTFILES/common/gitconfig.example
# Date: 2024-12-22
# Author: js0ny
# GNU Readline config file, works for programs that use that library
# e.g. Python REPL, Lua REPL, Bash on Linux
# Location:
# $XDG_CONFIG_HOME/readline/inputrc # $XDG_CONFIG_HOME/readline/inputrc
# Linking:
# ln -sf $DOTFILES/common/inputrc $XDG_CONFIG_HOME/readline/inputrc
# Colemak Key Remaps # Colemak Key Remaps
set editing-mode vi set editing-mode vi

View file

@ -1,6 +1,16 @@
# $XDG_CONFIG_HOME/lesskey -- less options # $DOTFILES/common/lesskey
# ln -sf $DOTFILES/.config/lesskey $XDG_CONFIG_HOME/lesskey # Date: 2024-12-22
# Author: js0ny
# Less the pager.
# Location:
# $XDG_CONFIG_HOME/lesskey
# Or specified by the environment variable $LESSKEYIN
# Linking:
# ln -sf $DOTFILES/common/lesskey ~/.config/lesskey
# ===========================================================
# work for less -V > 582, for mac, use brew install less to override the system less # work for less -V > 582, for mac, use brew install less to override the system less
# In Windows (current version), the default pager is `more`, should be specifed to `less` by `$Env:Pager = less`
# Format: key action # Format: key action

View file

@ -1,6 +1,14 @@
# $DOTFILES/common/npmrc
# Date: 2024-12-22
# Author: js0ny
# Location:
# $NPM_CONFIG_USERCONFIG
# ~/.npmrc (Default location)
# Linking:
# export NPM_CONFIG_USERCONFIG="$XDG_CONFIG_HOME"/npm/npmrc # export NPM_CONFIG_USERCONFIG="$XDG_CONFIG_HOME"/npm/npmrc
# ===========================================================
# $XDG_CONFIG_HOME/npm/npmrc
# ln -s $DOTFILES/.config/npm/npmrc $NPM_CONFIG_USERCONFIG # ln -s $DOTFILES/.config/npm/npmrc $NPM_CONFIG_USERCONFIG
# New-Item -ItemType SymbolicLink -Path $env:NPM_CONFIG_USERCONFIG -Value $env:DOTFILES/.config/npm/npmrc # New-Item -ItemType SymbolicLink -Path $env:NPM_CONFIG_USERCONFIG -Value $env:DOTFILES/.config/npm/npmrc
# registry=https://registry.npmmirror.com # registry=https://registry.npmmirror.com

View file

@ -1,5 +1,12 @@
# $DOTFILES/common/tmux.conf
# Date: 2024-12-22
# Author: js0ny
# `tmux` - Terminal Multiplexer
# Location:
# $XDG_CONFIG_HOME/tmux/tmux.conf # $XDG_CONFIG_HOME/tmux/tmux.conf
# ln -sf $DOTFILES/.config/tmux/tmux.conf $XDG_CONFIG_HOME/tmux/tmux.conf # Linking:
# ln -sf $DOTFILES/common/tmux.conf $XDG_CONFIG_HOME/tmux/tmux.conf
# Prefix # Prefix
# ----------------- # -----------------
@ -14,7 +21,7 @@ set-option -g allow-rename on
set-option -g alternate-screen on set-option -g alternate-screen on
set-option -g visual-activity on set-option -g visual-activity on
set-option -g pane-border-style fg=colour244 set-option -g pane-border-style fg=colour244
set-option -g pane-activity-border-style fg=colour239 # set-option -g pane-activity-border-style fg=colour239
# Index # Index
# ----------------- # -----------------
@ -54,17 +61,17 @@ bind ` resize-pane -Z
# Status Bar # Status Bar
# ----------------- # -----------------
# set -g status-position top
# set-option -g status-bg black
# set-option -g status-fg white
# set-option -g status-left '#[fg=green][#S] '
# setw -g window-status-current-format '#[fg=colour236,bg=colour39] #I #W '
set -g status-position top set -g status-position top
set -g @catppuccin_flavor "frappe" set-option -g status-bg black
run ~/.config/tmux/plugins/catppuccin/tmux/catppuccin.tmux set-option -g status-fg white
set -g status-right-length 100 set-option -g status-left '#[fg=green][#S] '
set -g status-left-length 100 setw -g window-status-current-format '#[fg=colour236,bg=colour39] #I #W '
set -g status-left ""
set -g status-right "#{E:@catppuccin_status_application}" # set -g status-position top
set -ag status-right "#{E:@catppuccin_status_session}" # set -g @catppuccin_flavor "frappe"
# run ~/.config/tmux/plugins/catppuccin/tmux/catppuccin.tmux
# set -g status-right-length 100
# set -g status-left-length 100
# set -g status-left ""
# set -g status-right "#{E:@catppuccin_status_application}"
# set -ag status-right "#{E:@catppuccin_status_session}"

View file

@ -13,9 +13,9 @@ keybinds {
} }
pane { pane {
bind "h" "Left" { MoveFocus "Left"; } bind "h" "Left" { MoveFocus "Left"; }
bind "i" "Right" { MoveFocus "Right"; }
bind "n" "Down" { MoveFocus "Down"; } bind "n" "Down" { MoveFocus "Down"; }
bind "e" "Up" { MoveFocus "Up"; } bind "e" "Up" { MoveFocus "Up"; }
bind "i" "Right" { MoveFocus "Right"; }
bind "p" { SwitchFocus; } bind "p" { SwitchFocus; }
} }
locked { locked {

View file

@ -0,0 +1,12 @@
# $DOTFILES/platforms/linux/hyprland/code-flags.conf
# Date: 2024-12-22
# Author: js0ny
# Force VSCode to use Wayland
# Location:
# ~/.config/code-flags.conf
# Linking:
# ln -sf $DOTFILES/platforms/linux/hyprland/code-flags.conf ~/.config/
--enable-features=UseOzonePlatform
--ozone-platform=wayland

View file

@ -0,0 +1,13 @@
# $DOTFILES/platforms/linux/hyprland/electron-flags.conf
# Date: 2024-12-22
# Author: js0ny
# Force electron apps to use Wayland
# Location:
# ~/.config/electron-flags.conf
# Linking:
# ln -sf $DOTFILES/platforms/linux/hyprland/electron-flags.conf ~/.config/
--enable-features=UseOzonePlatform
--ozone-platform=wayland
--enable-icd

View file

@ -0,0 +1,315 @@
# $DOTFILES/platforms/linux/hyprland/hypr/hyprland.conf
# Date: 2024-12-22
# Author: js0ny
# Hyprland Window Manager Configuration
# Location:
# $XDG_CONFIG_HOME/hypr/hyprland.conf
# Linking: (Link the whole `hypr` directory)
# ln -sf $DOTFILES/platforms/linux/hyprland/hypr $XDG_CONFIG_HOME/hypr
# #######################################################################################
# AUTOGENERATED HYPRLAND CONFIG.
# PLEASE USE THE CONFIG PROVIDED IN THE GIT REPO /examples/hyprland.conf AND EDIT IT,
# OR EDIT THIS ONE ACCORDING TO THE WIKI INSTRUCTIONS.
# #######################################################################################
autogenerated = 0 # remove this line to remove the warning
# This is an example Hyprland config file.
# Refer to the wiki for more information.
# https://wiki.hyprland.org/Configuring/
# Please note not all available settings / options are set here.
# For a full list, see the wiki
# You can split this configuration into multiple files
# Create your files separately and then link them to this file like this:
# source = ~/.config/hypr/myColors.conf
#
xwayland {
force_zero_scaling = true
}
################
### MONITORS ###
################
# See https://wiki.hyprland.org/Configuring/Monitors/
monitor=,preferred,auto,auto
###################
### MY PROGRAMS ###
###################
# See https://wiki.hyprland.org/Configuring/Keywords/
# Set programs that you use
$terminal = kitty
$fileManager = dolphin
$menu = wofi --show drun
#################
### AUTOSTART ###
#################
# Autostart necessary processes (like notifications daemons, status bars, etc.)
# Or execute your favorite apps at launch like this:
# exec-once = $terminal
# exec-once = nm-applet &
exec-once = waybar & hyprpaper & mako & systemctl --user start hyprpolkitagent
#############################
### ENVIRONMENT VARIABLES ###
#############################
# See https://wiki.hyprland.org/Configuring/Environment-variables/
env = XCURSOR_SIZE,24
env = HYPRCURSOR_SIZE,24
#####################
### LOOK AND FEEL ###
#####################
# Refer to https://wiki.hyprland.org/Configuring/Variables/
# https://wiki.hyprland.org/Configuring/Variables/#general
general {
gaps_in = 5
gaps_out = 20
border_size = 2
# https://wiki.hyprland.org/Configuring/Variables/#variable-types for info about colors
col.active_border = rgba(33ccffee) rgba(00ff99ee) 45deg
col.inactive_border = rgba(595959aa)
# Set to true enable resizing windows by clicking and dragging on borders and gaps
resize_on_border = false
# Please see https://wiki.hyprland.org/Configuring/Tearing/ before you turn this on
allow_tearing = false
layout = dwindle
}
# https://wiki.hyprland.org/Configuring/Variables/#decoration
decoration {
rounding = 10
# Change transparency of focused and unfocused windows
active_opacity = 1.0
inactive_opacity = 1.0
shadow {
enabled = true
range = 4
render_power = 3
color = rgba(1a1a1aee)
}
# https://wiki.hyprland.org/Configuring/Variables/#blur
blur {
enabled = true
size = 3
passes = 1
vibrancy = 0.1696
}
}
# https://wiki.hyprland.org/Configuring/Variables/#animations
animations {
enabled = yes, please :)
# Default animations, see https://wiki.hyprland.org/Configuring/Animations/ for more
bezier = easeOutQuint,0.23,1,0.32,1
bezier = easeInOutCubic,0.65,0.05,0.36,1
bezier = linear,0,0,1,1
bezier = almostLinear,0.5,0.5,0.75,1.0
bezier = quick,0.15,0,0.1,1
animation = global, 1, 10, default
animation = border, 1, 5.39, easeOutQuint
animation = windows, 1, 4.79, easeOutQuint
animation = windowsIn, 1, 4.1, easeOutQuint, popin 87%
animation = windowsOut, 1, 1.49, linear, popin 87%
animation = fadeIn, 1, 1.73, almostLinear
animation = fadeOut, 1, 1.46, almostLinear
animation = fade, 1, 3.03, quick
animation = layers, 1, 3.81, easeOutQuint
animation = layersIn, 1, 4, easeOutQuint, fade
animation = layersOut, 1, 1.5, linear, fade
animation = fadeLayersIn, 1, 1.79, almostLinear
animation = fadeLayersOut, 1, 1.39, almostLinear
animation = workspaces, 1, 1.94, almostLinear, fade
animation = workspacesIn, 1, 1.21, almostLinear, fade
animation = workspacesOut, 1, 1.94, almostLinear, fade
}
# Ref https://wiki.hyprland.org/Configuring/Workspace-Rules/
# "Smart gaps" / "No gaps when only"
# uncomment all if you wish to use that.
# workspace = w[tv1], gapsout:0, gapsin:0
# workspace = f[1], gapsout:0, gapsin:0
# windowrulev2 = bordersize 0, floating:0, onworkspace:w[tv1]
# windowrulev2 = rounding 0, floating:0, onworkspace:w[tv1]
# windowrulev2 = bordersize 0, floating:0, onworkspace:f[1]
# windowrulev2 = rounding 0, floating:0, onworkspace:f[1]
# See https://wiki.hyprland.org/Configuring/Dwindle-Layout/ for more
dwindle {
pseudotile = true # Master switch for pseudotiling. Enabling is bound to mainMod + P in the keybinds section below
preserve_split = true # You probably want this
}
# See https://wiki.hyprland.org/Configuring/Master-Layout/ for more
master {
new_status = master
}
# https://wiki.hyprland.org/Configuring/Variables/#misc
misc {
force_default_wallpaper = -1 # Set to 0 or 1 to disable the anime mascot wallpapers
disable_hyprland_logo = false # If true disables the random hyprland logo / anime girl background. :(
}
#############
### INPUT ###
#############
# https://wiki.hyprland.org/Configuring/Variables/#input
input {
kb_layout = us
kb_variant =
kb_model =
kb_options =
kb_rules =
follow_mouse = 1
sensitivity = 0 # -1.0 - 1.0, 0 means no modification.
touchpad {
natural_scroll = false
}
}
# https://wiki.hyprland.org/Configuring/Variables/#gestures
gestures {
workspace_swipe = false
}
# Example per-device config
# See https://wiki.hyprland.org/Configuring/Keywords/#per-device-input-configs for more
device {
name = epic-mouse-v1
sensitivity = -0.5
}
###################
### KEYBINDINGS ###
###################
# See https://wiki.hyprland.org/Configuring/Keywords/
$mainMod = SUPER # Sets "Windows" key as main modifier
# Example binds, see https://wiki.hyprland.org/Configuring/Binds/ for more
bind = $mainMod, R, exec, $terminal
bind = $mainMod, Q, killactive,
bind = $mainMod, M, exit,
bind = $mainMod, F, exec, $fileManager
bind = $mainMod, V, togglefloating,
bind = $mainMod, space, exec, $menu
bind = $mainMod, P, pseudo, # dwindle
bind = $mainMod, X, togglesplit, # dwindle
# Move focus with mainMod + arrow keys
bind = $mainMod, left, movefocus, l
bind = $mainMod, right, movefocus, r
bind = $mainMod, up, movefocus, u
bind = $mainMod, down, movefocus, d
bind = $mainMod, h, movefocus, l
bind = $mainMod, i, movefocus, r
bind = $mainMod, e, movefocus, u
bind = $mainMod, n, movefocus, d
# Switch workspaces with mainMod + [0-9]
bind = $mainMod, 1, workspace, 1
bind = $mainMod, 2, workspace, 2
bind = $mainMod, 3, workspace, 3
bind = $mainMod, 4, workspace, 4
bind = $mainMod, 5, workspace, 5
bind = $mainMod, 6, workspace, 6
bind = $mainMod, 7, workspace, 7
bind = $mainMod, 8, workspace, 8
bind = $mainMod, 9, workspace, 9
bind = $mainMod, 0, workspace, 10
# Move active window to a workspace with mainMod + SHIFT + [0-9]
bind = $mainMod SHIFT, 1, movetoworkspace, 1
bind = $mainMod SHIFT, 2, movetoworkspace, 2
bind = $mainMod SHIFT, 3, movetoworkspace, 3
bind = $mainMod SHIFT, 4, movetoworkspace, 4
bind = $mainMod SHIFT, 5, movetoworkspace, 5
bind = $mainMod SHIFT, 6, movetoworkspace, 6
bind = $mainMod SHIFT, 7, movetoworkspace, 7
bind = $mainMod SHIFT, 8, movetoworkspace, 8
bind = $mainMod SHIFT, 9, movetoworkspace, 9
bind = $mainMod SHIFT, 0, movetoworkspace, 10
# Example special workspace (scratchpad)
bind = $mainMod, S, togglespecialworkspace, magic
bind = $mainMod SHIFT, S, movetoworkspace, special:magic
# Scroll through existing workspaces with mainMod + scroll
bind = $mainMod, mouse_down, workspace, e+1
bind = $mainMod, mouse_up, workspace, e-1
# Move/resize windows with mainMod + LMB/RMB and dragging
bindm = $mainMod, mouse:272, movewindow
bindm = $mainMod, mouse:273, resizewindow
# Laptop multimedia keys for volume and LCD brightness
bindel = ,XF86AudioRaiseVolume, exec, wpctl set-volume @DEFAULT_AUDIO_SINK@ 5%+
bindel = ,XF86AudioLowerVolume, exec, wpctl set-volume @DEFAULT_AUDIO_SINK@ 5%-
bindel = ,XF86AudioMute, exec, wpctl set-mute @DEFAULT_AUDIO_SINK@ toggle
bindel = ,XF86AudioMicMute, exec, wpctl set-mute @DEFAULT_AUDIO_SOURCE@ toggle
bindel = ,XF86MonBrightnessUp, exec, brightnessctl s 10%+
bindel = ,XF86MonBrightnessDown, exec, brightnessctl s 10%-
# Requires playerctl
bindl = , XF86AudioNext, exec, playerctl next
bindl = , XF86AudioPause, exec, playerctl play-pause
bindl = , XF86AudioPlay, exec, playerctl play-pause
bindl = , XF86AudioPrev, exec, playerctl previous
##############################
### WINDOWS AND WORKSPACES ###
##############################
# See https://wiki.hyprland.org/Configuring/Window-Rules/ for more
# See https://wiki.hyprland.org/Configuring/Workspace-Rules/ for workspace rules
# Example windowrule v1
# windowrule = float, ^(kitty)$
# Example windowrule v2
# windowrulev2 = float,class:^(kitty)$,title:^(kitty)$
# Ignore maximize requests from apps. You'll probably like this.
windowrulev2 = suppressevent maximize, class:.*
# Fix some dragging issues with XWayland
windowrulev2 = nofocus,class:^$,title:^$,xwayland:1,floating:1,fullscreen:0,pinned:0

View file

@ -0,0 +1,12 @@
# $DOTFILES/platforms/linux/hyprland/hypr/hyprpaper.conf
# Date: 2024-12-22
# Author: js0ny
# Hyprland Wallpaper autoloader
# Location:
# $XDG_CONFIG_HOME/hypr/hyprpaper.conf
# Linking: (Link the whole `hypr` directory)
# ln -sf $DOTFILES/platforms/linux/hyprland/hypr $XDG_CONFIG_HOME/hypr
preload = ~/Pictures/Wallpaper/current.jpg
wallpaper = DP-2, ~/Pictures/Wallpaper/current.jpg

View file

@ -1,7 +1,16 @@
# $DOTFILES/platforms/linux/kde/dolphinrc
# Date: 2024-12-22
# Author: js0ny
# Dolphin - KDE File Explorer
# Location:
# $XDG_CONFIG_HOME/dolphinrc
# Linking:
# ln -sf $DOTFILES/platforms/linux/kde/dolphinrc $XDG_CONFIG_HOME/dolphinrc
[General] [General]
Version=202 Version=202
ViewPropsTimestamp=2024,12,10,0,19,35.931 ViewPropsTimestamp=2024,12,10,0,19,35.931
[IconsMode] [IconsMode]
PreviewSize=80 PreviewSize=80

View file

@ -0,0 +1,19 @@
# $DOTFILES/platforms/linux/kde/krunnerrc
# Date: 2024-12-22
# Author: js0ny
# Krunner Config
# Location:
# $XDG_CONFIG_HOME/krunnerrc
# Linking:
# ln -sf $DOTFILES/platforms/linux/kde/krunnerrc $XDG_CONFIG_HOME/krunnerrc
[General]
FreeFloating=true
historyBehavior=ImmediateCompletion
[Plugins][Favorites]
plugins=krunner_dictionary,krunner_services,krunner_systemsettings
[Runners][krunner_dictionary]
triggerWord=d

View file

@ -1,9 +0,0 @@
[General]
FreeFloating=true
historyBehavior=ImmediateCompletion
[Plugins][Favorites]
plugins=krunner_dictionary,krunner_services,krunner_systemsettings
[Runners][krunner_dictionary]
triggerWord=d

View file

@ -1,15 +1,13 @@
# Use powerline # $DOTFILES/platforms/linux/zshrc
USE_POWERLINE="true" # Date: 2024-12-22
# Has weird character width # Author: js0ny
# Example: # Sourced by user's zshrc if is Linux 在用户的 zshrc 中被引用
#  is not a diamond # Entry point in $DOTFILES/tools/zsh/common.zshrc (入口点)
HAS_WIDECHARS="false"
alias open=dolphin
# Source manjaro-zsh-configuration if [ -n "$WAYLAND_DISPLAY" ]; then
if [[ -e /usr/share/zsh/manjaro-zsh-config ]]; then alias clip="wl-copy"
source /usr/share/zsh/manjaro-zsh-config alias paste="wl-paste"
else [ -n "$DISPLAY" ]; then
alias clip="xclip"
fi fi
# Use manjaro zsh prompt
# if [[ -e /usr/share/zsh/manjaro-zsh-prompt ]]; then
# source /usr/share/zsh/manjaro-zsh-prompt
# fi

View file

@ -6,7 +6,6 @@
# macOS # # macOS #
alias xclip="pbcopy"
alias clip="pbcopy" alias clip="pbcopy"
alias paste="pbpaste" alias paste="pbpaste"

View file

@ -6,7 +6,7 @@
export FILE_EXPLORER="explorer.exe" # Directory Opus export FILE_EXPLORER="explorer.exe" # Directory Opus
alias clip="clip.exe" alias clip="clip.exe"
alias xclip="clip.exe" alias clip="clip.exe"
alias paste='pwsh.exe -NoProfile -Command "Get-Clipboard"' alias paste='pwsh.exe -NoProfile -Command "Get-Clipboard"'
alias dark-mode='pwsh.exe -Command "dark-mode" 2>&1 /dev/null' alias dark-mode='pwsh.exe -Command "dark-mode" 2>&1 /dev/null'
alias winfetch='pwsh.exe -NoProfile -Command "winfetch"' alias winfetch='pwsh.exe -NoProfile -Command "winfetch"'

View file

@ -1,4 +1,11 @@
# $DOTFILES/tools/fish/conf.d/alias.fish
# Date: 2024-12-22
# Author: js0ny
# Location:
# ~/.config/fish/conf.d/alias.fish
# Linking: Link the whole directory for submodules
# ln -sf $DOTFILES/tools/fish ~/.config/fish
# Powershell equivalent # Powershell equivalent
abbr --add ni touch abbr --add ni touch
@ -8,7 +15,7 @@ abbr --add ii open
# Editors # # Editors #
abbr --add v nvim abbr --add v nvim
abbr --add c code abbr --add c code
alias sv="sudo vim -u ~/.config/vim/vimrc" alias sv="sudo vim -u ~/.dotfiles/common/vim.noxdg.vimrc"
alias sn="sudo nvim -u ~/.config/nvim/init.lua" alias sn="sudo nvim -u ~/.config/nvim/init.lua"
# Dev # # Dev #

View file

@ -1,10 +1,20 @@
# $DOTFILES/tools/fish/conf.d/keymap.fish
# Date: 2024-12-22
# Author: js0ny
# Location:
# ~/.config/fish/conf.d/keymap.fish
# Linking: Link the whole directory for submodules
# ln -sf $DOTFILES/tools/fish ~/.config/fish
fish_vi_key_bindings fish_vi_key_bindings
# Colemak hnei # Colemak hnei
# ^ # ^
# n
# < h i >
# e # e
# < h i >
# n
# v # v
# bind -M default 'h' backward-char # bind -M default 'h' backward-char
bind -M default 'n' down-or-search bind -M default 'n' down-or-search
@ -14,3 +24,5 @@ bind -M default 'i' forward-char
# Similar position to [i] in QWERTY # Similar position to [i] in QWERTY
bind -M default -m insert l repaint-mode bind -M default -m insert l repaint-mode
bind -M default -m insert L beginning-of-line repaint-mode bind -M default -m insert L beginning-of-line repaint-mode
# TODO: Add more key bindings here

View file

@ -1,3 +1,11 @@
# $DOTFILES/tools/fish/conf.d/navi.fish
# Date: 2024-12-22
# Author: js0ny
# Location:
# ~/.config/fish/conf.d/navi.fish
# Linking: Link the whole directory for submodules
# ln -sf $DOTFILES/tools/fish ~/.config/fish
alias ..="cd .." alias ..="cd .."

View file

@ -1,3 +1,11 @@
# $DOTFILES/tools/fish/conf.d/prompt.fish
# Date: 2024-12-22
# Author: js0ny
# Location:
# ~/.config/fish/conf.d/prompt.fish
# Linking: Link the whole directory for submodules
# ln -sf $DOTFILES/tools/fish ~/.config/fish
if command -v starship > /dev/null if command -v starship > /dev/null
set -gx STARSHIP_CONFIG $DOTFILES/tools/starship/starship_fish.toml set -gx STARSHIP_CONFIG $DOTFILES/tools/starship/starship_fish.toml

View file

@ -1,17 +1,21 @@
-- Entry point of the plugin manager -- Entry point of the plugin manager
local lazypath = vim.fn.stdpath("data") .. "/lazy/lazy.nvim" local lazypath = vim.fn.stdpath("data") .. "/lazy/lazy.nvim"
if not vim.loop.fs_stat(lazypath) then if not (vim.uv or vim.loop).fs_stat(lazypath) then
vim.fn.system({ local lazyrepo = "https://github.com/folke/lazy.nvim.git"
"git", local out = vim.fn.system({ "git", "clone", "--filter=blob:none", "--branch=stable", lazyrepo, lazypath })
"clone", if vim.v.shell_error ~= 0 then
"--filter=blob:none", vim.api.nvim_echo({
"https://github.com/folke/lazy.nvim.git", { "Failed to clone lazy.nvim:\n", "ErrorMsg" },
"--branch=stable", { out, "WarningMsg" },
lazypath, { "\nPress any key to exit..." },
}) }, true, {})
vim.fn.getchar()
os.exit(1)
end
end end
vim.opt.rtp:prepend(lazypath) vim.opt.rtp:prepend(lazypath)
require("lazy").setup({ require("lazy").setup({
{ import = "plugins.appearance" }, { import = "plugins.appearance" },
{ import = "plugins.completion" }, { import = "plugins.completion" },

View file

@ -26,7 +26,7 @@ alias pulldots="cd $DOTFILES && git pull"
# Editors # # Editors #
alias v=nvim alias v=nvim
alias c=code alias c=code
alias sv="sudo vim -u ~/.config/vim/vimrc" alias sv="sudo vim -u ~/.dotfiles/common/vim.noxdg.vimrc"
alias sn="sudo nvim -u ~/.config/nvim/init.lua" alias sn="sudo nvim -u ~/.config/nvim/init.lua"
# lsd - modern ls # lsd - modern ls