33 lines
1,013 B
TypeScript
33 lines
1,013 B
TypeScript
import classNames from 'clsx';
|
|
import React from 'react';
|
|
import { useIntl, defineMessages } from 'react-intl';
|
|
|
|
import { Icon } from 'soapbox/components/ui';
|
|
import { useSoapboxConfig } from 'soapbox/hooks';
|
|
|
|
const messages = defineMessages({
|
|
verified: { id: 'account.verified', defaultMessage: 'Verified Account' },
|
|
});
|
|
|
|
interface IVerificationBadge {
|
|
className?: string,
|
|
}
|
|
|
|
const VerificationBadge: React.FC<IVerificationBadge> = ({ className }) => {
|
|
const intl = useIntl();
|
|
const soapboxConfig = useSoapboxConfig();
|
|
|
|
// Prefer a custom icon if found
|
|
const icon = soapboxConfig.verifiedIcon || require('assets/icons/verified.svg');
|
|
|
|
// Render component based on file extension
|
|
const Element = icon.endsWith('.svg') ? Icon : 'img';
|
|
|
|
return (
|
|
<span className='verified-icon' data-testid='verified-badge'>
|
|
<Element className={classNames('text-accent-500 w-4', className)} src={icon} alt={intl.formatMessage(messages.verified)} />
|
|
</span>
|
|
);
|
|
};
|
|
|
|
export default VerificationBadge;
|