{"version":3,"file":"chunk.Ceb0zm5k.js","sources":["../../src/assets/icons/flags/spain.png","../../src/assets/icons/flags/uk.png","../../src/assets/icons/flags/france.png","../../src/assets/icons/flags/germany.png","../../src/assets/icons/flags/italy.png","../../src/assets/icons/flags/portugal.png","../../src/assets/icons/flags/denmark.png","../../src/assets/icons/flags/holland.png","../../src/assets/icons/flags/poland.png","../../src/components/globals/languageSelector/LanguageSelector.tsx"],"sourcesContent":["export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","export default \"\"","import { useState, useEffect, useRef } from 'react';\nimport { useNavigate } from 'react-router-dom';\nimport { useTranslation } from 'react-i18next';\nimport LanguageDetector from 'i18next-browser-languagedetector';\nimport arrowDownIcon from '@/assets/icons/arrow-down.png';\nimport arrowUpIcon from '@/assets/icons/arrow-up.png';\nimport spainFlag from '@/assets/icons/flags/spain.png';\nimport ukFlag from '@/assets/icons/flags/uk.png';\nimport franceFlag from '@/assets/icons/flags/france.png';\nimport germanyFlag from '@/assets/icons/flags/germany.png';\nimport italyFlag from '@/assets/icons/flags/italy.png';\nimport portugalFlag from '@/assets/icons/flags/portugal.png';\nimport denmarkFlag from '@/assets/icons/flags/denmark.png';\nimport hollandFlag from '@/assets/icons/flags/holland.png';\nimport polandFlag from '@/assets/icons/flags/poland.png';\nimport useClickOutside from '@/hooks/useClickOutside';\nimport useRoutes from '@/hooks/useRoutes';\nimport styles from './LanguageSelector.module.scss';\nimport { useAppSelector } from '@/hooks/useRedux';\nimport getSelectedPlan from '@/utils/getSelectedPlan';\n\ninterface IProps {\n mode?: 'text' | 'flags';\n}\n\nexport const LanguageSelector = ({ mode = 'text' }: IProps) => {\n const currentPlanId = useAppSelector((state) => state.plan.currentPlan);\n const [showLangSelector, setShowLangSelector] = useState(false);\n const { isLandingGeneric, isLandingMarketing } = useRoutes();\n const { isAloyPlan } = getSelectedPlan(currentPlanId);\n const flagsContainer = useRef(null);\n const isFlagMode = mode === 'flags';\n const navigate = useNavigate();\n const { t, i18n } = useTranslation();\n const currentLang = i18n.language;\n const languages = [\n {\n slug: 'en',\n name: t('english'),\n flag: ukFlag,\n },\n {\n slug: 'es',\n name: t('spanish'),\n flag: spainFlag,\n },\n {\n slug: 'de',\n name: t('deutch'),\n flag: germanyFlag,\n },\n {\n slug: 'pt',\n name: t('portuguese'),\n flag: portugalFlag,\n },\n {\n slug: 'it',\n name: t('italian'),\n flag: italyFlag,\n },\n {\n slug: 'fr',\n name: t('french'),\n flag: franceFlag,\n },\n {\n slug: 'dk',\n name: t('danish'),\n flag: denmarkFlag,\n },\n {\n slug: 'pl',\n name: t('polish'),\n flag: polandFlag,\n },\n {\n slug: 'nl',\n name: t('dutch'),\n flag: hollandFlag,\n },\n ];\n\n const currentLangConfig = languages.find((item) => item.slug === currentLang) ?? languages[0];\n const [lang, setLang] = useState(currentLangConfig);\n\n const onClickOutside = () => {\n if (showLangSelector) setShowLangSelector(false);\n };\n\n useClickOutside(flagsContainer, onClickOutside);\n\n const onLanguageMenuClick = () => {\n setShowLangSelector(!showLangSelector);\n };\n\n const onLanguageClick = (newLang: string) => {\n // Referencia al archivo routes del idioma actual\n const routes = i18n.getResourceBundle(currentLang, 'routes');\n // Obtiene el pathname completo de la ruta actual\n const currentPathname = window.location.pathname.replace(/\\/+$/, '');\n // Busca en el archivo routes del idioma actual, la key cuyo valor sea igual al pathname actual\n let currentRouteKey = Object.keys(routes).find((key) => routes[key] === currentPathname);\n // Si está en la home no habrá path \"/\"\"y la key será undefined, en ese caso seteo la key manualmente a home\n const isHomePage = currentPathname === '' && currentRouteKey === undefined;\n if (isHomePage) currentRouteKey = 'home';\n // Obtiene el pathname con la misma key que el actual, pero en el archivo del nuevo idioma seleccionado\n\n setLanguageText();\n setShowLangSelector(false);\n\n i18n.changeLanguage(newLang).then(() => {\n if (isLandingGeneric || isLandingMarketing) {\n const newLandingPath = currentPathname.replace(`/${currentLang}/`, `/${newLang}/`);\n navigate(newLandingPath);\n } else {\n const newPathName = t(`routes:${currentRouteKey}`);\n navigate(newPathName);\n }\n });\n };\n\n /* const onLanguageClick = (newLang: string) => {\n setLanguageText();\n setShowLangSelector(false);\n i18n.changeLanguage(newLang);\n }; */\n\n const setLanguageText = () => {\n const languageUsed = i18n.use(LanguageDetector).language.split('-')[0];\n const langConfig =\n languages.find((item) => item.slug.toLowerCase() === languageUsed.toLowerCase()) ?? languages[0];\n\n setLang(langConfig);\n };\n\n useEffect(() => {\n setLanguageText();\n }, [i18n.language]);\n\n /* useEffect(() => {\n // Cada vez que cambie el tipo de funnel, hay que comprobar si el idioma seleccionado está disponible\n // para ese tipo de funnel, si no, cambiar al idioma por defecto (quizás al idioma del navegador del usuario)\n const aloyHasSelectedLanguage = languages.some((language) => language.slug === i18n.language);\n if (!aloyHasSelectedLanguage) {\n const languageUsed = i18n.use(LanguageDetector).language.split('-')[0];\n const langConfig =\n languages.find((item) => item.slug.toLowerCase() === languageUsed.toLowerCase()) ?? languages[0];\n\n onLanguageClick(langConfig.slug);\n }\n }, [isAloyPlan]); */\n\n const arrowIcon = showLangSelector ? arrowUpIcon : arrowDownIcon;\n const languagesToShow = languages.filter((item) => item.slug !== lang.slug);\n\n return (\n \n \n {isFlagMode ? \"\" : lang.name}\n \"\"\n \n {showLangSelector && (\n \n )}\n \n );\n};\n\nexport default LanguageSelector;\n"],"names":["spainFlag","ukFlag","franceFlag","germanyFlag","italyFlag","portugalFlag","denmarkFlag","hollandFlag","polandFlag","LanguageSelector","mode","useAppSelector","state","showLangSelector","setShowLangSelector","useState","isLandingGeneric","isLandingMarketing","useRoutes","flagsContainer","useRef","isFlagMode","navigate","useNavigate","t","i18n","useTranslation","currentLang","languages","currentLangConfig","_a","item","lang","setLang","useClickOutside","onLanguageMenuClick","onLanguageClick","newLang","routes","currentPathname","currentRouteKey","key","setLanguageText","newLandingPath","newPathName","languageUsed","LanguageDetector","langConfig","useEffect","arrowIcon","arrowUpIcon","arrowDownIcon","languagesToShow","jsxs","styles","jsx"],"mappings":"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"}