From d0628b492a779097b0569c2e29fde5ba91632b42 Mon Sep 17 00:00:00 2001
From: luxiaotao1123 <t1341870251@163.com>
Date: 星期五, 11 十月 2024 15:59:33 +0800
Subject: [PATCH] #

---
 zy-acs-flow/src/map/settings/CopyDrawer.jsx |  116 +++++++++++++++++++++++++++++++++++++---------------------
 1 files changed, 74 insertions(+), 42 deletions(-)

diff --git a/zy-acs-flow/src/map/settings/CopyDrawer.jsx b/zy-acs-flow/src/map/settings/CopyDrawer.jsx
index 8f6b767..41a495c 100644
--- a/zy-acs-flow/src/map/settings/CopyDrawer.jsx
+++ b/zy-acs-flow/src/map/settings/CopyDrawer.jsx
@@ -1,5 +1,5 @@
 import React, { useEffect } from 'react';
-import { useForm, Controller } from 'react-hook-form';
+import { useForm, useWatch, Controller } from 'react-hook-form';
 import {
     Box,
     Grid,
@@ -15,7 +15,6 @@
     Divider,
     Drawer,
     IconButton,
-    LinearProgress,
     Switch,
     FormControlLabel,
     FormLabel,
@@ -31,11 +30,28 @@
 } from '../constants';
 import { useNotification } from '../Notification';
 
+const incrementOptionsMap = {
+    [DEVICE_TYPE.SHELF]: [
+        { value: 'row', label: 'page.map.settings.config.shelf.row' },
+        { value: 'bay', label: 'page.map.settings.config.shelf.bay' },
+    ],
+    [DEVICE_TYPE.CHARGE]: [
+        { value: 'no', label: 'page.map.settings.config.base.no' },
+    ],
+    [DEVICE_TYPE.STATION]: [
+        { value: 'no', label: 'page.map.settings.config.base.no' },
+    ],
+    [DEVICE_TYPE.POINT]: [
+        { value: 'no', label: 'page.map.settings.config.base.no' },
+    ],
+};
+
 const CopyDrawer = (props) => {
     const { open, onCancel, sprite, value, width = PAGE_DRAWER_WIDTH, handleOnCopy } = props;
     const notify = useNotification();
     const translate = useTranslate();
     const deviceType = sprite?.data?.type;
+    const incrementOptions = incrementOptionsMap[deviceType]
 
     const { control, handleSubmit, reset, watch, setValue, formState: { errors } } = useForm({
         defaultValues: {
@@ -47,12 +63,31 @@
         },
     });
 
+    const autoIncrement = useWatch({ control, name: 'autoIncrement' });
+    const incrementValue = useWatch({ control, name: 'incrementValue' });
+
     useEffect(() => {
-        if (value && Object.keys(value).length > 0) {
-            // setValue('copyDirect', value.copyDirect);
-            // setValue('copyCount', value.copyCount);
+        if (autoIncrement && incrementOptions && incrementOptions.length > 0) {
+            if (!incrementValue) {
+                setValue('incrementValue', incrementOptions[0].value);
+            }
+        } else {
+            setValue('incrementValue', undefined);
         }
-    }, [value, setValue])
+    }, [autoIncrement, incrementOptions, setValue]);
+
+    useEffect(() => {
+        if (sprite && value && Object.keys(value).length > 0) {
+            reset({
+                copyDirect: value.copyDirect || '',
+                copyCount: value.copyCount || '',
+                gap: 0.0,
+                autoIncrement: false,
+                incrementMode: 'ascending',
+                incrementValue: undefined,
+            });
+        }
+    }, [sprite, value, reset, incrementOptions, setValue]);
 
     const handleClose = () => {
         onCancel();
@@ -61,7 +96,6 @@
     const onFormSubmit = (data) => {
         if (data) {
             console.log(data);
-
         }
         if (handleOnCopy) {
             handleOnCopy(data);
@@ -93,18 +127,6 @@
                         <Box p={3}>
                             <Box component="form" onSubmit={handleSubmit(onFormSubmit)} noValidate sx={{ mt: 0 }}>
                                 <Grid container spacing={1.4}>
-
-                                    {/* <Grid item xs={6}>
-                                        <Typography variant="body1">
-                                            {translate('page.map.settings.map.copy.direction')}: {value?.copyDirect}
-                                        </Typography>
-                                    </Grid>
-                                    <Grid item xs={6}>
-                                        <Typography variant="body1">
-                                            {translate('page.map.settings.map.copy.count')}: {value?.copyCount}
-                                        </Typography>
-                                    </Grid> */}
-
                                     <Grid item xs={6}>
                                         <Controller
                                             name="copyDirect"
@@ -181,7 +203,38 @@
                                         />
                                     </Grid>
 
-                                    {watch('autoIncrement') && (
+                                    {(!!incrementOptions?.length && autoIncrement) && (
+                                        <Grid item xs={12}>
+                                            <FormControl fullWidth>
+                                                <FormLabel sx={{ mb: 1 }}>
+                                                    {translate('page.map.settings.map.copy.field.incrementValue')}
+                                                </FormLabel>
+                                                <Controller
+                                                    name='incrementValue'
+                                                    control={control}
+                                                    render={({ field }) => (
+                                                        <ToggleButtonGroup
+                                                            {...field}
+                                                            value={field.value}
+                                                            exclusive
+                                                            onChange={(event, value) => {
+                                                                field.onChange(value);
+                                                            }}
+                                                            fullWidth
+                                                        >
+                                                            {incrementOptions.map((option, idx) => (
+                                                                <ToggleButton key={idx} value={option.value}>
+                                                                    {translate(option.label)}
+                                                                </ToggleButton>
+                                                            ))}
+                                                        </ToggleButtonGroup>
+                                                    )}
+                                                />
+                                            </FormControl>
+                                        </Grid>
+                                    )}
+
+                                    {autoIncrement && (
                                         <Grid item xs={12}>
                                             <FormControl fullWidth>
                                                 <FormLabel sx={{
@@ -215,28 +268,7 @@
                                         </Grid>
                                     )}
 
-                                    {deviceType === DEVICE_TYPE.SHELF && (
-                                        <>
-                                        </>
-                                    )}
-
-                                    {deviceType === DEVICE_TYPE.CHARGE && (
-                                        <>
-                                        </>
-                                    )}
-
-                                    {deviceType === DEVICE_TYPE.STATION && (
-                                        <>
-                                        </>
-                                    )}
-
-                                    {deviceType === DEVICE_TYPE.POINT && (
-                                        <>
-                                        </>
-                                    )}
-
-
-                                    <Grid item xs={12}>
+                                    <Grid item xs={12} mt={2}>
                                         <Divider />
                                     </Grid>
 

--
Gitblit v1.9.1