feat(admin): replace prop-based page title with context provider

This commit is contained in:
2026-04-22 17:58:04 -04:00
parent 18e0cb3486
commit 843f992b1f
3 changed files with 42 additions and 20 deletions
@@ -0,0 +1,18 @@
'use client';
import { createContext, useContext, useState } from 'react';
const AdminPageTitleContext = createContext({ title: '', setTitle: () => {} });
export function AdminPageTitleProvider({ children }) {
const [title, setTitle] = useState('');
return (
<AdminPageTitleContext.Provider value={{ title, setTitle }}>
{children}
</AdminPageTitleContext.Provider>
);
}
export function useAdminPageTitle() {
return useContext(AdminPageTitleContext);
}
+21 -19
View File
@@ -3,34 +3,36 @@
import { useState } from 'react'; import { useState } from 'react';
import AdminSidebar from './AdminSidebar.js'; import AdminSidebar from './AdminSidebar.js';
import AdminTop from './AdminTop.js'; import AdminTop from './AdminTop.js';
import { AdminPageTitleProvider } from './AdminPageTitleContext.js';
export default function AdminShell({ children, user, onLogout, appName, navigationSections, currentPageTitle }) { export default function AdminShell({ children, user, onLogout, appName, navigationSections }) {
const [isMobileMenuOpen, setIsMobileMenuOpen] = useState(false); const [isMobileMenuOpen, setIsMobileMenuOpen] = useState(false);
return ( return (
<div className="flex h-screen overflow-hidden bg-white dark:bg-black font-ibm-plex-sans"> <AdminPageTitleProvider>
<AdminSidebar <div className="flex h-screen overflow-hidden bg-white dark:bg-black font-ibm-plex-sans">
isMobileMenuOpen={isMobileMenuOpen} <AdminSidebar
setIsMobileMenuOpen={setIsMobileMenuOpen}
appName={appName}
navigationSections={navigationSections}
/>
<div className="flex-1 flex flex-col min-w-0">
<AdminTop
isMobileMenuOpen={isMobileMenuOpen} isMobileMenuOpen={isMobileMenuOpen}
setIsMobileMenuOpen={setIsMobileMenuOpen} setIsMobileMenuOpen={setIsMobileMenuOpen}
user={user}
onLogout={onLogout}
appName={appName} appName={appName}
navigationSections={navigationSections} navigationSections={navigationSections}
currentPageTitle={currentPageTitle}
/> />
<main className="flex-1 overflow-y-auto bg-neutral-50 dark:bg-black"> <div className="flex-1 flex flex-col min-w-0">
<div className="px-8 py-7 pb-32 max-w-[1920px] mx-auto"> <AdminTop
{children} isMobileMenuOpen={isMobileMenuOpen}
</div> setIsMobileMenuOpen={setIsMobileMenuOpen}
</main> user={user}
onLogout={onLogout}
appName={appName}
navigationSections={navigationSections}
/>
<main className="flex-1 overflow-y-auto bg-neutral-50 dark:bg-black">
<div className="px-8 py-7 pb-32 max-w-[1920px] mx-auto">
{children}
</div>
</main>
</div>
</div> </div>
</div> </AdminPageTitleProvider>
); );
} }
+3 -1
View File
@@ -6,9 +6,11 @@ import { ChevronDownIcon, User03Icon, DashboardSquare03Icon } from '@zen/core/sh
import { UserAvatar } from '@zen/core/shared/components'; import { UserAvatar } from '@zen/core/shared/components';
import { useRouter, usePathname } from 'next/navigation'; import { useRouter, usePathname } from 'next/navigation';
import { getPages } from '../registry.js'; import { getPages } from '../registry.js';
import { useAdminPageTitle } from './AdminPageTitleContext.js';
import { useTheme, getThemeIcon } from '@zen/core/themes'; import { useTheme, getThemeIcon } from '@zen/core/themes';
const AdminTop = ({ isMobileMenuOpen, setIsMobileMenuOpen, user, onLogout, appName = 'ZEN', navigationSections = [], currentPageTitle }) => { const AdminTop = ({ isMobileMenuOpen, setIsMobileMenuOpen, user, onLogout, appName = 'ZEN', navigationSections = [] }) => {
const { title: currentPageTitle } = useAdminPageTitle();
const router = useRouter(); const router = useRouter();
const pathname = usePathname(); const pathname = usePathname();