pleroma/app/soapbox/features/group/components/group-relationship.tsx
2023-03-30 12:57:23 -04:00

44 lines
No EOL
1.1 KiB
TypeScript

import React from 'react';
import { FormattedMessage } from 'react-intl';
import { HStack, Icon, Text } from 'soapbox/components/ui';
import { GroupRoles } from 'soapbox/schemas/group-member';
import { Group } from 'soapbox/types/entities';
interface IGroupRelationship {
group: Group
}
const GroupRelationship = ({ group }: IGroupRelationship) => {
const isOwner = group.relationship?.role === GroupRoles.OWNER;
const isAdmin = group.relationship?.role === GroupRoles.ADMIN;
if (!isOwner && !isAdmin) {
return null;
}
return (
<HStack
space={1}
alignItems='center'
data-testid='group-relationship'
>
<Icon
className='h-4 w-4'
src={
isOwner
? require('@tabler/icons/users.svg')
: require('@tabler/icons/gavel.svg')
}
/>
<Text tag='span' weight='medium' size='sm' theme='inherit'>
{isOwner
? <FormattedMessage id='group.role.owner' defaultMessage='Owner' />
: <FormattedMessage id='group.role.admin' defaultMessage='Admin' />}
</Text>
</HStack>
);
};
export default GroupRelationship;