Fix #115: Add keyboard navigation to media viewer.

This commit is contained in:
Nicolas Perriault 2017-07-13 17:34:00 +02:00
parent 7c602100a5
commit 885e0194c5
No known key found for this signature in database
GPG Key ID: DA5E4C83904F7A2A
7 changed files with 73 additions and 12 deletions

View File

@ -16,6 +16,7 @@
"elm-lang/dom": "1.1.1 <= v < 2.0.0", "elm-lang/dom": "1.1.1 <= v < 2.0.0",
"elm-lang/html": "2.0.0 <= v < 3.0.0", "elm-lang/html": "2.0.0 <= v < 3.0.0",
"elm-lang/http": "1.0.0 <= v < 2.0.0", "elm-lang/http": "1.0.0 <= v < 2.0.0",
"elm-lang/keyboard": "1.0.1 <= v < 2.0.0",
"elm-lang/navigation": "2.1.0 <= v < 3.0.0", "elm-lang/navigation": "2.1.0 <= v < 3.0.0",
"elm-lang/websocket": "1.0.2 <= v < 2.0.0", "elm-lang/websocket": "1.0.2 <= v < 2.0.0",
"evancz/url-parser": "2.0.1 <= v < 3.0.0", "evancz/url-parser": "2.0.1 <= v < 3.0.0",

View File

@ -1,6 +1,7 @@
module Subscription exposing (subscriptions) module Subscription exposing (subscriptions)
import Autocomplete import Autocomplete
import Keyboard
import Mastodon.WebSocket import Mastodon.WebSocket
import Ports import Ports
import Time import Time
@ -44,6 +45,9 @@ subscriptions { clients, currentView } =
uploadErrorSub = uploadErrorSub =
Ports.uploadError (DraftEvent << UploadError) Ports.uploadError (DraftEvent << UploadError)
keyDownsSub =
Keyboard.downs KeyMsg
in in
Sub.batch Sub.batch
[ timeSub [ timeSub
@ -52,4 +56,5 @@ subscriptions { clients, currentView } =
, autoCompleteSub , autoCompleteSub
, uploadSuccessSub , uploadSuccessSub
, uploadErrorSub , uploadErrorSub
, keyDownsSub
] ]

View File

@ -1,6 +1,7 @@
module Types exposing (..) module Types exposing (..)
import Autocomplete import Autocomplete
import Keyboard
import Mastodon.Http exposing (Response, Links) import Mastodon.Http exposing (Response, Links)
import Mastodon.Model exposing (..) import Mastodon.Model exposing (..)
import Navigation import Navigation
@ -34,6 +35,8 @@ type DraftMsg
type ViewerMsg type ViewerMsg
= CloseViewer = CloseViewer
| OpenViewer (List Attachment) Attachment | OpenViewer (List Attachment) Attachment
| PrevAttachment
| NextAttachment
type alias MastodonResult a = type alias MastodonResult a =
@ -99,6 +102,7 @@ type Msg
| DraftEvent DraftMsg | DraftEvent DraftMsg
| FilterNotifications NotificationFilter | FilterNotifications NotificationFilter
| FollowAccount Account | FollowAccount Account
| KeyMsg Keyboard.KeyCode
| LogoutClient Client | LogoutClient Client
| TimelineLoadNext String String | TimelineLoadNext String String
| MastodonEvent MastodonMsg | MastodonEvent MastodonMsg

View File

@ -55,6 +55,23 @@ update msg model =
} }
! [] ! []
KeyMsg code ->
case ( code, model.viewer ) of
( 27, Just _ ) ->
-- Esc
update (ViewerEvent CloseViewer) model
( 37, Just _ ) ->
-- Left arrow
update (ViewerEvent PrevAttachment) model
( 39, Just _ ) ->
-- Right arrow
update (ViewerEvent NextAttachment) model
_ ->
model ! []
ClearError index -> ClearError index ->
{ model | errors = removeAt index model.errors } ! [] { model | errors = removeAt index model.errors } ! []

View File

@ -1,8 +1,19 @@
module Update.Viewer exposing (update) module Update.Viewer exposing (getPrevNext, update)
import List.Extra exposing (elemIndex, getAt)
import Mastodon.Model exposing (..)
import Types exposing (..) import Types exposing (..)
getPrevNext : Viewer -> ( Maybe Attachment, Maybe Attachment )
getPrevNext { attachments, attachment } =
let
index =
Maybe.withDefault -1 <| elemIndex attachment attachments
in
( getAt (index - 1) attachments, getAt (index + 1) attachments )
update : ViewerMsg -> Maybe Viewer -> ( Maybe Viewer, Cmd Msg ) update : ViewerMsg -> Maybe Viewer -> ( Maybe Viewer, Cmd Msg )
update viewerMsg viewer = update viewerMsg viewer =
case viewerMsg of case viewerMsg of
@ -11,3 +22,29 @@ update viewerMsg viewer =
OpenViewer attachments attachment -> OpenViewer attachments attachment ->
(Just <| Viewer attachments attachment) ! [] (Just <| Viewer attachments attachment) ! []
PrevAttachment ->
case viewer of
Just viewer ->
case getPrevNext viewer of
( Just prev, _ ) ->
(Just <| Viewer viewer.attachments prev) ! []
_ ->
Just viewer ! []
Nothing ->
viewer ! []
NextAttachment ->
case viewer of
Just viewer ->
case getPrevNext viewer of
( _, Just next ) ->
(Just <| Viewer viewer.attachments next) ! []
_ ->
Just viewer ! []
Nothing ->
viewer ! []

View File

@ -2,21 +2,18 @@ module View.Viewer exposing (viewerView)
import Html exposing (..) import Html exposing (..)
import Html.Attributes exposing (..) import Html.Attributes exposing (..)
import List.Extra exposing (find, elemIndex, getAt)
import Types exposing (..) import Types exposing (..)
import Update.Viewer exposing (getPrevNext)
import View.Events exposing (..) import View.Events exposing (..)
viewerView : Viewer -> Html Msg viewerView : Viewer -> Html Msg
viewerView { attachments, attachment } = viewerView ({ attachments, attachment } as viewer) =
let let
index =
Maybe.withDefault -1 <| elemIndex attachment attachments
( prev, next ) = ( prev, next ) =
( getAt (index - 1) attachments, getAt (index + 1) attachments ) getPrevNext viewer
navLink label className target = navLink label className target event =
case target of case target of
Nothing -> Nothing ->
text "" text ""
@ -25,8 +22,7 @@ viewerView { attachments, attachment } =
a a
[ href "" [ href ""
, class className , class className
, onClickWithPreventAndStop <| , onClickWithPreventAndStop event
ViewerEvent (OpenViewer attachments target)
] ]
[ text label ] [ text label ]
in in
@ -36,7 +32,7 @@ viewerView { attachments, attachment } =
, onClickWithPreventAndStop <| ViewerEvent CloseViewer , onClickWithPreventAndStop <| ViewerEvent CloseViewer
] ]
[ span [ class "close" ] [ text "×" ] [ span [ class "close" ] [ text "×" ]
, navLink "" "prev" prev , navLink "" "prev" prev <| ViewerEvent NextAttachment
, case attachment.type_ of , case attachment.type_ of
"image" -> "image" ->
img [ class "viewer-content", src attachment.url ] [] img [ class "viewer-content", src attachment.url ] []
@ -49,5 +45,5 @@ viewerView { attachments, attachment } =
, loop True , loop True
] ]
[ source [ src attachment.url ] [] ] [ source [ src attachment.url ] [] ]
, navLink "" "next" next , navLink "" "next" next <| ViewerEvent NextAttachment
] ]

View File

@ -23,6 +23,7 @@
"elm-lang/dom": "1.1.1 <= v < 2.0.0", "elm-lang/dom": "1.1.1 <= v < 2.0.0",
"elm-lang/html": "2.0.0 <= v < 3.0.0", "elm-lang/html": "2.0.0 <= v < 3.0.0",
"elm-lang/http": "1.0.0 <= v < 2.0.0", "elm-lang/http": "1.0.0 <= v < 2.0.0",
"elm-lang/keyboard": "1.0.1 <= v < 2.0.0",
"elm-lang/navigation": "2.1.0 <= v < 3.0.0", "elm-lang/navigation": "2.1.0 <= v < 3.0.0",
"elm-lang/websocket": "1.0.2 <= v < 2.0.0", "elm-lang/websocket": "1.0.2 <= v < 2.0.0",
"evancz/url-parser": "2.0.1 <= v < 3.0.0", "evancz/url-parser": "2.0.1 <= v < 3.0.0",