From 617d30c96792795ab8561a6262c4c5f4e023b6cf Mon Sep 17 00:00:00 2001 From: Joris Date: Sun, 27 Mar 2016 21:24:11 +0200 Subject: Regroup monthly modules --- src/client/elm/LoggedIn/Monthly/Action.elm | 10 ++++ src/client/elm/LoggedIn/Monthly/Model.elm | 17 ++++++ src/client/elm/LoggedIn/Monthly/Update.elm | 21 +++++++ src/client/elm/LoggedIn/Monthly/View.elm | 89 ++++++++++++++++++++++++++++++ 4 files changed, 137 insertions(+) create mode 100644 src/client/elm/LoggedIn/Monthly/Action.elm create mode 100644 src/client/elm/LoggedIn/Monthly/Model.elm create mode 100644 src/client/elm/LoggedIn/Monthly/Update.elm create mode 100644 src/client/elm/LoggedIn/Monthly/View.elm (limited to 'src/client/elm/LoggedIn/Monthly') diff --git a/src/client/elm/LoggedIn/Monthly/Action.elm b/src/client/elm/LoggedIn/Monthly/Action.elm new file mode 100644 index 0000000..bf974f9 --- /dev/null +++ b/src/client/elm/LoggedIn/Monthly/Action.elm @@ -0,0 +1,10 @@ +module LoggedIn.Monthly.Action + ( Action(..) + ) where + +import Model.Payment exposing (Payment) + +type Action = + ToggleDetail + | AddPayment Payment + | DeletePayment Payment diff --git a/src/client/elm/LoggedIn/Monthly/Model.elm b/src/client/elm/LoggedIn/Monthly/Model.elm new file mode 100644 index 0000000..16009d6 --- /dev/null +++ b/src/client/elm/LoggedIn/Monthly/Model.elm @@ -0,0 +1,17 @@ +module LoggedIn.Monthly.Model + ( Model + , init + ) where + +import Model.Payment exposing (Payments) + +type alias Model = + { payments : Payments + , visibleDetail : Bool + } + +init : Payments -> Model +init payments = + { payments = payments + , visibleDetail = False + } diff --git a/src/client/elm/LoggedIn/Monthly/Update.elm b/src/client/elm/LoggedIn/Monthly/Update.elm new file mode 100644 index 0000000..62b40e6 --- /dev/null +++ b/src/client/elm/LoggedIn/Monthly/Update.elm @@ -0,0 +1,21 @@ +module LoggedIn.Monthly.Update + ( update + ) where + +import LoggedIn.Monthly.Action as MonthlyAction +import LoggedIn.Monthly.Model as MonthlyModel + +update : MonthlyAction.Action -> MonthlyModel.Model -> MonthlyModel.Model +update action monthly = + case action of + MonthlyAction.ToggleDetail -> + { monthly | visibleDetail = not monthly.visibleDetail } + MonthlyAction.AddPayment payment -> + { monthly + | payments = payment :: monthly.payments + , visibleDetail = True + } + MonthlyAction.DeletePayment payment -> + { monthly + | payments = List.filter (((/=) payment.id) << .id) monthly.payments + } diff --git a/src/client/elm/LoggedIn/Monthly/View.elm b/src/client/elm/LoggedIn/Monthly/View.elm new file mode 100644 index 0000000..f9ea3bf --- /dev/null +++ b/src/client/elm/LoggedIn/Monthly/View.elm @@ -0,0 +1,89 @@ +module LoggedIn.Monthly.View + ( view + ) where + +import String +import Signal exposing (Address) + +import Html exposing (..) +import Html.Attributes exposing (..) +import Html.Events exposing (..) + +import LoggedIn.Action as LoggedInAction +import LoggedIn.Model as LoggedInModel + +import LoggedIn.Monthly.Action as MonthlyAction +import LoggedIn.Monthly.Model as MonthlyModel + +import Model exposing (Model) +import Model.Payment as Payment exposing (Payments, Payment) +import Model.Translations exposing (getMessage, getParamMessage) +import Model.Action exposing (..) + +import View.Icon exposing (renderIcon) +import View.Expand exposing (..) +import View.Price exposing (price) + +view : Address Action -> Model -> LoggedInModel.Model -> Html +view address model loggedInModel = + let monthly = loggedInModel.monthly + in if List.length monthly.payments == 0 + then + text "" + else + div + [ classList + [ ("monthlyPayments", True) + , ("detail", monthly.visibleDetail) + ] + ] + [ monthlyCount address model monthly + , if monthly.visibleDetail then paymentsTable address model loggedInModel monthly else text "" + ] + +monthlyCount : Address Action -> Model -> MonthlyModel.Model -> Html +monthlyCount address model monthly = + let count = List.length monthly.payments + total = List.sum << List.map .cost <| monthly.payments + key = if count > 1 then "PluralMonthlyCount" else "SingularMonthlyCount" + in button + [ class "header" + , onClick address (UpdateLoggedIn << LoggedInAction.UpdateMonthly <| MonthlyAction.ToggleDetail) + ] + [ text (getParamMessage [toString count, price model total] key model.translations) + , expand ExpandDown monthly.visibleDetail + ] + +paymentsTable : Address Action -> Model -> LoggedInModel.Model -> MonthlyModel.Model -> Html +paymentsTable address model loggedInModel monthly = + div + [ class "table" ] + ( monthly.payments + |> List.sortBy (String.toLower << .name) + |> List.map (paymentLine address model loggedInModel) + ) + +paymentLine : Address Action -> Model -> LoggedInModel.Model -> Payment -> Html +paymentLine address model loggedInModel payment = + a + [ classList + [ ("row", True) + , ("edition", loggedInModel.paymentEdition == Just payment.id) + ] + , onClick address (UpdateLoggedIn (LoggedInAction.ToggleEdit payment.id)) + ] + [ div [ class "cell category" ] [ text (payment.name) ] + , div + [ classList + [ ("cell cost", True) + , ("refund", payment.cost < 0) + ] + ] + [ text (price model payment.cost) ] + , div + [ class "cell delete" + , onClick address (UpdateLoggedIn <| LoggedInAction.DeletePayment payment Payment.Monthly) + ] + [ button [] [ renderIcon "times" ] + ] + ] -- cgit v1.2.3