layout.tsx 1.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. import type { Metadata } from "next";
  2. import { Geist, Geist_Mono } from "next/font/google";
  3. import React from "react";
  4. import "./globals.scss";
  5. import { SignalRProvider } from '@/contexts/signalrProvider';
  6. import { AuthProvider } from "@/contexts/authProvider";
  7. import { MemberProvider } from "@/contexts/memberProvider";
  8. import { ConfigProvider } from "@/contexts/configProvider";
  9. import { getAccessToken, getSignalRUrl } from "@/lib/utils/server";
  10. const geistSans = Geist({
  11. variable: "--font-geist-sans",
  12. subsets: ["latin"],
  13. });
  14. const geistMono = Geist_Mono({
  15. variable: "--font-geist-mono",
  16. subsets: ["latin"],
  17. });
  18. export const metadata: Metadata = {
  19. title: "DPOT.LIVE",
  20. description: "Generated by create next app",
  21. keywords: "nextjs, typescript, tailwindcss",
  22. robots: {
  23. index: true,
  24. follow: true,
  25. nocache: true
  26. }
  27. };
  28. export default async function RootLayout({
  29. children,
  30. }: Readonly<{
  31. children: React.ReactNode;
  32. }>) {
  33. const accessToken = await getAccessToken();
  34. const signalRUrl = await getSignalRUrl();
  35. return (
  36. <html lang="ko">
  37. <body className={`${geistSans.variable} ${geistMono.variable} antialiased`}>
  38. <SignalRProvider accessToken={accessToken} signalRUrl={signalRUrl}>
  39. <AuthProvider>
  40. <MemberProvider>
  41. <ConfigProvider>
  42. {children}
  43. </ConfigProvider>
  44. </MemberProvider>
  45. </AuthProvider>
  46. </SignalRProvider>
  47. </body>
  48. </html>
  49. );
  50. }