ProjectCard() — supabase Function Reference
Architecture documentation for the ProjectCard() function in ProjectCard.tsx from the supabase codebase.
Entity Profile
Dependency Diagram
graph TD 1dcac9a8_5747_aea7_0621_578e314b0d7d["ProjectCard()"] c06df2be_a9ab_f6a3_7afa_b703f6c5ddb4["inferProjectStatus()"] 1dcac9a8_5747_aea7_0621_578e314b0d7d -->|calls| c06df2be_a9ab_f6a3_7afa_b703f6c5ddb4 style 1dcac9a8_5747_aea7_0621_578e314b0d7d fill:#6366f1,stroke:#818cf8,color:#fff
Relationship Graph
Source Code
apps/studio/components/interfaces/Home/ProjectList/ProjectCard.tsx lines 38–167
export const ProjectCard = ({
slug,
project,
organization,
rewriteHref,
githubIntegration,
vercelIntegration,
resourceWarnings,
}: ProjectCardProps) => {
const { name, ref: projectRef } = project
const [isDeleteModalOpen, setIsDeleteModalOpen] = useState(false)
const { infraAwsNimbusLabel } = useCustomContent(['infra:aws_nimbus_label'])
const providerLabel =
project.cloud_provider === 'AWS_NIMBUS' ? infraAwsNimbusLabel : project.cloud_provider
const desc = `${providerLabel} | ${project.region}`
const { projectHomepageShowInstanceSize } = useIsFeatureEnabled([
'project_homepage:show_instance_size',
])
const isGithubIntegrated = githubIntegration !== undefined
const isVercelIntegrated = vercelIntegration !== undefined
const githubRepository = githubIntegration?.metadata.name ?? undefined
const projectStatus = inferProjectStatus(project.status)
return (
<>
<li className="list-none h-min">
<CardButton
linkHref={rewriteHref ? rewriteHref : `/project/${projectRef}`}
className="h-44 !px-0 group pt-5 pb-0 overflow-hidden relative"
hideChevron
title={
<div className="w-full flex flex-col gap-y-4 justify-between px-5">
<div className="flex flex-col gap-y-0.5 relative">
<div className="flex items-center justify-between">
<h5 className="text-sm flex-shrink truncate pr-5">{name}</h5>
<div onClick={(e) => e.preventDefault()}>
<DropdownMenu>
<DropdownMenuTrigger asChild>
<Button
type="text"
icon={<MoreVertical size={14} />}
className="w-6 h-6 px-0"
onClick={(e) => {
e.stopPropagation()
e.preventDefault()
}}
onPointerDown={(e) => e.stopPropagation()}
/>
</DropdownMenuTrigger>
<DropdownMenuContent align="end" className="w-48">
<DropdownMenuItem
className="gap-x-2"
onClick={(e) => {
e.stopPropagation()
copyToClipboard(projectRef)
toast.success('Copied project ID to clipboard')
}}
>
<Copy size={14} />
<span>Copy project ID</span>
</DropdownMenuItem>
<DropdownMenuItem
className="gap-x-2"
onClick={(e) => {
e.stopPropagation()
setIsDeleteModalOpen(true)
}}
>
<Trash size={14} />
<span>Delete project</span>
</DropdownMenuItem>
</DropdownMenuContent>
</DropdownMenu>
</div>
</div>
<p className="text-sm text-foreground-lighter">{desc}</p>
</div>
<div className="flex items-center gap-x-1.5 relative">
<ProjectCardStatus
projectStatus={projectStatus}
resourceWarnings={resourceWarnings}
renderMode="badge"
/>
{project.status !== 'INACTIVE' && projectHomepageShowInstanceSize && (
<ComputeBadgeWrapper
slug={slug}
projectRef={project.ref}
cloudProvider={project.cloud_provider}
computeSize={getComputeSize(project)}
/>
)}
{isVercelIntegrated && (
<div className="bg-surface-100 w-5 h-5 p-1 border border-strong rounded-md flex items-center justify-center text-black dark:text-white">
<InlineSVG
src={`${BASE_PATH}/img/icons/vercel-icon.svg`}
title="Vercel Icon"
className="w-3"
/>
</div>
)}
{isGithubIntegrated && (
<div className="bg-surface-100 flex items-center gap-x-0.5 h-5 pr-1 border border-strong rounded-md">
<div className="w-5 h-5 p-1 flex items-center justify-center">
<Github size={12} strokeWidth={1.5} />
</div>
<p className="text-xs text-foreground-light truncate">{githubRepository}</p>
</div>
)}
</div>
</div>
}
footer={
<ProjectCardStatus projectStatus={projectStatus} resourceWarnings={resourceWarnings} />
}
containerElement={<ProjectIndexPageLink projectRef={projectRef} />}
/>
</li>
<DeleteProjectModal
visible={isDeleteModalOpen}
onClose={() => setIsDeleteModalOpen(false)}
project={project}
organization={organization}
/>
</>
)
}
Domain
Subdomains
Calls
Source
Frequently Asked Questions
What does ProjectCard() do?
ProjectCard() is a function in the supabase codebase.
What does ProjectCard() call?
ProjectCard() calls 1 function(s): inferProjectStatus.
Analyze Your Own Codebase
Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.
Try Supermodel Free