Subscription() — supabase Function Reference
Architecture documentation for the Subscription() function in Subscription.tsx from the supabase codebase.
Entity Profile
Relationship Graph
Source Code
apps/studio/components/interfaces/Organization/BillingSettings/Subscription/Subscription.tsx lines 23–157
const Subscription = () => {
const { slug } = useParams()
const snap = useOrgSettingsPageStateSnapshot()
const projectUpdateDisabled = useFlag('disableProjectCreationAndUpdate')
const { isSuccess: isPermissionsLoaded, can: canReadSubscriptions } = useAsyncCheckPermissions(
PermissionAction.BILLING_READ,
'stripe.subscriptions'
)
const {
data: subscription,
error,
isPending: isLoading,
isError,
isSuccess,
} = useOrgSubscriptionQuery({ orgSlug: slug }, { enabled: canReadSubscriptions })
const currentPlan = subscription?.plan
const planName = currentPlan?.name ?? 'Unknown'
const canChangeTier =
!projectUpdateDisabled && !['enterprise', 'platform'].includes(currentPlan?.id ?? '')
return (
<>
<ScaffoldSection>
<div className="col-span-12 pb-2">
<Restriction />
</div>
<ScaffoldSectionDetail>
<div className="sticky space-y-6 top-12">
<div className="space-y-2 mb-4">
<p className="text-foreground text-base m-0">Subscription Plan</p>
<p className="text-sm text-foreground-light m-0">
Each organization has it's own subscription plan, billing cycle, payment methods and
usage quotas.
</p>
</div>
</div>
</ScaffoldSectionDetail>
<ScaffoldSectionContent>
{isPermissionsLoaded && !canReadSubscriptions ? (
<NoPermission resourceText="view this organization's subscription" />
) : (
<>
{isLoading && (
<div className="space-y-2">
<ShimmeringLoader />
<ShimmeringLoader className="w-3/4" />
<ShimmeringLoader className="w-1/2" />
</div>
)}
{isError && <AlertError subject="Failed to retrieve subscription" error={error} />}
{isSuccess && (
<div className="space-y-6">
<div>
<p className="text-2xl text-brand">{currentPlan?.name ?? 'Unknown'} Plan</p>
</div>
<div>
{canChangeTier && (
<ProjectUpdateDisabledTooltip projectUpdateDisabled={projectUpdateDisabled}>
<Button
type="default"
className="pointer-events-auto"
disabled={!canChangeTier}
onClick={() => snap.setPanelKey('subscriptionPlan')}
>
Change subscription plan
</Button>
</ProjectUpdateDisabledTooltip>
)}
{!canChangeTier &&
(projectUpdateDisabled ? (
<Alert
className="mt-2"
withIcon
variant="info"
title={`Unable to update plan from ${planName}`}
>
We have temporarily disabled project and subscription changes - our
engineers are working on a fix.
</Alert>
) : (
<Alert
withIcon
className="mt-2"
variant="info"
title={`Unable to update plan from ${planName}`}
actions={[
<Button asChild key="contact-support" type="default">
<SupportLink
queryParams={{
category: SupportCategories.SALES_ENQUIRY,
subject: `Change plan away from ${planName}`,
}}
>
Contact support
</SupportLink>
</Button>,
]}
>
Please contact us if you'd like to change your plan.
</Alert>
))}
</div>
{!subscription?.usage_billing_enabled && (
<Admonition
type="default"
title="This organization is limited by the included usage"
>
<div className="[&>p]:!leading-normal prose text-sm">
Projects may become unresponsive when this organization exceeds its{' '}
<Link href={`/org/${slug}/usage`}>included usage quota</Link>. To scale
seamlessly,{' '}
{currentPlan?.id === 'free'
? 'upgrade to a paid plan.'
: 'you can disable Spend Cap under the Cost Control settings.'}
</div>
</Admonition>
)}
</div>
)}
</>
)}
</ScaffoldSectionContent>
</ScaffoldSection>
<PlanUpdateSidePanel />
</>
)
}
Domain
Subdomains
Source
Analyze Your Own Codebase
Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.
Try Supermodel Free