Files
supabase/apps/studio/components/interfaces/EdgeFunctions/EdgeFunctionsSortDropdown.tsx
Ali Waseem 86755ba1fd feat: Edge functions search and sorting (#40796)
* added sorting and search for edge functions

* updated logic

* updated types

* updated types

* updated search bar

* updated to remove unneeded map
2025-11-25 13:37:34 -07:00

89 lines
2.9 KiB
TypeScript

import { ArrowDownNarrowWide, ArrowDownWideNarrow } from 'lucide-react'
import {
Button,
DropdownMenu,
DropdownMenuContent,
DropdownMenuRadioGroup,
DropdownMenuRadioItem,
DropdownMenuSub,
DropdownMenuSubContent,
DropdownMenuSubTrigger,
DropdownMenuTrigger,
} from 'ui'
export const EDGE_FUNCTIONS_SORT_VALUES = [
'name:asc',
'name:desc',
'created_at:asc',
'created_at:desc',
'updated_at:asc',
'updated_at:desc',
] as const
export type EdgeFunctionsSort = (typeof EDGE_FUNCTIONS_SORT_VALUES)[number]
export type EdgeFunctionsSortColumn = EdgeFunctionsSort extends `${infer Column}:${string}`
? Column
: unknown
export type EdgeFunctionsSortOrder = EdgeFunctionsSort extends `${string}:${infer Order}`
? Order
: unknown
interface EdgeFunctionsSortDropdownProps {
value: EdgeFunctionsSort
onChange: (value: EdgeFunctionsSort) => void
}
function getSortLabel(value: EdgeFunctionsSort) {
const [sortCol] = value.split(':')
return sortCol.replace('_', ' ')
}
export const EdgeFunctionsSortDropdown = ({ value, onChange }: EdgeFunctionsSortDropdownProps) => {
return (
<DropdownMenu>
<DropdownMenuTrigger asChild>
<Button
type="default"
icon={
value.includes('desc') ? (
<ArrowDownWideNarrow size={14} />
) : (
<ArrowDownNarrowWide size={14} />
)
}
>
Sorted by {getSortLabel(value)}
</Button>
</DropdownMenuTrigger>
<DropdownMenuContent align="start" className="w-48">
<DropdownMenuRadioGroup
value={value}
onValueChange={(val) => onChange(val as EdgeFunctionsSort)}
>
<DropdownMenuSub>
<DropdownMenuSubTrigger>Sort by name</DropdownMenuSubTrigger>
<DropdownMenuSubContent>
<DropdownMenuRadioItem value="name:asc">Ascending</DropdownMenuRadioItem>
<DropdownMenuRadioItem value="name:desc">Descending</DropdownMenuRadioItem>
</DropdownMenuSubContent>
</DropdownMenuSub>
<DropdownMenuSub>
<DropdownMenuSubTrigger>Sort by created at</DropdownMenuSubTrigger>
<DropdownMenuSubContent>
<DropdownMenuRadioItem value="created_at:asc">Ascending</DropdownMenuRadioItem>
<DropdownMenuRadioItem value="created_at:desc">Descending</DropdownMenuRadioItem>
</DropdownMenuSubContent>
</DropdownMenuSub>
<DropdownMenuSub>
<DropdownMenuSubTrigger>Sort by updated at</DropdownMenuSubTrigger>
<DropdownMenuSubContent>
<DropdownMenuRadioItem value="updated_at:asc">Ascending</DropdownMenuRadioItem>
<DropdownMenuRadioItem value="updated_at:desc">Descending</DropdownMenuRadioItem>
</DropdownMenuSubContent>
</DropdownMenuSub>
</DropdownMenuRadioGroup>
</DropdownMenuContent>
</DropdownMenu>
)
}