import React, { useEffect, useRef, useState } from "react"; import { AtSign, BookOpen, Briefcase, Cpu, GitHub, LogOut, Menu, Package, Plus, Shield, Tool, } from "react-feather"; import IndexCount from "./IndexCount"; import LLMStatus from "./LLMStatus"; import SystemSettingsModal, { useSystemSettingsModal, } from "../Modals/Settings"; import NewWorkspaceModal, { useNewWorkspaceModal, } from "../Modals/NewWorkspace"; import ActiveWorkspaces from "./ActiveWorkspaces"; import paths from "../../utils/paths"; import Discord from "../Icons/Discord"; import useUser from "../../hooks/useUser"; import { userFromStorage } from "../../utils/request"; import { AUTH_TOKEN, AUTH_USER } from "../../utils/constants"; export default function Sidebar() { const sidebarRef = useRef(null); const { showing: showingSystemSettingsModal, showModal: showSystemSettingsModal, hideModal: hideSystemSettingsModal, } = useSystemSettingsModal(); const { showing: showingNewWsModal, showModal: showNewWsModal, hideModal: hideNewWsModal, } = useNewWorkspaceModal(); return ( <>
{/* Header Information */}

AnythingLLM

{/* Primary Body */}

Feedback form

{/* Footer */}
@MintplexLabs
{showingSystemSettingsModal && ( )} {showingNewWsModal && } ); } export function SidebarMobileHeader() { const sidebarRef = useRef(null); const [showSidebar, setShowSidebar] = useState(false); const [showBgOverlay, setShowBgOverlay] = useState(false); const { showing: showingSystemSettingsModal, showModal: showSystemSettingsModal, hideModal: hideSystemSettingsModal, } = useSystemSettingsModal(); const { showing: showingNewWsModal, showModal: showNewWsModal, hideModal: hideNewWsModal, } = useNewWorkspaceModal(); useEffect(() => { function handleBg() { if (showSidebar) { setTimeout(() => { setShowBgOverlay(true); }, 300); } else { setShowBgOverlay(false); } } handleBg(); }, [showSidebar]); return ( <>

AnythingLLM

setShowSidebar(false)} />
{/* Header Information */}

AnythingLLM

{/* Primary Body */}
{showingSystemSettingsModal && ( )} {showingNewWsModal && }
); } function AdminHome() { const { user } = useUser(); if (!user || user?.role !== "admin") return null; return ( ); } function LogoutButton() { if (!window.localStorage.getItem(AUTH_USER)) return null; const user = userFromStorage(); if (!user.username) return null; return ( ); } function ManagedHosting() { if (window.location.origin.includes(".useanything.com")) return null; return (

Managed cloud hosting

); }