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
|
|
|
|
|
2022-07-06 19:06:20 +00:00
|
|
|
import type { Meta, Story } from '@storybook/react';
|
2020-08-27 17:02:25 +00:00
|
|
|
import * as React from 'react';
|
|
|
|
|
|
|
|
import { action } from '@storybook/addon-actions';
|
|
|
|
|
2021-05-28 16:15:17 +00:00
|
|
|
import { ConversationColors } from '../../types/Colors';
|
2020-08-27 17:02:25 +00:00
|
|
|
import { pngUrl } from '../../storybook/Fixtures';
|
2022-11-04 13:22:07 +00:00
|
|
|
import type { Props as TimelineMessagesProps } from './TimelineMessage';
|
|
|
|
import { TimelineMessage } from './TimelineMessage';
|
|
|
|
import { TextDirection } from './Message';
|
2021-03-25 18:36:50 +00:00
|
|
|
import {
|
|
|
|
AUDIO_MP3,
|
|
|
|
IMAGE_PNG,
|
|
|
|
LONG_MESSAGE,
|
|
|
|
VIDEO_MP4,
|
2021-08-09 20:06:21 +00:00
|
|
|
stringToMIMEType,
|
2021-03-25 18:36:50 +00:00
|
|
|
} from '../../types/MIME';
|
2021-10-26 19:15:33 +00:00
|
|
|
import type { Props } from './Quote';
|
|
|
|
import { Quote } from './Quote';
|
2021-08-12 18:15:55 +00:00
|
|
|
import { ReadStatus } from '../../messages/MessageReadStatus';
|
2021-09-18 00:30:08 +00:00
|
|
|
import { setupI18n } from '../../util/setupI18n';
|
2020-08-27 17:02:25 +00:00
|
|
|
import enMessages from '../../../_locales/en/messages.json';
|
2021-05-07 22:21:10 +00:00
|
|
|
import { getDefaultConversation } from '../../test-both/helpers/getDefaultConversation';
|
2021-10-12 23:59:08 +00:00
|
|
|
import { WidthBreakpoint } from '../_util';
|
2021-11-15 22:53:42 +00:00
|
|
|
import { ThemeType } from '../../types/Util';
|
2022-11-30 21:47:54 +00:00
|
|
|
import { PaymentEventKind } from '../../types/Payment';
|
2020-09-14 19:51:27 +00:00
|
|
|
|
2020-08-27 17:02:25 +00:00
|
|
|
const i18n = setupI18n('en', enMessages);
|
|
|
|
|
2022-06-07 00:48:02 +00:00
|
|
|
export default {
|
2022-07-06 19:06:20 +00:00
|
|
|
component: Quote,
|
2022-06-07 00:48:02 +00:00
|
|
|
title: 'Components/Conversation/Quote',
|
2022-07-06 19:06:20 +00:00
|
|
|
argTypes: {
|
|
|
|
authorTitle: {
|
|
|
|
defaultValue: 'Default Sender',
|
|
|
|
},
|
|
|
|
conversationColor: {
|
|
|
|
defaultValue: 'forest',
|
|
|
|
},
|
|
|
|
doubleCheckMissingQuoteReference: { action: true },
|
|
|
|
i18n: {
|
|
|
|
defaultValue: i18n,
|
|
|
|
},
|
2023-04-03 20:16:27 +00:00
|
|
|
platform: {
|
|
|
|
defautlValue: 'darwin',
|
|
|
|
},
|
2022-07-06 19:06:20 +00:00
|
|
|
isFromMe: {
|
|
|
|
control: { type: 'checkbox' },
|
|
|
|
defaultValue: false,
|
|
|
|
},
|
|
|
|
isGiftBadge: {
|
|
|
|
control: { type: 'checkbox' },
|
|
|
|
defaultValue: false,
|
|
|
|
},
|
|
|
|
isIncoming: {
|
|
|
|
control: { type: 'checkbox' },
|
|
|
|
defaultValue: false,
|
|
|
|
},
|
|
|
|
isViewOnce: {
|
|
|
|
control: { type: 'checkbox' },
|
|
|
|
defaultValue: false,
|
|
|
|
},
|
|
|
|
onClick: { action: true },
|
|
|
|
onClose: { action: true },
|
|
|
|
rawAttachment: {
|
|
|
|
defaultValue: undefined,
|
|
|
|
},
|
|
|
|
referencedMessageNotFound: {
|
|
|
|
control: { type: 'checkbox' },
|
|
|
|
defaultValue: false,
|
|
|
|
},
|
|
|
|
text: {
|
|
|
|
defaultValue: 'A sample message from a pal',
|
|
|
|
},
|
|
|
|
},
|
|
|
|
} as Meta;
|
2020-08-27 17:02:25 +00:00
|
|
|
|
2022-11-04 13:22:07 +00:00
|
|
|
const defaultMessageProps: TimelineMessagesProps = {
|
2021-05-07 22:21:10 +00:00
|
|
|
author: getDefaultConversation({
|
2021-04-27 19:55:21 +00:00
|
|
|
id: 'some-id',
|
|
|
|
title: 'Person X',
|
2021-05-07 22:21:10 +00:00
|
|
|
}),
|
2022-02-02 20:01:22 +00:00
|
|
|
canReact: true,
|
2020-08-27 17:02:25 +00:00
|
|
|
canReply: true,
|
2022-03-04 19:22:31 +00:00
|
|
|
canRetry: true,
|
|
|
|
canRetryDeleteForEveryone: true,
|
2020-09-29 22:55:56 +00:00
|
|
|
canDeleteForEveryone: true,
|
2020-10-16 18:31:57 +00:00
|
|
|
canDownload: true,
|
2021-06-17 17:15:10 +00:00
|
|
|
checkForAccount: action('checkForAccount'),
|
2023-03-20 22:23:53 +00:00
|
|
|
clearTargetedMessage: action('default--clearTargetedMessage'),
|
2021-08-20 19:36:27 +00:00
|
|
|
containerElementRef: React.createRef<HTMLElement>(),
|
2021-10-12 23:59:08 +00:00
|
|
|
containerWidthBreakpoint: WidthBreakpoint.Wide,
|
2021-05-28 16:15:17 +00:00
|
|
|
conversationColor: 'crimson',
|
2020-08-27 17:02:25 +00:00
|
|
|
conversationId: 'conversationId',
|
2022-05-11 20:59:58 +00:00
|
|
|
conversationTitle: 'Conversation Title',
|
2020-08-27 17:02:25 +00:00
|
|
|
conversationType: 'direct', // override
|
2023-03-20 22:23:53 +00:00
|
|
|
deleteMessages: action('default--deleteMessages'),
|
2021-06-17 17:15:10 +00:00
|
|
|
deleteMessageForEveryone: action('default--deleteMessageForEveryone'),
|
2020-08-27 17:02:25 +00:00
|
|
|
direction: 'incoming',
|
2022-12-10 02:02:22 +00:00
|
|
|
showLightboxForViewOnceMedia: action('default--showLightboxForViewOnceMedia'),
|
2021-06-17 17:15:10 +00:00
|
|
|
doubleCheckMissingQuoteReference: action(
|
|
|
|
'default--doubleCheckMissingQuoteReference'
|
|
|
|
),
|
2021-11-17 21:11:46 +00:00
|
|
|
getPreferredBadge: () => undefined,
|
2020-08-27 17:02:25 +00:00
|
|
|
i18n,
|
2023-04-03 20:16:27 +00:00
|
|
|
platform: 'darwin',
|
2020-08-27 17:02:25 +00:00
|
|
|
id: 'messageId',
|
2022-11-04 13:22:07 +00:00
|
|
|
// renderingContext: 'storybook',
|
2020-08-27 17:02:25 +00:00
|
|
|
interactionMode: 'keyboard',
|
2021-02-02 17:09:53 +00:00
|
|
|
isBlocked: false,
|
|
|
|
isMessageRequestAccepted: true,
|
2023-03-20 22:23:53 +00:00
|
|
|
isSelected: false,
|
|
|
|
isSelectMode: false,
|
2023-04-10 16:31:45 +00:00
|
|
|
isSpoilerExpanded: false,
|
2023-03-20 22:23:53 +00:00
|
|
|
toggleSelectMessage: action('toggleSelectMessage'),
|
2021-06-17 17:15:10 +00:00
|
|
|
kickOffAttachmentDownload: action('default--kickOffAttachmentDownload'),
|
|
|
|
markAttachmentAsCorrupted: action('default--markAttachmentAsCorrupted'),
|
2022-02-16 18:43:45 +00:00
|
|
|
messageExpanded: action('default--message-expanded'),
|
2022-12-14 19:05:32 +00:00
|
|
|
showConversation: action('default--showConversation'),
|
2022-05-11 20:59:58 +00:00
|
|
|
openGiftBadge: action('openGiftBadge'),
|
2020-08-27 17:02:25 +00:00
|
|
|
previews: [],
|
2021-06-17 17:15:10 +00:00
|
|
|
reactToMessage: action('default--reactToMessage'),
|
2021-08-12 18:15:55 +00:00
|
|
|
readStatus: ReadStatus.Read,
|
2020-08-27 17:02:25 +00:00
|
|
|
renderEmojiPicker: () => <div />,
|
2021-09-10 18:00:31 +00:00
|
|
|
renderReactionPicker: () => <div />,
|
2021-03-10 20:36:58 +00:00
|
|
|
renderAudioAttachment: () => <div>*AudioAttachment*</div>,
|
2022-12-09 19:11:14 +00:00
|
|
|
setQuoteByMessageId: action('default--setQuoteByMessageId'),
|
2022-12-20 01:04:47 +00:00
|
|
|
retryMessageSend: action('default--retryMessageSend'),
|
2022-03-04 19:22:31 +00:00
|
|
|
retryDeleteForEveryone: action('default--retryDeleteForEveryone'),
|
2022-12-14 18:12:04 +00:00
|
|
|
saveAttachment: action('saveAttachment'),
|
2021-06-17 17:15:10 +00:00
|
|
|
scrollToQuotedMessage: action('default--scrollToQuotedMessage'),
|
2023-03-20 22:23:53 +00:00
|
|
|
targetMessage: action('default--targetMessage'),
|
2022-03-28 22:55:12 +00:00
|
|
|
shouldCollapseAbove: false,
|
|
|
|
shouldCollapseBelow: false,
|
|
|
|
shouldHideMetadata: false,
|
2023-04-10 16:31:45 +00:00
|
|
|
showSpoiler: action('showSpoiler'),
|
2022-12-15 01:10:09 +00:00
|
|
|
pushPanelForConversation: action('default--pushPanelForConversation'),
|
2021-06-17 17:15:10 +00:00
|
|
|
showContactModal: action('default--showContactModal'),
|
|
|
|
showExpiredIncomingTapToViewToast: action(
|
|
|
|
'showExpiredIncomingTapToViewToast'
|
|
|
|
),
|
|
|
|
showExpiredOutgoingTapToViewToast: action(
|
|
|
|
'showExpiredOutgoingTapToViewToast'
|
|
|
|
),
|
2023-03-20 22:23:53 +00:00
|
|
|
toggleForwardMessagesModal: action('default--toggleForwardMessagesModal'),
|
2022-12-10 02:02:22 +00:00
|
|
|
showLightbox: action('default--showLightbox'),
|
2022-04-12 00:26:09 +00:00
|
|
|
startConversation: action('default--startConversation'),
|
2020-08-27 17:02:25 +00:00
|
|
|
status: 'sent',
|
|
|
|
text: 'This is really interesting.',
|
2022-03-23 20:23:28 +00:00
|
|
|
textDirection: TextDirection.Default,
|
2021-11-15 22:53:42 +00:00
|
|
|
theme: ThemeType.light,
|
2020-08-27 17:02:25 +00:00
|
|
|
timestamp: Date.now(),
|
2022-07-06 19:06:20 +00:00
|
|
|
viewStory: action('viewStory'),
|
2020-08-27 17:02:25 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
const renderInMessage = ({
|
|
|
|
authorTitle,
|
2021-05-28 16:15:17 +00:00
|
|
|
conversationColor,
|
2020-08-27 17:02:25 +00:00
|
|
|
isFromMe,
|
2021-03-25 18:36:50 +00:00
|
|
|
rawAttachment,
|
2021-06-02 16:42:19 +00:00
|
|
|
isViewOnce,
|
2022-05-11 20:59:58 +00:00
|
|
|
isGiftBadge,
|
2020-08-27 17:02:25 +00:00
|
|
|
referencedMessageNotFound,
|
|
|
|
text: quoteText,
|
|
|
|
}: Props) => {
|
|
|
|
const messageProps = {
|
|
|
|
...defaultMessageProps,
|
2021-05-28 16:15:17 +00:00
|
|
|
conversationColor,
|
2020-08-27 17:02:25 +00:00
|
|
|
quote: {
|
|
|
|
authorId: 'an-author',
|
|
|
|
authorTitle,
|
2021-05-28 16:15:17 +00:00
|
|
|
conversationColor,
|
2022-11-30 21:47:54 +00:00
|
|
|
conversationTitle: getDefaultConversation().title,
|
2020-08-27 17:02:25 +00:00
|
|
|
isFromMe,
|
2021-03-25 18:36:50 +00:00
|
|
|
rawAttachment,
|
2021-06-02 16:42:19 +00:00
|
|
|
isViewOnce,
|
2022-05-11 20:59:58 +00:00
|
|
|
isGiftBadge,
|
2020-08-27 17:02:25 +00:00
|
|
|
referencedMessageNotFound,
|
|
|
|
sentAt: Date.now() - 30 * 1000,
|
|
|
|
text: quoteText,
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
|
|
|
return (
|
|
|
|
<div style={{ overflow: 'hidden' }}>
|
2022-11-04 13:22:07 +00:00
|
|
|
<TimelineMessage {...messageProps} />
|
2020-08-27 17:02:25 +00:00
|
|
|
<br />
|
2022-11-04 13:22:07 +00:00
|
|
|
<TimelineMessage {...messageProps} direction="outgoing" />
|
2020-08-27 17:02:25 +00:00
|
|
|
</div>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
2022-11-18 00:45:19 +00:00
|
|
|
// eslint-disable-next-line react/function-component-definition
|
2022-07-06 19:06:20 +00:00
|
|
|
const Template: Story<Props> = args => <Quote {...args} />;
|
|
|
|
const TemplateInMessage: Story<Props> = args => renderInMessage(args);
|
2020-08-27 17:02:25 +00:00
|
|
|
|
2022-07-06 19:06:20 +00:00
|
|
|
export const OutgoingByAnotherAuthor = Template.bind({});
|
|
|
|
OutgoingByAnotherAuthor.args = {
|
|
|
|
authorTitle: getDefaultConversation().title,
|
2022-06-07 00:48:02 +00:00
|
|
|
};
|
|
|
|
OutgoingByAnotherAuthor.story = {
|
|
|
|
name: 'Outgoing by Another Author',
|
|
|
|
};
|
|
|
|
|
2022-07-06 19:06:20 +00:00
|
|
|
export const OutgoingByMe = Template.bind({});
|
|
|
|
OutgoingByMe.args = {
|
|
|
|
isFromMe: true,
|
2022-06-07 00:48:02 +00:00
|
|
|
};
|
|
|
|
OutgoingByMe.story = {
|
|
|
|
name: 'Outgoing by Me',
|
|
|
|
};
|
|
|
|
|
2022-07-06 19:06:20 +00:00
|
|
|
export const IncomingByAnotherAuthor = Template.bind({});
|
|
|
|
IncomingByAnotherAuthor.args = {
|
|
|
|
authorTitle: getDefaultConversation().title,
|
|
|
|
isIncoming: true,
|
2022-06-07 00:48:02 +00:00
|
|
|
};
|
|
|
|
IncomingByAnotherAuthor.story = {
|
|
|
|
name: 'Incoming by Another Author',
|
|
|
|
};
|
2020-08-27 17:02:25 +00:00
|
|
|
|
2022-07-06 19:06:20 +00:00
|
|
|
export const IncomingByMe = Template.bind({});
|
|
|
|
IncomingByMe.args = {
|
|
|
|
isFromMe: true,
|
|
|
|
isIncoming: true,
|
2022-06-07 00:48:02 +00:00
|
|
|
};
|
|
|
|
IncomingByMe.story = {
|
|
|
|
name: 'Incoming by Me',
|
|
|
|
};
|
2020-08-27 17:02:25 +00:00
|
|
|
|
2022-11-18 00:45:19 +00:00
|
|
|
export function IncomingOutgoingColors(args: Props): JSX.Element {
|
2020-08-27 17:02:25 +00:00
|
|
|
return (
|
|
|
|
<>
|
2021-05-28 16:15:17 +00:00
|
|
|
{ConversationColors.map(color =>
|
2022-07-06 19:06:20 +00:00
|
|
|
renderInMessage({ ...args, conversationColor: color })
|
2021-05-28 16:15:17 +00:00
|
|
|
)}
|
2020-08-27 17:02:25 +00:00
|
|
|
</>
|
|
|
|
);
|
2022-11-18 00:45:19 +00:00
|
|
|
}
|
2022-07-06 19:06:20 +00:00
|
|
|
IncomingOutgoingColors.args = {};
|
2022-06-07 00:48:02 +00:00
|
|
|
IncomingOutgoingColors.story = {
|
|
|
|
name: 'Incoming/Outgoing Colors',
|
|
|
|
};
|
|
|
|
|
2022-07-06 19:06:20 +00:00
|
|
|
export const ImageOnly = Template.bind({});
|
|
|
|
ImageOnly.args = {
|
|
|
|
text: '',
|
|
|
|
rawAttachment: {
|
|
|
|
contentType: IMAGE_PNG,
|
|
|
|
fileName: 'sax.png',
|
|
|
|
isVoiceMessage: false,
|
|
|
|
thumbnail: {
|
2020-08-27 17:02:25 +00:00
|
|
|
contentType: IMAGE_PNG,
|
2022-07-06 19:06:20 +00:00
|
|
|
height: 100,
|
|
|
|
width: 100,
|
|
|
|
path: pngUrl,
|
|
|
|
objectUrl: pngUrl,
|
2020-08-27 17:02:25 +00:00
|
|
|
},
|
2022-07-06 19:06:20 +00:00
|
|
|
},
|
2022-06-07 00:48:02 +00:00
|
|
|
};
|
|
|
|
|
2022-07-06 19:06:20 +00:00
|
|
|
export const ImageAttachment = Template.bind({});
|
|
|
|
ImageAttachment.args = {
|
|
|
|
rawAttachment: {
|
|
|
|
contentType: IMAGE_PNG,
|
|
|
|
fileName: 'sax.png',
|
|
|
|
isVoiceMessage: false,
|
|
|
|
thumbnail: {
|
2020-08-27 17:02:25 +00:00
|
|
|
contentType: IMAGE_PNG,
|
2022-07-06 19:06:20 +00:00
|
|
|
height: 100,
|
|
|
|
width: 100,
|
|
|
|
path: pngUrl,
|
|
|
|
objectUrl: pngUrl,
|
2020-08-27 17:02:25 +00:00
|
|
|
},
|
2022-07-06 19:06:20 +00:00
|
|
|
},
|
2022-06-07 00:48:02 +00:00
|
|
|
};
|
2020-08-27 17:02:25 +00:00
|
|
|
|
2022-07-06 19:06:20 +00:00
|
|
|
export const ImageAttachmentNoThumbnail = Template.bind({});
|
|
|
|
ImageAttachmentNoThumbnail.args = {
|
|
|
|
rawAttachment: {
|
|
|
|
contentType: IMAGE_PNG,
|
|
|
|
fileName: 'sax.png',
|
|
|
|
isVoiceMessage: false,
|
|
|
|
},
|
2022-06-07 00:48:02 +00:00
|
|
|
};
|
2022-07-06 19:06:20 +00:00
|
|
|
ImageAttachmentNoThumbnail.story = {
|
2022-06-07 00:48:02 +00:00
|
|
|
name: 'Image Attachment w/o Thumbnail',
|
|
|
|
};
|
|
|
|
|
2022-07-06 19:06:20 +00:00
|
|
|
export const ImageTapToView = Template.bind({});
|
|
|
|
ImageTapToView.args = {
|
|
|
|
text: '',
|
|
|
|
isViewOnce: true,
|
|
|
|
rawAttachment: {
|
|
|
|
contentType: IMAGE_PNG,
|
|
|
|
fileName: 'sax.png',
|
|
|
|
isVoiceMessage: false,
|
|
|
|
},
|
2022-06-07 00:48:02 +00:00
|
|
|
};
|
|
|
|
ImageTapToView.story = {
|
|
|
|
name: 'Image Tap-to-View',
|
|
|
|
};
|
|
|
|
|
2022-07-06 19:06:20 +00:00
|
|
|
export const VideoOnly = Template.bind({});
|
|
|
|
VideoOnly.args = {
|
|
|
|
rawAttachment: {
|
|
|
|
contentType: VIDEO_MP4,
|
|
|
|
fileName: 'great-video.mp4',
|
|
|
|
isVoiceMessage: false,
|
|
|
|
thumbnail: {
|
|
|
|
contentType: IMAGE_PNG,
|
|
|
|
height: 100,
|
|
|
|
width: 100,
|
|
|
|
path: pngUrl,
|
|
|
|
objectUrl: pngUrl,
|
2020-08-27 17:02:25 +00:00
|
|
|
},
|
2022-07-06 19:06:20 +00:00
|
|
|
},
|
|
|
|
text: undefined,
|
2022-06-07 00:48:02 +00:00
|
|
|
};
|
2020-08-27 17:02:25 +00:00
|
|
|
|
2022-07-06 19:06:20 +00:00
|
|
|
export const VideoAttachment = Template.bind({});
|
|
|
|
VideoAttachment.args = {
|
|
|
|
rawAttachment: {
|
|
|
|
contentType: VIDEO_MP4,
|
|
|
|
fileName: 'great-video.mp4',
|
|
|
|
isVoiceMessage: false,
|
|
|
|
thumbnail: {
|
|
|
|
contentType: IMAGE_PNG,
|
|
|
|
height: 100,
|
|
|
|
width: 100,
|
|
|
|
path: pngUrl,
|
|
|
|
objectUrl: pngUrl,
|
2020-08-27 17:02:25 +00:00
|
|
|
},
|
2022-07-06 19:06:20 +00:00
|
|
|
},
|
2022-06-07 00:48:02 +00:00
|
|
|
};
|
2020-08-27 17:02:25 +00:00
|
|
|
|
2022-07-06 19:06:20 +00:00
|
|
|
export const VideoAttachmentNoThumbnail = Template.bind({});
|
|
|
|
VideoAttachmentNoThumbnail.args = {
|
|
|
|
rawAttachment: {
|
|
|
|
contentType: VIDEO_MP4,
|
|
|
|
fileName: 'great-video.mp4',
|
|
|
|
isVoiceMessage: false,
|
|
|
|
},
|
2022-06-07 00:48:02 +00:00
|
|
|
};
|
2022-07-06 19:06:20 +00:00
|
|
|
VideoAttachmentNoThumbnail.story = {
|
2022-06-07 00:48:02 +00:00
|
|
|
name: 'Video Attachment w/o Thumbnail',
|
|
|
|
};
|
2020-08-27 17:02:25 +00:00
|
|
|
|
2022-07-06 19:06:20 +00:00
|
|
|
export const VideoTapToView = Template.bind({});
|
|
|
|
VideoTapToView.args = {
|
|
|
|
text: '',
|
|
|
|
isViewOnce: true,
|
|
|
|
rawAttachment: {
|
|
|
|
contentType: VIDEO_MP4,
|
|
|
|
fileName: 'great-video.mp4',
|
|
|
|
isVoiceMessage: false,
|
|
|
|
},
|
2022-06-07 00:48:02 +00:00
|
|
|
};
|
|
|
|
VideoTapToView.story = {
|
|
|
|
name: 'Video Tap-to-View',
|
|
|
|
};
|
|
|
|
|
2022-07-06 19:06:20 +00:00
|
|
|
export const GiftBadge = TemplateInMessage.bind({});
|
|
|
|
GiftBadge.args = {
|
|
|
|
text: "Some text which shouldn't be rendered",
|
|
|
|
isGiftBadge: true,
|
|
|
|
};
|
|
|
|
|
|
|
|
export const AudioOnly = Template.bind({});
|
|
|
|
AudioOnly.args = {
|
|
|
|
rawAttachment: {
|
|
|
|
contentType: AUDIO_MP3,
|
|
|
|
fileName: 'great-video.mp3',
|
|
|
|
isVoiceMessage: false,
|
|
|
|
},
|
|
|
|
text: undefined,
|
|
|
|
};
|
|
|
|
|
|
|
|
export const AudioAttachment = Template.bind({});
|
|
|
|
AudioAttachment.args = {
|
|
|
|
rawAttachment: {
|
|
|
|
contentType: AUDIO_MP3,
|
|
|
|
fileName: 'great-video.mp3',
|
|
|
|
isVoiceMessage: false,
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
|
|
|
export const VoiceMessageOnly = Template.bind({});
|
|
|
|
VoiceMessageOnly.args = {
|
|
|
|
rawAttachment: {
|
|
|
|
contentType: AUDIO_MP3,
|
|
|
|
fileName: 'great-video.mp3',
|
|
|
|
isVoiceMessage: true,
|
|
|
|
},
|
|
|
|
text: undefined,
|
|
|
|
};
|
|
|
|
|
|
|
|
export const VoiceMessageAttachment = Template.bind({});
|
|
|
|
VoiceMessageAttachment.args = {
|
|
|
|
rawAttachment: {
|
|
|
|
contentType: AUDIO_MP3,
|
|
|
|
fileName: 'great-video.mp3',
|
|
|
|
isVoiceMessage: true,
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
|
|
|
export const OtherFileOnly = Template.bind({});
|
|
|
|
OtherFileOnly.args = {
|
|
|
|
rawAttachment: {
|
|
|
|
contentType: stringToMIMEType('application/json'),
|
|
|
|
fileName: 'great-data.json',
|
|
|
|
isVoiceMessage: false,
|
|
|
|
},
|
|
|
|
text: undefined,
|
|
|
|
};
|
|
|
|
|
|
|
|
export const MediaTapToView = Template.bind({});
|
|
|
|
MediaTapToView.args = {
|
|
|
|
text: '',
|
|
|
|
isViewOnce: true,
|
|
|
|
rawAttachment: {
|
|
|
|
contentType: AUDIO_MP3,
|
|
|
|
fileName: 'great-video.mp3',
|
|
|
|
isVoiceMessage: false,
|
|
|
|
},
|
2022-06-07 00:48:02 +00:00
|
|
|
};
|
|
|
|
MediaTapToView.story = {
|
|
|
|
name: 'Media Tap-to-View',
|
|
|
|
};
|
|
|
|
|
2022-07-06 19:06:20 +00:00
|
|
|
export const OtherFileAttachment = Template.bind({});
|
|
|
|
OtherFileAttachment.args = {
|
|
|
|
rawAttachment: {
|
|
|
|
contentType: stringToMIMEType('application/json'),
|
|
|
|
fileName: 'great-data.json',
|
|
|
|
isVoiceMessage: false,
|
|
|
|
},
|
2022-06-07 00:48:02 +00:00
|
|
|
};
|
2020-08-27 17:02:25 +00:00
|
|
|
|
2022-07-06 19:06:20 +00:00
|
|
|
export const LongMessageAttachmentShouldBeHidden = Template.bind({});
|
|
|
|
LongMessageAttachmentShouldBeHidden.args = {
|
|
|
|
rawAttachment: {
|
|
|
|
contentType: LONG_MESSAGE,
|
|
|
|
fileName: 'signal-long-message-123.txt',
|
|
|
|
isVoiceMessage: false,
|
|
|
|
},
|
2022-06-07 00:48:02 +00:00
|
|
|
};
|
|
|
|
LongMessageAttachmentShouldBeHidden.story = {
|
|
|
|
name: 'Long message attachment (should be hidden)',
|
|
|
|
};
|
|
|
|
|
2022-07-06 19:06:20 +00:00
|
|
|
export const NoCloseButton = Template.bind({});
|
|
|
|
NoCloseButton.args = {
|
|
|
|
onClose: undefined,
|
2022-06-07 00:48:02 +00:00
|
|
|
};
|
2020-08-27 17:02:25 +00:00
|
|
|
|
2022-07-06 19:06:20 +00:00
|
|
|
export const MessageNotFound = TemplateInMessage.bind({});
|
|
|
|
MessageNotFound.args = {
|
|
|
|
referencedMessageNotFound: true,
|
2022-06-07 00:48:02 +00:00
|
|
|
};
|
2020-08-27 17:02:25 +00:00
|
|
|
|
2022-07-06 19:06:20 +00:00
|
|
|
export const MissingTextAttachment = Template.bind({});
|
|
|
|
MissingTextAttachment.args = {
|
|
|
|
text: undefined,
|
2022-06-07 00:48:02 +00:00
|
|
|
};
|
|
|
|
MissingTextAttachment.story = {
|
|
|
|
name: 'Missing Text & Attachment',
|
|
|
|
};
|
2020-09-16 22:42:48 +00:00
|
|
|
|
2022-07-06 19:06:20 +00:00
|
|
|
export const MentionOutgoingAnotherAuthor = Template.bind({});
|
|
|
|
MentionOutgoingAnotherAuthor.args = {
|
|
|
|
authorTitle: 'Tony Stark',
|
|
|
|
text: '@Captain America Lunch later?',
|
2022-06-07 00:48:02 +00:00
|
|
|
};
|
|
|
|
MentionOutgoingAnotherAuthor.story = {
|
|
|
|
name: '@mention + outgoing + another author',
|
|
|
|
};
|
|
|
|
|
2022-07-06 19:06:20 +00:00
|
|
|
export const MentionOutgoingMe = Template.bind({});
|
|
|
|
MentionOutgoingMe.args = {
|
|
|
|
isFromMe: true,
|
|
|
|
text: '@Captain America Lunch later?',
|
2022-06-07 00:48:02 +00:00
|
|
|
};
|
|
|
|
MentionOutgoingMe.story = {
|
|
|
|
name: '@mention + outgoing + me',
|
|
|
|
};
|
|
|
|
|
2022-07-06 19:06:20 +00:00
|
|
|
export const MentionIncomingAnotherAuthor = Template.bind({});
|
|
|
|
MentionIncomingAnotherAuthor.args = {
|
|
|
|
authorTitle: 'Captain America',
|
|
|
|
isIncoming: true,
|
|
|
|
text: '@Tony Stark sure',
|
2022-06-07 00:48:02 +00:00
|
|
|
};
|
|
|
|
MentionIncomingAnotherAuthor.story = {
|
|
|
|
name: '@mention + incoming + another author',
|
|
|
|
};
|
2020-09-16 22:42:48 +00:00
|
|
|
|
2022-07-06 19:06:20 +00:00
|
|
|
export const MentionIncomingMe = Template.bind({});
|
|
|
|
MentionIncomingMe.args = {
|
|
|
|
isFromMe: true,
|
|
|
|
isIncoming: true,
|
|
|
|
text: '@Tony Stark sure',
|
2022-06-07 00:48:02 +00:00
|
|
|
};
|
|
|
|
MentionIncomingMe.story = {
|
|
|
|
name: '@mention + incoming + me',
|
|
|
|
};
|
2021-05-28 16:15:17 +00:00
|
|
|
|
2022-11-18 00:45:19 +00:00
|
|
|
export function CustomColor(args: Props): JSX.Element {
|
|
|
|
return (
|
|
|
|
<>
|
|
|
|
<Quote
|
|
|
|
{...args}
|
|
|
|
customColor={{
|
|
|
|
start: { hue: 82, saturation: 35 },
|
|
|
|
}}
|
|
|
|
/>
|
|
|
|
<Quote
|
|
|
|
{...args}
|
|
|
|
isIncoming={false}
|
|
|
|
text="A gradient"
|
|
|
|
customColor={{
|
|
|
|
deg: 192,
|
|
|
|
start: { hue: 304, saturation: 85 },
|
|
|
|
end: { hue: 231, saturation: 76 },
|
|
|
|
}}
|
|
|
|
/>
|
|
|
|
</>
|
|
|
|
);
|
|
|
|
}
|
2022-07-06 19:06:20 +00:00
|
|
|
CustomColor.args = {
|
|
|
|
isIncoming: true,
|
|
|
|
text: 'Solid + Gradient',
|
|
|
|
};
|
|
|
|
|
|
|
|
export const IsStoryReply = Template.bind({});
|
|
|
|
IsStoryReply.args = {
|
|
|
|
text: 'Wow!',
|
|
|
|
authorTitle: 'Amanda',
|
|
|
|
isStoryReply: true,
|
|
|
|
moduleClassName: 'StoryReplyQuote',
|
|
|
|
onClose: undefined,
|
|
|
|
rawAttachment: {
|
|
|
|
contentType: VIDEO_MP4,
|
|
|
|
fileName: 'great-video.mp4',
|
|
|
|
isVoiceMessage: false,
|
|
|
|
},
|
2022-06-07 00:48:02 +00:00
|
|
|
};
|
|
|
|
IsStoryReply.story = {
|
|
|
|
name: 'isStoryReply',
|
|
|
|
};
|
|
|
|
|
2022-07-06 19:06:20 +00:00
|
|
|
export const IsStoryReplyEmoji = Template.bind({});
|
|
|
|
IsStoryReplyEmoji.args = {
|
|
|
|
authorTitle: getDefaultConversation().firstName,
|
|
|
|
isStoryReply: true,
|
|
|
|
moduleClassName: 'StoryReplyQuote',
|
|
|
|
onClose: undefined,
|
|
|
|
rawAttachment: {
|
|
|
|
contentType: IMAGE_PNG,
|
|
|
|
fileName: 'sax.png',
|
|
|
|
isVoiceMessage: false,
|
|
|
|
thumbnail: {
|
|
|
|
contentType: IMAGE_PNG,
|
|
|
|
height: 100,
|
|
|
|
width: 100,
|
|
|
|
path: pngUrl,
|
|
|
|
objectUrl: pngUrl,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
reactionEmoji: '🏋️',
|
2022-06-07 00:48:02 +00:00
|
|
|
};
|
|
|
|
IsStoryReplyEmoji.story = {
|
|
|
|
name: 'isStoryReply emoji',
|
|
|
|
};
|
2022-11-30 21:47:54 +00:00
|
|
|
|
|
|
|
export const Payment = Template.bind({});
|
|
|
|
Payment.args = {
|
|
|
|
text: '',
|
|
|
|
payment: {
|
|
|
|
kind: PaymentEventKind.Notification,
|
|
|
|
note: null,
|
|
|
|
},
|
|
|
|
};
|