mirror of
https://github.com/MODSetter/SurfSense.git
synced 2026-05-01 20:03:30 +02:00
feat: enhance accessibility of ExpandedMediaOverlay with ARIA roles and focus management
This commit is contained in:
parent
c7ace83b61
commit
c76ff79bc4
1 changed files with 12 additions and 1 deletions
|
|
@ -1,7 +1,7 @@
|
|||
"use client";
|
||||
|
||||
import { AnimatePresence, motion } from "motion/react";
|
||||
import { useCallback, useEffect, useState } from "react";
|
||||
import { useCallback, useEffect, useRef, useState } from "react";
|
||||
import { createPortal } from "react-dom";
|
||||
|
||||
function isVideoSrc(src: string) {
|
||||
|
|
@ -17,6 +17,12 @@ function ExpandedMediaOverlay({
|
|||
alt: string;
|
||||
onClose: () => void;
|
||||
}) {
|
||||
const overlayRef = useRef<HTMLDivElement>(null);
|
||||
|
||||
useEffect(() => {
|
||||
overlayRef.current?.focus();
|
||||
}, []);
|
||||
|
||||
useEffect(() => {
|
||||
const handleKey = (e: KeyboardEvent) => {
|
||||
if (e.key === "Escape") onClose();
|
||||
|
|
@ -52,6 +58,11 @@ function ExpandedMediaOverlay({
|
|||
|
||||
return createPortal(
|
||||
<motion.div
|
||||
role="dialog"
|
||||
aria-modal="true"
|
||||
aria-label="Expanded media view"
|
||||
tabIndex={-1}
|
||||
ref={overlayRef}
|
||||
initial={{ opacity: 0 }}
|
||||
animate={{ opacity: 1 }}
|
||||
exit={{ opacity: 0 }}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue