"use client"; import { FilePlus, FolderPlus, Loader2, MonitorPlay, Search, Sparkles, } from "lucide-react"; import SidebarFile from "./file"; import SidebarFolder from "./folder"; import { Sandbox, TFile, TFolder, TTab } from "@/lib/types"; import { useEffect, useRef, useState } from "react"; import New from "./new"; import { Socket } from "socket.io-client"; import { Switch } from "@/components/ui/switch"; import { dropTargetForElements, monitorForElements, } from "@atlaskit/pragmatic-drag-and-drop/element/adapter"; import Button from "@/components/ui/customButton"; export default function Sidebar({ sandboxData, files, selectFile, handleRename, handleDeleteFile, handleDeleteFolder, socket, setFiles, addNew, ai, setAi, deletingFolderId, }: { sandboxData: Sandbox; files: (TFile | TFolder)[]; selectFile: (tab: TTab) => void; handleRename: ( id: string, newName: string, oldName: string, type: "file" | "folder" ) => boolean; handleDeleteFile: (file: TFile) => void; handleDeleteFolder: (folder: TFolder) => void; socket: Socket; setFiles: (files: (TFile | TFolder)[]) => void; addNew: (name: string, type: "file" | "folder") => void; ai: boolean; setAi: React.Dispatch>; deletingFolderId: string; }) { const ref = useRef(null); // drop target const [creatingNew, setCreatingNew] = useState<"file" | "folder" | null>( null ); const [movingId, setMovingId] = useState(""); useEffect(() => { const el = ref.current; if (el) { return dropTargetForElements({ element: el, getData: () => ({ id: `projects/${sandboxData.id}` }), canDrop: ({ source }) => { const file = files.find((child) => child.id === source.data.id); return !file; }, }); } }, [files]); useEffect(() => { return monitorForElements({ onDrop({ source, location }) { const destination = location.current.dropTargets[0]; if (!destination) { return; } const fileId = source.data.id as string; const folderId = destination.data.id as string; const fileFolder = fileId.split("/").slice(0, -1).join("/"); if (fileFolder === folderId) { return; } console.log("move file", fileId, "to folder", folderId); setMovingId(fileId); socket.emit( "moveFile", fileId, folderId, (response: (TFolder | TFile)[]) => { setFiles(response); setMovingId(""); } ); }, }); }, []); return (
Explorer
{/* Todo: Implement file searching */} {/* */}
{/*
*/} {files.length === 0 ? (
) : ( <> {files.map((child) => child.type === "file" ? ( ) : ( ) )} {creatingNew !== null ? ( { setCreatingNew(null); }} addNew={addNew} /> ) : null} )}
Copilot{" "} ⌘G
{/* */}
); }