From a98bb776a9208c5e2e1c6d3b491e5363d179ac9c Mon Sep 17 00:00:00 2001 From: James Walker Date: Tue, 17 Dec 2024 18:45:10 +0000 Subject: [PATCH] fix: Maintain selected region when switching between pages --- app/Route/Events.elm | 20 ++++++++++++++------ app/Route/Index.elm | 6 ++++-- app/Route/Partners.elm | 6 ++++-- app/Shared.elm | 4 ++++ src/Messages.elm | 1 + 5 files changed, 27 insertions(+), 10 deletions(-) diff --git a/app/Route/Events.elm b/app/Route/Events.elm index 1a473f2..4a2ea7b 100644 --- a/app/Route/Events.elm +++ b/app/Route/Events.elm @@ -26,6 +26,7 @@ import Theme.RegionSelector import Time import UrlPath import View exposing (View) +import Messages exposing (Msg(..)) type alias Model = @@ -66,7 +67,7 @@ update : -> Shared.Model -> Msg -> Model - -> ( Model, Effect.Effect Msg ) + -> ( Model, Effect.Effect Msg, Maybe Shared.Msg ) update app _ msg model = case msg of Theme.Page.Events.PaginatorMsg submsg -> @@ -77,6 +78,7 @@ update app _ msg model = Theme.Paginator.Day posix } , Effect.none + , Nothing ) Theme.Paginator.ClickedAllPastEvents -> @@ -84,6 +86,7 @@ update app _ msg model = | filterByDate = Theme.Paginator.Past } , Effect.none + , Nothing ) Theme.Paginator.ClickedAllFutureEvents -> @@ -91,6 +94,7 @@ update app _ msg model = | filterByDate = Theme.Paginator.Future } , Effect.none + , Nothing ) Theme.Paginator.GetTime newTime -> @@ -99,6 +103,7 @@ update app _ msg model = , nowTime = newTime } , Effect.none + , Nothing ) Theme.Paginator.ScrollRight -> @@ -107,6 +112,7 @@ update app _ msg model = (Theme.Paginator.scrollPagination Theme.Paginator.Right model.viewportWidth) |> Cmd.map Theme.Page.Events.fromPaginatorMsg |> Effect.fromCmd + , Nothing ) Theme.Paginator.ScrollLeft -> @@ -115,21 +121,23 @@ update app _ msg model = (Theme.Paginator.scrollPagination Theme.Paginator.Left model.viewportWidth) |> Cmd.map Theme.Page.Events.fromPaginatorMsg |> Effect.fromCmd + , Nothing ) Theme.Paginator.GotViewport viewport -> - ( { model | viewportWidth = Maybe.withDefault model.viewportWidth (Just viewport.scene.width) }, Effect.none ) + ( { model | viewportWidth = Maybe.withDefault model.viewportWidth (Just viewport.scene.width) }, Effect.none, Nothing ) Theme.Paginator.NoOp -> - ( model, Effect.none ) + ( model, Effect.none, Nothing ) Theme.Page.Events.RegionSelectorMsg submsg -> case submsg of - Theme.RegionSelector.ClickedSelector regionId -> + Theme.RegionSelector.ClickedSelector tagId -> ( { model - | filterByRegion = regionId + | filterByRegion = tagId } , Effect.none + , Just (SetRegion tagId) ) @@ -142,7 +150,7 @@ route : RouteBuilder.StatefulRoute RouteParams Data ActionData Model Msg route = RouteBuilder.single { data = data, head = head } - |> RouteBuilder.buildWithLocalState + |> RouteBuilder.buildWithSharedState { init = init , view = view , update = update diff --git a/app/Route/Index.elm b/app/Route/Index.elm index 333957d..ed5ec38 100644 --- a/app/Route/Index.elm +++ b/app/Route/Index.elm @@ -23,6 +23,7 @@ import Theme.RegionSelector exposing (Msg(..)) import Time import UrlPath import View +import Messages exposing (Msg(..)) type alias Model = @@ -56,7 +57,7 @@ update : -> Shared.Model -> Msg -> Model - -> ( Model, Effect.Effect Msg ) + -> ( Model, Effect.Effect Msg, Maybe Shared.Msg ) update app _ msg model = case msg of ClickedSelector tagId -> @@ -64,6 +65,7 @@ update app _ msg model = | filterByRegion = tagId } , Effect.none + , Just (SetRegion tagId) ) @@ -76,7 +78,7 @@ route : RouteBuilder.StatefulRoute RouteParams Data ActionData Model Msg route = RouteBuilder.single { data = data, head = head } - |> RouteBuilder.buildWithLocalState + |> RouteBuilder.buildWithSharedState { init = init , view = view , update = update diff --git a/app/Route/Partners.elm b/app/Route/Partners.elm index bc8c6e4..2596a9a 100644 --- a/app/Route/Partners.elm +++ b/app/Route/Partners.elm @@ -21,6 +21,7 @@ import Theme.PageTemplate import Theme.RegionSelector exposing (Msg(..)) import UrlPath import View +import Messages exposing (Msg(..)) type alias Model = @@ -50,7 +51,7 @@ update : -> Shared.Model -> Msg -> Model - -> ( Model, Effect.Effect Msg ) + -> ( Model, Effect.Effect Msg, Maybe Shared.Msg ) update app _ msg model = case msg of ClickedSelector tagId -> @@ -58,6 +59,7 @@ update app _ msg model = | filterByRegion = tagId } , Effect.none + , Just (SetRegion tagId) ) @@ -70,7 +72,7 @@ route : RouteBuilder.StatefulRoute RouteParams Data ActionData Model Msg route = RouteBuilder.single { data = data, head = head } - |> RouteBuilder.buildWithLocalState + |> RouteBuilder.buildWithSharedState { init = init , view = view , update = update diff --git a/app/Shared.elm b/app/Shared.elm index e8b1905..a65e444 100644 --- a/app/Shared.elm +++ b/app/Shared.elm @@ -123,6 +123,10 @@ update msg model = -- Shared SharedMsg _ -> ( model, Effect.none ) + + -- Update region filter + SetRegion tagId -> + ( { model | filterParam = Just (tagId) }, Effect.none ) subscriptions : UrlPath -> Model -> Sub Msg diff --git a/src/Messages.elm b/src/Messages.elm index a9fd34d..e14032e 100644 --- a/src/Messages.elm +++ b/src/Messages.elm @@ -14,6 +14,7 @@ type Msg | ToggleMenu -- Shared | SharedMsg SharedMsg + | SetRegion Int type SharedMsg