mirror of
https://github.com/MODSetter/SurfSense.git
synced 2026-04-25 08:46:22 +02:00
68 lines
1.9 KiB
TypeScript
68 lines
1.9 KiB
TypeScript
"use client";
|
|
|
|
import { ChevronsUpDown, Settings, UserPen } from "lucide-react";
|
|
import { useParams, useRouter } from "next/navigation";
|
|
import { useTranslations } from "next-intl";
|
|
import { Button } from "@/components/ui/button";
|
|
import {
|
|
DropdownMenu,
|
|
DropdownMenuContent,
|
|
DropdownMenuItem,
|
|
DropdownMenuSeparator,
|
|
DropdownMenuTrigger,
|
|
} from "@/components/ui/dropdown-menu";
|
|
import { cn } from "@/lib/utils";
|
|
import type { SearchSpace } from "../../types/layout.types";
|
|
|
|
interface SidebarHeaderProps {
|
|
searchSpace: SearchSpace | null;
|
|
isCollapsed?: boolean;
|
|
onSettings?: () => void;
|
|
onManageMembers?: () => void;
|
|
className?: string;
|
|
}
|
|
|
|
export function SidebarHeader({
|
|
searchSpace,
|
|
isCollapsed,
|
|
onSettings,
|
|
onManageMembers,
|
|
className,
|
|
}: SidebarHeaderProps) {
|
|
const t = useTranslations("sidebar");
|
|
const router = useRouter();
|
|
const params = useParams();
|
|
const searchSpaceId = params.search_space_id as string;
|
|
|
|
return (
|
|
<div className={cn("flex min-w-0 flex-1 items-center", className)}>
|
|
<DropdownMenu>
|
|
<DropdownMenuTrigger asChild>
|
|
<Button
|
|
variant="ghost"
|
|
className={cn(
|
|
"flex h-auto w-full items-center justify-between gap-1 overflow-hidden py-1.5 font-semibold",
|
|
isCollapsed && "w-10"
|
|
)}
|
|
>
|
|
<span className="truncate text-base">
|
|
{searchSpace?.name ?? t("select_search_space")}
|
|
</span>
|
|
<ChevronsUpDown className="h-4 w-4 shrink-0 text-muted-foreground" />
|
|
</Button>
|
|
</DropdownMenuTrigger>
|
|
<DropdownMenuContent align="start" className="w-48">
|
|
<DropdownMenuItem onClick={onManageMembers}>
|
|
<UserPen className="h-4 w-4" />
|
|
{t("manage_members")}
|
|
</DropdownMenuItem>
|
|
<DropdownMenuSeparator />
|
|
<DropdownMenuItem onClick={onSettings}>
|
|
<Settings className="h-4 w-4" />
|
|
{t("search_space_settings")}
|
|
</DropdownMenuItem>
|
|
</DropdownMenuContent>
|
|
</DropdownMenu>
|
|
</div>
|
|
);
|
|
}
|