Home / Function/ EnterpriseCard() — supabase Function Reference

EnterpriseCard() — supabase Function Reference

Architecture documentation for the EnterpriseCard() function in EnterpriseCard.tsx from the supabase codebase.

Entity Profile

Relationship Graph

Source Code

apps/studio/components/interfaces/Organization/BillingSettings/Subscription/EnterpriseCard.tsx lines 13–103

export const EnterpriseCard = ({ plan, isCurrentPlan }: EnterpriseCardProps) => {
  const { data: selectedOrganization } = useSelectedOrganizationQuery()
  const orgSlug = selectedOrganization?.slug

  const features = plan.features
  const currentPlan = selectedOrganization?.plan.name

  const { mutate: sendEvent } = useSendEventMutation()

  return (
    <div
      key={plan.id}
      className={cn(
        'grid grid-cols-1 md:grid-cols-3 border rounded-md bg-studio',
        'py-4 col-span-12 justify-between gap-x-8'
      )}
    >
      <div className="flex flex-col justify-center px-4">
        <div className="flex items-center space-x-2">
          <p className={cn('text-brand text-sm uppercase')}>{plan.name}</p>
          {isCurrentPlan ? (
            <div className="text-xs bg-surface-300 text-foreground-light rounded px-2 py-0.5">
              Current plan
            </div>
          ) : plan.nameBadge ? (
            <div className="text-xs bg-surface-200 text-brand rounded px-2 py-0.5">
              {plan.nameBadge}
            </div>
          ) : null}
        </div>

        <p className="text-sm mt-2 mb-4">{plan.description}</p>

        <Button
          block
          asChild
          type="default"
          size="tiny"
          onClick={() =>
            sendEvent({
              action: 'studio_pricing_plan_cta_clicked',
              properties: { selectedPlan: 'Enterprise', currentPlan },
              groups: { organization: orgSlug ?? 'Unknown' },
            })
          }
        >
          <a href={plan.href} className="hidden md:block" target="_blank">
            {plan.cta}
          </a>
        </Button>
      </div>

      <div className="flex flex-col justify-center col-span-2 px-4 md:px-0">
        <ul
          role="list"
          className="text-xs text-foreground-light md:grid md:grid-cols-2 md:gap-x-10"
        >
          {features.map((feature) => (
            <li
              key={typeof feature === 'string' ? feature : feature[0]}
              className="flex items-center py-2 first:mt-0"
            >
              <Check className="text-brand h-4 w-4" aria-hidden="true" strokeWidth={3} />
              <span className="text-foreground mb-0 ml-3 ">
                {typeof feature === 'string' ? feature : feature[0]}
              </span>
            </li>
          ))}
        </ul>

        <Button
          block
          asChild
          type="default"
          size="tiny"
          onClick={() =>
            sendEvent({
              action: 'studio_pricing_plan_cta_clicked',
              properties: { selectedPlan: 'Enterprise', currentPlan },
              groups: { organization: orgSlug ?? 'Unknown' },
            })
          }
        >
          <a href={plan.href} className="visible md:hidden mt-8" target="_blank">
            {plan.cta}
          </a>
        </Button>
      </div>
    </div>
  )
}

Subdomains

Analyze Your Own Codebase

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

Try Supermodel Free