From 4d967163971cddf734f72530a1139b267eb697df Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?H=C3=A5kon=20Fadum?= Date: Fri, 29 Nov 2024 13:52:04 +0100 Subject: [PATCH] Add robot specific stop button on robot page --- .../components/Pages/RobotPage/RobotPage.tsx | 40 ++++++++++++++++++- 1 file changed, 39 insertions(+), 1 deletion(-) diff --git a/frontend/src/components/Pages/RobotPage/RobotPage.tsx b/frontend/src/components/Pages/RobotPage/RobotPage.tsx index 80de16d06..c66dfff60 100644 --- a/frontend/src/components/Pages/RobotPage/RobotPage.tsx +++ b/frontend/src/components/Pages/RobotPage/RobotPage.tsx @@ -1,4 +1,4 @@ -import { Typography } from '@equinor/eds-core-react' +import { Icon, Typography } from '@equinor/eds-core-react' import { useParams } from 'react-router-dom' import styled from 'styled-components' import { BackButton } from 'utils/BackButton' @@ -23,6 +23,11 @@ import { VideoStreamSection } from '../MissionPage/MissionPage' import { useEffect, useState } from 'react' import { VideoStreamWindow } from '../MissionPage/VideoStream/VideoStreamWindow' import { MoveRobotArmSection } from './RobotArmMovement' +import { Icons } from 'utils/icons' +import { tokens } from '@equinor/eds-tokens' +import { StopMissionDialog } from '../FrontPage/MissionOverview/StopDialogs' +import { TaskType } from 'models/Task' +import { useMissionsContext } from 'components/Contexts/MissionRunsContext' const StyledTextButton = styled(StyledButton)` text-align: left; @@ -57,9 +62,22 @@ export const RobotPage = () => { const { enabledRobots } = useRobotContext() const { mediaStreams } = useMediaStreamContext() const [videoMediaStreams, setVideoMediaStreams] = useState([]) + const { ongoingMissions } = useMissionsContext() const selectedRobot = enabledRobots.find((robot) => robot.id === robotId) + const [isDialogOpen, setIsDialogOpen] = useState(false) + const toggleStopMissionDialog = () => { + setIsDialogOpen(!isDialogOpen) + } + + const mission = ongoingMissions.find((mission) => mission.robot.id === selectedRobot?.id) + + let missionTaskType = undefined + if (mission?.tasks.every((task) => task.type === TaskType.Inspection)) missionTaskType = TaskType.Inspection + if (mission?.tasks.every((task) => task.type === TaskType.ReturnHome)) missionTaskType = TaskType.ReturnHome + if (mission?.tasks.every((task) => task.type === TaskType.Localization)) missionTaskType = TaskType.Localization + const returnRobotToHome = () => { if (robotId) { BackendAPICaller.returnRobotToHome(robotId).catch((e) => { @@ -136,6 +154,26 @@ export const RobotPage = () => { {selectedRobot.model.type === RobotType.TaurobInspector && } {TranslateText('Actions')} + { + toggleStopMissionDialog() + }} + > + + {TranslateText('Stop')} {selectedRobot.name} + + {TranslateText('Return robot to home')}