2023-02-27 05:25:59 -08:00
|
|
|
import React, { forwardRef } from 'react';
|
2023-03-02 11:40:36 -08:00
|
|
|
import { Link } from 'react-router-dom';
|
2023-02-27 05:25:59 -08:00
|
|
|
|
2023-03-14 11:44:48 -07:00
|
|
|
import GroupAvatar from 'soapbox/components/groups/group-avatar';
|
2023-03-28 08:52:25 -07:00
|
|
|
import { HStack, Stack, Text } from 'soapbox/components/ui';
|
|
|
|
import GroupActionButton from 'soapbox/features/group/components/group-action-button';
|
2023-03-02 11:40:36 -08:00
|
|
|
import GroupMemberCount from 'soapbox/features/group/components/group-member-count';
|
|
|
|
import GroupPrivacy from 'soapbox/features/group/components/group-privacy';
|
2023-03-28 08:52:25 -07:00
|
|
|
|
|
|
|
import type { Group } from 'soapbox/schemas';
|
2023-02-27 05:25:59 -08:00
|
|
|
|
|
|
|
interface IGroup {
|
2023-03-28 08:52:25 -07:00
|
|
|
group: Group
|
2023-02-28 07:26:27 -08:00
|
|
|
width?: number
|
2023-02-27 05:25:59 -08:00
|
|
|
}
|
|
|
|
|
2023-03-08 10:22:10 -08:00
|
|
|
const GroupGridItem = forwardRef((props: IGroup, ref: React.ForwardedRef<HTMLDivElement>) => {
|
2023-02-27 05:25:59 -08:00
|
|
|
const { group, width = 'auto' } = props;
|
|
|
|
|
|
|
|
return (
|
|
|
|
<div
|
|
|
|
key={group.id}
|
|
|
|
className='relative flex shrink-0 flex-col space-y-2 px-0.5'
|
|
|
|
style={{
|
|
|
|
width,
|
|
|
|
}}
|
|
|
|
>
|
2023-03-02 11:40:36 -08:00
|
|
|
<Link to={`/groups/${group.id}`}>
|
|
|
|
<Stack
|
2023-04-01 11:37:34 -07:00
|
|
|
className='aspect-h-7 aspect-w-10 h-full w-full overflow-hidden rounded-lg'
|
2023-03-02 11:40:36 -08:00
|
|
|
ref={ref}
|
|
|
|
style={{ minHeight: 180 }}
|
|
|
|
>
|
|
|
|
{group.header && (
|
|
|
|
<img
|
|
|
|
src={group.header}
|
|
|
|
alt='Group cover'
|
|
|
|
className='absolute inset-0 object-cover'
|
|
|
|
/>
|
|
|
|
)}
|
2023-02-27 05:25:59 -08:00
|
|
|
|
2023-03-02 11:40:36 -08:00
|
|
|
<Stack justifyContent='end' className='z-10 p-4 text-white' space={3}>
|
2023-03-14 11:44:48 -07:00
|
|
|
<GroupAvatar
|
|
|
|
group={group}
|
2023-03-02 11:40:36 -08:00
|
|
|
size={44}
|
2023-02-27 05:25:59 -08:00
|
|
|
/>
|
|
|
|
|
2023-03-02 11:40:36 -08:00
|
|
|
<Stack space={1}>
|
|
|
|
<Text
|
|
|
|
weight='bold'
|
|
|
|
dangerouslySetInnerHTML={{ __html: group.display_name_html }}
|
|
|
|
theme='inherit'
|
|
|
|
truncate
|
2023-02-27 05:25:59 -08:00
|
|
|
/>
|
|
|
|
|
2023-03-02 11:40:36 -08:00
|
|
|
<HStack alignItems='center' space={1}>
|
|
|
|
<GroupPrivacy group={group} />
|
|
|
|
<span>•</span>
|
|
|
|
<GroupMemberCount group={group} />
|
|
|
|
</HStack>
|
|
|
|
</Stack>
|
2023-02-27 05:25:59 -08:00
|
|
|
</Stack>
|
|
|
|
|
2023-03-02 11:40:36 -08:00
|
|
|
<div
|
2023-04-01 11:37:34 -07:00
|
|
|
className='absolute inset-x-0 bottom-0 z-0 flex justify-center rounded-b-lg bg-gradient-to-t from-gray-900 to-transparent pb-8 pt-12 transition-opacity duration-500'
|
2023-03-02 11:40:36 -08:00
|
|
|
/>
|
|
|
|
</Stack>
|
|
|
|
</Link>
|
2023-02-27 05:25:59 -08:00
|
|
|
|
2023-03-28 08:52:25 -07:00
|
|
|
<GroupActionButton group={group} />
|
2023-02-27 05:25:59 -08:00
|
|
|
</div>
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
2023-03-08 10:22:10 -08:00
|
|
|
export default GroupGridItem;
|