mirror of
https://github.com/NoRedInk/noredink-ui.git
synced 2024-11-27 13:02:42 +03:00
Support Focus action in highlghter
This commit is contained in:
parent
710d605713
commit
3a629621e4
@ -59,6 +59,7 @@ TODO: Add documentation about how to wire in event listeners and subscriptions s
|
|||||||
|
|
||||||
import Accessibility.Styled.Aria as Aria
|
import Accessibility.Styled.Aria as Aria
|
||||||
import Accessibility.Styled.Key as Key
|
import Accessibility.Styled.Key as Key
|
||||||
|
import Browser.Dom as Dom
|
||||||
import Css
|
import Css
|
||||||
import Css.Global
|
import Css.Global
|
||||||
import Highlighter.Grouping as Grouping
|
import Highlighter.Grouping as Grouping
|
||||||
@ -76,6 +77,7 @@ import Nri.Ui.MediaQuery.V1 as MediaQuery
|
|||||||
import Sort exposing (Sorter)
|
import Sort exposing (Sorter)
|
||||||
import Sort.Set
|
import Sort.Set
|
||||||
import String.Extra
|
import String.Extra
|
||||||
|
import Task
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@ -179,7 +181,7 @@ text highlightables =
|
|||||||
type Msg marker
|
type Msg marker
|
||||||
= Pointer PointerMsg
|
= Pointer PointerMsg
|
||||||
| Keyboard KeyboardMsg
|
| Keyboard KeyboardMsg
|
||||||
| NoOp
|
| Focused (Result Dom.Error ())
|
||||||
|
|
||||||
|
|
||||||
{-| Messages used by highlighter when interacting with a mouse or finger.
|
{-| Messages used by highlighter when interacting with a mouse or finger.
|
||||||
@ -231,9 +233,10 @@ emptyIntent =
|
|||||||
determine whether they want to execute follow up actions.
|
determine whether they want to execute follow up actions.
|
||||||
|
|
||||||
-}
|
-}
|
||||||
withIntent : Model m -> ( Model m, Intent )
|
withIntent : ( Model m, Cmd (Msg m) ) -> ( Model m, Cmd (Msg m), Intent )
|
||||||
withIntent new =
|
withIntent ( new, cmd ) =
|
||||||
( { new | isInitialized = Initialized, hasChanged = NotChanged }
|
( { new | isInitialized = Initialized, hasChanged = NotChanged }
|
||||||
|
, cmd
|
||||||
, Intent
|
, Intent
|
||||||
{ listenTo =
|
{ listenTo =
|
||||||
case new.isInitialized of
|
case new.isInitialized of
|
||||||
@ -257,7 +260,8 @@ hasChanged (Intent { changed }) =
|
|||||||
{-| Actions are used as an intermediate algebra from pointer events to actual changes to the model.
|
{-| Actions are used as an intermediate algebra from pointer events to actual changes to the model.
|
||||||
-}
|
-}
|
||||||
type Action marker
|
type Action marker
|
||||||
= Blur Int
|
= Focus String
|
||||||
|
| Blur Int
|
||||||
| Hint Int Int
|
| Hint Int Int
|
||||||
| Hover Int
|
| Hover Int
|
||||||
| MouseDown Int
|
| MouseDown Int
|
||||||
@ -270,7 +274,7 @@ type Action marker
|
|||||||
|
|
||||||
{-| Update for highlighter returning additional info about whether there was a change
|
{-| Update for highlighter returning additional info about whether there was a change
|
||||||
-}
|
-}
|
||||||
update : Msg marker -> Model marker -> ( Model marker, Intent )
|
update : Msg marker -> Model marker -> ( Model marker, Cmd (Msg marker), Intent )
|
||||||
update msg model =
|
update msg model =
|
||||||
withIntent <|
|
withIntent <|
|
||||||
case msg of
|
case msg of
|
||||||
@ -282,17 +286,19 @@ update msg model =
|
|||||||
keyboardEventToActions keyboardMsg model
|
keyboardEventToActions keyboardMsg model
|
||||||
|> performActions model
|
|> performActions model
|
||||||
|
|
||||||
NoOp ->
|
Focused _ ->
|
||||||
model
|
( model, Cmd.none )
|
||||||
|
|
||||||
|
|
||||||
keyboardEventToActions : KeyboardMsg -> Model marker -> List (Action marker)
|
keyboardEventToActions : KeyboardMsg -> Model marker -> List (Action marker)
|
||||||
keyboardEventToActions msg model =
|
keyboardEventToActions msg model =
|
||||||
case msg of
|
case msg of
|
||||||
MoveLeft index ->
|
MoveLeft index ->
|
||||||
|
-- TODO: find the id of the element to the left, if there is one, and Focus it
|
||||||
[]
|
[]
|
||||||
|
|
||||||
MoveRight index ->
|
MoveRight index ->
|
||||||
|
-- TODO: find the id of the element to the right, if there is one, and Focus it
|
||||||
[]
|
[]
|
||||||
|
|
||||||
Space index ->
|
Space index ->
|
||||||
@ -375,51 +381,61 @@ pointerEventToActions msg model =
|
|||||||
|
|
||||||
{-| We fold over actions using (Model marker) as the accumulator.
|
{-| We fold over actions using (Model marker) as the accumulator.
|
||||||
-}
|
-}
|
||||||
performActions : Model marker -> List (Action marker) -> Model marker
|
performActions : Model marker -> List (Action marker) -> ( Model marker, Cmd (Msg m) )
|
||||||
performActions model actions =
|
performActions model actions =
|
||||||
List.foldl performAction model actions
|
List.foldl performAction ( model, [] ) actions
|
||||||
|
|> Tuple.mapSecond Cmd.batch
|
||||||
|
|
||||||
|
|
||||||
{-| Performs actual changes to the model, or emit a command.
|
{-| Performs actual changes to the model, or emit a command.
|
||||||
-}
|
-}
|
||||||
performAction : Action marker -> Model marker -> Model marker
|
performAction : Action marker -> ( Model marker, List (Cmd (Msg m)) ) -> ( Model marker, List (Cmd (Msg m)) )
|
||||||
performAction action model =
|
performAction action ( model, cmds ) =
|
||||||
case action of
|
case action of
|
||||||
|
Focus id ->
|
||||||
|
( model, Task.attempt Focused (Dom.focus id) :: cmds )
|
||||||
|
|
||||||
Blur index ->
|
Blur index ->
|
||||||
{ model | highlightables = Internal.blurAt index model.highlightables }
|
( { model | highlightables = Internal.blurAt index model.highlightables }, cmds )
|
||||||
|
|
||||||
Hover index ->
|
Hover index ->
|
||||||
{ model | highlightables = Internal.hoverAt index model.highlightables }
|
( { model | highlightables = Internal.hoverAt index model.highlightables }, cmds )
|
||||||
|
|
||||||
Hint start end ->
|
Hint start end ->
|
||||||
{ model | highlightables = Internal.hintBetween start end model.highlightables }
|
( { model | highlightables = Internal.hintBetween start end model.highlightables }, cmds )
|
||||||
|
|
||||||
Save marker ->
|
Save marker ->
|
||||||
{ model
|
( { model
|
||||||
| highlightables = Internal.saveHinted marker model.highlightables
|
| highlightables = Internal.saveHinted marker model.highlightables
|
||||||
, hasChanged = Changed
|
, hasChanged = Changed
|
||||||
}
|
}
|
||||||
|
, cmds
|
||||||
|
)
|
||||||
|
|
||||||
Toggle index marker ->
|
Toggle index marker ->
|
||||||
{ model
|
( { model
|
||||||
| highlightables = Internal.toggleHinted index marker model.highlightables
|
| highlightables = Internal.toggleHinted index marker model.highlightables
|
||||||
, hasChanged = Changed
|
, hasChanged = Changed
|
||||||
}
|
}
|
||||||
|
, cmds
|
||||||
|
)
|
||||||
|
|
||||||
Remove ->
|
Remove ->
|
||||||
{ model
|
( { model
|
||||||
| highlightables = Internal.removeHinted model.highlightables
|
| highlightables = Internal.removeHinted model.highlightables
|
||||||
, hasChanged = Changed
|
, hasChanged = Changed
|
||||||
}
|
}
|
||||||
|
, cmds
|
||||||
|
)
|
||||||
|
|
||||||
MouseDown index ->
|
MouseDown index ->
|
||||||
{ model | mouseDownIndex = Just index }
|
( { model | mouseDownIndex = Just index }, cmds )
|
||||||
|
|
||||||
MouseOver index ->
|
MouseOver index ->
|
||||||
{ model | mouseOverIndex = Just index }
|
( { model | mouseOverIndex = Just index }, cmds )
|
||||||
|
|
||||||
MouseUp ->
|
MouseUp ->
|
||||||
{ model | mouseDownIndex = Nothing }
|
( { model | mouseDownIndex = Nothing }, cmds )
|
||||||
|
|
||||||
|
|
||||||
{-| -}
|
{-| -}
|
||||||
|
@ -288,9 +288,9 @@ update msg state =
|
|||||||
|
|
||||||
HighlighterMsg highlighterMsg ->
|
HighlighterMsg highlighterMsg ->
|
||||||
let
|
let
|
||||||
( newHighlighter, _ ) =
|
( newHighlighter, effect, _ ) =
|
||||||
Highlighter.update highlighterMsg state.highlighter
|
Highlighter.update highlighterMsg state.highlighter
|
||||||
in
|
in
|
||||||
( { state | highlighter = newHighlighter }
|
( { state | highlighter = newHighlighter }
|
||||||
, Cmd.none
|
, Cmd.map HighlighterMsg effect
|
||||||
)
|
)
|
||||||
|
Loading…
Reference in New Issue
Block a user