feat: add battery and weather script
This commit is contained in:
@@ -14,6 +14,7 @@
|
||||
"memory",
|
||||
"pulseaudio",
|
||||
"clock",
|
||||
"custom/weather",
|
||||
"clock#simpleclock",
|
||||
"custom/tailscale",
|
||||
"network",
|
||||
@@ -51,7 +52,7 @@
|
||||
"window-rewrite": {
|
||||
"class<*>": " ",
|
||||
"class<firefox>": " ",
|
||||
"class<app.zen_browser.zen>": " " ,
|
||||
"class<app.zen_browser.zen>": " " ,
|
||||
"class<Code>": " ",
|
||||
"class<Alacritty>": " ",
|
||||
"class<Spotify>": " ",
|
||||
@@ -60,6 +61,9 @@
|
||||
"class<com.seafile.seafile-applet>": " ",
|
||||
"class<org.gnome.Nautilus>": " ",
|
||||
"class<org.gnome.Software>": " ",
|
||||
"class<chromium-browser>": " ",
|
||||
"class<chrome-web.telegram.org__-Default>": " ",
|
||||
"class<chrome-music.youtube.com__-Default>": " "
|
||||
}
|
||||
},
|
||||
"hyprland/window": {
|
||||
@@ -152,6 +156,13 @@
|
||||
"return-type": "json",
|
||||
"tooltip": false,
|
||||
},
|
||||
"custom/weather": {
|
||||
"format": "{}",
|
||||
"interval": 600,
|
||||
"exec": "~/.config/waybar/scripts/weather.sh", // or your dotfiles folder if you use stow
|
||||
"return-type": "json",
|
||||
"on-click": "gnome-weather"
|
||||
},
|
||||
"custom/tailscale": {
|
||||
"exec": "~/.config/waybar/scripts/tailscale.sh",
|
||||
"interval": 5,
|
||||
|
||||
55
waybar/scripts/battery.sh
Executable file
55
waybar/scripts/battery.sh
Executable file
@@ -0,0 +1,55 @@
|
||||
#!/usr/bin/env bash
|
||||
set -euo pipefail
|
||||
|
||||
# Find battery + AC device (works on most laptops)
|
||||
BAT="$(ls -1 /sys/class/power_supply 2>/dev/null | grep -E '^BAT|^CMB|^BATT' | head -n1 || true)"
|
||||
AC="$(ls -1 /sys/class/power_supply 2>/dev/null | grep -E '^AC|^ADP|^ACAD' | head -n1 || true)"
|
||||
|
||||
if [[ -z "${BAT}" ]]; then
|
||||
echo " --%" # unknown
|
||||
exit 0
|
||||
fi
|
||||
|
||||
BAT_PATH="/sys/class/power_supply/${BAT}"
|
||||
STATUS="$(<"${BAT_PATH}/status")" # Charging|Discharging|Full|Not charging|Unknown
|
||||
CAPACITY="$(<"${BAT_PATH}/capacity")" # 0-100
|
||||
|
||||
# 0-10, 11-35, 36-60, 61-85, 86-100
|
||||
if ((CAPACITY <= 10)); then
|
||||
if [[ "${STATUS}" == "Charging" ]]; then
|
||||
ICON=" "
|
||||
else
|
||||
ICON=" "
|
||||
fi
|
||||
elif ((CAPACITY <= 30)); then
|
||||
if [[ "${STATUS}" == "Charging" ]]; then
|
||||
ICON=" "
|
||||
else
|
||||
ICON=" "
|
||||
fi
|
||||
elif ((CAPACITY <= 60)); then
|
||||
if [[ "${STATUS}" == "Charging" ]]; then
|
||||
ICON=" "
|
||||
else
|
||||
ICON=" "
|
||||
fi
|
||||
elif ((CAPACITY <= 80)); then
|
||||
if [[ "${STATUS}" == "Charging" ]]; then
|
||||
ICON=" "
|
||||
else
|
||||
ICON=" "
|
||||
fi
|
||||
else
|
||||
if [[ "${STATUS}" == "Charging" ]]; then
|
||||
ICON=" "
|
||||
else
|
||||
ICON=" "
|
||||
fi
|
||||
fi
|
||||
|
||||
# If full, show a nicer indicator
|
||||
if [[ "${STATUS}" == "Full" ]]; then
|
||||
CHG_IND=" " # nf-fa-check
|
||||
fi
|
||||
|
||||
echo "${ICON} ${CAPACITY}%"
|
||||
102
waybar/scripts/weather.sh
Executable file
102
waybar/scripts/weather.sh
Executable file
@@ -0,0 +1,102 @@
|
||||
#!/bin/bash
|
||||
|
||||
# --- CONFIGURATION ---
|
||||
LAT="51.0509" # Replace with your Latitude
|
||||
LON="13.7383" # Replace with your Longitude
|
||||
UNITS="metric" # Use "metric" for Celsius, "imperial" for Fahrenheit
|
||||
TZ="Europe/Berlin"
|
||||
# ---------------------
|
||||
|
||||
if [[ "$UNITS" == "metric" ]]; then
|
||||
TEMP_UNIT="celsius"
|
||||
LABEL="°C"
|
||||
else
|
||||
TEMP_UNIT="fahrenheit"
|
||||
LABEL="°F"
|
||||
fi
|
||||
|
||||
# Fetch the weather data
|
||||
RESPONSE=$(curl -s "https://api.open-meteo.com/v1/forecast?latitude=${LAT}&longitude=${LON}¤t=temperature_2m,weather_code,is_day&timezone=${TZ}")
|
||||
|
||||
# Check if curl failed to get a response
|
||||
if [ -z "$RESPONSE" ]; then
|
||||
echo "No connection"
|
||||
exit 1
|
||||
fi
|
||||
|
||||
TEMP=$(echo "$RESPONSE" | jq -r '.current.temperature_2m | round')
|
||||
CODE=$(echo "$RESPONSE" | jq -r '.current.weather_code')
|
||||
IS_DAY=$(echo "$RESPONSE" | jq -r '.current.is_day')
|
||||
|
||||
case "$CODE" in
|
||||
0)
|
||||
if [[ "$IS_DAY" == "1" ]]; then
|
||||
ICON=" " # nf-weather-day_sunny
|
||||
else
|
||||
ICON=" " # nf-weather-night_clear
|
||||
fi
|
||||
DESC="Clear sky"
|
||||
;;
|
||||
1 | 2)
|
||||
if [[ "$IS_DAY" == "1" ]]; then
|
||||
ICON=" " # nf-weather-day_cloudy
|
||||
else
|
||||
ICON=" " # nf-weather-night_alt_cloudy
|
||||
fi
|
||||
DESC="Partly cloudy"
|
||||
;;
|
||||
3)
|
||||
ICON=" " # nf-weather-cloudy
|
||||
DESC="Overcast"
|
||||
;;
|
||||
45 | 48)
|
||||
ICON=" " # nf-weather-fog
|
||||
DESC="Fog"
|
||||
;;
|
||||
51 | 53 | 55)
|
||||
ICON=" " # nf-weather-sprinkle
|
||||
DESC="Drizzle"
|
||||
;;
|
||||
56 | 57)
|
||||
ICON=" "
|
||||
DESC="Freezing drizzle"
|
||||
;;
|
||||
61 | 63 | 65)
|
||||
ICON=" " # nf-weather-rain
|
||||
DESC="Rain"
|
||||
;;
|
||||
66 | 67)
|
||||
ICON=" "
|
||||
DESC="Freezing rain"
|
||||
;;
|
||||
71 | 73 | 75 | 77)
|
||||
ICON=" " # nf-weather-snow
|
||||
DESC="Snow"
|
||||
;;
|
||||
80 | 81 | 82)
|
||||
ICON=" " # nf-weather-showers
|
||||
DESC="Rain showers"
|
||||
;;
|
||||
85 | 86)
|
||||
ICON=" "
|
||||
DESC="Snow showers"
|
||||
;;
|
||||
95)
|
||||
ICON=" " # nf-weather-thunderstorm
|
||||
DESC="Thunderstorm"
|
||||
;;
|
||||
96 | 99)
|
||||
ICON=" "
|
||||
DESC="Thunderstorm with hail"
|
||||
;;
|
||||
esac
|
||||
|
||||
# Determine unit label
|
||||
if [ "$UNITS" = "metric" ]; then
|
||||
LABEL="°C"
|
||||
else
|
||||
LABEL="°F"
|
||||
fi
|
||||
|
||||
# Final JSON output for Waybar
|
||||
echo "{\"text\": \"${ICON} ${TEMP}${LABEL}\", \"tooltip\": \"${DESC}\"}"
|
||||
@@ -78,6 +78,7 @@ window#waybar {
|
||||
#custom-spotify,
|
||||
#custom-notification,
|
||||
#custom-tailscale,
|
||||
#custom-weather,
|
||||
#cpu,
|
||||
#tray,
|
||||
#memory,
|
||||
|
||||
Reference in New Issue
Block a user