From d2f5dbbc26d5cc23650e4a815446c95ddd0b2fa6 Mon Sep 17 00:00:00 2001 From: Svilen Markov <7613769+svilenmarkov@users.noreply.github.com> Date: Tue, 28 May 2024 17:45:02 +0100 Subject: [PATCH] Fix weather widget making HTTP request as part of validation Which would prevent app startup if there was no internet connection --- internal/widget/weather.go | 23 +++++++++++++++-------- 1 file changed, 15 insertions(+), 8 deletions(-) diff --git a/internal/widget/weather.go b/internal/widget/weather.go index 618237d..ac207d4 100644 --- a/internal/widget/weather.go +++ b/internal/widget/weather.go @@ -27,6 +27,10 @@ var timeLabels24h = [12]string{"02:00", "04:00", "06:00", "08:00", "10:00", "12: func (widget *Weather) Initialize() error { widget.withTitle("Weather").withCacheOnTheHour() + if widget.Location == "" { + return fmt.Errorf("location must be specified for weather widget") + } + if widget.HourFormat == "" || widget.HourFormat == "12h" { widget.TimeLabels = timeLabels12h } else if widget.HourFormat == "24h" { @@ -41,18 +45,21 @@ func (widget *Weather) Initialize() error { return fmt.Errorf("invalid units '%s' for weather, must be either metric or imperial", widget.Units) } - place, err := feed.FetchPlaceFromName(widget.Location) - - if err != nil { - return fmt.Errorf("failed fetching data for %s: %v", widget.Location, err) - } - - widget.Place = place - return nil } func (widget *Weather) Update(ctx context.Context) { + if widget.Place == nil { + place, err := feed.FetchPlaceFromName(widget.Location) + + if err != nil { + widget.withError(err).scheduleEarlyUpdate() + return + } + + widget.Place = place + } + weather, err := feed.FetchWeatherForPlace(widget.Place, widget.Units) if !widget.canContinueUpdateAfterHandlingErr(err) {