import React from "react"; import { useNavigate } from "react-router-dom"; import VisualizerPanel from "@/components/control/VisualizerPanel"; import { useToast } from "@/hooks/use-toast"; import DirectFollowerControlPanel from "@/components/control/DirectFollowerControlPanel"; import UrdfViewer from "@/components/UrdfViewer"; import UrdfProcessorInitializer from "@/components/UrdfProcessorInitializer"; import Logo from "@/components/Logo"; const DirectFollowerPage = () => { const navigate = useNavigate(); const { toast } = useToast(); const handleGoBack = async () => { try { // Stop the direct follower control process before navigating back console.log("🛑 Stopping direct follower control..."); const response = await fetch("http://localhost:8000/stop-direct-follower", { method: "POST", }); if (response.ok) { const result = await response.json(); console.log("✅ Direct follower control stopped:", result.message); toast({ title: "Direct Follower Control Stopped", description: result.message || "Direct follower control has been stopped successfully.", }); } else { const errorText = await response.text(); console.warn( "⚠️ Failed to stop direct follower control:", response.status, errorText ); toast({ title: "Warning", description: `Failed to stop direct follower control properly. Status: ${response.status}`, variant: "destructive", }); } } catch (error) { console.error("❌ Error stopping direct follower control:", error); toast({ title: "Error", description: "Failed to communicate with the robot server.", variant: "destructive", }); } finally { // Navigate back regardless of the result navigate("/"); } }; return (