Compare commits
2 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 3edc7267d8 | |||
| 843f992b1f |
Generated
+2
-2
@@ -1,12 +1,12 @@
|
|||||||
{
|
{
|
||||||
"name": "@zen/core",
|
"name": "@zen/core",
|
||||||
"version": "1.4.36",
|
"version": "1.4.37",
|
||||||
"lockfileVersion": 3,
|
"lockfileVersion": 3,
|
||||||
"requires": true,
|
"requires": true,
|
||||||
"packages": {
|
"packages": {
|
||||||
"": {
|
"": {
|
||||||
"name": "@zen/core",
|
"name": "@zen/core",
|
||||||
"version": "1.4.36",
|
"version": "1.4.37",
|
||||||
"license": "GPL-3.0-only",
|
"license": "GPL-3.0-only",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@headlessui/react": "^2.0.0",
|
"@headlessui/react": "^2.0.0",
|
||||||
|
|||||||
+1
-1
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "@zen/core",
|
"name": "@zen/core",
|
||||||
"version": "1.4.36",
|
"version": "1.4.37",
|
||||||
"description": "Un CMS Next.js construit sur l'essentiel, rien de plus, rien de moins.",
|
"description": "Un CMS Next.js construit sur l'essentiel, rien de plus, rien de moins.",
|
||||||
"repository": {
|
"repository": {
|
||||||
"type": "git",
|
"type": "git",
|
||||||
|
|||||||
@@ -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);
|
||||||
|
}
|
||||||
@@ -3,11 +3,13 @@
|
|||||||
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 (
|
||||||
|
<AdminPageTitleProvider>
|
||||||
<div className="flex h-screen overflow-hidden bg-white dark:bg-black font-ibm-plex-sans">
|
<div className="flex h-screen overflow-hidden bg-white dark:bg-black font-ibm-plex-sans">
|
||||||
<AdminSidebar
|
<AdminSidebar
|
||||||
isMobileMenuOpen={isMobileMenuOpen}
|
isMobileMenuOpen={isMobileMenuOpen}
|
||||||
@@ -23,7 +25,6 @@ export default function AdminShell({ children, user, onLogout, appName, navigati
|
|||||||
onLogout={onLogout}
|
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">
|
<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">
|
<div className="px-8 py-7 pb-32 max-w-[1920px] mx-auto">
|
||||||
@@ -32,5 +33,6 @@ export default function AdminShell({ children, user, onLogout, appName, navigati
|
|||||||
</main>
|
</main>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
</AdminPageTitleProvider>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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();
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user