feat: 增加系统消息的信息渲染

pull/13/head
moonrailgun 3 years ago
parent b331bd7f23
commit 3dcbad68fd

@ -132,6 +132,7 @@ export type { AppStore, AppState, AppDispatch } from './redux/store';
// utils
export { joinArray } from './utils/array-helper';
export { SYSTEM_USERID } from './utils/consts';
export {
shouldShowMessageTime,
getMessageTimeDiff,

@ -2,3 +2,8 @@
*
*/
export const LANGUAGE_KEY = 'i18n:language';
/**
* id
*/
export const SYSTEM_USERID = '000000000000000000000000';

@ -2,6 +2,7 @@ import React, { useMemo } from 'react';
import {
ChatMessage,
formatShortTime,
SYSTEM_USERID,
t,
useCachedUserInfo,
useChatBoxContext,
@ -53,59 +54,87 @@ const MessageQuote: React.FC<{ payload: ChatMessage }> = React.memo(
);
MessageQuote.displayName = 'MessageQuote';
interface ChatMessageItemProps {
showAvatar: boolean;
payload: ChatMessage;
}
export const ChatMessageItem: React.FC<ChatMessageItemProps> = React.memo(
(props) => {
const { showAvatar, payload } = props;
const userInfo = useCachedUserInfo(payload.author ?? '');
/**
*
*/
const NormalMessage: React.FC<ChatMessageItemProps> = React.memo((props) => {
const { showAvatar, payload } = props;
const userInfo = useCachedUserInfo(payload.author ?? '');
const actions = useChatMessageItemAction(payload);
const actions = useChatMessageItemAction(payload);
return (
<div className="chat-message-item flex px-2 group hover:bg-black hover:bg-opacity-10 relative">
{/* 头像 */}
<div className="w-18 flex items-start justify-center pt-0.5">
{showAvatar ? (
<Avatar size={40} src={userInfo.avatar} name={userInfo.nickname} />
) : (
<div className="hidden group-hover:block opacity-40">
return (
<div className="chat-message-item flex px-2 group hover:bg-black hover:bg-opacity-10 relative">
{/* 头像 */}
<div className="w-18 flex items-start justify-center pt-0.5">
{showAvatar ? (
<Avatar size={40} src={userInfo.avatar} name={userInfo.nickname} />
) : (
<div className="hidden group-hover:block opacity-40">
{formatShortTime(payload.createdAt)}
</div>
)}
</div>
{/* 主体 */}
<div className="flex flex-col flex-1 overflow-auto group">
{showAvatar && (
<div className="flex items-center">
<div className="font-bold">{userInfo.nickname}</div>
<div className="hidden group-hover:block opacity-40 ml-1 text-sm">
{formatShortTime(payload.createdAt)}
</div>
)}
</div>
</div>
)}
{/* 主体 */}
<div className="flex flex-col flex-1 overflow-auto group">
{showAvatar && (
<div className="flex items-center">
<div className="font-bold">{userInfo.nickname}</div>
<div className="hidden group-hover:block opacity-40 ml-1 text-sm">
{formatShortTime(payload.createdAt)}
</div>
</div>
)}
<div className="leading-6 break-words">
<MessageQuote payload={payload} />
<div className="leading-6 break-words">
<MessageQuote payload={payload} />
<span>{getMessageRender(payload.content)}</span>
<span>{getMessageRender(payload.content)}</span>
{/* 解释器按钮 */}
{useRenderPluginMessageInterpreter(payload.content)}
</div>
</div>
{/* 解释器按钮 */}
{useRenderPluginMessageInterpreter(payload.content)}
</div>
{/* 操作 */}
<Dropdown overlay={actions} placement="bottomLeft" trigger={['click']}>
<div className="opacity-0 group-hover:opacity-100 bg-black bg-opacity-5 hover:bg-opacity-10 rounded px-0.5 absolute right-2 top-0.5 cursor-pointer">
<Icon icon="mdi:dots-horizontal" />
</div>
</Dropdown>
</div>
);
});
NormalMessage.displayName = 'NormalMessage';
{/* 操作 */}
<Dropdown overlay={actions} placement="bottomLeft" trigger={['click']}>
<div className="opacity-0 group-hover:opacity-100 bg-black bg-opacity-5 hover:bg-opacity-10 rounded px-0.5 absolute right-2 top-0.5 cursor-pointer">
<Icon icon="mdi:dots-horizontal" />
</div>
</Dropdown>
/**
*
*/
const SystemMessage: React.FC<ChatMessageItemProps> = React.memo(
({ payload }) => {
return (
<div className="text-center">
<div className="bg-black bg-opacity-20 rounded inline-block py-0.5 px-2 my-1 text-sm">
{payload.content}
</div>
</div>
);
}
);
SystemMessage.displayName = 'SystemMessage';
interface ChatMessageItemProps {
showAvatar: boolean;
payload: ChatMessage;
}
export const ChatMessageItem: React.FC<ChatMessageItemProps> = React.memo(
(props) => {
if (props.payload.author === SYSTEM_USERID) {
return <SystemMessage {...props} />;
}
return <NormalMessage {...props} />;
}
);
ChatMessageItem.displayName = 'ChatMessageItem';

Loading…
Cancel
Save