71 lines
No EOL
2.1 KiB
TypeScript
71 lines
No EOL
2.1 KiB
TypeScript
import React from 'react'
|
|
import { Metadata, Viewport } from 'next'
|
|
import './globals.css'
|
|
import { GeistSans } from 'geist/font/sans'
|
|
import AnimatedTitle from '../components/AnimatedTitle'
|
|
import I18nProvider from '../components/I18nProvider'
|
|
|
|
export const metadata: Metadata = {
|
|
title: 'aidxn.cc',
|
|
description: "The Internet home of Aidan. Come on in!",
|
|
authors: [{ name: 'aidxn.cc' }],
|
|
robots: 'index, follow',
|
|
metadataBase: new URL('https://aidxn.cc'),
|
|
openGraph: {
|
|
type: "website",
|
|
url: "https://aidxn.cc",
|
|
title: "aidxn.cc",
|
|
description: "The Internet home of Aidan. Come on in!",
|
|
siteName: "aidxn.cc",
|
|
images: [
|
|
{
|
|
url: "https://aidxn.cc/android-icon-192x192.png",
|
|
width: 192,
|
|
height: 192,
|
|
},
|
|
],
|
|
},
|
|
icons: {
|
|
icon: [
|
|
{ url: '/favicon-16x16.png', sizes: '16x16', type: 'image/png' },
|
|
{ url: '/favicon-32x32.png', sizes: '32x32', type: 'image/png' },
|
|
{ url: '/favicon-96x96.png', sizes: '96x96', type: 'image/png' },
|
|
{ url: '/android-icon-192x192.png', sizes: '192x192', type: 'image/png' },
|
|
],
|
|
apple: [
|
|
{ url: '/apple-icon-57x57.png', sizes: '57x57' },
|
|
{ url: '/apple-icon-60x60.png', sizes: '60x60' },
|
|
{ url: '/apple-icon-72x72.png', sizes: '72x72' },
|
|
{ url: '/apple-icon-76x76.png', sizes: '76x76' },
|
|
{ url: '/apple-icon-114x114.png', sizes: '114x114' },
|
|
{ url: '/apple-icon-120x120.png', sizes: '120x120' },
|
|
{ url: '/apple-icon-144x144.png', sizes: '144x144' },
|
|
{ url: '/apple-icon-152x152.png', sizes: '152x152' },
|
|
{ url: '/apple-icon-180x180.png', sizes: '180x180' },
|
|
],
|
|
},
|
|
manifest: '/manifest.json',
|
|
}
|
|
|
|
export const viewport: Viewport = {
|
|
themeColor: '#111827',
|
|
width: 'device-width',
|
|
initialScale: 1,
|
|
}
|
|
|
|
export default function RootLayout({
|
|
children,
|
|
}: {
|
|
children: React.ReactNode
|
|
}) {
|
|
return (
|
|
<html lang="en" className="dark">
|
|
<body className={`${GeistSans.className} bg-gray-900 text-gray-100`}>
|
|
<AnimatedTitle />
|
|
<I18nProvider>
|
|
{children}
|
|
</I18nProvider>
|
|
</body>
|
|
</html>
|
|
);
|
|
} |