diff options
Diffstat (limited to 'src/client/elm/Main.elm')
-rw-r--r-- | src/client/elm/Main.elm | 48 |
1 files changed, 32 insertions, 16 deletions
diff --git a/src/client/elm/Main.elm b/src/client/elm/Main.elm index 0ba25b7..ac70202 100644 --- a/src/client/elm/Main.elm +++ b/src/client/elm/Main.elm @@ -3,11 +3,12 @@ module Main ) where import Graphics.Element exposing (..) +import Json.Decode as Json import Html exposing (Html) import StartApp exposing (App) import Effects exposing (Effects, Never) -import Json.Decode as Json +import TransitRouter import Task exposing (..) import Time exposing (..) @@ -16,34 +17,48 @@ import Server import Action exposing (..) import Model exposing (Model, initialModel) -import Update exposing (update) +import Update exposing (update, routerConfig) import View exposing (view) import Utils.Maybe exposing (isJust) +import Utils.Effects as Effects main : Signal Html main = app.html app : App Model app = StartApp.start - { init = - case Json.decodeString Json.string signInError of - Ok signInError -> - ( initialModel initialTime translations conf (Just signInError) - , Effects.none - ) - Err _ -> - ( initialModel initialTime translations conf Nothing - , Server.init - |> Task.map GoLoggedInView - |> flip Task.onError (always <| Task.succeed GoSignInView) - |> Effects.task - ) + { init = initData `Effects.andThen` initRouter , view = view , update = update - , inputs = [ Signal.map UpdateTime (Time.every 1000) ] + , inputs = + [ Signal.map UpdateTime (Time.every 1000) + , Signal.map RouterAction TransitRouter.actions + ] } +-- Init + +initData : (Model, Effects Action) +initData = + case Json.decodeString Json.string signInError of + Ok signInError -> + ( initialModel initialTime translations conf (Just signInError) + , Effects.none + ) + Err _ -> + ( initialModel initialTime translations conf Nothing + , Server.init + |> Task.map GoLoggedInView + |> flip Task.onError (always <| Task.succeed GoSignInView) + |> Effects.task + ) + +initRouter : Model -> (Model, Effects Action) +initRouter model = TransitRouter.init routerConfig location model + +-- Output ports + port tasks : Signal (Task.Task Never ()) port tasks = app.tasks @@ -53,3 +68,4 @@ port initialTime : Time port translations : String port conf : String port signInError : String +port location : String |