fix(weather): show correct wind speed and unit for imperial units

When OPENWEATHER_UNITS=imperial, OpenWeatherMap returns wind speed in
mph directly — the server was incorrectly multiplying by 3.6 (m/s→km/h)
on top of that. All locale strings also hardcoded the unit label instead
of using a {{windUnit}} placeholder, so the label always read km/h.

Resolves #79

Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
Ulas Kalayci
2026-04-22 07:39:13 +02:00
parent 6a4ef09912
commit e1ea0bdb7e
17 changed files with 21 additions and 17 deletions
+2 -1
View File
@@ -390,6 +390,7 @@ function renderWeatherWidget(weather) {
const { city, current, forecast, units } = weather;
const unitSymbol = units === 'imperial' ? '°F' : units === 'standard' ? 'K' : '°C';
const windUnit = units === 'imperial' ? 'mph' : 'km/h';
const forecastHtml = forecast.map((d, i) => {
const date = new Date(d.date + 'T12:00:00');
@@ -419,7 +420,7 @@ function renderWeatherWidget(weather) {
<div class="weather-widget__desc">${esc(current.desc)}</div>
<div class="weather-widget__city">${esc(city)}</div>
<div class="weather-widget__meta">
${t('dashboard.weatherFeelsLike', { temp: current.feels_like, humidity: current.humidity, wind: current.wind_speed })}
${t('dashboard.weatherFeelsLike', { temp: current.feels_like, humidity: current.humidity, wind: current.wind_speed, windUnit })}
</div>
</div>
<img class="weather-widget__icon" src="${WEATHER_ICON_BASE}${current.icon}"