dashboard/src/Route.elm

101 lines
3.2 KiB
Elm
Raw Normal View History

2020-11-23 15:44:45 +03:00
module Route exposing (..)
import Air exposing (callBI, fold, next, par, relayEvent, seq, set)
2020-11-25 22:11:11 +03:00
import Dict
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-25 22:11:11 +03:00
import ModulePage.View as ModulePage
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
2020-11-25 19:51:53 +03:00
2020-11-25 22:11:11 +03:00
routeView : Model -> Route -> Html msg
routeView model route =
case route of
Page page ->
case page of
"hub" ->
HubPage.view {}
2020-11-25 19:51:53 +03:00
2020-11-25 22:11:11 +03:00
"module" ->
let
up = (\(pid, p) -> Maybe.map (\a -> Tuple.pair pid a) (List.head (List.drop 0 p.services)))
el = (List.head (List.drop 3 (Dict.toList model.discoveredPeers)))
_ = Debug.log "el" el
in
case Maybe.andThen up el of
Just (peerId, service) ->
let
example =
{ name = "Chat"
, id = service.service_id
, author = "Fluence Labs"
, authorPeerId = peerId
, description = "Cool service"
, website = "https://github.com/fluencelabs/chat"
, service = service
}
in
ModulePage.view example
Nothing ->
Html.text "alala"
_ ->
Html.text ("undefined page: " ++ page)
Peer peer ->
Html.text peer
2020-11-23 16:31:31 +03:00
2020-11-25 19:51:53 +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
2020-11-25 19:51:53 +03:00
_ =
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"))
2020-11-23 17:29:56 +03:00
(relayEvent "peers_discovered" [ "p", "morePeers" ])
)
(next "p")
)
2020-11-23 15:44:45 +03:00
)
in
sendAir (relayId <| clientId <| air)
Peer _ ->
Cmd.none