a11y: Enhance accessibility across various components by adding ARIA attributes, semantic elements, and input labels.

This commit is contained in:
2026-02-25 17:18:12 -03:00
parent f36c53aed1
commit f6c48ca8f0
9 changed files with 108 additions and 52 deletions
+5 -2
View File
@@ -35,17 +35,20 @@ export default function Modal({ isOpen, onClose, title, children }: ModalProps)
<div className="fixed inset-0 z-[100] flex items-center justify-center p-4 bg-black/60 backdrop-blur-sm animate-in fade-in duration-200">
<div
ref={modalRef}
role="dialog"
aria-modal="true"
aria-labelledby="modal-title"
className="w-full max-w-md glass-card bg-[#1a1d23] border border-white/10 rounded-2xl p-8 shadow-2xl animate-in zoom-in-95 duration-200"
>
<div className="flex justify-between items-center mb-6">
<h2 className="text-xl font-bold bg-gradient-to-r from-white to-gray-400 bg-clip-text text-transparent italic">
<h2 id="modal-title" className="text-xl font-bold bg-gradient-to-r from-white to-gray-400 bg-clip-text text-transparent italic">
{title}
</h2>
<button
onClick={onClose}
className="p-2 hover:bg-white/5 rounded-full transition-colors text-gray-400 hover:text-white"
>
<X size={20} />
<X size={20} aria-hidden="true" />
</button>
</div>
{children}