refactor(EmbedCodeDialog): don't use markdown renderer

This commit is contained in:
Jeremy Kahn 2023-10-08 16:58:29 -05:00
parent 7a7ddf80fc
commit 0911c29729

View File

@ -6,19 +6,6 @@ import DialogActions from '@mui/material/DialogActions'
import DialogContent from '@mui/material/DialogContent' import DialogContent from '@mui/material/DialogContent'
import DialogContentText from '@mui/material/DialogContentText' import DialogContentText from '@mui/material/DialogContentText'
import DialogTitle from '@mui/material/DialogTitle' import DialogTitle from '@mui/material/DialogTitle'
// These imports need to be ts-ignored to prevent spurious errors that look
// like this:
//
// Module 'react-markdown' cannot be imported using this construct. The
// specifier only resolves to an ES module, which cannot be imported
// synchronously. Use dynamic import instead. (tsserver 1471)
//
// @ts-ignore
import Markdown from 'react-markdown'
// @ts-ignore
import { CodeProps } from 'react-markdown/lib/ast-to-react'
// @ts-ignore
import remarkGfm from 'remark-gfm'
interface EmbedCodeDialogProps { interface EmbedCodeDialogProps {
showEmbedCode: boolean showEmbedCode: boolean
@ -34,21 +21,7 @@ export const EmbedCodeDialog = ({
<Dialog open={showEmbedCode} onClose={handleEmbedCodeWindowClose}> <Dialog open={showEmbedCode} onClose={handleEmbedCodeWindowClose}>
<DialogTitle>Room embed code</DialogTitle> <DialogTitle>Room embed code</DialogTitle>
<DialogContent> <DialogContent>
<Markdown
remarkPlugins={[remarkGfm]}
components={{
// https://github.com/remarkjs/react-markdown#use-custom-components-syntax-highlight
code({
node,
inline,
className,
children,
style,
...props
}: CodeProps) {
return (
<SyntaxHighlighter <SyntaxHighlighter
children={String(children).replace(/\n$/, '')}
language="html" language="html"
style={materialDark} style={materialDark}
PreTag="div" PreTag="div"
@ -59,16 +32,9 @@ export const EmbedCodeDialog = ({
}, },
}} }}
wrapLines={true} wrapLines={true}
{...props}
/>
)
},
}}
> >
{`\`\`\`html {`<iframe src="${embedUrl}" allow="camera;microphone;display-capture" width="800" height="800" />`}
<iframe src="${embedUrl}" allow="camera;microphone;display-capture" width="800" height="800" /> </SyntaxHighlighter>
\`\`\``}
</Markdown>
<DialogContentText <DialogContentText
sx={{ sx={{
mb: 2, mb: 2,