// Copyright 2020 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import * as React from 'react'; import { action } from '@storybook/addon-actions'; import { boolean, text } from '@storybook/addon-knobs'; import { ConversationDetailsIcon, IconType } from './ConversationDetailsIcon'; import type { Props } from './PanelRow'; import { PanelRow } from './PanelRow'; export default { title: 'Components/Conversation/ConversationDetails/PanelRow', }; const createProps = (overrideProps: Partial = {}): Props => ({ icon: boolean('with icon', overrideProps.icon !== undefined) ? ( ) : null, label: text('label', (overrideProps.label as string) || ''), info: text('info', overrideProps.info || ''), right: text('right', (overrideProps.right as string) || ''), actions: boolean('with action', overrideProps.actions !== undefined) ? ( ) : null, onClick: boolean('clickable', overrideProps.onClick !== undefined) ? overrideProps.onClick || action('onClick') : undefined, }); export function Basic(): JSX.Element { const props = createProps({ label: 'this is a panel row', }); return ; } export function Simple(): JSX.Element { const props = createProps({ label: 'this is a panel row', icon: 'with icon', right: 'side text', }); return ; } export function Full(): JSX.Element { const props = createProps({ label: 'this is a panel row', icon: 'with icon', info: 'this is some info that exists below the main label', right: 'side text', actions: 'with action', }); return ; } export function Button(): JSX.Element { const props = createProps({ label: 'this is a panel row', icon: 'with icon', right: 'side text', onClick: action('onClick'), }); return ; }