language-selector.tsx 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. "use client";
  2. import { useAction } from "next-safe-action/hooks";
  3. import { Languages } from "lucide-react";
  4. import { useChangeLocale, languages, useI18n } from "locales/client";
  5. import { updateUserAction } from "@/entities/user/model/update-user.action";
  6. const languageFlags: Record<string, string> = {
  7. en: "🇬🇧",
  8. fr: "🇫🇷",
  9. es: "🇪🇸",
  10. };
  11. export function LanguageSelector() {
  12. const action = useAction(updateUserAction);
  13. const changeLocale = useChangeLocale();
  14. const t = useI18n();
  15. const handleLanguageChange = async (newLocale: string) => {
  16. await action.execute({ locale: newLocale });
  17. changeLocale(newLocale as "en" | "fr" | "es");
  18. };
  19. return (
  20. <div className="dropdown dropdown-end">
  21. <div className="tooltip tooltip-bottom" data-tip={t("commons.change_language")}>
  22. <div
  23. className="btn btn-ghost btn-circle h-8 w-8 p-0 text-xl flex items-center justify-center hover:bg-slate-200 border-none dark:hover:bg-gray-800 rounded-full"
  24. role="button"
  25. tabIndex={0}
  26. >
  27. <Languages className="w-5 h-5 text-blue-500 dark:text-blue-400" />
  28. </div>
  29. </div>
  30. <ul
  31. className="mt-3 z-[1] p-2 shadow menu menu-sm dropdown-content bg-base-100 dark:bg-black dark:text-gray-200 rounded-box border border-slate-200 dark:border-gray-800"
  32. tabIndex={0}
  33. >
  34. {languages.map((language) => (
  35. <li className="" key={language}>
  36. <button
  37. className="flex items-center gap-2 text-base hover:bg-slate-200 dark:hover:bg-gray-800 rounded-lg px-3 py-2 transition-colors"
  38. onClick={() => handleLanguageChange(language)}
  39. >
  40. <span className="text-lg">{languageFlags[language]}</span>
  41. <span className="text-base">{language === "en" ? "English" : language === "fr" ? "Français" : "Español"}</span>
  42. </button>
  43. </li>
  44. ))}
  45. </ul>
  46. </div>
  47. );
  48. }