{- This file is part of Vervis. - - Written in 2016 by fr33domlover . - - ♡ Copying is an act of love. Please copy, reuse and share. - - The author(s) have dedicated all copyright and related and neighboring - rights to this software to the public domain worldwide. This software is - distributed without any warranty. - - You should have received a copy of the CC0 Public Domain Dedication along - with this software. If not, see - . -} module Vervis.Form.Ticket ( newTicketForm ) where import Prelude import Control.Monad.IO.Class (liftIO) import Control.Monad.Trans.Class (lift) import Data.Time.Clock (getCurrentTime) import Yesod.Form import Vervis.Foundation (Form, Handler) import Vervis.Model --TODO use custom fields to ensure uniqueness or other constraints? --TODO stuff like number and created - do I generate them here using monadic -- form or do I rely on handler to provide? which approach is better? newTicketAForm :: ProjectId -> Int -> PersonId -> AForm Handler Ticket newTicketAForm pid number author = Ticket <$> pure pid <*> pure number <*> lift (liftIO getCurrentTime) <*> pure author <*> areq textField "Title*" Nothing <*> (maybe "" unTextarea <$> aopt textareaField "Description (Markdown)" Nothing) <*> pure False newTicketForm :: ProjectId -> Int -> PersonId -> Form Ticket newTicketForm pid number author = renderDivs $ newTicketAForm pid number author