Version 3 of the kit: - Radix UI replaced with Base UI (using the Shadcn UI patterns) - next-intl replaces react-i18next - enhanceAction deprecated; usage moved to next-safe-action - main layout now wrapped with [locale] path segment - Teams only mode - Layout updates - Zod v4 - Next.js 16.2 - Typescript 6 - All other dependencies updated - Removed deprecated Edge CSRF - Dynamic Github Action runner
59 lines
1.6 KiB
TypeScript
59 lines
1.6 KiB
TypeScript
import { use } from 'react';
|
|
|
|
import { getTranslations } from 'next-intl/server';
|
|
|
|
import { PersonalAccountSettingsContainer } from '@kit/accounts/personal-account-settings';
|
|
|
|
import authConfig from '~/config/auth.config';
|
|
import featureFlagsConfig from '~/config/feature-flags.config';
|
|
import pathsConfig from '~/config/paths.config';
|
|
import { requireUserInServerComponent } from '~/lib/server/require-user-in-server-component';
|
|
|
|
// Show email option if password, magic link, or OTP is enabled
|
|
const showEmailOption =
|
|
authConfig.providers.password ||
|
|
authConfig.providers.magicLink ||
|
|
authConfig.providers.otp;
|
|
|
|
const features = {
|
|
showLinkEmailOption: showEmailOption,
|
|
enablePasswordUpdate: authConfig.providers.password,
|
|
enableAccountDeletion: featureFlagsConfig.enableAccountDeletion,
|
|
enableAccountLinking: authConfig.enableIdentityLinking,
|
|
};
|
|
|
|
const providers = authConfig.providers.oAuth;
|
|
|
|
const callbackPath = pathsConfig.auth.callback;
|
|
const accountSettingsPath = pathsConfig.app.accountSettings;
|
|
|
|
const paths = {
|
|
callback: callbackPath + `?next=${accountSettingsPath}`,
|
|
};
|
|
|
|
export const generateMetadata = async () => {
|
|
const t = await getTranslations('account');
|
|
const title = t('settingsTab');
|
|
|
|
return {
|
|
title,
|
|
};
|
|
};
|
|
|
|
function PersonalAccountSettingsPage() {
|
|
const user = use(requireUserInServerComponent());
|
|
|
|
return (
|
|
<div className={'flex w-full flex-1 flex-col lg:max-w-2xl'}>
|
|
<PersonalAccountSettingsContainer
|
|
userId={user.id}
|
|
features={features}
|
|
paths={paths}
|
|
providers={providers}
|
|
/>
|
|
</div>
|
|
);
|
|
}
|
|
|
|
export default PersonalAccountSettingsPage;
|