aboutsummaryrefslogtreecommitdiff
path: root/src/client/elm/LoggedIn/Monthly
diff options
context:
space:
mode:
authorJoris2016-03-28 17:51:14 +0200
committerJoris2016-03-28 17:51:14 +0200
commit166cd04e4b28770ede854dafc9ae30eae64102fe (patch)
tree2245a31243a165acc6f7355534da44cfd17e6038 /src/client/elm/LoggedIn/Monthly
parentb0d80a5458d7ba4546e5f01f5b6398ea6d23f981 (diff)
Create an empty but reachable user page
Diffstat (limited to 'src/client/elm/LoggedIn/Monthly')
-rw-r--r--src/client/elm/LoggedIn/Monthly/Action.elm10
-rw-r--r--src/client/elm/LoggedIn/Monthly/Model.elm17
-rw-r--r--src/client/elm/LoggedIn/Monthly/Update.elm21
-rw-r--r--src/client/elm/LoggedIn/Monthly/View.elm89
4 files changed, 0 insertions, 137 deletions
diff --git a/src/client/elm/LoggedIn/Monthly/Action.elm b/src/client/elm/LoggedIn/Monthly/Action.elm
deleted file mode 100644
index bf974f9..0000000
--- a/src/client/elm/LoggedIn/Monthly/Action.elm
+++ /dev/null
@@ -1,10 +0,0 @@
-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
deleted file mode 100644
index 16009d6..0000000
--- a/src/client/elm/LoggedIn/Monthly/Model.elm
+++ /dev/null
@@ -1,17 +0,0 @@
-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
deleted file mode 100644
index 62b40e6..0000000
--- a/src/client/elm/LoggedIn/Monthly/Update.elm
+++ /dev/null
@@ -1,21 +0,0 @@
-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
deleted file mode 100644
index f4ae2c9..0000000
--- a/src/client/elm/LoggedIn/Monthly/View.elm
+++ /dev/null
@@ -1,89 +0,0 @@
-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.View.Price exposing (price)
-import LoggedIn.View.Expand exposing (..)
-
-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 Action exposing (..)
-
-import View.Icon exposing (renderIcon)
-
-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" ]
- ]
- ]