init: layout with simple side navigation
This commit is contained in:
@@ -1,10 +1,15 @@
|
||||
"use client";
|
||||
|
||||
import "./globals.css";
|
||||
import type { Metadata } from "next";
|
||||
import localFont from "next/font/local";
|
||||
import * as React from "react";
|
||||
import { CssBaseline, ThemeProvider } from "@mui/material";
|
||||
import { ChangeEvent, useState } from "react";
|
||||
|
||||
import { StyledEngineProvider } from "@mui/material/styles";
|
||||
import cx from "classnames";
|
||||
// import { tw } from "../utils/tailwind";
|
||||
|
||||
import { darkTheme, lightTheme } from "./theme/themes";
|
||||
import { Sidebar } from "@/components/sidebar";
|
||||
|
||||
const roboto = localFont({
|
||||
src: [
|
||||
@@ -13,49 +18,42 @@ const roboto = localFont({
|
||||
weight: "400",
|
||||
style: "normal",
|
||||
},
|
||||
// {
|
||||
// path: "./Roboto-Italic.woff2",
|
||||
// weight: "400",
|
||||
// style: "italic",
|
||||
// },
|
||||
// {
|
||||
// path: "./Roboto-Bold.woff2",
|
||||
// weight: "700",
|
||||
// style: "normal",
|
||||
// },
|
||||
// {
|
||||
// path: "./Roboto-BoldItalic.woff2",
|
||||
// weight: "700",
|
||||
// style: "italic",
|
||||
// },
|
||||
],
|
||||
});
|
||||
|
||||
export const metadata: Metadata = {
|
||||
title: "Create Next App",
|
||||
description: "Generated by create next app",
|
||||
};
|
||||
|
||||
export default function RootLayout({
|
||||
children,
|
||||
}: {
|
||||
children: React.ReactNode;
|
||||
}) {
|
||||
let [useDarkTheme, setUseDarkTheme] = useState(false);
|
||||
let [theme, setTheme] = useState(useDarkTheme ? darkTheme : lightTheme);
|
||||
|
||||
const changeThemeHandler = (target: ChangeEvent, currentValue: boolean) => {
|
||||
setUseDarkTheme(currentValue);
|
||||
setTheme(currentValue ? darkTheme : lightTheme);
|
||||
};
|
||||
|
||||
return (
|
||||
<html lang="en">
|
||||
<head>
|
||||
<title>Clan.lol</title>
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
||||
<meta name="description" content="Clan.lol - build your own network" />
|
||||
<link rel="icon" href="/favicon.ico" />
|
||||
</head>
|
||||
<StyledEngineProvider injectFirst>
|
||||
<body
|
||||
className={cx(
|
||||
"h-screen",
|
||||
"min-h-screen",
|
||||
"w-screen",
|
||||
"bg-white",
|
||||
// custom animation defined in tailwind.config
|
||||
roboto.className
|
||||
)}
|
||||
>
|
||||
{children}
|
||||
</body>
|
||||
<ThemeProvider theme={theme}>
|
||||
<body id="__next" className={roboto.className}>
|
||||
<CssBaseline />
|
||||
<div className="flex h-screen overflow-hidden">
|
||||
<Sidebar />
|
||||
<div className="relative flex flex-1 flex-col overflow-y-auto overflow-x-hidden">
|
||||
<main>{children}</main>
|
||||
</div>
|
||||
</div>
|
||||
</body>
|
||||
</ThemeProvider>
|
||||
</StyledEngineProvider>
|
||||
</html>
|
||||
);
|
||||
|
||||
Reference in New Issue
Block a user