Compare commits

..

No commits in common. "bb751c14760a388f5d980a120d1cdbe301f56da1" and "3ac29ae9094e62a7491e7021d91420df6de4a612" have entirely different histories.

8 changed files with 75 additions and 96 deletions

View File

@ -5,5 +5,5 @@ export const metadata: Metadata = {
}; };
export default async function Page() { export default async function Page() {
return <p>Hello world!</p>; return <p>Classes</p>;
} }

View File

@ -1,41 +1,10 @@
"use client";
import { Sidebar } from "@/app/components/Sidebar"; import { Sidebar } from "@/app/components/Sidebar";
import { Divider } from "@nextui-org/react";
import { usePathname } from "next/navigation";
import { FaDoorClosed, FaRegUser } from "react-icons/fa";
import { FiSettings } from "react-icons/fi";
import { IoMdStats } from "react-icons/io";
import { MdInbox } from "react-icons/md";
export default function Layout({ children }: { children: React.ReactNode }) { export default function Layout({ children }: { children: React.ReactNode }) {
const pathName = usePathname();
const sidebarItems = [
[
{ href: "/admin", title: "Dashboard", icon: <IoMdStats /> },
{ href: "/admin/users", title: "Users", icon: <FaRegUser /> },
{ href: "/admin/classes", title: "Classes", icon: <MdInbox /> },
{ href: "/admin/rooms", title: "Rooms", icon: <FaDoorClosed /> },
],
[{ href: "/admin/settings", title: "Settings", icon: <FiSettings /> }],
];
return ( return (
<div className="flex"> <div className="flex">
<Sidebar items={sidebarItems} /> <Sidebar />
<main className="p-7 w-full"> <main>{children}</main>
<h1 className="text-2xl font-semibold">
{
sidebarItems
.flat()
.find((item) => item.href === pathName)?.title
}
</h1>
<Divider className="mt-2 mb-5 bg-foreground-300" />
{children}
</main>
</div> </div>
); );
} }

View File

@ -5,7 +5,5 @@ export const metadata: Metadata = {
}; };
export default async function Page() { export default async function Page() {
return ( return <p>Admin Home</p>;
<p>Hello world!</p>
);
} }

View File

@ -5,7 +5,5 @@ export const metadata: Metadata = {
}; };
export default async function Page() { export default async function Page() {
return ( return <p>Rooms</p>;
<p>Hello world!</p>
);
} }

View File

@ -5,7 +5,5 @@ export const metadata: Metadata = {
}; };
export default async function Page() { export default async function Page() {
return ( return <p>Settings</p>;
<p>Hello world!</p>
);
} }

View File

@ -6,5 +6,9 @@ export const metadata: Metadata = {
}; };
export default async function Page() { export default async function Page() {
return <UserList />; return (
<div className="p-4">
<UserList />
</div>
);
} }

View File

@ -1,65 +1,77 @@
"use client"; "use client";
import { Divider, Link } from "@nextui-org/react"; import { Divider, Link } from "@nextui-org/react";
import { usePathname, useRouter } from "next/navigation"; import { useRouter } from "next/navigation";
import { FaDoorClosed, FaRegUser } from "react-icons/fa";
import { FiSettings } from "react-icons/fi";
import { IoMdStats } from "react-icons/io";
import { MdInbox } from "react-icons/md";
import { ThemeSwitcher } from "../ThemeSwitcher/ThemeSwitcher"; import { ThemeSwitcher } from "../ThemeSwitcher/ThemeSwitcher";
import { SidebarItem } from "./item"; import { SidebarItem } from "./item";
export const Sidebar = ({ export const Sidebar = () => {
items,
}: {
items: {
href: string;
title: string;
icon: React.ReactNode;
}[][];
}) => {
const router = useRouter(); const router = useRouter();
const pathName = usePathname();
return ( return (
<aside className="h-screen"> <aside className="h-screen">
<div className="flex flex-col w-72 gap-5 h-full px-3 py-4 overflow-y-auto bg-foreground-100"> <div className="flex flex-col w-64 gap-2 h-full px-3 py-4 overflow-y-auto bg-foreground-100">
<div className="flex flex-col gap-2 p-2"> <ul className="font-medium gap-2">
<Link <li>
className="flex text-2xl font-semibold text-gray-900 dark:text-white rounded-lg cursor-pointer" <Link
onPress={() => router.push("/")} className="flex justify-center p-2 text-gray-900 dark:text-white rounded-lg cursor-pointer"
> onPress={() => router.push("/")}
Toogether >
</Link> Toogether
<p className="text-sm text-foreground-400 dark:text-gray-400"> </Link>
Manage classes, rooms, and users </li>
</p> </ul>
</div>
{items.map((group, index) => ( <section className="flex flex-col">
<div key={index}> <ul className="flex flex-col gap-2">
<section className="flex flex-col"> <li className="hover:bg-foreground-300 rounded-md cursor-pointer">
<ul className="flex flex-col gap-2"> <SidebarItem
{group.map((item, index) => ( href="/admin"
<li title="Dashboard"
key={index} icon={<IoMdStats />}
className={`${ />
pathName === item.href </li>
? "bg-foreground-300" <li className="hover:bg-foreground-300 rounded-md cursor-pointer">
: "hover:bg-foreground-200" <SidebarItem
} rounded-md cursor-pointer`} href="/admin/users"
> title="Users"
<SidebarItem icon={<FaRegUser />}
href={item.href} />
title={item.title} </li>
icon={item.icon} <li className="hover:bg-foreground-300 rounded-md cursor-pointer">
/> <SidebarItem
</li> href="/admin/classes"
))} title="Classes"
</ul> icon={<MdInbox />}
</section> />
</li>
<li className="hover:bg-foreground-300 rounded-md cursor-pointer">
<SidebarItem
href="/admin/rooms"
title="Rooms"
icon={<FaDoorClosed />}
/>
</li>
</ul>
</section>
{index < items.length - 1 && ( <Divider className="bg-foreground-300 my-4" />
<Divider className="bg-foreground-300 mt-4" />
)} <section className="flex flex-col">
</div> <ul className="flex flex-col gap-2">
))} <li className="hover:bg-foreground-300 rounded-md cursor-pointer">
<SidebarItem
href="/admin/settings"
title="Settings"
icon={<FiSettings />}
/>
</li>
</ul>
</section>
<section className="mt-auto flex justify-between"> <section className="mt-auto flex justify-between">
<ThemeSwitcher /> <ThemeSwitcher />

View File

@ -17,9 +17,9 @@ export const SidebarItem = ({
<Link <Link
onPress={() => router.push(href)} onPress={() => router.push(href)}
color="foreground" color="foreground"
className="w-full p-2 gap-3 text-md" className="w-full px-2 py-1 gap-2 text-xl"
> >
<span className="text-xl">{icon}</span> {icon}
{title} {title}
</Link> </Link>
); );