import { useMutation, useQueryClient } from '@tanstack/react-query' import { toast } from 'sonner' import type { components } from 'data/api' import { handleError, post } from 'data/fetchers' import type { ResponseError, UseCustomMutationOptions } from 'types' import type { Content } from './content-query' import { contentKeys } from './keys' export type InsertContentPayload = Omit & { content: Content['content'] favorite?: boolean } export type InsertContentVariables = { projectRef: string payload: InsertContentPayload } export type InsertContentResponse = components['schemas']['UserContentObject'] export async function insertContent( { projectRef, payload }: InsertContentVariables, signal?: AbortSignal ) { const { data, error } = await post('/platform/projects/{ref}/content', { params: { path: { ref: projectRef } }, body: { id: payload.id, name: payload.name, description: payload.description, owner_id: payload.owner_id, type: payload.type, visibility: payload.visibility, content: payload.content as any, folder_id: payload.folder_id, favorite: payload.favorite, }, signal, }) if (error) handleError(error) return data } export type InsertContentData = Awaited> export const useContentInsertMutation = ({ onError, onSuccess, ...options }: Omit< UseCustomMutationOptions, 'mutationFn' > = {}) => { const queryClient = useQueryClient() return useMutation({ mutationFn: (args) => insertContent(args), async onSuccess(data, variables, context) { const { projectRef } = variables await queryClient.invalidateQueries({ queryKey: contentKeys.allContentLists(projectRef) }) await onSuccess?.(data, variables, context) }, async onError(data, variables, context) { if (onError === undefined) { toast.error(`Failed to insert content: ${data.message}`) } else { onError(data, variables, context) } }, ...options, }) }