import './name-text.css'; import { useLingui } from '@lingui/react'; import { memo } from 'preact/compat'; import { api } from '../utils/api'; import mem from '../utils/mem'; import states from '../utils/states'; import Avatar from './avatar'; import EmojiText from './emoji-text'; const nameCollator = mem((locale) => { const options = { sensitivity: 'base', }; try { return new Intl.Collator(locale || undefined, options); } catch (e) { return new Intl.Collator(undefined, options); } }); function NameText({ account, instance, showAvatar, showAcct, short, external, onClick, }) { const { i18n } = useLingui(); const { acct, avatar, avatarStatic, id, url, displayName, emojis, bot, username, } = account; const [_, acct1, acct2] = acct.match(/([^@]+)(@.+)/i) || [, acct]; if (!instance) instance = api().instance; const trimmedUsername = username.toLowerCase().trim(); const trimmedDisplayName = (displayName || '').toLowerCase().trim(); const shortenedDisplayName = trimmedDisplayName .replace(/(\:(\w|\+|\-)+\:)(?=|[\!\.\?]|$)/g, '') // Remove shortcodes, regex from https://regex101.com/r/iE9uV0/1 .replace(/\s+/g, ''); // E.g. "My name" === "myname" const shortenedAlphaNumericDisplayName = shortenedDisplayName.replace( /[^a-z0-9@\.]/gi, '', ); // Remove non-alphanumeric characters const hideUsername = (!short && (trimmedUsername === trimmedDisplayName || trimmedUsername === shortenedDisplayName || trimmedUsername === shortenedAlphaNumericDisplayName || nameCollator(i18n.locale).compare( trimmedUsername, shortenedDisplayName, ) === 0)) || shortenedAlphaNumericDisplayName === acct.toLowerCase(); return ( { if (external) return; if (e.shiftKey) return; // Save link? 🤷‍♂️ e.preventDefault(); e.stopPropagation(); if (onClick) return onClick(e); if (e.metaKey || e.ctrlKey || e.shiftKey || e.which === 2) { const internalURL = `#/${instance}/a/${id}`; window.open(internalURL, '_blank'); return; } states.showAccount = { account, instance, }; }} > {showAvatar && ( <> {' '} )} {displayName && !short ? ( <> {!showAcct && !hideUsername && ( <> {' '} @{username} )} ) : short ? ( {username} ) : ( {username} )} {showAcct && ( <>
{acct2 ? '' : '@'} {acct1} {!!acct2 && {acct2}} )}
); } export default memo(NameText, (oldProps, newProps) => { // Only care about account.id, the other props usually don't change const { account } = oldProps; const { account: newAccount } = newProps; return account?.acct === newAccount?.acct; });