2023-03-08 10:22:10 -08:00
|
|
|
import React from 'react';
|
|
|
|
import { FormattedMessage } from 'react-intl';
|
2023-03-09 08:55:35 -08:00
|
|
|
import { Link } from 'react-router-dom';
|
2023-03-08 10:22:10 -08:00
|
|
|
|
2023-03-14 11:44:48 -07:00
|
|
|
import GroupAvatar from 'soapbox/components/groups/group-avatar';
|
|
|
|
import { Button, HStack, Icon, Stack, Text } from 'soapbox/components/ui';
|
2023-03-20 10:27:22 -07:00
|
|
|
import { useJoinGroup } from 'soapbox/hooks/api';
|
2023-03-08 10:22:10 -08:00
|
|
|
import { Group as GroupEntity } from 'soapbox/types/entities';
|
|
|
|
import { shortNumberFormat } from 'soapbox/utils/numbers';
|
|
|
|
|
|
|
|
interface IGroup {
|
|
|
|
group: GroupEntity
|
|
|
|
withJoinAction?: boolean
|
|
|
|
}
|
|
|
|
|
|
|
|
const GroupListItem = (props: IGroup) => {
|
|
|
|
const { group, withJoinAction = true } = props;
|
|
|
|
|
2023-03-20 10:27:22 -07:00
|
|
|
const joinGroup = useJoinGroup(group);
|
2023-03-09 08:55:35 -08:00
|
|
|
|
|
|
|
const onJoinGroup = () => joinGroup.mutate(group);
|
|
|
|
|
2023-03-08 10:22:10 -08:00
|
|
|
return (
|
|
|
|
<HStack
|
|
|
|
alignItems='center'
|
|
|
|
justifyContent='between'
|
|
|
|
>
|
2023-03-09 08:55:35 -08:00
|
|
|
<Link key={group.id} to={`/groups/${group.id}`}>
|
|
|
|
<HStack alignItems='center' space={2}>
|
2023-03-14 11:44:48 -07:00
|
|
|
<GroupAvatar
|
|
|
|
group={group}
|
2023-03-09 08:55:35 -08:00
|
|
|
size={44}
|
2023-03-08 10:22:10 -08:00
|
|
|
/>
|
|
|
|
|
2023-03-09 08:55:35 -08:00
|
|
|
<Stack>
|
|
|
|
<Text
|
|
|
|
weight='bold'
|
|
|
|
dangerouslySetInnerHTML={{ __html: group.display_name_html }}
|
2023-03-08 10:22:10 -08:00
|
|
|
/>
|
|
|
|
|
2023-03-09 08:55:35 -08:00
|
|
|
<HStack className='text-gray-700 dark:text-gray-600' space={1} alignItems='center'>
|
|
|
|
<Icon
|
|
|
|
className='h-4.5 w-4.5'
|
|
|
|
src={group.locked ? require('@tabler/icons/lock.svg') : require('@tabler/icons/world.svg')}
|
|
|
|
/>
|
|
|
|
|
|
|
|
<Text theme='inherit' tag='span' size='sm' weight='medium'>
|
|
|
|
{group.locked ? (
|
|
|
|
<FormattedMessage id='group.privacy.locked' defaultMessage='Private' />
|
|
|
|
) : (
|
|
|
|
<FormattedMessage id='group.privacy.public' defaultMessage='Public' />
|
|
|
|
)}
|
|
|
|
</Text>
|
2023-03-08 10:22:10 -08:00
|
|
|
|
2023-03-09 08:55:35 -08:00
|
|
|
{typeof group.members_count !== 'undefined' && (
|
|
|
|
<>
|
|
|
|
<span>•</span>
|
|
|
|
<Text theme='inherit' tag='span' size='sm' weight='medium'>
|
|
|
|
{shortNumberFormat(group.members_count)}
|
|
|
|
{' '}
|
|
|
|
<FormattedMessage
|
|
|
|
id='groups.discover.search.results.member_count'
|
|
|
|
defaultMessage='{members, plural, one {member} other {members}}'
|
|
|
|
values={{
|
|
|
|
members: group.members_count,
|
|
|
|
}}
|
|
|
|
/>
|
|
|
|
</Text>
|
|
|
|
</>
|
|
|
|
)}
|
|
|
|
</HStack>
|
|
|
|
</Stack>
|
|
|
|
</HStack>
|
|
|
|
</Link>
|
2023-03-08 10:22:10 -08:00
|
|
|
|
|
|
|
{withJoinAction && (
|
2023-03-09 08:55:35 -08:00
|
|
|
<Button theme='primary' onClick={onJoinGroup} disabled={joinGroup.isLoading}>
|
2023-03-08 10:22:10 -08:00
|
|
|
{group.locked
|
|
|
|
? <FormattedMessage id='group.join.private' defaultMessage='Request Access' />
|
|
|
|
: <FormattedMessage id='group.join.public' defaultMessage='Join Group' />}
|
|
|
|
</Button>
|
|
|
|
)}
|
|
|
|
</HStack>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
export default GroupListItem;
|