// react import { useEffect } from "react"; // next import { useRouter } from "next/router"; // react-hook-form import { Controller, useForm } from "react-hook-form"; // hooks import useToast from "lib/hooks/useToast"; // ui import { Loader } from "ui"; // icons import { CalendarDaysIcon, ChartPieIcon, LinkIcon, UserIcon } from "@heroicons/react/24/outline"; // types import { CycleIssueResponse, ICycle } from "types"; // common import { copyTextToClipboard, groupBy } from "constants/common"; import { mutate } from "swr"; import cyclesService from "lib/services/cycles.service"; import { CYCLE_DETAIL } from "constants/api-routes"; type Props = { cycle: ICycle | undefined; isOpen: boolean; cycleIssues: CycleIssueResponse[]; }; const defaultValues: Partial = { start_date: new Date().toString(), end_date: new Date().toString(), }; const CycleDetailSidebar: React.FC = ({ cycle, isOpen, cycleIssues }) => { const router = useRouter(); const { query: { workspaceSlug, projectId }, } = router; const { setToastAlert } = useToast(); const { reset, control } = useForm({ defaultValues, }); const groupedIssues = { backlog: [], unstarted: [], started: [], cancelled: [], completed: [], ...groupBy(cycleIssues ?? [], "issue_detail.state_detail.group"), }; const submitChanges = (data: Partial) => { if (!workspaceSlug || !projectId || !module) return; cyclesService .patchCycle(workspaceSlug as string, projectId as string, cycle?.id ?? "", data) .then((res) => { console.log(res); mutate(CYCLE_DETAIL); }) .catch((e) => { console.log(e); }); }; useEffect(() => { if (cycle) reset({ ...cycle, }); }, [cycle, reset]); return (
{cycle ? ( <>

{cycle.name}

Owned by

{cycle.owned_by.first_name !== "" ? ( <> {cycle.owned_by.first_name} {cycle.owned_by.last_name} ) : ( cycle.owned_by.email )}

Progress

{groupedIssues.completed.length}/{cycleIssues?.length}

Start date

( { submitChanges({ start_date: e.target.value }); onChange(e.target.value); }} className="w-full cursor-pointer rounded-md border bg-transparent px-2 py-1 text-xs shadow-sm duration-300 hover:bg-gray-100 focus:border-indigo-500 focus:outline-none focus:ring-1 focus:ring-indigo-500" /> )} />

End date

( { submitChanges({ end_date: e.target.value }); onChange(e.target.value); }} className="w-full cursor-pointer rounded-md border bg-transparent px-2 py-1 text-xs shadow-sm duration-300 hover:bg-gray-100 focus:border-indigo-500 focus:outline-none focus:ring-1 focus:ring-indigo-500" /> )} />
) : (
)}
); }; export default CycleDetailSidebar;