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 Util 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 $ InputIn { _inputIn_reset = R.ffilter Either.isRight signInResult , _inputIn_hasResetButton = True , _inputIn_label = Msg.get Msg.SignIn_EmailLabel , _inputIn_initialValue = "" , _inputIn_inputType = "text" } 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) <- Util.waitFor (\email -> Ajax.post "/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