2022-04-28 08:19:20 +02:00
|
|
|
import React from 'react';
|
|
|
|
import { ComponentStory, ComponentMeta } from '@storybook/react';
|
2022-09-05 03:07:50 +02:00
|
|
|
import { RecoilRoot } from 'recoil';
|
2022-09-07 09:00:28 +02:00
|
|
|
import { ChatUserMessage } from './ChatUserMessage';
|
2022-09-03 20:38:52 +02:00
|
|
|
import { ChatMessage } from '../../../interfaces/chat-message.model';
|
|
|
|
import Mock from '../../../stories/assets/mocks/chatmessage-user.png';
|
2022-04-28 08:19:20 +02:00
|
|
|
|
|
|
|
export default {
|
|
|
|
title: 'owncast/Chat/Messages/Standard user',
|
2022-09-03 20:38:52 +02:00
|
|
|
component: ChatUserMessage,
|
2022-05-13 05:52:19 +02:00
|
|
|
parameters: {
|
|
|
|
design: {
|
|
|
|
type: 'image',
|
|
|
|
url: Mock,
|
|
|
|
scale: 0.5,
|
|
|
|
},
|
|
|
|
docs: {
|
|
|
|
description: {
|
|
|
|
component: `This is the standard text message design that is used when a user sends a message in Owncast chat.`,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2022-09-03 20:38:52 +02:00
|
|
|
} as ComponentMeta<typeof ChatUserMessage>;
|
2022-04-28 08:19:20 +02:00
|
|
|
|
2022-09-05 03:07:50 +02:00
|
|
|
const Template: ComponentStory<typeof ChatUserMessage> = args => (
|
|
|
|
<RecoilRoot>
|
|
|
|
<ChatUserMessage {...args} />
|
|
|
|
</RecoilRoot>
|
|
|
|
);
|
2022-04-28 08:19:20 +02:00
|
|
|
|
2022-04-30 00:09:53 +02:00
|
|
|
const standardMessage: ChatMessage = JSON.parse(`{
|
|
|
|
"type": "CHAT",
|
|
|
|
"id": "wY-MEXwnR",
|
|
|
|
"timestamp": "2022-04-28T20:30:27.001762726Z",
|
|
|
|
"user": {
|
|
|
|
"id": "h_5GQ6E7R",
|
|
|
|
"displayName": "EliteMooseTaskForce",
|
2022-06-29 04:13:44 +02:00
|
|
|
"displayColor": 3,
|
2022-04-30 00:09:53 +02:00
|
|
|
"createdAt": "2022-03-24T03:52:37.966584694Z",
|
|
|
|
"previousNames": ["gifted-nobel", "EliteMooseTaskForce"],
|
|
|
|
"nameChangedAt": "2022-04-26T23:56:05.531287897Z",
|
|
|
|
"scopes": []
|
|
|
|
},
|
|
|
|
"body": "Test message from a regular user."}`);
|
|
|
|
|
|
|
|
const moderatorMessage: ChatMessage = JSON.parse(`{
|
|
|
|
"type": "CHAT",
|
|
|
|
"id": "wY-MEXwnR",
|
|
|
|
"timestamp": "2022-04-28T20:30:27.001762726Z",
|
|
|
|
"user": {
|
|
|
|
"id": "h_5GQ6E7R",
|
|
|
|
"displayName": "EliteMooseTaskForce",
|
2022-06-29 04:13:44 +02:00
|
|
|
"displayColor": 2,
|
2022-04-30 00:09:53 +02:00
|
|
|
"createdAt": "2022-03-24T03:52:37.966584694Z",
|
|
|
|
"previousNames": ["gifted-nobel", "EliteMooseTaskForce"],
|
|
|
|
"nameChangedAt": "2022-04-26T23:56:05.531287897Z",
|
|
|
|
"scopes": ["moderator"]
|
|
|
|
},
|
|
|
|
"body": "I am a moderator user."}`);
|
|
|
|
|
|
|
|
const authenticatedUserMessage: ChatMessage = JSON.parse(`{
|
|
|
|
"type": "CHAT",
|
|
|
|
"id": "wY-MEXwnR",
|
|
|
|
"timestamp": "2022-04-28T20:30:27.001762726Z",
|
|
|
|
"user": {
|
|
|
|
"id": "h_5GQ6E7R",
|
|
|
|
"displayName": "EliteMooseTaskForce",
|
2022-06-29 04:13:44 +02:00
|
|
|
"displayColor": 7,
|
2022-04-30 00:09:53 +02:00
|
|
|
"createdAt": "2022-03-24T03:52:37.966584694Z",
|
|
|
|
"previousNames": ["gifted-nobel", "EliteMooseTaskForce"],
|
|
|
|
"nameChangedAt": "2022-04-26T23:56:05.531287897Z",
|
|
|
|
"authenticated": true,
|
|
|
|
"scopes": []
|
|
|
|
},
|
|
|
|
"body": "I am an authenticated user."}`);
|
|
|
|
|
|
|
|
export const WithoutModeratorMenu = Template.bind({});
|
|
|
|
WithoutModeratorMenu.args = {
|
|
|
|
message: standardMessage,
|
|
|
|
showModeratorMenu: false,
|
|
|
|
};
|
|
|
|
|
|
|
|
export const WithModeratorMenu = Template.bind({});
|
|
|
|
WithModeratorMenu.args = {
|
|
|
|
message: standardMessage,
|
|
|
|
showModeratorMenu: true,
|
|
|
|
};
|
|
|
|
|
|
|
|
export const FromModeratorUser = Template.bind({});
|
|
|
|
FromModeratorUser.args = {
|
|
|
|
message: moderatorMessage,
|
|
|
|
showModeratorMenu: false,
|
2022-08-11 06:41:56 +02:00
|
|
|
isAuthorModerator: true,
|
2022-04-30 00:09:53 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
export const FromAuthenticatedUser = Template.bind({});
|
|
|
|
FromAuthenticatedUser.args = {
|
|
|
|
message: authenticatedUserMessage,
|
|
|
|
showModeratorMenu: false,
|
2022-08-21 23:04:16 +02:00
|
|
|
isAuthorAuthenticated: true,
|
2022-04-30 00:09:53 +02:00
|
|
|
};
|
2022-06-25 06:30:54 +02:00
|
|
|
|
|
|
|
export const WithStringHighlighted = Template.bind({});
|
|
|
|
WithStringHighlighted.args = {
|
|
|
|
message: standardMessage,
|
|
|
|
showModeratorMenu: false,
|
|
|
|
highlightString: 'message',
|
|
|
|
};
|