mirror of
https://github.com/meta-llama/llama-stack.git
synced 2025-08-16 06:27:58 +00:00
# What does this PR do? This updates the sidebar to look a little more like other popular ones. <img width="1913" height="1352" alt="Screenshot 2025-08-08 at 11 25 31 PM" src="https://github.com/user-attachments/assets/00738412-1101-48ec-8864-cde4a8733ec1" /> ## Test Plan <!-- Describe the tests you ran to verify your changes with result summaries. *Provide clear instructions so the plan can be easily re-executed.* --> Signed-off-by: Francisco Javier Arceo <farceo@redhat.com>
151 lines
3.6 KiB
TypeScript
151 lines
3.6 KiB
TypeScript
"use client";
|
|
|
|
import {
|
|
MessageSquareText,
|
|
MessagesSquare,
|
|
MoveUpRight,
|
|
Database,
|
|
MessageCircle,
|
|
Settings2,
|
|
Compass,
|
|
} from "lucide-react";
|
|
import Link from "next/link";
|
|
import { usePathname } from "next/navigation";
|
|
import { cn } from "@/lib/utils";
|
|
|
|
import {
|
|
Sidebar,
|
|
SidebarContent,
|
|
SidebarGroup,
|
|
SidebarGroupContent,
|
|
SidebarGroupLabel,
|
|
SidebarMenu,
|
|
SidebarMenuButton,
|
|
SidebarMenuItem,
|
|
SidebarHeader,
|
|
} from "@/components/ui/sidebar";
|
|
|
|
const createItems = [
|
|
{
|
|
title: "Chat Playground",
|
|
url: "/chat-playground",
|
|
icon: MessageCircle,
|
|
},
|
|
];
|
|
|
|
const manageItems = [
|
|
{
|
|
title: "Chat Completions",
|
|
url: "/logs/chat-completions",
|
|
icon: MessageSquareText,
|
|
},
|
|
{
|
|
title: "Responses",
|
|
url: "/logs/responses",
|
|
icon: MessagesSquare,
|
|
},
|
|
{
|
|
title: "Vector Stores",
|
|
url: "/logs/vector-stores",
|
|
icon: Database,
|
|
},
|
|
{
|
|
title: "Documentation",
|
|
url: "https://llama-stack.readthedocs.io/en/latest/references/api_reference/index.html",
|
|
icon: MoveUpRight,
|
|
},
|
|
];
|
|
|
|
const optimizeItems: { title: string; url: string; icon: React.ElementType }[] = [
|
|
{
|
|
title: "Evaluations",
|
|
url: "",
|
|
icon: Compass,
|
|
},
|
|
{
|
|
title: "Fine-tuning",
|
|
url: "",
|
|
icon: Settings2,
|
|
},
|
|
];
|
|
|
|
interface SidebarItem {
|
|
title: string;
|
|
url: string;
|
|
icon: React.ElementType;
|
|
}
|
|
|
|
export function AppSidebar() {
|
|
const pathname = usePathname();
|
|
|
|
const renderSidebarItems = (items: SidebarItem[]) => {
|
|
return items.map((item) => {
|
|
const isActive = pathname.startsWith(item.url);
|
|
return (
|
|
<SidebarMenuItem key={item.title}>
|
|
<SidebarMenuButton
|
|
asChild
|
|
className={cn(
|
|
"justify-start",
|
|
isActive &&
|
|
"bg-gray-200 dark:bg-gray-700 hover:bg-gray-200 dark:hover:bg-gray-700 text-gray-900 dark:text-gray-100",
|
|
)}
|
|
>
|
|
<Link href={item.url}>
|
|
<item.icon
|
|
className={cn(
|
|
isActive && "text-gray-900 dark:text-gray-100",
|
|
"mr-2 h-4 w-4",
|
|
)}
|
|
/>
|
|
<span>{item.title}</span>
|
|
</Link>
|
|
</SidebarMenuButton>
|
|
</SidebarMenuItem>
|
|
);
|
|
});
|
|
};
|
|
|
|
return (
|
|
<Sidebar>
|
|
<SidebarHeader>
|
|
<Link href="/">Llama Stack</Link>
|
|
</SidebarHeader>
|
|
<SidebarContent>
|
|
<SidebarGroup>
|
|
<SidebarGroupLabel>Create</SidebarGroupLabel>
|
|
<SidebarGroupContent>
|
|
<SidebarMenu>{renderSidebarItems(createItems)}</SidebarMenu>
|
|
</SidebarGroupContent>
|
|
</SidebarGroup>
|
|
|
|
<SidebarGroup>
|
|
<SidebarGroupLabel>Manage</SidebarGroupLabel>
|
|
<SidebarGroupContent>
|
|
<SidebarMenu>{renderSidebarItems(manageItems)}</SidebarMenu>
|
|
</SidebarGroupContent>
|
|
</SidebarGroup>
|
|
|
|
<SidebarGroup>
|
|
<SidebarGroupLabel>Optimize</SidebarGroupLabel>
|
|
<SidebarGroupContent>
|
|
<SidebarMenu>
|
|
{optimizeItems.map((item) => (
|
|
<SidebarMenuItem key={item.title}>
|
|
<SidebarMenuButton
|
|
disabled
|
|
className="justify-start opacity-60 cursor-not-allowed"
|
|
>
|
|
<item.icon className="mr-2 h-4 w-4" />
|
|
<span>{item.title}</span>
|
|
<span className="ml-2 text-xs text-gray-500">(Coming Soon)</span>
|
|
</SidebarMenuButton>
|
|
</SidebarMenuItem>
|
|
))}
|
|
</SidebarMenu>
|
|
</SidebarGroupContent>
|
|
</SidebarGroup>
|
|
</SidebarContent>
|
|
</Sidebar>
|
|
);
|
|
}
|