CoastalCommitsPastes/client/app/(posts)/components/file-dropdown/index.tsx

70 lines
1.6 KiB
TypeScript
Raw Normal View History

import { Popover } from "@components/popover"
2022-03-25 13:01:46 -07:00
import { codeFileExtensions } from "@lib/constants"
import clsx from "clsx"
2022-11-12 01:28:06 -08:00
import type { File } from "lib/server/prisma"
import styles from "./dropdown.module.css"
import buttonStyles from "@components/button/button.module.css"
import { ChevronDown, Code, File as FileIcon } from "react-feather"
2022-12-04 01:31:51 -08:00
import { Spinner } from "@components/spinner"
2022-03-25 13:01:46 -07:00
type Item = File & {
2022-04-09 17:48:19 -07:00
icon: JSX.Element
2022-03-25 13:01:46 -07:00
}
2022-12-04 01:31:51 -08:00
const FileDropdown = ({ files, loading }: { files: File[], loading?: boolean }) => {
if (loading) {
return <Spinner />
}
const items = files.map((file) => {
const extension = file.title.split(".").pop()
if (codeFileExtensions.includes(extension || "")) {
return {
...file,
icon: <Code />
}
} else {
return {
...file,
icon: <FileIcon />
2022-04-09 17:48:19 -07:00
}
}
})
2022-03-25 13:01:46 -07:00
const content = (
<ul className={styles.content}>
{items.map((item) => (
<li key={item.id}>
<a href={`#${item.title}`} className={styles.listItem}>
<span className={styles.fileIcon}>{item.icon}</span>
<span className={styles.fileTitle}>
{item.title ? item.title : "Untitled"}
</span>
</a>
</li>
))}
</ul>
)
2022-03-25 13:01:46 -07:00
2022-04-09 17:48:19 -07:00
return (
<Popover>
<Popover.Trigger className={buttonStyles.button}>
<div
className={clsx(buttonStyles.icon, styles.chevron)}
style={{ marginRight: 6 }}
>
<ChevronDown />
</div>
2022-11-17 22:36:53 -08:00
<span>
Jump to {files.length} {files.length === 1 ? "file" : "files"}
</span>
</Popover.Trigger>
<Popover.Content className={styles.contentWrapper}>
{content}
</Popover.Content>
</Popover>
2022-04-09 17:48:19 -07:00
)
2022-03-25 13:01:46 -07:00
}
2022-04-09 17:48:19 -07:00
export default FileDropdown