mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-06 22:40:14 -05:00
82a775086c
refs. https://github.com/TryGhost/Product/issues/4169 - some of the new components were not prepared for mobile sizes and dark mode - Storybook settings had to be updated to include mobile sizes that reflect the actual system
107 lines
2.1 KiB
TypeScript
107 lines
2.1 KiB
TypeScript
import React from 'react';
|
|
|
|
import '../styles.css';
|
|
import './storybook.css';
|
|
|
|
import type { Preview } from "@storybook/react";
|
|
import DesignSystemProvider from '../src/providers/DesignSystemProvider';
|
|
import adminxTheme from './adminx-theme';
|
|
|
|
// import { MINIMAL_VIEWPORTS } from '@storybook/addon-viewport';
|
|
|
|
const customViewports = {
|
|
sm: {
|
|
name: 'sm',
|
|
styles: {
|
|
width: '480px',
|
|
height: '801px',
|
|
},
|
|
},
|
|
md: {
|
|
name: 'md',
|
|
styles: {
|
|
width: '640px',
|
|
height: '801px',
|
|
},
|
|
},
|
|
lg: {
|
|
name: 'lg',
|
|
styles: {
|
|
width: '1024px',
|
|
height: '801px',
|
|
},
|
|
},
|
|
xl: {
|
|
name: 'xl',
|
|
styles: {
|
|
width: '1320px',
|
|
height: '801px',
|
|
},
|
|
},
|
|
tablet: {
|
|
name: 'tablet',
|
|
styles: {
|
|
width: '860px',
|
|
height: '801px',
|
|
},
|
|
},
|
|
};
|
|
|
|
const preview: Preview = {
|
|
parameters: {
|
|
actions: { argTypesRegex: "^on[A-Z].*" },
|
|
controls: {
|
|
matchers: {
|
|
color: /(background|color)$/i,
|
|
date: /Date$/,
|
|
},
|
|
},
|
|
options: {
|
|
storySort: {
|
|
method: 'alphabetical',
|
|
order: ['Welcome', 'Foundations', ['Style Guide', 'Colors', 'Icons', 'ErrorHandling'], 'Global', ['Form', 'Chrome', 'Modal', 'Layout', 'List', 'Table', '*'], 'Settings', ['Setting Section', 'Setting Group', '*'], 'Experimental'],
|
|
},
|
|
},
|
|
docs: {
|
|
theme: adminxTheme,
|
|
},
|
|
viewport: {
|
|
viewports: {
|
|
...customViewports,
|
|
},
|
|
},
|
|
},
|
|
decorators: [
|
|
(Story, context) => {
|
|
let {scheme} = context.globals;
|
|
|
|
return (
|
|
<div className={`admin-x-design-system admin-x-base ${scheme === 'dark' ? 'dark' : ''}`} style={{
|
|
// padding: '24px',
|
|
// width: 'unset',
|
|
height: 'unset',
|
|
// overflow: 'unset',
|
|
background: (scheme === 'dark' ? '#131416' : '')
|
|
}}>
|
|
{/* 👇 Decorators in Storybook also accept a function. Replace <Story/> with Story() to enable it */}
|
|
<DesignSystemProvider fetchKoenigLexical={async () => {}}>
|
|
<Story />
|
|
</DesignSystemProvider>
|
|
</div>);
|
|
},
|
|
],
|
|
globalTypes: {
|
|
scheme: {
|
|
name: "Scheme",
|
|
description: "Select light or dark mode",
|
|
defaultValue: "light",
|
|
toolbar: {
|
|
icon: "mirror",
|
|
items: ["light", "dark"],
|
|
dynamicTitle: true
|
|
}
|
|
}
|
|
}
|
|
};
|
|
|
|
export default preview;
|