commit d4136d41293b50f2c76f5e526fc1a56509b4e734 Author: transcaffeine Date: Sat Sep 14 14:51:03 2024 +0200 feat: initial commit diff --git a/.gitmodules b/.gitmodules new file mode 100644 index 0000000..b05ff7b --- /dev/null +++ b/.gitmodules @@ -0,0 +1,3 @@ +[submodule "config/alacritty/themes"] + path = config/alacritty/themes + url = git@github.com:alacritty/alacritty-theme.git diff --git a/config/JetBrains/IdeaIC2024.1/idea64.vmoptions b/config/JetBrains/IdeaIC2024.1/idea64.vmoptions new file mode 100644 index 0000000..ce6d033 --- /dev/null +++ b/config/JetBrains/IdeaIC2024.1/idea64.vmoptions @@ -0,0 +1,2 @@ +-Dawt.toolkit.name=WLToolkit +-Xmx4096m diff --git a/config/JetBrains/IdeaIC2024.1/options/colors.scheme.xml b/config/JetBrains/IdeaIC2024.1/options/colors.scheme.xml new file mode 100644 index 0000000..a7fa7c5 --- /dev/null +++ b/config/JetBrains/IdeaIC2024.1/options/colors.scheme.xml @@ -0,0 +1,5 @@ + + + + + \ No newline at end of file diff --git a/config/alacritty/alacritty.toml b/config/alacritty/alacritty.toml new file mode 100644 index 0000000..6579b39 --- /dev/null +++ b/config/alacritty/alacritty.toml @@ -0,0 +1,6 @@ +import = [ + "~/.config/alacritty/themes/current-theme.toml" +] + +live_config_reload = true +ipc_socket = true diff --git a/config/alacritty/themes b/config/alacritty/themes new file mode 160000 index 0000000..e759daf --- /dev/null +++ b/config/alacritty/themes @@ -0,0 +1 @@ +Subproject commit e759dafb8e2e00abb428592979ce006da7fba4a7 diff --git a/config/darkman/config.yaml b/config/darkman/config.yaml new file mode 100644 index 0000000..b1b3fd4 --- /dev/null +++ b/config/darkman/config.yaml @@ -0,0 +1,4 @@ +lat: redacted +lng: redacted +dbusserver: true +portal: true diff --git a/config/htop/htoprc b/config/htop/htoprc new file mode 100644 index 0000000..6c380dc --- /dev/null +++ b/config/htop/htoprc @@ -0,0 +1,67 @@ +# Beware! This file is rewritten by htop when settings are changed in the interface. +# The parser is also very primitive, and not human-friendly. +htop_version=3.3.0 +config_reader_min_version=3 +fields=0 48 17 18 38 39 40 2 46 47 49 1 +hide_kernel_threads=1 +hide_userland_threads=0 +hide_running_in_container=0 +shadow_other_users=0 +show_thread_names=0 +show_program_path=0 +highlight_base_name=0 +highlight_deleted_exe=1 +shadow_distribution_path_prefix=0 +highlight_megabytes=1 +highlight_threads=1 +highlight_changes=0 +highlight_changes_delay_secs=5 +find_comm_in_cmdline=1 +strip_exe_from_cmdline=1 +show_merged_command=0 +header_margin=1 +screen_tabs=1 +detailed_cpu_time=0 +cpu_count_from_one=0 +show_cpu_usage=1 +show_cpu_frequency=1 +show_cpu_temperature=1 +degree_fahrenheit=0 +update_process_names=0 +account_guest_in_cpu_meter=0 +color_scheme=0 +enable_mouse=1 +delay=15 +hide_function_bar=0 +header_layout=four_25_25_25_25 +column_meters_0=LeftCPUs +column_meter_modes_0=1 +column_meters_1=RightCPUs +column_meter_modes_1=1 +column_meters_2=Memory Swap HugePages Blank LoadAverage Tasks DiskIO NetworkIO +column_meter_modes_2=1 1 1 2 2 2 2 2 +column_meters_3=Hostname Uptime DateTime Battery Blank Blank System SystemdUser +column_meter_modes_3=2 2 2 2 2 2 2 2 +tree_view=0 +sort_key=46 +tree_sort_key=46 +sort_direction=-1 +tree_sort_direction=-1 +tree_view_always_by_pid=0 +all_branches_collapsed=0 +screen:Main=PID USER PRIORITY NICE M_VIRT M_RESIDENT M_SHARE STATE PERCENT_CPU PERCENT_MEM TIME Command +.sort_key=PERCENT_CPU +.tree_sort_key=PERCENT_CPU +.tree_view_always_by_pid=0 +.tree_view=0 +.sort_direction=-1 +.tree_sort_direction=-1 +.all_branches_collapsed=0 +screen:I/O=PID USER IO_PRIORITY IO_RATE IO_READ_RATE IO_WRITE_RATE PERCENT_SWAP_DELAY PERCENT_IO_DELAY Command +.sort_key=IO_RATE +.tree_sort_key=PID +.tree_view_always_by_pid=0 +.tree_view=0 +.sort_direction=-1 +.tree_sort_direction=1 +.all_branches_collapsed=0 diff --git a/config/mako/config b/config/mako/config new file mode 100644 index 0000000..b287e79 --- /dev/null +++ b/config/mako/config @@ -0,0 +1,22 @@ +max-history=10 +background-color=#444444 +text-color=#ffffff +height=120 +border-color=#c2005b +anchor=top-right +default-timeout=10000 +max-visible=10 +# need libnotify so firefox etc use mako + +[mode=do-not-disturb] +invisible=1 + +[mode=system-light] +background-color=#eeeeee +text-color=#555555 +border-color=#c2005b + +[mode=system-dark] +background-color=#444444 +text-color=#ffffff +border-color=#c2005b diff --git a/config/sway/config b/config/sway/config new file mode 100644 index 0000000..264ed4e --- /dev/null +++ b/config/sway/config @@ -0,0 +1,257 @@ +# Default config for sway +# +# Copy this to ~/.config/sway/config and edit it to your liking. +# +# Read `man 5 sway` for a complete reference. + +### Variables +# +# Logo key. Use Mod1 for Alt. +set $mod Mod4 +# Home row direction keys, like vim +set $left h +set $down j +set $up k +set $right l +# Your preferred terminal emulator +set $term alacritty +# Your preferred application launcher +# Note: pass the final command to swaymsg so that the resulting window can be opened +# on the original workspace that the command was run on. +#set $menu dmenu_path | dmenu | xargs swaymsg exec -- + +### Output configuration +# +# Default wallpaper (more resolutions are available in /usr/share/backgrounds/sway/) +output * bg /usr/share/backgrounds/sway/Sway_Wallpaper_Blue_1920x1080.png fill +# +# Example configuration: +# +# output HDMI-A-1 resolution 1920x1080 position 1920,0 +# +# You can get the names of your outputs by running: swaymsg -t get_outputs + +### Idle configuration +# +# Example configuration: +# + +exec_always "pkill swayidle; swayidle -w \ + timeout 300 'swaylock -F -l -f -c 111111' \ + timeout 900 'swaymsg \"output * power off\"' resume 'swaymsg \"output * power on\"' \ + before-sleep 'swaylock -F -l -f -c 111111'" + +set $lock swaylock -F -l -c 111111 --ring-color d90166 --ring-clear-color cccccc --ring-wrong-color ff0000 --line-color dddddd --key-hl-color fe2e90 +bindsym $mod+l exec $lock +# +# This will lock your screen after 300 seconds of inactivity, then turn off +# your displays after another 300 seconds, and turn your screens back on when +# resumed. It will also lock your screen before your computer goes to sleep. + +### Input configuration +# +# Example configuration: +# +# input "2:14:SynPS/2_Synaptics_TouchPad" { +# dwt enabled +# tap enabled +# natural_scroll enabled +# middle_emulation enabled +# } +# +# You can get the names of your inputs by running: swaymsg -t get_inputs +# Read `man 5 sway-input` for more information about this section. + +### Key bindings +# +# Basics: +# + # Start a terminal + bindsym $mod+Return exec $term + + # Kill focused window + bindsym $mod+Shift+q kill + + # Start your launcher + bindsym $mod+d exec $menu + + # Drag floating windows by holding down $mod and left mouse button. + # Resize them with right mouse button + $mod. + # Despite the name, also works for non-floating windows. + # Change normal to inverse to use left mouse button for resizing and right + # mouse button for dragging. + floating_modifier $mod normal + + # Reload the configuration file + bindsym $mod+Shift+c reload + + # Exit sway (logs you out of your Wayland session) + bindsym $mod+Shift+e exec swaynag -t warning -m 'You pressed the exit shortcut. Do you really want to exit sway? This will end your Wayland session.' -B 'Yes, exit sway' 'swaymsg exit' + + # Screenshot (grim+slurp) + bindsym print exec grim -g "$(slurp -d)" - | wl-copy + + # Media buttons / Brightness + bindsym --locked XF86MonBrightnessUp exec brightnessctl set +13 amdgpu_bl1 + bindsym --locked XF86MonBrightnessDown exec brightnessctl set 13- amdgpu_bl1 + bindsym --locked XF86AudioRaiseVolume exec "pw-volume change +2.5%;" + bindsym --locked XF86AudioLowerVolume exec "pw-volume change -2.5%;" + bindsym --locked XF86AudioMute exec "pw-volume mute toggle;" + +# +# Moving around: +# + + # Or use $mod+[up|down|left|right] + bindsym $mod+Left focus left + bindsym $mod+Down focus down + bindsym $mod+Up focus up + bindsym $mod+Right focus right + + # Ditto, with arrow keys + bindsym $mod+Shift+Left move left + bindsym $mod+Shift+Down move down + bindsym $mod+Shift+Up move up + bindsym $mod+Shift+Right move right + + # for entire workspaces + bindsym $mod+Control+Shift+Left move workspace to output left + bindsym $mod+Control+Shift+Down move workspace to output down + bindsym $mod+Control+Shift+Up move workspace to output up + bindsym $mod+Control+Shift+Right move workspace to output right +# +# Workspaces: +# + # Switch to workspace + bindsym $mod+1 workspace number 1 + bindsym $mod+2 workspace number 2 + bindsym $mod+3 workspace number 3 + bindsym $mod+4 workspace number 4 + bindsym $mod+5 workspace number 5 + bindsym $mod+6 workspace number 6 + bindsym $mod+7 workspace number 7 + bindsym $mod+8 workspace number 8 + bindsym $mod+9 workspace number 9 + bindsym $mod+0 workspace number 10 + # Move focused container to workspace + bindsym $mod+Shift+1 move container to workspace number 1 + bindsym $mod+Shift+2 move container to workspace number 2 + bindsym $mod+Shift+3 move container to workspace number 3 + bindsym $mod+Shift+4 move container to workspace number 4 + bindsym $mod+Shift+5 move container to workspace number 5 + bindsym $mod+Shift+6 move container to workspace number 6 + bindsym $mod+Shift+7 move container to workspace number 7 + bindsym $mod+Shift+8 move container to workspace number 8 + bindsym $mod+Shift+9 move container to workspace number 9 + bindsym $mod+Shift+0 move container to workspace number 10 + # Note: workspaces can have any name you want, not just numbers. + # We just use 1-10 as the default. +# +# Layout stuff: +# + # You can "split" the current object of your focus with + # $mod+b or $mod+v, for horizontal and vertical splits + # respectively. + bindsym $mod+b splith + bindsym $mod+v splitv + + # Switch the current container between different layout styles + bindsym $mod+s layout stacking + bindsym $mod+w layout tabbed + bindsym $mod+e layout toggle split + + # Make the current focus fullscreen + bindsym $mod+f fullscreen + + # Toggle the current focus between tiling and floating mode + bindsym $mod+Shift+space floating toggle + + # Swap focus between the tiling area and the floating area + #bindsym $mod+space focus mode_toggle + + # Move focus to the parent container + bindsym $mod+a focus parent +# +# Scratchpad: +# + # Sway has a "scratchpad", which is a bag of holding for windows. + # You can send windows there and get them back later. + + # Move the currently focused window to the scratchpad + bindsym $mod+Shift+minus move scratchpad + + # Show the next scratchpad window or hide the focused scratchpad window. + # If there are multiple scratchpad windows, this command cycles through them. + bindsym $mod+minus scratchpad show +# +# Resizing containers: +# +mode "resize" { + # left will shrink the containers width + # right will grow the containers width + # up will shrink the containers height + # down will grow the containers height + bindsym $left resize shrink width 10px + bindsym $down resize grow height 10px + bindsym $up resize shrink height 10px + bindsym $right resize grow width 10px + + # Ditto, with arrow keys + bindsym Left resize shrink width 10px + bindsym Down resize grow height 10px + bindsym Up resize shrink height 10px + bindsym Right resize grow width 10px + + # Return to default mode + bindsym Return mode "default" + bindsym Escape mode "default" +} +bindsym $mod+r mode "resize" + +# +# Status Bar: +# +# Read `man 5 sway-bar` for more information about this section. +#bar { +# position top + # When the status_command prints a new line to stdout, swaybar updates. + # The default just shows the current date and time. + #status_command while date +'%Y-%m-%d %I:%M:%S %p'; do sleep 1; done +#} + +# use sway-launcher-desktop +for_window [app_id="^launcher$"] floating enable, sticky enable, resize set 30 ppt 60 ppt, border pixel 5 +set $menu exec $term --class launcher -e /usr/bin/sway-launcher-desktop + +# style pinentry programs +for_window [app_id="^pinentry$"] floating enable, sticky enable, resize set 80 ppt 120 ppt, border pixel 2 + +# set picture-in-picture to floating +for_window [app_id="^firefox$" title="^Picture-in-Picture$"] floating enable, inhibit_idle visible; + +#for_window [class="^Nextcloud$" title="^Nextcloud$"] floating enable, sticky enable, border pixel 10; + +# Nag mode using swaynagmode +set $nag exec swaynagmode +mode "nag" { + bindsym { + Ctrl+d mode "default" + Ctrl+c $nag --exit + q $nag --exit + Escape $nag --exit + Return $nag --confirm + Shift+Tab $nag --select prev + Tab $nag --select next + Left $nag --select prev + Right $nag --select next + Up $nag --select prev + Down $nag --select next + } +} + +# launch kanshi +exec_always 'sleep 0.5; pkill kanshi' +exec_always 'sleep 0.75; kanshi' + +include ~/.config/sway/current-theme +include ~/.config/sway/config.d/* diff --git a/config/sway/config.d/10-systemd-user.conf b/config/sway/config.d/10-systemd-user.conf new file mode 100644 index 0000000..8781db9 --- /dev/null +++ b/config/sway/config.d/10-systemd-user.conf @@ -0,0 +1,16 @@ +# sway does not set DISPLAY/WAYLAND_DISPLAY in the systemd user environment +# See FS#63021 +# Adapted from xorg's 50-systemd-user.sh, which achieves a similar goal. + +# Upstream refuses to set XDG_CURRENT_DESKTOP so we have to. +exec systemctl --user set-environment XDG_CURRENT_DESKTOP=sway +exec systemctl --user import-environment DISPLAY \ + SWAYSOCK \ + WAYLAND_DISPLAY \ + XDG_CURRENT_DESKTOP + +exec hash dbus-update-activation-environment 2>/dev/null && \ + dbus-update-activation-environment --systemd DISPLAY \ + SWAYSOCK \ + XDG_CURRENT_DESKTOP=sway \ + WAYLAND_DISPLAY diff --git a/config/sway/config.d/20-systemd-user-sway-target.conf b/config/sway/config.d/20-systemd-user-sway-target.conf new file mode 100644 index 0000000..6a0e6bc --- /dev/null +++ b/config/sway/config.d/20-systemd-user-sway-target.conf @@ -0,0 +1,4 @@ +# see https://github.com/swaywm/sway/wiki/Systemd-integration +exec 'systemctl --user import-environment {,WAYLAND_}DISPLAY SWAYSOCK; systemctl --user start sway-session.target' +exec swaymsg -t subscribe '["shutdown"]' && systemctl --user stop sway-session.target + diff --git a/config/sway/current-theme b/config/sway/current-theme new file mode 120000 index 0000000..39b0bdd --- /dev/null +++ b/config/sway/current-theme @@ -0,0 +1 @@ +light-mode \ No newline at end of file diff --git a/config/sway/dark-mode b/config/sway/dark-mode new file mode 100644 index 0000000..aa672ff --- /dev/null +++ b/config/sway/dark-mode @@ -0,0 +1,14 @@ +bar { + position top + status_command i3status + colors { + statusline #dddddd + background #222222 + inactive_workspace #323232 #323232 #999999 + active_workspace #cccccc #c2005b #bbbbbb + focused_workspace #aaaaaa #d90166 #dddddd + } +} + +client.focused #555555 #444444 #eeeeee #2e92f4 #555555 +# vi:syntax=swayconfig diff --git a/config/sway/light-mode b/config/sway/light-mode new file mode 100644 index 0000000..abb22d8 --- /dev/null +++ b/config/sway/light-mode @@ -0,0 +1,19 @@ +bar { + position top + status_command i3status + colors { + statusline #222222 + background #ededed + # workspace type border background text + inactive_workspace #888888 #efefef #666666 + active_workspace #454545 #444444 #bbbbbb + focused_workspace #aaaaaa #d90166 #dddddd + } +} + +# class border background text indicator child_border +client.focused #c2005b #e0e0e0 #c2005b #2e92f4 #eeeeee +client.unfocused #bbbbbb #ededed #666666 +client.focused_inactive #777777 #bcbcbc #444444 + +# vi:syntax=swayconfig diff --git a/config/xdg-desktop-portal/sway-portals.conf b/config/xdg-desktop-portal/sway-portals.conf new file mode 100644 index 0000000..cd677a7 --- /dev/null +++ b/config/xdg-desktop-portal/sway-portals.conf @@ -0,0 +1,6 @@ +[preferred] +default=gtk +org.freedesktop.impl.ScreenCast=wlr +org.freedesktop.impl.Screenshot=wlr +org.freedesktop.impl.portal.Settings=darkman +org.freedesktop.impl.portal.Inhibit=none diff --git a/local/share/dark-mode.d/alacritty.sh b/local/share/dark-mode.d/alacritty.sh new file mode 100755 index 0000000..93deea6 --- /dev/null +++ b/local/share/dark-mode.d/alacritty.sh @@ -0,0 +1,4 @@ +#!/bin/bash + +ln -fs ../themes/themes/monokai_pro.toml .config/alacritty/themes/current-theme.toml +touch ~/.config/alacritty/alacritty.toml diff --git a/local/share/dark-mode.d/mako.sh b/local/share/dark-mode.d/mako.sh new file mode 100755 index 0000000..b98b751 --- /dev/null +++ b/local/share/dark-mode.d/mako.sh @@ -0,0 +1,3 @@ +#!/bin/bash + +makoctl set-mode system-dark diff --git a/local/share/dark-mode.d/sway.sh b/local/share/dark-mode.d/sway.sh new file mode 100755 index 0000000..33596f1 --- /dev/null +++ b/local/share/dark-mode.d/sway.sh @@ -0,0 +1,7 @@ +#!/bin/bash + +ln -fs dark-mode ~/.config/sway/current-theme + +SWAYSOCK="/run/user/$(id -u)/sway-ipc.$(id -u).$(pgrep -x sway).sock" + +swaymsg -s $SWAYSOCK reload diff --git a/local/share/dark-mode.d/tmux.sh b/local/share/dark-mode.d/tmux.sh new file mode 100755 index 0000000..be91e69 --- /dev/null +++ b/local/share/dark-mode.d/tmux.sh @@ -0,0 +1,7 @@ +#!/bin/bash + +ln -fs dark-mode.conf ~/.config/tmux/current-theme.conf + +if tmux list-sessions; then + tmux source ~/.tmux.conf +fi diff --git a/local/share/light-mode.d/alacritty.sh b/local/share/light-mode.d/alacritty.sh new file mode 100755 index 0000000..41026e0 --- /dev/null +++ b/local/share/light-mode.d/alacritty.sh @@ -0,0 +1,4 @@ +#!/bin/bash + +ln -fs ../themes/themes/catppuccin_latte.toml .config/alacritty/themes/current-theme.toml +touch ~/.config/alacritty/alacritty.toml diff --git a/local/share/light-mode.d/mako.sh b/local/share/light-mode.d/mako.sh new file mode 100755 index 0000000..af8ba8a --- /dev/null +++ b/local/share/light-mode.d/mako.sh @@ -0,0 +1,3 @@ +#!/bin/bash + +makoctl set-mode system-light diff --git a/local/share/light-mode.d/sway.sh b/local/share/light-mode.d/sway.sh new file mode 100755 index 0000000..279fcc4 --- /dev/null +++ b/local/share/light-mode.d/sway.sh @@ -0,0 +1,7 @@ +#!/bin/bash + +ln -fs light-mode ~/.config/sway/current-theme + +SWAYSOCK="/run/user/$(id -u)/sway-ipc.$(id -u).$(pgrep -x sway).sock" + +swaymsg -s $SWAYSOCK reload diff --git a/local/share/light-mode.d/tmux.sh b/local/share/light-mode.d/tmux.sh new file mode 100755 index 0000000..1397d2d --- /dev/null +++ b/local/share/light-mode.d/tmux.sh @@ -0,0 +1,7 @@ +#!/bin/bash + +ln -fs light-mode.conf ~/.config/tmux/current-theme.conf + +if tmux list-sesions; then + tmux source ~/.tmux.conf +fi