Files
pfadi-bussle/pages/_app.tsx
Thomas Ruoff 0486b99b3e use @next/mdx
2024-03-13 23:49:26 +01:00

52 lines
1.3 KiB
TypeScript

import { AxiomWebVitals } from 'next-axiom'
import { Analytics } from '@vercel/analytics/react';
import { useEffect } from 'react'
import type { AppProps } from 'next/app'
import { useSession, signIn, SessionProvider } from 'next-auth/react'
import Layout from '../components/layout';
import '../styles/index.css'
import '../styles/gfm.css'
function Auth({ children }) {
const { data: session, status } = useSession()
const isUser = !!session?.user
useEffect(() => {
if (status === 'loading') return // Do nothing while loading
if (!isUser) signIn() // If not authenticated, force log in
}, [isUser, status])
if (isUser) {
return children
}
// Session is being fetched, or no user.
// If no user, useEffect() will redirect.
return <div>Loading...</div>
}
export default function MyApp({
Component,
pageProps: { session, ...pageProps },
}) {
return (
<div className="flex flex-col min-h-screen">
<SessionProvider session={session}>
<Layout>
{Component.authenticationRequired ? (
<Auth>
<Component {...pageProps} />
</Auth>
) : (
<Component {...pageProps} />
)}
<Analytics />
</Layout>
</SessionProvider>
<AxiomWebVitals />
</div>
)
}