2022-03-09 14:57:44 -08:00
|
|
|
import { memo, useEffect, useState } from "react"
|
2022-03-22 20:16:24 -07:00
|
|
|
import styles from './preview.module.css'
|
2022-03-06 16:46:59 -08:00
|
|
|
|
2022-03-09 14:57:44 -08:00
|
|
|
type Props = {
|
|
|
|
height?: number | string
|
2022-03-22 20:06:15 -07:00
|
|
|
fileId?: string
|
|
|
|
content?: string
|
|
|
|
title?: string
|
2022-03-09 14:57:44 -08:00
|
|
|
// file extensions we can highlight
|
|
|
|
}
|
|
|
|
|
2022-03-22 20:06:15 -07:00
|
|
|
const MarkdownPreview = ({ height = 500, fileId, content, title }: Props) => {
|
|
|
|
const [preview, setPreview] = useState<string>(content || "")
|
|
|
|
const [isLoading, setIsLoading] = useState<boolean>(true)
|
2022-03-09 14:57:44 -08:00
|
|
|
useEffect(() => {
|
2022-03-22 20:06:15 -07:00
|
|
|
async function fetchPost() {
|
|
|
|
if (fileId) {
|
2022-03-23 12:36:29 -07:00
|
|
|
const resp = await fetch(`/server-api/files/html/${fileId}`, {
|
2022-03-22 20:06:15 -07:00
|
|
|
method: "GET",
|
|
|
|
})
|
|
|
|
if (resp.ok) {
|
|
|
|
const res = await resp.text()
|
|
|
|
setPreview(res)
|
|
|
|
setIsLoading(false)
|
|
|
|
}
|
2022-03-22 20:16:24 -07:00
|
|
|
} else if (content) {
|
2022-03-22 20:06:15 -07:00
|
|
|
const resp = await fetch(`/api/render-markdown`, {
|
|
|
|
method: "POST",
|
|
|
|
headers: {
|
|
|
|
"Content-Type": "application/json",
|
|
|
|
},
|
|
|
|
body: JSON.stringify({
|
|
|
|
title,
|
|
|
|
content,
|
|
|
|
}),
|
|
|
|
})
|
|
|
|
if (resp.ok) {
|
|
|
|
const res = await resp.text()
|
|
|
|
setPreview(res)
|
|
|
|
setIsLoading(false)
|
|
|
|
}
|
|
|
|
}
|
2022-03-22 20:16:24 -07:00
|
|
|
setIsLoading(false)
|
2022-03-09 14:57:44 -08:00
|
|
|
}
|
2022-03-22 20:06:15 -07:00
|
|
|
fetchPost()
|
|
|
|
}, [content, fileId, title])
|
|
|
|
return (<>
|
2022-03-23 16:28:39 -07:00
|
|
|
{isLoading ? <div>Loading...</div> : <article className={styles.markdownPreview} dangerouslySetInnerHTML={{ __html: preview }} style={{
|
2022-03-22 20:06:15 -07:00
|
|
|
height
|
|
|
|
}} />}
|
|
|
|
</>)
|
|
|
|
|
2022-03-06 16:46:59 -08:00
|
|
|
}
|
|
|
|
|
|
|
|
export default memo(MarkdownPreview)
|