module Text.Digestive.Field
( Field (..)
, SomeField (..)
, evalField
, fieldMapView
) where
import Control.Arrow (second)
import Data.Maybe (fromMaybe, listToMaybe)
import Data.Text (Text)
import qualified Data.Text as T
import Text.Digestive.Types
import Text.Digestive.Util
data Field v a where
Singleton :: a -> Field v a
Text :: Text -> Field v Text
Choice :: [(a, v)] -> Int -> Field v (a, Int)
Bool :: Bool -> Field v Bool
File :: Field v (Maybe FilePath)
instance Show (Field v a) where
show (Singleton _) = "Singleton _"
show (Text t) = "Text " ++ show t
show (Choice _ _) = "Choice _ _"
show (Bool b) = "Bool " ++ show b
show (File) = "File"
data SomeField v = forall a. SomeField (Field v a)
evalField :: Method
-> [FormInput]
-> Field v a
-> a
evalField _ _ (Singleton x) = x
evalField _ (TextInput x : _) (Text _) = x
evalField _ _ (Text x) = x
evalField _ (TextInput x : _) (Choice ls y) =
fromMaybe (fst (ls !! y), y) $ do
t <- listToMaybe $ reverse $ toPath x
i <- readMaybe $ T.unpack t
return $ (fst (ls !! i), i)
evalField _ _ (Choice ls x) = (fst (ls !! x), x)
evalField Get _ (Bool x) = x
evalField Post (TextInput x : _) (Bool _) = x == "on"
evalField Post _ (Bool _) = False
evalField Post (FileInput x : _) File = Just x
evalField _ _ File = Nothing
fieldMapView :: (v -> w) -> Field v a -> Field w a
fieldMapView _ (Singleton x) = Singleton x
fieldMapView _ (Text x) = Text x
fieldMapView f (Choice xs i) = Choice (map (second f) xs) i
fieldMapView _ (Bool x) = Bool x
fieldMapView _ File = File