aboutsummaryrefslogtreecommitdiff
path: root/sway-de/wob
diff options
context:
space:
mode:
authorMatt Singleton <matt@xcolour.net>2023-04-02 20:16:45 -0500
committerMatt Singleton <matt@xcolour.net>2023-04-11 16:06:09 -0500
commit5ca60114560f24617d0a82ef230bc11484617800 (patch)
tree471cfb42af8518d262b1b2403971479f2fc65dc0 /sway-de/wob
parented3b3470003bf3bcb9ea605daf9d8c68458474df (diff)
each program in a sway package
Diffstat (limited to 'sway-de/wob')
-rw-r--r--sway-de/wob/.config/wob/wob.ini6
-rwxr-xr-xsway-de/wob/.local/bin/setbright30
-rwxr-xr-xsway-de/wob/.local/bin/setvol30
-rw-r--r--sway-de/wob/.local/share/systemd/user/wob.service13
-rw-r--r--sway-de/wob/.local/share/systemd/user/wob.socket9
5 files changed, 88 insertions, 0 deletions
diff --git a/sway-de/wob/.config/wob/wob.ini b/sway-de/wob/.config/wob/wob.ini
new file mode 100644
index 0000000..ab4ffcb
--- /dev/null
+++ b/sway-de/wob/.config/wob/wob.ini
@@ -0,0 +1,6 @@
+border_color=5e4b4f
+background_color=efefef
+bar_color=5e4b4f
+border_offset=0
+border_size=1
+bar_padding=5
diff --git a/sway-de/wob/.local/bin/setbright b/sway-de/wob/.local/bin/setbright
new file mode 100755
index 0000000..7d2784a
--- /dev/null
+++ b/sway-de/wob/.local/bin/setbright
@@ -0,0 +1,30 @@
+#!/bin/bash
+
+set -euo pipefail
+
+wobsock="$XDG_RUNTIME_DIR/wob.sock"
+if [ ! -p "$wobsock" ]; then
+ echo $wobsock
+ echo "communication socket not found"
+ exit 2
+fi
+
+current=$(brightnessctl -m info | cut -d, -f4 | tr --delete '%')
+case $1 in
+ up)
+ increment=$(( 5 - ( current % 5 ) ))
+ new=$(( current + increment ))
+ if [ $new -gt 100 ]; then
+ new=100
+ fi
+ brightnessctl set $new% > /dev/null 2>&1
+ echo $new > $wobsock;;
+ down)
+ increment=$(( ( ( current - 1 ) % 5 ) + 1 ))
+ new=$(( current - increment ))
+ if [ $new -lt 0 ]; then
+ new=0
+ fi
+ brightnessctl set $new% > /dev/null 2>&1
+ echo $new > $wobsock;;
+esac
diff --git a/sway-de/wob/.local/bin/setvol b/sway-de/wob/.local/bin/setvol
new file mode 100755
index 0000000..f8bb4df
--- /dev/null
+++ b/sway-de/wob/.local/bin/setvol
@@ -0,0 +1,30 @@
+#!/bin/bash
+
+set -euo pipefail
+
+wobsock="$XDG_RUNTIME_DIR/wob.sock"
+if [ ! -p "$wobsock" ]; then
+ echo $wobsock
+ echo "communication socket not found"
+ exit 2
+fi
+
+current_volume=$(pactl get-sink-volume @DEFAULT_SINK@ | grep Volume | sed -e 's/.* \([0-9][0-9]*\)%.*/\1/')
+case $1 in
+ up)
+ increment=$(( 5 - ( current_volume % 5 ) ))
+ newvol=$(( current_volume + increment ))
+ if [ $newvol -gt 100 ]; then
+ newvol=100
+ fi
+ pactl set-sink-volume @DEFAULT_SINK@ $newvol%
+ echo $newvol > $wobsock;;
+ down)
+ increment=$(( ( ( current_volume - 1 ) % 5 ) + 1 ))
+ newvol=$(( current_volume - increment ))
+ if [ $newvol -lt 0 ]; then
+ newvol=0
+ fi
+ pactl set-sink-volume @DEFAULT_SINK@ $newvol%
+ echo $newvol > $wobsock;;
+esac
diff --git a/sway-de/wob/.local/share/systemd/user/wob.service b/sway-de/wob/.local/share/systemd/user/wob.service
new file mode 100644
index 0000000..1193b30
--- /dev/null
+++ b/sway-de/wob/.local/share/systemd/user/wob.service
@@ -0,0 +1,13 @@
+[Unit]
+Description=A lightweight overlay volume/backlight/progress/anything bar for Wayland
+Documentation=man:wob(1)
+PartOf=sway-session.target
+After=sway-session.target
+ConditionEnvironment=WAYLAND_DISPLAY
+
+[Service]
+StandardInput=socket
+ExecStart=/usr/bin/wob
+
+[Install]
+WantedBy=sway-session.target
diff --git a/sway-de/wob/.local/share/systemd/user/wob.socket b/sway-de/wob/.local/share/systemd/user/wob.socket
new file mode 100644
index 0000000..01296d8
--- /dev/null
+++ b/sway-de/wob/.local/share/systemd/user/wob.socket
@@ -0,0 +1,9 @@
+[Socket]
+ListenFIFO=%t/wob.sock
+SocketMode=0600
+RemoveOnStop=on
+# If wob exits on invalid input, systemd should NOT shove following input right back into it after it restarts
+FlushPending=yes
+
+[Install]
+WantedBy=sockets.target