SurfSense/surfsense_web/components/LanguageSwitcher.tsx

57 lines
1.5 KiB
TypeScript
Raw Normal View History

'use client';
import {useLocaleContext} from '@/contexts/LocaleContext';
import {
Select,
SelectContent,
SelectItem,
SelectTrigger,
SelectValue,
} from '@/components/ui/select';
import {Globe} from 'lucide-react';
/**
* Language switcher component
* Allows users to change the application language
* Persists preference in localStorage
*/
export function LanguageSwitcher() {
const {locale, setLocale} = useLocaleContext();
// Supported languages configuration
const languages = [
{code: 'en' as const, name: 'English', flag: '🇺🇸'},
{code: 'zh' as const, name: '简体中文', flag: '🇨🇳'},
];
/**
* Handle language change
* Updates locale in context and localStorage
*/
const handleLanguageChange = (newLocale: string) => {
setLocale(newLocale as 'en' | 'zh');
};
return (
<Select value={locale} onValueChange={handleLanguageChange}>
<SelectTrigger className="w-[160px]">
<Globe className="mr-2 h-4 w-4" />
<SelectValue>
{languages.find(lang => lang.code === locale)?.name || 'English'}
</SelectValue>
</SelectTrigger>
<SelectContent>
{languages.map((language) => (
<SelectItem key={language.code} value={language.code}>
<span className="flex items-center gap-2">
<span>{language.flag}</span>
<span>{language.name}</span>
</span>
</SelectItem>
))}
</SelectContent>
</Select>
);
}