35 lines
1.2 KiB
TypeScript
35 lines
1.2 KiB
TypeScript
import type { Metadata } from "next";
|
|
import { Geist, Geist_Mono } from "next/font/google";
|
|
import "./globals.css";
|
|
import Sidebar from "@/components/Sidebar";
|
|
import { AuthProvider } from "@/lib/auth";
|
|
import AuthHeader from "@/components/AuthHeader";
|
|
|
|
const geistSans = Geist({ variable: "--font-geist-sans", subsets: ["latin"] });
|
|
const geistMono = Geist_Mono({ variable: "--font-geist-mono", subsets: ["latin"] });
|
|
|
|
export const metadata: Metadata = {
|
|
title: "Arbitrage Engine",
|
|
description: "Funding rate arbitrage monitoring system",
|
|
};
|
|
|
|
export default function RootLayout({ children }: Readonly<{ children: React.ReactNode }>) {
|
|
return (
|
|
<html lang="zh">
|
|
<body className={`${geistSans.variable} ${geistMono.variable} antialiased min-h-screen bg-slate-50 text-slate-900`}>
|
|
<AuthProvider>
|
|
<div className="flex min-h-screen">
|
|
<Sidebar />
|
|
<div className="flex-1 flex flex-col min-w-0">
|
|
<AuthHeader />
|
|
<main className="flex-1 p-4 md:p-6 pt-16 md:pt-6">
|
|
{children}
|
|
</main>
|
|
</div>
|
|
</div>
|
|
</AuthProvider>
|
|
</body>
|
|
</html>
|
|
);
|
|
}
|