import { FC, useEffect, useState } from "react"; import { observer } from "mobx-react"; import { ChevronLeft } from "lucide-react"; import { TEstimateSystemKeys, TEstimateUpdateStageKeys } from "@plane/types"; import { Button } from "@plane/ui"; // components import { EModalPosition, EModalWidth, ModalCore } from "@/components/core"; import { EstimateUpdateStageOne, EstimatePointEditRoot, EstimatePointSwitchRoot } from "@/components/estimates"; // constants import { EEstimateSystem, EEstimateUpdateStages } from "@/constants/estimates"; // hooks import { useEstimate } from "@/hooks/store"; type TUpdateEstimateModal = { workspaceSlug: string; projectId: string; estimateId: string | undefined; isOpen: boolean; handleClose: () => void; }; export const UpdateEstimateModal: FC = observer((props) => { // props const { workspaceSlug, projectId, estimateId, isOpen, handleClose } = props; // hooks const { asJson: estimate } = useEstimate(estimateId); // states const [estimateEditType, setEstimateEditType] = useState(undefined); const [estimateSystemSwitchType, setEstimateSystemSwitchType] = useState(undefined); useEffect(() => { if (isOpen) { setEstimateEditType(undefined); setEstimateSystemSwitchType(undefined); } }, [isOpen]); const handleEstimateEditType = (type: TEstimateUpdateStageKeys) => { if (type === EEstimateUpdateStages.SWITCH && estimate?.type) setEstimateSystemSwitchType( estimate?.type === EEstimateSystem.CATEGORIES ? EEstimateSystem.POINTS : EEstimateSystem.CATEGORIES ); setEstimateEditType(type); }; return (
{/* heading */}
{estimateEditType && (
setEstimateEditType(undefined)} className="flex-shrink-0 cursor-pointer w-5 h-5 flex justify-center items-center" >
)}
Edit estimate system
{estimateEditType === EEstimateUpdateStages.EDIT && ( )}
{!estimateEditType && } {estimateEditType && estimateId && ( <> {estimateEditType === EEstimateUpdateStages.EDIT && ( )} {estimateEditType === EEstimateUpdateStages.SWITCH && estimateSystemSwitchType && ( )} )}
{estimateEditType === undefined && (
)}
); });