yammat/Handler/Modify.hs

101 lines
3.7 KiB
Haskell
Raw Normal View History

2015-08-09 21:16:33 +02:00
-- yammat - Yet Another MateMAT
-- Copyright (C) 2015 Amedeo Molnár
--
-- This program is free software: you can redistribute it and/or modify
-- it under the terms of the GNU Affero General Public License as published
-- by the Free Software Foundation, either version 3 of the License, or
-- (at your option) any later version.
--
-- This program is distributed in the hope that it will be useful,
-- but WITHOUT ANY WARRANTY; without even the implied warranty of
-- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
-- GNU Affero General Public License for more details.
--
-- You should have received a copy of the GNU Affero General Public License
-- along with this program. If not, see <http://www.gnu.org/licenses/>.
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] []
2015-09-15 00:49:13 +02:00
let bs = map (barcodeCode . entityVal) rawbs
2015-07-21 09:14:38 +02:00
(modifyWidget, enctype) <- generateFormPost $ modifyForm bev bs
2015-09-15 00:49:13 +02:00
defaultLayout $
2015-04-04 06:46:33 +02:00
$(widgetFile "modify")
Nothing -> do
2015-04-10 00:40:58 +02:00
setMessageI MsgItemUnknown
2015-09-15 00:49:13 +02:00
redirect SummaryR
2015-04-04 06:46:33 +02:00
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] []
2015-09-15 00:49:13 +02:00
let bs = map (barcodeCode . entityVal) rawbs
2015-07-21 09:14:38 +02:00
((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
2015-09-15 00:49:13 +02:00
, BeverageCorrectedAmount +=. (modBevAmount nBev - beverageAmount bev)
2015-07-21 09:14:38 +02:00
, 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-09-15 00:49:13 +02:00
redirect SummaryR
2015-04-04 06:46:33 +02:00
_ -> do
2015-04-10 00:40:58 +02:00
setMessageI MsgEditFail
2015-09-15 00:49:13 +02:00
redirect SummaryR
2015-04-04 06:46:33 +02:00
Nothing -> do
2015-04-10 00:40:58 +02:00
setMessageI MsgItemUnknown
2015-09-15 00:49:13 +02:00
redirect SummaryR
2015-04-04 06:46:33 +02:00
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]
2015-09-15 00:49:13 +02:00
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-09-15 00:49:13 +02:00
redirect HomeR
2015-04-04 06:46:33 +02:00
Nothing -> do
2015-04-10 00:40:58 +02:00
setMessageI MsgItemUnknown
2015-09-15 00:49:13 +02:00
redirect HomeR