Compare commits

..

No commits in common. "master" and "v1.0.3" have entirely different histories.

28 changed files with 107 additions and 507 deletions

80
debian/changelog vendored
View file

@ -1,83 +1,3 @@
tileos-settings-river (1.2.1~tileos) unstable; urgency=medium
* Fix screnlocker
-- Aleksey Samoilov <samoilov.lex@gmail.com> Fri, 06 Jun 2025 20:33:13 +0400
tileos-settings-river (1.2.0~tileos) unstable; urgency=medium
* Add mic-mute.sh script for toggling microphone on/off
-- Aleksey Samoilov <samoilov.lex@gmail.com> Sat, 19 Oct 2024 23:41:50 +0400
tileos-settings-river (1.1.5~tileos) unstable; urgency=medium
* Updates from Sway edition
-- Aleksey Samoilov <samoilov.lex@gmail.com> Wed, 04 Sep 2024 21:37:22 +0400
tileos-settings-river (1.1.4~tileos) unstable; urgency=medium
* Pass SSH_AUTH_SOCK to all processes
-- Aleksey Samoilov <samoilov.lex@gmail.com> Thu, 25 Jul 2024 00:00:10 +0400
tileos-settings-river (1.1.3~tileos) unstable; urgency=medium
* Fix swayidle restart path
* Added waybar restart path
-- Aleksey Samoilov <samoilov.lex@gmail.com> Tue, 23 Jul 2024 18:29:06 +0400
tileos-settings-river (1.1.2~tileos) unstable; urgency=medium
* Some fixes
-- Aleksey Samoilov <samoilov.lex@gmail.com> Sat, 20 Jul 2024 15:03:38 +0400
tileos-settings-river (1.1.1~tileos) unstable; urgency=medium
* Set qt6 style to kvantum-dark
-- Aleksey Samoilov <samoilov.lex@gmail.com> Wed, 19 Jun 2024 17:02:21 +0400
tileos-settings-river (1.1.0~tileos) unstable; urgency=medium
* waybar: limit window name characters to 50
-- Aleksey Samoilov <samoilov.lex@gmail.com> Tue, 02 Apr 2024 16:09:36 +0400
tileos-settings-river (1.0.8~tileos) unstable; urgency=medium
* correct regexp in getSymbolDict
-- Aleksey Samoilov <samoilov.lex@gmail.com> Thu, 14 Mar 2024 10:26:55 +0400
tileos-settings-river (1.0.7~tileos) unstable; urgency=medium
* Change wallpaper
-- Aleksey Samoilov <samoilov.lex@gmail.com> Wed, 14 Feb 2024 22:58:39 +0400
tileos-settings-river (1.0.6~tileos) unstable; urgency=medium
* waybar: disable bluetooth module if no controller is found
-- Aleksey Samoilov <samoilov.lex@gmail.com> Thu, 08 Feb 2024 19:32:41 +0400
tileos-settings-river (1.0.5~tileos) unstable; urgency=medium
* Enable idle inhibit on startup
-- Aleksey Samoilov <samoilov.lex@gmail.com> Fri, 02 Feb 2024 22:38:13 +0400
tileos-settings-river (1.0.4~tileos) unstable; urgency=medium
* Add keybindings help overlay
* waybar: add help overlay module
-- Aleksey Samoilov <samoilov.lex@gmail.com> Mon, 29 Jan 2024 10:22:24 +0400
tileos-settings-river (1.0.3~tileos) unstable; urgency=medium tileos-settings-river (1.0.3~tileos) unstable; urgency=medium
* Fix cursor for GTK 2 apps * Fix cursor for GTK 2 apps

View file

@ -1,3 +1,3 @@
#!/usr/bin/env bash #!/usr/bin/env bash
pkill swaybg pkill swaybg
swaybg -o '*' -i "/usr/share/wallpapers/tileos-final-river.png" -m fill & swaybg -o '*' -i "/usr/share/wallpapers/tileos-final.png" -m fill &

View file

@ -1,97 +1,79 @@
color_set:
text: &TEXT "#cad3f5"
subtext0: &SUBTEXT0 "#e3e3f3"
subtext1: &SUBTEXT1 "#ced4e0"
surface2: &SURFACE2 "#5b6078"
surface1: &SURFACE1 "#494d64"
index16: &INDEX16 "#ed6c13"
index17: &INDEX17 "#f4dbd6"
base: &BASE "#24273a"
red: &RED "#ed6070"
green: &GREEN "#a6da95"
blue: &BLUE "#8aadf4"
yellow: &YELLOW "#eed49f"
pink: &PINK "#f5bde6"
teal: &TEAL "#8bd5ca"
rosewater: &ROSEWATER "#f4dbd6"
lavender: &LAVENDER "#b7bdf8"
colors: colors:
# Default colors # Default colors
primary: primary:
background: *BASE background: "#24273A" # base
foreground: *TEXT foreground: "#CAD3F5" # text
# Bright and dim foreground colors # Bright and dim foreground colors
dim_foreground: *TEXT dim_foreground: "#CAD3F5" # text
bright_foreground: *TEXT bright_foreground: "#CAD3F5" # text
# Cursor colors # Cursor colors
cursor: cursor:
text: *BASE text: "#24273A" # base
cursor: *ROSEWATER cursor: "#F4DBD6" # rosewater
vi_mode_cursor: vi_mode_cursor:
text: *BASE text: "#24273A" # base
cursor: *LAVENDER cursor: "#B7BDF8" # lavender
# Search colors # Search colors
search: search:
matches: matches:
foreground: *BASE foreground: "#24273A" # base
background: *SUBTEXT0 background: "#A5ADCB" # subtext0
focused_match: focused_match:
foreground: *BASE foreground: "#24273A" # base
background: *GREEN background: "#A6DA95" # green
footer_bar: footer_bar:
foreground: *BASE foreground: "#24273A" # base
background: *SUBTEXT0 background: "#A5ADCB" # subtext0
# Keyboard regex hints # Keyboard regex hints
hints: hints:
start: start:
foreground: *BASE foreground: "#24273A" # base
background: *YELLOW background: "#EED49F" # yellow
end: end:
foreground: *BASE foreground: "#24273A" # base
background: *SUBTEXT0 background: "#A5ADCB" # subtext0
# Selection colors # Selection colors
selection: selection:
text: *BASE text: "#24273A" # base
background: *ROSEWATER background: "#F4DBD6" # rosewater
# Normal colors # Normal colors
normal: normal:
black: *SURFACE1 black: "#494D64" # surface1
red: *RED red: "#ED8796" # red
green: *GREEN green: "#A6DA95" # green
yellow: *YELLOW yellow: "#EED49F" # yellow
blue: *BLUE blue: "#8AADF4" # blue
magenta: *PINK magenta: "#F5BDE6" # pink
cyan: *TEAL cyan: "#8BD5CA" # teal
white: *SUBTEXT1 white: "#B8C0E0" # subtext1
# Bright colors # Bright colors
bright: bright:
black: *SURFACE2 black: "#5B6078" # surface2
red: *RED red: "#ED8796" # red
green: *GREEN green: "#A6DA95" # green
yellow: *YELLOW yellow: "#EED49F" # yellow
blue: *BLUE blue: "#8AADF4" # blue
magenta: *PINK magenta: "#F5BDE6" # pink
cyan: *TEAL cyan: "#8BD5CA" # teal
white: *SUBTEXT0 white: "#A5ADCB" # subtext0
# Dim colors # Dim colors
dim: dim:
black: *SURFACE1 black: "#494D64" # surface1
red: *RED red: "#ED8796" # red
green: *GREEN green: "#A6DA95" # green
yellow: *YELLOW yellow: "#EED49F" # yellow
blue: *BLUE blue: "#8AADF4" # blue
magenta: *PINK magenta: "#F5BDE6" # pink
cyan: *TEAL cyan: "#8BD5CA" # teal
white: *SUBTEXT1 white: "#B8C0E0" # subtext1
indexed_colors: indexed_colors:
- { index: 16, color: *INDEX16 } - { index: 16, color: "#F5A97F" }
- { index: 17, color: *INDEX17 } - { index: 17, color: "#F4DBD6" }

View file

@ -1,15 +0,0 @@
{
adapter: ""
gsm-apn: ""
gsm-number: ""
keybindings: {}
receive-dir: ""
theme: {
AdapterPowered: "powderblue",
AdapterNotPowered: "lightcoral",
AdapterPairable: "thistle",
AdapterScanning: "mistyrose",
DevicePropertyDiscovered: "mistyrose",
DevicePropertyConnected: "powderblue"
}
}

View file

@ -58,7 +58,7 @@ theme[cached_mid]="#8aadf4"
theme[cached_end]="#b7bdf8" theme[cached_end]="#b7bdf8"
# Mem/Disk available meter (Peach -> Red) # Mem/Disk available meter (Peach -> Red)
theme[available_start]="#ed6c13" theme[available_start]="#f5a97f"
theme[available_mid]="#ee99a0" theme[available_mid]="#ee99a0"
theme[available_end]="#ed8796" theme[available_end]="#ed8796"
@ -68,7 +68,7 @@ theme[used_mid]="#8bd5ca"
theme[used_end]="#91d7e3" theme[used_end]="#91d7e3"
# Download graph colors (Peach -> Red) # Download graph colors (Peach -> Red)
theme[download_start]="#ed6c13" theme[download_start]="#f5a97f"
theme[download_mid]="#ee99a0" theme[download_mid]="#ee99a0"
theme[download_end]="#ed8796" theme[download_end]="#ed8796"

View file

@ -1,7 +1,7 @@
[ [
{ {
"label": "Lock", "label": "Lock",
"exec": "riverctl spawn /usr/share/river/scripts/lock.sh", "exec": "riverctl spawn ~/.config/swaylock/lock.sh",
"icon": "system-lock-screen" "icon": "system-lock-screen"
}, },
{ {

View file

@ -1,2 +0,0 @@
#!/bin/sh
/usr/share/river/scripts/sbdp.py $HOME/.config/river/keybindings.sh | jq --raw-output 'sort_by(.category) | .[] | .action + ": <b>" + .keybinding + "</b>"'

View file

@ -1,13 +0,0 @@
window {
background-color: @theme_bg_color;
font-size: medium;
color: #cad3f5;
}
#box-inner {
border-radius: 0px;
border-style: solid;
border-width: 2px;
border-color: #8aadf4;
padding: 10px;
}

View file

@ -13,9 +13,9 @@ Catppuccin Gedit theme based on Oblivion theme and Cappuccin for Visual Studio C
<color name="macchiato_flamingo" value="#f0c6c6"/> <color name="macchiato_flamingo" value="#f0c6c6"/>
<color name="macchiato_pink" value="#f5bde6"/> <color name="macchiato_pink" value="#f5bde6"/>
<color name="macchiato_mauve" value="#c6a0f6"/> <color name="macchiato_mauve" value="#c6a0f6"/>
<color name="macchiato_red" value="#ed6070"/> <color name="macchiato_red" value="#ed8796"/>
<color name="macchiato_maroon" value="#ee99a0"/> <color name="macchiato_maroon" value="#ee99a0"/>
<color name="macchiato_peach" value="#ed6c13"/> <color name="macchiato_peach" value="#f5a97f"/>
<color name="macchiato_yellow" value="#eed49f"/> <color name="macchiato_yellow" value="#eed49f"/>
<color name="macchiato_green" value="#a6da95"/> <color name="macchiato_green" value="#a6da95"/>
<color name="macchiato_teal" value="#8bd5ca"/> <color name="macchiato_teal" value="#8bd5ca"/>
@ -24,8 +24,8 @@ Catppuccin Gedit theme based on Oblivion theme and Cappuccin for Visual Studio C
<color name="macchiato_blue" value="#8aadf4"/> <color name="macchiato_blue" value="#8aadf4"/>
<color name="macchiato_lavender" value="#b7bdf8"/> <color name="macchiato_lavender" value="#b7bdf8"/>
<color name="macchiato_text" value="#cad3f5"/> <color name="macchiato_text" value="#cad3f5"/>
<color name="macchiato_subtext1" value="#ced4e0"/> <color name="macchiato_subtext1" value="#b8c0e0"/>
<color name="macchiato_subtext0" value="#e3e3f3"/> <color name="macchiato_subtext0" value="#a5adcb"/>
<color name="macchiato_overlay2" value="#939ab7"/> <color name="macchiato_overlay2" value="#939ab7"/>
<color name="macchiato_overlay1" value="#8087a2"/> <color name="macchiato_overlay1" value="#8087a2"/>
<color name="macchiato_overlay0" value="#6e738d"/> <color name="macchiato_overlay0" value="#6e738d"/>

View file

@ -3,7 +3,7 @@ color_scheme_path=$HOME/.config/qt6ct/colors/Catppuccin-Macchiato.conf
custom_palette=true custom_palette=true
icon_theme=ePapirus icon_theme=ePapirus
standard_dialogs=default standard_dialogs=default
style=kvantum-dark style=Fusion
[Fonts] [Fonts]
fixed="Noto Sans,11,-1,5,400,0,0,0,0,0,0,0,0,0,0,1,Regular" fixed="Noto Sans,11,-1,5,400,0,0,0,0,0,0,0,0,0,0,1,Regular"

View file

@ -45,9 +45,6 @@ riverctl spawn $HOME/.azotebg
# Include keybindings # Include keybindings
riverctl spawn $HOME/.config/river/keybindings.sh riverctl spawn $HOME/.config/river/keybindings.sh
# Keybindings help overlay
riverctl spawn /usr/share/river/scripts/help.sh & disown
# Clipboard daemon # Clipboard daemon
pkill wl-paste pkill wl-paste
wl-paste --watch cliphist store & disown wl-paste --watch cliphist store & disown

View file

@ -12,9 +12,6 @@ launcher="eval rofi -show combi -combi-modi 'drun,run' -terminal $term -ssh-comm
# Volume changing notify # Volume changing notify
volume_bar="/usr/share/river/scripts/volume-notify.sh" volume_bar="/usr/share/river/scripts/volume-notify.sh"
# Mic volume mute
mic_mute="/usr/share/river/scripts/mic-mute.sh"
# Brightness changing notify # Brightness changing notify
brightness_bar="/usr/share/river/scripts/brightness-notify.sh" brightness_bar="/usr/share/river/scripts/brightness-notify.sh"
@ -28,108 +25,106 @@ riverctl map normal "$mod" Print spawn "/usr/bin/river-grimshot save area - | sw
# Set keyboard layout. See man riverctl # Set keyboard layout. See man riverctl
# riverctl keyboard-layout -options "grp:caps_toggle" "us,ru" # riverctl keyboard-layout -options "grp:caps_toggle" "us,ru"
## Action // Reload River Configuration // $mod+R ## # Binding to reload the configuration (good for edits on bindings or adding new stuff
riverctl map normal $mod R spawn $HOME/.config/river/init riverctl map normal $mod R spawn $HOME/.config/river/init
## Launch // Terminal // $mod+Return ## # $mod+Shift+Return to start an instance of terminal
riverctl map normal $mod Return spawn $term riverctl map normal $mod Return spawn $term
## Launch // Launcher // $mod+D ## # $mod+D to start an instance of application launcher
riverctl map normal $mod D spawn "$launcher" riverctl map normal $mod D spawn "$launcher"
## Action // Exit River // $mod+Shift+E ## # $mod+Q to close the focused view
riverctl map normal $mod+Shift E spawn nwg-bar
## Action // Kill focused window // $mod+Q ##
riverctl map normal $mod+Shift Q close riverctl map normal $mod+Shift Q close
## Navigation // Focus the next/previous view in the layout stack // $mod+{J,K} ## # $mod+Shift+E to run nwg-bar (logout, restart, shutdown, etc)
riverctl map normal $mod+Shift E spawn nwg-bar
# $mod+J and $mod+K to focus the next/previous view in the layout stack
riverctl map normal $mod J focus-view next riverctl map normal $mod J focus-view next
riverctl map normal $mod K focus-view previous riverctl map normal $mod K focus-view previous
## Navigation // Swap the focused view in the layout stack // $mod+Shift+{J,K} ## # $mod+Shift+J and $mod+Shift+K to swap the focused view with the next/previous
# view in the layout stack
riverctl map normal $mod+Shift J swap next riverctl map normal $mod+Shift J swap next
riverctl map normal $mod+Shift K swap previous riverctl map normal $mod+Shift K swap previous
## Navigation // Focus the next/previous output // $mod+{, .} ## # $mod+Period and $mod+Comma to focus the next/previous output
riverctl map normal $mod Period focus-output next riverctl map normal $mod Period focus-output next
riverctl map normal $mod Comma focus-output previous riverctl map normal $mod Comma focus-output previous
## Navigation // Send the focused view to the next/previous output // $mod+Shift+{, .} ## # $mod+Shift+{Period,Comma} to send the focused view to the next/previous output
riverctl map normal $mod+Shift Period send-to-output next riverctl map normal $mod+Shift Period send-to-output next
riverctl map normal $mod+Shift Comma send-to-output previous riverctl map normal $mod+Shift Comma send-to-output previous
## Navigation // Bump the focused view to the top of the layout stack // $mod+Shift+Return ## # $mod+Return to bump the focused view to the top of the layout stack
riverctl map normal $mod+Shift Return zoom riverctl map normal $mod+Shift Return zoom
## Navigation // Decrease/increase the main ratio of rivertile // $mod+{H,L} ## # $mod+H and $mod+L to decrease/increase the main ratio of rivertile(1)
riverctl map normal $mod H send-layout-cmd rivertile "main-ratio -0.05" riverctl map normal $mod H send-layout-cmd rivertile "main-ratio -0.05"
riverctl map normal $mod L send-layout-cmd rivertile "main-ratio +0.05" riverctl map normal $mod L send-layout-cmd rivertile "main-ratio +0.05"
## Navigation // Increment/decrement the main count of rivertile // $mod+Shift+{H,L} ## # $mod+Shift+H and $mod+Shift+L to increment/decrement the main count of rivertile(1)
riverctl map normal $mod+Shift H send-layout-cmd rivertile "main-count +1" riverctl map normal $mod+Shift H send-layout-cmd rivertile "main-count +1"
riverctl map normal $mod+Shift L send-layout-cmd rivertile "main-count -1" riverctl map normal $mod+Shift L send-layout-cmd rivertile "main-count -1"
## Navigation // Move views // $mod+Alt+{H,J,K,L} ## # $mod+Alt+{H,J,K,L} to move views
riverctl map normal $mod+Alt H move left 100 riverctl map normal $mod+Alt H move left 100
riverctl map normal $mod+Alt J move down 100 riverctl map normal $mod+Alt J move down 100
riverctl map normal $mod+Alt K move up 100 riverctl map normal $mod+Alt K move up 100
riverctl map normal $mod+Alt L move right 100 riverctl map normal $mod+Alt L move right 100
## Navigation // Snap views to screen edges // $mod+Alt+Control+{H,J,K,L}## # $mod+Alt+Control+{H,J,K,L} to snap views to screen edges
riverctl map normal $mod+Alt+Control H snap left riverctl map normal $mod+Alt+Control H snap left
riverctl map normal $mod+Alt+Control J snap down riverctl map normal $mod+Alt+Control J snap down
riverctl map normal $mod+Alt+Control K snap up riverctl map normal $mod+Alt+Control K snap up
riverctl map normal $mod+Alt+Control L snap right riverctl map normal $mod+Alt+Control L snap right
## Navigation // Resize views // $mod+Alt+Shift+{H,J,K,L} ## # $mod+Alt+Shift+{H,J,K,L} to resize views
riverctl map normal $mod+Alt+Shift H resize horizontal -100 riverctl map normal $mod+Alt+Shift H resize horizontal -100
riverctl map normal $mod+Alt+Shift J resize vertical 100 riverctl map normal $mod+Alt+Shift J resize vertical 100
riverctl map normal $mod+Alt+Shift K resize vertical -100 riverctl map normal $mod+Alt+Shift K resize vertical -100
riverctl map normal $mod+Alt+Shift L resize horizontal 100 riverctl map normal $mod+Alt+Shift L resize horizontal 100
## Navigation // Move views with mouse // $mod + Left Mouse Button ## # $mod + Left Mouse Button to move views
riverctl map-pointer normal $mod BTN_LEFT move-view riverctl map-pointer normal $mod BTN_LEFT move-view
## Navigation // Resize views with mouse // $mod + Right Mouse Button ## # $mod + Right Mouse Button to resize views
riverctl map-pointer normal $mod BTN_RIGHT resize-view riverctl map-pointer normal $mod BTN_RIGHT resize-view
## Navigation // Toggle float // $mod + Middle Mouse Button ## # $mod + Middle Mouse Button to toggle float
riverctl map-pointer normal $mod BTN_MIDDLE toggle-float riverctl map-pointer normal $mod BTN_MIDDLE toggle-float
# Tags navigation
## Navigation // Focus tag [0-8] // $mod+[1-9] ##
## Navigation // Tag focused view with tag [0-8] // $mod+Shift+[1-9] ##
## Navigation // Toggle focus of tag [0-8] // mod+Control+[1-9] ##
## Navigation // Toggle tag [0-8] of focused view // $mod+Shift+Control+[1-9] ##
for i in $(seq 1 9) for i in $(seq 1 9)
do do
tags=$((1 << ($i - 1))) tags=$((1 << ($i - 1)))
# $mod+[1-9] to focus tag [0-8]
riverctl map normal $mod $i set-focused-tags $tags riverctl map normal $mod $i set-focused-tags $tags
# $mod+Shift+[1-9] to tag focused view with tag [0-8]
riverctl map normal $mod+Shift $i set-view-tags $tags riverctl map normal $mod+Shift $i set-view-tags $tags
# $mod+Control+[1-9] to toggle focus of tag [0-8]
riverctl map normal $mod+Control $i toggle-focused-tags $tags riverctl map normal $mod+Control $i toggle-focused-tags $tags
# $mod+Shift+Control+[1-9] to toggle tag [0-8] of focused view
riverctl map normal $mod+Shift+Control $i toggle-view-tags $tags riverctl map normal $mod+Shift+Control $i toggle-view-tags $tags
done done
## Navigation // Focus all tags // $mod+0 ## # $mod+0 to focus all tags
## Navigation // Tag focused view with all tags // $mod+Shift+0 ## # $mod+Shift+0 to tag focused view with all tags
all_tags=$(((1 << 32) - 1)) all_tags=$(((1 << 32) - 1))
riverctl map normal $mod 0 set-focused-tags $all_tags riverctl map normal $mod 0 set-focused-tags $all_tags
riverctl map normal $mod+Shift 0 set-view-tags $all_tags riverctl map normal $mod+Shift 0 set-view-tags $all_tags
## Action // Toggle floating // $mod+Space ## # $mod+Space to toggle float
riverctl map normal $mod Space toggle-float riverctl map normal $mod Space toggle-float
## Action // Toggle fullscreen // $mod+F ## # $mod+F to toggle fullscreen
riverctl map normal $mod F toggle-fullscreen riverctl map normal $mod F toggle-fullscreen
## Navigation // Change layout orientation // $mod+{↑ ↓ ← →} ## # $mod+{Up,Right,Down,Left} to change layout orientation
riverctl map normal $mod Up send-layout-cmd rivertile "main-location top" riverctl map normal $mod Up send-layout-cmd rivertile "main-location top"
riverctl map normal $mod Right send-layout-cmd rivertile "main-location right" riverctl map normal $mod Right send-layout-cmd rivertile "main-location right"
riverctl map normal $mod Down send-layout-cmd rivertile "main-location bottom" riverctl map normal $mod Down send-layout-cmd rivertile "main-location bottom"
@ -139,10 +134,10 @@ riverctl map normal $mod Left send-layout-cmd rivertile "main-location left"
# normal mode. This makes it useful for testing a nested wayland compositor # normal mode. This makes it useful for testing a nested wayland compositor
riverctl declare-mode passthrough riverctl declare-mode passthrough
## Action // Enter passthrough mode // $mod+F11 ## # $mod+F11 to enter passthrough mode
riverctl map normal $mod F11 enter-mode passthrough riverctl map normal $mod F11 enter-mode passthrough
## Action // Return to normal mode // $mod+F11 ## # $mod+F11 to return to normal mode
riverctl map passthrough $mod F11 enter-mode normal riverctl map passthrough $mod F11 enter-mode normal
# Various media key mapping examples for both normal and locked mode which do # Various media key mapping examples for both normal and locked mode which do
@ -156,7 +151,6 @@ do
riverctl map $mode None XF86AudioRaiseVolume spawn "pulsemixer --change-volume +5 && $volume_bar" riverctl map $mode None XF86AudioRaiseVolume spawn "pulsemixer --change-volume +5 && $volume_bar"
riverctl map $mode None XF86AudioLowerVolume spawn "pulsemixer --change-volume -5 && $volume_bar" riverctl map $mode None XF86AudioLowerVolume spawn "pulsemixer --change-volume -5 && $volume_bar"
riverctl map $mode None XF86AudioMute spawn "pulsemixer --toggle-mute && $volume_bar" riverctl map $mode None XF86AudioMute spawn "pulsemixer --toggle-mute && $volume_bar"
riverctl map $mode None XF86AudioMicMute spawn "$mic_mute"
# Control MPRIS aware media players with playerctl (https://github.com/altdesktop/playerctl) # Control MPRIS aware media players with playerctl (https://github.com/altdesktop/playerctl)
riverctl map $mode None XF86AudioMedia spawn 'playerctl play-pause' riverctl map $mode None XF86AudioMedia spawn 'playerctl play-pause'

View file

@ -1,5 +1,6 @@
timeout 240 'light -G > /tmp/brightness && light -S 10' resume 'light -S $([ -f /tmp/brightness ] && cat /tmp/brightness || echo 100%)' timeout 240 'light -G > /tmp/brightness && light -S 10' resume 'light -S $([ -f /tmp/brightness ] && cat /tmp/brightness || echo 100%)'
timeout 300 '/usr/share/river/scripts/lock.sh' timeout 300 ~/.config/swaylock/lock.sh
timeout 600 'wlopm --off \*' resume 'wlopm --on \*' timeout 600 'swaymsg "output * power off"' resume 'swaymsg "output * power on"'
before-sleep 'playerctl pause' before-sleep 'playerctl pause'
before-sleep '/usr/share/river/scripts/lock.sh && sleep 2' before-sleep ~/.config/swaylock/lock.sh
lock ~/.config/swaylock/lock.sh

View file

@ -7,7 +7,6 @@
"modules-right": [ "modules-right": [
"tray", "tray",
"custom/playerctl", "custom/playerctl",
"custom/help",
"custom/wlsunset", "custom/wlsunset",
"idle_inhibitor", "idle_inhibitor",
"custom/dunst", "custom/dunst",
@ -32,8 +31,7 @@
}, },
"river/window": { "river/window": {
"format": "{}", "format": "{}"
"max-length": 50
}, },
"custom/playerctl": { "custom/playerctl": {
@ -53,12 +51,6 @@
"signal": 5 "signal": 5
}, },
"custom/help": {
"format": "",
"on-click": "/usr/share/river/scripts/help.sh --toggle",
"tooltip": "false"
},
"custom/wlsunset": { "custom/wlsunset": {
"interval": "once", "interval": "once",
"tooltip": true, "tooltip": true,
@ -147,7 +139,6 @@
"bluetooth": { "bluetooth": {
"format": "", "format": "",
"format-disabled": "", "format-disabled": "",
"format-no-controller": "",
"on-click": "alacritty --class floating_shell -e bluetuith", "on-click": "alacritty --class floating_shell -e bluetuith",
"on-click-right": "rfkill toggle bluetooth", "on-click-right": "rfkill toggle bluetooth",
"tooltip-format": "{}" "tooltip-format": "{}"

View file

@ -76,7 +76,6 @@ window#waybar.hidden {
} }
#clock, #clock,
#custom-help,
#custom-playerctl, #custom-playerctl,
#custom-power, #custom-power,
#custom-wlsunset, #custom-wlsunset,
@ -114,46 +113,42 @@ window#waybar.hidden {
#tray { #tray {
padding-left: 5px; padding-left: 5px;
padding-right: 5px; padding-right: 5px;
color: @flamingo; color: @rosewater;
} }
#custom-playerctl { #custom-playerctl {
color: @pink; color: @flamingo;
}
#custom-help {
color: @mauve;
} }
#custom-wlsunset { #custom-wlsunset {
color: @red; color: @pink;
} }
#idle_inhibitor { #idle_inhibitor {
color: @maroon; color: @mauve;
} }
#custom-dunst { #custom-dunst {
color: @peach; color: @red;
} }
#custom-clipboard { #custom-clipboard {
color: @yellow; color: @maroon;
} }
#cpu { #cpu {
color: @green; color: @peach;
} }
#memory { #memory {
color: @teal; color: @yellow;
} }
#battery { #battery {
animation-timing-function: linear; animation-timing-function: linear;
animation-iteration-count: infinite; animation-iteration-count: infinite;
animation-direction: alternate; animation-direction: alternate;
color: @sky; color: @green;
} }
#battery.warning { #battery.warning {
@ -179,7 +174,7 @@ label:focus {
} }
#network { #network {
color: @sapphire; color: @teal;
} }
#network.disconnected { #network.disconnected {
@ -187,7 +182,7 @@ label:focus {
} }
#bluetooth { #bluetooth {
color: @blue; color: @sky;
} }
#bluetooth.disabled { #bluetooth.disabled {
@ -195,7 +190,7 @@ label:focus {
} }
#pulseaudio { #pulseaudio {
color: @lavender; color: @sapphire;
} }
#pulseaudio.muted { #pulseaudio.muted {
@ -203,5 +198,5 @@ label:focus {
} }
#custom-power { #custom-power {
color: @text; color: @lavender;
} }

View file

@ -47,8 +47,4 @@ if [ -d "${XDG_CONFIG_HOME:-$HOME/.config}/environment.d" ]; then
set +o allexport set +o allexport
fi fi
run_river() { exec systemd-cat -- /usr/bin/river $@
exec systemd-cat -- /usr/bin/ssh-agent /usr/bin/river $@
}
run_river

View file

@ -1,12 +0,0 @@
[Unit]
Description=Toggle idle inhibition depending on whether the audio is playing or not
PartOf=swayidle.service
After=swayidle.service
[Service]
ExecStart=/usr/share/river/scripts/idle-inhibitor.sh
Restart=always
RestartSec=30
[Install]
WantedBy=river-session.target

View file

@ -1,9 +0,0 @@
[Unit]
Description=Automatically restart the swayidle when its configuration changes
PartOf=swayidle.service
[Path]
PathChanged=%h/.config/swayidle/config
[Install]
WantedBy=paths.target

View file

@ -1,6 +0,0 @@
[Service]
ExecStart=systemctl --user restart swayidle.service
Type=oneshot
[Install]
WantedBy=graphical-session.target

View file

@ -6,7 +6,7 @@ ConditionPathExists=/usr/bin/swayidle
[Service] [Service]
Type=simple Type=simple
ExecStart=/usr/bin/swayidle -w ExecStart=/usr/bin/swayidle
[Install] [Install]
WantedBy=river-session.target WantedBy=river-session.target

View file

@ -1,11 +0,0 @@
[Unit]
Description=Automatically restart the waybar when its configuration changes
PartOf=waybar.service
[Path]
PathChanged=%h/.config/waybar
PathChanged=%h/.config/waybar/colors
PathChanged=%h/waybar/config
[Install]
WantedBy=paths.target

View file

@ -1,3 +0,0 @@
[Service]
ExecStart=systemctl --user restart waybar.service
Type=oneshot

View file

@ -1,13 +0,0 @@
#!/bin/bash
set -x
# toggles the help wrapper state
VISIBILITY_SIGNAL=30
QUIT_SIGNAL=31
if [ "$1" = "--toggle" ]; then
pkill -f -${VISIBILITY_SIGNAL} nwg-wrapper
else
pkill -f -${QUIT_SIGNAL} nwg-wrapper
nwg-wrapper -i -sv ${VISIBILITY_SIGNAL} -sq ${QUIT_SIGNAL} -s help.sh -p left -a end &
fi

View file

@ -1,32 +0,0 @@
#!/bin/bash
check_status() {
grep -s -l -v "closed" \
/proc/asound/card*/pcm*/sub*/status \
&>/dev/null
}
out() {
printf "Idle inhibition is OFF.\n"
exit 0
}
watch_status() {
printf "Idle inhibition is ON.\n"
while check_status; do
sleep 10
done
out
}
main() {
check_status || out
test "$1" = "-w" && watch_status
systemd-inhibit \
--what=idle \
--who="${0##*/}" \
--why="Inhibit idle due to audio is now playing" \
--mode=block \
"$0" -w
}
main "$@"

View file

@ -1,10 +0,0 @@
#!/bin/bash
USER_SCRIPT="$HOME/.config/swaylock/lock.sh"
GLOB_SCRIPT="/usr/share/river/scripts/swaylock.sh"
if [[ -x "$USER_SCRIPT" ]]; then
"$USER_SCRIPT"
else
"$GLOB_SCRIPT"
fi

View file

@ -1,14 +0,0 @@
#!/bin/bash
set -e
MIC="${1:-'Capture'}"
amixer sset "$MIC" toggle
STATE="$(amixer sget "$MIC",0 | sed -E -e '0,/^.*\[(on|off)\].*$/d' -e 's/^.*\[(\w+)\].*$/\1/')"
test -n "$STATE" && notify-send \
--app-name river \
--expire-time 800 \
"Microphone is $STATE"

View file

@ -1,136 +0,0 @@
#!/usr/bin/python3
import sys
import glob
import re
from typing import Text
import json
if len(sys.argv) >= 2:
rootPath = sys.argv[1]
else:
rootPath = './keybindings.sh'
def readFile(filePath):
try:
paths = glob.glob(filePath)
except (Exception, IndexError):
print("couldn't resolve glob:", filePath)
paths = []
allLines: list[str] = []
for path in paths:
allLines = allLines + open(path, "r").readlines()
finalLines: list[str] = []
for line in allLines:
if re.search(r'^include\s+(.+?)$', line):
nextPath = re.findall(r'^include\s+(.+?)$', line)[0]
finalLines = finalLines + readFile(nextPath)
else:
finalLines = finalLines + [line]
return finalLines
lines = readFile(rootPath)
def findKeybindingForLine(lineNumber: int, lines: list[str]):
return lines[lineNumber + 1].split(' ')[3]
class DocsConfig:
category: Text
action: Text
keybinding: Text
def getDocsConfig(lines: list[str]):
docsLineRegex = r"^## (?P<category>.+?) // (?P<action>.+?)\s+(// (?P<keybinding>.+?))*##"
docsConfig: list[DocsConfig] = []
for index, line in enumerate(lines):
match = re.match(docsLineRegex, line)
if match:
config = DocsConfig()
config.category = match.group('category')
config.action = match.group('action')
config.keybinding = match.group('keybinding')
if config.keybinding is None:
config.keybinding = findKeybindingForLine(index, lines)
docsConfig = docsConfig + [config]
return docsConfig
def getSymbolDict(lines: list[str]):
setRegex = r"^(?P<variable>\w+)\=\"(?P<value>[^\"]+)+\" ?"
dictionary = {}
for line in lines:
match = re.match(setRegex, line)
if match:
if match.group('variable'):
dictionary['$'+match.group('variable')] = match.group('value')
return dict(dictionary)
translations = {
'Mod1': "Alt",
'Mod2': "NumLk",
'Mod3': "",
'Mod4': "",
'Mod5': "Scroll",
'question': "?",
'space': "",
'minus': "-",
'plus': '+',
'Return': "Enter",
'XF86AudioRaiseVolume': "",
'XF86AudioLowerVolume': "",
'XF86AudioMute': "",
'XF86AudioMicMute': '',
'XF86MonBrightnessUp': "",
'XF86MonBrightnessDown': "",
'XF86PowerOff': "",
'XF86TouchpadToggle': "Toggle Touchpad"
}
def translate(word: Text, dictionary: dict):
try:
return dictionary[word.strip()]
except KeyError:
return word.strip()
def replaceBindingFromMap(binding: Text, dictionary: dict):
elements = binding.split('+')
resultElements = []
for el in elements:
translation = translate(translate(el, dictionary), translations)
resultElements = resultElements + [translation]
return " + ".join(resultElements)
def sanitize(configs: list[DocsConfig], symbolDict: dict):
for index, config in enumerate(configs):
config.keybinding = replaceBindingFromMap(
config.keybinding, symbolDict)
configs[index] = config
return configs
def getDocsList(lines: list[str]):
docsConfig = getDocsConfig(lines)
symbolDict = getSymbolDict(lines)
sanitizedConfig = sanitize(docsConfig, symbolDict)
return sanitizedConfig
docsList = getDocsList(lines)
result = []
for config in docsList:
result = result + [{'category': config.category,
'action': config.action, 'keybinding': config.keybinding}]
print(json.dumps(result))