diff options
| author | Joris Guyonvarch | 2015-07-20 21:55:52 +0200 | 
|---|---|---|
| committer | Joris Guyonvarch | 2015-07-20 21:55:52 +0200 | 
| commit | a271d6034bc4cc631a64476d25d21c83a701fa39 (patch) | |
| tree | 89ffa3df69999c5c9ed3cda9f4e4ec04f7a6ae1d /src/client/View/Payments | |
| parent | a40c4825996c90d107901b0d71162f9356f1395a (diff) | |
Add a payment from the UI, it needs polishing however
Diffstat (limited to 'src/client/View/Payments')
| -rw-r--r-- | src/client/View/Payments/Add.elm | 34 | ||||
| -rw-r--r-- | src/client/View/Payments/Table.elm | 51 | 
2 files changed, 85 insertions, 0 deletions
| diff --git a/src/client/View/Payments/Add.elm b/src/client/View/Payments/Add.elm new file mode 100644 index 0000000..f2230be --- /dev/null +++ b/src/client/View/Payments/Add.elm @@ -0,0 +1,34 @@ +module View.Payments.Add +  ( addPayment +  ) where + +import Html exposing (..) +import Html.Attributes exposing (..) +import Html.Events exposing (..) + +import ServerCommunication as SC +import ServerCommunication exposing (serverCommunications) + +import Update exposing (..) +import Update.Payment exposing (..) + +addPayment : String -> String -> Html +addPayment name cost = +  div +    [ class "add" ] +    [ text "Name" +    , input +        [ value name +        , on "input" targetValue (Signal.message actions.address << UpdatePayment << UpdateName) +        ] +        [] +    , text "Cost" +    , input +        [ value cost +        , on "input" targetValue (Signal.message actions.address << UpdatePayment << UpdateCost) +        ] +        [] +    , button +        [ onClick serverCommunications.address (SC.AddPayment name cost) ] +        [ text "Add" ] +    ] diff --git a/src/client/View/Payments/Table.elm b/src/client/View/Payments/Table.elm new file mode 100644 index 0000000..34dc058 --- /dev/null +++ b/src/client/View/Payments/Table.elm @@ -0,0 +1,51 @@ +module View.Payments.Table +  ( paymentsTable +  ) where + +import Html exposing (..) +import Html.Attributes exposing (..) + +import Date +import Date exposing (Date) + +import String exposing (append) + +import Model.Payment exposing (Payments, Payment) + +import View.Icon exposing (renderIcon) + +paymentsTable : Payments -> Html +paymentsTable payments = +  table +    [] +    ([ tr +        [] +        [ th [] [ renderIcon "user" ] +        , th [] [ renderIcon "shopping-cart" ] +        , th [] [ renderIcon "euro" ] +        , th [] [ renderIcon "calendar" ] +        ] +    ] ++ (paymentLines payments)) + +paymentLines : Payments -> List Html +paymentLines payments = +  payments +    |> List.sortBy (Date.toTime << .creation) +    |> List.reverse +    |> List.map paymentLine + +paymentLine : Payment -> Html +paymentLine payment = +  tr +    [] +    [ td [] [ text payment.userName ] +    , td [] [ text payment.name ] +    , 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))) | 
