502ea174ab
Co-authored-by: Scott Nonnenberg <scott@signal.org>
258 lines
7 KiB
TypeScript
258 lines
7 KiB
TypeScript
// Copyright 2022 Signal Messenger, LLC
|
|
// SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
import type { Meta } from '@storybook/react';
|
|
import React from 'react';
|
|
import { action } from '@storybook/addon-actions';
|
|
import type { PropsType } from './StoryViewer';
|
|
import enMessages from '../../_locales/en/messages.json';
|
|
import { SendStatus } from '../messages/MessageSendState';
|
|
import { StoryViewModeType } from '../types/Stories';
|
|
import { generateStoryDistributionId } from '../types/StoryDistributionId';
|
|
import { StoryViewer } from './StoryViewer';
|
|
import { VIDEO_MP4 } from '../types/MIME';
|
|
import { fakeAttachment } from '../test-both/helpers/fakeAttachment';
|
|
import { getDefaultConversation } from '../test-both/helpers/getDefaultConversation';
|
|
import { getFakeStoryView } from '../test-both/helpers/getFakeStory';
|
|
import { setupI18n } from '../util/setupI18n';
|
|
|
|
const i18n = setupI18n('en', enMessages);
|
|
|
|
export default {
|
|
title: 'Components/StoryViewer',
|
|
component: StoryViewer,
|
|
argTypes: {
|
|
hasAllStoriesUnmuted: {
|
|
control: 'boolean',
|
|
},
|
|
hasViewReceiptSetting: {
|
|
control: 'boolean',
|
|
},
|
|
},
|
|
args: {
|
|
currentIndex: 0,
|
|
getPreferredBadge: () => undefined,
|
|
group: undefined,
|
|
hasAllStoriesUnmuted: true,
|
|
hasViewReceiptSetting: true,
|
|
i18n,
|
|
platform: 'darwin',
|
|
loadStoryReplies: action('loadStoryReplies'),
|
|
markStoryRead: action('markStoryRead'),
|
|
numStories: 1,
|
|
onGoToConversation: action('onGoToConversation'),
|
|
onHideStory: action('onHideStory'),
|
|
onReactToStory: action('onReactToStory'),
|
|
onReplyToStory: action('onReplyToStory'),
|
|
onSetSkinTone: action('onSetSkinTone'),
|
|
onTextTooLong: action('onTextTooLong'),
|
|
onUseEmoji: action('onUseEmoji'),
|
|
onMediaPlaybackStart: action('onMediaPlaybackStart'),
|
|
preferredReactionEmoji: ['❤️', '👍', '👎', '😂', '😮', '😢'],
|
|
queueStoryDownload: action('queueStoryDownload'),
|
|
renderEmojiPicker: () => <>EmojiPicker</>,
|
|
retryMessageSend: action('retryMessageSend'),
|
|
showToast: action('showToast'),
|
|
skinTone: 0,
|
|
story: getFakeStoryView(),
|
|
storyViewMode: StoryViewModeType.All,
|
|
viewStory: action('viewStory'),
|
|
isWindowActive: true,
|
|
},
|
|
} satisfies Meta<PropsType>;
|
|
|
|
export function SomeonesStory(args: PropsType): JSX.Element {
|
|
return <StoryViewer {...args} />;
|
|
}
|
|
|
|
export function WideStory(args: PropsType): JSX.Element {
|
|
return (
|
|
<StoryViewer
|
|
{...args}
|
|
story={getFakeStoryView('/fixtures/nathan-anderson-316188-unsplash.jpg')}
|
|
/>
|
|
);
|
|
}
|
|
|
|
export function InAGroup(args: PropsType): JSX.Element {
|
|
return (
|
|
<StoryViewer
|
|
{...args}
|
|
group={getDefaultConversation({
|
|
avatarPath: '/fixtures/kitten-4-112-112.jpg',
|
|
title: 'Family Group',
|
|
type: 'group',
|
|
})}
|
|
/>
|
|
);
|
|
}
|
|
|
|
export function MultiStory(args: PropsType): JSX.Element {
|
|
return (
|
|
<StoryViewer
|
|
{...args}
|
|
currentIndex={2}
|
|
numStories={7}
|
|
story={{
|
|
...getFakeStoryView(),
|
|
attachment: fakeAttachment({
|
|
contentType: VIDEO_MP4,
|
|
fileName: 'pixabay-Soap-Bubble-7141.mp4',
|
|
url: '/fixtures/kitten-4-112-112.jpg',
|
|
screenshotPath: '/fixtures/kitten-4-112-112.jpg',
|
|
}),
|
|
}}
|
|
/>
|
|
);
|
|
}
|
|
|
|
export function Caption(args: PropsType): JSX.Element {
|
|
return (
|
|
<StoryViewer
|
|
{...args}
|
|
story={{
|
|
...getFakeStoryView(),
|
|
attachment: fakeAttachment({
|
|
caption: 'This place looks lovely',
|
|
path: 'file.jpg',
|
|
url: '/fixtures/nathan-anderson-316188-unsplash.jpg',
|
|
}),
|
|
}}
|
|
/>
|
|
);
|
|
}
|
|
|
|
export function EmojiCaption(args: PropsType): JSX.Element {
|
|
return (
|
|
<StoryViewer
|
|
{...args}
|
|
story={{
|
|
...getFakeStoryView(),
|
|
attachment: fakeAttachment({
|
|
caption: 'WOOOOOOOOW 🥰',
|
|
path: 'file.jpg',
|
|
url: '/fixtures/nathan-anderson-316188-unsplash.jpg',
|
|
}),
|
|
}}
|
|
/>
|
|
);
|
|
}
|
|
|
|
export function LongCaption(args: PropsType): JSX.Element {
|
|
return (
|
|
<StoryViewer
|
|
{...args}
|
|
story={{
|
|
...getFakeStoryView(),
|
|
attachment: fakeAttachment({
|
|
caption:
|
|
'Snowycle, snowycle, snowycle\nI want to ride my snowycle, snowycle, snowycle\nI want to ride my snowycle\nI want to ride my snow\nI want to ride my snowycle\nI want to ride it where I like\nSnowycle, snowycle, snowycle\nI want to ride my snowycle, snowycle, snowycle\nI want to ride my snowycle\nI want to ride my snow\nI want to ride my snowycle\nI want to ride it where I like\nSnowycle, snowycle, snowycle\nI want to ride my snowycle, snowycle, snowycle\nI want to ride my snowycle\nI want to ride my snow\nI want to ride my snowycle\nI want to ride it where I like',
|
|
path: 'file.jpg',
|
|
url: '/fixtures/snow.jpg',
|
|
}),
|
|
}}
|
|
/>
|
|
);
|
|
}
|
|
|
|
export function YourStory(args: PropsType): JSX.Element {
|
|
const storyView = getFakeStoryView(
|
|
'/fixtures/nathan-anderson-316188-unsplash.jpg'
|
|
);
|
|
return (
|
|
<StoryViewer
|
|
{...args}
|
|
distributionList={{
|
|
id: generateStoryDistributionId(),
|
|
name: 'Close Friends',
|
|
}}
|
|
story={{
|
|
...storyView,
|
|
sender: {
|
|
...storyView.sender,
|
|
isMe: true,
|
|
},
|
|
sendState: [
|
|
{
|
|
recipient: getDefaultConversation(),
|
|
status: SendStatus.Viewed,
|
|
},
|
|
{
|
|
recipient: getDefaultConversation(),
|
|
status: SendStatus.Delivered,
|
|
},
|
|
{
|
|
recipient: getDefaultConversation(),
|
|
status: SendStatus.Pending,
|
|
},
|
|
],
|
|
}}
|
|
/>
|
|
);
|
|
}
|
|
|
|
export function YourStoryFailed(args: PropsType): JSX.Element {
|
|
const storyView = getFakeStoryView(
|
|
'/fixtures/nathan-anderson-316188-unsplash.jpg'
|
|
);
|
|
|
|
return (
|
|
<StoryViewer
|
|
{...args}
|
|
distributionList={{
|
|
id: generateStoryDistributionId(),
|
|
name: 'Close Friends',
|
|
}}
|
|
story={{
|
|
...storyView,
|
|
sender: {
|
|
...storyView.sender,
|
|
isMe: true,
|
|
},
|
|
sendState: [
|
|
{
|
|
recipient: getDefaultConversation(),
|
|
status: SendStatus.Viewed,
|
|
},
|
|
{
|
|
recipient: getDefaultConversation(),
|
|
status: SendStatus.Failed,
|
|
},
|
|
],
|
|
}}
|
|
/>
|
|
);
|
|
}
|
|
|
|
export function ReadReceiptsOff(args: PropsType): JSX.Element {
|
|
const storyView = getFakeStoryView(
|
|
'/fixtures/nathan-anderson-316188-unsplash.jpg'
|
|
);
|
|
return (
|
|
<StoryViewer
|
|
{...args}
|
|
hasViewReceiptSetting={false}
|
|
story={{
|
|
...storyView,
|
|
sender: {
|
|
...storyView.sender,
|
|
isMe: true,
|
|
},
|
|
sendState: [
|
|
{
|
|
recipient: getDefaultConversation(),
|
|
status: SendStatus.Viewed,
|
|
},
|
|
{
|
|
recipient: getDefaultConversation(),
|
|
status: SendStatus.Delivered,
|
|
},
|
|
{
|
|
recipient: getDefaultConversation(),
|
|
status: SendStatus.Pending,
|
|
},
|
|
],
|
|
}}
|
|
/>
|
|
);
|
|
}
|