Merge pull request #46 from NoRedInk/extract-nri-page

Extract `Nri.Page`
This commit is contained in:
Jasper Woudenberg 2018-05-03 14:38:06 +02:00 committed by GitHub
commit f82e89f50e
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 268 additions and 0 deletions

View File

@ -24,6 +24,7 @@
"Nri.Ui.Icon.V2", "Nri.Ui.Icon.V2",
"Nri.Ui.Modal.V1", "Nri.Ui.Modal.V1",
"Nri.Ui.Outline.V1", "Nri.Ui.Outline.V1",
"Nri.Ui.Page.V1",
"Nri.Ui.Palette.V1", "Nri.Ui.Palette.V1",
"Nri.Ui.SegmentedControl.V1", "Nri.Ui.SegmentedControl.V1",
"Nri.Ui.SegmentedControl.V2", "Nri.Ui.SegmentedControl.V2",

205
src/Nri/Ui/Page/V1.elm Normal file
View File

@ -0,0 +1,205 @@
module Nri.Ui.Page.V1 exposing (DefaultPage, blocked, broken, noPermission, notFound)
{-| A styled NRI issue page!
@docs DefaultPage, broken, blocked, notFound, noPermission
-}
import Css exposing (..)
import Html
import Html.Styled
import Nri.Ui.Button.V2 as Button
import Nri.Ui.Text.V1
{-| The default page information is for the button
which will direct the user back to the main page of
the SPA. Specify it's name and the message which will
navigate to the page.
-}
type alias DefaultPage msg =
{ link : msg
, name : String
}
{-| For the not found page.
-}
notFound : DefaultPage msg -> Html.Html msg
notFound defaultPage =
view
{ emoji = "\x1F914"
, title = "We couldnt find that!"
, subtitle = "Feel free to browse around, or check out our help center."
, defaultPage = Just defaultPage
, details = Nothing
}
{-| For HTTP errors and other broken states.
-}
broken : DefaultPage msg -> Html.Html msg
broken defaultPage =
view
{ emoji = "😵"
, title = "There was a problem!"
, subtitle = "You can try again, or check out our help center."
, defaultPage = Just defaultPage
, details = Nothing
}
{-| For HTTP errors and other broken states, where link goes to "/".
-}
blocked : String -> Html.Html msg
blocked details =
view
{ emoji = "😵"
, title = "There was a problem!"
, subtitle = "You can try again, or check out our help center."
, defaultPage = Nothing
, details = Just details
}
{-| For pages the user does not have access to.
-}
noPermission : DefaultPage msg -> Html.Html msg
noPermission defaultPage =
view
{ emoji = "\x1F910"
, title = "You do not have access to this page!"
, subtitle = "Talk to a site administrator if you believe you should have access to this page."
, defaultPage = Just defaultPage
, details = Nothing
}
-- INTERNAL
type alias Config msg =
{ emoji : String
, title : String
, subtitle : String
, defaultPage : Maybe (DefaultPage msg)
, details : Maybe String
}
view : Config msg -> Html.Html msg
view config =
Html.Styled.toUnstyled <|
viewContainer
[ viewEmoji [ Html.Styled.text config.emoji ]
, Nri.Ui.Text.V1.heading [ Html.text config.title ]
|> Html.Styled.fromUnstyled
, Nri.Ui.Text.V1.tagline [ Html.text config.subtitle ]
|> Html.Styled.fromUnstyled
, viewButton
[ viewExit config ]
, viewButton
[ Button.linkExternal
{ label = "Get help!"
, icon = Nothing
, url = "https://noredink.zendesk.com/hc/en-us"
, size = Button.Large
, style = Button.Secondary
, width = Just 260
}
|> Html.Styled.fromUnstyled
]
, case config.details of
Just details ->
viewButton [ viewDetails details ]
Nothing ->
Html.Styled.text ""
]
viewExit : Config msg -> Html.Styled.Html msg
viewExit config =
case config.defaultPage of
Just defaultPage ->
Button.button
{ onClick = defaultPage.link
, size = Button.Large
, style = Button.Primary
, width = Just 260
}
{ label = "Return to " ++ defaultPage.name
, state = Button.Enabled
, icon = Nothing
}
|> Html.Styled.fromUnstyled
Nothing ->
Button.link
{ label = "Return to dashboard"
, icon = Nothing
, url = "/"
, size = Button.Large
, style = Button.Primary
, width = Just 260
}
|> Html.Styled.fromUnstyled
viewDetails : String -> Html.Styled.Html msg
viewDetails detailsForEngineers =
Html.Styled.div []
[ Html.Styled.styled Html.Styled.details
[ margin (px 10) ]
[]
[ Html.Styled.styled Html.Styled.summary
[ color (hex "8F8F8F") ]
[]
[ Html.Styled.text "Details for NoRedInk engineers" ]
, Html.Styled.styled Html.Styled.code
[ display block
, whiteSpace normal
, overflowWrap breakWord
, textAlign left
, marginTop (px 10)
]
[]
[ Html.Styled.text detailsForEngineers ]
]
]
viewContainer : List (Html.Styled.Html msg) -> Html.Styled.Html msg
viewContainer =
Html.Styled.styled Html.Styled.div
[ marginTop (px 80)
, displayFlex
, flexDirection column
, alignItems center
]
[]
viewButton : List (Html.Styled.Html msg) -> Html.Styled.Html msg
viewButton children =
Html.Styled.styled Html.Styled.div
[ marginTop (px 15)
]
[]
[ Html.Styled.styled Html.Styled.div
[ textAlign center ]
[]
children
]
viewEmoji : List (Html.Styled.Html msg) -> Html.Styled.Html msg
viewEmoji =
Html.Styled.styled Html.Styled.div
[ fontSize (px 75)
, height (px 98)
, lineHeight (px 98)
]
[]

View File

@ -0,0 +1,59 @@
module Examples.Page exposing (example, styles)
{-|
@docs example, styles
-}
import Css
import Css.Foreign exposing (Snippet, adjacentSiblings, children, class, descendants, each, everything, media, selector, withClass)
import Html exposing (Html)
import ModuleExample as ModuleExample exposing (Category(..), ModuleExample)
import Nri.Ui.Page.V1 as Page
import Nri.Ui.Styles.V1 as Styles
{-| -}
example : msg -> ModuleExample msg
example noOp =
{ filename = "Nri/Ui/Page/V1.elm"
, category = Pages
, content =
[ Html.h3 [] [ Html.text "Pages for problems" ]
, Html.h4 [] [ Html.text "Page: Not Found" ]
, Page.notFound
{ link = noOp
, name = "The Main Page"
}
, Html.h4 [] [ Html.text "Page: Broken" ]
, Page.broken
{ link = noOp
, name = "The Main Page"
}
, Html.h4 [] [ Html.text "Page: No Permission" ]
, Page.noPermission
{ link = noOp
, name = "The Main Page"
}
]
}
{-| -}
styles : Styles.Styles id class msg
styles =
Styles.styles "Examples-Page-"
[ Css.Foreign.class Container
[ Css.displayFlex
, Css.flexWrap Css.wrap
]
]
-- INTERNAL
type CssClasses
= Container

View File

@ -7,6 +7,7 @@ import Examples.Colors
import Examples.Dropdown import Examples.Dropdown
import Examples.Fonts import Examples.Fonts
import Examples.Icon import Examples.Icon
import Examples.Page
import Examples.SegmentedControl import Examples.SegmentedControl
import Examples.Select import Examples.Select
import Examples.Table import Examples.Table
@ -150,6 +151,7 @@ nriThemedModules model =
[ Examples.Button.example assets (exampleMessages ButtonExampleMsg) model.buttonExampleState [ Examples.Button.example assets (exampleMessages ButtonExampleMsg) model.buttonExampleState
, Examples.Dropdown.example DropdownMsg model.dropdownState , Examples.Dropdown.example DropdownMsg model.dropdownState
, Examples.Icon.example , Examples.Icon.example
, Examples.Page.example NoOp
, Examples.SegmentedControl.example SegmentedControlMsg model.segmentedControlState , Examples.SegmentedControl.example SegmentedControlMsg model.segmentedControlState
, Examples.Select.example SelectMsg model.selectState , Examples.Select.example SelectMsg model.selectState
, Examples.Text.example , Examples.Text.example
@ -183,6 +185,7 @@ styles =
[ ModuleExample.styles [ ModuleExample.styles
] ]
, (Examples.Icon.styles |> .css) () , (Examples.Icon.styles |> .css) ()
, (Examples.Page.styles |> .css) ()
, (Examples.SegmentedControl.styles |> .css) () , (Examples.SegmentedControl.styles |> .css) ()
, (Button.styles |> .css) assets , (Button.styles |> .css) assets
, (Nri.Ui.Dropdown.V1.styles |> .css) () , (Nri.Ui.Dropdown.V1.styles |> .css) ()