FPSMS-frontend
您最多选择25个主题 主题必须以字母或数字开头,可以包含连字符 (-),并且长度不得超过35个字符
 
 
 

68 行
2.2 KiB

  1. import AppBar from "@/components/AppBar";
  2. import { AuthOptions, getServerSession } from "next-auth";
  3. import { authOptions, SessionWithTokens } from "@/config/authConfig";
  4. import { redirect } from "next/navigation";
  5. import Box from "@mui/material/Box";
  6. import { NAVIGATION_CONTENT_WIDTH } from "@/config/uiConfig";
  7. import Stack from "@mui/material/Stack";
  8. import Breadcrumb from "@/components/Breadcrumb";
  9. import { AxiosProvider } from "@/app/(main)/axios/AxiosProvider";
  10. import { SetupAxiosInterceptors } from "@/app/(main)/axios/axiosInstance";
  11. import { CameraProvider } from "@/components/Cameras/CameraProvider";
  12. import { UploadProvider } from "@/components/UploadProvider/UploadProvider";
  13. import SessionProviderWrapper from "@/components/SessionProviderWrapper/SessionProviderWrapper";
  14. import QrCodeScannerProvider from "@/components/QrCodeScannerProvider/QrCodeScannerProvider";
  15. import { I18nProvider } from "@/i18n";
  16. export default async function MainLayout({
  17. children,
  18. }: {
  19. children: React.ReactNode;
  20. }) {
  21. const session = await getServerSession<AuthOptions, SessionWithTokens>(authOptions);
  22. if (!session?.user) {
  23. redirect("/login");
  24. }
  25. // console.log(session?.user);
  26. // Verify if the session is valid
  27. if (session) {
  28. SetupAxiosInterceptors(session.accessToken);
  29. }
  30. return (
  31. <SessionProviderWrapper session={session}>
  32. <UploadProvider>
  33. <CameraProvider>
  34. <AxiosProvider>
  35. <QrCodeScannerProvider>
  36. <>
  37. <AppBar
  38. profileName={session.user.name!}
  39. avatarImageSrc={session.user.image || undefined}
  40. />
  41. <Box
  42. component="main"
  43. sx={{
  44. marginInlineStart: { xs: 0, xl: NAVIGATION_CONTENT_WIDTH },
  45. padding: { xs: "1rem", sm: "1.5rem", lg: "3rem" },
  46. }}
  47. >
  48. <Stack spacing={2}>
  49. <I18nProvider namespaces={["common"]}>
  50. <Breadcrumb />
  51. </I18nProvider>
  52. {children}
  53. </Stack>
  54. </Box>
  55. </>
  56. </QrCodeScannerProvider>
  57. </AxiosProvider>
  58. </CameraProvider>
  59. </UploadProvider>
  60. </SessionProviderWrapper>
  61. );
  62. }