mirror of
https://github.com/danny-avila/LibreChat.git
synced 2026-03-16 04:36:34 +01:00
* 🗑️ chore: Remove unused Legacy Provider clients and related helpers * Deleted OpenAIClient and GoogleClient files along with their associated tests. * Removed references to these clients in the clients index file. * Cleaned up typedefs by removing the OpenAISpecClient export. * Updated chat controllers to use the OpenAI SDK directly instead of the removed client classes. * chore/remove-openapi-specs * 🗑️ chore: Remove unused mergeSort and misc utility functions * Deleted mergeSort.js and misc.js files as they are no longer needed. * Removed references to cleanUpPrimaryKeyValue in messages.js and adjusted related logic. * Updated mongoMeili.ts to eliminate local implementations of removed functions. * chore: remove legacy endpoints * chore: remove all plugins endpoint related code * chore: remove unused prompt handling code and clean up imports * Deleted handleInputs.js and instructions.js files as they are no longer needed. * Removed references to these files in the prompts index.js. * Updated docker-compose.yml to simplify reverse proxy configuration. * chore: remove unused LightningIcon import from Icons.tsx * chore: clean up translation.json by removing deprecated and unused keys * chore: update Jest configuration and remove unused mock file * Simplified the setupFiles array in jest.config.js by removing the fetchEventSource mock. * Deleted the fetchEventSource.js mock file as it is no longer needed. * fix: simplify endpoint type check in Landing and ConversationStarters components * Updated the endpoint type check to use strict equality for better clarity and performance. * Ensured consistency in the handling of the azureOpenAI endpoint across both components. * chore: remove unused dependencies from package.json and package-lock.json * chore: remove legacy EditController, associated routes and imports * chore: update banResponse logic to refine request handling for banned users * chore: remove unused validateEndpoint middleware and its references * chore: remove unused 'res' parameter from initializeClient in multiple endpoint files * chore: remove unused 'isSmallScreen' prop from BookmarkNav and NewChat components; clean up imports in ArchivedChatsTable and useSetIndexOptions hooks; enhance localization in PromptVersions * chore: remove unused import of Constants and TMessage from MobileNav; retain only necessary QueryKeys import * chore: remove unused TResPlugin type and related references; clean up imports in types and schemas
122 lines
3.3 KiB
TypeScript
122 lines
3.3 KiB
TypeScript
import {
|
|
TPreset,
|
|
TConversation,
|
|
EModelEndpoint,
|
|
tConvoUpdateSchema,
|
|
} from 'librechat-data-provider';
|
|
import type { TSetExample, TSetOption, TSetOptionsPayload } from '~/common';
|
|
import usePresetIndexOptions from './usePresetIndexOptions';
|
|
import { useChatContext } from '~/Providers/ChatContext';
|
|
|
|
type TUseSetOptions = (preset?: TPreset | boolean | null) => TSetOptionsPayload;
|
|
|
|
const useSetIndexOptions: TUseSetOptions = (preset = false) => {
|
|
const { conversation, setConversation } = useChatContext();
|
|
|
|
const result = usePresetIndexOptions(preset);
|
|
|
|
if (result && typeof result !== 'boolean') {
|
|
return result;
|
|
}
|
|
|
|
const setOption: TSetOption = (param) => (newValue) => {
|
|
const update = {};
|
|
update[param] = newValue;
|
|
|
|
if (param === 'presetOverride') {
|
|
const currentOverride = conversation?.presetOverride || {};
|
|
update['presetOverride'] = {
|
|
...currentOverride,
|
|
...(newValue as unknown as Partial<TPreset>),
|
|
};
|
|
}
|
|
|
|
// Auto-enable Responses API when web search is enabled (only for OpenAI/Azure/Custom endpoints)
|
|
if (param === 'web_search' && newValue === true) {
|
|
const currentEndpoint = conversation?.endpoint;
|
|
const isOpenAICompatible =
|
|
currentEndpoint === EModelEndpoint.openAI ||
|
|
currentEndpoint === EModelEndpoint.azureOpenAI ||
|
|
currentEndpoint === EModelEndpoint.custom;
|
|
|
|
if (isOpenAICompatible) {
|
|
const currentUseResponsesApi = conversation?.useResponsesApi ?? false;
|
|
if (!currentUseResponsesApi) {
|
|
update['useResponsesApi'] = true;
|
|
}
|
|
}
|
|
}
|
|
|
|
setConversation(
|
|
(prevState) =>
|
|
tConvoUpdateSchema.parse({
|
|
...prevState,
|
|
...update,
|
|
}) as TConversation,
|
|
);
|
|
};
|
|
|
|
const setExample: TSetExample = (i, type, newValue = null) => {
|
|
const update = {};
|
|
const current = conversation?.examples?.slice() || [];
|
|
const currentExample = { ...current[i] };
|
|
currentExample[type] = { content: newValue };
|
|
current[i] = currentExample;
|
|
update['examples'] = current;
|
|
setConversation(
|
|
(prevState) =>
|
|
tConvoUpdateSchema.parse({
|
|
...prevState,
|
|
...update,
|
|
}) as TConversation,
|
|
);
|
|
};
|
|
|
|
const addExample: () => void = () => {
|
|
const update = {};
|
|
const current = conversation?.examples?.slice() || [];
|
|
current.push({ input: { content: '' }, output: { content: '' } });
|
|
update['examples'] = current;
|
|
setConversation(
|
|
(prevState) =>
|
|
tConvoUpdateSchema.parse({
|
|
...prevState,
|
|
...update,
|
|
}) as TConversation,
|
|
);
|
|
};
|
|
|
|
const removeExample: () => void = () => {
|
|
const update = {};
|
|
const current = conversation?.examples?.slice() || [];
|
|
if (current.length <= 1) {
|
|
update['examples'] = [{ input: { content: '' }, output: { content: '' } }];
|
|
setConversation(
|
|
(prevState) =>
|
|
tConvoUpdateSchema.parse({
|
|
...prevState,
|
|
...update,
|
|
}) as TConversation,
|
|
);
|
|
return;
|
|
}
|
|
current.pop();
|
|
update['examples'] = current;
|
|
setConversation(
|
|
(prevState) =>
|
|
tConvoUpdateSchema.parse({
|
|
...prevState,
|
|
...update,
|
|
}) as TConversation,
|
|
);
|
|
};
|
|
|
|
return {
|
|
setOption,
|
|
setExample,
|
|
addExample,
|
|
removeExample,
|
|
};
|
|
};
|
|
|
|
export default useSetIndexOptions;
|