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
67 lines
1.7 KiB
TypeScript
67 lines
1.7 KiB
TypeScript
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';
|
|
|
|
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;
|
|
|
|
export const generateMetadata = async () => {
|
|
const t = await getTranslations('account');
|
|
const title = t('settingsTab');
|
|
|
|
return {
|
|
title,
|
|
};
|
|
};
|
|
|
|
interface TeamProfileSettingsPageProps {
|
|
params: Promise<{ account: string }>;
|
|
}
|
|
|
|
async function TeamProfileSettingsPage({
|
|
params,
|
|
}: TeamProfileSettingsPageProps) {
|
|
const [user, { account }] = await Promise.all([
|
|
requireUserInServerComponent(),
|
|
params,
|
|
]);
|
|
|
|
const profilePath = pathsConfig.app.accountProfileSettings.replace(
|
|
'[account]',
|
|
account,
|
|
);
|
|
|
|
const paths = {
|
|
callback: pathsConfig.auth.callback + `?next=${profilePath}`,
|
|
};
|
|
|
|
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 TeamProfileSettingsPage;
|