-
Notifications
You must be signed in to change notification settings - Fork 13.4k
Expand file tree
/
Copy pathNavBarSearchItemWithData.tsx
More file actions
42 lines (34 loc) · 1.55 KB
/
NavBarSearchItemWithData.tsx
File metadata and controls
42 lines (34 loc) · 1.55 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
import { SidebarV2ItemIcon } from '@rocket.chat/fuselage';
import type { SubscriptionWithRoom } from '@rocket.chat/ui-contexts';
import type { ComponentProps, ReactElement } from 'react';
import { useTranslation } from 'react-i18next';
import NavBarSearchItem from './NavBarSearchItem';
import { RoomIcon } from '../../components/RoomIcon';
import { roomCoordinator } from '../../lib/rooms/roomCoordinator';
import SidebarItemBadges from '../../sidebarv2/badges/SidebarItemBadges';
import { useUnreadDisplay } from '../../sidebarv2/hooks/useUnreadDisplay';
type NavBarSearchItemWithDataProps = {
room: SubscriptionWithRoom;
id: string;
AvatarTemplate: ReactElement;
} & Partial<ComponentProps<typeof NavBarSearchItem>>;
const NavBarSearchItemWithData = ({ room, AvatarTemplate, ...props }: NavBarSearchItemWithDataProps) => {
const { t } = useTranslation();
const href = roomCoordinator.getRouteLink(room.t, room) || '';
const title = roomCoordinator.getRoomName(room.t, room) || '';
const { unreadTitle, showUnread, highlightUnread: highlighted } = useUnreadDisplay(room);
const icon = <SidebarV2ItemIcon highlighted={highlighted} icon={<RoomIcon room={room} placement='sidebar' size='x20' />} />;
return (
<NavBarSearchItem
{...props}
unread={highlighted}
href={href}
aria-label={showUnread ? t('__unreadTitle__from__roomTitle__', { unreadTitle, roomTitle: title }) : title}
title={title}
icon={icon}
badges={<SidebarItemBadges room={room} roomTitle={title} />}
avatar={AvatarTemplate}
/>
);
};
export default NavBarSearchItemWithData;