import { deleteUserMutationKeys } from "@better-auth-ui/core/plugins" import { mutationOptions, useMutation } from "@tanstack/react-query" import type { BetterFetchError } from "better-auth/react" import type { AuthClient } from "../../lib/auth-client" export type DeleteUserParams = Parameters< TAuthClient["deleteUser"] >[0] export type DeleteUserOptions = Omit< ReturnType>, "mutationKey" | "mutationFn" > /** * Mutation options factory for deleting the authenticated user's account. * * @param authClient - The Better Auth client. */ export function deleteUserOptions( authClient: TAuthClient ) { const mutationKey = deleteUserMutationKeys.deleteUser const mutationFn = (params: DeleteUserParams) => authClient.deleteUser({ ...params, fetchOptions: { ...params?.fetchOptions, throw: true } }) return mutationOptions< Awaited>, BetterFetchError, Parameters[0] >({ mutationKey, mutationFn }) } /** * Create a mutation for deleting the authenticated user's account. * * Wraps `authClient.deleteUser` and forwards React Query mutation options * such as `onSuccess`, `onError`, and `retry`. * * @param authClient - The Better Auth client. * @param options - React Query options forwarded to `useMutation`. */ export function useDeleteUser( authClient: TAuthClient, options?: DeleteUserOptions ) { return useMutation({ ...deleteUserOptions(authClient), ...options }) }