dashboard/src/Route.elm

68 lines
2.0 KiB
Elm
Raw Normal View History

2020-11-23 15:44:45 +03:00
module Route exposing (..)
import Air exposing (call, callBI, fold, next, par, relayEvent, seq, set)
import Html exposing (Html)
import HubPage.View as HubPage
2020-11-23 15:44:45 +03:00
import Json.Encode as Encode
2020-11-23 16:31:31 +03:00
import Model exposing (Model, Route(..))
2020-11-23 15:44:45 +03:00
import Port exposing (sendAir)
import Url.Parser exposing ((</>), Parser, map, oneOf, s, string)
routeParser : Parser (Route -> a) a
routeParser =
oneOf
[ map Peer (s "peer" </> string)
, map Page string
]
2020-11-23 16:31:31 +03:00
parse url =
Maybe.withDefault (Page "") <| Url.Parser.parse routeParser url
routeView : Route -> Html msg
routeView route =
case route of
Page page ->
case page of
"hub" ->
HubPage.view {}
_ ->
Html.text ("undefined page: " ++ page)
Peer peer ->
Html.text peer
2020-11-23 16:31:31 +03:00
2020-11-23 15:44:45 +03:00
routeCommand : Model -> Route -> Cmd msg
routeCommand m r =
case r of
Page s ->
2020-11-23 15:44:45 +03:00
let
_ = Debug.log "page" s
2020-11-23 15:44:45 +03:00
clientId =
set "clientId" <| Encode.string m.peerId
relayId =
set "relayId" <| Encode.string m.relayId
air =
seq
(callBI "relayId" ( "dht", "neighborhood" ) [ "clientId" ] (Just "peers"))
2020-11-23 17:29:56 +03:00
(par
(relayEvent "peers_discovered" [ "relayId", "peers" ])
(fold "peers" "p" <|
par
(seq
(callBI "p" ( "dht", "neighborhood" ) [ "clientId" ] (Just "morePeers[]"))
(relayEvent "peers_discovered" [ "p", "morePeers" ])
)
(next "p")
)
2020-11-23 15:44:45 +03:00
)
in
sendAir (relayId <| clientId <| air)
Peer _ ->
Cmd.none