noredink-ui/styleguide-app/Routes.elm

139 lines
3.5 KiB
Elm
Raw Normal View History

2022-05-20 22:20:12 +03:00
module Routes exposing (Route(..), fromLocation, toString, viewBreadCrumbs)
2018-02-13 00:32:38 +03:00
2022-05-20 22:20:12 +03:00
import Accessibility.Styled as Html exposing (Html)
import Category
import Dict exposing (Dict)
import Example exposing (Example)
2022-05-20 22:20:12 +03:00
import Html.Styled.Attributes as Attributes
import Nri.Ui.BreadCrumbs.V1 as BreadCrumbs exposing (BreadCrumbs)
import Nri.Ui.Util exposing (dashify)
2018-12-05 21:56:04 +03:00
import Parser exposing ((|.), (|=), Parser)
import Url exposing (Url)
2018-02-13 00:32:38 +03:00
type Route state msg
= Doodad (Example state msg)
| Category Category.Category
2018-02-13 00:32:38 +03:00
| All
| NotFound String
2018-02-13 00:32:38 +03:00
toString : Route state msg -> String
toString route_ =
case route_ of
NotFound name ->
"#/doodad/" ++ name
Doodad example ->
"#/doodad/" ++ example.name
Category c ->
"#/category/" ++ Debug.toString c
All ->
"#/"
route : Dict String (Example state msg) -> Parser (Route state msg)
route examples =
let
findExample : String -> Route state msg
findExample name =
Dict.get name examples
|> Maybe.map Doodad
|> Maybe.withDefault (NotFound name)
in
2018-12-05 21:56:04 +03:00
Parser.oneOf
[ Parser.succeed Category
|. Parser.token "/category/"
2018-12-08 01:16:00 +03:00
|= (restOfPath |> Parser.andThen category)
, Parser.succeed findExample
|. Parser.token "/doodad/"
2018-12-08 01:16:00 +03:00
|= restOfPath
2018-12-05 21:56:04 +03:00
, Parser.succeed All
2018-02-13 00:32:38 +03:00
]
2018-12-08 01:16:00 +03:00
restOfPath : Parser String
restOfPath =
Parser.getChompedString (Parser.chompWhile (always True))
2018-12-05 21:56:04 +03:00
category : String -> Parser Category.Category
2018-12-05 21:56:04 +03:00
category string =
case Category.fromString string of
2018-12-05 21:56:04 +03:00
Ok c ->
Parser.succeed c
Err e ->
Parser.problem e
2018-02-13 00:32:38 +03:00
fromLocation : Dict String (Example state msg) -> Url -> Route state msg
fromLocation examples location =
location.fragment
|> Maybe.withDefault ""
|> Parser.run (route examples)
2018-12-05 21:56:04 +03:00
|> Result.withDefault All
2022-05-20 22:20:12 +03:00
viewBreadCrumbs : Route state msg -> Html msg2
2022-05-20 22:20:12 +03:00
viewBreadCrumbs currentRoute =
breadCrumbs currentRoute
|> Maybe.map
(BreadCrumbs.view
{ aTagAttributes = \r -> [ Attributes.href ("/" ++ toString r) ]
, isCurrentRoute = (==) currentRoute
}
)
|> Maybe.withDefault (Html.text "")
breadCrumbs : Route state msg -> Maybe (BreadCrumbs (Route state msg))
2022-05-20 22:20:12 +03:00
breadCrumbs route_ =
case route_ of
All ->
Just allBreadCrumb
Category category_ ->
Just (categoryCrumb category_)
Doodad example ->
Just (doodadCrumb example)
NotFound _ ->
2022-05-20 22:20:12 +03:00
Nothing
allBreadCrumb : BreadCrumbs (Route state msg)
2022-05-20 22:20:12 +03:00
allBreadCrumb =
BreadCrumbs.init
{ icon = Nothing
, iconStyle = BreadCrumbs.Default
, id = "breadcrumbs__all"
, text = "All"
, route = All
}
categoryCrumb : Category.Category -> BreadCrumbs (Route state msg)
2022-05-20 22:20:12 +03:00
categoryCrumb category_ =
BreadCrumbs.after allBreadCrumb
{ icon = Nothing
, iconStyle = BreadCrumbs.Default
, id = "breadcrumbs__" ++ Category.forId category_
, text = Category.forDisplay category_
, route = Category category_
}
doodadCrumb : Example state msg -> BreadCrumbs (Route state msg)
doodadCrumb example =
BreadCrumbs.after allBreadCrumb
{ icon = Nothing
, iconStyle = BreadCrumbs.Default
, id = "breadcrumbs__" ++ dashify example.name
, text = Example.fullName example
, route = Doodad example
}