aboutsummaryrefslogtreecommitdiff
path: root/src/client/elm/LoggedIn/Stat
diff options
context:
space:
mode:
Diffstat (limited to 'src/client/elm/LoggedIn/Stat')
-rw-r--r--src/client/elm/LoggedIn/Stat/Account/View.elm38
-rw-r--r--src/client/elm/LoggedIn/Stat/View.elm13
2 files changed, 44 insertions, 7 deletions
diff --git a/src/client/elm/LoggedIn/Stat/Account/View.elm b/src/client/elm/LoggedIn/Stat/Account/View.elm
new file mode 100644
index 0000000..3eb5ef4
--- /dev/null
+++ b/src/client/elm/LoggedIn/Stat/Account/View.elm
@@ -0,0 +1,38 @@
+module LoggedIn.Stat.Account.View exposing
+ ( view
+ )
+
+import Html exposing (..)
+import Html.Attributes exposing (..)
+
+import Msg exposing (Msg)
+
+import LoggedData exposing (LoggedData)
+
+import LoggedIn.View.Format as Format
+
+import Model exposing (Model)
+import Model.User exposing (getUserName)
+import Model.Payer exposing (..)
+
+view : LoggedData -> Html Msg
+view loggedData =
+ ul
+ [ class "exceedingPayers" ]
+ (List.map (exceedingPayer loggedData) (getOrderedExceedingPayers loggedData.currentTime loggedData.users loggedData.incomes loggedData.payments))
+
+exceedingPayer : LoggedData -> ExceedingPayer -> Html Msg
+exceedingPayer loggedData payer =
+ li
+ []
+ [ span
+ [ class "userName" ]
+ [ payer.userId
+ |> getUserName loggedData.users
+ |> Maybe.withDefault "−"
+ |> text
+ ]
+ , span
+ [ class "amount" ]
+ [ text ("+ " ++ (Format.price loggedData.conf payer.amount)) ]
+ ]
diff --git a/src/client/elm/LoggedIn/Stat/View.elm b/src/client/elm/LoggedIn/Stat/View.elm
index bb1ec84..f99ef0e 100644
--- a/src/client/elm/LoggedIn/Stat/View.elm
+++ b/src/client/elm/LoggedIn/Stat/View.elm
@@ -19,9 +19,9 @@ import Model.Translations exposing (getMessage, getParamMessage)
import LoggedIn.View.Format as Format
import LoggedIn.View.Date as Date
-
import View.Plural exposing (plural)
-import LoggedIn.View.Format as Format
+
+import LoggedIn.Stat.Account.View as AccountView
import Utils.Tuple as Tuple
import Utils.List as List
@@ -30,7 +30,9 @@ view : LoggedData -> Html Msg
view loggedData =
div
[ class "stat" ]
- [ h1 [] [ text (getMessage "Overall" loggedData.translations) ]
+ [ h1 [] [ text (getMessage "Balance" loggedData.translations) ]
+ , AccountView.view loggedData
+ , h1 [] [ text (getMessage "Overall" loggedData.translations) ]
, paymentsDetail loggedData (Payment.punctual loggedData.payments)
, h1 [] [ text (getMessage "ByMonths" loggedData.translations) ]
, monthsDetail loggedData
@@ -42,10 +44,7 @@ paymentsDetail loggedData payments =
[]
[ li
[]
- [ let single = getMessage "Payment" loggedData.translations
- multiple = getMessage "Payments" loggedData.translations
- in text <| plural (List.length payments) single multiple
- ]
+ [ text <| plural loggedData.translations (List.length payments) "Payment" "Payments" ]
, li
[]
[ text (paymentsSum loggedData.conf payments)