import { useMutation } from '@tanstack/react-query' import { toast } from 'sonner' import { handleError, post } from '@/data/fetchers' import type { ResponseError, UseCustomMutationOptions } from '@/types' export type SendFeedbackVariables = { message: string pathname?: string projectRef?: string organizationSlug?: string } export async function sendFeedback({ message, pathname, projectRef, organizationSlug, }: SendFeedbackVariables) { const { data, error } = await post(`/platform/feedback/send`, { body: { message, category: 'Feedback', tags: ['dashboard-feedback'], projectRef, organizationSlug, pathname, }, }) if (error) handleError(error) return data } type SendFeedbackData = Awaited> export const useSendFeedbackMutation = ({ onError, ...options }: Omit< UseCustomMutationOptions, 'mutationFn' > = {}) => { return useMutation({ mutationFn: (vars) => sendFeedback(vars), async onError(data, variables, context) { if (onError === undefined) { toast.error(`Failed to submit feedback: ${data.message}`) } else { onError(data, variables, context) } }, ...options, }) }