import { useQuery, useMutation, useQueryClient } from '@tanstack/react-query'; import type { UseQueryOptions, UseMutationResult, QueryObserverResult, } from '@tanstack/react-query'; import { initialModelsConfig, LocalStorageKeys } from '../config'; import { defaultOrderQuery } from '../types/assistants'; import * as dataService from '../data-service'; import * as m from '../types/mutations'; import { QueryKeys } from '../keys'; import request from '../request'; import * as s from '../schemas'; import * as t from '../types'; export const useAbortRequestWithMessage = (): UseMutationResult< void, Error, { endpoint: string; abortKey: string; message: string } > => { const queryClient = useQueryClient(); return useMutation( ({ endpoint, abortKey, message }) => dataService.abortRequestWithMessage(endpoint, abortKey, message), { onSuccess: () => { queryClient.invalidateQueries([QueryKeys.balance]); }, }, ); }; export const useGetUserQuery = ( config?: UseQueryOptions, ): QueryObserverResult => { return useQuery([QueryKeys.user], () => dataService.getUser(), { refetchOnWindowFocus: false, refetchOnReconnect: false, refetchOnMount: false, retry: false, ...config, }); }; export const useGetMessagesByConvoId = ( id: string, config?: UseQueryOptions, ): QueryObserverResult => { return useQuery( [QueryKeys.messages, id], () => dataService.getMessagesByConvoId(id), { refetchOnWindowFocus: false, refetchOnReconnect: false, refetchOnMount: false, ...config, }, ); }; export const useGetSharedMessages = ( shareId: string, config?: UseQueryOptions, ): QueryObserverResult => { return useQuery( [QueryKeys.sharedMessages, shareId], () => dataService.getSharedMessages(shareId), { refetchOnWindowFocus: false, refetchOnReconnect: false, refetchOnMount: false, ...config, }, ); }; export const useGetUserBalance = ( config?: UseQueryOptions, ): QueryObserverResult => { return useQuery([QueryKeys.balance], () => dataService.getUserBalance(), { refetchOnWindowFocus: true, refetchOnReconnect: true, refetchOnMount: true, ...config, }); }; export const useGetConversationByIdQuery = ( id: string, config?: UseQueryOptions, ): QueryObserverResult => { return useQuery( [QueryKeys.conversation, id], () => dataService.getConversationById(id), { refetchOnWindowFocus: false, refetchOnReconnect: false, refetchOnMount: false, ...config, }, ); }; //This isn't ideal because its just a query and we're using mutation, but it was the only way //to make it work with how the Chat component is structured export const useGetConversationByIdMutation = (id: string): UseMutationResult => { const queryClient = useQueryClient(); return useMutation(() => dataService.getConversationById(id), { // onSuccess: (res: s.TConversation) => { onSuccess: () => { queryClient.invalidateQueries([QueryKeys.conversation, id]); }, }); }; export const useUpdateMessageMutation = ( id: string, ): UseMutationResult => { const queryClient = useQueryClient(); return useMutation((payload: t.TUpdateMessageRequest) => dataService.updateMessage(payload), { onSuccess: () => { queryClient.invalidateQueries([QueryKeys.messages, id]); }, }); }; export const useUpdateUserKeysMutation = (): UseMutationResult< t.TUser, unknown, t.TUpdateUserKeyRequest, unknown > => { const queryClient = useQueryClient(); return useMutation((payload: t.TUpdateUserKeyRequest) => dataService.updateUserKey(payload), { onSuccess: (data, variables) => { queryClient.invalidateQueries([QueryKeys.name, variables.name]); }, }); }; export const useClearConversationsMutation = (): UseMutationResult => { const queryClient = useQueryClient(); return useMutation(() => dataService.clearAllConversations(), { onSuccess: () => { queryClient.invalidateQueries([QueryKeys.allConversations]); }, }); }; export const useRevokeUserKeyMutation = (name: string): UseMutationResult => { const queryClient = useQueryClient(); return useMutation(() => dataService.revokeUserKey(name), { onSuccess: () => { queryClient.invalidateQueries([QueryKeys.name, name]); if (s.isAssistantsEndpoint(name)) { queryClient.invalidateQueries([QueryKeys.assistants, name, defaultOrderQuery]); queryClient.invalidateQueries([QueryKeys.assistantDocs]); queryClient.invalidateQueries([QueryKeys.assistants]); queryClient.invalidateQueries([QueryKeys.assistant]); queryClient.invalidateQueries([QueryKeys.actions]); queryClient.invalidateQueries([QueryKeys.tools]); } }, }); }; export const useRevokeAllUserKeysMutation = (): UseMutationResult => { const queryClient = useQueryClient(); return useMutation(() => dataService.revokeAllUserKeys(), { onSuccess: () => { queryClient.invalidateQueries([QueryKeys.name]); queryClient.invalidateQueries([ QueryKeys.assistants, s.EModelEndpoint.assistants, defaultOrderQuery, ]); queryClient.invalidateQueries([ QueryKeys.assistants, s.EModelEndpoint.azureAssistants, defaultOrderQuery, ]); queryClient.invalidateQueries([QueryKeys.assistantDocs]); queryClient.invalidateQueries([QueryKeys.assistants]); queryClient.invalidateQueries([QueryKeys.assistant]); queryClient.invalidateQueries([QueryKeys.actions]); queryClient.invalidateQueries([QueryKeys.tools]); }, }); }; export const useGetSearchEnabledQuery = ( config?: UseQueryOptions, ): QueryObserverResult => { return useQuery([QueryKeys.searchEnabled], () => dataService.getSearchEnabled(), { refetchOnWindowFocus: false, refetchOnReconnect: false, refetchOnMount: false, ...config, }); }; export const useGetEndpointsQuery = ( config?: UseQueryOptions, ): QueryObserverResult => { return useQuery( [QueryKeys.endpoints], () => dataService.getAIEndpoints(), { staleTime: Infinity, refetchOnWindowFocus: false, refetchOnReconnect: false, refetchOnMount: false, ...config, }, ); }; export const useGetModelsQuery = ( config?: UseQueryOptions, ): QueryObserverResult => { return useQuery([QueryKeys.models], () => dataService.getModels(), { initialData: initialModelsConfig, refetchOnWindowFocus: false, refetchOnReconnect: false, refetchOnMount: false, staleTime: Infinity, ...config, }); }; export const useCreatePresetMutation = (): UseMutationResult< s.TPreset, unknown, s.TPreset, unknown > => { const queryClient = useQueryClient(); return useMutation((payload: s.TPreset) => dataService.createPreset(payload), { onSuccess: () => { queryClient.invalidateQueries([QueryKeys.presets]); }, }); }; export const useDeletePresetMutation = (): UseMutationResult< m.PresetDeleteResponse, unknown, s.TPreset | undefined, unknown > => { const queryClient = useQueryClient(); return useMutation((payload: s.TPreset | undefined) => dataService.deletePreset(payload), { onSuccess: () => { queryClient.invalidateQueries([QueryKeys.presets]); }, }); }; export const useSearchQuery = ( searchQuery: string, pageNumber: string, config?: UseQueryOptions, ): QueryObserverResult => { return useQuery( [QueryKeys.searchResults, pageNumber, searchQuery], () => dataService.searchConversations(searchQuery, pageNumber), { refetchOnWindowFocus: false, refetchOnReconnect: false, refetchOnMount: false, ...config, }, ); }; export const useUpdateTokenCountMutation = (): UseMutationResult< t.TUpdateTokenCountResponse, unknown, { text: string }, unknown > => { const queryClient = useQueryClient(); return useMutation(({ text }: { text: string }) => dataService.updateTokenCount(text), { onSuccess: () => { queryClient.invalidateQueries([QueryKeys.tokenCount]); }, }); }; export const useLoginUserMutation = (): UseMutationResult< t.TLoginResponse, unknown, t.TLoginUser, unknown > => { const queryClient = useQueryClient(); return useMutation((payload: t.TLoginUser) => dataService.login(payload), { onMutate: () => { queryClient.removeQueries(); localStorage.removeItem(LocalStorageKeys.LAST_CONVO_SETUP); localStorage.removeItem(`${LocalStorageKeys.LAST_CONVO_SETUP}_0`); localStorage.removeItem(`${LocalStorageKeys.LAST_CONVO_SETUP}_1`); localStorage.removeItem(LocalStorageKeys.LAST_MODEL); localStorage.removeItem(LocalStorageKeys.LAST_TOOLS); localStorage.removeItem(LocalStorageKeys.FILES_TO_DELETE); // localStorage.removeItem('lastAssistant'); }, }); }; export const useRegisterUserMutation = ( options?: m.RegistrationOptions, ): UseMutationResult => { const queryClient = useQueryClient(); return useMutation((payload: t.TRegisterUser) => dataService.register(payload), { ...options, onSuccess: (...args) => { queryClient.invalidateQueries([QueryKeys.user]); if (options?.onSuccess) { options.onSuccess(...args); } }, }); }; export const useRefreshTokenMutation = (): UseMutationResult< t.TRefreshTokenResponse, unknown, unknown, unknown > => { const queryClient = useQueryClient(); return useMutation(() => request.refreshToken(), { onMutate: () => { queryClient.removeQueries(); }, }); }; export const useUserKeyQuery = ( name: string, config?: UseQueryOptions, ): QueryObserverResult => { return useQuery( [QueryKeys.name, name], () => { if (!name) { return Promise.resolve({ expiresAt: '' }); } return dataService.userKeyQuery(name); }, { refetchOnWindowFocus: false, refetchOnReconnect: false, refetchOnMount: false, retry: false, ...config, }, ); }; export const useRequestPasswordResetMutation = (): UseMutationResult< t.TRequestPasswordResetResponse, unknown, t.TRequestPasswordReset, unknown > => { return useMutation((payload: t.TRequestPasswordReset) => dataService.requestPasswordReset(payload), ); }; export const useResetPasswordMutation = (): UseMutationResult< unknown, unknown, t.TResetPassword, unknown > => { return useMutation((payload: t.TResetPassword) => dataService.resetPassword(payload)); }; export const useAvailablePluginsQuery = ( config?: UseQueryOptions, ): QueryObserverResult => { return useQuery( [QueryKeys.availablePlugins], () => dataService.getAvailablePlugins(), { refetchOnWindowFocus: false, refetchOnReconnect: false, refetchOnMount: false, ...config, }, ); }; export const useUpdateUserPluginsMutation = (): UseMutationResult< t.TUser, unknown, t.TUpdateUserPlugins, unknown > => { const queryClient = useQueryClient(); return useMutation((payload: t.TUpdateUserPlugins) => dataService.updateUserPlugins(payload), { onSuccess: () => { queryClient.invalidateQueries([QueryKeys.user]); }, }); }; export const useGetStartupConfig = ( config?: UseQueryOptions, ): QueryObserverResult => { return useQuery( [QueryKeys.startupConfig], () => dataService.getStartupConfig(), { refetchOnWindowFocus: false, refetchOnReconnect: false, refetchOnMount: false, ...config, }, ); }; export const useGetCustomConfigSpeechQuery = ( config?: UseQueryOptions, ): QueryObserverResult => { return useQuery( [QueryKeys.customConfigSpeech], () => dataService.getCustomConfigSpeech(), { refetchOnWindowFocus: false, refetchOnReconnect: false, refetchOnMount: false, ...config, }, ); };