mirror of
https://github.com/cheeaun/phanpy.git
synced 2025-01-26 10:36:27 +01:00
74 lines
1.7 KiB
JavaScript
74 lines
1.7 KiB
JavaScript
import './name-text.css';
|
|
|
|
import emojifyText from '../utils/emojify-text';
|
|
import states from '../utils/states';
|
|
|
|
import Avatar from './avatar';
|
|
|
|
function NameText({ account, showAvatar, showAcct, short, external, onClick }) {
|
|
const { acct, avatar, avatarStatic, id, url, displayName, emojis } = account;
|
|
let { username } = account;
|
|
|
|
const displayNameWithEmoji = emojifyText(displayName, emojis);
|
|
|
|
if (
|
|
!short &&
|
|
username.toLowerCase().trim() ===
|
|
(displayName || '')
|
|
.replace(/(\:(\w|\+|\-)+\:)(?=|[\!\.\?]|$)/g, '') // Remove shortcodes, regex from https://regex101.com/r/iE9uV0/1
|
|
.replace(/\s+/g, '') // E.g. "My name" === "myname"
|
|
.replace(/[^a-z0-9]/gi, '') // Remove non-alphanumeric characters
|
|
.toLowerCase()
|
|
.trim()
|
|
) {
|
|
username = null;
|
|
}
|
|
|
|
return (
|
|
<a
|
|
class={`name-text ${short ? 'short' : ''}`}
|
|
href={url}
|
|
target={external ? '_blank' : null}
|
|
title={`@${acct}`}
|
|
onClick={(e) => {
|
|
if (external) return;
|
|
e.preventDefault();
|
|
if (onClick) return onClick(e);
|
|
states.showAccount = account;
|
|
}}
|
|
>
|
|
{showAvatar && (
|
|
<>
|
|
<Avatar url={avatar} />{' '}
|
|
</>
|
|
)}
|
|
{displayName && !short ? (
|
|
<>
|
|
<b
|
|
dangerouslySetInnerHTML={{
|
|
__html: displayNameWithEmoji,
|
|
}}
|
|
/>
|
|
{!showAcct && username && (
|
|
<>
|
|
{' '}
|
|
<i>@{username}</i>
|
|
</>
|
|
)}
|
|
</>
|
|
) : short ? (
|
|
<i>@{username}</i>
|
|
) : (
|
|
<b>@{username}</b>
|
|
)}
|
|
{showAcct && (
|
|
<>
|
|
<br />
|
|
<i>@{acct}</i>
|
|
</>
|
|
)}
|
|
</a>
|
|
);
|
|
}
|
|
|
|
export default NameText;
|