"use client" import Editor, { OnMount } from "@monaco-editor/react" import monaco from "monaco-editor" import { useRef, useState } from "react" // import theme from "./theme.json" import { ResizableHandle, ResizablePanel, ResizablePanelGroup, } from "@/components/ui/resizable" import { ChevronLeft, ChevronRight, RotateCw, TerminalSquare, } from "lucide-react" import Tab from "../ui/tab" import Sidebar from "./sidebar" import { useClerk } from "@clerk/nextjs" import { TFile, TFolder } from "./sidebar/types" export default function CodeEditor({ files }: { files: (TFile | TFolder)[] }) { // const editorRef = useRef(null) // const handleEditorMount: OnMount = (editor, monaco) => { // editorRef.current = editor // } const clerk = useClerk() const [tabs, setTabs] = useState([]) const [activeId, setActiveId] = useState(null) const selectFile = (tab: TFile) => { setTabs((prev) => { const exists = prev.find((t) => t.id === tab.id) if (exists) { setActiveId(exists.id) return prev } return [...prev, tab] }) setActiveId(tab.id) } const closeTab = (tab: TFile) => { const numTabs = tabs.length const index = tabs.findIndex((t) => t.id === tab.id) setActiveId((prev) => { const next = prev === tab.id ? numTabs === 1 ? null : index < numTabs - 1 ? tabs[index + 1].id : tabs[index - 1].id : prev return next }) setTabs((prev) => prev.filter((t) => t.id !== tab.id)) } return ( <>
{tabs.map((tab) => ( setActiveId(tab.id)} onClose={() => closeTab(tab)} > {tab.name} ))}
{activeId === null ? ( <>
No file selected.
) : clerk.loaded ? ( ) : null}
Preview
Node Console
) }