Skip to content

Commit

Permalink
Merge pull request #454 from Ryuno-Ki/weather-api-forecast
Browse files Browse the repository at this point in the history
feat: show daily forecast
  • Loading branch information
streetturtle authored Oct 5, 2024
2 parents 68ddbd9 + 27727f0 commit c9c1d6b
Show file tree
Hide file tree
Showing 2 changed files with 73 additions and 3 deletions.
1 change: 1 addition & 0 deletions weather-api-widget/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ following config parameters:
| units | `metric` | `metric` for celsius, `imperial` for fahrenheit |
| icon_pack_name | `weather-underground-icons` | Name of the icon pack, could be `weather-underground-icon` or `VitalyGorbachev` or create your own, more details below |
| icons_extension | `.png` | File extension of icons in the pack |
| show_forecast | false | Show forecast for next three days |
| timeout | 120 | How often in seconds the widget refreshes |

### Icons:
Expand Down
75 changes: 72 additions & 3 deletions weather-api-widget/weather.lua
Original file line number Diff line number Diff line change
Expand Up @@ -174,13 +174,16 @@ local function worker(user_args)
local both_units_widget = args.both_units_widget or false
local icon_pack_name = args.icons or 'weather-underground-icons'
local icons_extension = args.icons_extension or '.png'
local show_forecast = args.show_forecast or false
local timeout = args.timeout or 120

local ICONS_DIR = WIDGET_DIR .. '/icons/' .. icon_pack_name .. '/'
local weather_api =
('https://api.weatherapi.com/v1/current.json' ..
-- Forecast endpoint includes current. I could map show_forecast to days here.
-- Currently overfetching but only showing when opting in.
local weather_api =
('https://api.weatherapi.com/v1/forecast.json' ..
'?q=' .. coordinates[1] .. ',' .. coordinates[2] .. '&key=' .. api_key ..
'&units=' .. units .. '&lang=' .. LANG)
'&units=' .. units .. '&lang=' .. LANG .. '&days=3')

weather_widget = wibox.widget {
{
Expand Down Expand Up @@ -301,6 +304,66 @@ local function worker(user_args)
end
}

local forecast_widget = {
forced_width = 300,
layout = wibox.layout.flex.horizontal,
update = function(self, forecast)
local count = #self
for i = 0, count do self[i] = nil end
for i, day in ipairs(forecast) do
-- Free plan allows forecast for up to three days, each with hours
if i > 3 then break end
local day_forecast = wibox.widget {
{
text = os.date('%a', tonumber(day.date_epoch)),
align = 'center',
font = font_name .. ' 9',
widget = wibox.widget.textbox
},
{
{
{
image = ICONS_DIR .. icon_map[day.day.condition.code] .. icons_extension,
resize = true,
forced_width = 48,
forced_height = 48,
widget = wibox.widget.imagebox
},
align = 'center',
layout = wibox.container.place
},
{
text = day.day.condition.text,
font = font_name .. ' 8',
align = 'center',
forced_height = 50,
widget = wibox.widget.textbox
},
layout = wibox.layout.fixed.vertical
},
{
{
text = gen_temperature_str(day.day.mintemp_c, '%.0f', false, units),
align = 'center',
font = font_name .. ' 9',
widget = wibox.widget.textbox
},
{
text = gen_temperature_str(day.day.maxtemp_c, '%.0f', false, units),
align = 'center',
font = font_name .. ' 9',
widget = wibox.widget.textbox
},
layout = wibox.layout.fixed.vertical
},
spacing = 8,
layout = wibox.layout.fixed.vertical
}
table.insert(self, day_forecast)
end
end
}

local function update_widget(widget, stdout, stderr)
if stderr ~= '' then
if not warning_shown then
Expand Down Expand Up @@ -347,6 +410,12 @@ local function worker(user_args)
layout = wibox.layout.fixed.vertical
}


if show_forecast then
forecast_widget:update(result.forecast.forecastday)
table.insert(final_widget, forecast_widget)
end

weather_popup:setup({
{
final_widget,
Expand Down

0 comments on commit c9c1d6b

Please sign in to comment.