// Copyright 2021 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import * as React from 'react'; import { storiesOf } from '@storybook/react'; import { text, withKnobs } from '@storybook/addon-knobs'; import { action } from '@storybook/addon-actions'; import { setupI18n } from '../util/setupI18n'; import enMessages from '../../_locales/en/messages.json'; import type { PropsType } from './MainHeader'; import { MainHeader } from './MainHeader'; const i18n = setupI18n('en', enMessages); const story = storiesOf('Components/MainHeader', module); const requiredText = (name: string, value: string | undefined) => text(name, value || ''); const optionalText = (name: string, value: string | undefined) => text(name, value || '') || undefined; // Storybook types are incorrect // eslint-disable-next-line @typescript-eslint/no-explicit-any story.addDecorator((withKnobs as any)({ escapeHTML: false })); const createProps = (overrideProps: Partial = {}): PropsType => ({ searchTerm: requiredText('searchTerm', overrideProps.searchTerm), searchConversationName: optionalText( 'searchConversationName', overrideProps.searchConversationName ), searchConversationId: optionalText( 'searchConversationId', overrideProps.searchConversationId ), selectedConversation: undefined, startSearchCounter: 0, ourConversationId: '', ourUuid: '', ourNumber: '', regionCode: '', phoneNumber: optionalText('phoneNumber', overrideProps.phoneNumber), title: requiredText('title', overrideProps.title), name: optionalText('name', overrideProps.name), avatarPath: optionalText('avatarPath', overrideProps.avatarPath), hasPendingUpdate: Boolean(overrideProps.hasPendingUpdate), i18n, updateSearchTerm: action('updateSearchTerm'), searchMessages: action('searchMessages'), searchDiscussions: action('searchDiscussions'), startSearch: action('startSearch'), searchInConversation: action('searchInConversation'), clearConversationSearch: action('clearConversationSearch'), clearSearch: action('clearSearch'), startUpdate: action('startUpdate'), showArchivedConversations: action('showArchivedConversations'), startComposing: action('startComposing'), toggleProfileEditor: action('toggleProfileEditor'), }); story.add('Basic', () => { const props = createProps({}); return ; }); story.add('Name', () => { const props = createProps({ name: 'John Smith', title: 'John Smith', }); return ; }); story.add('Phone Number', () => { const props = createProps({ name: 'John Smith', phoneNumber: '+15553004000', }); return ; }); story.add('Search Term', () => { const props = createProps({ name: 'John Smith', searchTerm: 'Hewwo?', title: 'John Smith', }); return ; }); story.add('Searching Conversation', () => { const props = createProps({ name: 'John Smith', searchConversationId: 'group-id-1', searchConversationName: 'Everyone', }); return ; }); story.add('Searching Conversation with Term', () => { const props = createProps({ name: 'John Smith', searchTerm: 'address', searchConversationId: 'group-id-1', searchConversationName: 'Everyone', }); return ; }); story.add('Update Available', () => { const props = createProps({ hasPendingUpdate: true }); return ; });