Spaces:
Paused
Paused
Update app.py
Browse files
app.py
CHANGED
|
@@ -146,6 +146,72 @@ def fetch_local_events():
|
|
| 146 |
else:
|
| 147 |
return "<p>Failed to fetch local events</p>"
|
| 148 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 149 |
def fetch_local_weather():
|
| 150 |
try:
|
| 151 |
api_key = os.environ['WEATHER_API']
|
|
@@ -156,10 +222,12 @@ def fetch_local_weather():
|
|
| 156 |
|
| 157 |
current_conditions = jsonData.get("currentConditions", {})
|
| 158 |
temp_celsius = current_conditions.get("temp", "N/A")
|
|
|
|
| 159 |
if temp_celsius != "N/A":
|
| 160 |
-
temp_fahrenheit = (temp_celsius * 9/5) + 32
|
| 161 |
else:
|
| 162 |
temp_fahrenheit = "N/A"
|
|
|
|
| 163 |
condition = current_conditions.get("conditions", "N/A")
|
| 164 |
humidity = current_conditions.get("humidity", "N/A")
|
| 165 |
|
|
@@ -212,7 +280,6 @@ def fetch_local_weather():
|
|
| 212 |
return weather_html
|
| 213 |
except requests.exceptions.RequestException as e:
|
| 214 |
return f"<p>Failed to fetch local weather: {e}</p>"
|
| 215 |
-
|
| 216 |
def get_weather_icon(condition):
|
| 217 |
condition_map = {
|
| 218 |
"Clear": "c01d",
|
|
|
|
| 146 |
else:
|
| 147 |
return "<p>Failed to fetch local events</p>"
|
| 148 |
|
| 149 |
+
# def fetch_local_weather():
|
| 150 |
+
# try:
|
| 151 |
+
# api_key = os.environ['WEATHER_API']
|
| 152 |
+
# url = f'https://weather.visualcrossing.com/VisualCrossingWebServices/rest/services/timeline/omaha?unitGroup=metric&include=events%2Calerts%2Chours%2Cdays%2Ccurrent&key={api_key}'
|
| 153 |
+
# response = requests.get(url)
|
| 154 |
+
# response.raise_for_status()
|
| 155 |
+
# jsonData = response.json()
|
| 156 |
+
|
| 157 |
+
# current_conditions = jsonData.get("currentConditions", {})
|
| 158 |
+
# temp_celsius = current_conditions.get("temp", "N/A")
|
| 159 |
+
# if temp_celsius != "N/A":
|
| 160 |
+
# temp_fahrenheit = (temp_celsius * 9/5) + 32
|
| 161 |
+
# else:
|
| 162 |
+
# temp_fahrenheit = "N/A"
|
| 163 |
+
# condition = current_conditions.get("conditions", "N/A")
|
| 164 |
+
# humidity = current_conditions.get("humidity", "N/A")
|
| 165 |
+
|
| 166 |
+
# weather_html = f"""
|
| 167 |
+
# <div class="weather-theme">
|
| 168 |
+
# <h2 style="font-family: 'Georgia', serif; color: #4CAF50; background-color: #f8f8f8; padding: 10px; border-radius: 10px;">Local Weather</h2>
|
| 169 |
+
# <div class="weather-content">
|
| 170 |
+
# <div class="weather-icon">
|
| 171 |
+
# <img src="https://www.weatherbit.io/static/img/icons/{get_weather_icon(condition)}.png" alt="{condition}" style="width: 100px; height: 100px;">
|
| 172 |
+
# </div>
|
| 173 |
+
# <div class="weather-details">
|
| 174 |
+
# <p style="font-family: 'Verdana', sans-serif; color: #333; font-size: 1.2em;">Temperature: {temp_fahrenheit}°F</p>
|
| 175 |
+
# <p style="font-family: 'Verdana', sans-serif; color: #333; font-size: 1.2em;">Condition: {condition}</p>
|
| 176 |
+
# <p style="font-family: 'Verdana', sans-serif; color: #333; font-size: 1.2em;">Humidity: {humidity}%</p>
|
| 177 |
+
# </div>
|
| 178 |
+
# </div>
|
| 179 |
+
# </div>
|
| 180 |
+
# <style>
|
| 181 |
+
# .weather-theme {{
|
| 182 |
+
# animation: backgroundAnimation 10s infinite alternate;
|
| 183 |
+
# border: 1px solid #ddd;
|
| 184 |
+
# border-radius: 10px;
|
| 185 |
+
# padding: 10px;
|
| 186 |
+
# margin-bottom: 15px;
|
| 187 |
+
# background: linear-gradient(45deg, #ffcc33, #ff6666, #ffcc33, #ff6666);
|
| 188 |
+
# background-size: 400% 400%;
|
| 189 |
+
# box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
|
| 190 |
+
# transition: box-shadow 0.3s ease, background-color 0.3s ease;
|
| 191 |
+
# }}
|
| 192 |
+
# .weather-theme:hover {{
|
| 193 |
+
# box-shadow: 0 8px 16px rgba(0, 0, 0, 0.2);
|
| 194 |
+
# background-position: 100% 100%;
|
| 195 |
+
# }}
|
| 196 |
+
# @keyframes backgroundAnimation {{
|
| 197 |
+
# 0% {{ background-position: 0% 50%; }}
|
| 198 |
+
# 100% {{ background-position: 100% 50%; }}
|
| 199 |
+
# }}
|
| 200 |
+
# .weather-content {{
|
| 201 |
+
# display: flex;
|
| 202 |
+
# align-items: center;
|
| 203 |
+
# }}
|
| 204 |
+
# .weather-icon {{
|
| 205 |
+
# flex: 1;
|
| 206 |
+
# }}
|
| 207 |
+
# .weather-details {{
|
| 208 |
+
# flex: 3;
|
| 209 |
+
# }}
|
| 210 |
+
# </style>
|
| 211 |
+
# """
|
| 212 |
+
# return weather_html
|
| 213 |
+
# except requests.exceptions.RequestException as e:
|
| 214 |
+
# return f"<p>Failed to fetch local weather: {e}</p>"
|
| 215 |
def fetch_local_weather():
|
| 216 |
try:
|
| 217 |
api_key = os.environ['WEATHER_API']
|
|
|
|
| 222 |
|
| 223 |
current_conditions = jsonData.get("currentConditions", {})
|
| 224 |
temp_celsius = current_conditions.get("temp", "N/A")
|
| 225 |
+
|
| 226 |
if temp_celsius != "N/A":
|
| 227 |
+
temp_fahrenheit = int((temp_celsius * 9/5) + 32)
|
| 228 |
else:
|
| 229 |
temp_fahrenheit = "N/A"
|
| 230 |
+
|
| 231 |
condition = current_conditions.get("conditions", "N/A")
|
| 232 |
humidity = current_conditions.get("humidity", "N/A")
|
| 233 |
|
|
|
|
| 280 |
return weather_html
|
| 281 |
except requests.exceptions.RequestException as e:
|
| 282 |
return f"<p>Failed to fetch local weather: {e}</p>"
|
|
|
|
| 283 |
def get_weather_icon(condition):
|
| 284 |
condition_map = {
|
| 285 |
"Clear": "c01d",
|