Files
omnivore/packages/web/lib/networking/queries/useGetNewsletterEmailsQuery.tsx
2023-02-27 10:34:12 +08:00

73 lines
1.6 KiB
TypeScript

import { gql } from 'graphql-request'
import useSWR from 'swr'
import { publicGqlFetcher } from '../networkHelpers'
type NewsletterEmailsQueryResponse = {
isValidating: boolean
emailAddresses: NewsletterEmail[]
revalidate: () => void
}
type NewsletterEmailsResponseData = {
newsletterEmails?: NewsletterEmailsData
}
type NewsletterEmailsData = {
newsletterEmails?: unknown
}
export type NewsletterEmail = {
id: string
address: string
createdAt: string
subscriptionCount: number
confirmationCode?: string
}
export function useGetNewsletterEmailsQuery(): NewsletterEmailsQueryResponse {
const query = gql`
query GetNewsletterEmails {
newsletterEmails {
... on NewsletterEmailsSuccess {
newsletterEmails {
id
address
createdAt
subscriptionCount
confirmationCode
}
}
... on NewsletterEmailsError {
errorCodes
}
}
}
`
const { data, mutate, isValidating } = useSWR(query, publicGqlFetcher)
try {
if (data) {
const result = data as NewsletterEmailsResponseData
const emailAddresses = result.newsletterEmails
?.newsletterEmails as NewsletterEmail[]
return {
isValidating,
emailAddresses,
revalidate: () => {
mutate(undefined, true)
},
}
}
} catch (error) {
console.log('error', error)
}
return {
isValidating: true,
emailAddresses: [],
// eslint-disable-next-line @typescript-eslint/no-empty-function
revalidate: () => {},
}
}