### With all data types ```jsx const contact = { avatar: { avatar: { path: util.gifObjectUrl, }, }, name: { displayName: 'Someone Somewhere', }, number: [ { value: '(202) 555-0000', type: 3, }, { value: '(202) 555-0001', type: 4, label: 'My favorite custom label', }, ], email: [ { value: 'someone@somewhere.com', type: 2, }, { value: 'someone2@somewhere.com', type: 4, label: 'My second-favorite custom label', }, ], address: [ { street: '5 Pike Place', city: 'Seattle', region: 'WA', postcode: '98101', type: 1, }, { street: '10 Pike Place', pobox: '3242', neighborhood: 'Downtown', city: 'Seattle', region: 'WA', postcode: '98101', country: 'United States', type: 3, label: 'My favorite spot!', }, ], }; <ContactDetail contact={contact} hasSignalAccount={true} i18n={util.i18n} onSendMessage={() => console.log('onSendMessage')} />; ``` ### With missing custom labels ```jsx const contact = { avatar: { avatar: { path: util.gifObjectUrl, }, }, name: { displayName: 'Someone Somewhere', }, number: [ { value: '(202) 555-0000', type: 4, }, ], email: [ { value: 'someone2@somewhere.com', type: 4, }, ], address: [ { street: '10 Pike Place, Seattle WA', type: 3, }, ], }; <ContactDetail contact={contact} hasSignalAccount={true} i18n={util.i18n} onSendMessage={() => console.log('onSendMessage')} />; ``` ### With default avatar ```jsx const contact = { name: { displayName: 'Someone Somewhere', }, number: [ { value: '(202) 555-0000', type: 1, }, ], }; <ContactDetail contact={contact} hasSignalAccount={true} i18n={util.i18n} onSendMessage={() => console.log('onSendMessage')} />; ``` ### Without a Signal account ```jsx const contact = { avatar: { avatar: { path: util.gifObjectUrl, }, }, name: { displayName: 'Someone Somewhere', }, number: [ { value: '(202) 555-0001', type: 1, }, ], }; <ContactDetail contact={contact} hasSignalAccount={false} i18n={util.i18n} onSendMessage={() => console.log('onSendMessage')} />; ``` ### No phone or email, partial addresses ```jsx const contact = { avatar: { avatar: { path: util.gifObjectUrl, }, }, name: { displayName: 'Someone Somewhere', }, address: [ { type: 1, neighborhood: 'Greenwood', region: 'WA', }, { type: 2, city: 'Seattle', region: 'WA', }, { type: 3, label: 'My label', region: 'WA', }, { type: 1, label: 'My label', postcode: '98101', region: 'WA', }, { type: 2, label: 'My label', postcode: '98101', }, ], }; <ContactDetail contact={contact} hasSignalAccount={false} i18n={util.i18n} onSendMessage={() => console.log('onSendMessage')} />; ``` ### Empty contact ```jsx const contact = {}; <ContactDetail contact={contact} hasSignalAccount={false} i18n={util.i18n} onSendMessage={() => console.log('onSendMessage')} />; ```