import { useMemo, useState } from 'react' import Avatar from '@/components/ui/Avatar' import Dropdown from '@/components/ui/Dropdown' import Spinner from '@/components/ui/Spinner' import classNames from 'classnames' import withHeaderItem from '@/utils/hoc/withHeaderItem' import { useStoreState, useStoreActions } from '@/store' import dayjs from 'dayjs' import { FaCheck } from 'react-icons/fa' import type { CommonProps } from '@/@types/common' import appConfig from '@/configs/app.config' import { dateLocales } from '@/constants/dateLocales.constant' import { Tooltip } from '../ui' import { useLocalization } from '@/utils/hooks/useLocalization' const _LanguageSelector = ({ className }: CommonProps) => { const [loading, setLoading] = useState(false) const { setLang } = useStoreActions((actions) => actions.locale) const { config } = useStoreState((state) => state.abpConfig) const languageList = config?.localization.languages const currentLang = config?.localization?.currentCulture?.cultureName const selectLangFlag = useMemo(() => { return languageList?.find((lang) => lang.cultureName === currentLang)?.cultureName }, [currentLang, languageList]) const { translate } = useLocalization() const selectedLanguage = (