import React, { Fragment, useState } from "react" import { Dialog, Menu, Transition } from "@headlessui/react" import { Bars3BottomLeftIcon, XMarkIcon, TagIcon, CircleStackIcon, CogIcon, ChatBubbleLeftIcon, Bars3Icon, Bars4Icon, ArrowPathIcon } from "@heroicons/react/24/outline" import logoImage from "data-base64:~assets/icon.png" import { Link, useParams, useLocation, useNavigate } from "react-router-dom" import { Sidebar } from "./Sidebar" import { Drawer, Layout, Modal, Select } from "antd" import { useQuery } from "@tanstack/react-query" import { fetchModels } from "~services/ollama" import { useMessageOption } from "~hooks/useMessageOption" import { PanelLeftIcon, Settings2 } from "lucide-react" import { Settings } from "./Settings" import { useDarkMode } from "~hooks/useDarkmode" const navigation = [ { name: "Embed", href: "/bot/:id", icon: TagIcon }, { name: "Preview", href: "/bot/:id/preview", icon: ChatBubbleLeftIcon }, { name: "Data Sources", href: "/bot/:id/data-sources", icon: CircleStackIcon }, { name: "Settings", href: "/bot/:id/settings", icon: CogIcon } ] //@ts-ignore - function classNames(...classes) { return classes.filter(Boolean).join(" ") } export default function OptionLayout({ children }: { children: React.ReactNode }) { const [sidebarOpen, setSidebarOpen] = useState(false) const [open, setOpen] = useState(false) const { data: models, isLoading: isModelsLoading, refetch: refetchModels, isFetching: isModelsFetching } = useQuery({ queryKey: ["fetchModel"], queryFn: fetchModels }) const { selectedModel, setSelectedModel } = useMessageOption() return (