-
Notifications
You must be signed in to change notification settings - Fork 0
/
Main.elm
79 lines (51 loc) · 1.28 KB
/
Main.elm
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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
module Main exposing (Model, init, update, view, subscriptions)
import Html exposing (Html, div)
import LoginPage as Login
-- MAIN
main : Program Never Model Msg
main =
Html.program
{ init = ( init, Cmd.none )
, update = update
, view = view
, subscriptions = subscriptions
}
subscriptions : Model -> Sub Msg
subscriptions model =
Sub.none
-- MODEL
type alias Model =
{ login : Login.Model
}
init : Model
init =
{ login = Login.init
}
-- UPDATE
type Msg
= NoOp
| LoginMsg Login.Msg
update : Msg -> Model -> ( Model, Cmd Msg )
update msg model =
case Debug.log "msg:" msg of
NoOp ->
model ! []
LoginMsg loginMsg ->
let
loginCtx : Login.Context msg
loginCtx =
{ url = "http://localhost:8000/login"
, onSuccess = Nothing
}
( newLogin, newMsg ) =
Login.update loginCtx loginMsg model.login
in
{ model | login = newLogin } ! [ Cmd.map LoginMsg newMsg ]
-- VIEW
view : Model -> Html Msg
view model =
let
login =
Html.map LoginMsg <| Login.view model.login
in
div [] [ login ]