All files / src/lib useAlerts.ts

0% Statements 0/12
0% Branches 0/10
0% Functions 0/3
0% Lines 0/10

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36                                                                       
import { UseQueryOptions, useQuery } from '@tanstack/react-query'
import { ApiError } from 'next/dist/server/api-utils'
 
import { Alert, AlertApiRequestQuery } from './types'
 
export const fetchAlerts = async (
  alertQuery: AlertApiRequestQuery,
  init?: RequestInit,
): Promise<Alert[] | null> => {
  const query = new URLSearchParams({ ...alertQuery }).toString()
  let uri = alertQuery.page ? `/api/alerts?${query}` : `/api/alerts`
 
  const response = await fetch(uri, {
    ...(init ?? {}),
    headers: { 'Cache-Control': 'max-age=600' },
  })
 
  if (response.ok) return response.json()
  if (response.status === 404) return null
  throw new ApiError(response.status, response.statusText)
}
 
export const useAlerts = (
  alertQuery: AlertApiRequestQuery,
  queryOptions?: Omit<
    UseQueryOptions<Alert[] | null, ApiError, Alert[] | null>,
    'queryKey' | 'queryFn'
  >,
) => {
  return useQuery<Alert[] | null, ApiError, Alert[] | null>({
    ...(queryOptions ?? {}),
    queryKey: ['ps:api:alerts', alertQuery],
    queryFn: ({ signal }) => fetchAlerts(alertQuery, { signal }),
  })
}