mirror of
https://github.com/blakeblackshear/frigate.git
synced 2026-02-12 06:05:22 +03:00
76 lines
2.0 KiB
TypeScript
76 lines
2.0 KiB
TypeScript
import { Polygon } from "@/types/canvas";
|
|
import { Tooltip, TooltipContent, TooltipTrigger } from "../ui/tooltip";
|
|
import { MdOutlineRestartAlt, MdUndo } from "react-icons/md";
|
|
import { Button } from "../ui/button";
|
|
|
|
type PolygonEditControlsProps = {
|
|
polygons: Polygon[];
|
|
setPolygons: React.Dispatch<React.SetStateAction<Polygon[]>>;
|
|
activePolygonIndex: number | undefined;
|
|
};
|
|
|
|
export default function PolygonEditControls({
|
|
polygons,
|
|
setPolygons,
|
|
activePolygonIndex,
|
|
}: PolygonEditControlsProps) {
|
|
const undo = () => {
|
|
if (activePolygonIndex === undefined || !polygons) {
|
|
return;
|
|
}
|
|
|
|
const updatedPolygons = [...polygons];
|
|
const activePolygon = updatedPolygons[activePolygonIndex];
|
|
updatedPolygons[activePolygonIndex] = {
|
|
...activePolygon,
|
|
points: [...activePolygon.points.slice(0, -1)],
|
|
isFinished: false,
|
|
};
|
|
setPolygons(updatedPolygons);
|
|
};
|
|
|
|
const reset = () => {
|
|
if (activePolygonIndex === undefined || !polygons) {
|
|
return;
|
|
}
|
|
|
|
const updatedPolygons = [...polygons];
|
|
const activePolygon = updatedPolygons[activePolygonIndex];
|
|
updatedPolygons[activePolygonIndex] = {
|
|
...activePolygon,
|
|
points: [],
|
|
isFinished: false,
|
|
};
|
|
setPolygons(updatedPolygons);
|
|
};
|
|
|
|
return (
|
|
<div className="flex flex-row justify-center gap-2">
|
|
<Tooltip>
|
|
<TooltipTrigger asChild>
|
|
<Button
|
|
variant="secondary"
|
|
className="size-6 p-1 rounded-md text-background bg-secondary-foreground"
|
|
onClick={undo}
|
|
>
|
|
<MdUndo />
|
|
</Button>
|
|
</TooltipTrigger>
|
|
<TooltipContent>Undo</TooltipContent>
|
|
</Tooltip>
|
|
<Tooltip>
|
|
<TooltipTrigger asChild>
|
|
<Button
|
|
variant="secondary"
|
|
className="size-6 p-1 rounded-md text-background bg-secondary-foreground"
|
|
onClick={reset}
|
|
>
|
|
<MdOutlineRestartAlt />
|
|
</Button>
|
|
</TooltipTrigger>
|
|
<TooltipContent>Reset</TooltipContent>
|
|
</Tooltip>
|
|
</div>
|
|
);
|
|
}
|