mirror of
https://github.com/documenso/documenso.git
synced 2025-11-14 00:32:43 +10:00
42 lines
1.3 KiB
TypeScript
42 lines
1.3 KiB
TypeScript
import React from 'react';
|
|
|
|
import { setupI18nSSR } from '@documenso/lib/client-only/providers/i18n.server';
|
|
import { getServerComponentSession } from '@documenso/lib/next-auth/get-server-component-session';
|
|
import type { TGetTeamsResponse } from '@documenso/lib/server-only/team/get-teams';
|
|
import { getTeams } from '@documenso/lib/server-only/team/get-teams';
|
|
|
|
import { Header as AuthenticatedHeader } from '~/components/(dashboard)/layout/header';
|
|
import { NextAuthProvider } from '~/providers/next-auth';
|
|
|
|
type RecipientLayoutProps = {
|
|
children: React.ReactNode;
|
|
};
|
|
|
|
/**
|
|
* A layout to handle scenarios where the user is a recipient of a given resource
|
|
* where we do not care whether they are authenticated or not.
|
|
*
|
|
* Such as direct template access, or signing.
|
|
*/
|
|
export default async function RecipientLayout({ children }: RecipientLayoutProps) {
|
|
await setupI18nSSR();
|
|
|
|
const { user, session } = await getServerComponentSession();
|
|
|
|
let teams: TGetTeamsResponse = [];
|
|
|
|
if (user && session) {
|
|
teams = await getTeams({ userId: user.id });
|
|
}
|
|
|
|
return (
|
|
<NextAuthProvider session={session}>
|
|
<div className="min-h-screen">
|
|
{user && <AuthenticatedHeader user={user} teams={teams} />}
|
|
|
|
<main className="mb-8 mt-8 px-4 md:mb-12 md:mt-12 md:px-8">{children}</main>
|
|
</div>
|
|
</NextAuthProvider>
|
|
);
|
|
}
|