// Copyright 2020 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import * as React from 'react'; import { action } from '@storybook/addon-actions'; import type { Meta } from '@storybook/react'; import type { Props } from './ContactDetail'; import { ContactDetail } from './ContactDetail'; import { AddressType, ContactFormType } from '../../types/EmbeddedContact'; import { setupI18n } from '../../util/setupI18n'; import enMessages from '../../../_locales/en/messages.json'; import { IMAGE_GIF } from '../../types/MIME'; import { fakeAttachment } from '../../test-both/helpers/fakeAttachment'; const i18n = setupI18n('en', enMessages); export default { title: 'Components/Conversation/ContactDetail', } satisfies Meta; const createProps = (overrideProps: Partial = {}): Props => ({ contact: overrideProps.contact || {}, hasSignalAccount: overrideProps.hasSignalAccount || false, i18n, onSendMessage: action('onSendMessage'), }); const fullContact = { address: [ { type: AddressType.HOME, street: '555 Main St.', city: 'Boston', region: 'MA', postcode: '33333', pobox: '2323-444', country: 'US', neighborhood: 'Garden Place', }, { type: AddressType.WORK, street: '333 Another St.', city: 'Boston', region: 'MA', postcode: '33344', pobox: '2424-555', country: 'US', neighborhood: 'Factory Place', }, { type: AddressType.CUSTOM, street: '111 Dream St.', city: 'Miami', region: 'FL', postcode: '44232', pobox: '111-333', country: 'US', neighborhood: 'BeachVille', label: 'vacation', }, { type: AddressType.CUSTOM, street: '333 Fake St.', city: 'Boston', region: 'MA', postcode: '33345', pobox: '123-444', country: 'US', neighborhood: 'Downtown', }, ], avatar: { avatar: fakeAttachment({ path: '/fixtures/giphy-GVNvOUpeYmI7e.gif', contentType: IMAGE_GIF, }), isProfile: true, }, email: [ { value: 'jerjor@fakemail.com', type: ContactFormType.HOME, }, { value: 'jerry.jordan@fakeco.com', type: ContactFormType.WORK, }, { value: 'jj@privatething.net', type: ContactFormType.CUSTOM, label: 'private', }, { value: 'jordan@another.net', type: ContactFormType.CUSTOM, }, ], name: { givenName: 'Jerry', familyName: 'Jordan', prefix: 'Dr.', suffix: 'Jr.', middleName: 'James', displayName: 'Jerry Jordan', }, number: [ { value: '555-444-2323', type: ContactFormType.HOME, }, { value: '555-444-3232', type: ContactFormType.WORK, }, { value: '555-666-3232', type: ContactFormType.MOBILE, }, { value: '333-666-3232', type: ContactFormType.CUSTOM, label: 'special', }, { value: '333-777-3232', type: ContactFormType.CUSTOM, }, ], }; export function FullyFilledOut(): JSX.Element { const props = createProps({ contact: fullContact, hasSignalAccount: true, }); return ; } export function OnlyEmail(): JSX.Element { const props = createProps({ contact: { email: [ { value: 'jerjor@fakemail.com', type: ContactFormType.HOME, }, ], }, hasSignalAccount: true, }); return ; } export function GivenName(): JSX.Element { const props = createProps({ contact: { name: { givenName: 'Jerry', }, }, hasSignalAccount: true, }); return ; } export function Organization(): JSX.Element { const props = createProps({ contact: { organization: 'Company 5', }, hasSignalAccount: true, }); return ; } export function GivenFamilyName(): JSX.Element { const props = createProps({ contact: { name: { givenName: 'Jerry', familyName: 'FamilyName', }, }, hasSignalAccount: true, }); return ; } export function FamilyName(): JSX.Element { const props = createProps({ contact: { name: { familyName: 'FamilyName', }, }, hasSignalAccount: true, }); return ; } export function LoadingAvatar(): JSX.Element { const props = createProps({ contact: { avatar: { avatar: fakeAttachment({ contentType: IMAGE_GIF, pending: true, }), isProfile: true, }, }, hasSignalAccount: true, }); return ; } export function EmptyWithAccount(): JSX.Element { const props = createProps({ hasSignalAccount: true, }); return ; } export function EmptyWithoutAccount(): JSX.Element { const props = createProps({ hasSignalAccount: false, }); return ; }