mirror of
https://github.com/supabase/supabase.git
synced 2026-05-09 02:09:50 -04:00
f223b455d6
* 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>
33 lines
920 B
TypeScript
33 lines
920 B
TypeScript
import { Ref, useCallback } from 'react'
|
|
|
|
type PossibleRef<T> = Ref<T> | undefined
|
|
|
|
/**
|
|
* Set a given ref to a given value
|
|
* This utility takes care of different types of refs: callback refs and RefObject(s)
|
|
*/
|
|
function setRef<T>(ref: PossibleRef<T>, value: T) {
|
|
if (typeof ref === 'function') {
|
|
ref(value)
|
|
} else if (ref !== null && ref !== undefined) {
|
|
;(ref as React.MutableRefObject<T>).current = value
|
|
}
|
|
}
|
|
|
|
/**
|
|
* A utility to compose multiple refs together
|
|
* Accepts callback refs and RefObject(s)
|
|
*/
|
|
export function composeRefs<T>(...refs: PossibleRef<T>[]) {
|
|
return (node: T) => refs.forEach((ref) => setRef(ref, node))
|
|
}
|
|
|
|
/**
|
|
* A custom hook that composes multiple refs
|
|
* Accepts callback refs and RefObject(s)
|
|
*/
|
|
export function useComposedRefs<T>(...refs: PossibleRef<T>[]) {
|
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
return useCallback(composeRefs(...refs), refs)
|
|
}
|