module Examples.Button exposing (Msg, State, example, init, update) {- \ @docs Msg, State, example, init, update, -} import Css exposing (middle, verticalAlign) import Debug.Control as Control exposing (Control) import Headings import Html.Styled exposing (..) import Html.Styled.Attributes exposing (css, id) import ModuleExample as ModuleExample exposing (Category(..), ModuleExample, ModuleMessages) import Nri.Ui.AssetPath exposing (Asset) import Nri.Ui.Button.V8 as Button import Nri.Ui.Icon.V4 as Icon import Nri.Ui.Svg.V1 as NriSvg exposing (Svg) import Nri.Ui.Text.V2 as Text {-| -} type Msg = SetState State {-| -} type State = State (Control Model) {-| -} type ButtonType = Button | Link {-| -} example : (String -> ModuleMessages Msg parentMsg) -> State -> ModuleExample parentMsg example unnamedMessages state = let messages = unnamedMessages "ButtonExample" in { filename = "Nri.Ui.Button.V8" , category = Buttons , content = [ viewButtonExamples messages state ] } {-| -} init : { r | performance : String, lock : String } -> State init assets = Control.record Model |> Control.field "label" (Control.string "Button") |> Control.field "icon" (Control.maybe False <| Control.choice ( "Performance" , Icon.performance assets |> Icon.decorativeIcon |> NriSvg.fromHtml |> Control.value ) [ ( "Lock" , Icon.lock assets |> Icon.decorativeIcon |> NriSvg.fromHtml |> Control.value ) ] ) |> Control.field "width" (Control.choice ( "Nri.Ui.Button.V7.WidthExact 120", Control.value <| Button.WidthExact 120 ) [ ( "Nri.Ui.Button.V7.WidthExact 70", Control.value <| Button.WidthExact 70 ) , ( "Nri.Ui.Button.V7.WidthUnbounded", Control.value <| Button.WidthUnbounded ) , ( "Nri.Ui.Button.V7.WidthFillContainer", Control.value <| Button.WidthFillContainer ) ] ) |> Control.field "button type" (Control.choice ( "Nri.Ui.Button.V7.button", Control.value Button ) [ ( "Nri.Ui.Button.V7.link", Control.value Link ) ] ) |> Control.field "state (button only)" (Control.choice ( Debug.toString Button.Enabled, Control.value Button.Enabled ) (List.map (\x -> ( Debug.toString x, Control.value x )) [ Button.Disabled , Button.Error , Button.Unfulfilled , Button.Loading , Button.Success ] ) ) |> State {-| -} update : Msg -> State -> ( State, Cmd Msg ) update msg state = case msg of SetState newState -> ( newState, Cmd.none ) -- INTERNAL type alias Model = { label : String , icon : Maybe Svg , width : Button.ButtonWidth , buttonType : ButtonType , state : Button.ButtonState } viewButtonExamples : ModuleMessages Msg parentMsg -> State -> Html parentMsg viewButtonExamples messages (State control) = let model = Control.currentValue control in [ Control.view (State >> SetState >> messages.wrapper) control |> fromUnstyled , buttons messages model , toggleButtons messages , Button.delete { label = "Delete Something" , onClick = messages.showItWorked "delete" } , Button.linkExternalWithTracking (messages.showItWorked "linkExternalWithTracking clicked") { size = Button.Medium , style = Button.Secondary , width = Button.WidthUnbounded , label = "linkExternalWithTracking" , icon = Nothing , url = "#" } ] |> div [] sizes : List Button.ButtonSize sizes = [ Button.Small , Button.Medium , Button.Large ] allStyles : List Button.ButtonStyle allStyles = [ Button.Primary , Button.Secondary , Button.Danger , Button.Premium ] buttons : ModuleMessages Msg parentMsg -> Model -> Html parentMsg buttons messages model = let exampleRow style = List.concat [ [ td [ css [ verticalAlign middle ] ] [ text <| Debug.toString style ] ] , sizes |> List.map (exampleCell style) ] |> tr [] exampleCell style size = (case model.buttonType of Link -> Button.link { size = size , style = style , label = model.label , icon = model.icon , url = "" , width = model.width } Button -> Button.button { size = size , style = style , onClick = messages.showItWorked (Debug.toString ( style, size )) , width = model.width } { label = model.label , icon = model.icon , state = model.state } ) |> List.singleton |> td [ css [ verticalAlign middle , Css.width (Css.px 200) ] ] in List.concat [ [ sizes |> List.map (\size -> th [] [ text <| Debug.toString size ]) |> (\cells -> tr [] (th [] [] :: cells)) ] , allStyles |> List.map exampleRow ] |> table [] toggleButtons : ModuleMessages Msg parentMsg -> Html parentMsg toggleButtons messages = div [] [ Headings.h3 [ text "Button toggle" ] , Button.toggleButton { onDeselect = messages.showItWorked "onDeselect" , onSelect = messages.showItWorked "onSelect" , label = "5" , pressed = False } , Button.toggleButton { onDeselect = messages.showItWorked "onDeselect" , onSelect = messages.showItWorked "onSelect" , label = "5" , pressed = True } ]