librechat-data-provider 0.3.5 → 0.3.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/index.es.js +1 -1
- package/dist/index.es.js.map +1 -1
- package/dist/index.js +1 -1
- package/dist/index.js.map +1 -1
- package/dist/react-query/index.es.js +1 -1
- package/dist/react-query/index.es.js.map +1 -1
- package/package.json +1 -1
- package/src/config.ts +51 -0
- package/src/data-service.ts +5 -1
- package/src/keys.ts +1 -0
- package/src/schemas.ts +38 -1
- package/src/types/files.ts +18 -5
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.es.js","sources":["../../src/api-endpoints.ts","../../src/request.ts","../../src/headers-helpers.ts","../../src/data-service.ts","../../src/keys.ts","../../src/react-query/react-query-service.ts","../../src/react-query/assistants.ts"],"sourcesContent":["export const user = () => '/api/user';\n\nexport const balance = () => '/api/balance';\n\nexport const userPlugins = () => '/api/user/plugins';\n\nexport const messages = (conversationId: string, messageId?: string) =>\n `/api/messages/${conversationId}${messageId ? `/${messageId}` : ''}`;\n\nconst keysEndpoint = '/api/keys';\n\nexport const keys = () => keysEndpoint;\n\nexport const userKeyQuery = (name: string) => `${keysEndpoint}?name=${name}`;\n\nexport const revokeUserKey = (name: string) => `${keysEndpoint}/${name}`;\n\nexport const revokeAllUserKeys = () => `${keysEndpoint}?all=true`;\n\nexport const abortRequest = (endpoint: string) => `/api/ask/${endpoint}/abort`;\n\nexport const conversations = (pageNumber: string) => `/api/convos?pageNumber=${pageNumber}`;\n\nexport const conversationById = (id: string) => `/api/convos/${id}`;\n\nexport const updateConversation = () => '/api/convos/update';\n\nexport const deleteConversation = () => '/api/convos/clear';\n\nexport const search = (q: string, pageNumber: string) =>\n `/api/search?q=${q}&pageNumber=${pageNumber}`;\n\nexport const searchEnabled = () => '/api/search/enable';\n\nexport const presets = () => '/api/presets';\n\nexport const deletePreset = () => '/api/presets/delete';\n\nexport const aiEndpoints = () => '/api/endpoints';\n\nexport const endpointsConfigOverride = () => '/api/endpoints/config/override';\n\nexport const models = () => '/api/models';\n\nexport const tokenizer = () => '/api/tokenizer';\n\nexport const login = () => '/api/auth/login';\n\nexport const logout = () => '/api/auth/logout';\n\nexport const register = () => '/api/auth/register';\n\nexport const loginFacebook = () => '/api/auth/facebook';\n\nexport const loginGoogle = () => '/api/auth/google';\n\nexport const refreshToken = (retry?: boolean) => `/api/auth/refresh${retry ? '?retry=true' : ''}`;\n\nexport const requestPasswordReset = () => '/api/auth/requestPasswordReset';\n\nexport const resetPassword = () => '/api/auth/resetPassword';\n\nexport const plugins = () => '/api/plugins';\n\nexport const config = () => '/api/config';\n\nexport const assistants = (id?: string) => `/api/assistants${id ? `/${id}` : ''}`;\n\nexport const files = () => '/api/files';\n\nexport const images = () => `${files()}/images`;\n\nexport const avatar = () => `${images()}/avatar`;\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport axios, { AxiosRequestConfig, AxiosError } from 'axios';\nimport { setTokenHeader } from './headers-helpers';\nimport * as endpoints from './api-endpoints';\n\nasync function _get<T>(url: string, options?: AxiosRequestConfig): Promise<T> {\n const response = await axios.get(url, { ...options });\n return response.data;\n}\n\nasync function _post(url: string, data?: any) {\n const response = await axios.post(url, JSON.stringify(data), {\n headers: { 'Content-Type': 'application/json' },\n });\n return response.data;\n}\n\nasync function _postMultiPart(url: string, formData: FormData, options?: AxiosRequestConfig) {\n const response = await axios.post(url, formData, {\n ...options,\n headers: { 'Content-Type': 'multipart/form-data' },\n });\n return response.data;\n}\n\nasync function _put(url: string, data?: any) {\n const response = await axios.put(url, JSON.stringify(data), {\n headers: { 'Content-Type': 'application/json' },\n });\n return response.data;\n}\n\nasync function _delete<T>(url: string): Promise<T> {\n const response = await axios.delete(url);\n return response.data;\n}\n\nasync function _deleteWithOptions<T>(url: string, options?: AxiosRequestConfig): Promise<T> {\n const response = await axios.delete(url, { ...options });\n return response.data;\n}\n\nasync function _patch(url: string, data?: any) {\n const response = await axios.patch(url, JSON.stringify(data), {\n headers: { 'Content-Type': 'application/json' },\n });\n return response.data;\n}\n\nlet isRefreshing = false;\nlet failedQueue: { resolve: (value?: any) => void; reject: (reason?: any) => void }[] = [];\n\nconst refreshToken = (retry?: boolean) => _post(endpoints.refreshToken(retry));\n\nconst processQueue = (error: AxiosError | null, token: string | null = null) => {\n failedQueue.forEach((prom) => {\n if (error) {\n prom.reject(error);\n } else {\n prom.resolve(token);\n }\n });\n failedQueue = [];\n};\n\naxios.interceptors.response.use(\n (response) => response,\n async (error) => {\n const originalRequest = error.config;\n\n if (error.response.status === 401 && !originalRequest._retry) {\n originalRequest._retry = true;\n\n if (isRefreshing) {\n try {\n const token = await new Promise((resolve, reject) => {\n failedQueue.push({ resolve, reject });\n });\n originalRequest.headers['Authorization'] = 'Bearer ' + token;\n return await axios(originalRequest);\n } catch (err) {\n return Promise.reject(err);\n }\n }\n\n isRefreshing = true;\n\n try {\n const { token } = await refreshToken(\n // Handle edge case where we get a blank screen if the initial 401 error is from a refresh token request\n originalRequest.url?.includes('api/auth/refresh') ? true : false,\n );\n\n if (token) {\n originalRequest.headers['Authorization'] = 'Bearer ' + token;\n setTokenHeader(token);\n window.dispatchEvent(new CustomEvent('tokenUpdated', { detail: token }));\n processQueue(null, token);\n return await axios(originalRequest);\n } else {\n window.location.href = '/login';\n }\n } catch (err) {\n processQueue(err as AxiosError, null);\n return Promise.reject(err);\n } finally {\n isRefreshing = false;\n }\n }\n\n return Promise.reject(error);\n },\n);\n\nexport default {\n get: _get,\n post: _post,\n postMultiPart: _postMultiPart,\n put: _put,\n delete: _delete,\n deleteWithOptions: _deleteWithOptions,\n patch: _patch,\n refreshToken,\n};\n","import axios from 'axios';\n\nexport function setAcceptLanguageHeader(value: string): void {\n axios.defaults.headers.common['Accept-Language'] = value;\n}\n\nexport function setTokenHeader(token: string) {\n axios.defaults.headers.common['Authorization'] = 'Bearer ' + token;\n}\n","import * as f from './types/files';\nimport * as m from './types/mutations';\nimport * as a from './types/assistants';\nimport * as t from './types';\nimport * as s from './schemas';\nimport request from './request';\nimport * as endpoints from './api-endpoints';\n\nexport function getConversations(pageNumber: string): Promise<t.TGetConversationsResponse> {\n return request.get(endpoints.conversations(pageNumber));\n}\n\nexport function abortRequestWithMessage(\n endpoint: string,\n abortKey: string,\n message: string,\n): Promise<void> {\n return request.post(endpoints.abortRequest(endpoint), { arg: { abortKey, message } });\n}\n\nexport function deleteConversation(payload: t.TDeleteConversationRequest) {\n //todo: this should be a DELETE request\n return request.post(endpoints.deleteConversation(), { arg: payload });\n}\n\nexport function clearAllConversations(): Promise<unknown> {\n return request.post(endpoints.deleteConversation(), { arg: {} });\n}\n\nexport function revokeUserKey(name: string): Promise<unknown> {\n return request.delete(endpoints.revokeUserKey(name));\n}\n\nexport function revokeAllUserKeys(): Promise<unknown> {\n return request.delete(endpoints.revokeAllUserKeys());\n}\n\nexport function getMessagesByConvoId(conversationId: string): Promise<s.TMessage[]> {\n if (conversationId === 'new') {\n return Promise.resolve([]);\n }\n return request.get(endpoints.messages(conversationId));\n}\n\nexport function getConversationById(id: string): Promise<s.TConversation> {\n return request.get(endpoints.conversationById(id));\n}\n\nexport function updateConversation(\n payload: t.TUpdateConversationRequest,\n): Promise<t.TUpdateConversationResponse> {\n return request.post(endpoints.updateConversation(), { arg: payload });\n}\n\nexport function updateMessage(payload: t.TUpdateMessageRequest): Promise<unknown> {\n const { conversationId, messageId, text } = payload;\n if (!conversationId) {\n throw new Error('conversationId is required');\n }\n\n return request.put(endpoints.messages(conversationId, messageId), { text });\n}\n\nexport function updateUserKey(payload: t.TUpdateUserKeyRequest) {\n const { value } = payload;\n if (!value) {\n throw new Error('value is required');\n }\n\n return request.put(endpoints.keys(), payload);\n}\n\nexport function getPresets(): Promise<s.TPreset[]> {\n return request.get(endpoints.presets());\n}\n\nexport function createPreset(payload: s.TPreset): Promise<s.TPreset> {\n return request.post(endpoints.presets(), payload);\n}\n\nexport function updatePreset(payload: s.TPreset): Promise<s.TPreset> {\n return request.post(endpoints.presets(), payload);\n}\n\nexport function deletePreset(arg: s.TPreset | undefined): Promise<m.PresetDeleteResponse> {\n return request.post(endpoints.deletePreset(), arg);\n}\n\nexport function getSearchEnabled(): Promise<boolean> {\n return request.get(endpoints.searchEnabled());\n}\n\nexport function getUser(): Promise<t.TUser> {\n return request.get(endpoints.user());\n}\n\nexport function getUserBalance(): Promise<string> {\n return request.get(endpoints.balance());\n}\n\nexport const searchConversations = async (\n q: string,\n pageNumber: string,\n): Promise<t.TSearchResults> => {\n return request.get(endpoints.search(q, pageNumber));\n};\n\nexport const updateTokenCount = (text: string) => {\n return request.post(endpoints.tokenizer(), { arg: text });\n};\n\nexport const login = (payload: t.TLoginUser) => {\n return request.post(endpoints.login(), payload);\n};\n\nexport const logout = () => {\n return request.post(endpoints.logout());\n};\n\nexport const register = (payload: t.TRegisterUser) => {\n return request.post(endpoints.register(), payload);\n};\n\nexport const userKeyQuery = (name: string): Promise<t.TCheckUserKeyResponse> =>\n request.get(endpoints.userKeyQuery(name));\n\nexport const getLoginGoogle = () => {\n return request.get(endpoints.loginGoogle());\n};\n\nexport const requestPasswordReset = (\n payload: t.TRequestPasswordReset,\n): Promise<t.TRequestPasswordResetResponse> => {\n return request.post(endpoints.requestPasswordReset(), payload);\n};\n\nexport const resetPassword = (payload: t.TResetPassword) => {\n return request.post(endpoints.resetPassword(), payload);\n};\n\nexport const getAvailablePlugins = (): Promise<s.TPlugin[]> => {\n return request.get(endpoints.plugins());\n};\n\nexport const updateUserPlugins = (payload: t.TUpdateUserPlugins) => {\n return request.post(endpoints.userPlugins(), payload);\n};\n\n/* Config */\n\nexport const getStartupConfig = (): Promise<t.TStartupConfig> => {\n return request.get(endpoints.config());\n};\n\nexport const getAIEndpoints = (): Promise<t.TEndpointsConfig> => {\n return request.get(endpoints.aiEndpoints());\n};\n\nexport const getModels = async (): Promise<t.TModelsConfig> => {\n return request.get(endpoints.models());\n};\n\nexport const getEndpointsConfigOverride = (): Promise<unknown | boolean> => {\n return request.get(endpoints.endpointsConfigOverride());\n};\n\n/* Assistants */\n\nexport const createAssistant = (data: a.AssistantCreateParams): Promise<a.Assistant> => {\n return request.post(endpoints.assistants(), data);\n};\n\nexport const getAssistantById = (assistant_id: string): Promise<a.Assistant> => {\n return request.get(endpoints.assistants(assistant_id));\n};\n\nexport const updateAssistant = (\n assistant_id: string,\n data: a.AssistantUpdateParams,\n): Promise<a.Assistant> => {\n return request.patch(endpoints.assistants(assistant_id), data);\n};\n\nexport const deleteAssistant = (assistant_id: string): Promise<void> => {\n return request.delete(endpoints.assistants(assistant_id));\n};\n\nexport const listAssistants = (\n params?: a.AssistantListParams,\n): Promise<a.AssistantListResponse> => {\n return request.get(endpoints.assistants(), { params });\n};\n\n/* Files */\n\nexport const uploadImage = (data: FormData): Promise<f.FileUploadResponse> => {\n return request.postMultiPart(endpoints.images(), data);\n};\n\nexport const uploadAvatar = (data: FormData): Promise<f.AvatarUploadResponse> => {\n return request.postMultiPart(endpoints.avatar(), data);\n};\n\nexport const deleteFiles = async (files: f.BatchFile[]): Promise<f.DeleteFilesResponse> =>\n request.deleteWithOptions(endpoints.files(), {\n data: { files },\n });\n","export enum QueryKeys {\n messages = 'messages',\n allConversations = 'allConversations',\n conversation = 'conversation',\n searchEnabled = 'searchEnabled',\n user = 'user',\n name = 'name', // user key name\n models = 'models',\n balance = 'balance',\n endpoints = 'endpoints',\n presets = 'presets',\n searchResults = 'searchResults',\n tokenCount = 'tokenCount',\n availablePlugins = 'availablePlugins',\n startupConfig = 'startupConfig',\n assistants = 'assistants',\n assistant = 'assistant',\n endpointsConfigOverride = 'endpointsConfigOverride',\n}\n\nexport enum MutationKeys {\n imageUpload = 'imageUpload',\n fileDelete = 'fileDelete',\n updatePreset = 'updatePreset',\n deletePreset = 'deletePreset',\n logoutUser = 'logoutUser',\n avatarUpload = 'avatarUpload',\n}\n","import {\n UseQueryOptions,\n useQuery,\n useMutation,\n useQueryClient,\n UseMutationResult,\n QueryObserverResult,\n} from '@tanstack/react-query';\nimport * as t from '../types';\nimport * as s from '../schemas';\nimport * as m from '../types/mutations';\nimport * as dataService from '../data-service';\nimport request from '../request';\nimport { QueryKeys } from '../keys';\n\nexport const useAbortRequestWithMessage = (): UseMutationResult<\n void,\n Error,\n { endpoint: string; abortKey: string; message: string }\n> => {\n const queryClient = useQueryClient();\n return useMutation(\n ({ endpoint, abortKey, message }) =>\n dataService.abortRequestWithMessage(endpoint, abortKey, message),\n {\n onSuccess: () => {\n queryClient.invalidateQueries([QueryKeys.balance]);\n },\n },\n );\n};\n\nexport const useGetUserQuery = (\n config?: UseQueryOptions<t.TUser>,\n): QueryObserverResult<t.TUser> => {\n return useQuery<t.TUser>([QueryKeys.user], () => dataService.getUser(), {\n refetchOnWindowFocus: false,\n refetchOnReconnect: false,\n refetchOnMount: false,\n retry: false,\n ...config,\n });\n};\n\nexport const useGetMessagesByConvoId = <TData = s.TMessage[]>(\n id: string,\n config?: UseQueryOptions<s.TMessage[], unknown, TData>,\n): QueryObserverResult<TData> => {\n return useQuery<s.TMessage[], unknown, TData>(\n [QueryKeys.messages, id],\n () => dataService.getMessagesByConvoId(id),\n {\n refetchOnWindowFocus: false,\n refetchOnReconnect: false,\n refetchOnMount: false,\n ...config,\n },\n );\n};\n\nexport const useGetUserBalance = (\n config?: UseQueryOptions<string>,\n): QueryObserverResult<string> => {\n return useQuery<string>([QueryKeys.balance], () => dataService.getUserBalance(), {\n refetchOnWindowFocus: true,\n refetchOnReconnect: true,\n refetchOnMount: true,\n ...config,\n });\n};\n\nexport const useGetConversationByIdQuery = (\n id: string,\n config?: UseQueryOptions<s.TConversation>,\n): QueryObserverResult<s.TConversation> => {\n return useQuery<s.TConversation>(\n [QueryKeys.conversation, id],\n () => dataService.getConversationById(id),\n {\n refetchOnWindowFocus: false,\n refetchOnReconnect: false,\n refetchOnMount: false,\n ...config,\n },\n );\n};\n\n/* like above, but first try the convos query data */\nexport const useGetConvoIdQuery = (\n id: string,\n config?: UseQueryOptions<s.TConversation>,\n): QueryObserverResult<s.TConversation> => {\n const queryClient = useQueryClient();\n return useQuery<s.TConversation>(\n [QueryKeys.conversation, id],\n () => {\n const defaultQuery = () => dataService.getConversationById(id);\n\n const convosQueryKey = [QueryKeys.allConversations, { pageNumber: '1', active: true }];\n const convosQuery = queryClient.getQueryData<t.TGetConversationsResponse>(convosQueryKey);\n\n if (!convosQuery) {\n return defaultQuery();\n }\n\n const convo = convosQuery.conversations?.find((c) => c.conversationId === id);\n if (convo) {\n return convo;\n }\n\n return defaultQuery();\n },\n {\n refetchOnWindowFocus: false,\n refetchOnReconnect: false,\n refetchOnMount: false,\n ...config,\n },\n );\n};\n\n//This isn't ideal because its just a query and we're using mutation, but it was the only way\n//to make it work with how the Chat component is structured\nexport const useGetConversationByIdMutation = (id: string): UseMutationResult<s.TConversation> => {\n const queryClient = useQueryClient();\n return useMutation(() => dataService.getConversationById(id), {\n // onSuccess: (res: s.TConversation) => {\n onSuccess: () => {\n queryClient.invalidateQueries([QueryKeys.conversation, id]);\n },\n });\n};\n\nexport const useUpdateConversationMutation = (\n id: string,\n): UseMutationResult<\n t.TUpdateConversationResponse,\n unknown,\n t.TUpdateConversationRequest,\n unknown\n> => {\n const queryClient = useQueryClient();\n return useMutation(\n (payload: t.TUpdateConversationRequest) => dataService.updateConversation(payload),\n {\n onSuccess: () => {\n queryClient.invalidateQueries([QueryKeys.conversation, id]);\n queryClient.invalidateQueries([QueryKeys.allConversations]);\n },\n },\n );\n};\n\nexport const useUpdateMessageMutation = (\n id: string,\n): UseMutationResult<unknown, unknown, t.TUpdateMessageRequest, unknown> => {\n const queryClient = useQueryClient();\n return useMutation((payload: t.TUpdateMessageRequest) => dataService.updateMessage(payload), {\n onSuccess: () => {\n queryClient.invalidateQueries([QueryKeys.messages, id]);\n },\n });\n};\n\nexport const useUpdateUserKeysMutation = (): UseMutationResult<\n t.TUser,\n unknown,\n t.TUpdateUserKeyRequest,\n unknown\n> => {\n const queryClient = useQueryClient();\n return useMutation((payload: t.TUpdateUserKeyRequest) => dataService.updateUserKey(payload), {\n onSuccess: () => {\n queryClient.invalidateQueries([QueryKeys.name]);\n },\n });\n};\n\nexport const useDeleteConversationMutation = (\n id?: string,\n): UseMutationResult<\n t.TDeleteConversationResponse,\n unknown,\n t.TDeleteConversationRequest,\n unknown\n> => {\n const queryClient = useQueryClient();\n return useMutation(\n (payload: t.TDeleteConversationRequest) => dataService.deleteConversation(payload),\n {\n onSuccess: () => {\n queryClient.invalidateQueries([QueryKeys.conversation, id]);\n queryClient.invalidateQueries([QueryKeys.allConversations]);\n },\n },\n );\n};\n\nexport const useClearConversationsMutation = (): UseMutationResult<unknown> => {\n const queryClient = useQueryClient();\n return useMutation(() => dataService.clearAllConversations(), {\n onSuccess: () => {\n queryClient.invalidateQueries([QueryKeys.allConversations]);\n },\n });\n};\n\nexport const useRevokeUserKeyMutation = (name: string): UseMutationResult<unknown> => {\n const queryClient = useQueryClient();\n return useMutation(() => dataService.revokeUserKey(name), {\n onSuccess: () => {\n queryClient.invalidateQueries([QueryKeys.name]);\n },\n });\n};\n\nexport const useRevokeAllUserKeysMutation = (): UseMutationResult<unknown> => {\n const queryClient = useQueryClient();\n return useMutation(() => dataService.revokeAllUserKeys(), {\n onSuccess: () => {\n queryClient.invalidateQueries([QueryKeys.name]);\n },\n });\n};\n\nexport const useGetConversationsQuery = (\n pageNumber: string,\n config?: UseQueryOptions<t.TGetConversationsResponse>,\n): QueryObserverResult<t.TGetConversationsResponse> => {\n return useQuery<t.TGetConversationsResponse>(\n [QueryKeys.allConversations, { pageNumber, active: true }],\n () => dataService.getConversations(pageNumber),\n {\n refetchOnReconnect: false,\n refetchOnMount: false,\n retry: 1,\n ...config,\n },\n );\n};\n\nexport const useGetSearchEnabledQuery = (\n config?: UseQueryOptions<boolean>,\n): QueryObserverResult<boolean> => {\n return useQuery<boolean>([QueryKeys.searchEnabled], () => dataService.getSearchEnabled(), {\n refetchOnWindowFocus: false,\n refetchOnReconnect: false,\n refetchOnMount: false,\n ...config,\n });\n};\n\nexport const useGetEndpointsQuery = <TData = t.TEndpointsConfig>(\n config?: UseQueryOptions<t.TEndpointsConfig, unknown, TData>,\n): QueryObserverResult<TData> => {\n return useQuery<t.TEndpointsConfig, unknown, TData>(\n [QueryKeys.endpoints],\n () => dataService.getAIEndpoints(),\n {\n staleTime: Infinity,\n refetchOnWindowFocus: false,\n refetchOnReconnect: false,\n refetchOnMount: false,\n ...config,\n },\n );\n};\n\nexport const useGetModelsQuery = (\n config?: UseQueryOptions<t.TModelsConfig>,\n): QueryObserverResult<t.TModelsConfig> => {\n return useQuery<t.TModelsConfig>([QueryKeys.models], () => dataService.getModels(), {\n staleTime: Infinity,\n refetchOnWindowFocus: false,\n refetchOnReconnect: false,\n refetchOnMount: false,\n ...config,\n });\n};\n\nexport const useCreatePresetMutation = (): UseMutationResult<\n s.TPreset,\n unknown,\n s.TPreset,\n unknown\n> => {\n const queryClient = useQueryClient();\n return useMutation((payload: s.TPreset) => dataService.createPreset(payload), {\n onSuccess: () => {\n queryClient.invalidateQueries([QueryKeys.presets]);\n },\n });\n};\n\nexport const useDeletePresetMutation = (): UseMutationResult<\n m.PresetDeleteResponse,\n unknown,\n s.TPreset | undefined,\n unknown\n> => {\n const queryClient = useQueryClient();\n return useMutation((payload: s.TPreset | undefined) => dataService.deletePreset(payload), {\n onSuccess: () => {\n queryClient.invalidateQueries([QueryKeys.presets]);\n },\n });\n};\n\nexport const useSearchQuery = (\n searchQuery: string,\n pageNumber: string,\n config?: UseQueryOptions<t.TSearchResults>,\n): QueryObserverResult<t.TSearchResults> => {\n return useQuery<t.TSearchResults>(\n [QueryKeys.searchResults, pageNumber, searchQuery],\n () => dataService.searchConversations(searchQuery, pageNumber),\n {\n refetchOnWindowFocus: false,\n refetchOnReconnect: false,\n refetchOnMount: false,\n ...config,\n },\n );\n};\n\nexport const useUpdateTokenCountMutation = (): UseMutationResult<\n t.TUpdateTokenCountResponse,\n unknown,\n { text: string },\n unknown\n> => {\n const queryClient = useQueryClient();\n return useMutation(({ text }: { text: string }) => dataService.updateTokenCount(text), {\n onSuccess: () => {\n queryClient.invalidateQueries([QueryKeys.tokenCount]);\n },\n });\n};\n\nexport const useLoginUserMutation = (): UseMutationResult<\n t.TLoginResponse,\n unknown,\n t.TLoginUser,\n unknown\n> => {\n const queryClient = useQueryClient();\n return useMutation((payload: t.TLoginUser) => dataService.login(payload), {\n onMutate: () => {\n queryClient.removeQueries();\n localStorage.removeItem('lastConversationSetup');\n localStorage.removeItem('lastSelectedModel');\n localStorage.removeItem('lastSelectedTools');\n localStorage.removeItem('filesToDelete');\n localStorage.removeItem('lastAssistant');\n },\n });\n};\n\nexport const useRegisterUserMutation = (): UseMutationResult<\n unknown,\n unknown,\n t.TRegisterUser,\n unknown\n> => {\n const queryClient = useQueryClient();\n return useMutation((payload: t.TRegisterUser) => dataService.register(payload), {\n onSuccess: () => {\n queryClient.invalidateQueries([QueryKeys.user]);\n },\n });\n};\n\nexport const useRefreshTokenMutation = (): UseMutationResult<\n t.TRefreshTokenResponse,\n unknown,\n unknown,\n unknown\n> => {\n const queryClient = useQueryClient();\n return useMutation(() => request.refreshToken(), {\n onMutate: () => {\n queryClient.removeQueries();\n },\n });\n};\n\nexport const useUserKeyQuery = (\n name: string,\n config?: UseQueryOptions<t.TCheckUserKeyResponse>,\n): QueryObserverResult<t.TCheckUserKeyResponse> => {\n return useQuery<t.TCheckUserKeyResponse>(\n [QueryKeys.name, name],\n () => {\n if (!name) {\n return Promise.resolve({ expiresAt: '' });\n }\n return dataService.userKeyQuery(name);\n },\n {\n refetchOnWindowFocus: false,\n refetchOnReconnect: false,\n refetchOnMount: false,\n retry: false,\n ...config,\n },\n );\n};\n\nexport const useRequestPasswordResetMutation = (): UseMutationResult<\n t.TRequestPasswordResetResponse,\n unknown,\n t.TRequestPasswordReset,\n unknown\n> => {\n return useMutation((payload: t.TRequestPasswordReset) =>\n dataService.requestPasswordReset(payload),\n );\n};\n\nexport const useResetPasswordMutation = (): UseMutationResult<\n unknown,\n unknown,\n t.TResetPassword,\n unknown\n> => {\n return useMutation((payload: t.TResetPassword) => dataService.resetPassword(payload));\n};\n\nexport const useAvailablePluginsQuery = (): QueryObserverResult<s.TPlugin[]> => {\n return useQuery<s.TPlugin[]>(\n [QueryKeys.availablePlugins],\n () => dataService.getAvailablePlugins(),\n {\n refetchOnWindowFocus: false,\n refetchOnReconnect: false,\n refetchOnMount: false,\n },\n );\n};\n\nexport const useUpdateUserPluginsMutation = (): UseMutationResult<\n t.TUser,\n unknown,\n t.TUpdateUserPlugins,\n unknown\n> => {\n const queryClient = useQueryClient();\n return useMutation((payload: t.TUpdateUserPlugins) => dataService.updateUserPlugins(payload), {\n onSuccess: () => {\n queryClient.invalidateQueries([QueryKeys.user]);\n },\n });\n};\n\nexport const useGetStartupConfig = (): QueryObserverResult<t.TStartupConfig> => {\n return useQuery<t.TStartupConfig>(\n [QueryKeys.startupConfig],\n () => dataService.getStartupConfig(),\n {\n refetchOnWindowFocus: false,\n refetchOnReconnect: false,\n refetchOnMount: false,\n },\n );\n};\n","import { useQuery, useMutation, useQueryClient, useInfiniteQuery } from '@tanstack/react-query';\nimport type {\n UseQueryOptions,\n UseMutationResult,\n QueryObserverResult,\n UseInfiniteQueryOptions,\n} from '@tanstack/react-query';\nimport * as t from '../types/assistants';\nimport * as dataService from '../data-service';\nimport { QueryKeys } from '../keys';\n\n/**\n * Hook for listing all assistants, with optional parameters provided for pagination and sorting\n */\nexport const useListAssistantsQuery = <TData = t.AssistantListResponse>(\n params?: t.AssistantListParams,\n config?: UseQueryOptions<t.AssistantListResponse, unknown, TData>,\n): QueryObserverResult<TData> => {\n return useQuery<t.AssistantListResponse, unknown, TData>(\n [QueryKeys.assistants, params],\n () => dataService.listAssistants(params),\n {\n // Example selector to sort them by created_at\n // select: (res) => {\n // return res.data.sort((a, b) => a.created_at - b.created_at);\n // },\n refetchOnWindowFocus: false,\n refetchOnReconnect: false,\n refetchOnMount: false,\n retry: false,\n ...config,\n },\n );\n};\n\nexport const useListAssistantsInfiniteQuery = (\n params?: t.AssistantListParams,\n config?: UseInfiniteQueryOptions<t.AssistantListResponse, Error>,\n) => {\n return useInfiniteQuery<t.AssistantListResponse, Error>(\n ['assistantsList', params],\n ({ pageParam = '' }) => dataService.listAssistants({ ...params, after: pageParam }),\n {\n getNextPageParam: (lastPage) => {\n // lastPage is of type AssistantListResponse, you can use the has_more and last_id from it directly\n if (lastPage.has_more) {\n return lastPage.last_id;\n }\n return undefined;\n },\n ...config,\n },\n );\n};\n\n/**\n * Hook for creating a new assistant\n */\nexport const useCreateAssistantMutation = (): UseMutationResult<\n t.Assistant,\n Error,\n t.AssistantCreateParams\n> => {\n const queryClient = useQueryClient();\n return useMutation(\n (newAssistantData: t.AssistantCreateParams) => dataService.createAssistant(newAssistantData),\n {\n onSuccess: () => {\n // Invalidate and refetch assistants query to update list\n queryClient.invalidateQueries([QueryKeys.assistants]);\n },\n },\n );\n};\n\n/**\n * Hook for retrieving details about a single assistant\n */\nexport const useGetAssistantByIdQuery = (\n assistant_id: string,\n config?: UseQueryOptions<t.Assistant>,\n): QueryObserverResult<t.Assistant> => {\n return useQuery<t.Assistant>(\n [QueryKeys.assistant, assistant_id],\n () => dataService.getAssistantById(assistant_id),\n {\n enabled: !!assistant_id, // Query will not execute until the assistant_id exists\n refetchOnWindowFocus: false,\n refetchOnReconnect: false,\n refetchOnMount: false,\n retry: false,\n ...config,\n },\n );\n};\n\n/**\n * Hook for updating an assistant\n */\nexport const useUpdateAssistantMutation = (): UseMutationResult<\n t.Assistant,\n Error,\n { assistant_id: string; data: t.AssistantUpdateParams }\n> => {\n const queryClient = useQueryClient();\n return useMutation(\n ({ assistant_id, data }: { assistant_id: string; data: t.AssistantUpdateParams }) =>\n dataService.updateAssistant(assistant_id, data),\n {\n onSuccess: (_, { assistant_id }) => {\n // Invalidate and refetch assistant details query\n queryClient.invalidateQueries([QueryKeys.assistant, assistant_id]);\n // Optionally invalidate and refetch list of assistants\n queryClient.invalidateQueries([QueryKeys.assistants]);\n },\n },\n );\n};\n\n/**\n * Hook for deleting an assistant\n */\nexport const useDeleteAssistantMutation = (): UseMutationResult<\n void,\n Error,\n { assistant_id: string }\n> => {\n const queryClient = useQueryClient();\n return useMutation(\n ({ assistant_id }: { assistant_id: string }) => dataService.deleteAssistant(assistant_id),\n {\n onSuccess: () => {\n // Invalidate and refetch assistant list query\n queryClient.invalidateQueries([QueryKeys.assistants]);\n },\n },\n );\n};\n"],"names":["messages","conversationId","messageId","concat","keysEndpoint","search","q","pageNumber","assistants","id","_post","url","data","axios","post","JSON","stringify","headers","_a","sent","isRefreshing","failedQueue","refreshToken","retry","endpoints.refreshToken","processQueue","error","token","forEach","prom","reject","resolve","interceptors","response","use","__awaiter","originalRequest","config","status","_retry","Promise","push","_b","err_1","includes","defaults","common","setTokenHeader","window","dispatchEvent","CustomEvent","detail","location","href","err_2","request","get","options","__assign","postMultiPart","formData","put","delete","deleteWithOptions","patch","revokeUserKey","name","endpoints.revokeUserKey","revokeAllUserKeys","getConversationById","endpoints.conversationById","updateUserKey","payload","value","Error","QueryKeys","MutationKeys","userKeyQuery","endpoints.userKeyQuery","listAssistants","params","endpoints.assistants","useAbortRequestWithMessage","queryClient","useQueryClient","useMutation","endpoint","abortKey","message","endpoints.abortRequest","arg","dataService.abortRequestWithMessage","onSuccess","invalidateQueries","balance","useGetUserQuery","useQuery","user","refetchOnWindowFocus","refetchOnReconnect","refetchOnMount","useGetMessagesByConvoId","endpoints.messages","useGetUserBalance","useGetConversationByIdQuery","conversation","dataService.getConversationById","useGetConvoIdQuery","defaultQuery","convosQueryKey","allConversations","active","convosQuery","getQueryData","convo","conversations","find","c","useGetConversationByIdMutation","useUpdateConversationMutation","dataService.updateConversation","useUpdateMessageMutation","text","dataService.updateMessage","useUpdateUserKeysMutation","dataService.updateUserKey","useDeleteConversationMutation","dataService.deleteConversation","useClearConversationsMutation","useRevokeUserKeyMutation","dataService.revokeUserKey","useRevokeAllUserKeysMutation","dataService.revokeAllUserKeys","useGetConversationsQuery","endpoints.conversations","dataService.getConversations","useGetSearchEnabledQuery","searchEnabled","useGetEndpointsQuery","endpoints","staleTime","Infinity","useGetModelsQuery","models","useCreatePresetMutation","dataService.createPreset","presets","useDeletePresetMutation","useSearchQuery","searchQuery","searchResults","endpoints.search","dataService.searchConversations","useUpdateTokenCountMutation","dataService.updateTokenCount","tokenCount","useLoginUserMutation","dataService.login","onMutate","removeQueries","localStorage","removeItem","useRegisterUserMutation","dataService.register","useRefreshTokenMutation","useUserKeyQuery","dataService.userKeyQuery","expiresAt","useRequestPasswordResetMutation","dataService.requestPasswordReset","useResetPasswordMutation","dataService.resetPassword","useAvailablePluginsQuery","availablePlugins","useUpdateUserPluginsMutation","dataService.updateUserPlugins","useGetStartupConfig","startupConfig","useListAssistantsQuery","dataService.listAssistants","useListAssistantsInfiniteQuery","useInfiniteQuery","pageParam","after","getNextPageParam","lastPage","has_more","last_id","useCreateAssistantMutation","newAssistantData","useGetAssistantByIdQuery","assistant_id","assistant","dataService.getAssistantById","enabled","useUpdateAssistantMutation","dataService.updateAssistant","_","useDeleteAssistantMutation","dataService.deleteAssistant"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"index.es.js","sources":["../../src/api-endpoints.ts","../../src/request.ts","../../src/headers-helpers.ts","../../src/data-service.ts","../../src/keys.ts","../../src/react-query/react-query-service.ts","../../src/react-query/assistants.ts"],"sourcesContent":["export const user = () => '/api/user';\n\nexport const balance = () => '/api/balance';\n\nexport const userPlugins = () => '/api/user/plugins';\n\nexport const messages = (conversationId: string, messageId?: string) =>\n `/api/messages/${conversationId}${messageId ? `/${messageId}` : ''}`;\n\nconst keysEndpoint = '/api/keys';\n\nexport const keys = () => keysEndpoint;\n\nexport const userKeyQuery = (name: string) => `${keysEndpoint}?name=${name}`;\n\nexport const revokeUserKey = (name: string) => `${keysEndpoint}/${name}`;\n\nexport const revokeAllUserKeys = () => `${keysEndpoint}?all=true`;\n\nexport const abortRequest = (endpoint: string) => `/api/ask/${endpoint}/abort`;\n\nexport const conversations = (pageNumber: string) => `/api/convos?pageNumber=${pageNumber}`;\n\nexport const conversationById = (id: string) => `/api/convos/${id}`;\n\nexport const updateConversation = () => '/api/convos/update';\n\nexport const deleteConversation = () => '/api/convos/clear';\n\nexport const search = (q: string, pageNumber: string) =>\n `/api/search?q=${q}&pageNumber=${pageNumber}`;\n\nexport const searchEnabled = () => '/api/search/enable';\n\nexport const presets = () => '/api/presets';\n\nexport const deletePreset = () => '/api/presets/delete';\n\nexport const aiEndpoints = () => '/api/endpoints';\n\nexport const endpointsConfigOverride = () => '/api/endpoints/config/override';\n\nexport const models = () => '/api/models';\n\nexport const tokenizer = () => '/api/tokenizer';\n\nexport const login = () => '/api/auth/login';\n\nexport const logout = () => '/api/auth/logout';\n\nexport const register = () => '/api/auth/register';\n\nexport const loginFacebook = () => '/api/auth/facebook';\n\nexport const loginGoogle = () => '/api/auth/google';\n\nexport const refreshToken = (retry?: boolean) => `/api/auth/refresh${retry ? '?retry=true' : ''}`;\n\nexport const requestPasswordReset = () => '/api/auth/requestPasswordReset';\n\nexport const resetPassword = () => '/api/auth/resetPassword';\n\nexport const plugins = () => '/api/plugins';\n\nexport const config = () => '/api/config';\n\nexport const assistants = (id?: string) => `/api/assistants${id ? `/${id}` : ''}`;\n\nexport const files = () => '/api/files';\n\nexport const images = () => `${files()}/images`;\n\nexport const avatar = () => `${images()}/avatar`;\n","/* eslint-disable @typescript-eslint/no-explicit-any */\nimport axios, { AxiosRequestConfig, AxiosError } from 'axios';\nimport { setTokenHeader } from './headers-helpers';\nimport * as endpoints from './api-endpoints';\n\nasync function _get<T>(url: string, options?: AxiosRequestConfig): Promise<T> {\n const response = await axios.get(url, { ...options });\n return response.data;\n}\n\nasync function _post(url: string, data?: any) {\n const response = await axios.post(url, JSON.stringify(data), {\n headers: { 'Content-Type': 'application/json' },\n });\n return response.data;\n}\n\nasync function _postMultiPart(url: string, formData: FormData, options?: AxiosRequestConfig) {\n const response = await axios.post(url, formData, {\n ...options,\n headers: { 'Content-Type': 'multipart/form-data' },\n });\n return response.data;\n}\n\nasync function _put(url: string, data?: any) {\n const response = await axios.put(url, JSON.stringify(data), {\n headers: { 'Content-Type': 'application/json' },\n });\n return response.data;\n}\n\nasync function _delete<T>(url: string): Promise<T> {\n const response = await axios.delete(url);\n return response.data;\n}\n\nasync function _deleteWithOptions<T>(url: string, options?: AxiosRequestConfig): Promise<T> {\n const response = await axios.delete(url, { ...options });\n return response.data;\n}\n\nasync function _patch(url: string, data?: any) {\n const response = await axios.patch(url, JSON.stringify(data), {\n headers: { 'Content-Type': 'application/json' },\n });\n return response.data;\n}\n\nlet isRefreshing = false;\nlet failedQueue: { resolve: (value?: any) => void; reject: (reason?: any) => void }[] = [];\n\nconst refreshToken = (retry?: boolean) => _post(endpoints.refreshToken(retry));\n\nconst processQueue = (error: AxiosError | null, token: string | null = null) => {\n failedQueue.forEach((prom) => {\n if (error) {\n prom.reject(error);\n } else {\n prom.resolve(token);\n }\n });\n failedQueue = [];\n};\n\naxios.interceptors.response.use(\n (response) => response,\n async (error) => {\n const originalRequest = error.config;\n\n if (error.response.status === 401 && !originalRequest._retry) {\n originalRequest._retry = true;\n\n if (isRefreshing) {\n try {\n const token = await new Promise((resolve, reject) => {\n failedQueue.push({ resolve, reject });\n });\n originalRequest.headers['Authorization'] = 'Bearer ' + token;\n return await axios(originalRequest);\n } catch (err) {\n return Promise.reject(err);\n }\n }\n\n isRefreshing = true;\n\n try {\n const { token } = await refreshToken(\n // Handle edge case where we get a blank screen if the initial 401 error is from a refresh token request\n originalRequest.url?.includes('api/auth/refresh') ? true : false,\n );\n\n if (token) {\n originalRequest.headers['Authorization'] = 'Bearer ' + token;\n setTokenHeader(token);\n window.dispatchEvent(new CustomEvent('tokenUpdated', { detail: token }));\n processQueue(null, token);\n return await axios(originalRequest);\n } else {\n window.location.href = '/login';\n }\n } catch (err) {\n processQueue(err as AxiosError, null);\n return Promise.reject(err);\n } finally {\n isRefreshing = false;\n }\n }\n\n return Promise.reject(error);\n },\n);\n\nexport default {\n get: _get,\n post: _post,\n postMultiPart: _postMultiPart,\n put: _put,\n delete: _delete,\n deleteWithOptions: _deleteWithOptions,\n patch: _patch,\n refreshToken,\n};\n","import axios from 'axios';\n\nexport function setAcceptLanguageHeader(value: string): void {\n axios.defaults.headers.common['Accept-Language'] = value;\n}\n\nexport function setTokenHeader(token: string) {\n axios.defaults.headers.common['Authorization'] = 'Bearer ' + token;\n}\n","import * as f from './types/files';\nimport * as m from './types/mutations';\nimport * as a from './types/assistants';\nimport * as t from './types';\nimport * as s from './schemas';\nimport request from './request';\nimport * as endpoints from './api-endpoints';\n\nexport function getConversations(pageNumber: string): Promise<t.TGetConversationsResponse> {\n return request.get(endpoints.conversations(pageNumber));\n}\n\nexport function abortRequestWithMessage(\n endpoint: string,\n abortKey: string,\n message: string,\n): Promise<void> {\n return request.post(endpoints.abortRequest(endpoint), { arg: { abortKey, message } });\n}\n\nexport function deleteConversation(payload: t.TDeleteConversationRequest) {\n //todo: this should be a DELETE request\n return request.post(endpoints.deleteConversation(), { arg: payload });\n}\n\nexport function clearAllConversations(): Promise<unknown> {\n return request.post(endpoints.deleteConversation(), { arg: {} });\n}\n\nexport function revokeUserKey(name: string): Promise<unknown> {\n return request.delete(endpoints.revokeUserKey(name));\n}\n\nexport function revokeAllUserKeys(): Promise<unknown> {\n return request.delete(endpoints.revokeAllUserKeys());\n}\n\nexport function getMessagesByConvoId(conversationId: string): Promise<s.TMessage[]> {\n if (conversationId === 'new') {\n return Promise.resolve([]);\n }\n return request.get(endpoints.messages(conversationId));\n}\n\nexport function getConversationById(id: string): Promise<s.TConversation> {\n return request.get(endpoints.conversationById(id));\n}\n\nexport function updateConversation(\n payload: t.TUpdateConversationRequest,\n): Promise<t.TUpdateConversationResponse> {\n return request.post(endpoints.updateConversation(), { arg: payload });\n}\n\nexport function updateMessage(payload: t.TUpdateMessageRequest): Promise<unknown> {\n const { conversationId, messageId, text } = payload;\n if (!conversationId) {\n throw new Error('conversationId is required');\n }\n\n return request.put(endpoints.messages(conversationId, messageId), { text });\n}\n\nexport function updateUserKey(payload: t.TUpdateUserKeyRequest) {\n const { value } = payload;\n if (!value) {\n throw new Error('value is required');\n }\n\n return request.put(endpoints.keys(), payload);\n}\n\nexport function getPresets(): Promise<s.TPreset[]> {\n return request.get(endpoints.presets());\n}\n\nexport function createPreset(payload: s.TPreset): Promise<s.TPreset> {\n return request.post(endpoints.presets(), payload);\n}\n\nexport function updatePreset(payload: s.TPreset): Promise<s.TPreset> {\n return request.post(endpoints.presets(), payload);\n}\n\nexport function deletePreset(arg: s.TPreset | undefined): Promise<m.PresetDeleteResponse> {\n return request.post(endpoints.deletePreset(), arg);\n}\n\nexport function getSearchEnabled(): Promise<boolean> {\n return request.get(endpoints.searchEnabled());\n}\n\nexport function getUser(): Promise<t.TUser> {\n return request.get(endpoints.user());\n}\n\nexport function getUserBalance(): Promise<string> {\n return request.get(endpoints.balance());\n}\n\nexport const searchConversations = async (\n q: string,\n pageNumber: string,\n): Promise<t.TSearchResults> => {\n return request.get(endpoints.search(q, pageNumber));\n};\n\nexport const updateTokenCount = (text: string) => {\n return request.post(endpoints.tokenizer(), { arg: text });\n};\n\nexport const login = (payload: t.TLoginUser) => {\n return request.post(endpoints.login(), payload);\n};\n\nexport const logout = () => {\n return request.post(endpoints.logout());\n};\n\nexport const register = (payload: t.TRegisterUser) => {\n return request.post(endpoints.register(), payload);\n};\n\nexport const userKeyQuery = (name: string): Promise<t.TCheckUserKeyResponse> =>\n request.get(endpoints.userKeyQuery(name));\n\nexport const getLoginGoogle = () => {\n return request.get(endpoints.loginGoogle());\n};\n\nexport const requestPasswordReset = (\n payload: t.TRequestPasswordReset,\n): Promise<t.TRequestPasswordResetResponse> => {\n return request.post(endpoints.requestPasswordReset(), payload);\n};\n\nexport const resetPassword = (payload: t.TResetPassword) => {\n return request.post(endpoints.resetPassword(), payload);\n};\n\nexport const getAvailablePlugins = (): Promise<s.TPlugin[]> => {\n return request.get(endpoints.plugins());\n};\n\nexport const updateUserPlugins = (payload: t.TUpdateUserPlugins) => {\n return request.post(endpoints.userPlugins(), payload);\n};\n\n/* Config */\n\nexport const getStartupConfig = (): Promise<t.TStartupConfig> => {\n return request.get(endpoints.config());\n};\n\nexport const getAIEndpoints = (): Promise<t.TEndpointsConfig> => {\n return request.get(endpoints.aiEndpoints());\n};\n\nexport const getModels = async (): Promise<t.TModelsConfig> => {\n return request.get(endpoints.models());\n};\n\nexport const getEndpointsConfigOverride = (): Promise<unknown | boolean> => {\n return request.get(endpoints.endpointsConfigOverride());\n};\n\n/* Assistants */\n\nexport const createAssistant = (data: a.AssistantCreateParams): Promise<a.Assistant> => {\n return request.post(endpoints.assistants(), data);\n};\n\nexport const getAssistantById = (assistant_id: string): Promise<a.Assistant> => {\n return request.get(endpoints.assistants(assistant_id));\n};\n\nexport const updateAssistant = (\n assistant_id: string,\n data: a.AssistantUpdateParams,\n): Promise<a.Assistant> => {\n return request.patch(endpoints.assistants(assistant_id), data);\n};\n\nexport const deleteAssistant = (assistant_id: string): Promise<void> => {\n return request.delete(endpoints.assistants(assistant_id));\n};\n\nexport const listAssistants = (\n params?: a.AssistantListParams,\n): Promise<a.AssistantListResponse> => {\n return request.get(endpoints.assistants(), { params });\n};\n\n/* Files */\n\nexport const getFiles = (): Promise<f.TFile[]> => {\n return request.get(endpoints.files());\n};\n\nexport const uploadImage = (data: FormData): Promise<f.TFileUpload> => {\n return request.postMultiPart(endpoints.images(), data);\n};\n\nexport const uploadAvatar = (data: FormData): Promise<f.AvatarUploadResponse> => {\n return request.postMultiPart(endpoints.avatar(), data);\n};\n\nexport const deleteFiles = async (files: f.BatchFile[]): Promise<f.DeleteFilesResponse> =>\n request.deleteWithOptions(endpoints.files(), {\n data: { files },\n });\n","export enum QueryKeys {\n messages = 'messages',\n allConversations = 'allConversations',\n conversation = 'conversation',\n searchEnabled = 'searchEnabled',\n user = 'user',\n name = 'name', // user key name\n models = 'models',\n balance = 'balance',\n endpoints = 'endpoints',\n presets = 'presets',\n searchResults = 'searchResults',\n tokenCount = 'tokenCount',\n availablePlugins = 'availablePlugins',\n startupConfig = 'startupConfig',\n assistants = 'assistants',\n assistant = 'assistant',\n endpointsConfigOverride = 'endpointsConfigOverride',\n files = 'files',\n}\n\nexport enum MutationKeys {\n imageUpload = 'imageUpload',\n fileDelete = 'fileDelete',\n updatePreset = 'updatePreset',\n deletePreset = 'deletePreset',\n logoutUser = 'logoutUser',\n avatarUpload = 'avatarUpload',\n}\n","import {\n UseQueryOptions,\n useQuery,\n useMutation,\n useQueryClient,\n UseMutationResult,\n QueryObserverResult,\n} from '@tanstack/react-query';\nimport * as t from '../types';\nimport * as s from '../schemas';\nimport * as m from '../types/mutations';\nimport * as dataService from '../data-service';\nimport request from '../request';\nimport { QueryKeys } from '../keys';\n\nexport const useAbortRequestWithMessage = (): UseMutationResult<\n void,\n Error,\n { endpoint: string; abortKey: string; message: string }\n> => {\n const queryClient = useQueryClient();\n return useMutation(\n ({ endpoint, abortKey, message }) =>\n dataService.abortRequestWithMessage(endpoint, abortKey, message),\n {\n onSuccess: () => {\n queryClient.invalidateQueries([QueryKeys.balance]);\n },\n },\n );\n};\n\nexport const useGetUserQuery = (\n config?: UseQueryOptions<t.TUser>,\n): QueryObserverResult<t.TUser> => {\n return useQuery<t.TUser>([QueryKeys.user], () => dataService.getUser(), {\n refetchOnWindowFocus: false,\n refetchOnReconnect: false,\n refetchOnMount: false,\n retry: false,\n ...config,\n });\n};\n\nexport const useGetMessagesByConvoId = <TData = s.TMessage[]>(\n id: string,\n config?: UseQueryOptions<s.TMessage[], unknown, TData>,\n): QueryObserverResult<TData> => {\n return useQuery<s.TMessage[], unknown, TData>(\n [QueryKeys.messages, id],\n () => dataService.getMessagesByConvoId(id),\n {\n refetchOnWindowFocus: false,\n refetchOnReconnect: false,\n refetchOnMount: false,\n ...config,\n },\n );\n};\n\nexport const useGetUserBalance = (\n config?: UseQueryOptions<string>,\n): QueryObserverResult<string> => {\n return useQuery<string>([QueryKeys.balance], () => dataService.getUserBalance(), {\n refetchOnWindowFocus: true,\n refetchOnReconnect: true,\n refetchOnMount: true,\n ...config,\n });\n};\n\nexport const useGetConversationByIdQuery = (\n id: string,\n config?: UseQueryOptions<s.TConversation>,\n): QueryObserverResult<s.TConversation> => {\n return useQuery<s.TConversation>(\n [QueryKeys.conversation, id],\n () => dataService.getConversationById(id),\n {\n refetchOnWindowFocus: false,\n refetchOnReconnect: false,\n refetchOnMount: false,\n ...config,\n },\n );\n};\n\n/* like above, but first try the convos query data */\nexport const useGetConvoIdQuery = (\n id: string,\n config?: UseQueryOptions<s.TConversation>,\n): QueryObserverResult<s.TConversation> => {\n const queryClient = useQueryClient();\n return useQuery<s.TConversation>(\n [QueryKeys.conversation, id],\n () => {\n const defaultQuery = () => dataService.getConversationById(id);\n\n const convosQueryKey = [QueryKeys.allConversations, { pageNumber: '1', active: true }];\n const convosQuery = queryClient.getQueryData<t.TGetConversationsResponse>(convosQueryKey);\n\n if (!convosQuery) {\n return defaultQuery();\n }\n\n const convo = convosQuery.conversations?.find((c) => c.conversationId === id);\n if (convo) {\n return convo;\n }\n\n return defaultQuery();\n },\n {\n refetchOnWindowFocus: false,\n refetchOnReconnect: false,\n refetchOnMount: false,\n ...config,\n },\n );\n};\n\n//This isn't ideal because its just a query and we're using mutation, but it was the only way\n//to make it work with how the Chat component is structured\nexport const useGetConversationByIdMutation = (id: string): UseMutationResult<s.TConversation> => {\n const queryClient = useQueryClient();\n return useMutation(() => dataService.getConversationById(id), {\n // onSuccess: (res: s.TConversation) => {\n onSuccess: () => {\n queryClient.invalidateQueries([QueryKeys.conversation, id]);\n },\n });\n};\n\nexport const useUpdateConversationMutation = (\n id: string,\n): UseMutationResult<\n t.TUpdateConversationResponse,\n unknown,\n t.TUpdateConversationRequest,\n unknown\n> => {\n const queryClient = useQueryClient();\n return useMutation(\n (payload: t.TUpdateConversationRequest) => dataService.updateConversation(payload),\n {\n onSuccess: () => {\n queryClient.invalidateQueries([QueryKeys.conversation, id]);\n queryClient.invalidateQueries([QueryKeys.allConversations]);\n },\n },\n );\n};\n\nexport const useUpdateMessageMutation = (\n id: string,\n): UseMutationResult<unknown, unknown, t.TUpdateMessageRequest, unknown> => {\n const queryClient = useQueryClient();\n return useMutation((payload: t.TUpdateMessageRequest) => dataService.updateMessage(payload), {\n onSuccess: () => {\n queryClient.invalidateQueries([QueryKeys.messages, id]);\n },\n });\n};\n\nexport const useUpdateUserKeysMutation = (): UseMutationResult<\n t.TUser,\n unknown,\n t.TUpdateUserKeyRequest,\n unknown\n> => {\n const queryClient = useQueryClient();\n return useMutation((payload: t.TUpdateUserKeyRequest) => dataService.updateUserKey(payload), {\n onSuccess: () => {\n queryClient.invalidateQueries([QueryKeys.name]);\n },\n });\n};\n\nexport const useDeleteConversationMutation = (\n id?: string,\n): UseMutationResult<\n t.TDeleteConversationResponse,\n unknown,\n t.TDeleteConversationRequest,\n unknown\n> => {\n const queryClient = useQueryClient();\n return useMutation(\n (payload: t.TDeleteConversationRequest) => dataService.deleteConversation(payload),\n {\n onSuccess: () => {\n queryClient.invalidateQueries([QueryKeys.conversation, id]);\n queryClient.invalidateQueries([QueryKeys.allConversations]);\n },\n },\n );\n};\n\nexport const useClearConversationsMutation = (): UseMutationResult<unknown> => {\n const queryClient = useQueryClient();\n return useMutation(() => dataService.clearAllConversations(), {\n onSuccess: () => {\n queryClient.invalidateQueries([QueryKeys.allConversations]);\n },\n });\n};\n\nexport const useRevokeUserKeyMutation = (name: string): UseMutationResult<unknown> => {\n const queryClient = useQueryClient();\n return useMutation(() => dataService.revokeUserKey(name), {\n onSuccess: () => {\n queryClient.invalidateQueries([QueryKeys.name]);\n },\n });\n};\n\nexport const useRevokeAllUserKeysMutation = (): UseMutationResult<unknown> => {\n const queryClient = useQueryClient();\n return useMutation(() => dataService.revokeAllUserKeys(), {\n onSuccess: () => {\n queryClient.invalidateQueries([QueryKeys.name]);\n },\n });\n};\n\nexport const useGetConversationsQuery = (\n pageNumber: string,\n config?: UseQueryOptions<t.TGetConversationsResponse>,\n): QueryObserverResult<t.TGetConversationsResponse> => {\n return useQuery<t.TGetConversationsResponse>(\n [QueryKeys.allConversations, { pageNumber, active: true }],\n () => dataService.getConversations(pageNumber),\n {\n refetchOnReconnect: false,\n refetchOnMount: false,\n retry: 1,\n ...config,\n },\n );\n};\n\nexport const useGetSearchEnabledQuery = (\n config?: UseQueryOptions<boolean>,\n): QueryObserverResult<boolean> => {\n return useQuery<boolean>([QueryKeys.searchEnabled], () => dataService.getSearchEnabled(), {\n refetchOnWindowFocus: false,\n refetchOnReconnect: false,\n refetchOnMount: false,\n ...config,\n });\n};\n\nexport const useGetEndpointsQuery = <TData = t.TEndpointsConfig>(\n config?: UseQueryOptions<t.TEndpointsConfig, unknown, TData>,\n): QueryObserverResult<TData> => {\n return useQuery<t.TEndpointsConfig, unknown, TData>(\n [QueryKeys.endpoints],\n () => dataService.getAIEndpoints(),\n {\n staleTime: Infinity,\n refetchOnWindowFocus: false,\n refetchOnReconnect: false,\n refetchOnMount: false,\n ...config,\n },\n );\n};\n\nexport const useGetModelsQuery = (\n config?: UseQueryOptions<t.TModelsConfig>,\n): QueryObserverResult<t.TModelsConfig> => {\n return useQuery<t.TModelsConfig>([QueryKeys.models], () => dataService.getModels(), {\n staleTime: Infinity,\n refetchOnWindowFocus: false,\n refetchOnReconnect: false,\n refetchOnMount: false,\n ...config,\n });\n};\n\nexport const useCreatePresetMutation = (): UseMutationResult<\n s.TPreset,\n unknown,\n s.TPreset,\n unknown\n> => {\n const queryClient = useQueryClient();\n return useMutation((payload: s.TPreset) => dataService.createPreset(payload), {\n onSuccess: () => {\n queryClient.invalidateQueries([QueryKeys.presets]);\n },\n });\n};\n\nexport const useDeletePresetMutation = (): UseMutationResult<\n m.PresetDeleteResponse,\n unknown,\n s.TPreset | undefined,\n unknown\n> => {\n const queryClient = useQueryClient();\n return useMutation((payload: s.TPreset | undefined) => dataService.deletePreset(payload), {\n onSuccess: () => {\n queryClient.invalidateQueries([QueryKeys.presets]);\n },\n });\n};\n\nexport const useSearchQuery = (\n searchQuery: string,\n pageNumber: string,\n config?: UseQueryOptions<t.TSearchResults>,\n): QueryObserverResult<t.TSearchResults> => {\n return useQuery<t.TSearchResults>(\n [QueryKeys.searchResults, pageNumber, searchQuery],\n () => dataService.searchConversations(searchQuery, pageNumber),\n {\n refetchOnWindowFocus: false,\n refetchOnReconnect: false,\n refetchOnMount: false,\n ...config,\n },\n );\n};\n\nexport const useUpdateTokenCountMutation = (): UseMutationResult<\n t.TUpdateTokenCountResponse,\n unknown,\n { text: string },\n unknown\n> => {\n const queryClient = useQueryClient();\n return useMutation(({ text }: { text: string }) => dataService.updateTokenCount(text), {\n onSuccess: () => {\n queryClient.invalidateQueries([QueryKeys.tokenCount]);\n },\n });\n};\n\nexport const useLoginUserMutation = (): UseMutationResult<\n t.TLoginResponse,\n unknown,\n t.TLoginUser,\n unknown\n> => {\n const queryClient = useQueryClient();\n return useMutation((payload: t.TLoginUser) => dataService.login(payload), {\n onMutate: () => {\n queryClient.removeQueries();\n localStorage.removeItem('lastConversationSetup');\n localStorage.removeItem('lastSelectedModel');\n localStorage.removeItem('lastSelectedTools');\n localStorage.removeItem('filesToDelete');\n localStorage.removeItem('lastAssistant');\n },\n });\n};\n\nexport const useRegisterUserMutation = (): UseMutationResult<\n unknown,\n unknown,\n t.TRegisterUser,\n unknown\n> => {\n const queryClient = useQueryClient();\n return useMutation((payload: t.TRegisterUser) => dataService.register(payload), {\n onSuccess: () => {\n queryClient.invalidateQueries([QueryKeys.user]);\n },\n });\n};\n\nexport const useRefreshTokenMutation = (): UseMutationResult<\n t.TRefreshTokenResponse,\n unknown,\n unknown,\n unknown\n> => {\n const queryClient = useQueryClient();\n return useMutation(() => request.refreshToken(), {\n onMutate: () => {\n queryClient.removeQueries();\n },\n });\n};\n\nexport const useUserKeyQuery = (\n name: string,\n config?: UseQueryOptions<t.TCheckUserKeyResponse>,\n): QueryObserverResult<t.TCheckUserKeyResponse> => {\n return useQuery<t.TCheckUserKeyResponse>(\n [QueryKeys.name, name],\n () => {\n if (!name) {\n return Promise.resolve({ expiresAt: '' });\n }\n return dataService.userKeyQuery(name);\n },\n {\n refetchOnWindowFocus: false,\n refetchOnReconnect: false,\n refetchOnMount: false,\n retry: false,\n ...config,\n },\n );\n};\n\nexport const useRequestPasswordResetMutation = (): UseMutationResult<\n t.TRequestPasswordResetResponse,\n unknown,\n t.TRequestPasswordReset,\n unknown\n> => {\n return useMutation((payload: t.TRequestPasswordReset) =>\n dataService.requestPasswordReset(payload),\n );\n};\n\nexport const useResetPasswordMutation = (): UseMutationResult<\n unknown,\n unknown,\n t.TResetPassword,\n unknown\n> => {\n return useMutation((payload: t.TResetPassword) => dataService.resetPassword(payload));\n};\n\nexport const useAvailablePluginsQuery = (): QueryObserverResult<s.TPlugin[]> => {\n return useQuery<s.TPlugin[]>(\n [QueryKeys.availablePlugins],\n () => dataService.getAvailablePlugins(),\n {\n refetchOnWindowFocus: false,\n refetchOnReconnect: false,\n refetchOnMount: false,\n },\n );\n};\n\nexport const useUpdateUserPluginsMutation = (): UseMutationResult<\n t.TUser,\n unknown,\n t.TUpdateUserPlugins,\n unknown\n> => {\n const queryClient = useQueryClient();\n return useMutation((payload: t.TUpdateUserPlugins) => dataService.updateUserPlugins(payload), {\n onSuccess: () => {\n queryClient.invalidateQueries([QueryKeys.user]);\n },\n });\n};\n\nexport const useGetStartupConfig = (): QueryObserverResult<t.TStartupConfig> => {\n return useQuery<t.TStartupConfig>(\n [QueryKeys.startupConfig],\n () => dataService.getStartupConfig(),\n {\n refetchOnWindowFocus: false,\n refetchOnReconnect: false,\n refetchOnMount: false,\n },\n );\n};\n","import { useQuery, useMutation, useQueryClient, useInfiniteQuery } from '@tanstack/react-query';\nimport type {\n UseQueryOptions,\n UseMutationResult,\n QueryObserverResult,\n UseInfiniteQueryOptions,\n} from '@tanstack/react-query';\nimport * as t from '../types/assistants';\nimport * as dataService from '../data-service';\nimport { QueryKeys } from '../keys';\n\n/**\n * Hook for listing all assistants, with optional parameters provided for pagination and sorting\n */\nexport const useListAssistantsQuery = <TData = t.AssistantListResponse>(\n params?: t.AssistantListParams,\n config?: UseQueryOptions<t.AssistantListResponse, unknown, TData>,\n): QueryObserverResult<TData> => {\n return useQuery<t.AssistantListResponse, unknown, TData>(\n [QueryKeys.assistants, params],\n () => dataService.listAssistants(params),\n {\n // Example selector to sort them by created_at\n // select: (res) => {\n // return res.data.sort((a, b) => a.created_at - b.created_at);\n // },\n refetchOnWindowFocus: false,\n refetchOnReconnect: false,\n refetchOnMount: false,\n retry: false,\n ...config,\n },\n );\n};\n\nexport const useListAssistantsInfiniteQuery = (\n params?: t.AssistantListParams,\n config?: UseInfiniteQueryOptions<t.AssistantListResponse, Error>,\n) => {\n return useInfiniteQuery<t.AssistantListResponse, Error>(\n ['assistantsList', params],\n ({ pageParam = '' }) => dataService.listAssistants({ ...params, after: pageParam }),\n {\n getNextPageParam: (lastPage) => {\n // lastPage is of type AssistantListResponse, you can use the has_more and last_id from it directly\n if (lastPage.has_more) {\n return lastPage.last_id;\n }\n return undefined;\n },\n ...config,\n },\n );\n};\n\n/**\n * Hook for creating a new assistant\n */\nexport const useCreateAssistantMutation = (): UseMutationResult<\n t.Assistant,\n Error,\n t.AssistantCreateParams\n> => {\n const queryClient = useQueryClient();\n return useMutation(\n (newAssistantData: t.AssistantCreateParams) => dataService.createAssistant(newAssistantData),\n {\n onSuccess: () => {\n // Invalidate and refetch assistants query to update list\n queryClient.invalidateQueries([QueryKeys.assistants]);\n },\n },\n );\n};\n\n/**\n * Hook for retrieving details about a single assistant\n */\nexport const useGetAssistantByIdQuery = (\n assistant_id: string,\n config?: UseQueryOptions<t.Assistant>,\n): QueryObserverResult<t.Assistant> => {\n return useQuery<t.Assistant>(\n [QueryKeys.assistant, assistant_id],\n () => dataService.getAssistantById(assistant_id),\n {\n enabled: !!assistant_id, // Query will not execute until the assistant_id exists\n refetchOnWindowFocus: false,\n refetchOnReconnect: false,\n refetchOnMount: false,\n retry: false,\n ...config,\n },\n );\n};\n\n/**\n * Hook for updating an assistant\n */\nexport const useUpdateAssistantMutation = (): UseMutationResult<\n t.Assistant,\n Error,\n { assistant_id: string; data: t.AssistantUpdateParams }\n> => {\n const queryClient = useQueryClient();\n return useMutation(\n ({ assistant_id, data }: { assistant_id: string; data: t.AssistantUpdateParams }) =>\n dataService.updateAssistant(assistant_id, data),\n {\n onSuccess: (_, { assistant_id }) => {\n // Invalidate and refetch assistant details query\n queryClient.invalidateQueries([QueryKeys.assistant, assistant_id]);\n // Optionally invalidate and refetch list of assistants\n queryClient.invalidateQueries([QueryKeys.assistants]);\n },\n },\n );\n};\n\n/**\n * Hook for deleting an assistant\n */\nexport const useDeleteAssistantMutation = (): UseMutationResult<\n void,\n Error,\n { assistant_id: string }\n> => {\n const queryClient = useQueryClient();\n return useMutation(\n ({ assistant_id }: { assistant_id: string }) => dataService.deleteAssistant(assistant_id),\n {\n onSuccess: () => {\n // Invalidate and refetch assistant list query\n queryClient.invalidateQueries([QueryKeys.assistants]);\n },\n },\n );\n};\n"],"names":["messages","conversationId","messageId","concat","keysEndpoint","search","q","pageNumber","assistants","id","_post","url","data","axios","post","JSON","stringify","headers","_a","sent","isRefreshing","failedQueue","refreshToken","retry","endpoints.refreshToken","processQueue","error","token","forEach","prom","reject","resolve","interceptors","response","use","__awaiter","originalRequest","config","status","_retry","Promise","push","_b","err_1","includes","defaults","common","setTokenHeader","window","dispatchEvent","CustomEvent","detail","location","href","err_2","request","get","options","__assign","postMultiPart","formData","put","delete","deleteWithOptions","patch","revokeUserKey","name","endpoints.revokeUserKey","revokeAllUserKeys","getConversationById","endpoints.conversationById","updateUserKey","payload","value","Error","QueryKeys","MutationKeys","userKeyQuery","endpoints.userKeyQuery","listAssistants","params","endpoints.assistants","useAbortRequestWithMessage","queryClient","useQueryClient","useMutation","endpoint","abortKey","message","endpoints.abortRequest","arg","dataService.abortRequestWithMessage","onSuccess","invalidateQueries","balance","useGetUserQuery","useQuery","user","refetchOnWindowFocus","refetchOnReconnect","refetchOnMount","useGetMessagesByConvoId","endpoints.messages","useGetUserBalance","useGetConversationByIdQuery","conversation","dataService.getConversationById","useGetConvoIdQuery","defaultQuery","convosQueryKey","allConversations","active","convosQuery","getQueryData","convo","conversations","find","c","useGetConversationByIdMutation","useUpdateConversationMutation","dataService.updateConversation","useUpdateMessageMutation","text","dataService.updateMessage","useUpdateUserKeysMutation","dataService.updateUserKey","useDeleteConversationMutation","dataService.deleteConversation","useClearConversationsMutation","useRevokeUserKeyMutation","dataService.revokeUserKey","useRevokeAllUserKeysMutation","dataService.revokeAllUserKeys","useGetConversationsQuery","endpoints.conversations","dataService.getConversations","useGetSearchEnabledQuery","searchEnabled","useGetEndpointsQuery","endpoints","staleTime","Infinity","useGetModelsQuery","models","useCreatePresetMutation","dataService.createPreset","presets","useDeletePresetMutation","useSearchQuery","searchQuery","searchResults","endpoints.search","dataService.searchConversations","useUpdateTokenCountMutation","dataService.updateTokenCount","tokenCount","useLoginUserMutation","dataService.login","onMutate","removeQueries","localStorage","removeItem","useRegisterUserMutation","dataService.register","useRefreshTokenMutation","useUserKeyQuery","dataService.userKeyQuery","expiresAt","useRequestPasswordResetMutation","dataService.requestPasswordReset","useResetPasswordMutation","dataService.resetPassword","useAvailablePluginsQuery","availablePlugins","useUpdateUserPluginsMutation","dataService.updateUserPlugins","useGetStartupConfig","startupConfig","useListAssistantsQuery","dataService.listAssistants","useListAssistantsInfiniteQuery","useInfiniteQuery","pageParam","after","getNextPageParam","lastPage","has_more","last_id","useCreateAssistantMutation","newAssistantData","useGetAssistantByIdQuery","assistant_id","assistant","dataService.getAssistantById","enabled","useUpdateAssistantMutation","dataService.updateAssistant","_","useDeleteAssistantMutation","dataService.deleteAssistant"],"mappings":"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"}
|
package/package.json
CHANGED
package/src/config.ts
CHANGED
|
@@ -1,5 +1,8 @@
|
|
|
1
1
|
import { z } from 'zod';
|
|
2
2
|
import { EModelEndpoint, eModelEndpointSchema } from './schemas';
|
|
3
|
+
import { FileSources } from './types/files';
|
|
4
|
+
|
|
5
|
+
export const fileSourceSchema = z.nativeEnum(FileSources);
|
|
3
6
|
|
|
4
7
|
export const endpointSchema = z.object({
|
|
5
8
|
name: z.string().refine((value) => !eModelEndpointSchema.safeParse(value).success, {
|
|
@@ -20,11 +23,13 @@ export const endpointSchema = z.object({
|
|
|
20
23
|
summaryModel: z.string().optional(),
|
|
21
24
|
forcePrompt: z.boolean().optional(),
|
|
22
25
|
modelDisplayLabel: z.string().optional(),
|
|
26
|
+
headers: z.record(z.any()).optional(),
|
|
23
27
|
});
|
|
24
28
|
|
|
25
29
|
export const configSchema = z.object({
|
|
26
30
|
version: z.string(),
|
|
27
31
|
cache: z.boolean(),
|
|
32
|
+
fileStrategy: fileSourceSchema.optional(),
|
|
28
33
|
endpoints: z
|
|
29
34
|
.object({
|
|
30
35
|
custom: z.array(endpointSchema.partial()),
|
|
@@ -184,3 +189,49 @@ export enum AuthKeys {
|
|
|
184
189
|
*/
|
|
185
190
|
GOOGLE_API_KEY = 'GOOGLE_API_KEY',
|
|
186
191
|
}
|
|
192
|
+
|
|
193
|
+
/**
|
|
194
|
+
* Enum for Image Detail Cost.
|
|
195
|
+
*
|
|
196
|
+
* **Low Res Fixed Cost:** `85`
|
|
197
|
+
*
|
|
198
|
+
* **High Res Calculation:**
|
|
199
|
+
*
|
|
200
|
+
* Number of `512px` Tiles * `170` + `85` (Additional Cost)
|
|
201
|
+
*/
|
|
202
|
+
export enum ImageDetailCost {
|
|
203
|
+
/**
|
|
204
|
+
* Low resolution is a fixed value.
|
|
205
|
+
*/
|
|
206
|
+
LOW = 85,
|
|
207
|
+
/**
|
|
208
|
+
* High resolution Cost Per Tile
|
|
209
|
+
*/
|
|
210
|
+
HIGH = 170,
|
|
211
|
+
/**
|
|
212
|
+
* Additional Cost added to High Resolution Total Cost
|
|
213
|
+
*/
|
|
214
|
+
ADDITIONAL = 85,
|
|
215
|
+
}
|
|
216
|
+
|
|
217
|
+
/**
|
|
218
|
+
* Tab values for Settings Dialog
|
|
219
|
+
*/
|
|
220
|
+
export enum SettingsTabValues {
|
|
221
|
+
/**
|
|
222
|
+
* Tab for General Settings
|
|
223
|
+
*/
|
|
224
|
+
GENERAL = 'general',
|
|
225
|
+
/**
|
|
226
|
+
* Tab for Beta Features
|
|
227
|
+
*/
|
|
228
|
+
BETA = 'beta',
|
|
229
|
+
/**
|
|
230
|
+
* Tab for Data Controls
|
|
231
|
+
*/
|
|
232
|
+
DATA = 'data',
|
|
233
|
+
/**
|
|
234
|
+
* Tab for Account Settings
|
|
235
|
+
*/
|
|
236
|
+
ACCOUNT = 'account',
|
|
237
|
+
}
|
package/src/data-service.ts
CHANGED
|
@@ -193,7 +193,11 @@ export const listAssistants = (
|
|
|
193
193
|
|
|
194
194
|
/* Files */
|
|
195
195
|
|
|
196
|
-
export const
|
|
196
|
+
export const getFiles = (): Promise<f.TFile[]> => {
|
|
197
|
+
return request.get(endpoints.files());
|
|
198
|
+
};
|
|
199
|
+
|
|
200
|
+
export const uploadImage = (data: FormData): Promise<f.TFileUpload> => {
|
|
197
201
|
return request.postMultiPart(endpoints.images(), data);
|
|
198
202
|
};
|
|
199
203
|
|
package/src/keys.ts
CHANGED
package/src/schemas.ts
CHANGED
|
@@ -52,6 +52,26 @@ export const eModelEndpointSchema = z.nativeEnum(EModelEndpoint);
|
|
|
52
52
|
|
|
53
53
|
export const extendedModelEndpointSchema = z.union([eModelEndpointSchema, z.string()]);
|
|
54
54
|
|
|
55
|
+
export enum ImageDetail {
|
|
56
|
+
low = 'low',
|
|
57
|
+
auto = 'auto',
|
|
58
|
+
high = 'high',
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
export const imageDetailNumeric = {
|
|
62
|
+
[ImageDetail.low]: 0,
|
|
63
|
+
[ImageDetail.auto]: 1,
|
|
64
|
+
[ImageDetail.high]: 2,
|
|
65
|
+
};
|
|
66
|
+
|
|
67
|
+
export const imageDetailValue = {
|
|
68
|
+
0: ImageDetail.low,
|
|
69
|
+
1: ImageDetail.auto,
|
|
70
|
+
2: ImageDetail.high,
|
|
71
|
+
};
|
|
72
|
+
|
|
73
|
+
export const eImageDetailSchema = z.nativeEnum(ImageDetail);
|
|
74
|
+
|
|
55
75
|
export const tPluginAuthConfigSchema = z.object({
|
|
56
76
|
authField: z.string(),
|
|
57
77
|
label: z.string(),
|
|
@@ -140,8 +160,8 @@ export type TMessage = z.input<typeof tMessageSchema> & {
|
|
|
140
160
|
plugin?: TResPlugin | null;
|
|
141
161
|
plugins?: TResPlugin[];
|
|
142
162
|
files?: {
|
|
143
|
-
type: string;
|
|
144
163
|
file_id: string;
|
|
164
|
+
type?: string;
|
|
145
165
|
filename?: string;
|
|
146
166
|
preview?: string;
|
|
147
167
|
filepath?: string;
|
|
@@ -184,6 +204,9 @@ export const tConversationSchema = z.object({
|
|
|
184
204
|
toneStyle: z.string().nullable().optional(),
|
|
185
205
|
maxOutputTokens: z.number().optional(),
|
|
186
206
|
agentOptions: tAgentOptionsSchema.nullable().optional(),
|
|
207
|
+
/* vision */
|
|
208
|
+
resendImages: z.boolean().optional(),
|
|
209
|
+
imageDetail: eImageDetailSchema.optional(),
|
|
187
210
|
/* assistant */
|
|
188
211
|
assistant_id: z.string().optional(),
|
|
189
212
|
thread_id: z.string().optional(),
|
|
@@ -234,6 +257,8 @@ export const openAISchema = tConversationSchema
|
|
|
234
257
|
top_p: true,
|
|
235
258
|
presence_penalty: true,
|
|
236
259
|
frequency_penalty: true,
|
|
260
|
+
resendImages: true,
|
|
261
|
+
imageDetail: true,
|
|
237
262
|
})
|
|
238
263
|
.transform((obj) => ({
|
|
239
264
|
...obj,
|
|
@@ -244,6 +269,8 @@ export const openAISchema = tConversationSchema
|
|
|
244
269
|
top_p: obj.top_p ?? 1,
|
|
245
270
|
presence_penalty: obj.presence_penalty ?? 0,
|
|
246
271
|
frequency_penalty: obj.frequency_penalty ?? 0,
|
|
272
|
+
resendImages: obj.resendImages ?? false,
|
|
273
|
+
imageDetail: obj.imageDetail ?? ImageDetail.auto,
|
|
247
274
|
}))
|
|
248
275
|
.catch(() => ({
|
|
249
276
|
model: 'gpt-3.5-turbo',
|
|
@@ -253,6 +280,8 @@ export const openAISchema = tConversationSchema
|
|
|
253
280
|
top_p: 1,
|
|
254
281
|
presence_penalty: 0,
|
|
255
282
|
frequency_penalty: 0,
|
|
283
|
+
resendImages: false,
|
|
284
|
+
imageDetail: ImageDetail.auto,
|
|
256
285
|
}));
|
|
257
286
|
|
|
258
287
|
export const googleSchema = tConversationSchema
|
|
@@ -455,6 +484,8 @@ export const compactOpenAISchema = tConversationSchema
|
|
|
455
484
|
top_p: true,
|
|
456
485
|
presence_penalty: true,
|
|
457
486
|
frequency_penalty: true,
|
|
487
|
+
resendImages: true,
|
|
488
|
+
imageDetail: true,
|
|
458
489
|
})
|
|
459
490
|
.transform((obj: Partial<TConversation>) => {
|
|
460
491
|
const newObj: Partial<TConversation> = { ...obj };
|
|
@@ -473,6 +504,12 @@ export const compactOpenAISchema = tConversationSchema
|
|
|
473
504
|
if (newObj.frequency_penalty === 0) {
|
|
474
505
|
delete newObj.frequency_penalty;
|
|
475
506
|
}
|
|
507
|
+
if (newObj.resendImages !== true) {
|
|
508
|
+
delete newObj.resendImages;
|
|
509
|
+
}
|
|
510
|
+
if (newObj.imageDetail === ImageDetail.auto) {
|
|
511
|
+
delete newObj.imageDetail;
|
|
512
|
+
}
|
|
476
513
|
|
|
477
514
|
return removeNullishValues(newObj);
|
|
478
515
|
})
|
package/src/types/files.ts
CHANGED
|
@@ -1,13 +1,25 @@
|
|
|
1
|
-
export
|
|
1
|
+
export enum FileSources {
|
|
2
|
+
local = 'local',
|
|
3
|
+
firebase = 'firebase',
|
|
4
|
+
openai = 'openai',
|
|
5
|
+
s3 = 's3',
|
|
6
|
+
}
|
|
7
|
+
|
|
8
|
+
export type TFile = {
|
|
2
9
|
message: string;
|
|
3
10
|
file_id: string;
|
|
4
|
-
temp_file_id: string;
|
|
5
11
|
filepath: string;
|
|
6
12
|
filename: string;
|
|
7
13
|
type: string;
|
|
8
14
|
size: number;
|
|
9
|
-
|
|
10
|
-
|
|
15
|
+
temp_file_id?: string;
|
|
16
|
+
source?: FileSources;
|
|
17
|
+
height?: number;
|
|
18
|
+
width?: number;
|
|
19
|
+
};
|
|
20
|
+
|
|
21
|
+
export type TFileUpload = TFile & {
|
|
22
|
+
temp_file_id: string;
|
|
11
23
|
};
|
|
12
24
|
|
|
13
25
|
export type AvatarUploadResponse = {
|
|
@@ -20,7 +32,7 @@ export type FileUploadBody = {
|
|
|
20
32
|
};
|
|
21
33
|
|
|
22
34
|
export type UploadMutationOptions = {
|
|
23
|
-
onSuccess?: (data:
|
|
35
|
+
onSuccess?: (data: TFileUpload, variables: FileUploadBody, context?: unknown) => void;
|
|
24
36
|
onMutate?: (variables: FileUploadBody) => void | Promise<unknown>;
|
|
25
37
|
onError?: (error: unknown, variables: FileUploadBody, context?: unknown) => void;
|
|
26
38
|
};
|
|
@@ -39,6 +51,7 @@ export type DeleteFilesResponse = {
|
|
|
39
51
|
export type BatchFile = {
|
|
40
52
|
file_id: string;
|
|
41
53
|
filepath: string;
|
|
54
|
+
source: FileSources;
|
|
42
55
|
};
|
|
43
56
|
|
|
44
57
|
export type DeleteFilesBody = {
|