Files
supabase/apps/studio/components/interfaces/Support/OrganizationSelector.tsx
Gildas Garcia 0facd341a6 chore: remove UI form components _Shadcn_ suffix (#45212)
## Problem

We used to have a `_Shadcn_` suffix for all the shadcn form components
because we also had `formik` form components.
This is not needed anymore.

## Solution

- Remove the suffix
- Update all usages
2026-04-24 12:14:15 +02:00

85 lines
3.2 KiB
TypeScript

import type { UseFormReturn } from 'react-hook-form'
import {
Badge,
FormControl,
FormField,
Select_Shadcn_,
SelectContent_Shadcn_,
SelectGroup_Shadcn_,
SelectItem_Shadcn_,
SelectTrigger_Shadcn_,
SelectValue_Shadcn_,
} from 'ui'
import { FormItemLayout } from 'ui-patterns/form/FormItemLayout/FormItemLayout'
import type { SupportFormValues } from './SupportForm.schema'
import { getOrgSubscriptionPlan, NO_ORG_MARKER, NO_PROJECT_MARKER } from './SupportForm.utils'
// End of third-party imports
import { useOrganizationsQuery } from '@/data/organizations/organizations-query'
interface OrganizationSelectorProps {
form: UseFormReturn<SupportFormValues>
orgSlug: string | null
}
export function OrganizationSelector({ form, orgSlug }: OrganizationSelectorProps) {
const { data: organizations, isSuccess: isSuccessOrganizations } = useOrganizationsQuery()
const subscriptionPlanId = getOrgSubscriptionPlan(organizations, orgSlug)
return (
<FormField
name="organizationSlug"
control={form.control}
render={({ field }) => {
const { ref: _ref, ...fieldWithoutRef } = field
return (
<FormItemLayout hideMessage layout="vertical" label="Which organization is affected?">
<FormControl>
<Select_Shadcn_
{...fieldWithoutRef}
disabled={!isSuccessOrganizations}
defaultValue={field.value}
onValueChange={(value) => {
const previousOrgSlug = form.getValues('organizationSlug')
field.onChange(value)
if (previousOrgSlug !== value) {
form.resetField('projectRef', { defaultValue: NO_PROJECT_MARKER })
}
}}
>
<SelectTrigger_Shadcn_ className="w-full" aria-label="Select an organization">
<SelectValue_Shadcn_ asChild placeholder="Select an organization">
<div className="flex items-center gap-x-2">
{orgSlug === NO_ORG_MARKER ? (
<span>No specific organization</span>
) : (
(organizations ?? []).find((o) => o.slug === field.value)?.name
)}
{subscriptionPlanId && <Badge variant="default">{subscriptionPlanId}</Badge>}
</div>
</SelectValue_Shadcn_>
</SelectTrigger_Shadcn_>
<SelectContent_Shadcn_>
<SelectGroup_Shadcn_>
{organizations?.map((org) => (
<SelectItem_Shadcn_ key={org.slug} value={org.slug}>
{org.name}
</SelectItem_Shadcn_>
))}
{isSuccessOrganizations && (organizations ?? []).length === 0 && (
<SelectItem_Shadcn_ value={NO_ORG_MARKER}>
No specific organization
</SelectItem_Shadcn_>
)}
</SelectGroup_Shadcn_>
</SelectContent_Shadcn_>
</Select_Shadcn_>
</FormControl>
</FormItemLayout>
)
}}
/>
)
}