// Copyright 2020-2021 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, select, text } from '@storybook/addon-knobs'; import type { Props } from './AvatarPopup'; import { AvatarPopup } from './AvatarPopup'; import type { AvatarColorType } from '../types/Colors'; import { AvatarColors } from '../types/Colors'; import { setupI18n } from '../util/setupI18n'; import enMessages from '../../_locales/en/messages.json'; import { StorybookThemeContext } from '../../.storybook/StorybookThemeContext'; import { getFakeBadge } from '../test-both/helpers/getFakeBadge'; const i18n = setupI18n('en', enMessages); const colorMap: Record = AvatarColors.reduce( (m, color) => ({ ...m, [color]: color, }), {} ); const conversationTypeMap: Record = { direct: 'direct', group: 'group', }; const useProps = (overrideProps: Partial = {}): Props => ({ acceptedMessageRequest: true, avatarPath: text('avatarPath', overrideProps.avatarPath || ''), badge: overrideProps.badge, color: select('color', colorMap, overrideProps.color || AvatarColors[0]), conversationType: select( 'conversationType', conversationTypeMap, overrideProps.conversationType || 'direct' ), hasPendingUpdate: Boolean(overrideProps.hasPendingUpdate), i18n, isMe: true, name: text('name', overrideProps.name || ''), noteToSelf: boolean('noteToSelf', overrideProps.noteToSelf || false), onEditProfile: action('onEditProfile'), onViewArchive: action('onViewArchive'), onViewPreferences: action('onViewPreferences'), phoneNumber: text('phoneNumber', overrideProps.phoneNumber || ''), profileName: text('profileName', overrideProps.profileName || ''), sharedGroupNames: [], size: 80, startUpdate: action('startUpdate'), style: {}, theme: React.useContext(StorybookThemeContext), title: text('title', overrideProps.title || ''), }); const stories = storiesOf('Components/Avatar Popup', module); stories.add('Avatar Only', () => { const props = useProps(); return ; }); stories.add('Has badge', () => { const props = useProps({ badge: getFakeBadge(), title: 'Janet Yellen', }); return ; }); stories.add('Title', () => { const props = useProps({ title: 'My Great Title', }); return ; }); stories.add('Profile Name', () => { const props = useProps({ profileName: 'Sam Neill', }); return ; }); stories.add('Phone Number', () => { const props = useProps({ profileName: 'Sam Neill', phoneNumber: '(555) 867-5309', }); return ; }); stories.add('Update Available', () => { const props = useProps({ hasPendingUpdate: true, }); return ; });