// 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, 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, noteToSelf: boolean('noteToSelf', overrideProps.noteToSelf || false), onEditProfile: action('onEditProfile'), onStartUpdate: action('startUpdate'), phoneNumber: text('phoneNumber', overrideProps.phoneNumber || ''), profileName: text('profileName', overrideProps.profileName || ''), sharedGroupNames: [], style: {}, theme: React.useContext(StorybookThemeContext), title: text('title', overrideProps.title || ''), }); export default { title: 'Components/Avatar Popup', }; export function AvatarOnly(): JSX.Element { const props = useProps(); return ; } export function HasBadge(): JSX.Element { const props = useProps({ badge: getFakeBadge(), title: 'Janet Yellen', }); return ; } HasBadge.story = { name: 'Has badge', }; export function Title(): JSX.Element { const props = useProps({ title: 'My Great Title', }); return ; } export function ProfileName(): JSX.Element { const props = useProps({ profileName: 'Sam Neill', }); return ; } export function PhoneNumber(): JSX.Element { const props = useProps({ profileName: 'Sam Neill', phoneNumber: '(555) 867-5309', }); return ; } export function UpdateAvailable(): JSX.Element { const props = useProps({ hasPendingUpdate: true, }); return ; }