-
Notifications
You must be signed in to change notification settings - Fork 372
Cookbook Multi field validation
Sibi Prabakaran edited this page Jun 22, 2016
·
4 revisions
[WARNING] Yesod Cookbook has moved to a new place. Please contribute there.
{-# LANGUAGE OverloadedStrings, QuasiQuotes, TemplateHaskell,
TypeFamilies, MultiParamTypeClasses #-}
import Yesod
import Data.Text (Text)
import Control.Applicative ((<$>), (<*>))
data MF = MF
instance Yesod MF
instance RenderMessage MF FormMessage where
renderMessage _ _ = defaultFormMessage
mkYesod "MF" [parseRoutes|
/ RootR GET
|]
form html = do
(res, widget) <- flip renderDivs html $ (,)
<$> areq textField "Name" Nothing
<*> areq intField "Age" Nothing
return $ case res of
FormSuccess (name, age)
| name == "Michael" && age /= 26 ->
let msg = "Invalid name/age combination"
in (FormFailure [msg], [whamlet|
<p .errors>#{msg}
^{widget}
|])
_ -> (res, widget)
getRootR :: Handler Html
getRootR = do
((res, widget), enctype) <- runFormGet form
defaultLayout [whamlet|
<p>Result: #{show res}
<form enctype=#{enctype}>
^{widget}
<p>
<input type=submit>
|]
main = warp 3000 MF