2022-11-16 02:16:56 -08:00
|
|
|
import { Popover } from "@components/popover"
|
2022-03-25 13:01:46 -07:00
|
|
|
import { codeFileExtensions } from "@lib/constants"
|
2022-11-16 02:16:56 -08:00
|
|
|
import clsx from "clsx"
|
2022-11-12 01:28:06 -08:00
|
|
|
import type { File } from "lib/server/prisma"
|
2022-04-19 23:36:56 -07:00
|
|
|
import styles from "./dropdown.module.css"
|
2022-11-16 02:16:56 -08:00
|
|
|
import buttonStyles from "@components/button/button.module.css"
|
2022-11-29 00:43:04 -08:00
|
|
|
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 />
|
|
|
|
}
|
|
|
|
|
2022-11-16 02:16:56 -08:00
|
|
|
const items = files.map((file) => {
|
|
|
|
const extension = file.title.split(".").pop()
|
|
|
|
if (codeFileExtensions.includes(extension || "")) {
|
|
|
|
return {
|
|
|
|
...file,
|
2022-11-29 00:43:04 -08:00
|
|
|
icon: <Code />
|
2022-11-16 02:16:56 -08:00
|
|
|
}
|
|
|
|
} else {
|
|
|
|
return {
|
|
|
|
...file,
|
|
|
|
icon: <FileIcon />
|
2022-04-09 17:48:19 -07:00
|
|
|
}
|
2022-11-16 02:16:56 -08:00
|
|
|
}
|
|
|
|
})
|
2022-03-25 13:01:46 -07:00
|
|
|
|
2022-04-11 23:07:06 -07:00
|
|
|
const content = (
|
2022-04-10 20:05:42 -07:00
|
|
|
<ul className={styles.content}>
|
|
|
|
{items.map((item) => (
|
2022-11-16 02:16:56 -08:00
|
|
|
<li key={item.id}>
|
2022-11-29 22:10:51 -08:00
|
|
|
<a href={`#${item.title}`} className={styles.listItem}>
|
|
|
|
<span className={styles.fileIcon}>{item.icon}</span>
|
2022-04-10 20:05:42 -07:00
|
|
|
<span className={styles.fileTitle}>
|
|
|
|
{item.title ? item.title : "Untitled"}
|
|
|
|
</span>
|
|
|
|
</a>
|
|
|
|
</li>
|
|
|
|
))}
|
|
|
|
</ul>
|
2022-04-11 23:07:06 -07:00
|
|
|
)
|
2022-03-25 13:01:46 -07:00
|
|
|
|
2022-04-09 17:48:19 -07:00
|
|
|
return (
|
2022-11-16 02:16:56 -08:00
|
|
|
<Popover>
|
2022-11-17 23:39:52 -08:00
|
|
|
<Popover.Trigger className={buttonStyles.button}>
|
|
|
|
<div
|
|
|
|
className={clsx(buttonStyles.icon, styles.chevron)}
|
|
|
|
style={{ marginRight: 6 }}
|
|
|
|
>
|
2022-11-16 02:16:56 -08:00
|
|
|
<ChevronDown />
|
|
|
|
</div>
|
2022-11-17 22:36:53 -08:00
|
|
|
<span>
|
|
|
|
Jump to {files.length} {files.length === 1 ? "file" : "files"}
|
|
|
|
</span>
|
2022-11-16 02:16:56 -08:00
|
|
|
</Popover.Trigger>
|
2022-11-29 22:10:51 -08:00
|
|
|
<Popover.Content className={styles.contentWrapper}>
|
|
|
|
{content}
|
|
|
|
</Popover.Content>
|
2022-11-16 02:16:56 -08:00
|
|
|
</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
|