aboutsummaryrefslogtreecommitdiff
path: root/client/src/View/SignIn.hs
blob: 7f53299bf20a688d4e727b997b37283d1527a926 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
module View.SignIn
  ( SignInMessage (..)
  , view
  ) where

import qualified Data.Either  as Either
import           Data.Text    (Text)
import           Prelude      hiding (error)
import           Reflex.Dom   (Event, MonadWidget)
import qualified Reflex.Dom   as R

import           Common.Model (SignIn (SignIn))
import qualified Common.Msg   as Msg

import           Component    (ButtonIn (..), ButtonOut (..), InputIn (..),
                               InputOut (..))
import qualified Component    as Component
import qualified Util.Ajax    as Ajax
import qualified Util.WaitFor as WaitFor

data SignInMessage =
  SuccessMessage Text
  | ErrorMessage Text
  | EmptyMessage

view :: forall t m. MonadWidget t m => SignInMessage -> m ()
view signInMessage =
  R.divClass "signIn" $
    Component.form $ do
      rec
        input <- (Component.input
          (Component.defaultInputIn { _inputIn_label = Msg.get Msg.SignIn_EmailLabel })
          (R.ffilter Either.isRight signInResult))

        button <- Component.button $
          (Component.defaultButtonIn (R.text $ Msg.get Msg.SignIn_Button))
            { _buttonIn_class = R.constDyn "validate"
            , _buttonIn_waiting = waiting
            , _buttonIn_submit = True
            }

        (signInResult, waiting) <- WaitFor.waitFor
          (\email -> Ajax.postJson "/askSignIn" (SignIn <$> email))
          (_buttonOut_clic button)
          (_inputOut_value input)

      showSignInResult signInMessage signInResult

showSignInResult :: forall t m. MonadWidget t m => SignInMessage -> Event t (Either Text Text) -> m ()
showSignInResult signInMessage signInResult = do
  _ <- R.widgetHold (showInitResult signInMessage) $ R.ffor signInResult showResult
  R.blank

  where showInitResult (SuccessMessage success) = showSuccess success
        showInitResult (ErrorMessage error)     = showError error
        showInitResult EmptyMessage             = R.blank

        showResult (Left error)    = showError error
        showResult (Right success) = showSuccess success

        showError = R.divClass "error" . R.text
        showSuccess = R.divClass "success" . R.text