phanpy/src/components/account-block.jsx

109 lines
2.3 KiB
React
Raw Normal View History

2023-02-12 12:29:03 +01:00
import './account-block.css';
import { useNavigate } from 'react-router-dom';
import niceDateTime from '../utils/nice-date-time';
2023-02-12 12:29:03 +01:00
import states from '../utils/states';
import Avatar from './avatar';
import EmojiText from './emoji-text';
2023-02-12 12:29:03 +01:00
function AccountBlock({
skeleton,
account,
avatarSize = 'xl',
instance,
external,
internal,
2023-02-12 12:29:03 +01:00
onClick,
showActivity = false,
2023-02-12 12:29:03 +01:00
}) {
if (skeleton) {
return (
<div class="account-block skeleton">
<Avatar size={avatarSize} />
<span>
<b></b>
<br />
<span class="account-block-acct">@</span>
2023-02-12 12:29:03 +01:00
</span>
</div>
);
}
const navigate = useNavigate();
const {
id,
acct,
avatar,
avatarStatic,
displayName,
username,
emojis,
url,
statusesCount,
lastStatusAt,
2023-04-10 18:26:43 +02:00
bot,
} = account;
const [_, acct1, acct2] = acct.match(/([^@]+)(@.+)/i) || [, acct];
2023-02-12 12:29:03 +01:00
return (
<a
class="account-block"
href={url}
target={external ? '_blank' : null}
title={`@${acct}`}
onClick={(e) => {
if (external) return;
e.preventDefault();
if (onClick) return onClick(e);
if (internal) {
navigate(`/${instance}/a/${id}`);
} else {
states.showAccount = {
account,
instance,
};
}
2023-02-12 12:29:03 +01:00
}}
>
2023-04-10 18:26:43 +02:00
<Avatar url={avatar} size={avatarSize} squircle={bot} />
2023-02-12 12:29:03 +01:00
<span>
{displayName ? (
<b>
<EmojiText text={displayName} emojis={emojis} />
</b>
2023-02-12 12:29:03 +01:00
) : (
<b>{username}</b>
)}
<br />
<span class="account-block-acct">
@{acct1}
<wbr />
{acct2}
</span>
{showActivity && (
<>
<br />
<small class="last-status-at insignificant">
Posts: {statusesCount}
{!!lastStatusAt && (
<>
{' '}
&middot; Last posted:{' '}
{niceDateTime(lastStatusAt, {
hideTime: true,
})}
</>
)}
</small>
</>
)}
2023-02-12 12:29:03 +01:00
</span>
</a>
);
}
export default AccountBlock;