AIvoices/frontend-nextjs/hooks/useMediaQuery.ts
2025-09-19 16:40:15 +07:00

16 lines
466 B
TypeScript

import { useState, useEffect } from "react";
export function useMediaQuery(query: string): boolean {
const [matches, setMatches] = useState(false);
useEffect(() => {
const media = window.matchMedia(query);
setMatches(media.matches);
const listener = () => setMatches(media.matches);
media.addListener(listener);
return () => media.removeListener(listener);
}, [query]); // Remove 'matches' from dependency array
return matches;
}