From 7f70cb15d035f0c233b9e62b9e43aa985317c908 Mon Sep 17 00:00:00 2001
From: luxiaotao1123 <t1341870251@163.com>
Date: 星期一, 04 十一月 2024 10:22:45 +0800
Subject: [PATCH] #

---
 zy-acs-flow/src/map/insight/agv/AgvControl.jsx |   55 +++++++++++++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 51 insertions(+), 4 deletions(-)

diff --git a/zy-acs-flow/src/map/insight/agv/AgvControl.jsx b/zy-acs-flow/src/map/insight/agv/AgvControl.jsx
index 6b98bdd..a350946 100644
--- a/zy-acs-flow/src/map/insight/agv/AgvControl.jsx
+++ b/zy-acs-flow/src/map/insight/agv/AgvControl.jsx
@@ -1,4 +1,4 @@
-import React from 'react';
+import React, { useEffect } from 'react';
 import { useTranslate } from "react-admin";
 import { useForm, Controller } from 'react-hook-form';
 import {
@@ -25,7 +25,7 @@
     const theme = useTheme();
     const translate = useTranslate();
 
-    const { control, handleSubmit, reset, watch } = useForm({
+    const { control, handleSubmit, reset, watch, setValue } = useForm({
         defaultValues: {
             taskMode: 'MOVE',
             startCode: '',
@@ -47,10 +47,15 @@
         { value: 'STA_TO_STA', label: translate('page.map.insight.control.type.STA_TO_STA') },
     ];
 
+    useEffect(() => {
+        reset();
+    }, [curAgvNo, reset]);
+
     const onSubmit = (data) => {
         if (curAgvNo) {
-            console.log(data);
-            handleControlAgv(curAgvNo, data);
+            handleControlAgv({ agvNo: curAgvNo, ...data }, () => {
+
+            });
         }
     };
 
@@ -79,29 +84,71 @@
     const {
         options: endCodeOptions,
         setInputValue: setEndCodeInputValue,
+        resetInput: resetEndCodeInput,
     } = useCoolHook('/code/page', 'data');
 
     const {
         options: startLocOptions,
         setInputValue: setStartLocInputValue,
+        resetInput: resetStartLocInput,
     } = useCoolHook('/loc/page', 'locNo');
 
     const {
         options: endLocOptions,
         setInputValue: setEndLocInputValue,
+        resetInput: resetEndLocInput,
     } = useCoolHook('/loc/page', 'locNo');
 
     const {
         options: startStaOptions,
         setInputValue: setStartStaInputValue,
+        resetInput: resetStartStaInput,
     } = useCoolHook('/sta/page', 'staNo');
 
     const {
         options: endStaOptions,
         setInputValue: setEndStaInputValue,
+        resetInput: resetEndStaInput,
     } = useCoolHook('/sta/page', 'staNo');
 
+    useEffect(() => {
+        const fieldsToClear = ['endCode', 'startLocNo', 'endLocNo', 'startStaNo', 'endStaNo'];
 
+        fieldsToClear.forEach(field => {
+            if (!showField(field)) {
+                setValue(field, '');
+
+                switch (field) {
+                    case 'endCode':
+                        resetEndCodeInput();
+                        break;
+                    case 'startLocNo':
+                        resetStartLocInput();
+                        break;
+                    case 'endLocNo':
+                        resetEndLocInput();
+                        break;
+                    case 'startStaNo':
+                        resetStartStaInput();
+                        break;
+                    case 'endStaNo':
+                        resetEndStaInput();
+                        break;
+                    default:
+                        break;
+                }
+            }
+        });
+    }, [
+        taskMode,
+        setValue,
+        showField,
+        resetEndCodeInput,
+        resetStartLocInput,
+        resetEndLocInput,
+        resetStartStaInput,
+        resetEndStaInput
+    ]);
     return (
         <>
             <form onSubmit={handleSubmit(onSubmit)}>

--
Gitblit v1.9.1