feat: optimized sbar, gammastep asia, wpdef
This commit is contained in:
parent
f48e958d44
commit
395119a0fe
19 changed files with 159 additions and 157 deletions
126
.local/bin/sbar
126
.local/bin/sbar
|
@ -1,127 +1,117 @@
|
|||
#!/bin/bash
|
||||
|
||||
function update_crypto() {
|
||||
function scrypto() {
|
||||
local c
|
||||
|
||||
c="$(crypto 2> /dev/null)" && echo "$c" > "$SBAR/crypto"
|
||||
c="$(crypto 2> /dev/null)" && echo "$c" > crypto
|
||||
}
|
||||
|
||||
function update_cpu() {
|
||||
echo " $(awk '{print $1}' /proc/loadavg)" > "$SBAR/cpu"
|
||||
function scpu() {
|
||||
echo " $(awk '{print $1}' /proc/loadavg)" > cpu
|
||||
}
|
||||
|
||||
function update_memory() {
|
||||
echo " $(free -h | awk '/^Mem:/{print $3}')" > "$SBAR/memory"
|
||||
function smemory() {
|
||||
echo " $(free -h | awk '/^Mem:/{print $3}')" > memory
|
||||
}
|
||||
|
||||
function update_bat() {
|
||||
function sbat() {
|
||||
local cap; cap="$(cat /sys/class/power_supply/BAT0/capacity)"
|
||||
|
||||
if grep -qv Discharging /sys/class/power_supply/BAT0/status; then
|
||||
echo " $cap%" > "$SBAR/bat"
|
||||
echo " $cap%"
|
||||
else
|
||||
echo " $cap%" > "$SBAR/bat"
|
||||
fi
|
||||
echo " $cap%"
|
||||
fi > bat
|
||||
}
|
||||
|
||||
function update_sink_vol() {
|
||||
local vol mute
|
||||
function svol() {
|
||||
local st v vol=('' ' ') mut=('🔇' ' ') m
|
||||
|
||||
read -r _ vol mute < <(wpctl get-volume '@DEFAULT_AUDIO_SINK@') || return
|
||||
if [ -n "$mute" ]; then
|
||||
echo '🔇' > "$SBAR/sink"
|
||||
else
|
||||
echo " $((10#${vol/./}))" > "$SBAR/sink"
|
||||
mapfile -t st <<< "$(wpctl status | sed -n 's/.*\*.*\[vol: \(.*\)]/\1/p')"
|
||||
if [ -z "${st[0]}" ]; then
|
||||
return > vol
|
||||
fi
|
||||
for i in "${!vol[@]}"; do
|
||||
read -r v m <<< "${st[$i]}"
|
||||
if [ -n "$m" ]; then
|
||||
echo -n "${mut[$i]}"
|
||||
else
|
||||
echo -n "${vol[$i]} $((10#${v/./}))"
|
||||
fi
|
||||
done > vol
|
||||
}
|
||||
|
||||
function update_source_vol() {
|
||||
local vol mute
|
||||
|
||||
read -r _ vol mute < <(wpctl get-volume '@DEFAULT_AUDIO_SOURCE@') || return
|
||||
if [ -n "$mute" ]; then
|
||||
echo '' > "$SBAR/source"
|
||||
else
|
||||
echo " $((10#${vol/./}))" > "$SBAR/source"
|
||||
fi
|
||||
}
|
||||
|
||||
function update_net() {
|
||||
function snet() {
|
||||
local dev j ssid sig
|
||||
|
||||
dev="$(ip route | grep -oP 'default.*dev\s+\K[^\s]+')"
|
||||
j="$(networkctl status "$dev" --json=short)"
|
||||
case "$(jq -r .Type <<< "$j")" in
|
||||
ether)
|
||||
echo "🌐 $dev" > "$SBAR/net"
|
||||
echo "🌐 $dev"
|
||||
;;
|
||||
wlan)
|
||||
ssid="$(jq -r .SSID <<< "$j")"
|
||||
sig="$(awk "/$dev/{printf \"%.0f\", \$3}" /proc/net/wireless)"
|
||||
if [ "$sig" -gt 56 ]; then echo "▂▄▆█ $ssid" > "$SBAR/net"
|
||||
elif [ "$sig" -gt 38 ]; then echo "▂▄▆_ $ssid" > "$SBAR/net"
|
||||
elif [ "$sig" -gt 21 ]; then echo "▂▄__ $ssid" > "$SBAR/net"
|
||||
elif [ "$sig" -gt 3 ]; then echo "▂___ $ssid" > "$SBAR/net"
|
||||
else echo "____ $ssid" > "$SBAR/net"
|
||||
if [ "$sig" -gt 56 ]; then echo "▂▄▆█ $ssid"
|
||||
elif [ "$sig" -gt 38 ]; then echo "▂▄▆_ $ssid"
|
||||
elif [ "$sig" -gt 21 ]; then echo "▂▄__ $ssid"
|
||||
elif [ "$sig" -gt 3 ]; then echo "▂___ $ssid"
|
||||
else echo "____ $ssid"
|
||||
fi
|
||||
;;
|
||||
*)
|
||||
echo '⚠' > "$SBAR/net"
|
||||
echo '⚠'
|
||||
;;
|
||||
esac
|
||||
esac > net
|
||||
}
|
||||
|
||||
function update_vpn() {
|
||||
function svpn() {
|
||||
local v; v="$(ip -br link show type wireguard | awk '{print $1}')"
|
||||
|
||||
if [ -n "$v" ]; then
|
||||
echo " 🔒 $v" > "$SBAR/vpn"
|
||||
else
|
||||
: > "$SBAR/vpn"
|
||||
fi
|
||||
echo " 🔒 $v"
|
||||
fi > vpn
|
||||
}
|
||||
|
||||
function update_time() {
|
||||
echo "$(TZ=Asia/Makassar date '+%R %Z') - $(date -u '+%a %m-%d %R')" \
|
||||
> "$SBAR/time"
|
||||
function stime() {
|
||||
# shellcheck disable=SC2238
|
||||
TZ=Asia/Makassar date '+%a %m-%d %R %Z' > time
|
||||
}
|
||||
|
||||
function display() {
|
||||
for f in "$SBAR"/*; do
|
||||
local "$(basename "$f")"="$(cat "$f")"
|
||||
for f in *; do
|
||||
local - "$f"="$(cat "$f")"
|
||||
done
|
||||
# shellcheck disable=SC2154
|
||||
xsetroot -name "$crypto | $cpu | $memory | $sink $source | $net$vpn | $bat | $time"
|
||||
# shellcheck disable=SC2128,SC2154
|
||||
xsetroot -name "$crypto | $cpu | $memory | $vol | $net$vpn | $bat | $time"
|
||||
}
|
||||
|
||||
# SIGNALING
|
||||
# trap '<function>;display;wait -n' 'RTMIN+n'
|
||||
trap 'update_sink_vol;display;wait -n' 'RTMIN+0'
|
||||
trap 'update_source_vol;display;wait -n' 'RTMIN+1'
|
||||
trap 'update_net;display;wait -n' 'RTMIN+2'
|
||||
trap 'update_vpn;display;wait -n' 'RTMIN+3'
|
||||
# trap '<function>;display;wait' 'RTMIN+n'
|
||||
trap 'svol;display;wait' 'RTMIN+0'
|
||||
trap 'snet;display;wait' 'RTMIN+1'
|
||||
trap 'svpn;display;wait' 'RTMIN+2'
|
||||
# to update it from external commands
|
||||
## kill -m "$(cat "$XDG_CACHE_HOME/pidofbar")"
|
||||
# where m = 34 + n
|
||||
|
||||
SBAR="$XDG_CACHE_HOME/sbar"
|
||||
mkdir -p "$SBAR"
|
||||
echo "$$" > "$SBAR/pid"
|
||||
mkdir -p "$XDG_RUNTIME_DIR/sbar" && cd "$XDG_RUNTIME_DIR/sbar" || exit 1
|
||||
echo "$$" > pid
|
||||
|
||||
(while :; do
|
||||
update_crypto
|
||||
sleep $((300 - 10#$(date '+%S') % 300)) & wait -n
|
||||
scrypto
|
||||
sleep $((300 - 10#$(date '+%S') % 300)) & wait
|
||||
done &)
|
||||
|
||||
while true; do
|
||||
update_cpu
|
||||
update_memory
|
||||
update_sink_vol
|
||||
update_source_vol
|
||||
update_net
|
||||
update_vpn
|
||||
update_bat
|
||||
update_time
|
||||
scpu
|
||||
smemory
|
||||
svol
|
||||
snet
|
||||
svpn
|
||||
sbat
|
||||
stime
|
||||
display
|
||||
sleep $((5 - 10#$(date '+%S') % 5)) & wait -n
|
||||
sleep $((5 - 10#$(date '+%S') % 5)) & wait
|
||||
done
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue