module Model
  ( Model
  , initialModel
  ) where

import Time exposing (Time)
import Json.Decode as Json

import TransitRouter
import Route exposing (Route)

import Model.View exposing (..)
import Model.Translations exposing (..)
import Model.Conf exposing (..)

import SignIn.Model as SignInModel

import Utils.Maybe exposing (isJust)

type alias Model =
  { view : View
  , currentTime : Time
  , translations : Translations
  , conf : Conf
  , transitRouter : TransitRouter.TransitRouter Route
  }

initialModel : Time -> String -> String -> Maybe String -> Model
initialModel initialTime translations conf mbSignInError =
  { view =
      if isJust mbSignInError
        then SignInView (SignInModel.init mbSignInError)
        else LoadingView
  , currentTime = initialTime
  , translations =
      case Json.decodeString translationsDecoder translations of
        Ok translations -> translations
        Err _ -> []
  , conf =
      case Json.decodeString confDecoder conf of
        Ok conf -> conf
        Err _ -> { currency = "" }
  , transitRouter = TransitRouter.empty Route.Empty
  }