yammat/Handler/Modify.hs

120 lines
4.4 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-10-22 23:57:27 +02:00
(modifyWidget, enctype) <- generateFormPost
$ renderBootstrap3 BootstrapBasicForm
$ 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-10-22 23:57:27 +02:00
((res, _), _) <- runFormPost
$ renderBootstrap3 BootstrapBasicForm
$ 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-10-11 20:07:12 +02:00
, BeverageSupplier =. modBevSupp nBev
, BeverageMaxAmount =. modBevMaxAmount nBev
, BeveragePerCrate =. modBevPC nBev
, BeverageArtNr =. modBevArtNr nBev
, BeveragePricePerCrate =. modBevPricePC 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
2015-10-11 20:07:12 +02:00
, modBevMaxAmount :: Int
2015-07-21 09:14:38 +02:00
, modBevMl :: Int
2015-10-11 20:07:12 +02:00
, modBevPC :: Maybe Int
, modBevPricePC :: Maybe Int
2015-07-21 09:14:38 +02:00
, modBevAvatar :: Maybe AvatarId
, modBevBarcodes :: Maybe [Text]
2015-10-11 20:07:12 +02:00
, modBevSupp :: Maybe SupplierId
, modBevArtNr :: Maybe Text
2015-07-21 09:14:38 +02:00
}
2015-10-22 23:57:27 +02:00
modifyForm :: Beverage -> [Text] -> AForm Handler ModBev
modifyForm bev bs = ModBev
<$> areq textField (bfs MsgName) (Just $ beverageIdent bev)
<*> areq currencyField (bfs MsgPrice) (Just $ beveragePrice bev)
<*> areq amountField (bfs MsgCurrentStock) (Just $ beverageAmount bev)
<*> areq amountField (bfs MsgAnnouncedStock) (Just $ beverageAlertAmount bev)
<*> areq amountField (bfs MsgMaxAmount) (Just $ beverageMaxAmount bev)
<*> areq volumeField (bfs MsgVolume) (Just $ beverageMl bev)
<*> aopt amountField (bfs MsgAmountPerCrate) (Just $ beveragePerCrate bev)
<*> aopt currencyField (bfs MsgPricePerCrate) (Just $ beveragePricePerCrate bev)
<*> aopt (selectField avatars) (bfs MsgSelectAvatar) (Just $ beverageAvatar bev)
<*> aopt barcodeField (bfs MsgBarcodeField) (Just $ Just bs)
<*> aopt (selectField sups) (bfs MsgSelectSupplier) (Just $ beverageSupplier bev)
<*> aopt textField (bfs MsgArtNr) (Just $ beverageArtNr bev)
<* bootstrapSubmit (msgToBSSubmit MsgSubmit)
2015-04-16 02:12:03 +02:00
where
2015-10-11 20:07:12 +02:00
avatars = optionsPersistKey [] [Asc AvatarIdent] avatarIdent
sups = optionsPersistKey [] [Asc SupplierIdent] supplierIdent
2015-04-04 06:46:33 +02:00
getDeleteBeverageR :: BeverageId -> Handler Html
getDeleteBeverageR bId = do
mBev <- runDB $ get bId
case mBev of
2016-01-21 22:06:14 +01:00
Just _ -> do
2015-04-04 06:46:33 +02:00
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