Allow to create and set ticket params of enum type, fixes #111

This commit is contained in:
fr33domlover 2020-01-04 10:49:44 +00:00
parent 64cf836b47
commit b78a0fa116
3 changed files with 43 additions and 27 deletions

View file

@ -1,6 +1,6 @@
{- This file is part of Vervis. {- This file is part of Vervis.
- -
- Written in 2016, 2019 by fr33domlover <fr33domlover@riseup.net>. - Written in 2016, 2019, 2020 by fr33domlover <fr33domlover@riseup.net>.
- -
- Copying is an act of love. Please copy, reuse and share. - Copying is an act of love. Please copy, reuse and share.
- -
@ -26,6 +26,7 @@ module Vervis.Form.Workflow
where where
import Data.Text (Text) import Data.Text (Text)
import Database.Persist
import Yesod.Form.Fields import Yesod.Form.Fields
import Yesod.Form.Functions import Yesod.Form.Functions
import Yesod.Form.Types import Yesod.Form.Types
@ -58,6 +59,7 @@ data NewField = NewField
, nfName :: Text , nfName :: Text
, nfDesc :: Maybe Text , nfDesc :: Maybe Text
, nfType :: WorkflowFieldType , nfType :: WorkflowFieldType
, nfEnum :: Maybe WorkflowFieldEnumId
, nfReq :: Bool , nfReq :: Bool
, nfConst :: Bool , nfConst :: Bool
, nfNew :: Bool , nfNew :: Bool
@ -71,11 +73,18 @@ newFieldAForm wid = NewField
<*> areq textField "Name*" Nothing <*> areq textField "Name*" Nothing
<*> aopt textField "Description" Nothing <*> aopt textField "Description" Nothing
<*> areq (selectField optionsEnum) "Type*" Nothing <*> areq (selectField optionsEnum) "Type*" Nothing
<*> aopt (selectField selectEnum) "Enum*" (Just Nothing)
<*> areq checkBoxField "Required*" Nothing <*> areq checkBoxField "Required*" Nothing
<*> areq checkBoxField "Constant*" Nothing <*> areq checkBoxField "Constant*" Nothing
<*> areq checkBoxField "Applies to New*" (Just True) <*> areq checkBoxField "Applies to New*" (Just True)
<*> areq checkBoxField "Applies to Todo*" (Just True) <*> areq checkBoxField "Applies to Todo*" (Just True)
<*> areq checkBoxField "Applies to Closed*" (Just True) <*> areq checkBoxField "Applies to Closed*" (Just True)
where
selectEnum =
optionsPersistKey
[WorkflowFieldEnumWorkflow ==. wid]
[Asc WorkflowFieldEnumName]
workflowFieldEnumName
newFieldForm :: WorkflowId -> Form NewField newFieldForm :: WorkflowId -> Form NewField
newFieldForm wid = renderDivs $ newFieldAForm wid newFieldForm wid = renderDivs $ newFieldAForm wid

View file

@ -1,6 +1,6 @@
{- This file is part of Vervis. {- This file is part of Vervis.
- -
- Written in 2016, 2018, 2019 by fr33domlover <fr33domlover@riseup.net>. - Written in 2016, 2018, 2019, 2020 by fr33domlover <fr33domlover@riseup.net>.
- -
- Copying is an act of love. Please copy, reuse and share. - Copying is an act of love. Please copy, reuse and share.
- -

View file

@ -1,6 +1,6 @@
{- This file is part of Vervis. {- This file is part of Vervis.
- -
- Written in 2016, 2018 by fr33domlover <fr33domlover@riseup.net>. - Written in 2016, 2018, 2020 by fr33domlover <fr33domlover@riseup.net>.
- -
- Copying is an act of love. Please copy, reuse and share. - Copying is an act of love. Please copy, reuse and share.
- -
@ -45,7 +45,7 @@ module Vervis.Handler.Workflow
) )
where where
import Data.Maybe (fromMaybe) import Data.Maybe
import Data.Text (Text) import Data.Text (Text)
import Database.Persist import Database.Persist
import Network.HTTP.Types (StdMethod (DELETE, PUT)) import Network.HTTP.Types (StdMethod (DELETE, PUT))
@ -144,15 +144,18 @@ postWorkflowFieldsR shr wfl = do
Entity wid _ <- getBy404 $ UniqueWorkflow sid wfl Entity wid _ <- getBy404 $ UniqueWorkflow sid wfl
return wid return wid
((result, widget), enctype) <- runFormPost $ newFieldForm wid ((result, widget), enctype) <- runFormPost $ newFieldForm wid
identOrMsg <-
case result of case result of
FormSuccess nf -> do FormSuccess nf ->
if (nfType nf == WFTEnum) == isJust (nfEnum nf)
then do
let field = WorkflowField let field = WorkflowField
{ workflowFieldWorkflow = wid { workflowFieldWorkflow = wid
, workflowFieldIdent = nfIdent nf , workflowFieldIdent = nfIdent nf
, workflowFieldName = nfName nf , workflowFieldName = nfName nf
, workflowFieldDesc = nfDesc nf , workflowFieldDesc = nfDesc nf
, workflowFieldType = nfType nf , workflowFieldType = nfType nf
, workflowFieldEnm = Nothing , workflowFieldEnm = nfEnum nf
, workflowFieldRequired = nfReq nf , workflowFieldRequired = nfReq nf
, workflowFieldConstant = nfConst nf , workflowFieldConstant = nfConst nf
, workflowFieldFilterNew = nfNew nf , workflowFieldFilterNew = nfNew nf
@ -160,14 +163,18 @@ postWorkflowFieldsR shr wfl = do
, workflowFieldFilterClosed = nfClosed nf , workflowFieldFilterClosed = nfClosed nf
} }
runDB $ insert_ field runDB $ insert_ field
return $ Right $ nfIdent nf
else return $ Left "Type/Enum mismatch"
FormMissing -> return $ Left "Field(s) missing"
FormFailure _l ->
return $ Left "Workflow field creation failed, see below"
case identOrMsg of
Left msg -> do
setMessage msg
defaultLayout $(widgetFile "workflow/field/new")
Right fld -> do
setMessage "Workflow field added." setMessage "Workflow field added."
redirect $ WorkflowFieldR shr wfl (nfIdent nf) redirect $ WorkflowFieldR shr wfl fld
FormMissing -> do
setMessage "Field(s) missing"
defaultLayout $(widgetFile "workflow/field/new")
FormFailure _l -> do
setMessage "Workflow field creation failed, see below"
defaultLayout $(widgetFile "workflow/field/new")
getWorkflowFieldNewR :: ShrIdent -> WflIdent -> Handler Html getWorkflowFieldNewR :: ShrIdent -> WflIdent -> Handler Html
getWorkflowFieldNewR shr wfl = do getWorkflowFieldNewR shr wfl = do