Add OpenWeatherMap module
It needs an API key for which you have to solve a Google captcha which I refuse, so I'm probably going to remove this again
This commit is contained in:
parent
c8808cbb5e
commit
9d90d53c3d
2 changed files with 97 additions and 0 deletions
|
@ -53,6 +53,7 @@ font-2 = fixed:pixelsize=10;1
|
||||||
font-3 = "Material Icons:pixelsize=14;3"
|
font-3 = "Material Icons:pixelsize=14;3"
|
||||||
font-4 = "Fira Sans:size=12;1"
|
font-4 = "Fira Sans:size=12;1"
|
||||||
font-5 = "Fira Mono:size=10;1"
|
font-5 = "Fira Mono:size=10;1"
|
||||||
|
font-6 = "Weather Icons:size=10;1"
|
||||||
;font-3 = unifont:fontformat=truetype:size=8:antialias=false;0
|
;font-3 = unifont:fontformat=truetype:size=8:antialias=false;0
|
||||||
;font-4 = siji:pixelsize=10;1
|
;font-4 = siji:pixelsize=10;1
|
||||||
|
|
||||||
|
@ -395,6 +396,12 @@ type = custom/script
|
||||||
exec = LAYOUT=azerty ICON= METRIC=wpm ~/.config/polybar/info-hackspeed.sh
|
exec = LAYOUT=azerty ICON= METRIC=wpm ~/.config/polybar/info-hackspeed.sh
|
||||||
tail = true
|
tail = true
|
||||||
|
|
||||||
|
[module/weather-full]
|
||||||
|
type = custom/script
|
||||||
|
exec = ~/.config/polybar/openweathermap-fullfeatured.sh
|
||||||
|
interval = 600
|
||||||
|
label-font = 7
|
||||||
|
|
||||||
[settings]
|
[settings]
|
||||||
screenchange-reload = true
|
screenchange-reload = true
|
||||||
; they say: see https://www.cairographics.org/manual/cairo-cairo-t.html#cairo-operator-t
|
; they say: see https://www.cairographics.org/manual/cairo-cairo-t.html#cairo-operator-t
|
||||||
|
|
90
polybar/openweathermap-fullfeatured.sh
Executable file
90
polybar/openweathermap-fullfeatured.sh
Executable file
|
@ -0,0 +1,90 @@
|
||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
get_icon() {
|
||||||
|
case $1 in
|
||||||
|
01d) icon="";;
|
||||||
|
01n) icon="";;
|
||||||
|
02d) icon="";;
|
||||||
|
02n) icon="";;
|
||||||
|
03*) icon="";;
|
||||||
|
04*) icon="";;
|
||||||
|
09d) icon="";;
|
||||||
|
09n) icon="";;
|
||||||
|
10d) icon="";;
|
||||||
|
10n) icon="";;
|
||||||
|
11d) icon="";;
|
||||||
|
11n) icon="";;
|
||||||
|
13d) icon="";;
|
||||||
|
13n) icon="";;
|
||||||
|
50d) icon="";;
|
||||||
|
50n) icon="";;
|
||||||
|
*) icon="";
|
||||||
|
esac
|
||||||
|
|
||||||
|
echo $icon
|
||||||
|
}
|
||||||
|
|
||||||
|
get_duration() {
|
||||||
|
|
||||||
|
osname=$(uname -s)
|
||||||
|
|
||||||
|
case $osname in
|
||||||
|
*BSD) date -r "$1" -u +%H:%M;;
|
||||||
|
*) date --date="@$1" -u +%H:%M;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
KEY=""
|
||||||
|
CITY=""
|
||||||
|
UNITS="metric"
|
||||||
|
SYMBOL="°"
|
||||||
|
|
||||||
|
if [ ! -z $CITY ]; then
|
||||||
|
current=$(curl -sf "http://api.openweathermap.org/data/2.5/weather?APPID=$KEY&id=$CITY&units=$UNITS")
|
||||||
|
forecast=$(curl -sf "http://api.openweathermap.org/data/2.5/forecast?APPID=$KEY&id=$CITY&units=$UNITS&cnt=1")
|
||||||
|
else
|
||||||
|
location=$(curl -sf https://location.services.mozilla.com/v1/geolocate?key=geoclue)
|
||||||
|
|
||||||
|
if [ ! -z "$location" ]; then
|
||||||
|
location_lat="$(echo "$location" | jq '.location.lat')"
|
||||||
|
location_lon="$(echo "$location" | jq '.location.lng')"
|
||||||
|
|
||||||
|
current=$(curl -sf "http://api.openweathermap.org/data/2.5/weather?appid=$KEY&lat=$location_lat&lon=$location_lon&units=$UNITS")
|
||||||
|
forecast=$(curl -sf "http://api.openweathermap.org/data/2.5/forecast?APPID=$KEY&lat=$location_lat&lon=$location_lon&units=$UNITS&cnt=1")
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ ! -z "$current" ] && [ ! -z "$forecast" ]; then
|
||||||
|
current_temp=$(echo "$current" | jq ".main.temp" | cut -d "." -f 1)
|
||||||
|
current_icon=$(echo "$current" | jq -r ".weather[].icon")
|
||||||
|
|
||||||
|
forecast_temp=$(echo "$forecast" | jq ".list[].main.temp" | cut -d "." -f 1)
|
||||||
|
forecast_icon=$(echo "$forecast" | jq -r ".list[].weather[].icon")
|
||||||
|
|
||||||
|
|
||||||
|
if [ "$current_temp" -gt "$forecast_temp" ]; then
|
||||||
|
trend=""
|
||||||
|
elif [ "$forecast_temp" -gt "$current_temp" ]; then
|
||||||
|
trend=""
|
||||||
|
else
|
||||||
|
trend=""
|
||||||
|
fi
|
||||||
|
|
||||||
|
|
||||||
|
sun_rise=$(echo "$current" | jq ".sys.sunrise")
|
||||||
|
sun_set=$(echo "$current" | jq ".sys.sunset")
|
||||||
|
now=$(date +%s)
|
||||||
|
|
||||||
|
if [ "$sun_rise" -gt "$now" ]; then
|
||||||
|
daytime=" $(get_duration "$(($sun_rise-$now))")"
|
||||||
|
elif [ "$sun_set" -gt "$now" ]; then
|
||||||
|
daytime=" $(get_duration "$(($sun_set-$now))")"
|
||||||
|
else
|
||||||
|
daytime=" $(get_duration "$(($sun_rise-$now))")"
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "$(get_icon "$current_icon") $current_temp$SYMBOL $trend $(get_icon "$forecast_icon") $forecast_temp$SYMBOL $daytime"
|
||||||
|
else
|
||||||
|
echo "No weather info"
|
||||||
|
fi
|
Loading…
Reference in a new issue