From 3c6b8e97be4a2b4c793ddfcc5009fc1e0f00b9bb Mon Sep 17 00:00:00 2001 From: Mohamed Bassem Date: Sun, 30 Nov 2025 15:46:31 +0000 Subject: feat: add a notification badge for list invitations --- apps/web/components/dashboard/sidebar/AllLists.tsx | 2 ++ .../sidebar/InvitationNotificationBadge.tsx | 25 ++++++++++++++++++++++ 2 files changed, 27 insertions(+) create mode 100644 apps/web/components/dashboard/sidebar/InvitationNotificationBadge.tsx (limited to 'apps/web/components/dashboard/sidebar') diff --git a/apps/web/components/dashboard/sidebar/AllLists.tsx b/apps/web/components/dashboard/sidebar/AllLists.tsx index f8b80cba..306bf4b4 100644 --- a/apps/web/components/dashboard/sidebar/AllLists.tsx +++ b/apps/web/components/dashboard/sidebar/AllLists.tsx @@ -24,6 +24,7 @@ import { ZBookmarkListTreeNode } from "@karakeep/shared/utils/listUtils"; import { CollapsibleBookmarkLists } from "../lists/CollapsibleBookmarkLists"; import { EditListModal } from "../lists/EditListModal"; import { ListOptions } from "../lists/ListOptions"; +import { InvitationNotificationBadge } from "./InvitationNotificationBadge"; export default function AllLists({ initialData, @@ -90,6 +91,7 @@ export default function AllLists({ path={`/dashboard/lists`} linkClassName="py-0.5" className="px-0.5" + right={} /> ⭐️} diff --git a/apps/web/components/dashboard/sidebar/InvitationNotificationBadge.tsx b/apps/web/components/dashboard/sidebar/InvitationNotificationBadge.tsx new file mode 100644 index 00000000..e4d7b39f --- /dev/null +++ b/apps/web/components/dashboard/sidebar/InvitationNotificationBadge.tsx @@ -0,0 +1,25 @@ +"use client"; + +import { api } from "@/lib/trpc"; + +export function InvitationNotificationBadge() { + const { data: pendingInvitations } = api.lists.getPendingInvitations.useQuery( + undefined, + { + refetchInterval: 1000 * 60 * 5, + }, + ); + const pendingInvitationsCount = pendingInvitations?.length ?? 0; + + if (pendingInvitationsCount === 0) { + return null; + } + + return ( +
+ + {pendingInvitationsCount} + +
+ ); +} -- cgit v1.2.3-70-g09d2