import React, { Fragment } from "react"; import Image from "next/image"; // hooks import useTheme from "hooks/use-theme"; // icons import { XMarkIcon, ArchiveIcon, ClockIcon, SortIcon, BellNotificationIcon, } from "components/icons"; import { Popover, Transition, Menu } from "@headlessui/react"; import { ArrowLeftIcon } from "@heroicons/react/20/solid"; // hooks import useUserNotification from "hooks/use-user-notifications"; // components import { Spinner } from "components/ui"; import { SnoozeNotificationModal, NotificationCard } from "components/notifications"; // type import type { NotificationType } from "types"; const notificationTabs: Array<{ label: string; value: NotificationType; }> = [ { label: "My Issues", value: "assigned", }, { label: "Created by me", value: "created", }, { label: "Subscribed", value: "watching", }, ]; export const NotificationPopover = () => { const { notifications, archived, readNotification, selectedNotificationForSnooze, selectedTab, setArchived, setReadNotification, setSelectedNotificationForSnooze, setSelectedTab, setSnoozed, snoozed, notificationsMutate, markNotificationArchivedStatus, markNotificationReadStatus, } = useUserNotification(); // theme context const { collapsed: sidebarCollapse } = useTheme(); return ( <> setSelectedNotificationForSnooze(null)} notificationId={selectedNotificationForSnooze} onSuccess={() => { notificationsMutate(); setSelectedNotificationForSnooze(null); }} /> {({ open: isActive, close: closePopover }) => ( <> {sidebarCollapse ? null : Notifications}

Notifications

{snoozed || archived || readNotification ? (
) : (
)}
{notifications ? ( notifications.length > 0 ? ( notifications.map((notification) => ( )) ) : (
Empty

You{"'"}re updated with all the notifications

You have read all the notifications.

) ) : (
)}
)}
); };