diff --git a/config/hypr/hyprland.conf b/config/hypr/hyprland.conf new file mode 100644 index 0000000..44da35d --- /dev/null +++ b/config/hypr/hyprland.conf @@ -0,0 +1,319 @@ + +# ####################################################################################### +# 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 = 1 # 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 + + +################ +### MONITORS ### +################ + +# See https://wiki.hyprland.org/Configuring/Monitors/ +monitor=,preferred,auto,1 + + +################### +### MY PROGRAMS ### +################### + +# See https://wiki.hyprland.org/Configuring/Keywords/ + +# Set programs that you use +$terminal = st +$fileManager = st -e ranger +$menu = rofi -show run +$screenie = screenie + + +################# +### AUTOSTART ### +################# + +# Autostart necessary processes (like notifications daemons, status bars, etc.) +# Or execute your favorite apps at launch like this: + +# exec-once = $terminal +# exec-once = nm-applet & +# exec-once = waybar & hyprpaper & firefox +exec-once = waybar +exec-once = swww-daemon +exec-once = swww img ~/files/pics/wallhaven-r7899j_1920x1080.png +exec-once = hyprctl setcursor breeze_cursors 24 + +############################# +### ENVIRONMENT VARIABLES ### +############################# + +# See https://wiki.hyprland.org/Configuring/Environment-variables/ + +env = XCURSOR_SIZE,24 +env = HYPRCURSOR_SIZE,24 + + +################### +### PERMISSIONS ### +################### + +# See https://wiki.hyprland.org/Configuring/Permissions/ +# Please note permission changes here require a Hyprland restart and are not applied on-the-fly +# for security reasons + +# ecosystem { +# enforce_permissions = 1 +# } + +# permission = /usr/(bin|local/bin)/grim, screencopy, allow +# permission = /usr/(lib|libexec|lib64)/xdg-desktop-portal-hyprland, screencopy, allow +# permission = /usr/(bin|local/bin)/hyprpm, plugin, allow + + +##################### +### LOOK AND FEEL ### +##################### + +# Refer to https://wiki.hyprland.org/Configuring/Variables/ + +# https://wiki.hyprland.org/Configuring/Variables/#general +general { + gaps_in = 5 + gaps_out = 8.8 + + border_size = 1 + + # https://wiki.hyprland.org/Configuring/Variables/#variable-types for info about colors + # 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 + +col.active_border = rgba(646496ee) rgba(121218ee) 45deg +col.inactive_border = rgba(404040cc) + +} + +# https://wiki.hyprland.org/Configuring/Variables/#decoration +decoration { + rounding = 0 + rounding_power = 2 + + # Change transparency of focused and unfocused windows + active_opacity = 1.0 + inactive_opacity = 1.0 + + shadow { + enabled = true + range = 4 + render_power = 3 + color = rgba(1a1a1aee) + } + + # https://wiki.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 +# windowrule = bordersize 0, floating:0, onworkspace:w[tv1] +# windowrule = rounding 0, floating:0, onworkspace:w[tv1] +# windowrule = bordersize 0, floating:0, onworkspace:f[1] +# windowrule = 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 + +bind = $mainMod, B, exec, firefox-bin +bind = $mainMod, PRINT, exec, screenie + +# Example binds, see https://wiki.hyprland.org/Configuring/Binds/ for more +bind = $mainMod, Return, exec, $terminal +bind = $mainMod, S, killactive, +bind = $mainMod, Q, exit, +bind = $mainMod, F, exec, $fileManager +bind = $mainMod, V, togglefloating, +bind = $mainMod, R, exec, $menu +bind = $mainMod, P, pseudo, # dwindle +bind = $mainMod, J, togglesplit, # dwindle + +# Move focus with mainMod + arrow keys +bind = $mainMod, left, movefocus, l +bind = $mainMod, right, movefocus, r +bind = $mainMod, up, movefocus, u +bind = $mainMod, down, movefocus, d + +# Switch workspaces with mainMod + [0-9] +bind = $mainMod, 1, workspace, 1 +bind = $mainMod, 2, workspace, 2 +bind = $mainMod, 3, workspace, 3 +bind = $mainMod, 4, workspace, 4 +bind = $mainMod, 5, workspace, 5 +bind = $mainMod, 6, workspace, 6 +bind = $mainMod, 7, workspace, 7 +bind = $mainMod, 8, workspace, 8 +bind = $mainMod, 9, workspace, 9 +bind = $mainMod, 0, workspace, 10 + +# Move active window to a workspace with mainMod + SHIFT + [0-9] +bind = $mainMod SHIFT, 1, movetoworkspace, 1 +bind = $mainMod SHIFT, 2, movetoworkspace, 2 +bind = $mainMod SHIFT, 3, movetoworkspace, 3 +bind = $mainMod SHIFT, 4, movetoworkspace, 4 +bind = $mainMod SHIFT, 5, movetoworkspace, 5 +bind = $mainMod SHIFT, 6, movetoworkspace, 6 +bind = $mainMod SHIFT, 7, movetoworkspace, 7 +bind = $mainMod SHIFT, 8, movetoworkspace, 8 +bind = $mainMod SHIFT, 9, movetoworkspace, 9 +bind = $mainMod SHIFT, 0, movetoworkspace, 10 + +# Example special workspace (scratchpad) +#bind = $mainMod, S, togglespecialworkspace, magic +bind = $mainMod SHIFT, S, movetoworkspace, special:magic + +# Scroll through existing workspaces with mainMod + scroll +bind = $mainMod, mouse_down, workspace, e+1 +bind = $mainMod, mouse_up, workspace, e-1 + +# Move/resize windows with mainMod + LMB/RMB and dragging +bindm = $mainMod, mouse:272, movewindow +bindm = $mainMod, mouse:273, resizewindow + +# Laptop multimedia keys for volume and LCD brightness +bindel = ,XF86AudioRaiseVolume, exec, wpctl set-volume -l 1 @DEFAULT_AUDIO_SINK@ 5%+ +bindel = ,XF86AudioLowerVolume, exec, wpctl set-volume @DEFAULT_AUDIO_SINK@ 5%- +bindel = ,XF86AudioMute, exec, wpctl set-mute @DEFAULT_AUDIO_SINK@ toggle +bindel = ,XF86AudioMicMute, exec, wpctl set-mute @DEFAULT_AUDIO_SOURCE@ toggle +bindel = ,XF86MonBrightnessUp, exec, brightnessctl -e4 -n2 set 5%+ +bindel = ,XF86MonBrightnessDown, exec, brightnessctl -e4 -n2 set 5%- + +# Requires playerctl +bindl = , XF86AudioNext, exec, playerctl next +bindl = , XF86AudioPause, exec, playerctl play-pause +bindl = , XF86AudioPlay, exec, playerctl play-pause +bindl = , XF86AudioPrev, exec, playerctl previous + +############################## +### WINDOWS AND WORKSPACES ### +############################## + +# See https://wiki.hyprland.org/Configuring/Window-Rules/ for more +# See https://wiki.hyprland.org/Configuring/Workspace-Rules/ for workspace rules + +# Example windowrule +# windowrule = float,class:^(kitty)$,title:^(kitty)$ + +# Ignore maximize requests from apps. You'll probably like this. +windowrule = suppressevent maximize, class:.* + +# Fix some dragging issues with XWayland +windowrule = nofocus,class:^$,title:^$,xwayland:1,floating:1,fullscreen:0,pinned:0 diff --git a/config/waybar/.config.swp b/config/waybar/.config.swp new file mode 100644 index 0000000..1512331 Binary files /dev/null and b/config/waybar/.config.swp differ diff --git a/config/waybar/.style.css.swp b/config/waybar/.style.css.swp new file mode 100644 index 0000000..9b484a6 Binary files /dev/null and b/config/waybar/.style.css.swp differ diff --git a/config/waybar/config b/config/waybar/config new file mode 100644 index 0000000..fff2d81 --- /dev/null +++ b/config/waybar/config @@ -0,0 +1,61 @@ +{ + "$schema": "https://raw.githubusercontent.com/Alexays/Waybar/master/schemas/config.schema.json", + "layer": "top", + "position": "top", + "height": 32, + "margin": "4 6 2 6", + "spacing": 4, + "modules-left": ["hyprland/workspaces"], + "modules-center": ["clock"], + "modules-right": ["pulseaudio", "cpu", "memory", "battery", "tray"], + + "hyprland/workspaces": { + "format": "{name}", + "format-icons": { + "active": "●", + "default": "○", + "urgent": "!" + }, + "on-click": "activate", + "disable-scroll": false + }, + + "clock": { + "format": "{:%I:%M %p}", + "tooltip-format": "{:%A, %d %B}", + "interval": 60 + }, + + "cpu": { + "format": "CPU {usage}%", + "interval": 5 + }, + + "memory": { + "format": "MEM {percentage}%", + "interval": 5 + }, + + "battery": { + "format": "BAT {capacity}%", + "format-icons": ["", "", "", "", ""], + "states": { + "warning": 20, + "critical": 10 + }, + "interval": 5 + }, + + "pulseaudio": { + "format": "VOL {volume}%", + "format-muted": "󰝟 Muted", + "format-icons": ["", "", ""], + "scroll-step": 5, + "on-click": "pactl set-sink-mute @DEFAULT_SINK@ toggle" + }, + + "tray": { + "spacing": 6, + "icon-size": 16 + } +} diff --git a/config/waybar/style.css b/config/waybar/style.css new file mode 100644 index 0000000..31ee1c0 --- /dev/null +++ b/config/waybar/style.css @@ -0,0 +1,52 @@ +* { + all: unset; + font-family: "Iosevka Term", "Symbols Nerd Font"; + font-size: 14px; + font-weight: 500; +} + +window#waybar { + background-color: #121218; + color: #e0e0e0; + border-bottom: 1px solid #646496; +} + +/* Workspaces */ +#workspaces button { + color: #6e6a86; + padding: 0 6px; +} + +#workspaces button.active { + color: #ffffff; + background: rgba(100, 100, 150, 0.2); +} + +#workspaces button.urgent { + color: #eb6f92; +} + +/* Modules */ +#clock, #cpu, #memory, #battery, #pulseaudio, #tray { + padding: 0 8px; + margin: 0 2px; +} + +/* Battery states */ +#battery.warning { + color: #f6c177; +} + +#battery.critical { + color: #eb6f92; + animation: blink 1s linear infinite; +} + +@keyframes blink { + 50% { opacity: 0; } +} + +/* Pulseaudio muted state */ +#pulseaudio.muted { + color: #6e6a86; +} diff --git a/suckless/dmenu/dmenu b/suckless/dmenu/dmenu index 656bab8..28c9d8a 100755 Binary files a/suckless/dmenu/dmenu and b/suckless/dmenu/dmenu differ diff --git a/suckless/dmenu/dmenu.o b/suckless/dmenu/dmenu.o index e491592..7028ae2 100644 Binary files a/suckless/dmenu/dmenu.o and b/suckless/dmenu/dmenu.o differ diff --git a/suckless/dmenu/drw.o b/suckless/dmenu/drw.o index dbafb16..69dbfa9 100644 Binary files a/suckless/dmenu/drw.o and b/suckless/dmenu/drw.o differ diff --git a/suckless/dmenu/stest b/suckless/dmenu/stest index 45f7c04..344348c 100755 Binary files a/suckless/dmenu/stest and b/suckless/dmenu/stest differ diff --git a/suckless/dmenu/stest.o b/suckless/dmenu/stest.o index a2b3e88..3d5045e 100644 Binary files a/suckless/dmenu/stest.o and b/suckless/dmenu/stest.o differ diff --git a/suckless/dmenu/util.o b/suckless/dmenu/util.o index 26adb18..5dd48bf 100644 Binary files a/suckless/dmenu/util.o and b/suckless/dmenu/util.o differ diff --git a/suckless/dwm/drw.o b/suckless/dwm/drw.o index dbafb16..69dbfa9 100644 Binary files a/suckless/dwm/drw.o and b/suckless/dwm/drw.o differ diff --git a/suckless/dwm/dwm b/suckless/dwm/dwm index 3628153..ee9c011 100755 Binary files a/suckless/dwm/dwm and b/suckless/dwm/dwm differ diff --git a/suckless/dwm/dwm.o b/suckless/dwm/dwm.o index 7c4854b..796d8ce 100644 Binary files a/suckless/dwm/dwm.o and b/suckless/dwm/dwm.o differ diff --git a/suckless/dwm/util.o b/suckless/dwm/util.o index 26adb18..5dd48bf 100644 Binary files a/suckless/dwm/util.o and b/suckless/dwm/util.o differ diff --git a/suckless/slstatus/components/battery.o b/suckless/slstatus/components/battery.o index 7f1c3e8..28b2ca7 100644 Binary files a/suckless/slstatus/components/battery.o and b/suckless/slstatus/components/battery.o differ diff --git a/suckless/slstatus/components/cat.o b/suckless/slstatus/components/cat.o index 6c3820d..b861349 100644 Binary files a/suckless/slstatus/components/cat.o and b/suckless/slstatus/components/cat.o differ diff --git a/suckless/slstatus/components/cpu.o b/suckless/slstatus/components/cpu.o index 8e1bfc1..8b3d1b1 100644 Binary files a/suckless/slstatus/components/cpu.o and b/suckless/slstatus/components/cpu.o differ diff --git a/suckless/slstatus/components/datetime.o b/suckless/slstatus/components/datetime.o index 225a048..9181ae6 100644 Binary files a/suckless/slstatus/components/datetime.o and b/suckless/slstatus/components/datetime.o differ diff --git a/suckless/slstatus/components/disk.o b/suckless/slstatus/components/disk.o index f3bd7bd..edb3cfb 100644 Binary files a/suckless/slstatus/components/disk.o and b/suckless/slstatus/components/disk.o differ diff --git a/suckless/slstatus/components/entropy.o b/suckless/slstatus/components/entropy.o index 53d9b82..8547174 100644 Binary files a/suckless/slstatus/components/entropy.o and b/suckless/slstatus/components/entropy.o differ diff --git a/suckless/slstatus/components/hostname.o b/suckless/slstatus/components/hostname.o index e678e25..20e1d33 100644 Binary files a/suckless/slstatus/components/hostname.o and b/suckless/slstatus/components/hostname.o differ diff --git a/suckless/slstatus/components/ip.o b/suckless/slstatus/components/ip.o index 66982f1..e1543a5 100644 Binary files a/suckless/slstatus/components/ip.o and b/suckless/slstatus/components/ip.o differ diff --git a/suckless/slstatus/components/kernel_release.o b/suckless/slstatus/components/kernel_release.o index 207785e..978d5f9 100644 Binary files a/suckless/slstatus/components/kernel_release.o and b/suckless/slstatus/components/kernel_release.o differ diff --git a/suckless/slstatus/components/keyboard_indicators.o b/suckless/slstatus/components/keyboard_indicators.o index 5542fb2..7df304b 100644 Binary files a/suckless/slstatus/components/keyboard_indicators.o and b/suckless/slstatus/components/keyboard_indicators.o differ diff --git a/suckless/slstatus/components/keymap.o b/suckless/slstatus/components/keymap.o index 0737998..5a582c4 100644 Binary files a/suckless/slstatus/components/keymap.o and b/suckless/slstatus/components/keymap.o differ diff --git a/suckless/slstatus/components/load_avg.o b/suckless/slstatus/components/load_avg.o index 3be39fc..735d51d 100644 Binary files a/suckless/slstatus/components/load_avg.o and b/suckless/slstatus/components/load_avg.o differ diff --git a/suckless/slstatus/components/netspeeds.o b/suckless/slstatus/components/netspeeds.o index 9d8e32c..4afd7ae 100644 Binary files a/suckless/slstatus/components/netspeeds.o and b/suckless/slstatus/components/netspeeds.o differ diff --git a/suckless/slstatus/components/num_files.o b/suckless/slstatus/components/num_files.o index b18b49e..a347143 100644 Binary files a/suckless/slstatus/components/num_files.o and b/suckless/slstatus/components/num_files.o differ diff --git a/suckless/slstatus/components/ram.o b/suckless/slstatus/components/ram.o index 55c1c63..7e34de6 100644 Binary files a/suckless/slstatus/components/ram.o and b/suckless/slstatus/components/ram.o differ diff --git a/suckless/slstatus/components/run_command.o b/suckless/slstatus/components/run_command.o index 1499323..2a88b65 100644 Binary files a/suckless/slstatus/components/run_command.o and b/suckless/slstatus/components/run_command.o differ diff --git a/suckless/slstatus/components/swap.o b/suckless/slstatus/components/swap.o index b5cf1d7..dfdca6c 100644 Binary files a/suckless/slstatus/components/swap.o and b/suckless/slstatus/components/swap.o differ diff --git a/suckless/slstatus/components/temperature.o b/suckless/slstatus/components/temperature.o index 0a95a28..5663e46 100644 Binary files a/suckless/slstatus/components/temperature.o and b/suckless/slstatus/components/temperature.o differ diff --git a/suckless/slstatus/components/uptime.o b/suckless/slstatus/components/uptime.o index 61f6704..aa75195 100644 Binary files a/suckless/slstatus/components/uptime.o and b/suckless/slstatus/components/uptime.o differ diff --git a/suckless/slstatus/components/user.o b/suckless/slstatus/components/user.o index 7e2240e..f58bb3a 100644 Binary files a/suckless/slstatus/components/user.o and b/suckless/slstatus/components/user.o differ diff --git a/suckless/slstatus/components/volume.o b/suckless/slstatus/components/volume.o index 9328f11..e42a586 100644 Binary files a/suckless/slstatus/components/volume.o and b/suckless/slstatus/components/volume.o differ diff --git a/suckless/slstatus/components/wifi.o b/suckless/slstatus/components/wifi.o index 52d77f8..2c7a79c 100644 Binary files a/suckless/slstatus/components/wifi.o and b/suckless/slstatus/components/wifi.o differ diff --git a/suckless/slstatus/slstatus b/suckless/slstatus/slstatus index d51fc58..a5bf5c3 100755 Binary files a/suckless/slstatus/slstatus and b/suckless/slstatus/slstatus differ diff --git a/suckless/slstatus/slstatus.o b/suckless/slstatus/slstatus.o index 7333d70..551855b 100644 Binary files a/suckless/slstatus/slstatus.o and b/suckless/slstatus/slstatus.o differ diff --git a/suckless/slstatus/util.o b/suckless/slstatus/util.o index 8cc5fdb..b5454d1 100644 Binary files a/suckless/slstatus/util.o and b/suckless/slstatus/util.o differ diff --git a/suckless/st/hb.o b/suckless/st/hb.o index 5efaf3e..34d5bbe 100644 Binary files a/suckless/st/hb.o and b/suckless/st/hb.o differ diff --git a/suckless/st/st b/suckless/st/st index 049a7cf..a80dd98 100755 Binary files a/suckless/st/st and b/suckless/st/st differ diff --git a/suckless/st/st.o b/suckless/st/st.o index 6f4b43b..53e6ffd 100644 Binary files a/suckless/st/st.o and b/suckless/st/st.o differ diff --git a/suckless/st/x.o b/suckless/st/x.o index 9c23ee6..cde21ef 100644 Binary files a/suckless/st/x.o and b/suckless/st/x.o differ