module Main
  ( main
  ) where

import qualified Data.Aeson                           as Aeson
import qualified Data.ByteString.Lazy                 as LB
import qualified Data.JSString.Text                   as Dom
import qualified Data.Text.Encoding                   as T
import qualified JSDOM                                as Dom
import qualified JSDOM.Generated.HTMLElement          as Dom
import qualified JSDOM.Generated.NonElementParentNode as Dom
import           JSDOM.Types                          (HTMLElement (..), JSM)
import qualified JSDOM.Types                          as Dom
import           Prelude                              hiding (error, init)

import           Common.Model                         (InitResult (InitError))
import qualified Common.Msg                           as Msg

import qualified View.App                             as App

main :: JSM ()
main = do
  initResult <- readInit
  App.widget initResult

readInit :: JSM InitResult
readInit = do
  document <- Dom.currentDocumentUnchecked
  initNode <- Dom.getElementById document ("init" :: Dom.JSString)

  case initNode of
    Just node -> do
      text <- Dom.textFromJSString <$> Dom.getInnerText (Dom.uncheckedCastTo HTMLElement node)
      return $ case Aeson.decode (LB.fromStrict . T.encodeUtf8 $ text) of
        Just init -> init
        Nothing   -> initParseError
    _ ->
      return initParseError

  where initParseError = InitError $ Msg.get Msg.SignIn_ParseError