Files
supabase/apps/studio/components/ui/AIAssistantPanel/ModelSelector.tsx
Gildas Garcia 243e079a2c chore: remove _Shadcn_ suffix from Command components (#46153)
## Problem

The `_Shadcn_` suffix isn't needed anymore on `Command` components

## Solution

- Remove the `_Shadcn_` suffix
- Simplify UI package exports
- Apply prettier

<!-- This is an auto-generated comment: release notes by coderabbit.ai
-->

## Summary by CodeRabbit

* **Refactor**
* Simplified command component imports and exports across the UI library
by removing internal naming aliases and adopting direct component
references. Updated the public UI package barrel export to use wildcard
re-exports for cleaner API surface.

<!-- review_stack_entry_start -->

[![Review Change
Stack](https://storage.googleapis.com/coderabbit_public_assets/review-stack-in-coderabbit-ui.svg)](https://app.coderabbit.ai/change-stack/supabase/supabase/pull/46153?utm_source=github_walkthrough&utm_medium=github&utm_campaign=change_stack)

<!-- review_stack_entry_end -->

<!-- end of auto-generated comment: release notes by coderabbit.ai -->
2026-05-20 15:45:32 +02:00

106 lines
3.3 KiB
TypeScript

import { Check, ChevronsUpDown } from 'lucide-react'
import { useRouter } from 'next/router'
import { useState } from 'react'
import {
Badge,
Button,
Command,
CommandGroup,
CommandItem,
CommandList,
Popover,
PopoverContent,
PopoverTrigger,
Tooltip,
TooltipContent,
TooltipTrigger,
} from 'ui'
import { useCheckEntitlements } from '@/hooks/misc/useCheckEntitlements'
import { useSelectedOrganizationQuery } from '@/hooks/misc/useSelectedOrganization'
import { ASSISTANT_MODELS, isAdvanceOnlyModelId } from '@/lib/ai/model.utils'
import type { AssistantModelId } from '@/lib/ai/model.utils'
interface ModelSelectorProps {
selectedModel: AssistantModelId
onSelectModel: (model: AssistantModelId) => void
}
export const ModelSelector = ({ selectedModel, onSelectModel }: ModelSelectorProps) => {
const router = useRouter()
const { data: organization } = useSelectedOrganizationQuery()
const { hasAccess: hasAccessToAdvanceModel, isLoading: isLoadingEntitlements } =
useCheckEntitlements('assistant.advance_model')
const [open, setOpen] = useState(false)
const slug = organization?.slug ?? '_'
const upgradeHref = `/org/${slug}/billing?panel=subscriptionPlan&source=ai-assistant-model`
const handleSelectModel = (modelId: AssistantModelId) => {
if (isLoadingEntitlements && isAdvanceOnlyModelId(modelId)) {
return
}
if (isAdvanceOnlyModelId(modelId) && !hasAccessToAdvanceModel) {
setOpen(false)
void router.push(upgradeHref)
return
}
onSelectModel(modelId)
setOpen(false)
}
return (
<Popover open={open} onOpenChange={setOpen}>
<PopoverTrigger asChild>
<Button
type="default"
className="text-foreground-light"
iconRight={<ChevronsUpDown strokeWidth={1} size={12} />}
>
{selectedModel}
</Button>
</PopoverTrigger>
<PopoverContent className="p-0 w-44" align="start" side="top">
<Command>
<CommandList>
<CommandGroup>
{ASSISTANT_MODELS.map((m) => (
<CommandItem
key={m.id}
value={m.id}
disabled={isLoadingEntitlements && isAdvanceOnlyModelId(m.id)}
onSelect={() => handleSelectModel(m.id)}
className="flex justify-between"
>
<span>{m.id}</span>
{isAdvanceOnlyModelId(m.id) &&
!hasAccessToAdvanceModel &&
!isLoadingEntitlements ? (
<Tooltip>
<TooltipTrigger asChild>
<div>
<Badge role="button" variant="warning">
Upgrade
</Badge>
</div>
</TooltipTrigger>
<TooltipContent side="right">
{m.id} is available on Pro plans and above
</TooltipContent>
</Tooltip>
) : (
selectedModel === m.id && <Check className="h-3.5 w-3.5" />
)}
</CommandItem>
))}
</CommandGroup>
</CommandList>
</Command>
</PopoverContent>
</Popover>
)
}