mirror of
https://github.com/infiniflow/ragflow.git
synced 2025-12-24 15:36:50 +08:00
### What problem does this PR solve? Feat: Users can chat directly without first creating a conversation. #11768 ### Type of change - [x] New Feature (non-breaking change which adds functionality)
96 lines
2.6 KiB
TypeScript
96 lines
2.6 KiB
TypeScript
import {
|
|
ChatVariableEnabledField,
|
|
EmptyConversationId,
|
|
} from '@/constants/chat';
|
|
import { IMessage, Message } from '@/interfaces/database/chat';
|
|
import { omit } from 'lodash';
|
|
import { v4 as uuid } from 'uuid';
|
|
|
|
export const isConversationIdExist = (conversationId: string) => {
|
|
return conversationId !== EmptyConversationId && conversationId !== '';
|
|
};
|
|
|
|
export const buildMessageUuid = (message: Partial<Message | IMessage>) => {
|
|
if ('id' in message && message.id) {
|
|
return message.id;
|
|
}
|
|
return uuid();
|
|
};
|
|
|
|
export const buildMessageListWithUuid = (messages?: Message[]) => {
|
|
return (
|
|
messages?.map((x: Message | IMessage) => ({
|
|
...omit(x, 'reference'),
|
|
id: buildMessageUuid(x),
|
|
})) ?? []
|
|
);
|
|
};
|
|
|
|
export const generateConversationId = () => {
|
|
return uuid().replace(/-/g, '');
|
|
};
|
|
|
|
// When rendering each message, add a prefix to the id to ensure uniqueness.
|
|
export const buildMessageUuidWithRole = (
|
|
message: Partial<Message | IMessage>,
|
|
) => {
|
|
return `${message.role}_${message.id}`;
|
|
};
|
|
|
|
// Preprocess LaTeX equations to be rendered by KaTeX
|
|
// ref: https://github.com/remarkjs/react-markdown/issues/785
|
|
|
|
export const preprocessLaTeX = (content: string) => {
|
|
const blockProcessedContent = content.replace(
|
|
/\\\[([\s\S]*?)\\\]/g,
|
|
(_, equation) => `$$${equation}$$`,
|
|
);
|
|
const inlineProcessedContent = blockProcessedContent.replace(
|
|
/\\\(([\s\S]*?)\\\)/g,
|
|
(_, equation) => `$${equation}$`,
|
|
);
|
|
return inlineProcessedContent;
|
|
};
|
|
|
|
export function replaceThinkToSection(text: string = '') {
|
|
const pattern = /<think>([\s\S]*?)<\/think>/g;
|
|
|
|
const result = text.replace(pattern, '<section class="think">$1</section>');
|
|
|
|
return result;
|
|
}
|
|
|
|
export function setInitialChatVariableEnabledFieldValue(
|
|
field: ChatVariableEnabledField,
|
|
) {
|
|
return false;
|
|
return field !== ChatVariableEnabledField.MaxTokensEnabled;
|
|
}
|
|
|
|
const ShowImageFields = ['image', 'table'];
|
|
|
|
export function showImage(filed?: string) {
|
|
return ShowImageFields.some((x) => x === filed);
|
|
}
|
|
|
|
export function setChatVariableEnabledFieldValuePage() {
|
|
const variableCheckBoxFieldMap = Object.values(
|
|
ChatVariableEnabledField,
|
|
).reduce<Record<string, boolean>>((pre, cur) => {
|
|
pre[cur] = cur !== ChatVariableEnabledField.MaxTokensEnabled;
|
|
return pre;
|
|
}, {});
|
|
|
|
return variableCheckBoxFieldMap;
|
|
}
|
|
|
|
const oldReg = /(#{2}\d+\${2})/g;
|
|
export const currentReg = /\[ID:(\d+)\]/g;
|
|
|
|
// To be compatible with the old index matching mode
|
|
export const replaceTextByOldReg = (text: string) => {
|
|
return text?.replace(oldReg, (substring: string) => {
|
|
return `[ID:${substring.slice(2, -2)}]`;
|
|
});
|
|
};
|