pleroma/app/soapbox/features/group/components/group-relationship.tsx

45 lines
1.2 KiB
TypeScript
Raw Normal View History

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