You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
56 lines
1.3 KiB
TypeScript
56 lines
1.3 KiB
TypeScript
import React from 'react';
|
|
import classNames from 'classnames';
|
|
|
|
import { Emojify } from './Emojify';
|
|
|
|
type Props = {
|
|
phoneNumber: string;
|
|
name?: string | null;
|
|
profileName?: string | null;
|
|
module?: string;
|
|
boldProfileName?: Boolean;
|
|
compact?: Boolean;
|
|
shouldShowPubkey: Boolean;
|
|
};
|
|
|
|
export const ContactName = (props: Props) => {
|
|
const {
|
|
phoneNumber,
|
|
name,
|
|
profileName,
|
|
module,
|
|
boldProfileName,
|
|
compact,
|
|
shouldShowPubkey,
|
|
} = props;
|
|
const prefix = module ? module : 'module-contact-name';
|
|
|
|
const title = name ? name : phoneNumber;
|
|
const shouldShowProfile = Boolean(profileName || name);
|
|
const styles = (boldProfileName
|
|
? {
|
|
fontWeight: 'bold',
|
|
}
|
|
: {}) as React.CSSProperties;
|
|
const textProfile = profileName || name || window.i18n('anonymous');
|
|
const profileElement = shouldShowProfile ? (
|
|
<span style={styles as any} className={`${prefix}__profile-name`}>
|
|
<Emojify text={textProfile} />
|
|
</span>
|
|
) : null;
|
|
|
|
const pubKeyElement = shouldShowPubkey ? (
|
|
<span className={`${prefix}__profile-number`}>
|
|
<Emojify text={title} />
|
|
</span>
|
|
) : null;
|
|
|
|
return (
|
|
<span className={classNames(prefix, compact && 'compact')} dir="auto">
|
|
{profileElement}
|
|
{shouldShowProfile ? ' ' : null}
|
|
{pubKeyElement}
|
|
</span>
|
|
);
|
|
};
|