signal-desktop/ts/components/Lightbox.stories.tsx

351 lines
8.6 KiB
TypeScript
Raw Normal View History

2023-01-03 19:55:46 +00:00
// Copyright 2020 Signal Messenger, LLC
2020-10-30 20:34:04 +00:00
// SPDX-License-Identifier: AGPL-3.0-only
2020-08-21 22:05:32 +00:00
import * as React from 'react';
2021-08-23 23:14:53 +00:00
import { action } from '@storybook/addon-actions';
import { number } from '@storybook/addon-knobs';
2020-08-21 22:05:32 +00:00
2021-08-23 23:14:53 +00:00
import enMessages from '../../_locales/en/messages.json';
import type { PropsType } from './Lightbox';
import { Lightbox } from './Lightbox';
import type { MediaItemType } from '../types/MediaItem';
2021-09-18 00:30:08 +00:00
import { setupI18n } from '../util/setupI18n';
2020-08-21 22:05:32 +00:00
import {
AUDIO_MP3,
IMAGE_JPEG,
VIDEO_MP4,
VIDEO_QUICKTIME,
2021-08-09 20:06:21 +00:00
stringToMIMEType,
2020-08-21 22:05:32 +00:00
} from '../types/MIME';
2020-09-12 00:46:52 +00:00
import { fakeAttachment } from '../test-both/helpers/fakeAttachment';
2020-08-21 22:05:32 +00:00
const i18n = setupI18n('en', enMessages);
2022-06-07 00:48:02 +00:00
export default {
title: 'Components/Lightbox',
};
2020-08-21 22:05:32 +00:00
2021-08-23 23:14:53 +00:00
type OverridePropsMediaItemType = Partial<MediaItemType> & { caption?: string };
2020-08-21 22:05:32 +00:00
2021-08-23 23:14:53 +00:00
function createMediaItem(
overrideProps: OverridePropsMediaItemType
): MediaItemType {
return {
attachment: fakeAttachment({
2021-08-23 23:14:53 +00:00
caption: overrideProps.caption || '',
contentType: IMAGE_JPEG,
fileName: overrideProps.objectURL,
url: overrideProps.objectURL,
}),
2021-08-23 23:14:53 +00:00
contentType: IMAGE_JPEG,
index: 0,
message: {
attachments: [],
conversationId: '1234',
id: 'image-msg',
received_at: 0,
received_at_ms: Date.now(),
2021-08-25 21:08:32 +00:00
sent_at: Date.now(),
2021-08-23 23:14:53 +00:00
},
objectURL: '',
...overrideProps,
};
}
2021-06-29 21:13:36 +00:00
2021-08-23 23:14:53 +00:00
const createProps = (overrideProps: Partial<PropsType> = {}): PropsType => ({
2022-12-10 02:02:22 +00:00
closeLightbox: action('closeLightbox'),
2021-08-23 23:14:53 +00:00
i18n,
2021-08-24 21:47:14 +00:00
isViewOnce: Boolean(overrideProps.isViewOnce),
2021-08-23 23:14:53 +00:00
media: overrideProps.media || [],
2022-12-14 18:12:04 +00:00
saveAttachment: action('saveAttachment'),
2021-08-23 23:14:53 +00:00
selectedIndex: number('selectedIndex', overrideProps.selectedIndex || 0),
2022-12-10 02:02:22 +00:00
toggleForwardMessageModal: action('toggleForwardMessageModal'),
2020-08-21 22:05:32 +00:00
});
2022-11-18 00:45:19 +00:00
export function Multimedia(): JSX.Element {
2020-08-21 22:05:32 +00:00
const props = createProps({
2021-08-23 23:14:53 +00:00
media: [
{
attachment: fakeAttachment({
2021-08-23 23:14:53 +00:00
contentType: IMAGE_JPEG,
fileName: 'tina-rolf-269345-unsplash.jpg',
url: '/fixtures/tina-rolf-269345-unsplash.jpg',
caption:
'Still from The Lighthouse, starring Robert Pattinson and Willem Defoe.',
}),
2021-08-23 23:14:53 +00:00
contentType: IMAGE_JPEG,
index: 0,
message: {
attachments: [],
conversationId: '1234',
id: 'image-msg',
received_at: 1,
received_at_ms: Date.now(),
2021-08-25 21:08:32 +00:00
sent_at: Date.now(),
2021-08-23 23:14:53 +00:00
},
objectURL: '/fixtures/tina-rolf-269345-unsplash.jpg',
},
{
attachment: fakeAttachment({
2021-08-23 23:14:53 +00:00
contentType: VIDEO_MP4,
fileName: 'pixabay-Soap-Bubble-7141.mp4',
url: '/fixtures/pixabay-Soap-Bubble-7141.mp4',
}),
2021-08-23 23:14:53 +00:00
contentType: VIDEO_MP4,
index: 1,
message: {
attachments: [],
conversationId: '1234',
id: 'video-msg',
received_at: 2,
received_at_ms: Date.now(),
2021-08-25 21:08:32 +00:00
sent_at: Date.now(),
2021-08-23 23:14:53 +00:00
},
objectURL: '/fixtures/pixabay-Soap-Bubble-7141.mp4',
},
createMediaItem({
contentType: IMAGE_JPEG,
index: 2,
thumbnailObjectUrl: '/fixtures/kitten-1-64-64.jpg',
objectURL: '/fixtures/kitten-1-64-64.jpg',
}),
createMediaItem({
contentType: IMAGE_JPEG,
index: 3,
thumbnailObjectUrl: '/fixtures/kitten-2-64-64.jpg',
objectURL: '/fixtures/kitten-2-64-64.jpg',
}),
],
2020-08-21 22:05:32 +00:00
});
return <Lightbox {...props} />;
2022-11-18 00:45:19 +00:00
}
2020-08-21 22:05:32 +00:00
2022-11-18 00:45:19 +00:00
export function MissingMedia(): JSX.Element {
2020-08-21 22:05:32 +00:00
const props = createProps({
2021-08-23 23:14:53 +00:00
media: [
{
attachment: fakeAttachment({
2021-08-23 23:14:53 +00:00
contentType: IMAGE_JPEG,
fileName: 'tina-rolf-269345-unsplash.jpg',
url: '/fixtures/tina-rolf-269345-unsplash.jpg',
}),
2021-08-23 23:14:53 +00:00
contentType: IMAGE_JPEG,
index: 0,
message: {
attachments: [],
conversationId: '1234',
id: 'image-msg',
received_at: 3,
received_at_ms: Date.now(),
2021-08-25 21:08:32 +00:00
sent_at: Date.now(),
2021-08-23 23:14:53 +00:00
},
objectURL: undefined,
},
],
2020-08-21 22:05:32 +00:00
});
return <Lightbox {...props} />;
2022-11-18 00:45:19 +00:00
}
2020-08-21 22:05:32 +00:00
2022-11-18 00:45:19 +00:00
export function SingleImage(): JSX.Element {
return (
<Lightbox
{...createProps({
media: [
createMediaItem({
objectURL: '/fixtures/tina-rolf-269345-unsplash.jpg',
}),
],
})}
/>
);
}
2020-08-21 22:05:32 +00:00
2022-11-18 00:45:19 +00:00
export function ImageWithCaptionNormalImage(): JSX.Element {
return (
<Lightbox
{...createProps({
media: [
createMediaItem({
caption:
'This lighthouse is really cool because there are lots of rocks and there is a tower that has a light and the light is really bright because it shines so much. The day was super duper cloudy and stormy and you can see all the waves hitting against the rocks. Wait? What is that weird red hose line thingy running all the way to the tower? Those rocks look slippery! I bet that water is really cold. I am cold now, can I get a sweater? I wonder where this place is, probably somewhere cold like Coldsgar, Frozenville.',
objectURL: '/fixtures/tina-rolf-269345-unsplash.jpg',
}),
],
})}
/>
);
}
2022-06-07 00:48:02 +00:00
ImageWithCaptionNormalImage.story = {
name: 'Image with Caption (normal image)',
};
2020-08-21 22:05:32 +00:00
2022-11-18 00:45:19 +00:00
export function ImageWithCaptionAllWhiteImage(): JSX.Element {
return (
<Lightbox
{...createProps({
media: [
createMediaItem({
caption:
'This is the user-provided caption. It should be visible on light backgrounds.',
objectURL: '/fixtures/2000x2000-white.png',
}),
],
})}
/>
);
}
2020-08-21 22:05:32 +00:00
2022-06-07 00:48:02 +00:00
ImageWithCaptionAllWhiteImage.story = {
name: 'Image with Caption (all-white image)',
};
2022-11-18 00:45:19 +00:00
export function SingleVideo(): JSX.Element {
return (
<Lightbox
{...createProps({
media: [
createMediaItem({
contentType: VIDEO_MP4,
objectURL: '/fixtures/pixabay-Soap-Bubble-7141.mp4',
}),
],
})}
/>
);
}
2020-08-21 22:05:32 +00:00
2022-11-18 00:45:19 +00:00
export function SingleVideoWCaption(): JSX.Element {
return (
<Lightbox
{...createProps({
media: [
createMediaItem({
caption:
'This is the user-provided caption. It can get long and wrap onto multiple lines.',
contentType: VIDEO_MP4,
objectURL: '/fixtures/pixabay-Soap-Bubble-7141.mp4',
}),
],
})}
/>
);
}
2022-06-07 00:48:02 +00:00
SingleVideoWCaption.story = {
name: 'Single Video w/caption',
};
2020-08-21 22:05:32 +00:00
2022-11-18 00:45:19 +00:00
export function UnsupportedImageType(): JSX.Element {
return (
<Lightbox
{...createProps({
media: [
createMediaItem({
contentType: stringToMIMEType('image/tiff'),
objectURL: 'unsupported-image.tiff',
}),
],
})}
/>
);
}
2020-08-21 22:05:32 +00:00
2022-11-18 00:45:19 +00:00
export function UnsupportedVideoType(): JSX.Element {
return (
<Lightbox
{...createProps({
media: [
createMediaItem({
contentType: VIDEO_QUICKTIME,
objectURL: 'unsupported-video.mov',
}),
],
})}
/>
);
}
2020-08-21 22:05:32 +00:00
2022-11-18 00:45:19 +00:00
export function UnsupportedContent(): JSX.Element {
return (
<Lightbox
{...createProps({
media: [
createMediaItem({
contentType: AUDIO_MP3,
objectURL: '/fixtures/incompetech-com-Agnus-Dei-X.mp3',
}),
],
})}
/>
);
}
2021-08-06 00:17:05 +00:00
2022-11-18 00:45:19 +00:00
export function CustomChildren(): JSX.Element {
return (
<Lightbox {...createProps({})} media={[]}>
<div
style={{
color: 'white',
display: 'flex',
alignItems: 'center',
justifyContent: 'center',
}}
>
I am middle child
</div>
</Lightbox>
);
}
2022-06-07 00:48:02 +00:00
CustomChildren.story = {
name: 'Custom children',
};
2021-08-23 23:14:53 +00:00
2022-11-18 00:45:19 +00:00
export function ConversationHeader(): JSX.Element {
return (
<Lightbox
{...createProps({})}
getConversation={() => ({
acceptedMessageRequest: true,
avatarPath: '/fixtures/kitten-1-64-64.jpg',
badges: [],
id: '1234',
isMe: false,
name: 'Test',
profileName: 'Test',
sharedGroupNames: [],
title: 'Test',
type: 'direct',
})}
media={[
2021-08-24 21:47:14 +00:00
createMediaItem({
contentType: VIDEO_MP4,
objectURL: '/fixtures/pixabay-Soap-Bubble-7141.mp4',
}),
2022-11-18 00:45:19 +00:00
]}
/>
);
}
export function ViewOnceVideo(): JSX.Element {
return (
<Lightbox
{...createProps({
isViewOnce: true,
media: [
createMediaItem({
contentType: VIDEO_MP4,
objectURL: '/fixtures/pixabay-Soap-Bubble-7141.mp4',
}),
],
})}
isViewOnce
/>
);
}