From 36dc2b0d5b3dba1674c91abf40e35a6afe19b42d Mon Sep 17 00:00:00 2001 From: Stanislav Smirnov Date: Mon, 19 Aug 2024 02:55:29 +0300 Subject: [PATCH 1/3] Create checkboxesField' - correct version of checkboxesField --- yesod-form/ChangeLog.md | 4 ++++ yesod-form/Yesod/Form/Fields.hs | 22 ++++++++++++++++++++++ yesod-form/yesod-form.cabal | 2 +- 3 files changed, 27 insertions(+), 1 deletion(-) diff --git a/yesod-form/ChangeLog.md b/yesod-form/ChangeLog.md index 3bd798ef6..f04e94f78 100644 --- a/yesod-form/ChangeLog.md +++ b/yesod-form/ChangeLog.md @@ -1,5 +1,9 @@ # ChangeLog for yesod-form +## 1.7.9 + +* Added `checkboxesField'` for creating checkbox in more correct wat than original `checkboxesField` + Function `checkboxesField` marked as deprecated. [#1843](https://github.com/yesodweb/yesod/pull/1843) ## 1.7.8 diff --git a/yesod-form/Yesod/Form/Fields.hs b/yesod-form/Yesod/Form/Fields.hs index ab8583313..c08008af6 100644 --- a/yesod-form/Yesod/Form/Fields.hs +++ b/yesod-form/Yesod/Form/Fields.hs @@ -52,6 +52,7 @@ module Yesod.Form.Fields , radioFieldList , withRadioField , checkboxesField + , checkboxesField' , checkboxesFieldList , multiSelectField , multiSelectFieldList @@ -125,6 +126,7 @@ import Data.Monoid import Data.Char (isHexDigit) {-# DEPRECATED radioField "This function seems to have a bug (label could not be found with byLabel algorithm)" #-} +{-# DEPRECATED checkboxesField "This function seems to have a bug (label could not be found with byLabel algorithm)" #-} defaultFormMessage :: FormMessage -> Text defaultFormMessage = englishFormMessage @@ -533,6 +535,26 @@ checkboxesField ioptlist = (multiSelectField ioptlist) |] } +-- | Creates an input with @type="checkbox"@ for selecting multiple options. +checkboxesField' :: Eq a + => HandlerFor site (OptionList a) + -> Field (HandlerFor site) [a] +checkboxesField' ioptlist = (multiSelectField ioptlist) + { fieldView = + \theId name attrs val _isReq -> do + opts <- olOptions <$> handlerToWidget ioptlist + let optselected (Left _) _ = False + optselected (Right vals) opt = optionInternalValue opt `elem` vals + [whamlet| + + $forall opt <- opts + +