aboutsummaryrefslogtreecommitdiff
path: root/src/client/Update/Payment.elm
diff options
context:
space:
mode:
authorJoris2015-09-04 23:13:48 +0200
committerJoris2015-09-04 23:13:48 +0200
commitc876fd8c2f1aac2c3fe10c2b7de734f3ef71b71f (patch)
tree23ff6a85ee81a0cc8419b7c1acbec0a33bd02fab /src/client/Update/Payment.elm
parentc1f44a5890fbb26faf6f17c676662ea1bd495f2e (diff)
Paging model works with both payments addition and deletion
Diffstat (limited to 'src/client/Update/Payment.elm')
-rw-r--r--src/client/Update/Payment.elm39
1 files changed, 16 insertions, 23 deletions
diff --git a/src/client/Update/Payment.elm b/src/client/Update/Payment.elm
index 798cdb4..b9b60dd 100644
--- a/src/client/Update/Payment.elm
+++ b/src/client/Update/Payment.elm
@@ -17,9 +17,9 @@ import Update.Payment.Add exposing (..)
type PaymentAction =
UpdateAdd AddPaymentAction
| UpdatePayments Payments
- | AddPayment PaymentId String Int
+ | AddPayment String Int Payments
| ToggleEdit PaymentId
- | Remove PaymentId
+ | Remove String Int Payments
| UpdatePage Int Payments
updatePayment : Model -> PaymentAction -> PaymentView -> PaymentView
@@ -29,29 +29,22 @@ updatePayment model action paymentView =
{ paymentView | add <- updateAddPayment addPaymentAction paymentView.add }
UpdatePayments payments ->
{ paymentView | payments <- payments }
- AddPayment id name cost ->
- let payment =
- { creation = Date.fromTime model.currentTime
- , name = name
- , cost = cost
- , userName = paymentView.userName
- }
- in { paymentView
- | payments <- addPayment paymentView.payments (id, payment)
- , add <- initAddPayment
- , payers <- updatePayers paymentView.payers payment.userName payment.cost
- }
+ AddPayment userName cost payments ->
+ { paymentView
+ | payments <- payments
+ , currentPage <- 1
+ , add <- initAddPayment
+ , payers <- updatePayers paymentView.payers userName cost
+ , paymentsCount <- paymentView.paymentsCount + 1
+ }
ToggleEdit id ->
{ paymentView | edition <- if paymentView.edition == Just id then Nothing else Just id }
- Remove id ->
- case Dict.get id paymentView.payments of
- Just payment ->
- { paymentView
- | payments <- removePayment paymentView.payments id
- , payers <- updatePayers paymentView.payers payment.userName -payment.cost
- }
- Nothing ->
- paymentView
+ Remove userName cost payments ->
+ { paymentView
+ | payments <- payments
+ , payers <- updatePayers paymentView.payers userName -cost
+ , paymentsCount <- paymentView.paymentsCount - 1
+ }
UpdatePage page payments ->
{ paymentView
| currentPage <- page