diff options
author | Joris Guyonvarch | 2015-07-10 00:03:42 +0200 |
---|---|---|
committer | Joris Guyonvarch | 2015-07-10 00:03:42 +0200 |
commit | 0041c546869f0a7fd59a085cc75b481237b6c380 (patch) | |
tree | 4814108670fc1a3e7c5a334e884accd0e9dc5e96 /src/client/Main.elm | |
parent | 4ce9751c9e645916fdde71874c2cdadd252f32a0 (diff) |
Fetching payments and showing them in a table
Diffstat (limited to 'src/client/Main.elm')
-rw-r--r-- | src/client/Main.elm | 39 |
1 files changed, 14 insertions, 25 deletions
diff --git a/src/client/Main.elm b/src/client/Main.elm index dd87b8c..18a4aba 100644 --- a/src/client/Main.elm +++ b/src/client/Main.elm @@ -7,37 +7,26 @@ import Graphics.Element exposing (..) import Html exposing (Html) import Http -import Json.Decode as Json exposing ((:=)) import Task exposing (..) -import Date exposing (..) -import View.Page exposing (renderPage) +import Model exposing (Model, initialModel) +import Model.Payment exposing (Payments, paymentsDecoder) -main : Html -main = renderPage +import Update exposing (Action(..), actions, updateModel) -getPayments : Task Http.Error (List Payment) -getPayments = Http.get paymentsDecoder "/payments" +import View.Page exposing (renderPage) -type alias Payments = List Payment +main : Signal Html +main = Signal.map renderPage model -type alias Payment = - { creation : Date - , name : String - , cost : Int - , userName : String - } +model : Signal Model +model = Signal.foldp updateModel initialModel actions.signal -paymentsDecoder : Json.Decoder Payments -paymentsDecoder = Json.list paymentDecoder +port fetchPayments : Task Http.Error () +port fetchPayments = getPayments `Task.andThen` report -paymentDecoder : Json.Decoder Payment -paymentDecoder = - Json.object4 Payment - ("creation" := dateDecoder) - ("name" := Json.string) - ("cost" := Json.int) - ("userName" := Json.string) +report : Payments -> Task x () +report payments = Signal.send actions.address (UpdatePayments payments) -dateDecoder : Json.Decoder Date -dateDecoder = Json.customDecoder Json.string Date.fromString +getPayments : Task Http.Error Payments +getPayments = Http.get paymentsDecoder "/payments" |