initial commit

This commit is contained in:
2024-04-06 19:31:51 -05:00
commit 8ff9cb0e98
32 changed files with 1229 additions and 0 deletions

27
waybar/scripts/updates.sh Executable file
View File

@ -0,0 +1,27 @@
#!/usr/bin/env bash
if [ ! -f /etc/arch-release ]; then
exit 0
fi
AUR=$(paru -Qua | wc -l)
OFFICIAL=$(checkupdates | wc -l)
case $1 in
aur) echo "$AUR";;
official) echo "$OFFICIAL";;
esac
if [ "$1" = "update" ]; then
alacritty -o 'window.startup_mode="Fullscreen"' -e 'paru'
fi
if [ "$1" = "json" ]; then
COUNT=$((OFFICIAL+AUR))
echo "{ \"text\": \" $COUNT\", \"alt\": \"$COUNT Updates\", \"tooltip\": \"Updates Available\n\nAUR: $AUR\nOfficial: $OFFICIAL\nTotal: $COUNT\" }"
fi
if [ "$1" = "" ]; then
echo "$((OFFICIAL+AUR))"
fi

115
waybar/scripts/weather.py Executable file
View File

@ -0,0 +1,115 @@
#!/usr/bin/env python
import json
import requests
from datetime import datetime
ZIP_CODE = 38654
WEATHER_CODES = {
'113': '☀️',
'116': '',
'119': '☁️',
'122': '☁️',
'143': '☁️',
'176': '🌧️',
'179': '🌧️',
'182': '🌧️',
'185': '🌧️',
'200': '⛈️',
'227': '🌨️',
'230': '🌨️',
'248': '☁️',
'260': '☁️',
'263': '🌧️',
'266': '🌧️',
'281': '🌧️',
'284': '🌧️',
'293': '🌧️',
'296': '🌧️',
'299': '🌧️',
'302': '🌧️',
'305': '🌧️',
'308': '🌧️',
'311': '🌧️',
'314': '🌧️',
'317': '🌧️',
'320': '🌨️',
'323': '🌨️',
'326': '🌨️',
'329': '❄️',
'332': ' ',
'335': '❄️',
'338': '❄️',
'350': '🌧️',
'353': '🌧️',
'356': '',
'359': '',
'362': '',
'365': '',
'368': '',
'371': '❄️',
'374': '',
'377': '',
'386': '',
'389': '',
'392': '',
'395': '❄️'
}
data = {}
weather = requests.get(f"https://wttr.in/{ZIP_CODE}?format=j1").json()
def format_time(time):
return time.replace("00", "").zfill(2)
def format_temp(temp):
return (hour['FeelsLikeF']+"°").ljust(3)
def format_chances(hour):
chances = {
"chanceoffog": "Fog",
"chanceoffrost": "Frost",
"chanceofovercast": "Overcast",
"chanceofrain": "Rain",
"chanceofsnow": "Snow",
"chanceofsunshine": "Sunshine",
"chanceofthunder": "Thunder",
"chanceofwindy": "Wind"
}
conditions = []
for event in chances.keys():
if int(hour[event]) > 0:
conditions.append(chances[event]+" "+hour[event]+"%")
return ", ".join(conditions)
tempint = int(weather['current_condition'][0]['FeelsLikeF'])
extrachar = ''
if tempint > 0 and tempint < 10:
extrachar = '+'
data['text'] = ''+WEATHER_CODES[weather['current_condition'][0]['weatherCode']] + \
" "+extrachar+weather['current_condition'][0]['FeelsLikeF']+"°"
data['tooltip'] = f"<b>{weather['current_condition'][0]['weatherDesc'][0]['value']} {weather['current_condition'][0]['temp_F']}°</b>\n"
data['tooltip'] += f"Feels like: {weather['current_condition'][0]['FeelsLikeF']}°\n"
data['tooltip'] += f"Wind: {weather['current_condition'][0]['windspeedKmph']}Km/h\n"
data['tooltip'] += f"Humidity: {weather['current_condition'][0]['humidity']}%\n"
for i, day in enumerate(weather['weather']):
data['tooltip'] += f"\n<b>"
if i == 0:
data['tooltip'] += "Today, "
if i == 1:
data['tooltip'] += "Tomorrow, "
data['tooltip'] += f"{day['date']}</b>\n"
data['tooltip'] += f"⬆️ {day['maxtempF']}° ⬇️ {day['mintempF']}° "
data['tooltip'] += f"🌅 {day['astronomy'][0]['sunrise']} 🌇 {day['astronomy'][0]['sunset']}\n"
for hour in day['hourly']:
if i == 0:
if int(format_time(hour['time'])) < datetime.now().hour-2:
continue
data['tooltip'] += f"{format_time(hour['time'])} {WEATHER_CODES[hour['weatherCode']]} {format_temp(hour['FeelsLikeF'])} {hour['weatherDesc'][0]['value'].replace('Clear ', 'Clear')}, {format_chances(hour)}\n"
print(json.dumps(data))