mirror of
https://github.com/documenso/documenso.git
synced 2025-11-14 00:32:43 +10:00
65 lines
1.7 KiB
TypeScript
65 lines
1.7 KiB
TypeScript
import { msg } from '@lingui/core/macro';
|
|
import { useLingui } from '@lingui/react';
|
|
import { CheckIcon } from 'lucide-react';
|
|
|
|
import { SUPPORTED_LANGUAGES } from '@documenso/lib/constants/i18n';
|
|
import { dynamicActivate } from '@documenso/lib/utils/i18n';
|
|
import { cn } from '@documenso/ui/lib/utils';
|
|
import {
|
|
CommandDialog,
|
|
CommandGroup,
|
|
CommandInput,
|
|
CommandItem,
|
|
CommandList,
|
|
} from '@documenso/ui/primitives/command';
|
|
|
|
type LanguageSwitcherDialogProps = {
|
|
open: boolean;
|
|
setOpen: (_open: boolean) => void;
|
|
};
|
|
|
|
export const LanguageSwitcherDialog = ({ open, setOpen }: LanguageSwitcherDialogProps) => {
|
|
const { i18n, _ } = useLingui();
|
|
|
|
const setLanguage = async (lang: string) => {
|
|
setOpen(false);
|
|
|
|
await dynamicActivate(lang);
|
|
|
|
const formData = new FormData();
|
|
|
|
formData.append('lang', lang);
|
|
|
|
await fetch('/api/locale', {
|
|
method: 'post',
|
|
body: formData,
|
|
});
|
|
};
|
|
|
|
return (
|
|
<CommandDialog open={open} onOpenChange={setOpen}>
|
|
<CommandInput placeholder={_(msg`Search languages...`)} />
|
|
|
|
<CommandList>
|
|
<CommandGroup>
|
|
{Object.values(SUPPORTED_LANGUAGES).map((language) => (
|
|
<CommandItem
|
|
key={language.short}
|
|
value={language.full}
|
|
onSelect={async () => setLanguage(language.short)}
|
|
>
|
|
<CheckIcon
|
|
className={cn(
|
|
'mr-2 h-4 w-4',
|
|
i18n.locale === language.short ? 'opacity-100' : 'opacity-0',
|
|
)}
|
|
/>
|
|
{SUPPORTED_LANGUAGES[language.short].full}
|
|
</CommandItem>
|
|
))}
|
|
</CommandGroup>
|
|
</CommandList>
|
|
</CommandDialog>
|
|
);
|
|
};
|