Stories no longer wrap with QueryClientProvider, ToastProvider, ThemeProvider, or MemoryRouter; global StorybookDecorator provides them. - Route-specific pages use parameters.router.initialEntries (ResetPasswordPage, VerifyEmailPage) or minimal MemoryRouter+Route where useParams is needed (TrackDetailPage, PlaylistDetailPage). - Stories that seeded query cache use useQueryClient() from global decorator (FollowButton, CollaboratorManagement, CommentSection). - Navbar, AuthLayout, DashboardLayout, Header, and 25+ story files simplified to layout divs only. Co-authored-by: Cursor <cursoragent@cursor.com>
26 lines
649 B
TypeScript
26 lines
649 B
TypeScript
import type { Meta, StoryObj } from '@storybook/react';
|
|
import { Header } from './Header';
|
|
|
|
const meta = {
|
|
title: 'Components/Layout/Header',
|
|
component: Header,
|
|
tags: ['autodocs'],
|
|
decorators: [
|
|
(Story) => (
|
|
<div className="h-screen bg-kodo-void">
|
|
<Story />
|
|
<div className="pt-24 px-8 text-white">
|
|
<h1>Page Content</h1>
|
|
</div>
|
|
</div>
|
|
),
|
|
],
|
|
parameters: {
|
|
layout: 'fullscreen',
|
|
},
|
|
} satisfies Meta<typeof Header>;
|
|
|
|
export default meta;
|
|
type Story = StoryObj<typeof meta>;
|
|
|
|
export const Default: Story = {};
|