aboutsummaryrefslogtreecommitdiff
path: root/src/client/View/Page.elm
blob: 73afed977e7d216e5e0cb2f6758fcc7eb4c5f370 (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
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
module View.Page
  ( renderPage
  ) where

import Html exposing (..)
import Html as H
import Html.Attributes exposing (..)
import Html.Attributes as A
import Html.Events exposing (..)

import Date
import Date exposing (Date)

import String exposing (append)

import Model exposing (Model)
import Model.Payment exposing (Payments, Payment)

renderPage : Model -> Html
renderPage model =
  header
    []
    [ h1
        []
        [ text "Payments" ]
    , table
        []
        ([ tr
            []
            [ th [] [ text "Utilisateur" ]
            , th [] [ text "Nom" ]
            , th [] [ text "Prix" ]
            , th [] [ text "Date" ]
            ]
        ] ++ (List.map renderPayment model.payments))
    ]

renderPayments : Payments -> List Html
renderPayments =
  List.map renderPayment
    << List.reverse
    << List.sortBy (Date.toTime << .creation)

renderPayment : Payment -> Html
renderPayment payment =
  tr
    []
    [ td [] [ text payment.name ]
    , td [] [ text payment.userName ]
    , td [] [ text (toString payment.cost) ]
    , td [] [ text (renderDate payment.creation) ]
    ]

renderDate : Date -> String
renderDate date =
  toString (Date.day date)
    |> flip append (" " ++ (toString (Date.month date)))
    |> flip append (" " ++ (toString (Date.year date)))