2012-12-02 21:32:54 +00:00
|
|
|
{- git-annex assistant webapp form utilities
|
|
|
|
-
|
|
|
|
- Copyright 2012 Joey Hess <joey@kitenet.net>
|
|
|
|
-
|
|
|
|
- Licensed under the GNU AGPL version 3 or higher.
|
|
|
|
-}
|
|
|
|
|
|
|
|
{-# LANGUAGE FlexibleContexts, TypeFamilies, QuasiQuotes, MultiParamTypeClasses, TemplateHaskell, OverloadedStrings, RankNTypes #-}
|
|
|
|
|
|
|
|
module Assistant.WebApp.Form where
|
|
|
|
|
2012-12-04 17:28:22 +00:00
|
|
|
import Types.Remote (RemoteConfigKey)
|
|
|
|
|
2012-12-02 21:32:54 +00:00
|
|
|
import Yesod hiding (textField, passwordField)
|
|
|
|
import Yesod.Form.Fields as F
|
|
|
|
import Data.Text (Text)
|
|
|
|
|
|
|
|
{- Yesod's textField sets the required attribute for required fields.
|
|
|
|
- We don't want this, because many of the forms used in this webapp
|
|
|
|
- display a modal dialog when submitted, which interacts badly with
|
|
|
|
- required field handling by the browser.
|
|
|
|
-
|
|
|
|
- Required fields are still checked by Yesod.
|
|
|
|
-}
|
|
|
|
textField :: RenderMessage master FormMessage => Field sub master Text
|
|
|
|
textField = F.textField
|
|
|
|
{ fieldView = \theId name attrs val _isReq -> [whamlet|
|
|
|
|
<input id="#{theId}" name="#{name}" *{attrs} type="text" value="#{either id id val}">
|
|
|
|
|]
|
|
|
|
}
|
|
|
|
|
2012-12-03 02:33:30 +00:00
|
|
|
{- Also without required attribute. -}
|
2012-12-02 21:32:54 +00:00
|
|
|
passwordField :: RenderMessage master FormMessage => Field sub master Text
|
|
|
|
passwordField = F.passwordField
|
|
|
|
{ fieldView = \theId name attrs val _isReq -> toWidget [hamlet|
|
|
|
|
<input id="#{theId}" name="#{name}" *{attrs} type="password" value="#{either id id val}">
|
|
|
|
|]
|
|
|
|
}
|
2012-12-03 02:33:30 +00:00
|
|
|
|
|
|
|
{- Makes a note widget be displayed after a field. -}
|
2012-12-03 03:10:11 +00:00
|
|
|
withNote :: Field sub master v -> GWidget sub master () -> Field sub master v
|
2012-12-03 02:33:30 +00:00
|
|
|
withNote field note = field { fieldView = newview }
|
|
|
|
where
|
|
|
|
newview theId name attrs val isReq =
|
|
|
|
let fieldwidget = (fieldView field) theId name attrs val isReq
|
|
|
|
in [whamlet|^{fieldwidget} <span>^{note}</span>|]
|
2012-12-04 17:28:22 +00:00
|
|
|
|
|
|
|
|
2012-12-06 21:09:08 +00:00
|
|
|
{- Makes a help button be displayed after a field, that displays a help
|
|
|
|
- widget when clicked. Requires a unique ident for the help. -}
|
|
|
|
withHelp :: Field sub master v -> GWidget sub master () -> Text -> Field sub master v
|
|
|
|
withHelp field help ident = withNote field note
|
|
|
|
where
|
|
|
|
note = [whamlet|
|
|
|
|
<a .btn data-toggle="collapse" data-target="##{ident}">
|
|
|
|
Help
|
|
|
|
<div ##{ident} .collapse>
|
|
|
|
^{help}
|
|
|
|
|]
|
|
|
|
|
2012-12-04 17:28:22 +00:00
|
|
|
data EnableEncryption = SharedEncryption | NoEncryption
|
|
|
|
deriving (Eq)
|
|
|
|
|
|
|
|
{- Adds a check box to an AForm to control encryption. -}
|
|
|
|
enableEncryptionField :: RenderMessage master FormMessage => AForm sub master EnableEncryption
|
|
|
|
enableEncryptionField = areq (selectFieldList choices) "Encryption" (Just SharedEncryption)
|
|
|
|
where
|
|
|
|
choices :: [(Text, EnableEncryption)]
|
|
|
|
choices =
|
|
|
|
[ ("Encrypt all data", SharedEncryption)
|
|
|
|
, ("Disable encryption", NoEncryption)
|
|
|
|
]
|
|
|
|
|
|
|
|
{- Generates Remote configuration for encryption. -}
|
|
|
|
configureEncryption :: EnableEncryption -> (RemoteConfigKey, String)
|
|
|
|
configureEncryption SharedEncryption = ("encryption", "shared")
|
|
|
|
configureEncryption NoEncryption = ("encryption", "none")
|