mirror of
https://github.com/get-drexa/drive.git
synced 2025-12-01 05:51:39 +00:00
84 lines
2.1 KiB
TypeScript
84 lines
2.1 KiB
TypeScript
|
|
import type {
|
||
|
|
DirectoryHandle,
|
||
|
|
PathComponent,
|
||
|
|
} from "@fileone/convex/model/filesystem"
|
||
|
|
import { Link } from "@tanstack/react-router"
|
||
|
|
import { Fragment, useContext } from "react"
|
||
|
|
import {
|
||
|
|
Breadcrumb,
|
||
|
|
BreadcrumbItem,
|
||
|
|
BreadcrumbLink,
|
||
|
|
BreadcrumbList,
|
||
|
|
BreadcrumbPage,
|
||
|
|
BreadcrumbSeparator,
|
||
|
|
} from "../../components/ui/breadcrumb"
|
||
|
|
import {
|
||
|
|
Tooltip,
|
||
|
|
TooltipContent,
|
||
|
|
TooltipTrigger,
|
||
|
|
} from "../../components/ui/tooltip"
|
||
|
|
import { useFileDrop } from "../../files/use-file-drop"
|
||
|
|
import { cn } from "../../lib/utils"
|
||
|
|
import { DirectoryPageContext } from "./context"
|
||
|
|
import { dragInfoAtom } from "./state"
|
||
|
|
|
||
|
|
export function FilePathBreadcrumb() {
|
||
|
|
const { rootDirectory, directory } = useContext(DirectoryPageContext)
|
||
|
|
|
||
|
|
const breadcrumbItems: React.ReactNode[] = []
|
||
|
|
for (let i = 1; i < directory.path.length - 1; i++) {
|
||
|
|
breadcrumbItems.push(
|
||
|
|
<Fragment key={directory.path[i]?.handle.id}>
|
||
|
|
<BreadcrumbSeparator />
|
||
|
|
<FilePathBreadcrumbItem component={directory.path[i]!} />
|
||
|
|
</Fragment>,
|
||
|
|
)
|
||
|
|
}
|
||
|
|
|
||
|
|
return (
|
||
|
|
<Breadcrumb>
|
||
|
|
<BreadcrumbList>
|
||
|
|
{rootDirectory._id === directory._id ? (
|
||
|
|
<BreadcrumbItem>
|
||
|
|
<BreadcrumbPage>All Files</BreadcrumbPage>
|
||
|
|
</BreadcrumbItem>
|
||
|
|
) : (
|
||
|
|
<FilePathBreadcrumbItem component={directory.path[0]!} />
|
||
|
|
)}
|
||
|
|
{breadcrumbItems}
|
||
|
|
<BreadcrumbSeparator />
|
||
|
|
<BreadcrumbItem>
|
||
|
|
<BreadcrumbPage>{directory.name}</BreadcrumbPage>{" "}
|
||
|
|
</BreadcrumbItem>
|
||
|
|
</BreadcrumbList>
|
||
|
|
</Breadcrumb>
|
||
|
|
)
|
||
|
|
}
|
||
|
|
|
||
|
|
function FilePathBreadcrumbItem({ component }: { component: PathComponent }) {
|
||
|
|
const { isDraggedOver, dropHandlers } = useFileDrop({
|
||
|
|
destItem: component.handle as DirectoryHandle,
|
||
|
|
dragInfoAtom,
|
||
|
|
})
|
||
|
|
|
||
|
|
const dirName = component.name || "All Files"
|
||
|
|
|
||
|
|
return (
|
||
|
|
<Tooltip open={isDraggedOver}>
|
||
|
|
<TooltipTrigger asChild>
|
||
|
|
<BreadcrumbItem
|
||
|
|
className={cn({ "bg-muted": isDraggedOver })}
|
||
|
|
{...dropHandlers}
|
||
|
|
>
|
||
|
|
<BreadcrumbLink asChild>
|
||
|
|
<Link to={`/directories/${component.handle.id}`}>
|
||
|
|
{dirName}
|
||
|
|
</Link>
|
||
|
|
</BreadcrumbLink>
|
||
|
|
</BreadcrumbItem>
|
||
|
|
</TooltipTrigger>
|
||
|
|
<TooltipContent>Move to {dirName}</TooltipContent>
|
||
|
|
</Tooltip>
|
||
|
|
)
|
||
|
|
}
|