diff options
author | Joris | 2015-09-06 12:39:03 +0200 |
---|---|---|
committer | Joris | 2015-09-06 12:39:03 +0200 |
commit | e10531ba4e60c8709088798763ae3bae6608f9c9 (patch) | |
tree | f1550fab8833f0b31831ebb2e943a51eeaa41ee2 /src/client/Update/LoggedView.elm | |
parent | 24633871359ec9fbd63fdfebf79a6351b2792f77 (diff) |
Show montly payments with an expandable mechanism
Diffstat (limited to 'src/client/Update/LoggedView.elm')
-rw-r--r-- | src/client/Update/LoggedView.elm | 64 |
1 files changed, 64 insertions, 0 deletions
diff --git a/src/client/Update/LoggedView.elm b/src/client/Update/LoggedView.elm new file mode 100644 index 0000000..4a53ac4 --- /dev/null +++ b/src/client/Update/LoggedView.elm @@ -0,0 +1,64 @@ +module Update.LoggedView + ( LoggedAction(..) + , updateLoggedView + ) where + +import Date +import Dict + +import Model exposing (Model) +import Model.User exposing (UserId) +import Model.Payment exposing (..) +import Model.Payers exposing (..) +import Model.View.LoggedView exposing (..) +import Model.View.Payment.Add exposing (..) + +import Update.LoggedView.Add exposing (..) +import Update.LoggedView.Monthly exposing (..) + +type LoggedAction = + UpdateAdd AddPaymentAction + | UpdatePayments Payments + | AddPayment UserId PaymentId String Int Frequency Payments + | ToggleEdit PaymentId + | Remove UserId Int Payments + | UpdatePage Int Payments + | UpdateMonthly MonthlyAction + +updateLoggedView : Model -> LoggedAction -> LoggedView -> LoggedView +updateLoggedView model action loggedView = + case action of + UpdateAdd addPaymentAction -> + { loggedView | add <- updateAddPayment addPaymentAction loggedView.add } + UpdatePayments payments -> + { loggedView | payments <- payments } + AddPayment userId paymentId name cost frequency payments -> + { loggedView + | payments <- payments + , currentPage <- 1 + , add <- initAddPayment loggedView.add.frequency + , payers <- updatePayers loggedView.payers userId cost + , paymentsCount <- loggedView.paymentsCount + 1 + , monthly <- + if frequency == Monthly + then + let payment = Payment paymentId (Date.fromTime model.currentTime) name cost userId + in updateMonthly (AddMonthlyPayment payment) loggedView.monthly + else + loggedView.monthly + } + ToggleEdit id -> + { loggedView | paymentEdition <- if loggedView.paymentEdition == Just id then Nothing else Just id } + Remove userId cost payments -> + { loggedView + | payments <- payments + , payers <- updatePayers loggedView.payers userId -cost + , paymentsCount <- loggedView.paymentsCount - 1 + } + UpdatePage page payments -> + { loggedView + | currentPage <- page + , payments <- payments + } + UpdateMonthly monthlyAction -> + { loggedView | monthly <- updateMonthly monthlyAction loggedView.monthly } |