2024-07-18 16:36:09 +02:00
|
|
|
import { createSelector } from '@reduxjs/toolkit';
|
|
|
|
|
|
|
|
import { compareId } from 'flavours/glitch/compare_id';
|
|
|
|
import type { RootState } from 'flavours/glitch/store';
|
|
|
|
|
|
|
|
export const selectUnreadNotificationGroupsCount = createSelector(
|
|
|
|
[
|
|
|
|
(s: RootState) => s.notificationGroups.lastReadId,
|
|
|
|
(s: RootState) => s.notificationGroups.pendingGroups,
|
|
|
|
(s: RootState) => s.notificationGroups.groups,
|
|
|
|
],
|
|
|
|
(notificationMarker, pendingGroups, groups) => {
|
|
|
|
return (
|
|
|
|
groups.filter(
|
|
|
|
(group) =>
|
|
|
|
group.type !== 'gap' &&
|
|
|
|
group.page_max_id &&
|
|
|
|
compareId(group.page_max_id, notificationMarker) > 0,
|
|
|
|
).length +
|
|
|
|
pendingGroups.filter(
|
|
|
|
(group) =>
|
|
|
|
group.type !== 'gap' &&
|
|
|
|
group.page_max_id &&
|
|
|
|
compareId(group.page_max_id, notificationMarker) > 0,
|
|
|
|
).length
|
|
|
|
);
|
|
|
|
},
|
|
|
|
);
|
|
|
|
|
2024-08-07 13:12:42 +02:00
|
|
|
// Whether there is any unread notification according to the user-facing state
|
|
|
|
export const selectAnyPendingNotification = createSelector(
|
|
|
|
[
|
|
|
|
(s: RootState) => s.notificationGroups.readMarkerId,
|
|
|
|
(s: RootState) => s.notificationGroups.groups,
|
|
|
|
],
|
|
|
|
(notificationMarker, groups) => {
|
|
|
|
return groups.some(
|
|
|
|
(group) =>
|
|
|
|
group.type !== 'gap' &&
|
|
|
|
group.page_max_id &&
|
|
|
|
compareId(group.page_max_id, notificationMarker) > 0,
|
|
|
|
);
|
|
|
|
},
|
|
|
|
);
|
|
|
|
|
2024-07-18 16:36:09 +02:00
|
|
|
export const selectPendingNotificationGroupsCount = createSelector(
|
|
|
|
[(s: RootState) => s.notificationGroups.pendingGroups],
|
|
|
|
(pendingGroups) =>
|
|
|
|
pendingGroups.filter((group) => group.type !== 'gap').length,
|
|
|
|
);
|