263 lines
6.3 KiB
TypeScript
263 lines
6.3 KiB
TypeScript
// Copyright 2022 Signal Messenger, LLC
|
|
// SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
import type { Meta, Story } from '@storybook/react';
|
|
import React from 'react';
|
|
|
|
import { useArgs } from '@storybook/addons';
|
|
import type { PropsType } from './StoryViewsNRepliesModal';
|
|
import * as durations from '../util/durations';
|
|
import enMessages from '../../_locales/en/messages.json';
|
|
import { SendStatus } from '../messages/MessageSendState';
|
|
import { StoryViewsNRepliesModal } from './StoryViewsNRepliesModal';
|
|
import { UUID } from '../types/UUID';
|
|
import { getDefaultConversation } from '../test-both/helpers/getDefaultConversation';
|
|
import { setupI18n } from '../util/setupI18n';
|
|
import { StoryViewTargetType } from '../types/Stories';
|
|
|
|
const i18n = setupI18n('en', enMessages);
|
|
|
|
export default {
|
|
title: 'Components/StoryViewsNRepliesModal',
|
|
component: StoryViewsNRepliesModal,
|
|
argTypes: {
|
|
authorTitle: {
|
|
defaultValue: getDefaultConversation().title,
|
|
},
|
|
canReply: {
|
|
defaultValue: true,
|
|
},
|
|
getPreferredBadge: { action: true },
|
|
hasViewReceiptSetting: {
|
|
control: 'boolean',
|
|
defaultValue: true,
|
|
},
|
|
hasViewsCapability: {
|
|
control: 'boolean',
|
|
defaultValue: false,
|
|
},
|
|
i18n: {
|
|
defaultValue: i18n,
|
|
},
|
|
onClose: { action: true },
|
|
onSetSkinTone: { action: true },
|
|
onReact: { action: true },
|
|
onReply: { action: true },
|
|
onTextTooLong: { action: true },
|
|
onUseEmoji: { action: true },
|
|
preferredReactionEmoji: {
|
|
defaultValue: ['❤️', '👍', '👎', '😂', '😮', '😢'],
|
|
},
|
|
renderEmojiPicker: { action: true },
|
|
replies: {
|
|
defaultValue: [],
|
|
},
|
|
views: {
|
|
defaultValue: [],
|
|
},
|
|
viewTarget: {
|
|
defaultValue: StoryViewTargetType.Views,
|
|
},
|
|
onChangeViewTarget: {
|
|
action: true,
|
|
},
|
|
},
|
|
} as Meta;
|
|
|
|
function getViewsAndReplies() {
|
|
const p1 = getDefaultConversation();
|
|
const p2 = getDefaultConversation();
|
|
const p3 = getDefaultConversation();
|
|
const p4 = getDefaultConversation();
|
|
const p5 = getDefaultConversation();
|
|
const p6 = getDefaultConversation({
|
|
isMe: true,
|
|
});
|
|
|
|
const views = [
|
|
{
|
|
recipient: p1,
|
|
status: SendStatus.Viewed,
|
|
updatedAt: Date.now() - 20 * durations.MINUTE,
|
|
},
|
|
{
|
|
recipient: p2,
|
|
status: SendStatus.Viewed,
|
|
updatedAt: Date.now() - 25 * durations.MINUTE,
|
|
},
|
|
{
|
|
recipient: p3,
|
|
status: SendStatus.Viewed,
|
|
updatedAt: Date.now() - 15 * durations.MINUTE,
|
|
},
|
|
{
|
|
recipient: p4,
|
|
status: SendStatus.Viewed,
|
|
updatedAt: Date.now() - 5 * durations.MINUTE,
|
|
},
|
|
{
|
|
recipient: p5,
|
|
status: SendStatus.Viewed,
|
|
updatedAt: Date.now() - 30 * durations.MINUTE,
|
|
},
|
|
];
|
|
|
|
const replies = [
|
|
{
|
|
author: p2,
|
|
body: 'So cute ❤️',
|
|
conversationId: p2.id,
|
|
id: UUID.generate().toString(),
|
|
timestamp: Date.now() - 24 * durations.MINUTE,
|
|
},
|
|
{
|
|
author: p3,
|
|
body: "That's awesome",
|
|
conversationId: p3.id,
|
|
id: UUID.generate().toString(),
|
|
timestamp: Date.now() - 13 * durations.MINUTE,
|
|
},
|
|
{
|
|
author: p3,
|
|
body: 'Very awesome',
|
|
conversationId: p3.id,
|
|
id: UUID.generate().toString(),
|
|
timestamp: Date.now() - 13 * durations.MINUTE,
|
|
},
|
|
{
|
|
author: p3,
|
|
body: 'Did I mention how awesome this is?',
|
|
conversationId: p3.id,
|
|
id: UUID.generate().toString(),
|
|
timestamp: Date.now() - 12 * durations.MINUTE,
|
|
},
|
|
{
|
|
author: p4,
|
|
conversationId: p4.id,
|
|
id: UUID.generate().toString(),
|
|
reactionEmoji: '❤️',
|
|
timestamp: Date.now() - 5 * durations.MINUTE,
|
|
},
|
|
{
|
|
author: p6,
|
|
body: 'Thanks everyone!',
|
|
conversationId: p6.id,
|
|
id: UUID.generate().toString(),
|
|
sendStateByConversationId: {
|
|
[p1.id]: {
|
|
status: SendStatus.Pending,
|
|
},
|
|
},
|
|
timestamp: Date.now(),
|
|
},
|
|
];
|
|
|
|
return {
|
|
views,
|
|
replies,
|
|
};
|
|
}
|
|
|
|
// eslint-disable-next-line react/function-component-definition
|
|
const Template: Story<PropsType> = args => {
|
|
const [, updateArgs] = useArgs();
|
|
|
|
function onChangeViewTarget(viewTarget: StoryViewTargetType) {
|
|
args.onChangeViewTarget(viewTarget);
|
|
updateArgs({ viewTarget });
|
|
}
|
|
|
|
return (
|
|
<StoryViewsNRepliesModal
|
|
{...args}
|
|
onChangeViewTarget={onChangeViewTarget}
|
|
/>
|
|
);
|
|
};
|
|
|
|
export const CanReply = Template.bind({});
|
|
CanReply.args = {};
|
|
CanReply.storyName = 'Can reply';
|
|
|
|
export const ViewsOnly = Template.bind({});
|
|
ViewsOnly.args = {
|
|
canReply: false,
|
|
hasViewsCapability: true,
|
|
views: getViewsAndReplies().views,
|
|
};
|
|
ViewsOnly.storyName = 'Views only';
|
|
|
|
export const NoViews = Template.bind({});
|
|
NoViews.args = {
|
|
canReply: false,
|
|
hasViewsCapability: true,
|
|
views: [],
|
|
};
|
|
NoViews.storyName = 'No views';
|
|
|
|
export const InAGroupNoReplies = Template.bind({});
|
|
InAGroupNoReplies.args = {
|
|
group: {},
|
|
};
|
|
InAGroupNoReplies.storyName = 'In a group (no replies)';
|
|
|
|
export const InAGroup = Template.bind({});
|
|
{
|
|
const { views, replies } = getViewsAndReplies();
|
|
InAGroup.args = {
|
|
hasViewsCapability: true,
|
|
group: {},
|
|
replies,
|
|
views,
|
|
};
|
|
}
|
|
InAGroup.storyName = 'In a group';
|
|
|
|
export const CantReply = Template.bind({});
|
|
CantReply.args = {
|
|
canReply: false,
|
|
};
|
|
|
|
export const InAGroupCantReply = Template.bind({});
|
|
{
|
|
const { views, replies } = getViewsAndReplies();
|
|
InAGroupCantReply.args = {
|
|
canReply: false,
|
|
group: {},
|
|
replies,
|
|
views,
|
|
};
|
|
}
|
|
InAGroupCantReply.storyName = "In a group (can't reply)";
|
|
|
|
export const ReadReceiptsTurnedOff = Template.bind({});
|
|
ReadReceiptsTurnedOff.args = {
|
|
canReply: false,
|
|
hasViewReceiptSetting: false,
|
|
hasViewsCapability: true,
|
|
views: getViewsAndReplies().views,
|
|
};
|
|
ReadReceiptsTurnedOff.storyName = 'Read receipts turned off';
|
|
|
|
export const InAGroupButLeft = Template.bind({});
|
|
{
|
|
const { replies } = getViewsAndReplies();
|
|
InAGroupButLeft.args = {
|
|
group: { left: true },
|
|
replies,
|
|
};
|
|
}
|
|
InAGroupButLeft.storyName = 'In a group (but left)';
|
|
|
|
export const GroupReadReceiptsOff = Template.bind({});
|
|
{
|
|
const { views, replies } = getViewsAndReplies();
|
|
GroupReadReceiptsOff.args = {
|
|
hasViewReceiptSetting: false,
|
|
hasViewsCapability: true,
|
|
group: {},
|
|
replies,
|
|
views,
|
|
};
|
|
}
|
|
GroupReadReceiptsOff.storyName = 'Read receipts turned off (group)';
|