mirror of
https://github.com/danny-avila/LibreChat.git
synced 2025-12-20 10:20:15 +01:00
* better i18n support an internationalization-framework. * removed unused package * auto sort for translation.json * fixed tests with the new locales function * added new CI actions from locize * to use locize a mention in the README.md * to use locize a mention in the README.md * updated README.md and added TRANSLATION.md to the repo * updated TRANSLATION.md badges * updated README.md to go to the TRANSLATION.md when clicking on the Translation Progress badge * updated TRANSLATION.md and added a new issue template. * updated TRANSLATION.md and added a new issue template. * updated issue template to add the iso code link. * updated the new GitHub actions for `locize` * updated label for new issue template --> i18n * fixed type issue * Fix eslint * Fix eslint with key-spacing spacing * fix: error type * fix: handle undefined values in SortFilterHeader component * fix: typing in Image component * fix: handle optional promptGroup in PromptCard component * fix: update localize function to accept string type and remove unnecessary JSX element * fix: update localize function to enforce TranslationKeys type for better type safety * fix: improve type safety and handle null values in Assistants component * fix: enhance null checks for fileId in FilesListView component * fix: localize 'Go back' button text in FilesListView component * fix: update aria-label for menu buttons and add translation for 'Close Menu' * docs: add Reasoning UI section for Chain-of-Thought AI models in README * fix: enhance type safety by adding type for message in MultiMessage component * fix: improve null checks and optional chaining in useAutoSave hook * fix: improve handling of optional properties in cleanupPreset function * fix: ensure isFetchingNextPage defaults to false and improve null checks for messages in Search component * fix: enhance type safety and null checks in useBuildMessageTree hook --------- Co-authored-by: Danny Avila <danny@librechat.ai>
83 lines
2.6 KiB
TypeScript
83 lines
2.6 KiB
TypeScript
import { useCallback, useMemo } from 'react';
|
|
import { ContentTypes } from 'librechat-data-provider';
|
|
import { useQueryClient } from '@tanstack/react-query';
|
|
|
|
import type {
|
|
Text,
|
|
TMessage,
|
|
ImageFile,
|
|
ContentPart,
|
|
PartMetadata,
|
|
TContentData,
|
|
EventSubmission,
|
|
TMessageContentParts,
|
|
} from 'librechat-data-provider';
|
|
import { addFileToCache } from '~/utils';
|
|
|
|
type TUseContentHandler = {
|
|
setMessages: (messages: TMessage[]) => void;
|
|
getMessages: () => TMessage[] | undefined;
|
|
};
|
|
|
|
type TContentHandler = {
|
|
data: TContentData;
|
|
submission: EventSubmission;
|
|
};
|
|
|
|
export default function useContentHandler({ setMessages, getMessages }: TUseContentHandler) {
|
|
const queryClient = useQueryClient();
|
|
const messageMap = useMemo(() => new Map<string, TMessage>(), []);
|
|
return useCallback(
|
|
({ data, submission }: TContentHandler) => {
|
|
const { type, messageId, thread_id, conversationId, index } = data;
|
|
|
|
const _messages = getMessages();
|
|
const messages =
|
|
_messages
|
|
?.filter((m) => m.messageId !== messageId)
|
|
.map((msg) => ({ ...msg, thread_id })) ?? [];
|
|
const userMessage = messages[messages.length - 1] as TMessage | undefined;
|
|
|
|
const { initialResponse } = submission;
|
|
|
|
let response = messageMap.get(messageId);
|
|
if (!response) {
|
|
response = {
|
|
...(initialResponse as TMessage),
|
|
parentMessageId: userMessage?.messageId ?? '',
|
|
conversationId,
|
|
messageId,
|
|
thread_id,
|
|
};
|
|
messageMap.set(messageId, response);
|
|
}
|
|
|
|
// TODO: handle streaming for non-text
|
|
const textPart: Text | string | undefined = data[ContentTypes.TEXT];
|
|
const part: ContentPart =
|
|
textPart != null && typeof textPart === 'string' ? { value: textPart } : data[type];
|
|
|
|
if (type === ContentTypes.IMAGE_FILE) {
|
|
addFileToCache(queryClient, part as ImageFile & PartMetadata);
|
|
}
|
|
|
|
/* spreading the content array to avoid mutation */
|
|
response.content = [...(response.content ?? [])];
|
|
|
|
response.content[index] = { type, [type]: part } as TMessageContentParts;
|
|
|
|
if (
|
|
type !== ContentTypes.TEXT &&
|
|
initialResponse.content &&
|
|
((response.content[response.content.length - 1].type === ContentTypes.TOOL_CALL &&
|
|
response.content[response.content.length - 1][ContentTypes.TOOL_CALL].progress === 1) ||
|
|
response.content[response.content.length - 1].type === ContentTypes.IMAGE_FILE)
|
|
) {
|
|
response.content.push(initialResponse.content[0]);
|
|
}
|
|
|
|
setMessages([...messages, response]);
|
|
},
|
|
[queryClient, getMessages, messageMap, setMessages],
|
|
);
|
|
}
|