// Copyright 2020 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import * as React from 'react'; import { storiesOf } from '@storybook/react'; import { action } from '@storybook/addon-actions'; import { boolean, text } from '@storybook/addon-knobs'; import { setupI18n } from '../../util/setupI18n'; import enMessages from '../../../_locales/en/messages.json'; import type { ContactType, Props } from './SafetyNumberNotification'; import { SafetyNumberNotification } from './SafetyNumberNotification'; const i18n = setupI18n('en', enMessages); const createContact = (props: Partial): ContactType => ({ id: '', title: text('contact title', props.title || ''), }); const createProps = (overrideProps: Partial = {}): Props => ({ i18n, contact: overrideProps.contact || ({} as ContactType), isGroup: boolean('isGroup', overrideProps.isGroup || false), showIdentity: action('showIdentity'), }); const stories = storiesOf( 'Components/Conversation/SafetyNumberNotification', module ); stories.add('Group Conversation', () => { const props = createProps({ isGroup: true, contact: createContact({ title: 'Mr. Fire', }), }); return ; }); stories.add('Direct Conversation', () => { const props = createProps({ isGroup: false, contact: createContact({ title: 'Mr. Fire', }), }); return ; }); stories.add('Long name in group', () => { const props = createProps({ isGroup: true, contact: createContact({ title: '🐈‍⬛🍕🎂'.repeat(50), }), }); return ; });