mirror of
https://git.mirrors.martin98.com/https://github.com/infiniflow/ragflow.git
synced 2025-04-23 14:40:03 +08:00

### What problem does this PR solve? [remarkjs/react-markdown/issues/785](https://github.com/remarkjs/react-markdown/issues/785) Fix: Fixed an issue where math formulas could not be displayed correctly #4405 ### Type of change - [x] Bug Fix (non-breaking change which fixes an issue)
53 lines
1.5 KiB
TypeScript
53 lines
1.5 KiB
TypeScript
import classNames from 'classnames';
|
|
import Markdown from 'react-markdown';
|
|
import { Prism as SyntaxHighlighter } from 'react-syntax-highlighter';
|
|
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 styles from './index.less';
|
|
|
|
const HightLightMarkdown = ({
|
|
children,
|
|
}: {
|
|
children: string | null | undefined;
|
|
}) => {
|
|
return (
|
|
<Markdown
|
|
remarkPlugins={[remarkGfm, remarkMath]}
|
|
rehypePlugins={[rehypeRaw, rehypeKatex]}
|
|
className={classNames(styles.text)}
|
|
components={
|
|
{
|
|
code(props: any) {
|
|
const { children, className, node, ...rest } = props;
|
|
const match = /language-(\w+)/.exec(className || '');
|
|
return match ? (
|
|
<SyntaxHighlighter
|
|
{...rest}
|
|
PreTag="div"
|
|
language={match[1]}
|
|
// style={dark}
|
|
>
|
|
{String(children).replace(/\n$/, '')}
|
|
</SyntaxHighlighter>
|
|
) : (
|
|
<code {...rest} className={`${className} ${styles.code}`}>
|
|
{children}
|
|
</code>
|
|
);
|
|
},
|
|
} as any
|
|
}
|
|
>
|
|
{children ? preprocessLaTeX(children) : children}
|
|
</Markdown>
|
|
);
|
|
};
|
|
|
|
export default HightLightMarkdown;
|