mirror of
https://github.com/supabase/supabase.git
synced 2026-07-03 01:34:31 +08:00
* init new unified page * moar logs * init * add infinite and live logs example * Update useLogsPreview.tsx * add more sources * wrapped auth logs with edge logs * add role and user id * move unified logs * init * move demo pages. create a new directory to work in * extracted beta unified logs into own components * add example base page and components * add new files to use actual logging query * more organization * change import * adds new logs page. adds new query * add data table to UI pacakges * revert * table styles * text size * add timestamp, table, icons for log types, status code styling * add host * add log count to edge functions * starts to add dynamic filtering * spiking trace UI * Update status-code.ts * add new linik * now using POST * fix chart data for default 1 hour view * update API to accept POST requests * new filters * Update level.ts * fixed up chart to work on level filter. split up the logic into new files * prep for log type * prepped query for WHERE * fix: issue with white space in url param column parsing * level param now being removed correctly. * fix issue with chart showing wrong buckets for different time ranges * remove old query * refactor the queries into function for each source * total count fixed * lots of layout * start fixing log counts * comment out min and max for a while * added trace logging prototype in * random trace logs added for demo * added logs and ui to view logs if any * add Auth user * fix the live logs issue * some left over code * Midway * First pass refactor + clean up + reorganize files * Fix TS issues * Remove unused files * Clean up * Final clean up * more clean up * More clean up * Remove unused packages * Fix * Lint * Add feature flag for unified logs * Refactor * Remove trace UI * Snake case log types * more clean up * More clean up * Fix ts * more clean up * fixes * add flag check and redirect if flag is false * Update middleware.ts * Nit lint * Fix * Last refactors --------- Co-authored-by: Jonathan Summers-Muir <MildTomato@users.noreply.github.com>
55 lines
1.4 KiB
TypeScript
55 lines
1.4 KiB
TypeScript
import { type Column } from '@tanstack/react-table'
|
|
import { ChevronDown, ChevronUp } from 'lucide-react'
|
|
|
|
import { Button, cn, type ButtonProps } from 'ui'
|
|
|
|
interface DataTableColumnHeaderProps<TData, TValue> extends ButtonProps {
|
|
column: Column<TData, TValue>
|
|
title: string
|
|
}
|
|
|
|
export const DataTableColumnHeader = <TData, TValue>({
|
|
column,
|
|
title,
|
|
className,
|
|
...props
|
|
}: DataTableColumnHeaderProps<TData, TValue>) => {
|
|
if (!column.getCanSort()) {
|
|
return <div className={cn(className)}>{title}</div>
|
|
}
|
|
|
|
return (
|
|
<Button
|
|
type="text"
|
|
size="small"
|
|
onClick={() => {
|
|
column.toggleSorting(undefined)
|
|
}}
|
|
className={cn(
|
|
'text-xs',
|
|
'py-0 px-0 h-7 hover:bg-transparent flex gap-2 items-center justify-between w-full',
|
|
className
|
|
)}
|
|
iconRight={
|
|
<span className="flex flex-col">
|
|
<ChevronUp
|
|
className={cn(
|
|
'-mb-1 hover:text-foreground-lighter',
|
|
column.getIsSorted() === 'asc' ? 'text-foreground' : 'text-foreground-muted'
|
|
)}
|
|
/>
|
|
<ChevronDown
|
|
className={cn(
|
|
'-mt-1 hover:text-foreground-lighter',
|
|
column.getIsSorted() === 'desc' ? 'text-foreground' : 'text-foreground-muted'
|
|
)}
|
|
/>
|
|
</span>
|
|
}
|
|
{...props}
|
|
>
|
|
<span>{title}</span>
|
|
</Button>
|
|
)
|
|
}
|