ruvector/studio/components/ui/DataTable/DataTableToolbar.tsx
rUv 814f595995 feat(studio): Add complete RuVector Studio application
Major additions:
- Complete Next.js studio application with 1600+ components
- Docker support (Dockerfile.combined, docker-compose.yml)
- GCP deployment documentation and benchmarks
- SQL benchmark scripts for performance testing
- Sentry integration for monitoring
- Comprehensive test suite and mocks

Studio features:
- Dashboard and admin interfaces
- Data visualization components
- Authentication and user management
- API integration with RuVector backend
- Static data and public assets

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
2025-12-06 23:04:48 +00:00

80 lines
3 KiB
TypeScript

import { PanelLeftClose, PanelLeftOpen } from 'lucide-react'
import { ReactNode, useMemo } from 'react'
import { useHotKey } from 'hooks/ui/useHotKey'
import { Button, Tooltip, TooltipContent, TooltipTrigger } from 'ui'
import { formatCompactNumber } from './DataTable.utils'
import { DataTableFilterControlsDrawer } from './DataTableFilters/DataTableFilterControlsDrawer'
import { DataTableResetButton } from './DataTableResetButton'
import { DataTableViewOptions } from './DataTableViewOptions'
import { Kbd } from './primitives/Kbd'
import { useControls } from './providers/ControlsProvider'
import { useDataTable } from './providers/DataTableProvider'
interface DataTableToolbarProps {
renderActions?: () => ReactNode
}
export function DataTableToolbar({ renderActions }: DataTableToolbarProps) {
const { table, isLoading, columnFilters } = useDataTable()
const { open, setOpen } = useControls()
const filters = table.getState().columnFilters
useHotKey(() => setOpen((prev) => !prev), 'b')
const rows = useMemo(
() => ({
total: table.getCoreRowModel().rows.length,
filtered: table.getFilteredRowModel().rows.length,
}),
[isLoading, columnFilters]
)
return (
<div className="flex flex-wrap items-center justify-between gap-4">
<div className="flex flex-wrap items-center gap-2">
<Tooltip>
<TooltipTrigger asChild>
<Button
size="tiny"
type="default"
icon={open ? <PanelLeftClose /> : <PanelLeftOpen />}
onClick={() => setOpen((prev) => !prev)}
className="hidden sm:flex"
>
<span className="hidden md:block">{open ? 'Hide' : 'Show'} Controls</span>
</Button>
</TooltipTrigger>
<TooltipContent side="right">
<p>
Toggle controls with{' '}
<Kbd className="ml-1 text-muted-foreground group-hover:text-accent-foreground">
<span className="mr-1"></span>
<span>B</span>
</Kbd>
</p>
</TooltipContent>
</Tooltip>
<div className="block sm:hidden">
<DataTableFilterControlsDrawer />
</div>
<div>
<p className="hidden text-sm text-muted-foreground sm:block">
<span className="font-mono font-medium">{formatCompactNumber(rows.filtered)}</span> of{' '}
<span className="font-mono font-medium">{formatCompactNumber(rows.total)}</span> row(s){' '}
<span className="sr-only sm:not-sr-only">filtered</span>
</p>
<p className="block text-sm text-muted-foreground sm:hidden">
<span className="font-mono font-medium">{formatCompactNumber(rows.filtered)}</span>{' '}
row(s)
</p>
</div>
</div>
<div className="ml-auto flex items-center gap-2">
{filters.length ? <DataTableResetButton /> : null}
{renderActions?.()}
<DataTableViewOptions />
</div>
</div>
)
}