vision-agent / lib /hooks /useCleanedUpMessages.ts
wuyiqunLu
feat: change the upload flow (#17)
6b8f69a unverified
raw
history blame
1.65 kB
import { useMemo } from 'react';
import { MessageBase } from '../types';
const PAIRS: Record<string, string> = {
'┍': 'β”‘',
'┝': 'β”₯',
'β”œ': '─',
'β”•': 'β”™',
};
const MIDDLE_STARTER = '┝';
const MIDDLE_SEPARATOR = 'β”Ώ';
export const useCleanedUpMessages = ({ content, role }: MessageBase) => {
return useMemo(() => {
if (role === 'user') {
return {
content,
};
}
const [logs = '', answer = ''] = content.split('<ANSWER>');
const cleanedLogs = [];
let left = 0;
let right = 0;
while (right < logs.length) {
if (Object.keys(PAIRS).includes(content[right])) {
cleanedLogs.push(content.substring(left, right));
left = right++;
while (
right < content.length &&
PAIRS[content[left]] !== content[right]
) {
right++;
}
if (content[left] === MIDDLE_STARTER) {
// add the text alignment so it can be shown as a table
const separators = logs
.substring(left, right)
.split(MIDDLE_SEPARATOR).length;
if (separators > 0) {
cleanedLogs.push(
Array(separators + 1)
.fill('|')
.join(' :- '),
);
}
}
left = ++right;
} else {
right++;
}
}
cleanedLogs.push(content.substring(left, right));
return {
logs: cleanedLogs
.join('')
.replace(/β”‚/g, '|')
.split('|\n\n|')
.join('|\n|'),
content: answer.replace('</</ANSWER>', '').replace('</ANSWER>', ''),
};
}, [content, role]);
};