From 63c3bf26a41cc7a69be879b117791d297e0fd94f Mon Sep 17 00:00:00 2001 From: D071203 Date: Thu, 28 May 2020 16:00:59 +0200 Subject: [PATCH] Update stories of components update stories of components --- .../components/ActionSheet/demo.stories.tsx | 14 +- .../AnalyticalCard/demo.stories.tsx | 57 +++++-- .../AnalyticalTable.stories.tsx | 120 +++++++------ .../main/src/components/Bar/demo.stories.tsx | 14 +- .../components/Breadcrumbs/demo.stories.tsx | 20 ++- .../src/components/FilterBar/demo.stories.tsx | 161 +++++++++--------- .../src/components/FlexBox/demo.stories.tsx | 28 ++- .../main/src/components/Grid/Grid.stories.tsx | 19 ++- .../src/components/Loader/demo.stories.tsx | 20 ++- .../components/MessageBox/demo.stories.tsx | 21 +-- .../components/Notification/demo.stories.tsx | 58 ++++--- .../components/ObjectStatus/demo.stories.tsx | 30 ++-- .../main/src/components/Page/demo.stories.tsx | 29 ++-- .../ProgressIndicator/demo.stories.tsx | 20 ++- .../SideNavigation/demo.stories.tsx | 20 ++- .../src/components/Spinner/demo.stories.tsx | 15 +- .../main/src/components/Text/demo.stories.tsx | 10 +- .../VariantManagement/demo.stories.tsx | 29 ++-- 18 files changed, 402 insertions(+), 283 deletions(-) diff --git a/packages/main/src/components/ActionSheet/demo.stories.tsx b/packages/main/src/components/ActionSheet/demo.stories.tsx index eafe183ee70..3fcee59339b 100644 --- a/packages/main/src/components/ActionSheet/demo.stories.tsx +++ b/packages/main/src/components/ActionSheet/demo.stories.tsx @@ -1,15 +1,21 @@ -import { select } from '@storybook/addon-knobs'; import { ActionSheet } from '@ui5/webcomponents-react/lib/ActionSheet'; import { Button } from '@ui5/webcomponents-react/lib/Button'; import { PlacementType } from '@ui5/webcomponents-react/lib/PlacementType'; import React, { useCallback, useRef } from 'react'; +import { createSelectArgTypes } from '@shared/stories/createSelectArgTypes'; export default { title: 'Components / ActionSheet', - component: ActionSheet + component: ActionSheet, + argTypes: { + ...createSelectArgTypes({ placementType: PlacementType }) + }, + args: { + placement: PlacementType.Bottom + } }; -export const defaultStory = () => { +export const defaultStory = (props) => { const actionSheetRef = useRef(); const onButtonClick = useCallback( (e) => { @@ -20,7 +26,7 @@ export const defaultStory = () => { return ( <> - + diff --git a/packages/main/src/components/AnalyticalCard/demo.stories.tsx b/packages/main/src/components/AnalyticalCard/demo.stories.tsx index 1fb15d435a4..6e5f8c7610a 100644 --- a/packages/main/src/components/AnalyticalCard/demo.stories.tsx +++ b/packages/main/src/components/AnalyticalCard/demo.stories.tsx @@ -1,17 +1,38 @@ -import { action } from '@storybook/addon-actions'; -import { boolean, select, text } from '@storybook/addon-knobs'; import { LineChart } from '@ui5/webcomponents-react-charts/lib/LineChart'; import { AnalyticalCard } from '@ui5/webcomponents-react/lib/AnalyticalCard'; import { AnalyticalCardHeader } from '@ui5/webcomponents-react/lib/AnalyticalCardHeader'; import { DeviationIndicator } from '@ui5/webcomponents-react/lib/DeviationIndicator'; import { ValueState } from '@ui5/webcomponents-react/lib/ValueState'; import React from 'react'; +import { createSelectArgTypes } from '@shared/stories/createSelectArgTypes'; export default { title: 'Components / Analytical Card', component: AnalyticalCard, parameters: { subcomponents: { AnalyticalCardHeader } + }, + argTypes: { + ...createSelectArgTypes({ arrowIndicator: DeviationIndicator }), + ...createSelectArgTypes({ indicatorState: ValueState }), + ...createSelectArgTypes({ valueState: ValueState }), + ...createSelectArgTypes({ counterState: ValueState }) + }, + args: { + title: 'Title', + subTitle: 'Subtitle', + arrowIndicator: DeviationIndicator.Down, + indicatorState: ValueState.Success, + value: 'Value', + valueState: ValueState.Success, + unit: 'Unit', + target: 'Target', + deviation: 'Deviation', + showIndicator: true, + description: 'Description', + counter: 'Counter', + counterState: ValueState.Success, + currency: 'EUR' } }; @@ -38,25 +59,25 @@ const simpleDataSet = [ } ]; -export const defaultStory = () => ( +export const defaultStory = (props) => ( } > diff --git a/packages/main/src/components/AnalyticalTable/AnalyticalTable.stories.tsx b/packages/main/src/components/AnalyticalTable/AnalyticalTable.stories.tsx index 8ccc27a0f27..04c00cd033e 100644 --- a/packages/main/src/components/AnalyticalTable/AnalyticalTable.stories.tsx +++ b/packages/main/src/components/AnalyticalTable/AnalyticalTable.stories.tsx @@ -1,5 +1,3 @@ -import { action } from '@storybook/addon-actions'; -import { array, boolean, number, object, select, text } from '@storybook/addon-knobs'; import '@ui5/webcomponents-icons/dist/icons/delete'; import '@ui5/webcomponents-icons/dist/icons/edit'; import '@ui5/webcomponents-icons/dist/icons/settings'; @@ -16,6 +14,7 @@ import { FlexBoxJustifyContent } from '@ui5/webcomponents-react/lib/FlexBoxJusti import React from 'react'; import generateData from './demo/generateData'; import mdx from './AnalyticalTable.mdx'; +import { createSelectArgTypes } from '@shared/stories/createSelectArgTypes'; const columns = [ { @@ -83,7 +82,7 @@ const columns = [ const data = generateData(10_000); const dataTree = generateData(20, true); -export const defaultTable = () => { +export const defaultTable = (props) => { return (
{ } data={data} columns={columns} - loading={boolean('loading', false)} - busyIndicatorEnabled={boolean('busyIndicatorEnabled', true)} - alternateRowColor={boolean('alternateRowColor', false)} - sortable={boolean('sortable', true)} - filterable={boolean('filterable', true)} - visibleRows={number('visibleRows', 15)} - minRows={number('minRows', 5)} - groupable={boolean('groupable', true)} - selectionMode={select( - 'selectionMode', - TableSelectionMode, - TableSelectionMode.SINGLE_SELECT - )} - scaleWidthMode={select('scaleWidthMode', TableScaleWidthMode, TableScaleWidthMode.Default)} - onRowSelected={action('onRowSelected')} - onSort={action('onSort')} - onGroup={action('onGroup')} - onRowExpandChange={action('onRowExpandChange')} - groupBy={array('groupBy', [])} - rowHeight={number('rowHeight', 44)} - selectedRowIds={object('selectedRowIds', { 3: true })} - onColumnsReordered={action('onColumnsReordered')} - withRowHighlight={boolean('withRowHighlight', true)} - highlightField={text('highlightField', 'status')} - infiniteScroll={boolean('infiniteScroll', true)} - infiniteScrollThreshold={number('infiniteScrollThreshold', 20)} - onLoadMore={action('onLoadMore')} - selectionBehavior={select( - 'selectionBehavior', - TableSelectionBehavior, - TableSelectionBehavior.ROW - )} + loading={props.loading} + busyIndicatorEnabled={props.busyIndicatorEnabled} + alternateRowColor={props.alternateRowColor} + sortable={props.sortable} + filterable={props.filterable} + visibleRows={props.visibleRows} + minRows={props.minRows} + groupable={props.groupable} + selectionMode={props.selectionMode} + scaleWidthMode={props.scaleWidthMode} + onRowSelected={props.onRowSelected} + onSort={props.onSort} + onGroup={props.onGroup} + onRowExpandChange={props.onRowExpandChange} + groupBy={props.groupBy} + rowHeight={props.rowHeight} + selectedRowIds={props.selectedRowIds} + onColumnsReordered={props.onColumnsReordered} + withRowHighlight={props.withRowHighlight} + highlightField={props.highlightField} + infiniteScroll={props.infiniteScroll} + infiniteScrollThreshold={props.infiniteScrollThreshold} + onLoadMore={props.onLoadMore} + selectionBehavior={props.selectionBehavior} />
); @@ -134,30 +125,26 @@ export const defaultTable = () => { defaultTable.storyName = 'Default'; -export const treeTable = () => { +export const treeTable = (props) => { return ( ('selectionMode', TableSelectionMode, TableSelectionMode.MULTI_SELECT)} - onRowSelected={action('onRowSelected')} - onSort={action('onSort')} - onRowExpandChange={action('onRowExpandChange')} - subRowsKey={text('subRowsKey', 'subRows')} - selectedRowIds={object('selectedRowIds', { 3: true })} - selectionBehavior={select( - 'selectionBehavior', - TableSelectionBehavior, - TableSelectionBehavior.ROW - )} - isTreeTable={boolean('isTreeTable', true)} + loading={props.loading} + busyIndicatorEnabled={props.busyIndicatorEnabled} + sortable={props.sortable} + filterable={props.filterable} + visibleRows={props.visibleRows} + minRows={props.minRows} + selectionMode={props.selectionMode} + onRowSelected={props.onRowSelected} + onSort={props.onSort} + onRowExpandChange={props.onRowExpandChange} + subRowsKey={props.subRowsKey} + selectedRowIds={props.selectedRowIds} + selectionBehavior={props.selectionBehavior} + isTreeTable={props.isTreeTable} /> ); }; @@ -170,5 +157,30 @@ export default { docs: { page: mdx } + }, + argTypes: { + ...createSelectArgTypes({ scaleWidthMode: TableScaleWidthMode }), + ...createSelectArgTypes({ selectionMode: TableSelectionMode }), + ...createSelectArgTypes({ selectionBehavior: TableSelectionBehavior }) + }, + args: { + busyIndicatorEnabled: true, + sortable: true, + filterable: true, + visibleRows: 15, + minRows: 5, + groupable: true, + groupBy: [], + rowHeight: 44, + selectedRowIds: { 3: true }, + withRowHighlight: true, + highlightField: 'status', + infiniteScroll: true, + infiniteScrollThreshold: 20, + subRowsKey: 'subRows', + isTreeTable: true, + scaleWidthMode: TableScaleWidthMode.Default, + selectionMode: TableSelectionMode.SINGLE_SELECT, + selectionBehavior: TableSelectionBehavior.ROW } }; diff --git a/packages/main/src/components/Bar/demo.stories.tsx b/packages/main/src/components/Bar/demo.stories.tsx index 4855ed5d8b0..6bac4776aaf 100644 --- a/packages/main/src/components/Bar/demo.stories.tsx +++ b/packages/main/src/components/Bar/demo.stories.tsx @@ -1,13 +1,13 @@ -import { select } from '@storybook/addon-knobs'; import { Bar } from '@ui5/webcomponents-react/lib/Bar'; import { BarDesign } from '@ui5/webcomponents-react/lib/BarDesign'; import { Label } from '@ui5/webcomponents-react/lib/Label'; import React from 'react'; +import { createSelectArgTypes } from '@shared/stories/createSelectArgTypes'; -export const defaultStory = () => { +export const defaultStory = (props) => { return ( Content Left} contentMiddle={} contentRight={} @@ -18,5 +18,11 @@ defaultStory.storyName = 'Default'; export default { title: 'Components / Bar', - component: Bar + component: Bar, + argTypes: { + ...createSelectArgTypes({ design: BarDesign }) + }, + args: { + design: BarDesign.Auto + } }; diff --git a/packages/main/src/components/Breadcrumbs/demo.stories.tsx b/packages/main/src/components/Breadcrumbs/demo.stories.tsx index 304eb19bd2e..0f0487e4bd7 100644 --- a/packages/main/src/components/Breadcrumbs/demo.stories.tsx +++ b/packages/main/src/components/Breadcrumbs/demo.stories.tsx @@ -1,12 +1,12 @@ -import { select, text } from '@storybook/addon-knobs'; import { Breadcrumbs } from '@ui5/webcomponents-react/lib/Breadcrumbs'; import { BreadcrumbsSeparatorStyle } from '@ui5/webcomponents-react/lib/BreadcrumbsSeparatorStyle'; import { Link } from '@ui5/webcomponents-react/lib/Link'; import React from 'react'; +import { createSelectArgTypes } from '@shared/stories/createSelectArgTypes'; -export const defaultStory = () => { +export const defaultStory = (props) => { return ( - + Products Hardware Notebooks @@ -15,12 +15,9 @@ export const defaultStory = () => { ); }; defaultStory.storyName = 'Default'; -export const withCurrentLocation = () => { +export const withCurrentLocation = (props) => { return ( - + Products Hardware Notebooks @@ -35,5 +32,12 @@ export default { component: Breadcrumbs, parameters: { subcomponents: { Link } + }, + argTypes: { + ...createSelectArgTypes({ separatorStyle: BreadcrumbsSeparatorStyle }) + }, + args: { + separatorStyle: BreadcrumbsSeparatorStyle.Slash, + currentLocationText: 'Super Slim Notebook 13 inch' } }; diff --git a/packages/main/src/components/FilterBar/demo.stories.tsx b/packages/main/src/components/FilterBar/demo.stories.tsx index 0a75dcae677..f49b23f43ce 100644 --- a/packages/main/src/components/FilterBar/demo.stories.tsx +++ b/packages/main/src/components/FilterBar/demo.stories.tsx @@ -1,5 +1,3 @@ -import { action } from '@storybook/addon-actions'; -import { boolean, number, text } from '@storybook/addon-knobs'; import { DatePicker } from '@ui5/webcomponents-react/lib/DatePicker'; import { FilterBar } from '@ui5/webcomponents-react/lib/FilterBar'; import { FilterGroupItem } from '@ui5/webcomponents-react/lib/FilterGroupItem'; @@ -17,37 +15,37 @@ const variantItems = [ { label: 'Variant 2', key: '2' } ]; -export const renderDefaultStory = () => { +export const renderDefaultStory = (props) => { return ( } variants={} - useToolbar={boolean('useToolbar', true)} - filterBarExpanded={boolean('filterBarExpanded', true)} - loading={boolean('loading', false)} - considerGroupName={boolean('considerGroupName', false)} - filterContainerWidth={text('auto', undefined)} - activeFiltersCount={number('activeFiltersCount', undefined)} - showClearOnFB={boolean('showClearOnFB', false)} - showRestoreOnFB={boolean('showRestoreOnFB', false)} - showGo={boolean('showGo', false)} - showGoOnFB={boolean('showGoOnFB', false)} - showFilterConfiguration={boolean('showFilterConfiguration', false)} - showSearchOnFiltersDialog={boolean('showSearchOnFiltersDialog', false)} - showClearButton={boolean('showClearButton', false)} - showRestoreButton={boolean('showRestoreButton', false)} - onToggleFilters={action('onToggleFilters')} - onFiltersDialogOpen={action('onFiltersDialogOpen')} - onFiltersDialogClose={action('onFiltersDialogClose')} - onFiltersDialogSave={action('onFiltersDialogSave')} - onFiltersDialogClear={action('onFiltersDialogClear')} - onClear={action('onClear')} - onFiltersDialogSelectionChange={action('onFiltersDialogSelectionChange')} - onFiltersDialogSearch={action('onFiltersDialogSearch')} - onGo={action('onGo')} - onRestore={action('onRestore')} + useToolbar={props.useToolbar} + filterBarExpanded={props.filterBarExpanded} + loading={props.loading} + considerGroupName={props.considerGroupName} + filterContainerWidth={props.auto} + activeFiltersCount={props.activeFiltersCount} + showClearOnFB={props.showClearOnFB} + showRestoreOnFB={props.showRestoreOnFB} + showGo={props.showGo} + showGoOnFB={props.showGoOnFB} + showFilterConfiguration={props.showFilterConfiguration} + showSearchOnFiltersDialog={props.showSearchOnFiltersDialog} + showClearButton={props.showClearButton} + showRestoreButton={props.showRestoreButton} + onToggleFilters={props.onToggleFilters} + onFiltersDialogOpen={props.onFiltersDialogOpen} + onFiltersDialogClose={props.onFiltersDialogClose} + onFiltersDialogSave={props.onFiltersDialogSave} + onFiltersDialogClear={props.onFiltersDialogClear} + onClear={props.onClear} + onFiltersDialogSelectionChange={props.onFiltersDialogSelectionChange} + onFiltersDialogSearch={props.onFiltersDialogSearch} + onGo={props.onGo} + onRestore={props.onRestore} > - + - + - + @@ -71,52 +69,43 @@ export const renderDefaultStory = () => { }; renderDefaultStory.storyName = 'Default'; -export const renderStoryWithFiltersDialog = () => { +export const renderStoryWithFiltersDialog = (props) => { return ( } variants={} - useToolbar={boolean('useToolbar', true)} - filterBarExpanded={boolean('filterBarExpanded', true)} - loading={boolean('loading', false)} - considerGroupName={boolean('considerGroupName', true)} - filterContainerWidth={text('filterContainerWidth', '13rem')} - activeFiltersCount={number('activeFiltersCount', 0)} - showClearOnFB={boolean('showClearOnFB', true)} - showRestoreOnFB={boolean('showRestoreOnFB', true)} - showGo={boolean('showGo', true)} - showGoOnFB={boolean('showGoOnFB', true)} - showFilterConfiguration={boolean('showFilterConfiguration', true)} - showSearchOnFiltersDialog={boolean('showSearchOnFiltersDialog', true)} - showClearButton={boolean('showClearButton', true)} - showRestoreButton={boolean('showRestoreButton', true)} - onToggleFilters={action('onToggleFilters')} - onFiltersDialogOpen={action('onFiltersDialogOpen')} - onFiltersDialogClose={action('onFiltersDialogClose')} - onFiltersDialogSave={action('onFiltersDialogSave')} - onFiltersDialogClear={action('onFiltersDialogClear')} - onClear={action('onClear')} - onFiltersDialogSelectionChange={action('onFiltersDialogSelectionChange')} - onFiltersDialogSearch={action('onFiltersDialogSearch')} - onGo={action('onGo')} - onRestore={action('onRestore')} + useToolbar={props.useToolbar} + filterBarExpanded={props.filterBarExpanded} + loading={props.loading} + considerGroupName={props.considerGroupName} + filterContainerWidth={props.filterContainerWidth} + activeFiltersCount={props.activeFiltersCount} + showClearOnFB={props.showClearOnFB} + showRestoreOnFB={props.showRestoreOnFB} + showGo={props.showGo} + showGoOnFB={props.showGoOnFB} + showFilterConfiguration={props.showFilterConfiguration} + showSearchOnFiltersDialog={props.showSearchOnFiltersDialog} + showClearButton={props.showClearButton} + showRestoreButton={props.showRestoreButton} + onToggleFilters={props.onToggleFilters} + onFiltersDialogOpen={props.onFiltersDialogOpen} + onFiltersDialogClose={props.onFiltersDialogClose} + onFiltersDialogSave={props.onFiltersDialogSave} + onFiltersDialogClear={props.onFiltersDialogClear} + onClear={props.onClear} + onFiltersDialogSelectionChange={props.onFiltersDialogSelectionChange} + onFiltersDialogSearch={props.onFiltersDialogSearch} + onGo={props.onGo} + onRestore={props.onRestore} > - + - + - + - + - + @@ -158,11 +140,7 @@ export const renderStoryWithFiltersDialog = () => { - + @@ -170,7 +148,7 @@ export const renderStoryWithFiltersDialog = () => { - + @@ -183,5 +161,24 @@ export default { component: FilterBar, parameters: { subcomponents: { FilterGroupItem } + }, + args: { + useToolbar: true, + filterBarExpanded: true, + considerGroupName: true, + filterContainerWidth: '13rem', + activeFiltersCount: 0, + showClearOnFB: true, + showRestoreOnFB: true, + showGo: true, + showGoOnFB: true, + showFilterConfiguration: true, + showSearchOnFiltersDialog: true, + showClearButton: true, + showRestoreButton: true, + visibleInFilterBar: true, + groupName: 'Custom Group', + visible: true, + required: true } }; diff --git a/packages/main/src/components/FlexBox/demo.stories.tsx b/packages/main/src/components/FlexBox/demo.stories.tsx index 3d0979903d5..93242d38951 100644 --- a/packages/main/src/components/FlexBox/demo.stories.tsx +++ b/packages/main/src/components/FlexBox/demo.stories.tsx @@ -1,4 +1,3 @@ -import { boolean, select, text } from '@storybook/addon-knobs/'; import { FlexBox } from '@ui5/webcomponents-react/lib/FlexBox'; import { FlexBoxAlignItems } from '@ui5/webcomponents-react/lib/FlexBoxAlignItems'; import { FlexBoxDirection } from '@ui5/webcomponents-react/lib/FlexBoxDirection'; @@ -6,14 +5,15 @@ import { FlexBoxJustifyContent } from '@ui5/webcomponents-react/lib/FlexBoxJusti import { FlexBoxWrap } from '@ui5/webcomponents-react/lib/FlexBoxWrap'; import { Label } from '@ui5/webcomponents-react/lib/Label'; import React from 'react'; +import { createSelectArgTypes } from '@shared/stories/createSelectArgTypes'; -export const defaultStory = () => ( +export const defaultStory = (props) => ( @@ -26,5 +26,17 @@ defaultStory.storyName = 'Default'; export default { title: 'Components / FlexBox', - component: FlexBox + component: FlexBox, + argTypes: { + ...createSelectArgTypes({ justifyContent: FlexBoxJustifyContent }), + ...createSelectArgTypes({ alignItems: FlexBoxAlignItems }), + ...createSelectArgTypes({ direction: FlexBoxDirection }), + ...createSelectArgTypes({ wrap: FlexBoxWrap }) + }, + args: { + justifyContent: FlexBoxJustifyContent.Start, + alignItems: FlexBoxAlignItems.Stretch, + direction: FlexBoxDirection.Row, + wrap: FlexBoxWrap.NoWrap + } }; diff --git a/packages/main/src/components/Grid/Grid.stories.tsx b/packages/main/src/components/Grid/Grid.stories.tsx index 4f49614e607..143e8a6d71d 100644 --- a/packages/main/src/components/Grid/Grid.stories.tsx +++ b/packages/main/src/components/Grid/Grid.stories.tsx @@ -1,14 +1,13 @@ -import { text } from '@storybook/addon-knobs'; import { Grid } from '@ui5/webcomponents-react/lib/Grid'; import React from 'react'; -export const defaultStory = () => { +export const defaultStory = (props) => { return (
{`Div 1 with prop: data-layout-span="XL8 L8 M8 S12" and data-layout-indent="XL1 L1 M1 S0"`} @@ -24,5 +23,11 @@ export const defaultStory = () => { export default { title: 'Components / Grid', - component: Grid + component: Grid, + args: { + defaultSpan: 'XL3 L3 M6 S12', + defaultIndent: 'XL0 L0 M0 S0', + vSpacing: '1rem', + hSpacing: '1rem' + } }; diff --git a/packages/main/src/components/Loader/demo.stories.tsx b/packages/main/src/components/Loader/demo.stories.tsx index ce7ba09b61a..8cba39d89e9 100644 --- a/packages/main/src/components/Loader/demo.stories.tsx +++ b/packages/main/src/components/Loader/demo.stories.tsx @@ -1,18 +1,20 @@ -import { number, select, text } from '@storybook/addon-knobs'; import { Loader } from '@ui5/webcomponents-react/lib/Loader'; import { LoaderType } from '@ui5/webcomponents-react/lib/LoaderType'; import React from 'react'; +import { createSelectArgTypes } from '@shared/stories/createSelectArgTypes'; -export const renderLoader = () => ( - -); +export const renderLoader = (props) => ; renderLoader.storyName = 'Default'; export default { title: 'Components / Loader', - component: Loader + component: Loader, + argTypes: { + ...createSelectArgTypes({ type: LoaderType }) + }, + args: { + type: LoaderType.Indeterminate, + progress: '40%', + delay: 1000 + } }; diff --git a/packages/main/src/components/MessageBox/demo.stories.tsx b/packages/main/src/components/MessageBox/demo.stories.tsx index 026ee9feddc..62f0407fc41 100644 --- a/packages/main/src/components/MessageBox/demo.stories.tsx +++ b/packages/main/src/components/MessageBox/demo.stories.tsx @@ -1,16 +1,10 @@ -import { action } from '@storybook/addon-actions'; -import { boolean, select, text } from '@storybook/addon-knobs'; import { MessageBox } from '@ui5/webcomponents-react/lib/MessageBox'; import { MessageBoxTypes } from '@ui5/webcomponents-react/lib/MessageBoxTypes'; import React from 'react'; +import { createSelectArgTypes } from '@shared/stories/createSelectArgTypes'; -export const defaultStory = () => ( - +export const defaultStory = (props) => ( + Message Box Content ); @@ -19,5 +13,12 @@ defaultStory.storyName = 'Default'; export default { title: 'Components / MessageBox', - component: MessageBox + component: MessageBox, + argTypes: { + ...createSelectArgTypes({ type: MessageBoxTypes }) + }, + args: { + open: true, + type: MessageBoxTypes.CONFIRM + } }; diff --git a/packages/main/src/components/Notification/demo.stories.tsx b/packages/main/src/components/Notification/demo.stories.tsx index 51a979eb20a..bf88ebd3a93 100644 --- a/packages/main/src/components/Notification/demo.stories.tsx +++ b/packages/main/src/components/Notification/demo.stories.tsx @@ -1,5 +1,3 @@ -import { action } from '@storybook/addon-actions'; -import { boolean, select, text } from '@storybook/addon-knobs'; import { Avatar } from '@ui5/webcomponents-react/lib/Avatar'; import { AvatarShape } from '@ui5/webcomponents-react/lib/AvatarShape'; import { AvatarSize } from '@ui5/webcomponents-react/lib/AvatarSize'; @@ -7,33 +5,36 @@ import { Button } from '@ui5/webcomponents-react/lib/Button'; import { Notification } from '@ui5/webcomponents-react/lib/Notification'; import { Priority } from '@ui5/webcomponents-react/lib/Priority'; import React from 'react'; +import { createSelectArgTypes } from '@shared/stories/createSelectArgTypes'; const sampleAvatar = ''; -const ActionButtons = [ - , - -]; +const ActionButtons = (props) => { + return [ + , + + ]; +}; -export const defaultStory = () => ( +export const defaultStory = (props) => ( } - priority={select('priority', Priority, Priority.None)} - onClick={action('Notification clicked')} - noShowMoreButton={boolean('noShowMoreButton', false)} - truncate={boolean('truncate', true)} - noCloseButton={boolean('noCloseButton', false)} - onClose={action('Closed')} + priority={props.priority} + onClick={props.onNotificationsClick} + noShowMoreButton={props.noShowMoreButton} + truncate={props.truncate} + noCloseButton={props.noCloseButton} + onClose={props.onClose} /> ); @@ -41,5 +42,16 @@ defaultStory.storyName = 'Default'; export default { title: 'Components / Notification', - component: Notification + component: Notification, + argTypes: { + ...createSelectArgTypes({ priority: Priority }) + }, + args: { + description: 'Short description', + title: 'Notification Title', + authorName: 'Author', + priority: Priority.None, + truncate: true, + dateTime: 'DateTime' + } }; diff --git a/packages/main/src/components/ObjectStatus/demo.stories.tsx b/packages/main/src/components/ObjectStatus/demo.stories.tsx index 0f014d3bea6..19f8e9243e5 100644 --- a/packages/main/src/components/ObjectStatus/demo.stories.tsx +++ b/packages/main/src/components/ObjectStatus/demo.stories.tsx @@ -1,38 +1,38 @@ -import { boolean, select } from '@storybook/addon-knobs'; import '@ui5/webcomponents-icons/dist/icons/sys-cancel'; import { Icon } from '@ui5/webcomponents-react/lib/Icon'; import { ObjectStatus } from '@ui5/webcomponents-react/lib/ObjectStatus'; import { ValueState } from '@ui5/webcomponents-react/lib/ValueState'; import React from 'react'; +import { createSelectArgTypes } from '@shared/stories/createSelectArgTypes'; -export const onlyText = () => ( - Object Status -); +export const onlyText = (props) => Object Status; onlyText.storyName = 'with Text only'; -export const withIcon = () => ( - }> +export const withIcon = (props) => ( + }> Object Status ); withIcon.storyName = 'with Text and Icon'; -export const withDefaultIcon = () => ( - +export const withDefaultIcon = (props) => ( + Default Icon Status ); withDefaultIcon.storyName = 'with Default Icon'; -export const withIconOnly = () => ( - } state={select('state', ValueState, ValueState.Success)} /> -); +export const withIconOnly = (props) => } state={props.state} />; withIconOnly.storyName = 'with Icon only'; export default { title: 'Components / ObjectStatus', - component: ObjectStatus + component: ObjectStatus, + argTypes: { + ...createSelectArgTypes({ state: ValueState }) + }, + args: { + state: ValueState.Success, + showDefaultIcon: true + } }; diff --git a/packages/main/src/components/Page/demo.stories.tsx b/packages/main/src/components/Page/demo.stories.tsx index e5601e6dfd1..22b3e3060ad 100644 --- a/packages/main/src/components/Page/demo.stories.tsx +++ b/packages/main/src/components/Page/demo.stories.tsx @@ -1,23 +1,22 @@ -import { action } from '@storybook/addon-actions'; -import { boolean, select, text } from '@storybook/addon-knobs'; import { Bar } from '@ui5/webcomponents-react/lib/Bar'; import { Button } from '@ui5/webcomponents-react/lib/Button'; import { Label } from '@ui5/webcomponents-react/lib/Label'; import { Page } from '@ui5/webcomponents-react/lib/Page'; import { PageBackgroundDesign } from '@ui5/webcomponents-react/lib/PageBackgroundDesign'; import React from 'react'; +import { createSelectArgTypes } from '@shared/stories/createSelectArgTypes'; -export const renderPage = () => ( +export const renderPage = (props) => (
Button} />} customHeader={null} - onNavButtonPress={action('onNavButtonPress')} + onNavButtonPress={props.onNavButtonPress} > @@ -27,5 +26,15 @@ renderPage.storyName = 'Default'; export default { title: 'Components / Page', - component: Page + component: Page, + argTypes: { + ...createSelectArgTypes({ backgroundDesign: PageBackgroundDesign }) + }, + args: { + title: 'Page Demo', + showFooter: true, + showHeader: true, + showBackButton: true, + backgroundDesign: PageBackgroundDesign.Standard + } }; diff --git a/packages/main/src/components/ProgressIndicator/demo.stories.tsx b/packages/main/src/components/ProgressIndicator/demo.stories.tsx index 30b776cb5ee..6a57ee40504 100644 --- a/packages/main/src/components/ProgressIndicator/demo.stories.tsx +++ b/packages/main/src/components/ProgressIndicator/demo.stories.tsx @@ -1,17 +1,17 @@ -import { number, select, text } from '@storybook/addon-knobs'; import { ProgressIndicator } from '@ui5/webcomponents-react/lib/ProgressIndicator'; import { ValueState } from '@ui5/webcomponents-react/lib/ValueState'; import React from 'react'; +import { createSelectArgTypes } from '@shared/stories/createSelectArgTypes'; -export const renderStory = () => { +export const renderStory = (props) => { return (
@@ -25,5 +25,13 @@ renderStory.storyName = 'Default'; export default { title: 'Components / ProgressIndicator', - component: ProgressIndicator + component: ProgressIndicator, + argTypes: { + ...createSelectArgTypes({ state: ValueState }) + }, + args: { + percentValue: 5, + displayValue: '5%', + state: ValueState.None + } }; diff --git a/packages/main/src/components/SideNavigation/demo.stories.tsx b/packages/main/src/components/SideNavigation/demo.stories.tsx index 95b6da2467c..1e403bb67ca 100644 --- a/packages/main/src/components/SideNavigation/demo.stories.tsx +++ b/packages/main/src/components/SideNavigation/demo.stories.tsx @@ -1,5 +1,3 @@ -import { action } from '@storybook/addon-actions'; -import { boolean, select, text } from '@storybook/addon-knobs'; import '@ui5/webcomponents-icons/dist/icons/add-product'; import '@ui5/webcomponents-icons/dist/icons/calendar'; import '@ui5/webcomponents-icons/dist/icons/chain-link'; @@ -11,13 +9,14 @@ import { SideNavigation } from '@ui5/webcomponents-react/lib/SideNavigation'; import { SideNavigationListItem } from '@ui5/webcomponents-react/lib/SideNavigationListItem'; import { SideNavigationOpenState } from '@ui5/webcomponents-react/lib/SideNavigationOpenState'; import React from 'react'; +import { createSelectArgTypes } from '@shared/stories/createSelectArgTypes'; -export const defaultStory = () => ( +export const defaultStory = (props) => ( , @@ -48,5 +47,12 @@ export default { component: SideNavigation, parameters: { subcomponents: { SideNavigationListItem } + }, + argTypes: { + ...createSelectArgTypes({ openState: SideNavigationOpenState }) + }, + args: { + openState: SideNavigationOpenState.Expanded, + selectedId: 'sales-leads' } }; diff --git a/packages/main/src/components/Spinner/demo.stories.tsx b/packages/main/src/components/Spinner/demo.stories.tsx index 59183532d4d..fa65d1c59df 100644 --- a/packages/main/src/components/Spinner/demo.stories.tsx +++ b/packages/main/src/components/Spinner/demo.stories.tsx @@ -1,7 +1,7 @@ -import { number, select } from '@storybook/addon-knobs'; import { Size } from '@ui5/webcomponents-react/lib/Size'; import { Spinner } from '@ui5/webcomponents-react/lib/Spinner'; import React, { useMemo } from 'react'; +import { createSelectArgTypes } from '@shared/stories/createSelectArgTypes'; let spinnerKey = 0; @@ -10,16 +10,23 @@ const Demo = (props) => { const spinner = useMemo(() => { spinnerKey++; - return ; + return ; }, [delay]); return spinner; }; -export const renderSpinner = () => ; +export const renderSpinner = (props) => ; renderSpinner.storyName = 'Default'; export default { title: 'Components / Spinner', - component: Spinner + component: Spinner, + argTypes: { + ...createSelectArgTypes({ size: Size }) + }, + args: { + size: Size.Medium, + delay: 2000 + } }; diff --git a/packages/main/src/components/Text/demo.stories.tsx b/packages/main/src/components/Text/demo.stories.tsx index bce58c2b5c9..d173f8ae9e7 100644 --- a/packages/main/src/components/Text/demo.stories.tsx +++ b/packages/main/src/components/Text/demo.stories.tsx @@ -1,10 +1,9 @@ -import { boolean, text } from '@storybook/addon-knobs'; import { Text } from '@ui5/webcomponents-react/lib/Text'; import React from 'react'; -export const renderStory = () => { +export const renderStory = (props) => { return ( - + Lorem ipsum dolor st amet, consetetur sadipscing elitr, sed diam nonumy eirmod tempor invidunt ut labore et dolore magna aliquyam erat, sed diam voluptua. {'\n\n'} @@ -19,5 +18,8 @@ renderStory.storyName = 'Default'; export default { title: 'Components / Text', - component: Text + component: Text, + args: { + wrapping: true + } }; diff --git a/packages/main/src/components/VariantManagement/demo.stories.tsx b/packages/main/src/components/VariantManagement/demo.stories.tsx index e874d34a1ae..d7f6fdfe05d 100644 --- a/packages/main/src/components/VariantManagement/demo.stories.tsx +++ b/packages/main/src/components/VariantManagement/demo.stories.tsx @@ -1,29 +1,38 @@ -import { action } from '@storybook/addon-actions'; -import { boolean, select, text } from '@storybook/addon-knobs'; import { PlacementType } from '@ui5/webcomponents-react/lib/PlacementType'; import { TitleLevel } from '@ui5/webcomponents-react/lib/TitleLevel'; import { VariantManagement } from '@ui5/webcomponents-react/lib/VariantManagement'; import React from 'react'; +import { createSelectArgTypes } from '@shared/stories/createSelectArgTypes'; const variantItems = [ { label: 'Variant 1', key: '1' }, { label: 'Variant 2', key: '2' } ]; -export const renderStory = () => ( +export const renderStory = (props) => ( ); renderStory.storyName = 'Default'; export default { title: 'Components / VariantManagement', - component: VariantManagement + component: VariantManagement, + argTypes: { + ...createSelectArgTypes({ placement: PlacementType }), + ...createSelectArgTypes({ level: TitleLevel }) + }, + args: { + closeOnItemSelect: true, + selectedKey: '2', + placement: PlacementType.Bottom, + level: TitleLevel.H4 + } };