import { useMutation, useQueryClient } from '@tanstack/react-query' import { toast } from 'sonner' import { del, handleError } from 'data/fetchers' import type { ResponseError, UseCustomMutationOptions } from 'types' import { subscriptionKeys } from './keys' import type { AddonVariantId } from './types' export type ProjectAddonRemoveVariables = { projectRef: string variant: AddonVariantId } export async function removeSubscriptionAddon({ projectRef, variant, }: ProjectAddonRemoveVariables) { if (!projectRef) throw new Error('projectRef is required') if (!variant) throw new Error('variant is required') const { data, error } = await del(`/platform/projects/{ref}/billing/addons/{addon_variant}`, { params: { path: { ref: projectRef, addon_variant: variant, }, }, }) if (error) handleError(error) return data } type ProjectAddonRemoveData = Awaited> export const useProjectAddonRemoveMutation = ({ onSuccess, onError, ...options }: Omit< UseCustomMutationOptions, 'mutationFn' > = {}) => { const queryClient = useQueryClient() return useMutation({ mutationFn: (vars) => removeSubscriptionAddon(vars), async onSuccess(data, variables, context) { const { projectRef } = variables // [Joshen] Only invalidate addons, not subscriptions, as AddOn section in // subscription page is using AddOn react query await queryClient.invalidateQueries({ queryKey: subscriptionKeys.addons(projectRef) }) await onSuccess?.(data, variables, context) }, async onError(data, variables, context) { if (onError === undefined) { toast.error(`Failed to remove addon: ${data.message}`) } else { onError(data, variables, context) } }, ...options, }) }