- Add /account route with profile form (firstName, lastName, address, IBAN) - Create UserProfile type and MongoDB users collection - Implement server actions for getting and updating user profile - Add Account Circle icon to PageHeader linking to /account - Install Material UI icons for account icon - Add form input disabling during save with loading spinner - Add cancel button to discard changes and return home - Add English and Croatian translations for account page - Update locale names with flag emojis in language selector 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
30 lines
1.1 KiB
TypeScript
30 lines
1.1 KiB
TypeScript
import {notFound} from 'next/navigation';
|
|
import {getRequestConfig} from 'next-intl/server';
|
|
import { Formats, TranslationValues } from 'next-intl';
|
|
|
|
// Can be imported from a shared config
|
|
export const locales = ['en', 'hr'];
|
|
|
|
export const localeNames:Record<string,string> = {
|
|
en: '🇬🇧 En',
|
|
hr: '🇭🇷 Hr'
|
|
};
|
|
|
|
export const defaultLocale = 'hr';
|
|
|
|
/** Templating function type as returned by `useTemplate` and `getTranslations` */
|
|
export type IntlTemplateFn =
|
|
// this function type if returned by `useTransations`
|
|
(<TargetKey extends any>(key: TargetKey, values?: TranslationValues | undefined, formats?: Partial<Formats> | undefined) => string) |
|
|
// this functon type if returned by `getTranslations`
|
|
(<TargetKey extends any>(key: [TargetKey] extends [never] ? string : TargetKey, values?: TranslationValues | undefined, formats?: Partial<Formats> | undefined) => string);
|
|
|
|
|
|
export default getRequestConfig(async ({locale}) => {
|
|
// Validate that the incoming `locale` parameter is valid
|
|
if (!locales.includes(locale as any)) notFound();
|
|
|
|
return {
|
|
messages: (await import(`../messages/${locale}.json`)).default
|
|
};
|
|
}); |