From 0687abac30f06e065370a8162492d2377e4cc1fa Mon Sep 17 00:00:00 2001 From: danihagosbl <168411661+danihagosbl@users.noreply.github.com> Date: Wed, 23 Oct 2024 14:43:49 +0100 Subject: [PATCH] Fix keyboard thumbnail activation (fixes #1068) (#1155) --- .../modules/uv-contentleftpanel-module/ContentLeftPanel.ts | 6 +++++- .../iiif/modules/uv-contentleftpanel-module/ThumbsView.tsx | 6 ++++++ 2 files changed, 11 insertions(+), 1 deletion(-) diff --git a/src/content-handlers/iiif/modules/uv-contentleftpanel-module/ContentLeftPanel.ts b/src/content-handlers/iiif/modules/uv-contentleftpanel-module/ContentLeftPanel.ts index 96d77efa0..a02d21bed 100644 --- a/src/content-handlers/iiif/modules/uv-contentleftpanel-module/ContentLeftPanel.ts +++ b/src/content-handlers/iiif/modules/uv-contentleftpanel-module/ContentLeftPanel.ts @@ -44,10 +44,12 @@ export class ContentLeftPanel extends LeftPanel { $treeViewOptions: JQuery; $treeSelect: JQuery; $views: JQuery; + $keyElement: JQuery expandFullEnabled: boolean = false; galleryView: GalleryView; isThumbsViewOpen: boolean = false; isTreeViewOpen: boolean = false; + keyPress:boolean = false; treeData: TreeNode; treeSortType: TreeSortType = TreeSortType.NONE; treeView: TreeView; @@ -505,10 +507,12 @@ export class ContentLeftPanel extends LeftPanel { onClick: (thumb: Thumb) => { this.extensionHost.publish(IIIFEvents.THUMB_SELECTED, thumb); }, + onKeyDown: (thumb: Thumb) => { + this.extensionHost.publish(IIIFEvents.THUMB_SELECTED, thumb); + }, }) ); } - createGalleryView(): void { this.galleryView = new GalleryView(this.$galleryView); this.galleryView.galleryData = this.getGalleryData(); diff --git a/src/content-handlers/iiif/modules/uv-contentleftpanel-module/ThumbsView.tsx b/src/content-handlers/iiif/modules/uv-contentleftpanel-module/ThumbsView.tsx index bac81b9f7..278524675 100644 --- a/src/content-handlers/iiif/modules/uv-contentleftpanel-module/ThumbsView.tsx +++ b/src/content-handlers/iiif/modules/uv-contentleftpanel-module/ThumbsView.tsx @@ -7,6 +7,7 @@ import cx from "classnames"; const ThumbImage = ({ first, onClick, + onKeyDown, paged, selected, thumb, @@ -14,6 +15,7 @@ const ThumbImage = ({ }: { first: boolean; onClick: (thumb: Thumb) => void; + onKeyDown: (thumb: Thumb) => void; paged: boolean; selected: boolean; thumb: Thumb; @@ -28,6 +30,7 @@ const ThumbImage = ({ return (
onClick(thumb)} + onKeyDown= {(e) => {if(e.key === 'Enter'){onKeyDown(thumb)}}} className={cx("thumb", { first: first, placeholder: !thumb.uri, @@ -64,12 +67,14 @@ const ThumbImage = ({ const Thumbnails = ({ onClick, + onKeyDown, paged, selected, thumbs, viewingDirection, }: { onClick: (thumb: Thumb) => void; + onKeyDown: (thumb: Thumb) => void; paged: boolean; selected: number[]; thumbs: Thumb[]; @@ -122,6 +127,7 @@ const Thumbnails = ({