puffin-app/components/RootLayoutClient.tsx
Matt 7b4640f861
All checks were successful
Build and Push Docker Images / docker (push) Successful in 2m27s
Fix TypeScript build error - remove unused parameter
Remove unused 'registration' parameter from onSuccess callback to fix production build type checking.

Build tested locally and passes successfully.

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-11-04 15:47:52 +01:00

51 lines
1.5 KiB
TypeScript

'use client';
import { usePathname } from 'next/navigation';
import { useState, useEffect } from 'react';
import { Header } from './Header';
import { Footer } from './Footer';
import { UpdateNotification } from './UpdateNotification';
import * as swRegistration from '../lib/serviceWorkerRegistration';
export function RootLayoutClient({ children }: { children: React.ReactNode }) {
const pathname = usePathname();
const isAdminRoute = pathname?.startsWith('/admin');
const isCheckoutSuccess = pathname?.startsWith('/checkout/success');
const [updateAvailable, setUpdateAvailable] = useState<ServiceWorkerRegistration | null>(null);
useEffect(() => {
// Register service worker with update detection
swRegistration.register({
onUpdate: (registration) => {
console.log('New version available!');
setUpdateAvailable(registration);
},
onSuccess: () => {
console.log('Service worker registered successfully');
}
});
}, []);
if (isAdminRoute || isCheckoutSuccess) {
// Admin routes and checkout success render without header/footer
return (
<>
{children}
<UpdateNotification registration={updateAvailable} />
</>
);
}
// Regular routes render with header/footer
return (
<>
<Header />
<main className="flex-1 max-w-[1600px] w-full mx-auto pb-8 sm:pb-12 px-4 sm:px-6 lg:px-8 overflow-hidden" style={{ paddingTop: '110px' }}>
{children}
</main>
<Footer />
<UpdateNotification registration={updateAvailable} />
</>
);
}