2022-03-22 21:18:26 -07:00
|
|
|
import { memo, useRef, useState } from "react"
|
2022-04-09 17:48:19 -07:00
|
|
|
import styles from "./document.module.css"
|
|
|
|
import Download from "@geist-ui/icons/download"
|
|
|
|
import ExternalLink from "@geist-ui/icons/externalLink"
|
2022-03-09 17:11:37 -08:00
|
|
|
import Skeleton from "react-loading-skeleton"
|
2022-11-08 00:28:19 -08:00
|
|
|
import Link from 'next/link';
|
2022-03-21 20:43:50 -07:00
|
|
|
|
2022-04-09 17:48:19 -07:00
|
|
|
import {
|
|
|
|
Button,
|
|
|
|
ButtonGroup,
|
|
|
|
Spacer,
|
|
|
|
Tabs,
|
|
|
|
Textarea,
|
|
|
|
Tooltip,
|
|
|
|
Tag
|
|
|
|
} from "@geist-ui/core"
|
2022-03-23 12:36:29 -07:00
|
|
|
import HtmlPreview from "@components/preview"
|
2022-03-26 00:24:18 -07:00
|
|
|
import FadeIn from "@components/fade-in"
|
2022-03-21 20:43:50 -07:00
|
|
|
|
2022-03-11 18:48:40 -08:00
|
|
|
// import Link from "next/link"
|
2022-03-06 16:46:59 -08:00
|
|
|
type Props = {
|
2022-04-09 17:48:19 -07:00
|
|
|
title: string
|
|
|
|
initialTab?: "edit" | "preview"
|
|
|
|
skeleton?: boolean
|
|
|
|
id: string
|
|
|
|
content: string
|
2022-03-06 16:46:59 -08:00
|
|
|
}
|
|
|
|
|
2022-03-11 18:48:40 -08:00
|
|
|
const DownloadButton = ({ rawLink }: { rawLink?: string }) => {
|
2022-04-09 17:48:19 -07:00
|
|
|
return (
|
|
|
|
<div className={styles.actionWrapper}>
|
|
|
|
<ButtonGroup className={styles.actions}>
|
|
|
|
<Tooltip hideArrow text="Download">
|
2022-11-08 00:28:19 -08:00
|
|
|
<Link
|
2022-04-09 17:48:19 -07:00
|
|
|
href={`${rawLink}?download=true`}
|
|
|
|
target="_blank"
|
|
|
|
rel="noopener noreferrer"
|
|
|
|
>
|
|
|
|
<Button
|
|
|
|
scale={2 / 3}
|
|
|
|
px={0.6}
|
|
|
|
icon={<Download />}
|
|
|
|
auto
|
|
|
|
aria-label="Download"
|
|
|
|
/>
|
2022-11-08 00:28:19 -08:00
|
|
|
</Link>
|
2022-04-09 17:48:19 -07:00
|
|
|
</Tooltip>
|
|
|
|
<Tooltip hideArrow text="Open raw in new tab">
|
2022-11-08 00:28:19 -08:00
|
|
|
<Link href={rawLink || ""} target="_blank" rel="noopener noreferrer">
|
2022-04-09 17:48:19 -07:00
|
|
|
<Button
|
|
|
|
scale={2 / 3}
|
|
|
|
px={0.6}
|
|
|
|
icon={<ExternalLink />}
|
|
|
|
auto
|
|
|
|
aria-label="Open raw file in new tab"
|
|
|
|
/>
|
2022-11-08 00:28:19 -08:00
|
|
|
</Link>
|
2022-04-09 17:48:19 -07:00
|
|
|
</Tooltip>
|
|
|
|
</ButtonGroup>
|
|
|
|
</div>
|
|
|
|
)
|
2022-03-11 18:48:40 -08:00
|
|
|
}
|
|
|
|
|
2022-04-09 17:48:19 -07:00
|
|
|
const Document = ({
|
|
|
|
content,
|
|
|
|
title,
|
|
|
|
initialTab = "edit",
|
|
|
|
skeleton,
|
|
|
|
id
|
|
|
|
}: Props) => {
|
|
|
|
const codeEditorRef = useRef<HTMLTextAreaElement>(null)
|
|
|
|
const [tab, setTab] = useState(initialTab)
|
|
|
|
// const height = editable ? "500px" : '100%'
|
|
|
|
const height = "100%"
|
2022-03-11 18:48:40 -08:00
|
|
|
|
2022-04-09 17:48:19 -07:00
|
|
|
const handleTabChange = (newTab: string) => {
|
|
|
|
if (newTab === "edit") {
|
|
|
|
codeEditorRef.current?.focus()
|
|
|
|
}
|
|
|
|
setTab(newTab as "edit" | "preview")
|
|
|
|
}
|
2022-03-06 16:46:59 -08:00
|
|
|
|
2022-04-09 17:48:19 -07:00
|
|
|
const rawLink = () => {
|
|
|
|
if (id) {
|
|
|
|
return `/file/raw/${id}`
|
|
|
|
}
|
|
|
|
}
|
2022-03-11 18:48:40 -08:00
|
|
|
|
2022-04-09 17:48:19 -07:00
|
|
|
if (skeleton) {
|
|
|
|
return (
|
|
|
|
<>
|
|
|
|
<Spacer height={1} />
|
|
|
|
<div className={styles.card}>
|
|
|
|
<div className={styles.fileNameContainer}>
|
|
|
|
<Skeleton width={275} height={36} />
|
|
|
|
</div>
|
|
|
|
<div className={styles.descriptionContainer}>
|
|
|
|
<div style={{ flexDirection: "row", display: "flex" }}>
|
|
|
|
<Skeleton width={125} height={36} />
|
|
|
|
</div>
|
|
|
|
<Skeleton width={"100%"} height={350} />
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</>
|
|
|
|
)
|
|
|
|
}
|
2022-03-21 22:50:25 -07:00
|
|
|
|
2022-04-09 17:48:19 -07:00
|
|
|
return (
|
|
|
|
<FadeIn>
|
|
|
|
<Spacer height={1} />
|
|
|
|
<div className={styles.card}>
|
|
|
|
<Link href={`#${title}`} className={styles.fileNameContainer}>
|
|
|
|
<Tag
|
|
|
|
height={"100%"}
|
|
|
|
id={`${title}`}
|
|
|
|
width={"100%"}
|
|
|
|
style={{ borderRadius: 0 }}
|
|
|
|
>
|
|
|
|
{title || "Untitled"}
|
|
|
|
</Tag>
|
|
|
|
</Link>
|
|
|
|
<div className={styles.descriptionContainer}>
|
|
|
|
<DownloadButton rawLink={rawLink()} />
|
|
|
|
<Tabs
|
|
|
|
onChange={handleTabChange}
|
|
|
|
initialValue={initialTab}
|
|
|
|
hideDivider
|
|
|
|
leftSpace={0}
|
|
|
|
>
|
|
|
|
<Tabs.Item label={"Raw"} value="edit">
|
|
|
|
{/* <textarea className={styles.lineCounter} wrap='off' readOnly ref={lineNumberRef}>1.</textarea> */}
|
|
|
|
<div
|
|
|
|
style={{
|
|
|
|
marginTop: "var(--gap-half)",
|
|
|
|
display: "flex",
|
|
|
|
flexDirection: "column"
|
|
|
|
}}
|
|
|
|
>
|
|
|
|
<Textarea
|
|
|
|
readOnly
|
|
|
|
ref={codeEditorRef}
|
|
|
|
value={content}
|
|
|
|
width="100%"
|
|
|
|
// TODO: Textarea should grow to fill parent if height == 100%
|
|
|
|
style={{ flex: 1, minHeight: 350 }}
|
|
|
|
resize="vertical"
|
|
|
|
className={styles.textarea}
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
</Tabs.Item>
|
|
|
|
<Tabs.Item label="Preview" value="preview">
|
|
|
|
<div style={{ marginTop: "var(--gap-half)" }}>
|
|
|
|
<HtmlPreview
|
|
|
|
height={height}
|
|
|
|
fileId={id}
|
|
|
|
content={content}
|
|
|
|
title={title}
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
</Tabs.Item>
|
|
|
|
</Tabs>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</FadeIn>
|
|
|
|
)
|
2022-03-06 16:46:59 -08:00
|
|
|
}
|
|
|
|
|
2022-04-09 17:48:19 -07:00
|
|
|
export default memo(Document)
|