chore: reorg. content files, add blinking cursor

This commit is contained in:
Danny Avila 2023-03-21 09:46:08 -04:00
parent 04796824d5
commit 0cc4aea204
11 changed files with 7 additions and 159 deletions

View file

@ -30,7 +30,7 @@ const createOnProgress = () => {
tokens = citeText(tokens, true);
}
sendMessage(res, { text: tokens + '', message: true, initial: i === 0, ...rest });
sendMessage(res, { text: tokens + '<span class="result-streaming">█</span>', message: true, initial: i === 0, ...rest });
i++;
};

View file

@ -25,5 +25,6 @@ module.exports = {
],
"rules": {
'react/prop-types': ['off'],
'react/display-name': ['off'],
}
}

View file

@ -1,6 +1,6 @@
import React, { useRef, useState } from 'react';
import Clipboard from '../svg/Clipboard';
import CheckMark from '../svg/CheckMark';
import Clipboard from '~/components/svg/Clipboard';
import CheckMark from '~/components/svg/CheckMark';
const CodeBlock = ({ lang, codeChildren }) => {
const codeRef = useRef(null);

View file

@ -1,6 +1,6 @@
import React, { useState } from 'react';
import Clipboard from '../svg/Clipboard';
import CheckMark from '../svg/CheckMark';
import Clipboard from '~/components/svg/Clipboard';
import CheckMark from '~/components/svg/CheckMark';
const Embed = React.memo(({ children, lang = '', code, matched }) => {
const [buttonText, setButtonText] = useState('Copy code');

View file

@ -1,153 +0,0 @@
import React, { useState, useEffect } from 'react';
import ReactMarkdown from 'react-markdown';
import rehypeKatex from 'rehype-katex';
import rehypeHighlight from 'rehype-highlight';
import remarkMath from 'remark-math';
import remarkGfm from 'remark-gfm';
import TabLink from './TabLink';
import Markdown from 'markdown-to-jsx';
import Highlight from './Highlight';
import CodeBlock from './CodeBlock';
import Embed from './Embed';
// import { langSubset } from '~/utils/languages';
const mdOptions = {
wrapper: React.Fragment,
forceWrapper: true,
overrides: {
a: {
component: TabLink
// props: {
// className: 'foo'
// }
},
pre: code,
// code: {
// component: code
// },
// pre: {
// component: PreBlock
// },
p: {
component: p
}
}
};
const Content = ({ content }) => {
return (
<>
{/* <ReactMarkdown
remarkPlugins={[remarkGfm, [remarkMath, { singleDollarTextMath: false }]]}
rehypePlugins={[
[rehypeKatex, { output: 'mathml' }],
[
rehypeHighlight,
{
detect: true,
ignoreMissing: true,
subset: langSubset
}
]
]}
linkTarget="_new"
components={{
code,
p
// li,
// ul,
// ol
}}
>
{content}
</ReactMarkdown> */}
<Markdown
options={mdOptions}
>
{content}
</Markdown>
</>
);
};
const PreBlock = ({children, ...rest}) => {
console.log('pre', children);
if ('type' in children && children ['type'] === 'code') {
return code(children['props']);
}
return <pre {...rest}>{children}</pre>;
};
const code = (props) => {
const { inline, className, children, ...rest } = props;
if ('type' in children && children ['type'] === 'code') {
// return code(children['props']);
const match = /language-(\w+)/.exec(className || '');
const lang = match && match[1];
console.log('code', lang, children);
if (inline) {
return <code className={className}>{children}</code>;
} else {
return (
<Embed
language={lang}
code={children}
// matched={matched}
>
<Highlight
language={lang}
code={children}
/>
</Embed>
);
}
}
return <pre {...rest}>{children}</pre>;
const match = /language-(\w+)/.exec(className || '');
const lang = match && match[1];
console.log('code', lang, children);
if (inline) {
return <code className={className}>{children}</code>;
} else {
return (
<Embed
language={lang}
code={children}
// matched={matched}
>
<Highlight
language={lang}
code={children}
/>
</Embed>
);
}
};
const p = (props) => {
const regex = /^█$/;
const match = regex.exec(props?.children || '');
// if (match) {
// return (
// <p className="whitespace-pre-wrap ">
// {props?.children.slice(0, -1)}
// <span className="result-streaming">{''}</span>
// </p>
// );
if (match) {
return (
<p className="whitespace-pre-wrap ">
<span className="result-streaming">{'█'}</span>
</p>
);
}
return <p className="whitespace-pre-wrap ">{props?.children}</p>;
};
export default Content;

View file

@ -1,5 +1,5 @@
import React, { useState, useEffect, useRef, useCallback } from 'react';
import Wrapper from './Wrapper';
import Wrapper from './Content/Wrapper';
import MultiMessage from './MultiMessage';
import { useSelector, useDispatch } from 'react-redux';
import HoverButtons from './HoverButtons';