// Copyright 2020 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import * as React from 'react'; import { select, text } from '@storybook/addon-knobs'; import type { Props } from './Spinner'; import { Spinner, SpinnerDirections, SpinnerSvgSizes } from './Spinner'; export default { title: 'Components/Spinner', }; const createProps = (overrideProps: Partial = {}): Props => ({ size: text('size', overrideProps.size || ''), svgSize: select( 'svgSize', SpinnerSvgSizes.reduce((m, s) => ({ ...m, [s]: s }), {}), overrideProps.svgSize || 'normal' ), direction: select( 'direction', SpinnerDirections.reduce((d, s) => ({ ...d, [s]: s }), {}), overrideProps.direction ), }); export const Normal = (): JSX.Element => { const props = createProps(); return ; }; export const SvgSizes = (): JSX.Element => { const props = createProps(); return ( <> {SpinnerSvgSizes.map(svgSize => ( ))} ); }; SvgSizes.story = { name: 'SVG Sizes', }; export const Directions = (): JSX.Element => { const props = createProps(); return ( <> {SpinnerDirections.map(direction => ( ))} ); };