mirror of
https://git.kescher.at/CatCatNya/catstodon.git
synced 2025-01-22 20:24:05 +01:00
43 lines
1.2 KiB
TypeScript
43 lines
1.2 KiB
TypeScript
|
import classNames from 'classnames';
|
||
|
|
||
|
import CheckIcon from '@/material-icons/400-24px/check.svg?react';
|
||
|
import { Icon } from 'flavours/glitch/components/icon';
|
||
|
import { useLinks } from 'flavours/glitch/hooks/useLinks';
|
||
|
import type { Account } from 'flavours/glitch/models/account';
|
||
|
|
||
|
export const AccountFields: React.FC<{
|
||
|
fields: Account['fields'];
|
||
|
limit: number;
|
||
|
}> = ({ fields, limit = -1 }) => {
|
||
|
const handleClick = useLinks();
|
||
|
|
||
|
if (fields.size === 0) {
|
||
|
return null;
|
||
|
}
|
||
|
|
||
|
return (
|
||
|
<div className='account-fields' onClickCapture={handleClick}>
|
||
|
{fields.take(limit).map((pair, i) => (
|
||
|
<dl
|
||
|
key={i}
|
||
|
className={classNames({ verified: pair.get('verified_at') })}
|
||
|
>
|
||
|
<dt
|
||
|
dangerouslySetInnerHTML={{ __html: pair.get('name_emojified') }}
|
||
|
className='translate'
|
||
|
/>
|
||
|
|
||
|
<dd className='translate' title={pair.get('value_plain') ?? ''}>
|
||
|
{pair.get('verified_at') && (
|
||
|
<Icon id='check' icon={CheckIcon} className='verified__mark' />
|
||
|
)}
|
||
|
<span
|
||
|
dangerouslySetInnerHTML={{ __html: pair.get('value_emojified') }}
|
||
|
/>
|
||
|
</dd>
|
||
|
</dl>
|
||
|
))}
|
||
|
</div>
|
||
|
);
|
||
|
};
|