2022-10-05 22:43:24 -07:00
|
|
|
import { Avatar, Col, Row } from 'antd';
|
|
|
|
import dynamic from 'next/dynamic';
|
|
|
|
import React, { FC } from 'react';
|
2022-12-12 22:54:29 -08:00
|
|
|
import cn from 'classnames';
|
2022-10-05 22:43:24 -07:00
|
|
|
import { ChatSocialMessage as ChatMessage } from '../../../interfaces/chat-social-message.model';
|
|
|
|
import styles from './ChatSocialMessage.module.scss';
|
|
|
|
|
2023-01-10 16:39:12 -08:00
|
|
|
const FollowIcon = dynamic(() => import('./follow.svg'), {
|
|
|
|
ssr: false,
|
|
|
|
});
|
|
|
|
const LikeIcon = dynamic(() => import('./like.svg'), {
|
|
|
|
ssr: false,
|
|
|
|
});
|
|
|
|
const RepostIcon = dynamic(() => import('./repost.svg'), {
|
|
|
|
ssr: false,
|
|
|
|
});
|
2022-04-27 23:19:20 -07:00
|
|
|
|
2022-09-07 09:00:28 +02:00
|
|
|
export interface ChatSocialMessageProps {
|
2022-04-27 23:19:20 -07:00
|
|
|
message: ChatMessage;
|
|
|
|
}
|
|
|
|
|
2022-10-05 22:43:24 -07:00
|
|
|
export const ChatSocialMessage: FC<ChatSocialMessageProps> = ({ message }) => {
|
|
|
|
const { body, title, image, link, type } = message;
|
|
|
|
|
|
|
|
let Icon;
|
|
|
|
|
|
|
|
switch (type.toString()) {
|
2023-02-05 19:58:24 -08:00
|
|
|
case 'FEDIVERSE_ENGAGEMENT_FOLLOW':
|
2022-10-05 22:43:24 -07:00
|
|
|
Icon = FollowIcon;
|
|
|
|
break;
|
2023-02-05 19:58:24 -08:00
|
|
|
case 'FEDIVERSE_ENGAGEMENT_LIKE':
|
2022-10-05 22:43:24 -07:00
|
|
|
Icon = LikeIcon;
|
|
|
|
break;
|
2023-02-05 19:58:24 -08:00
|
|
|
case 'FEDIVERSE_ENGAGEMENT_REPOST':
|
2022-10-05 22:43:24 -07:00
|
|
|
Icon = RepostIcon;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
return (
|
2023-07-11 20:07:58 +00:00
|
|
|
<div className={styles.followerPadding}>
|
|
|
|
<div className={cn([styles.follower, 'chat-message_social'])}>
|
|
|
|
<a href={link} target="_blank" rel="noreferrer">
|
|
|
|
<Row wrap={false}>
|
|
|
|
<Col span={6} className={styles.avatarColumn}>
|
|
|
|
<Avatar src={image} alt="Avatar" className={styles.avatar} size="large">
|
|
|
|
{title.charAt(0).toUpperCase()}
|
|
|
|
</Avatar>
|
2023-02-19 14:57:44 -08:00
|
|
|
|
2023-07-11 20:07:58 +00:00
|
|
|
<Icon className={styles.icon} />
|
|
|
|
</Col>
|
|
|
|
<Col>
|
|
|
|
<Row className={styles.account}>{title}</Row>
|
|
|
|
<Row className={styles.body} dangerouslySetInnerHTML={{ __html: body }} />
|
|
|
|
</Col>
|
|
|
|
</Row>
|
|
|
|
</a>
|
|
|
|
</div>
|
2022-10-05 22:43:24 -07:00
|
|
|
</div>
|
|
|
|
);
|
|
|
|
};
|