import { useMutation, UseMutationOptions, useQueryClient } from '@tanstack/react-query' import { toast } from 'react-hot-toast' import { post } from 'data/fetchers' import { ResponseError } from 'types' import { integrationKeys } from './keys' export type GitHubIntegrationCreateVariables = { installationId: number orgSlug: string metadata: { supabaseConfig: { supabaseDirectory: string } } } export async function createGitHubIntegration({ installationId, orgSlug, metadata, }: GitHubIntegrationCreateVariables) { const { data, error } = await post('/platform/integrations/github', { body: { installation_id: installationId, organization_slug: orgSlug, metadata: metadata as any, }, }) if (error) throw error return data } type GitHubIntegrationCreateData = Awaited> export const useGitHubIntegrationCreateMutation = ({ onSuccess, onError, ...options }: Omit< UseMutationOptions, 'mutationFn' > = {}) => { const queryClient = useQueryClient() return useMutation( (vars) => createGitHubIntegration(vars), { async onSuccess(data, variables, context) { await Promise.all([ queryClient.invalidateQueries(integrationKeys.integrationsList()), queryClient.invalidateQueries(integrationKeys.integrationsListWithOrg(variables.orgSlug)), queryClient.invalidateQueries(integrationKeys.githubRepoList(data.id)), ]) await onSuccess?.(data, variables, context) }, async onError(data, variables, context) { if (onError === undefined) { toast.error(`Failed to create Github integration: ${data.message}`) } else { onError(data, variables, context) } }, ...options, } ) }