forked from CaliCastle/cali.so
-
Notifications
You must be signed in to change notification settings - Fork 0
/
layout.tsx
76 lines (71 loc) · 2.6 KB
/
layout.tsx
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
import '~/app/globals.css'
import { ClerkProvider } from '@clerk/nextjs/app-beta'
import { type Metadata } from 'next'
import { ThemeProvider } from '~/app/ThemeProvider'
import { Footer } from '~/components/layouts/Footer'
import { Header } from '~/components/layouts/Header'
import { sansFont } from '~/lib/font'
export const metadata: Metadata = {
title: 'Cali | 开发者、设计师、细节控、创始人',
description:
'我是 Cali,佐玩创始人,目前带领着佐玩致力于创造一个充满创造力的工作环境,同时鼓励团队创造影响世界的产品。我热爱开发,设计,创新,享受生活,以及在未知领域中探索。',
keywords: 'Cali,Cali Castle,郭晓楠,佐玩,创始人,CEO,开发者,设计师,细节控,创新',
icons: {
icon: '/favicon-32x32.png',
shortcut: '/favicon.ico',
apple: '/apple-touch-icon.png',
},
manifest: '/site.webmanifest',
robots: {
index: true,
follow: true,
googleBot: {
index: true,
follow: true,
'max-video-preview': -1,
'max-image-preview': 'large',
'max-snippet': -1,
},
},
twitter: {
site: '@thecalicastle',
creator: '@thecalicastle',
card: 'summary_large_image',
},
}
export default function RootLayout({
children,
}: {
children: React.ReactNode
}) {
return (
<html
lang="zh"
className={`${sansFont.variable} m-0 h-full p-0 font-sans antialiased`}
suppressHydrationWarning
>
<body className="flex h-full flex-col bg-zinc-50 bg-[url('/grid-black.svg')] bg-top bg-repeat dark:bg-primary-900 dark:bg-[url('/grid.svg')]">
<span className="pointer-events-none fixed top-0 block h-[800px] w-full select-none bg-[radial-gradient(103.72%_46.58%_at_50%_0%,rgba(5,5,5,0.045)_0%,rgba(0,0,0,0)_100%)] dark:bg-[radial-gradient(103.72%_46.58%_at_50%_0%,rgba(255,255,255,0.09)_0%,rgba(255,255,255,0)_100%)]" />
<ThemeProvider
attribute="class"
defaultTheme="system"
enableSystem
disableTransitionOnChange
>
<ClerkProvider>
<div className="fixed inset-0 flex justify-center sm:px-8">
<div className="flex w-full max-w-7xl lg:px-8">
<div className="w-full bg-zinc-50/90 ring-1 ring-zinc-100 dark:bg-zinc-900/80 dark:ring-zinc-400/20" />
</div>
</div>
<div className="relative text-zinc-800 dark:text-zinc-200">
<Header />
<main>{children}</main>
<Footer />
</div>
</ClerkProvider>
</ThemeProvider>
</body>
</html>
)
}