aboutsummaryrefslogtreecommitdiff
path: root/src/client/Update/Payment/Add.elm
blob: 27f2af08e6bbd5fff90185afb85e86abc9129a81 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
module Update.Payment.Add
  ( AddPaymentAction(..)
  , updateAddPayment
  ) where

import Model.View.Payment.Add exposing (..)

type AddPaymentAction =
  UpdateName String
  | UpdateCost String
  | AddError (Maybe String) (Maybe String)
  | ToggleFrequency

updateAddPayment : AddPaymentAction -> AddPayment -> AddPayment
updateAddPayment action addPayment =
  case action of
    UpdateName name ->
      { addPayment | name <- name }
    UpdateCost cost ->
      { addPayment | cost <- cost }
    AddError nameError costError ->
      { addPayment
      | nameError <- nameError
      , costError <- costError
      }
    ToggleFrequency ->
      { addPayment
      | frequency <- if addPayment.frequency == Punctual then Monthly else Punctual
      }