Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[core] Replace storybook knobs for args #601

Merged
merged 8 commits into from
Nov 30, 2020
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
@@ -1,34 +1,27 @@
const path = require('path');
const webpack = require('webpack');
import path from 'path';
import webpack from 'webpack';
import type { StorybookConfig } from '@storybook/core/types';

const env = process.env.NODE_ENV || 'development';
/* eslint-disable */
const __DEV__ = env === 'development';
const __PROD__ = env === 'production';
const isDevelopment = env === 'development';
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

DEV is already defined somewhere globally, typescript complains

const isProduction = env === 'production';
/* eslint-enable */

if (!(__DEV__ || __PROD__)) {
if (!(isDevelopment || isProduction)) {
throw new Error(`Unknown env: ${env}.`);
}
console.log(`Loading config for ${env}`);
const maxAssetSize = 1024 * 1024;

module.exports = {
const config: StorybookConfig = {
stories: ['../src/**/*.stories.*'],
addons: [
'@storybook/addon-docs',
'@storybook/addon-viewport/register',
'@storybook/addon-knobs/register',
'@storybook/addon-actions/register',
'@storybook/addon-storysource/register',
'@storybook/addon-a11y/register',
],
addons: ['@storybook/addon-essentials', '@storybook/addon-storysource', '@storybook/addon-a11y'],
typescript: {
check: __DEV__, // Netlify is breaking the deploy with this settings on. So deactivate on release
reactDocgen: false,
check: isDevelopment, // Netlify is breaking the deploy with this settings on. So deactivate on release
},
webpackFinal: async (config) => {
config.devtool = __DEV__ ? 'inline-source-map' : undefined;
config.devtool = isDevelopment ? 'inline-source-map' : undefined;
config.parallelism = 1;
config.module.rules.push({
test: /\.(ts|tsx)$/,
Expand All @@ -38,7 +31,7 @@ module.exports = {
},
],
});
if (__DEV__) {
if (isDevelopment) {
config.module.rules.push({
test: /\.(ts|tsx)$/,
use: ['source-map-loader'],
Expand Down Expand Up @@ -109,3 +102,5 @@ module.exports = {
return config;
},
};

export default config;
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
// @ts-ignore
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

To find out why and remove

import { LicenseInfo } from '@material-ui/x-grid';
import { addParameters } from '@storybook/react';
import { INITIAL_VIEWPORTS } from '@storybook/addon-viewport';
Expand All @@ -13,7 +14,8 @@ configureActions({
limit: 10,
});

addParameters({
export const parameters = {
actions: { argTypesRegex: '^on.*' },
options: {
/**
* display the top-level grouping as a "root" in the sidebar
Expand All @@ -35,4 +37,4 @@ addParameters({
docs: {
page: null,
},
});
};
21 changes: 10 additions & 11 deletions packages/storybook/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@
"private": true,
"scripts": {
"start": "start-storybook -p 6006 --ci",
"build": "build-storybook -o dist/ -s storybook --quiet",
"build": "build-storybook -o dist/ --quiet",
"export": "mv dist ../../docs/export/storybook",
"lint": "../../node_modules/.bin/tsc --noEmit && eslint 'src/**/*.{ts,tsx}' --quiet --fix -c ./.eslintrc.js",
"test": "jest -c integration/setup/jest.config.js --detectOpenHandles --force-exit --runInBand",
Expand All @@ -28,16 +28,15 @@
},
"devDependencies": {
"@babel/core": "^7.9.0",
"@storybook/addon-a11y": "^6.0.4",
"@storybook/addon-actions": "^6.0.4",
"@storybook/addon-console": "^1.2.1",
"@storybook/addon-docs": "^6.0.4",
"@storybook/addon-info": "^5.3.19",
"@storybook/addon-knobs": "^6.0.4",
"@storybook/addon-storysource": "^6.0.4",
"@storybook/addon-viewport": "^6.0.4",
"@storybook/react": "^6.0.4",
"@storybook/theming": "^6.0.4",
"@storybook/addon-a11y": "^6.1.9",
"@storybook/addon-actions": "^6.1.9",
"@storybook/addon-console": "^1.2.2",
"@storybook/addon-docs": "^6.1.9",
"@storybook/addon-essentials": "^6.1.9",
"@storybook/addon-storysource": "^6.1.9",
"@storybook/addon-viewport": "^6.1.9",
"@storybook/react": "^6.1.9",
"@storybook/theming": "^6.1.9",
"@types/jest": "^26.0.0",
"@types/jest-image-snapshot": "^4.1.0",
"@types/puppeteer": "^5.4.0",
Expand Down
2 changes: 0 additions & 2 deletions packages/storybook/src/stories/grid-columns.stories.tsx
Original file line number Diff line number Diff line change
@@ -1,14 +1,12 @@
import * as React from 'react';
import { ColDef, XGrid, ColTypeDef } from '@material-ui/x-grid';
import { withKnobs } from '@storybook/addon-knobs';
import CreateIcon from '@material-ui/icons/Create';
import Button from '@material-ui/core/Button';
import { useData } from '../hooks/useData';

export default {
title: 'X-Grid Tests/Columns',
component: XGrid,
decorators: [withKnobs],
parameters: {
options: { selectedPanel: 'storybook/storysource/panel' },
docs: {
Expand Down
2 changes: 0 additions & 2 deletions packages/storybook/src/stories/grid-data.stories.tsx
Original file line number Diff line number Diff line change
@@ -1,12 +1,10 @@
import * as React from 'react';
import { withKnobs } from '@storybook/addon-knobs';
import { XGrid, GridOptionsProp } from '@material-ui/x-grid';
import { useData } from '../hooks/useData';

export default {
title: 'X-Grid Tests/Dataset',
component: XGrid,
decorators: [withKnobs],
parameters: {
options: { selectedPanel: 'storybook/storysource/panel' },
docs: {
Expand Down
2 changes: 0 additions & 2 deletions packages/storybook/src/stories/grid-error.stories.tsx
Original file line number Diff line number Diff line change
@@ -1,12 +1,10 @@
import * as React from 'react';
import { XGrid, ColDef, useApiRef, GridOverlay } from '@material-ui/x-grid';
import { withKnobs } from '@storybook/addon-knobs';
import '../style/grid-stories.css';

export default {
title: 'X-Grid Tests/Error Handling',
component: XGrid,
decorators: [withKnobs],
parameters: {
options: { selectedPanel: 'storybook/storysource/panel' },
docs: {
Expand Down
2 changes: 0 additions & 2 deletions packages/storybook/src/stories/grid-events.stories.tsx
Original file line number Diff line number Diff line change
@@ -1,13 +1,11 @@
import * as React from 'react';
import { action } from '@storybook/addon-actions';
import { XGrid, GridOptionsProp } from '@material-ui/x-grid';
import { withKnobs } from '@storybook/addon-knobs';
import { useData } from '../hooks/useData';

export default {
title: 'X-Grid Tests/Events',
component: XGrid,
decorators: [withKnobs],
parameters: {
options: { selectedPanel: 'storybook/storysource/panel' },
docs: {
Expand Down
3 changes: 0 additions & 3 deletions packages/storybook/src/stories/grid-filter.stories.tsx
Original file line number Diff line number Diff line change
@@ -1,13 +1,10 @@
import * as React from 'react';
import { ColDef, XGrid, ColTypeDef } from '@material-ui/x-grid';
import { withKnobs } from '@storybook/addon-knobs';
import { withA11y } from '@storybook/addon-a11y';
import { useData } from '../hooks/useData';

export default {
title: 'X-Grid Tests/Filter',
component: XGrid,
decorators: [withKnobs, withA11y],
parameters: {
options: { selectedPanel: 'storybook/storysource/panel' },
docs: {
Expand Down
2 changes: 0 additions & 2 deletions packages/storybook/src/stories/grid-options.stories.tsx
Original file line number Diff line number Diff line change
@@ -1,12 +1,10 @@
import * as React from 'react';
import { ColDef, XGrid } from '@material-ui/x-grid';
import { withKnobs } from '@storybook/addon-knobs';
import { useData } from '../hooks/useData';

export default {
title: 'X-Grid Tests/Options',
component: XGrid,
decorators: [withKnobs],
parameters: {
options: { selectedPanel: 'storybook/storysource/panel' },
},
Expand Down
40 changes: 17 additions & 23 deletions packages/storybook/src/stories/grid-pagination.stories.tsx
Original file line number Diff line number Diff line change
@@ -1,22 +1,21 @@
import { DataGrid } from '@material-ui/data-grid';
import { useDemoData } from '@material-ui/x-grid-data-generator';
import * as React from 'react';
import { Story, Meta } from '@storybook/react';
import { ApiRef, useApiRef, XGrid, PageChangeParams, RowsProp } from '@material-ui/x-grid';
import Button from '@material-ui/core/Button';
import Pagination from '@material-ui/lab/Pagination';
import { action } from '@storybook/addon-actions';
import { array, boolean, number, withKnobs } from '@storybook/addon-knobs';
import { useData } from '../hooks/useData';
import { getData, GridData } from '../data/data-service';

export default {
title: 'X-Grid Tests/Pagination',
component: XGrid,
decorators: [withKnobs],
parameters: {
options: { selectedPanel: 'storybook/storysource/panel' },
},
};
} as Meta;

export function PaginationDefault() {
const data = useData(2000, 200);
Expand All @@ -38,28 +37,23 @@ export function PageSize100() {
);
}

export function PaginationKnobs() {
export const PaginationArgs: Story = (args) => {
const data = useData(2000, 200);
const rowsPerPageOptions = array('Rows per page options', ['10', '20', '50', '100', '200'], ', ');

return (
<XGrid
rows={data.rows}
columns={data.columns}
{...{
pagination: true,
pageSize: number('PageSize', 100),
page: number('Page', 1),
rowCount: number('RowCount', 2000),
autoPageSize: boolean('Auto page size', false),
rowsPerPageOptions: rowsPerPageOptions.map((value) => parseInt(value, 10)),
hideFooterRowCount: boolean('Hide row count', false),
hideFooterPagination: boolean('Hide footer pagination', false),
hideFooter: boolean('Hide footer', false),
}}
/>
);
}
return <XGrid rows={data.rows} columns={data.columns} {...args} />;
};
PaginationArgs.args = {
pagination: true,
pageSize: 100,
page: 1,
rowCount: 2000,
autoPageSize: false,
rowsPerPageOptions: [10, 20, 50, 100, 200],
hideFooterRowCount: false,
hideFooterPagination: false,
hideFooter: false,
};

export function HiddenPagination() {
const data = useData(2000, 200);

Expand Down
3 changes: 0 additions & 3 deletions packages/storybook/src/stories/grid-reorder.stories.tsx
Original file line number Diff line number Diff line change
@@ -1,14 +1,11 @@
import * as React from 'react';
import { ElementSize, XGrid } from '@material-ui/x-grid';
import { withKnobs } from '@storybook/addon-knobs';
import { withA11y } from '@storybook/addon-a11y';
import '../style/grid-stories.css';
import { useData } from '../hooks/useData';

export default {
title: 'X-Grid Tests/Reorder',
component: XGrid,
decorators: [withKnobs, withA11y],
parameters: {
options: { selectedPanel: 'storybook/storysource/panel' },
docs: {
Expand Down
2 changes: 0 additions & 2 deletions packages/storybook/src/stories/grid-resize.stories.tsx
Original file line number Diff line number Diff line change
@@ -1,13 +1,11 @@
import * as React from 'react';
import { ElementSize, XGrid } from '@material-ui/x-grid';
import { withKnobs } from '@storybook/addon-knobs';
import '../style/grid-stories.css';
import { useData } from '../hooks/useData';

export default {
title: 'X-Grid Tests/Resize',
component: XGrid,
decorators: [withKnobs],
parameters: {
options: { selectedPanel: 'storybook/storysource/panel' },
docs: {
Expand Down
2 changes: 0 additions & 2 deletions packages/storybook/src/stories/grid-selection.stories.tsx
Original file line number Diff line number Diff line change
@@ -1,14 +1,12 @@
import * as React from 'react';
import { action } from '@storybook/addon-actions';
import { XGrid, GridOptionsProp, useApiRef } from '@material-ui/x-grid';
import { withKnobs } from '@storybook/addon-knobs';
import { getData, GridData } from '../data/data-service';
import { useData } from '../hooks/useData';

export default {
title: 'X-Grid Tests/Selection',
component: XGrid,
decorators: [withKnobs],
parameters: {
options: { selectedPanel: 'storybook/storysource/panel' },
docs: {
Expand Down
2 changes: 0 additions & 2 deletions packages/storybook/src/stories/grid-sorting.stories.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -9,13 +9,11 @@ import {
SortModel,
useApiRef,
} from '@material-ui/x-grid';
import { withKnobs } from '@storybook/addon-knobs';
import { action } from '@storybook/addon-actions';

export default {
title: 'X-Grid Tests/Sorting',
component: XGrid,
decorators: [withKnobs],
parameters: {
options: { selectedPanel: 'storybook/action/panel' },
docs: {
Expand Down
2 changes: 0 additions & 2 deletions packages/storybook/src/stories/grid-state.stories.tsx
Original file line number Diff line number Diff line change
@@ -1,14 +1,12 @@
import * as React from 'react';
import Button from '@material-ui/core/Button';
import { GridState, SortingState, useApiRef, XGrid } from '@material-ui/x-grid';
import { withKnobs } from '@storybook/addon-knobs';
import { StateChangeParams } from '../../../grid/_modules_/grid/models/params/stateChangeParams';
import { useData } from '../hooks/useData';

export default {
title: 'X-Grid Tests/State',
component: XGrid,
decorators: [withKnobs],
parameters: {
options: { selectedPanel: 'storybook/storysource/panel' },
docs: {
Expand Down
2 changes: 0 additions & 2 deletions packages/storybook/src/stories/grid-streaming.stories.tsx
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
import * as React from 'react';
import { action } from '@storybook/addon-actions';
import { GridOptionsProp, XGrid, useApiRef } from '@material-ui/x-grid';
import { withKnobs } from '@storybook/addon-knobs';
import { interval } from 'rxjs';
import { randomInt, randomUserName } from '@material-ui/x-grid-data-generator';
import { FeedGrid } from '../components/feed-grid';
Expand All @@ -10,7 +9,6 @@ import { PricingGrid } from '../components/pricing-grid';
export default {
title: 'X-Grid Tests/Streaming',
component: XGrid,
decorators: [withKnobs],
parameters: {
options: { selectedPanel: 'storybook/storysource/panel' },
docs: {
Expand Down
2 changes: 0 additions & 2 deletions packages/storybook/src/stories/grid-style.stories.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -2,14 +2,12 @@ import * as React from 'react';
import { XGrid, GridOptionsProp, ColDef } from '@material-ui/x-grid';
import DoneIcon from '@material-ui/icons/Done';
import ClearIcon from '@material-ui/icons/Clear';
import { withKnobs } from '@storybook/addon-knobs';
import { useData } from '../hooks/useData';
import '../style/grid-stories.css';

export default {
title: 'X-Grid Tests/Styling',
component: XGrid,
decorators: [withKnobs],
parameters: {
options: { selectedPanel: 'storybook/storysource/panel' },
docs: {
Expand Down
Loading