yammat/Handler/Modify.hs

86 lines
2.9 KiB
Haskell
Raw Normal View History

2015-04-04 06:46:33 +02:00
module Handler.Modify where
import Import
import Handler.Common
getModifyR :: BeverageId -> Handler Html
getModifyR bId = do
mBev <- runDB $ get bId
case mBev of
Just bev -> do
2015-07-21 09:14:38 +02:00
p <- lookupGetParam "barcode"
_ <- handleGetParam p (Right bId)
rawbs <- runDB $ selectList [BarcodeBev ==. Just bId] []
bs <- return $ map (barcodeCode . entityVal) rawbs
(modifyWidget, enctype) <- generateFormPost $ modifyForm bev bs
2015-04-04 06:46:33 +02:00
defaultLayout $ do
$(widgetFile "modify")
Nothing -> do
2015-04-10 00:40:58 +02:00
setMessageI MsgItemUnknown
2015-04-04 06:46:33 +02:00
redirect $ SummaryR
postModifyR :: BeverageId -> Handler Html
postModifyR bId = do
mBev <- runDB $ get bId
case mBev of
Just bev -> do
2015-07-21 09:14:38 +02:00
rawbs <- runDB $ selectList [BarcodeBev ==. Just bId] []
bs <- return $ map (barcodeCode . entityVal) rawbs
((res, _), _) <- runFormPost $ modifyForm bev bs
2015-04-04 06:46:33 +02:00
case res of
FormSuccess nBev -> do
runDB $ update bId
2015-07-21 09:14:38 +02:00
[ BeverageIdent =. modBevIdent nBev
, BeveragePrice =. modBevPrice nBev
, BeverageAmount =. modBevAmount nBev
, BeverageAlertAmount =. modBevAlertAmount nBev
, BeverageCorrectedAmount +=. ((modBevAmount nBev) - (beverageAmount bev))
, BeverageMl =. modBevMl nBev
, BeverageAvatar =. modBevAvatar nBev
2015-04-04 06:46:33 +02:00
]
2015-07-21 10:00:19 +02:00
handleBarcodes (Right bId) (fromMaybe [] $ modBevBarcodes nBev)
2015-04-10 00:40:58 +02:00
setMessageI MsgEditSuccess
2015-04-04 06:46:33 +02:00
redirect $ SummaryR
_ -> do
2015-04-10 00:40:58 +02:00
setMessageI MsgEditFail
2015-04-04 06:46:33 +02:00
redirect $ SummaryR
Nothing -> do
2015-04-10 00:40:58 +02:00
setMessageI MsgItemUnknown
2015-04-04 06:46:33 +02:00
redirect $ SummaryR
2015-07-21 09:14:38 +02:00
data ModBev = ModBev
{ modBevIdent :: Text
, modBevPrice :: Int
, modBevAmount :: Int
, modBevAlertAmount :: Int
, modBevMl :: Int
, modBevAvatar :: Maybe AvatarId
, modBevBarcodes :: Maybe [Text]
}
modifyForm :: Beverage -> [Text] -> Form ModBev
modifyForm bev bs = renderDivs $ ModBev
2015-04-10 00:40:58 +02:00
<$> areq textField (fieldSettingsLabel MsgName) (Just $ beverageIdent bev)
<*> areq currencyField (fieldSettingsLabel MsgPrice) (Just $ beveragePrice bev)
<*> areq amountField (fieldSettingsLabel MsgCurrentStock) (Just $ beverageAmount bev)
<*> areq amountField (fieldSettingsLabel MsgAnnouncedStock) (Just $ beverageAlertAmount bev)
2015-05-03 18:01:30 +02:00
<*> areq volumeField (fieldSettingsLabel MsgVolume) (Just $ beverageMl bev)
2015-04-16 02:12:03 +02:00
<*> aopt (selectField avatars) (fieldSettingsLabel MsgSelectAvatar) (Just $ beverageAvatar bev)
2015-07-21 09:14:38 +02:00
<*> aopt barcodeField (fieldSettingsLabel MsgBarcodeField) (Just $ Just bs)
2015-04-16 02:12:03 +02:00
where
avatars = do
ents <- runDB $ selectList [] [Asc AvatarIdent]
optionsPairs $ map (\ent -> ((avatarIdent $ entityVal ent), entityKey ent)) ents
2015-04-04 06:46:33 +02:00
getDeleteBeverageR :: BeverageId -> Handler Html
getDeleteBeverageR bId = do
mBev <- runDB $ get bId
case mBev of
Just bev -> do
runDB $ delete bId
2015-04-10 00:40:58 +02:00
setMessageI MsgItemDeleted
2015-04-04 06:46:33 +02:00
redirect $ HomeR
Nothing -> do
2015-04-10 00:40:58 +02:00
setMessageI MsgItemUnknown
2015-04-04 06:46:33 +02:00
redirect $ HomeR