mirror of
https://github.com/NoRedInk/noredink-ui.git
synced 2024-12-26 15:15:26 +03:00
Switch to prevent default keydown event
This commit is contained in:
parent
751aa89f84
commit
4c0ef73fa8
@ -64,7 +64,8 @@ import Css exposing (..)
|
||||
import Css.Transitions
|
||||
import Html.Styled as Root
|
||||
import Html.Styled.Attributes as Attrs exposing (id)
|
||||
import Html.Styled.Events exposing (onClick)
|
||||
import Html.Styled.Events as Events exposing (onClick)
|
||||
import Json.Decode as Decode exposing (Decoder)
|
||||
import Nri.Ui.Colors.Extra
|
||||
import Nri.Ui.Colors.V1 as Colors
|
||||
import Nri.Ui.Fonts.V1 as Fonts
|
||||
@ -438,7 +439,7 @@ viewModal config styles =
|
||||
toContentAndFooter
|
||||
{ onlyFocusableElement =
|
||||
List.map (Attrs.map config.wrapMsg)
|
||||
[ Key.onKeyDown
|
||||
[ onKeyDownPreventDefault
|
||||
[ Key.tabBack (Focus autofocusId)
|
||||
, Key.tab (Focus autofocusId)
|
||||
]
|
||||
@ -451,12 +452,16 @@ viewModal config styles =
|
||||
toContentAndFooter
|
||||
{ firstFocusableElement =
|
||||
List.map (Attrs.map config.wrapMsg)
|
||||
[ Key.onKeyDown [ Key.tabBack (Focus lastId) ]
|
||||
[ onKeyDownPreventDefault
|
||||
[ Key.tabBack (Focus lastId)
|
||||
]
|
||||
, id firstId
|
||||
]
|
||||
, lastFocusableElement =
|
||||
List.map (Attrs.map config.wrapMsg)
|
||||
[ Key.onKeyDown [ Key.tab (Focus firstId) ]
|
||||
[ onKeyDownPreventDefault
|
||||
[ Key.tab (Focus firstId)
|
||||
]
|
||||
, id lastId
|
||||
]
|
||||
, autofocusElement =
|
||||
@ -466,6 +471,12 @@ viewModal config styles =
|
||||
]
|
||||
|
||||
|
||||
onKeyDownPreventDefault : List (Decoder msg) -> Html.Attribute msg
|
||||
onKeyDownPreventDefault decoders =
|
||||
Events.preventDefaultOn "keydown"
|
||||
(Decode.oneOf (List.map (Decode.map (\msg -> ( msg, True ))) decoders))
|
||||
|
||||
|
||||
{-| -}
|
||||
viewContent : Bool -> { content : List (Html msg), footer : List (Html msg) } -> Html msg
|
||||
viewContent visibleTitle { content, footer } =
|
||||
|
Loading…
Reference in New Issue
Block a user