Home / File/ sidebar-rsc.tsx — ui Source File

sidebar-rsc.tsx — ui Source File

Architecture documentation for sidebar-rsc.tsx, a tsx file in the ui codebase. 3 imports, 0 dependents.

File tsx ComponentRegistry ChartRegistry 3 imports 4 functions

Entity Profile

Dependency Diagram

graph LR
  f49628f2_f9fa_f0be_e2f6_5836aff167b7["sidebar-rsc.tsx"]
  1d141819_425e_b5fd_4c8e_32f7c6a42cf2["react"]
  f49628f2_f9fa_f0be_e2f6_5836aff167b7 --> 1d141819_425e_b5fd_4c8e_32f7c6a42cf2
  d39cd1e4_1b2d_9aa2_1d29_fd0b4bfb61c3["lucide-react"]
  f49628f2_f9fa_f0be_e2f6_5836aff167b7 --> d39cd1e4_1b2d_9aa2_1d29_fd0b4bfb61c3
  742f06fb_c1e8_243e_1fc4_8b1cf11704c2["sidebar"]
  f49628f2_f9fa_f0be_e2f6_5836aff167b7 --> 742f06fb_c1e8_243e_1fc4_8b1cf11704c2
  style f49628f2_f9fa_f0be_e2f6_5836aff167b7 fill:#6366f1,stroke:#818cf8,color:#fff

Relationship Graph

Source Code

import * as React from "react"
import { Frame, LifeBuoy, Map, PieChart, Send } from "lucide-react"

import {
  Sidebar,
  SidebarContent,
  SidebarGroup,
  SidebarGroupContent,
  SidebarGroupLabel,
  SidebarMenu,
  SidebarMenuButton,
  SidebarMenuItem,
  SidebarMenuSkeleton,
  SidebarProvider,
} from "@/registry/default/ui/sidebar"

const projects = [
  {
    name: "Design Engineering",
    url: "#",
    icon: Frame,
    badge: "24",
  },
  {
    name: "Sales & Marketing",
    url: "#",
    icon: PieChart,
    badge: "12",
  },
  {
    name: "Travel",
    url: "#",
    icon: Map,
    badge: "3",
  },
  {
    name: "Support",
    url: "#",
    icon: LifeBuoy,
    badge: "21",
  },
  {
    name: "Feedback",
    url: "#",
    icon: Send,
    badge: "8",
  },
]

// Dummy fetch function
async function fetchProjects() {
  await new Promise((resolve) => setTimeout(resolve, 3000))
  return projects
}

export default function AppSidebar() {
  return (
    <SidebarProvider>
      <Sidebar>
        <SidebarContent>
          <SidebarGroup>
            <SidebarGroupLabel>Projects</SidebarGroupLabel>
            <SidebarGroupContent>
              <React.Suspense fallback={<NavProjectsSkeleton />}>
                <NavProjects />
              </React.Suspense>
            </SidebarGroupContent>
          </SidebarGroup>
        </SidebarContent>
      </Sidebar>
    </SidebarProvider>
  )
}

function NavProjectsSkeleton() {
  return (
    <SidebarMenu>
      {Array.from({ length: 5 }).map((_, index) => (
        <SidebarMenuItem key={index}>
          <SidebarMenuSkeleton showIcon />
        </SidebarMenuItem>
      ))}
    </SidebarMenu>
  )
}

async function NavProjects() {
  const projects = await fetchProjects()

  return (
    <SidebarMenu>
      {projects.map((project) => (
        <SidebarMenuItem key={project.name}>
          <SidebarMenuButton asChild>
            <a href={project.url}>
              <project.icon />
              <span>{project.name}</span>
            </a>
          </SidebarMenuButton>
        </SidebarMenuItem>
      ))}
    </SidebarMenu>
  )
}

Subdomains

Dependencies

  • lucide-react
  • react
  • sidebar

Frequently Asked Questions

What does sidebar-rsc.tsx do?
sidebar-rsc.tsx is a source file in the ui codebase, written in tsx. It belongs to the ComponentRegistry domain, ChartRegistry subdomain.
What functions are defined in sidebar-rsc.tsx?
sidebar-rsc.tsx defines 4 function(s): AppSidebar, NavProjects, NavProjectsSkeleton, fetchProjects.
What does sidebar-rsc.tsx depend on?
sidebar-rsc.tsx imports 3 module(s): lucide-react, react, sidebar.
Where is sidebar-rsc.tsx in the architecture?
sidebar-rsc.tsx is located at deprecated/www/registry/default/internal/sidebar-rsc.tsx (domain: ComponentRegistry, subdomain: ChartRegistry, directory: deprecated/www/registry/default/internal).

Analyze Your Own Codebase

Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.

Try Supermodel Free