import React, { Fragment } from "react"; // next import { useRouter } from "next/router"; // react hook form import { useForm, Controller } from "react-hook-form"; import { Transition, Dialog, Listbox } from "@headlessui/react"; import { ChevronDownIcon, CheckIcon } from "@heroicons/react/20/solid"; // date helper import { getDatesAfterCurrentDate, getTimestampAfterCurrentTime } from "helpers/date-time.helper"; // services import userNotificationServices from "services/notifications.service"; // hooks import useToast from "hooks/use-toast"; // components import { PrimaryButton, SecondaryButton } from "components/ui"; // icons import { XMarkIcon } from "components/icons"; type SnoozeModalProps = { isOpen: boolean; onClose: () => void; onSuccess: () => void; notificationId: string | null; }; const dates = getDatesAfterCurrentDate(); const timeStamps = getTimestampAfterCurrentTime(); export const SnoozeNotificationModal: React.FC = (props) => { const { isOpen, onClose, notificationId, onSuccess } = props; const router = useRouter(); const { workspaceSlug } = router.query; const { setToastAlert } = useToast(); const { formState: { isSubmitting }, reset, handleSubmit, control, } = useForm(); const onSubmit = async (formData: any) => { if (!workspaceSlug || !notificationId) return; const dateTime = new Date( `${formData.date.toLocaleDateString()} ${formData.time.toLocaleTimeString()}` ); await userNotificationServices .patchUserNotification(workspaceSlug.toString(), notificationId, { snoozed_till: dateTime, }) .then(() => { onClose(); onSuccess(); setToastAlert({ title: "Notification snoozed", message: "Notification snoozed successfully", type: "success", }); }); }; const handleClose = () => { onClose(); const timeout = setTimeout(() => { reset(); clearTimeout(timeout); }, 500); }; return (
Customize Snooze Time
( {({ open }) => ( <>
{value?.toLocaleTimeString([], { hour: "2-digit", minute: "2-digit", }) || "Select Time"} {timeStamps.map((time, index) => ( `relative cursor-default select-none py-2 pl-3 pr-9 ${ active ? "bg-custom-primary-100 text-custom-text-100" : "text-custom-text-700" }` } value={time.value} > {({ selected, active }) => ( <>
{time.label}
{selected ? ( ) : null} )}
))}
)}
)} />
( {({ open }) => ( <>
{value?.toLocaleDateString([], { day: "numeric", month: "long", year: "numeric", }) || "Select Date"} {dates.map((date, index) => ( `relative cursor-default select-none py-2 pl-3 pr-9 ${ active ? "bg-custom-primary-100 text-custom-text-100" : "text-custom-text-700" }` } value={date.value} > {({ selected, active }) => ( <>
{date.label}
{selected ? ( ) : null} )}
))}
)}
)} />
Cancel Submit
); };