mirror of
https://github.com/makeplane/plane
synced 2024-06-14 14:31:34 +00:00
51 lines
1.4 KiB
TypeScript
51 lines
1.4 KiB
TypeScript
|
import { FC } from "react";
|
||
|
import { observer } from "mobx-react";
|
||
|
import { TOAST_TYPE, ToggleSwitch, setToast } from "@plane/ui";
|
||
|
// hooks
|
||
|
import { useProject, useProjectEstimates } from "@/hooks/store";
|
||
|
|
||
|
type TEstimateDisableSwitch = {
|
||
|
workspaceSlug: string;
|
||
|
projectId: string;
|
||
|
isAdmin: boolean;
|
||
|
};
|
||
|
|
||
|
export const EstimateDisableSwitch: FC<TEstimateDisableSwitch> = observer((props) => {
|
||
|
const { workspaceSlug, projectId, isAdmin } = props;
|
||
|
// hooks
|
||
|
const { updateProject, currentProjectDetails } = useProject();
|
||
|
const { currentActiveEstimateId } = useProjectEstimates();
|
||
|
|
||
|
const currentProjectActiveEstimate = currentProjectDetails?.estimate || undefined;
|
||
|
|
||
|
const disableEstimate = async () => {
|
||
|
if (!workspaceSlug || !projectId) return;
|
||
|
|
||
|
try {
|
||
|
await updateProject(workspaceSlug, projectId, {
|
||
|
estimate: currentProjectActiveEstimate ? null : currentActiveEstimateId,
|
||
|
});
|
||
|
setToast({
|
||
|
type: TOAST_TYPE.SUCCESS,
|
||
|
title: "Success!",
|
||
|
message: currentProjectActiveEstimate ? "Estimates have been disabled" : "Estimates have been enabled",
|
||
|
});
|
||
|
} catch (err) {
|
||
|
setToast({
|
||
|
type: TOAST_TYPE.ERROR,
|
||
|
title: "Error!",
|
||
|
message: "Estimate could not be disabled. Please try again",
|
||
|
});
|
||
|
}
|
||
|
};
|
||
|
|
||
|
return (
|
||
|
<ToggleSwitch
|
||
|
value={Boolean(currentProjectActiveEstimate)}
|
||
|
onChange={disableEstimate}
|
||
|
disabled={!isAdmin}
|
||
|
size="sm"
|
||
|
/>
|
||
|
);
|
||
|
});
|