link-stack/apps/link/components/Sidebar.tsx

518 lines
14 KiB
TypeScript
Raw Normal View History

2022-12-14 13:24:50 +01:00
import { FC, useState } from "react";
2022-12-02 10:55:56 +00:00
import {
Box,
Grid,
Typography,
List,
2022-12-14 13:24:50 +01:00
ListItemButton,
2022-12-02 10:55:56 +00:00
ListItemIcon,
ListItemText,
2022-12-14 13:24:50 +01:00
ListItemSecondaryAction,
2022-12-02 10:55:56 +00:00
Drawer,
2022-12-14 13:24:50 +01:00
Collapse,
2022-12-02 10:55:56 +00:00
} from "@mui/material";
2022-12-02 17:45:14 +01:00
import {
FeaturedPlayList as FeaturedPlayListIcon,
Person as PersonIcon,
Analytics as AnalyticsIcon,
Logout as LogoutIcon,
Cottage as CottageIcon,
Settings as SettingsIcon,
2023-01-11 16:18:56 +01:00
ExpandCircleDown as ExpandCircleDownIcon,
2022-12-02 17:45:14 +01:00
} from "@mui/icons-material";
2022-12-14 13:24:50 +01:00
import { useRouter } from "next/router";
2022-12-02 10:55:56 +00:00
import Link from "next/link";
2022-12-14 13:24:50 +01:00
import Image from "next/image";
import LinkLogo from "public/link-logo-small.png";
2023-02-22 13:05:52 +00:00
import { useSession } from "next-auth/react";
2022-12-02 10:55:56 +00:00
2022-12-14 13:24:50 +01:00
const openWidth = 270;
const closedWidth = 100;
const MenuItem = ({
name,
href,
Icon,
iconSize,
inset = false,
selected = false,
2023-01-11 16:18:56 +01:00
open = true,
2022-12-14 13:24:50 +01:00
badge,
}: any) => (
<Link href={href}>
<ListItemButton
2023-01-11 16:18:56 +01:00
sx={{
p: 0,
mb: 1,
bl: iconSize === 0 ? "1px solid white" : "inherit",
}}
2022-12-14 13:24:50 +01:00
selected={selected}
>
{iconSize > 0 ? (
<ListItemIcon
sx={{
color: `white`,
minWidth: 0,
mr: 2,
2023-01-11 16:18:56 +01:00
textAlign: "center",
margin: open ? "0 8 0 0" : "0 auto",
2022-12-14 13:24:50 +01:00
}}
>
<Box
sx={{
width: iconSize,
height: iconSize,
mr: 0.5,
mt: "-4px",
}}
>
<Icon />
</Box>
</ListItemIcon>
) : (
2022-12-02 10:55:56 +00:00
<Box
sx={{
2022-12-14 13:24:50 +01:00
width: 30,
height: "28px",
position: "relative",
ml: "9px",
mr: "1px",
2022-12-02 10:55:56 +00:00
}}
>
2022-12-14 13:24:50 +01:00
<Box
sx={{
width: "1px",
height: "56px",
backgroundColor: "white",
position: "absolute",
left: "3px",
top: "-10px",
}}
/>
<Box
sx={{
width: "42px",
height: "42px",
position: "absolute",
top: "-27px",
left: "3px",
border: "solid 1px #fff",
borderColor: "transparent transparent transparent #fff",
borderRadius: "60px",
rotate: "-35deg",
}}
/>
2022-12-02 10:55:56 +00:00
</Box>
2022-12-14 13:24:50 +01:00
)}
2023-01-11 16:18:56 +01:00
{open && (
<ListItemText
inset={inset}
primary={
<Typography
variant="body1"
sx={{
fontSize: 16,
fontFamily: "Roboto",
fontWeight: "bold",
border: 0,
textAlign: "left",
color: "white"
2023-01-11 16:18:56 +01:00
}}
>
{name}
</Typography>
}
/>
)}
2022-12-14 13:24:50 +01:00
{badge && (
<ListItemSecondaryAction>
<Typography
color="textSecondary"
variant="body1"
className="badge"
sx={{
backgroundColor: "#FFB620",
color: "black !important",
borderRadius: 10,
px: 1,
fontSize: 12,
fontWeight: "bold",
}}
>
{badge}
</Typography>
</ListItemSecondaryAction>
)}
</ListItemButton>
2022-12-02 10:55:56 +00:00
</Link>
);
interface SidebarProps {
open: boolean;
2023-01-11 16:18:56 +01:00
setOpen: (open: boolean) => void;
2022-12-02 10:55:56 +00:00
}
2023-01-11 16:18:56 +01:00
export const Sidebar: FC<SidebarProps> = ({ open, setOpen }) => {
2022-12-14 13:24:50 +01:00
const { pathname } = useRouter();
2023-02-22 13:05:52 +00:00
const { data: session } = useSession()
const username = session?.user?.name || "User"
2023-01-11 16:18:56 +01:00
2022-12-14 13:24:50 +01:00
return (
<Drawer
sx={{ width: open ? openWidth : closedWidth, flexShrink: 0 }}
variant="permanent"
anchor="left"
open={open}
PaperProps={{
sx: {
width: open ? openWidth : closedWidth,
border: 0,
2023-01-11 16:18:56 +01:00
overflow: "visible",
2022-12-14 13:24:50 +01:00
},
}}
2022-12-02 10:55:56 +00:00
>
2023-01-11 16:18:56 +01:00
<Box
sx={{
position: "absolute",
top: 20,
right: open ? -8 : -16,
color: "#1C75FD",
rotate: open ? "90deg" : "-90deg",
}}
onClick={() => {
setOpen!(!open);
}}
>
<ExpandCircleDownIcon
sx={{
width: 30,
height: 30,
background: "white",
borderRadius: 500,
}}
/>
</Box>
2022-12-14 13:24:50 +01:00
<Grid
container
direction="column"
justifyContent="space-between"
wrap="nowrap"
sx={{ backgroundColor: "#25272A", height: "100%", p: 2 }}
>
<Grid item container>
2023-01-11 16:18:56 +01:00
<Grid item sx={{ width: open ? "40px" : "100%" }}>
<Box
sx={{
width: "40px",
height: "40px",
margin: open ? "0" : "0 auto",
}}
>
2022-12-14 13:24:50 +01:00
<Image
src={LinkLogo}
alt="Link logo"
width={40}
height={40}
style={{
objectFit: "cover",
filter: "grayscale(100) brightness(100)",
}}
/>
</Box>
.
</Grid>
2023-01-11 16:18:56 +01:00
{open && (
<Grid item>
<Typography
variant="h2"
sx={{
fontSize: 26,
color: "white",
fontWeight: 700,
mt: 1,
ml: 0.5,
fontFamily: "Poppins",
}}
>
CDR Link
</Typography>
</Grid>
)}
2022-12-14 13:24:50 +01:00
</Grid>
<Grid item>
<Box
2022-12-02 17:45:14 +01:00
sx={{
2022-12-14 13:24:50 +01:00
height: "0.5px",
width: "100%",
backgroundColor: "#666",
mb: 1,
2022-12-02 17:45:14 +01:00
}}
/>
2022-12-14 13:24:50 +01:00
</Grid>
<Grid item>
<Typography
variant="h6"
2023-01-11 16:18:56 +01:00
sx={{
fontSize: 12,
color: "#999",
fontWeight: "bold",
textAlign: open ? "left" : "center",
}}
2022-12-14 13:24:50 +01:00
>
Hello
</Typography>
</Grid>
<Grid item>
<Typography
variant="h2"
2023-01-11 16:18:56 +01:00
sx={{
fontSize: 22,
color: "white",
mb: 1.5,
fontWeight: "bold",
textAlign: open ? "left" : "center",
}}
2022-12-14 13:24:50 +01:00
>
2023-01-11 16:18:56 +01:00
{open
? username
: username
2023-02-22 13:05:52 +00:00
.split(" ")
.map((name) => name.substring(0, 1))
.join("")}
2022-12-14 13:24:50 +01:00
</Typography>
</Grid>
<Grid item>
<Box
sx={{ height: "0.5px", width: "100%", backgroundColor: "#666" }}
2022-12-02 17:45:14 +01:00
/>
2022-12-14 13:24:50 +01:00
</Grid>
<Grid item container direction="column" sx={{ mt: "6px" }} flexGrow={1}>
<List
component="nav"
sx={{
a: {
textDecoration: "none",
".MuiListItemButton-root": {
p: 1,
borderRadius: 2,
"&:hover": {
background: "#555",
},
".MuiTypography-root": {
p: {
color: "#999 !important",
fontSize: 16,
},
},
".badge": {
p: { fontSize: 12, color: "black !important" },
},
},
".Mui-selected": {
background: "#444",
color: "#fff !important",
".MuiTypography-root": {
p: {
color: "#fff !important",
fontSize: 16,
},
},
".badge": {
p: { fontSize: 12, color: "black !important" },
},
},
},
}}
>
<MenuItem
name="Home"
href="/"
Icon={CottageIcon}
iconSize={20}
selected={pathname.endsWith("/")}
2023-01-11 16:18:56 +01:00
open={open}
2022-12-14 13:24:50 +01:00
/>
<MenuItem
name="Tickets"
href="/tickets/assigned"
Icon={FeaturedPlayListIcon}
selected={pathname.startsWith("/tickets")}
iconSize={20}
2023-01-11 16:18:56 +01:00
open={open}
2022-12-14 13:24:50 +01:00
/>
<Collapse
in={pathname.startsWith("/tickets")}
timeout="auto"
unmountOnExit
onClick={undefined}
>
<List component="div" disablePadding>
<MenuItem
name="Assigned"
href="/tickets/assigned"
Icon={FeaturedPlayListIcon}
iconSize={0}
selected={pathname.endsWith("/tickets/assigned")}
badge={3}
2023-01-11 16:18:56 +01:00
open={open}
2022-12-14 13:24:50 +01:00
/>
<MenuItem
name="Urgent"
href="/tickets/urgent"
Icon={FeaturedPlayListIcon}
iconSize={0}
selected={pathname.endsWith("/tickets/urgent")}
badge={1}
2023-01-11 16:18:56 +01:00
open={open}
2022-12-14 13:24:50 +01:00
/>
<MenuItem
name="Pending"
href="/tickets/pending"
Icon={FeaturedPlayListIcon}
iconSize={0}
selected={pathname.endsWith("/tickets/pending")}
badge={9}
2023-01-11 16:18:56 +01:00
open={open}
2022-12-14 13:24:50 +01:00
/>
<MenuItem
name="Unassigned"
href="/tickets/unassigned"
Icon={FeaturedPlayListIcon}
iconSize={0}
selected={pathname.endsWith("/tickets/unnassigned")}
badge={27}
2023-01-11 16:18:56 +01:00
open={open}
2022-12-14 13:24:50 +01:00
/>
<MenuItem
name="New Ticket UI"
2023-02-22 13:05:52 +00:00
href="/tickets/2"
2022-12-14 13:24:50 +01:00
Icon={SettingsIcon}
iconSize={0}
2023-02-22 13:05:52 +00:00
selected={pathname.endsWith("/tickets/2")}
2023-01-11 16:18:56 +01:00
open={open}
2022-12-14 13:24:50 +01:00
/>
</List>
</Collapse>
<MenuItem
name="Leafcutter"
href="/leafcutter"
Icon={AnalyticsIcon}
iconSize={20}
selected={pathname.endsWith("/leafcutter")}
2023-01-11 16:18:56 +01:00
open={open}
2022-12-14 13:24:50 +01:00
/>
<Collapse
in={pathname.startsWith("/leafcutter")}
timeout="auto"
unmountOnExit
onClick={undefined}
>
<List component="div" disablePadding>
<MenuItem
name="Dashboard"
href="/leafcutter"
iconSize={0}
selected={pathname.endsWith("/leafcutter")}
2023-01-11 16:18:56 +01:00
open={open}
2022-12-14 13:24:50 +01:00
/>
<MenuItem
name="Search and Create"
href="/leafcutter/create"
iconSize={0}
selected={pathname.endsWith("/leafcutter/create")}
2023-01-11 16:18:56 +01:00
open={open}
2022-12-14 13:24:50 +01:00
/>
<MenuItem
name="Trends"
href="/leafcutter/trends"
iconSize={0}
selected={pathname.endsWith("/leafcutter/trends")}
2023-01-11 16:18:56 +01:00
open={open}
2022-12-14 13:24:50 +01:00
/>
<MenuItem
name="FAQ"
href="/leafcutter/faq"
iconSize={0}
selected={pathname.endsWith("/leafcutter/faq")}
2023-01-11 16:18:56 +01:00
open={open}
2022-12-14 13:24:50 +01:00
/>
<MenuItem
name="About"
href="/leafcutter/about"
Icon={AnalyticsIcon}
iconSize={0}
selected={pathname.endsWith("/leafcutter/about")}
2023-01-11 16:18:56 +01:00
open={open}
2022-12-14 13:24:50 +01:00
/>
</List>
</Collapse>
<MenuItem
name="Profile"
href="/profile"
Icon={PersonIcon}
iconSize={20}
selected={pathname.endsWith("/profile")}
2023-01-11 16:18:56 +01:00
open={open}
2022-12-14 13:24:50 +01:00
/>
<MenuItem
name="Admin"
href="/admin/zammad"
Icon={SettingsIcon}
iconSize={20}
2023-01-11 16:18:56 +01:00
open={open}
2022-12-14 13:24:50 +01:00
/>
<Collapse
in={pathname.startsWith("/admin/")}
timeout="auto"
unmountOnExit
onClick={undefined}
>
<List component="div" disablePadding>
<MenuItem
name="Zammad Settings"
href="/admin/zammad"
Icon={FeaturedPlayListIcon}
iconSize={0}
selected={pathname.endsWith("/admin/zammad")}
2023-01-11 16:18:56 +01:00
open={open}
2022-12-14 13:24:50 +01:00
/>
<MenuItem
name="Metamigo"
href="/admin/metamigo"
Icon={FeaturedPlayListIcon}
iconSize={0}
selected={pathname.endsWith("/admin/metamigo")}
2023-01-11 16:18:56 +01:00
open={open}
2022-12-14 13:24:50 +01:00
/>
<MenuItem
name="Label Studio"
href="/admin/label-studio"
Icon={FeaturedPlayListIcon}
iconSize={0}
selected={pathname.endsWith("/admin/label-studio")}
2023-01-11 16:18:56 +01:00
open={open}
2022-12-14 13:24:50 +01:00
/>
</List>
</Collapse>
<MenuItem
name="Logout"
href="/logout"
Icon={LogoutIcon}
iconSize={20}
2023-01-11 16:18:56 +01:00
open={open}
2022-12-14 13:24:50 +01:00
/>
</List>
</Grid>
2022-12-02 10:55:56 +00:00
</Grid>
2022-12-14 13:24:50 +01:00
</Drawer>
);
};