64 lines
2.0 KiB
TypeScript
64 lines
2.0 KiB
TypeScript
'use client';
|
|
|
|
import React, { useState } from 'react';
|
|
import { Menu } from "@/app/components/menu";
|
|
import { Sidebar } from "@/app/components/sidebar";
|
|
import { useNavidrome } from "@/app/components/NavidromeContext";
|
|
import { AudioPlayer } from "./AudioPlayer";
|
|
import { Toaster } from "@/components/ui/toaster"
|
|
|
|
interface IhateserversideProps {
|
|
children: React.ReactNode;
|
|
}
|
|
|
|
const Ihateserverside: React.FC<IhateserversideProps> = ({ children }) => {
|
|
const [isSidebarVisible, setIsSidebarVisible] = useState(true);
|
|
const [isStatusBarVisible, setIsStatusBarVisible] = useState(true);
|
|
const [isSidebarHidden, setIsSidebarHidden] = useState(false);
|
|
const { playlists } = useNavidrome();
|
|
|
|
const handleTransitionEnd = () => {
|
|
if (!isSidebarVisible) {
|
|
setIsSidebarHidden(true); // This will fully hide the sidebar after transition
|
|
}
|
|
};
|
|
return (
|
|
<div className="hidden md:flex md:flex-col md:h-screen">
|
|
{/* Top Menu */}
|
|
<div className="sticky top-0 z-10 bg-background border-b">
|
|
<Menu
|
|
toggleSidebar={() => setIsSidebarVisible(!isSidebarVisible)}
|
|
isSidebarVisible={isSidebarVisible}
|
|
toggleStatusBar={() => setIsStatusBarVisible(!isStatusBarVisible)}
|
|
isStatusBarVisible={isStatusBarVisible}
|
|
/>
|
|
</div>
|
|
|
|
{/* Main Content Area */}
|
|
<div className="flex-1 flex overflow-hidden">
|
|
{isSidebarVisible && (
|
|
<div className="w-64 flex-shrink-0">
|
|
<Sidebar
|
|
playlists={playlists}
|
|
className="h-full overflow-y-auto"
|
|
onTransitionEnd={handleTransitionEnd}
|
|
/>
|
|
</div>
|
|
)}
|
|
<div className={`flex-1 overflow-y-auto ${isStatusBarVisible ? 'pb-24' : ''}`}>
|
|
<div>{children}</div>
|
|
</div>
|
|
</div>
|
|
|
|
{/* Audio Player */}
|
|
{isStatusBarVisible && (
|
|
<div className="fixed bottom-0 left-0 right-0 z-50 bg-background">
|
|
<AudioPlayer />
|
|
</div>
|
|
)}
|
|
<Toaster />
|
|
</div>
|
|
);
|
|
};
|
|
|
|
export default Ihateserverside; |