127 lines
2.7 KiB
Bash
Executable File
127 lines
2.7 KiB
Bash
Executable File
#!/bin/bash
|
|
|
|
scrypto() {
|
|
local tmp
|
|
|
|
tmp="$(crypto 2> /dev/null)" && echo "$tmp" > crypto
|
|
}
|
|
|
|
scpu() {
|
|
echo " $(awk '{print $1}' /proc/loadavg)" > cpu
|
|
}
|
|
|
|
smemory() {
|
|
echo " $(free -h | awk '/^Mem:/{print $3}')" > memory
|
|
}
|
|
|
|
sbat() {
|
|
local cap; cap="$(cat /sys/class/power_supply/BAT0/capacity)"
|
|
|
|
if grep -qv Discharging /sys/class/power_supply/BAT0/status; then
|
|
echo " $cap%"
|
|
else
|
|
echo " $cap%"
|
|
fi > bat
|
|
}
|
|
|
|
svol() {
|
|
local st v m vol=('' ' ')
|
|
|
|
mapfile -t st <<< "$(wpctl status | sed -n 's/.*\*.*\[vol: \(.*\)]/\1/p')"
|
|
for i in "${!vol[@]}"; do
|
|
read -r v m <<< "${st[$i]}"
|
|
if [ -z "$v" ]; then
|
|
break
|
|
fi
|
|
v="${vol[$i]} $((10#${v/./}))"
|
|
if [ -n "$m" ]; then
|
|
echo -n "${v//?/&$'\U0336'}"
|
|
else
|
|
echo -n "$v"
|
|
fi
|
|
done > vol
|
|
}
|
|
|
|
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"
|
|
;;
|
|
wlan)
|
|
ssid="$(jq -r .SSID <<< "$j")"
|
|
sig="$(awk "/$dev/{printf \"%.0f\", \$3}" /proc/net/wireless)"
|
|
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 '⚠'
|
|
;;
|
|
esac > net
|
|
}
|
|
|
|
svpn() {
|
|
local v; v="$(ip -br link show type wireguard | awk '{print $1}')"
|
|
|
|
if [ -n "$v" ]; then
|
|
echo " 🔒 $v"
|
|
fi > vpn
|
|
}
|
|
|
|
stz() {
|
|
local tmp ip; ip="$(ip route | grep -oP '^default.*src\s+\K[^\s]+')"
|
|
|
|
if ! [ -s tz ] || [ "$ip" != "$(cat ip)" ]; then
|
|
tmp="$(curl -s --interface wlan0 'https://ipapi.co/timezone')" \
|
|
&& echo "$tmp" > tz
|
|
echo "$ip" > ip
|
|
fi
|
|
}
|
|
|
|
stime() {
|
|
TZ="$(cat tz)" date '+%a %m-%d %R%:::z' > 'time'
|
|
}
|
|
|
|
display() {
|
|
for f in *; do
|
|
local - "$f"="$(cat "$f")"
|
|
done
|
|
# shellcheck disable=SC2154
|
|
xsetroot -name "$crypto | $cpu | $memory | $vol | $net$vpn | $bat | $time"
|
|
}
|
|
|
|
trap "kill 0" INT
|
|
|
|
mkdir -p "$XDG_RUNTIME_DIR/sbar"
|
|
cd "$XDG_RUNTIME_DIR/sbar" || exit 1
|
|
|
|
(while :; do
|
|
scrypto
|
|
stz
|
|
sleep 300
|
|
done &)
|
|
|
|
(while :; do
|
|
scpu
|
|
smemory
|
|
sbat
|
|
svol
|
|
snet
|
|
svpn
|
|
stime
|
|
display
|
|
sleep $((5 - $(date '+%S') % 5))
|
|
done &)
|
|
|
|
while read -r _ _ f; do
|
|
"s$f"
|
|
display
|
|
done < <(inotifywait -qme attrib .)
|