mirror of
https://github.com/owncast/owncast.git
synced 2024-11-29 11:39:08 +03:00
Add bot user badge. Closes #2681
This commit is contained in:
parent
84ddf0dcfe
commit
1ee71aecaa
5 changed files with 55 additions and 1 deletions
|
@ -150,6 +150,7 @@ export const ChatContainer: FC<ChatContainerProps> = ({
|
|||
sentBySelf={message.user?.id === chatUserId} // The local user sent this message
|
||||
sameUserAsLast={shouldCollapseMessages(messages, index)}
|
||||
isAuthorModerator={(message as ChatMessage).user.scopes?.includes('MODERATOR')}
|
||||
isAuthorBot={(message as ChatMessage).user.scopes?.includes('BOT')}
|
||||
isAuthorAuthenticated={message.user?.authenticated}
|
||||
key={message.id}
|
||||
/>
|
||||
|
|
17
web/components/chat/ChatUserBadge/BotUserBadge.tsx
Normal file
17
web/components/chat/ChatUserBadge/BotUserBadge.tsx
Normal file
|
@ -0,0 +1,17 @@
|
|||
import dynamic from 'next/dynamic';
|
||||
import React, { FC } from 'react';
|
||||
import { ChatUserBadge } from './ChatUserBadge';
|
||||
|
||||
// Lazy loaded components
|
||||
|
||||
const BulbFilled = dynamic(() => import('@ant-design/icons/BulbFilled'), {
|
||||
ssr: false,
|
||||
});
|
||||
|
||||
export type BotBadgeProps = {
|
||||
userColor: number;
|
||||
};
|
||||
|
||||
export const BotUserBadge: FC<BotBadgeProps> = ({ userColor }) => (
|
||||
<ChatUserBadge badge={<BulbFilled />} userColor={userColor} title="Bot" />
|
||||
);
|
|
@ -3,6 +3,7 @@ import { ComponentStory, ComponentMeta } from '@storybook/react';
|
|||
import { ChatUserBadge } from './ChatUserBadge';
|
||||
import { ModerationBadge } from './ModerationBadge';
|
||||
import { AuthedUserBadge } from './AuthedUserBadge';
|
||||
import { BotUserBadge } from './BotUserBadge';
|
||||
|
||||
export default {
|
||||
title: 'owncast/Chat/Messages/User Flag',
|
||||
|
@ -24,6 +25,8 @@ const AuthedTemplate: ComponentStory<typeof ModerationBadge> = args => (
|
|||
<AuthedUserBadge {...args} />
|
||||
);
|
||||
|
||||
const BotTemplate: ComponentStory<typeof BotUserBadge> = args => <BotUserBadge {...args} />;
|
||||
|
||||
export const Authenticated = AuthedTemplate.bind({});
|
||||
Authenticated.args = {
|
||||
userColor: '3',
|
||||
|
@ -34,6 +37,11 @@ Moderator.args = {
|
|||
userColor: '5',
|
||||
};
|
||||
|
||||
export const Bot = BotTemplate.bind({});
|
||||
Bot.args = {
|
||||
userColor: '7',
|
||||
};
|
||||
|
||||
export const Generic = Template.bind({});
|
||||
Generic.args = {
|
||||
badge: '?',
|
||||
|
|
|
@ -89,6 +89,22 @@ const authenticatedUserMessage: ChatMessage = JSON.parse(`{
|
|||
},
|
||||
"body": "I am an authenticated user."}`);
|
||||
|
||||
const botUserMessage: ChatMessage = JSON.parse(`{
|
||||
"type": "CHAT",
|
||||
"id": "wY-MEXwnR",
|
||||
"timestamp": "2022-04-28T20:30:27.001762726Z",
|
||||
"user": {
|
||||
"id": "h_5GQ6E7R",
|
||||
"displayName": "EliteMooseTaskForce",
|
||||
"displayColor": 7,
|
||||
"createdAt": "2022-03-24T03:52:37.966584694Z",
|
||||
"previousNames": ["gifted-nobel", "EliteMooseTaskForce"],
|
||||
"nameChangedAt": "2022-04-26T23:56:05.531287897Z",
|
||||
"authenticated": true,
|
||||
"scopes": ["bot"]
|
||||
},
|
||||
"body": "I am a bot."}`);
|
||||
|
||||
export const WithoutModeratorMenu = Template.bind({});
|
||||
WithoutModeratorMenu.args = {
|
||||
message: standardMessage,
|
||||
|
@ -121,6 +137,13 @@ FromAuthenticatedUser.args = {
|
|||
isAuthorAuthenticated: true,
|
||||
};
|
||||
|
||||
export const FromBotUser = Template.bind({});
|
||||
FromBotUser.args = {
|
||||
message: botUserMessage,
|
||||
showModeratorMenu: false,
|
||||
isAuthorBot: true,
|
||||
};
|
||||
|
||||
export const WithStringHighlighted = Template.bind({});
|
||||
WithStringHighlighted.args = {
|
||||
message: standardMessage,
|
||||
|
|
|
@ -14,6 +14,7 @@ import { accessTokenAtom } from '../../stores/ClientConfigStore';
|
|||
import { User } from '../../../interfaces/user.model';
|
||||
import { AuthedUserBadge } from '../ChatUserBadge/AuthedUserBadge';
|
||||
import { ModerationBadge } from '../ChatUserBadge/ModerationBadge';
|
||||
import { BotUserBadge } from '../ChatUserBadge/BotUserBadge';
|
||||
|
||||
// Lazy loaded components
|
||||
|
||||
|
@ -35,6 +36,7 @@ export type ChatUserMessageProps = {
|
|||
sameUserAsLast: boolean;
|
||||
isAuthorModerator: boolean;
|
||||
isAuthorAuthenticated: boolean;
|
||||
isAuthorBot: boolean;
|
||||
};
|
||||
|
||||
export type UserTooltipProps = {
|
||||
|
@ -61,6 +63,7 @@ export const ChatUserMessage: FC<ChatUserMessageProps> = ({
|
|||
sameUserAsLast,
|
||||
isAuthorModerator,
|
||||
isAuthorAuthenticated,
|
||||
isAuthorBot,
|
||||
}) => {
|
||||
const { id: messageId, body, user, timestamp } = message;
|
||||
const { id: userId, displayName, displayColor } = user;
|
||||
|
@ -76,7 +79,9 @@ export const ChatUserMessage: FC<ChatUserMessageProps> = ({
|
|||
if (isAuthorAuthenticated) {
|
||||
badgeNodes.push(<AuthedUserBadge key="auth" userColor={displayColor} />);
|
||||
}
|
||||
|
||||
if (isAuthorBot) {
|
||||
badgeNodes.push(<BotUserBadge key="bot" userColor={displayColor} />);
|
||||
}
|
||||
return (
|
||||
<div
|
||||
className={cn(
|
||||
|
|
Loading…
Reference in a new issue