Helmet: add unread chats count

This commit is contained in:
Alex Gleason 2022-12-07 15:48:32 -06:00
parent dc556248f0
commit d6d327c760
No known key found for this signature in database
GPG key ID: 7211D1F99744FBB7

View file

@ -1,6 +1,7 @@
import React from 'react'; import React from 'react';
import { Helmet as ReactHelmet } from 'react-helmet'; import { Helmet as ReactHelmet } from 'react-helmet';
import { useStatContext } from 'soapbox/contexts/stat-context';
import { useAppSelector, useInstance, useSettings } from 'soapbox/hooks'; import { useAppSelector, useInstance, useSettings } from 'soapbox/hooks';
import { RootState } from 'soapbox/store'; import { RootState } from 'soapbox/store';
import FaviconService from 'soapbox/utils/favicon-service'; import FaviconService from 'soapbox/utils/favicon-service';
@ -9,15 +10,15 @@ FaviconService.initFaviconService();
const getNotifTotals = (state: RootState): number => { const getNotifTotals = (state: RootState): number => {
const notifications = state.notifications.unread || 0; const notifications = state.notifications.unread || 0;
const chats = state.chats.items.reduce((acc: any, curr: any) => acc + Math.min(curr.get('unread', 0), 1), 0);
const reports = state.admin.openReports.count(); const reports = state.admin.openReports.count();
const approvals = state.admin.awaitingApproval.count(); const approvals = state.admin.awaitingApproval.count();
return notifications + chats + reports + approvals; return notifications + reports + approvals;
}; };
const Helmet: React.FC = ({ children }) => { const Helmet: React.FC = ({ children }) => {
const instance = useInstance(); const instance = useInstance();
const unreadCount = useAppSelector((state) => getNotifTotals(state)); const { unreadChatsCount } = useStatContext();
const unreadCount = useAppSelector((state) => getNotifTotals(state) + unreadChatsCount);
const demetricator = useSettings().get('demetricator'); const demetricator = useSettings().get('demetricator');
const hasUnreadNotifications = React.useMemo(() => !(unreadCount < 1 || demetricator), [unreadCount, demetricator]); const hasUnreadNotifications = React.useMemo(() => !(unreadCount < 1 || demetricator), [unreadCount, demetricator]);