Files
supabase/apps/studio/components/interfaces/BranchManagement/BranchSelector.tsx
Joshen Lim c6b2fe6fee Popover ui component to use portal by default, remove all manual declaration of portal for PopoverContent in dashboard (#41818)
* Popover ui component to use portal by default, remove all manual declaration of portal for PopoverContent in dashboard

* Forgot to add ui changes lol

* Clean uop
2026-01-20 11:58:31 +08:00

104 lines
3.5 KiB
TypeScript

import { Check, GitMerge, Shield } from 'lucide-react'
import { useState } from 'react'
import { ButtonTooltip } from 'components/ui/ButtonTooltip'
import { Branch } from 'data/branches/branches-query'
import {
CommandEmpty_Shadcn_,
CommandGroup_Shadcn_,
CommandInput_Shadcn_,
CommandItem_Shadcn_,
CommandList_Shadcn_,
Command_Shadcn_,
PopoverContent_Shadcn_,
PopoverTrigger_Shadcn_,
Popover_Shadcn_,
ScrollArea,
} from 'ui'
interface BranchSelectorProps {
branches: Branch[]
onBranchSelected?: (branch: Branch) => void
disabled?: boolean
isUpdating?: boolean
type?: 'primary' | 'outline'
}
export const BranchSelector = ({
branches,
onBranchSelected,
disabled = false,
isUpdating = false,
type = 'primary',
}: BranchSelectorProps) => {
const [open, setOpen] = useState(false)
const [selectedBranch, setSelectedBranch] = useState<Branch | null>(null)
// Filter out branches that are already ready for review or linked to a github branch
const availableBranches = branches.filter(
(branch) => !branch.is_default && !branch.review_requested_at && !branch.git_branch
)
const handleBranchSelect = (branch: Branch) => {
setSelectedBranch(branch)
setOpen(false)
onBranchSelected?.(branch)
}
return (
<Popover_Shadcn_ open={open} onOpenChange={setOpen} modal={false}>
<PopoverTrigger_Shadcn_ asChild>
<ButtonTooltip
icon={<GitMerge size={14} strokeWidth={1.5} />}
type={type}
disabled={disabled || availableBranches.length === 0 || isUpdating}
tooltip={{
content: {
side: 'bottom',
text:
branches.length === 0
? 'Create a branch first to start a merge request'
: availableBranches.length === 0
? 'All branches currently have merge requests'
: undefined,
},
}}
>
{isUpdating ? 'Creating...' : 'New merge request'}
</ButtonTooltip>
</PopoverTrigger_Shadcn_>
<PopoverContent_Shadcn_ className="p-0 w-80" side="bottom" align="end">
<Command_Shadcn_>
<CommandInput_Shadcn_ placeholder="Find branch to review..." />
<CommandList_Shadcn_>
<CommandEmpty_Shadcn_>No available branches found</CommandEmpty_Shadcn_>
<CommandGroup_Shadcn_>
<ScrollArea className="max-h-[210px] overflow-y-auto">
{availableBranches.map((branch) => (
<CommandItem_Shadcn_
key={branch.id}
value={branch.name.replaceAll('"', '')}
className="cursor-pointer w-full flex items-center justify-between"
onSelect={() => handleBranchSelect(branch)}
disabled={isUpdating}
>
<div className="flex items-center gap-2">
{branch.is_default && <Shield size={14} className="text-amber-900" />}
<span className="truncate" title={branch.name}>
{branch.name}
</span>
</div>
{selectedBranch?.id === branch.id && (
<Check size={14} strokeWidth={1.5} className="text-brand" />
)}
</CommandItem_Shadcn_>
))}
</ScrollArea>
</CommandGroup_Shadcn_>
</CommandList_Shadcn_>
</Command_Shadcn_>
</PopoverContent_Shadcn_>
</Popover_Shadcn_>
)
}