From af45df28d5a557da65e4aee5401b9aa440c2be0f Mon Sep 17 00:00:00 2001 From: Hamzat Victor Date: Tue, 24 Sep 2024 13:57:40 +0100 Subject: [PATCH] feat(ui): improve folder structure UI --- frontend/components/editor/sidebar/folder.tsx | 151 ++++++++++-------- 1 file changed, 88 insertions(+), 63 deletions(-) diff --git a/frontend/components/editor/sidebar/folder.tsx b/frontend/components/editor/sidebar/folder.tsx index 4715baf..94582d7 100644 --- a/frontend/components/editor/sidebar/folder.tsx +++ b/frontend/components/editor/sidebar/folder.tsx @@ -1,18 +1,20 @@ -"use client"; +"use client" -import Image from "next/image"; -import { useEffect, useRef, useState } from "react"; -import { getIconForFolder, getIconForOpenFolder } from "vscode-icons-js"; -import { TFile, TFolder, TTab } from "@/lib/types"; -import SidebarFile from "./file"; +import Image from "next/image" +import { useEffect, useRef, useState } from "react" +import { getIconForFolder, getIconForOpenFolder } from "vscode-icons-js" +import { TFile, TFolder, TTab } from "@/lib/types" +import SidebarFile from "./file" import { ContextMenu, ContextMenuContent, ContextMenuItem, ContextMenuTrigger, -} from "@/components/ui/context-menu"; -import { Loader2, Pencil, Trash2 } from "lucide-react"; -import { dropTargetForElements } from "@atlaskit/pragmatic-drag-and-drop/element/adapter"; +} from "@/components/ui/context-menu" +import { ChevronRight, Loader2, Pencil, Trash2 } from "lucide-react" +import { dropTargetForElements } from "@atlaskit/pragmatic-drag-and-drop/element/adapter" +import { cn } from "@/lib/utils" +import { motion, AnimatePresence } from "framer-motion" // Note: Renaming has not been implemented in the backend yet, so UI relating to renaming is commented out @@ -25,27 +27,27 @@ export default function SidebarFolder({ movingId, deletingFolderId, }: { - data: TFolder; - selectFile: (file: TTab) => void; + data: TFolder + selectFile: (file: TTab) => void handleRename: ( id: string, newName: string, oldName: string, type: "file" | "folder" - ) => boolean; - handleDeleteFile: (file: TFile) => void; - handleDeleteFolder: (folder: TFolder) => void; - movingId: string; - deletingFolderId: string; + ) => boolean + handleDeleteFile: (file: TFile) => void + handleDeleteFolder: (folder: TFolder) => void + movingId: string + deletingFolderId: string }) { - const ref = useRef(null); // drop target - const [isDraggedOver, setIsDraggedOver] = useState(false); + const ref = useRef(null) // drop target + const [isDraggedOver, setIsDraggedOver] = useState(false) const isDeleting = - deletingFolderId.length > 0 && data.id.startsWith(deletingFolderId); + deletingFolderId.length > 0 && data.id.startsWith(deletingFolderId) useEffect(() => { - const el = ref.current; + const el = ref.current if (el) return dropTargetForElements({ @@ -67,17 +69,17 @@ export default function SidebarFolder({ // no dropping while awaiting move canDrop: () => { - return !movingId; + return !movingId }, - }); - }, []); + }) + }, []) - const [isOpen, setIsOpen] = useState(false); + const [isOpen, setIsOpen] = useState(false) const folder = isOpen ? getIconForOpenFolder(data.name) - : getIconForFolder(data.name); + : getIconForFolder(data.name) - const inputRef = useRef(null); + const inputRef = useRef(null) // const [editing, setEditing] = useState(false); // useEffect(() => { @@ -96,6 +98,12 @@ export default function SidebarFolder({ isDraggedOver ? "bg-secondary/50 rounded-t-sm" : "rounded-sm" } w-full flex items-center h-7 px-1 transition-colors hover:bg-secondary cursor-pointer`} > + Folder icon { - handleDeleteFolder(data); + handleDeleteFolder(data) }} > Delete - {isOpen ? ( -
-
-
- {data.children.map((child) => - child.type === "file" ? ( - - ) : ( - - ) - )} -
-
- ) : null} + + {isOpen ? ( + +
+
+ {data.children.map((child) => + child.type === "file" ? ( + + ) : ( + + ) + )} +
+
+
+ ) : null} +
- ); + ) }