Files
supabase/apps/studio/components/interfaces/QueryPerformance/TextSearchPopover.tsx
Jonathan Summers-Muir 2815dac7e0 Feat/index suggestions inline (#35107)
* init

* hovercard

* adds button to install index advisor

* hover card now now insert indexes

* update

* moved hook

* align alert dialog to design syste,

* Update index-advisor.utils.ts

* shows all index statements now

* Update query-performance.tsx

* Some refactors

* Clean up

* Fix

* One last nit refactor

---------

Co-authored-by: Joshen Lim <joshenlimek@gmail.com>
2025-05-07 19:09:58 +08:00

81 lines
2.2 KiB
TypeScript

import { useState } from 'react'
import {
Button,
PopoverContent_Shadcn_,
PopoverTrigger_Shadcn_,
Popover_Shadcn_,
TextArea_Shadcn_,
} from 'ui'
interface TextSearchPopoverProps {
name: string
value: string
placeholder?: string
rows?: number
onSaveText: (value: string) => void
}
export const TextSearchPopover = ({
name,
value = '',
placeholder,
rows = 4,
onSaveText,
}: TextSearchPopoverProps) => {
const [open, setOpen] = useState(false)
const [search, setSearch] = useState<string>(value)
const applySearch = () => {
onSaveText(search)
setOpen(false)
}
return (
<Popover_Shadcn_ open={open} onOpenChange={setOpen} modal={false}>
<PopoverTrigger_Shadcn_ asChild>
<Button
asChild
type={value.length > 0 ? 'default' : 'dashed'}
onClick={() => setOpen(false)}
>
<div className="max-w-[170px]">
<span>{name}</span>
{value.length > 0 && <span className="mr-1">:</span>}
<span className="truncate">{value}</span>
</div>
</Button>
</PopoverTrigger_Shadcn_>
<PopoverContent_Shadcn_ portal className="p-0" side="bottom" align="start">
<div className="space-y-4 p-3 min-w-[170px]">
<TextArea_Shadcn_
value={search}
onChange={(event) => setSearch(event.target.value)}
rows={rows}
className="text-xs font-mono tracking-tight"
placeholder={placeholder ?? 'Search for a query'}
onKeyDown={(event) => {
if (event.metaKey && event.code === 'Enter') applySearch()
}}
/>
</div>
<div className="flex items-center justify-end gap-2 border-t border-overlay bg-surface-200 py-2 px-3">
<Button
size="tiny"
type="default"
onClick={() => {
onSaveText('')
setSearch('')
setOpen(false)
}}
>
Clear
</Button>
<Button type="primary" onClick={() => applySearch()}>
Apply search
</Button>
</div>
</PopoverContent_Shadcn_>
</Popover_Shadcn_>
)
}