SurfSense/surfsense_web/components/layout/ui/sidebar/SidebarHeader.tsx

69 lines
1.9 KiB
TypeScript
Raw Normal View History

"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"
)}
>
2026-01-12 14:17:15 -08:00
<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>
);
}