import { Language } from '@mui/icons-material'; import { IconButton, Popover } from '@mui/material'; import { useRouter } from 'next/router'; import { useTranslation } from 'next-i18next'; import { MouseEvent, useState } from 'react'; import { languages } from '@/config/languages'; import styles from './LanguageSwitcher.module.scss'; const LanguageSwitcher = () => { const router = useRouter(); const { t } = useTranslation(); const [anchorEl, setAnchorEl] = useState(null); const handleClick = (event: MouseEvent) => setAnchorEl(event.currentTarget); const handleClose = () => setAnchorEl(null); const handleChangeLanguage = (locale: string) => { const { pathname, asPath, query } = router; document.cookie = `NEXT_LOCALE=${locale}; path=/; expires=2147483647`; router.push({ pathname, query }, asPath, { locale }); }; return (
{languages.map(({ code, name, localName }) => (

handleChangeLanguage(code)}> {name} {localName && `(${localName})`}

))} {t('common.footer.language.missing')}
); }; export default LanguageSwitcher;