fbredius/storybook

View on GitHub
lib/ui/src/components/layout/mobile.stories.tsx

Summary

Maintainability
B
5 hrs
Test Coverage
import React, { Fragment } from 'react';
import { ActiveTabs } from '@storybook/api';
import type { DecoratorFn } from '@storybook/react';

import { Mobile, MobileProps } from './mobile';

import { mockProps, realProps, MockPage } from './app.mockdata';

export default {
  title: 'UI/Layout/Mobile',
  component: Mobile,
  parameters: { passArgsFirst: false },
  decorators: [
    ((storyFn, c) => {
      const mocked = true;

      const props = {
        ...(mocked ? mockProps : realProps),
      };

      return storyFn({ props, ...c });
    }) as DecoratorFn,
  ],
};

export const InitialSidebar = ({ props }: { props: MobileProps }) => (
  <Mobile {...props} options={{ ...props.options, initialActive: ActiveTabs.SIDEBAR }} />
);
export const InitialCanvas = ({ props }: { props: MobileProps }) => (
  <Mobile {...props} options={{ ...props.options, initialActive: ActiveTabs.CANVAS }} />
);
export const InitialAddons = ({ props }: { props: MobileProps }) => (
  <Mobile {...props} options={{ ...props.options, initialActive: ActiveTabs.ADDONS }} />
);

export const DocsOnly = ({ props }: { props: MobileProps }) => <Mobile {...props} docsOnly />;

export const Page = ({ props }: { props: MobileProps }) => (
  <Mobile
    {...props}
    options={{ ...props.options, initialActive: ActiveTabs.CANVAS }}
    pages={[
      {
        key: 'settings',
        route: ({ children }) => <Fragment>{children}</Fragment>,
        render: () => <MockPage />,
      },
    ]}
    viewMode="settings"
  />
);