mirror of
https://github.com/infiniflow/ragflow.git
synced 2025-12-25 16:26:51 +08:00
### What problem does this PR solve? Fix: Changed 'HightLightMarkdown' to 'HighLightMarkdown', and replaced the private component with a public component. ### Type of change - [x] Bug Fix (non-breaking change which fixes an issue)
60 lines
1.7 KiB
TypeScript
60 lines
1.7 KiB
TypeScript
import classNames from 'classnames';
|
|
import Markdown from 'react-markdown';
|
|
import { Prism as SyntaxHighlighter } from 'react-syntax-highlighter';
|
|
import {
|
|
oneDark,
|
|
oneLight,
|
|
} from 'react-syntax-highlighter/dist/esm/styles/prism';
|
|
import rehypeKatex from 'rehype-katex';
|
|
import rehypeRaw from 'rehype-raw';
|
|
import remarkGfm from 'remark-gfm';
|
|
import remarkMath from 'remark-math';
|
|
|
|
import 'katex/dist/katex.min.css'; // `rehype-katex` does not import the CSS for you
|
|
|
|
import { preprocessLaTeX } from '@/utils/chat';
|
|
import { useIsDarkTheme } from '../theme-provider';
|
|
import styles from './index.less';
|
|
|
|
const HighLightMarkdown = ({
|
|
children,
|
|
}: {
|
|
children: string | null | undefined;
|
|
}) => {
|
|
const isDarkTheme = useIsDarkTheme();
|
|
|
|
return (
|
|
<Markdown
|
|
remarkPlugins={[remarkGfm, remarkMath]}
|
|
rehypePlugins={[rehypeRaw, rehypeKatex]}
|
|
className={classNames(styles.text)}
|
|
components={
|
|
{
|
|
code(props: any) {
|
|
const { children, className, ...rest } = props;
|
|
const match = /language-(\w+)/.exec(className || '');
|
|
return match ? (
|
|
<SyntaxHighlighter
|
|
{...rest}
|
|
PreTag="div"
|
|
language={match[1]}
|
|
style={isDarkTheme ? oneDark : oneLight}
|
|
>
|
|
{String(children).replace(/\n$/, '')}
|
|
</SyntaxHighlighter>
|
|
) : (
|
|
<code {...rest} className={`${className} ${styles.code}`}>
|
|
{children}
|
|
</code>
|
|
);
|
|
},
|
|
} as any
|
|
}
|
|
>
|
|
{children ? preprocessLaTeX(children) : children}
|
|
</Markdown>
|
|
);
|
|
};
|
|
|
|
export default HighLightMarkdown;
|