Implement internationalization support across components

- Integrated `next-intl` for toast messages and locale handling in various components, including `Providers`, `CanvasUserMenu`, and `CreditOverview`.
- Replaced hardcoded strings with translation keys to enhance localization capabilities.
- Updated `RootLayout` to dynamically set the language attribute based on the user's locale.
- Ensured consistent user feedback through localized toast messages in actions such as sign-out, canvas operations, and billing notifications.
This commit is contained in:
2026-04-01 18:16:52 +02:00
parent 6ce1d4a82e
commit 79d9092d43
44 changed files with 1385 additions and 507 deletions

View File

@@ -3,10 +3,11 @@
import { authClient } from "@/lib/auth-client";
import { useRouter } from "next/navigation";
import Link from "next/link";
import { useTranslations } from "next-intl";
import { toast } from "@/lib/toast";
import { msg } from "@/lib/toast-messages";
export default function Home() {
const t = useTranslations('toasts');
const { data: session, isPending } = authClient.useSession();
const router = useRouter();
@@ -35,7 +36,7 @@ export default function Home() {
</Link>
<button
onClick={() => {
toast.info(msg.auth.signedOut.title);
toast.info(t('auth.signedOut'));
void authClient.signOut().then(() => router.refresh());
}}
className="rounded-lg border border-border px-6 py-3 text-sm hover:bg-accent"