{-# language OverloadedStrings #-} {-# language MultiParamTypeClasses #-} {-# language FlexibleInstances #-} {-# language TypeFamilies #-} {-# OPTIONS_GHC -fno-warn-orphans #-} module Web.Scotty.Form where import Data.Text (Text) import Ditto.Core hiding (view) import Ditto.Lucid import Ditto.Types import Lucid (HtmlT, Html) import Web.Scotty import Ditto.Backend import qualified Data.Text as T import qualified Data.Text.Lazy as TL instance Environment ActionM [Param] where environment formId = do qp <- params let !formId' = TL.fromStrict $ encodeFormId formId case filter (\(x,_) -> x == formId') qp of [] -> pure Missing xs -> pure (Found xs) instance FormInput [Param] where type FileType [Param] = () getInputStrings xs = fmap (TL.unpack . snd) xs getInputFile _ = Left $ commonFormError $ (NoFileFound [("","No support for file uploads")] :: CommonFormError [Param]) instance FormError [Param] Text where commonFormError e = commonFormErrorText encQP e where encQP [] = "" encQP xs = T.intercalate ", " (fmap (TL.toStrict . snd) xs) type ScottyForm a = Form ActionM [Param] Text (Html ()) a reform :: (Monoid view) => ([(Text, Text)] -> view -> view) -- ^ wrap raw form html inside a