TradingAgents/frontend/app/layout.tsx

75 lines
2.6 KiB
TypeScript

import type { Metadata } from "next";
import { Inter } from "next/font/google";
import "./globals.css";
import { Header } from "@/components/layout/Header";
import { Footer } from "@/components/layout/Footer";
import { AnalysisProvider } from "@/context/AnalysisContext";
import { ThemeProvider } from "@/components/theme/ThemeProvider";
import { AuthProvider } from "@/contexts/auth-context";
const inter = Inter({ subsets: ["latin"] });
export const metadata: Metadata = {
title: "TradingAgentsX - 多代理 LLM 金融交易",
description: "由 AI 驅動的多代理 LLM 金融交易框架",
icons: {
icon: [
{ url: "/favicon.ico", sizes: "32x32" },
{ url: "/icon-192.png", sizes: "192x192", type: "image/png" },
{ url: "/icon-512.png", sizes: "512x512", type: "image/png" },
{ url: "/icon.png", sizes: "1024x1024", type: "image/png" },
],
apple: [
{ url: "/apple-touch-icon.png", sizes: "180x180", type: "image/png" },
],
shortcut: "/favicon.ico",
},
appleWebApp: {
capable: true,
statusBarStyle: "black-translucent",
title: "TAgentsX",
},
openGraph: {
title: "TradingAgentsX - 多代理 LLM 金融交易",
description: "由 AI 驅動的多代理 LLM 金融交易框架",
siteName: "TradingAgentsX",
type: "website",
},
};
export default function RootLayout({
children,
}: Readonly<{
children: React.ReactNode;
}>) {
return (
<html lang="en" suppressHydrationWarning>
<head>
<meta name="viewport" content="width=device-width, initial-scale=1, viewport-fit=cover" />
<link rel="manifest" href="/manifest.json" />
<meta name="theme-color" content="#6B21A8" />
<meta name="apple-mobile-web-app-capable" content="yes" />
<meta name="apple-mobile-web-app-status-bar-style" content="black-translucent" />
<meta name="apple-mobile-web-app-title" content="TAgentsX" />
<link rel="apple-touch-icon" href="/apple-touch-icon.png" />
<link rel="apple-touch-icon" sizes="180x180" href="/apple-touch-icon.png" />
<link rel="apple-touch-icon" sizes="152x152" href="/apple-touch-icon.png" />
<link rel="apple-touch-icon" sizes="120x120" href="/apple-touch-icon.png" />
</head>
<body className={inter.className}>
<ThemeProvider>
<AuthProvider>
<AnalysisProvider>
<div className="flex flex-col min-h-screen gradient-page-bg">
<Header />
<main className="flex-1">{children}</main>
<Footer />
</div>
</AnalysisProvider>
</AuthProvider>
</ThemeProvider>
</body>
</html>
);
}