2025-10-08 20:55:43 +09:00
|
|
|
import type { Metadata } from "next";
|
|
|
|
|
import "./globals.css";
|
2025-10-09 15:13:12 +09:00
|
|
|
import QueryProvider from "@/app/QueryProvider";
|
2025-10-09 15:22:05 +09:00
|
|
|
import { AppHeader } from "@/app/components/AppHeader";
|
|
|
|
|
import { AppSidebar } from "@/app/components/AppSidebar";
|
|
|
|
|
import { AppFooter } from "@/app/components/AppFooter";
|
2025-10-08 20:55:43 +09:00
|
|
|
|
|
|
|
|
|
|
|
|
|
export const metadata: Metadata = {
|
2025-10-08 21:12:12 +09:00
|
|
|
title: "msg App",
|
|
|
|
|
description: "msg App",
|
2025-10-08 20:55:43 +09:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
export default function RootLayout({
|
|
|
|
|
children,
|
|
|
|
|
}: Readonly<{
|
|
|
|
|
children: React.ReactNode;
|
|
|
|
|
}>) {
|
|
|
|
|
return (
|
|
|
|
|
<html lang="en">
|
2025-10-09 15:13:12 +09:00
|
|
|
<body>
|
|
|
|
|
<QueryProvider>
|
2025-10-09 15:22:05 +09:00
|
|
|
<AppHeader />
|
|
|
|
|
<div style={{ display: "flex", minHeight: "80vh" }}>
|
|
|
|
|
<AppSidebar />
|
|
|
|
|
<main style={{ flex: 1, padding: 16 }}>{children}</main>
|
|
|
|
|
</div>
|
|
|
|
|
<AppFooter />
|
2025-10-09 15:13:12 +09:00
|
|
|
</QueryProvider>
|
2025-10-08 20:55:43 +09:00
|
|
|
</body>
|
|
|
|
|
</html>
|
|
|
|
|
);
|
|
|
|
|
}
|