import { useEffect } from "react"; import Link from "next/link"; import Image from "next/image"; import { useRouter } from "next/router"; // mobx import { observer } from "mobx-react-lite"; // components import { NavbarSearch } from "./search"; import { NavbarIssueBoardView } from "./issue-board-view"; import { NavbarTheme } from "./theme"; // ui import { PrimaryButton } from "components/ui"; // lib import { useMobxStore } from "lib/mobx/store-provider"; // store import { RootStore } from "store/root"; const renderEmoji = (emoji: string | { name: string; color: string }) => { if (!emoji) return; if (typeof emoji === "object") return ( <span style={{ color: emoji.color }} className="material-symbols-rounded text-lg"> {emoji.name} </span> ); else return isNaN(parseInt(emoji)) ? emoji : String.fromCodePoint(parseInt(emoji)); }; const IssueNavbar = observer(() => { const { project: projectStore, user: userStore }: RootStore = useMobxStore(); // router const router = useRouter(); const { workspace_slug, project_slug, board } = router.query; const user = userStore?.currentUser; useEffect(() => { if (workspace_slug && project_slug) { projectStore.fetchProjectSettings(workspace_slug.toString(), project_slug.toString()); } }, [projectStore, workspace_slug, project_slug]); useEffect(() => { if (workspace_slug && project_slug) { if (!board) { router.push({ pathname: `/${workspace_slug}/${project_slug}`, query: { board: "list", }, }); return projectStore.setActiveBoard("list"); } projectStore.setActiveBoard(board.toString()); } }, [board, workspace_slug, project_slug]); return ( <div className="px-5 relative w-full flex items-center gap-4"> {/* project detail */} <div className="flex-shrink-0 flex items-center gap-2"> <div className="w-4 h-4 flex justify-center items-center"> {projectStore?.project && projectStore?.project?.emoji ? ( renderEmoji(projectStore?.project?.emoji) ) : ( <Image src="/plane-logo.webp" alt="plane logo" className="w-[24px] h-[24px]" height="24" width="24" /> )} </div> <div className="font-medium text-lg max-w-[300px] line-clamp-1 overflow-hidden"> {projectStore?.project?.name || `...`} </div> </div> {/* issue search bar */} <div className="w-full"> <NavbarSearch /> </div> {/* issue views */} <div className="flex-shrink-0 relative flex items-center gap-1 transition-all ease-in-out delay-150"> <NavbarIssueBoardView /> </div> {/* theming */} <div className="flex-shrink-0 relative"> <NavbarTheme /> </div> {user ? ( <div className="border border-custom-border-200 rounded flex items-center gap-2 p-2"> {user.avatar && user.avatar !== "" ? ( <div className="h-5 w-5 rounded-full"> {/* eslint-disable-next-line @next/next/no-img-element */} <img src={user.avatar} alt={user.display_name ?? ""} className="rounded-full" /> </div> ) : ( <div className="bg-custom-background-80 h-5 w-5 rounded-full grid place-items-center text-[10px] capitalize"> {(user.display_name ?? "A")[0]} </div> )} <h6 className="text-xs font-medium">{user.display_name}</h6> </div> ) : ( <div className="flex-shrink-0"> <Link href={`/?next_path=${router.asPath}`}> <a> <PrimaryButton className="flex-shrink-0" outline> Sign in </PrimaryButton> </a> </Link> </div> )} </div> ); }); export default IssueNavbar;