blob: f4247f73bc4df462ccdb565832b4228f95aabf73 (
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
|
port module Client exposing (main)
import Browser
import Html exposing (Html)
import Url exposing (Url)
port webSocketIn : (String -> msg) -> Sub msg
port webSocketOut : String -> Cmd msg
type Msg
= Ignore
| Send
| WebSocketIn String
type Model
= Error String
| JoinRoom
{ id : String
}
parseRoomId : Url -> Result String String
parseRoomId url = case String.split "/" url.path of
_ :: "rooms" :: roomId :: _ -> Ok roomId
_ -> Err <| "Invalid path: " ++ url.path
view : Model -> List (Html Msg)
view model = case model of
Error str ->
[ Html.h1 [] [Html.text "Error"]
, Html.p [] [Html.text str]
]
JoinRoom room ->
[ Html.h1 [] [Html.text <| "Room " ++ room.id]
]
subscriptions : Model -> Sub Msg
subscriptions model = webSocketIn WebSocketIn
update : Msg -> Model -> (Model, Cmd Msg)
update msg model = case msg of
Ignore -> (model, Cmd.none)
Send -> (model, webSocketOut "Hi")
WebSocketIn str -> Debug.log str (model, Cmd.none)
main : Program () Model Msg
main = Browser.application
{ init = \() url key -> case parseRoomId url of
Err str -> (Error <| "Could not parse room ID: " ++ str, Cmd.none)
Ok roomId -> (JoinRoom {id = roomId}, Cmd.none)
, update = update
, subscriptions = subscriptions
, view = \model -> {title = "Client", body = view model}
, onUrlChange = \url -> Ignore
, onUrlRequest = \urlRequest -> Ignore
}
|