// Copyright 2022 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import React from 'react'; import { storiesOf } from '@storybook/react'; import { action } from '@storybook/addon-actions'; import type { PropsType } from './StoryViewer'; import { StoryViewer } from './StoryViewer'; import enMessages from '../../_locales/en/messages.json'; import { setupI18n } from '../util/setupI18n'; import { getDefaultConversation } from '../test-both/helpers/getDefaultConversation'; import { fakeAttachment } from '../test-both/helpers/fakeAttachment'; const i18n = setupI18n('en', enMessages); const story = storiesOf('Components/StoryViewer', module); function getDefaultProps(): PropsType { const sender = getDefaultConversation(); return { conversationId: sender.id, getPreferredBadge: () => undefined, group: undefined, hasAllStoriesMuted: false, i18n, loadStoryReplies: action('loadStoryReplies'), markStoryRead: action('markStoryRead'), onClose: action('onClose'), onGoToConversation: action('onGoToConversation'), onHideStory: action('onHideStory'), onNextUserStories: action('onNextUserStories'), onPrevUserStories: action('onPrevUserStories'), onReactToStory: action('onReactToStory'), onReplyToStory: action('onReplyToStory'), onSetSkinTone: action('onSetSkinTone'), onTextTooLong: action('onTextTooLong'), onUseEmoji: action('onUseEmoji'), preferredReactionEmoji: ['❤️', '👍', '👎', '😂', '😮', '😢'], queueStoryDownload: action('queueStoryDownload'), renderEmojiPicker: () =>
, stories: [ { attachment: fakeAttachment({ path: 'snow.jpg', url: '/fixtures/snow.jpg', }), canReply: true, messageId: '123', sender, timestamp: Date.now(), }, ], toggleHasAllStoriesMuted: action('toggleHasAllStoriesMuted'), }; } story.add("Someone's story", () => ); story.add('Wide story', () => ( )); story.add('In a group', () => ( )); story.add('Multi story', () => { const sender = getDefaultConversation(); return ( ); }); story.add('Caption', () => ( )); story.add('Long Caption', () => ( ));