#
luxiaotao1123
2024-10-12 822d9d9494cc575c1bcdbaa51d68da817236c0b8
zy-acs-flow/src/map/settings/CopyDrawer.jsx
@@ -1,21 +1,26 @@
import React, { useEffect } from 'react';
import { useForm, Controller } from 'react-hook-form';
import { useForm, useWatch, Controller } from 'react-hook-form';
import {
    Box,
    Grid,
    Typography,
    TextField,
    Slider,
    Card,
    CardContent,
    Button,
    Select,
    MenuItem,
    InputLabel,
    useTheme,
    FormControl,
    Stack,
    Divider,
    Drawer,
    IconButton,
    LinearProgress,
    Switch,
    FormControlLabel,
    FormLabel,
    ToggleButtonGroup,
    ToggleButton,
} from '@mui/material';
import CloseIcon from '@mui/icons-material/Close';
import { useTranslate } from 'react-admin';
@@ -26,39 +31,91 @@
} 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 validateIncrement = (value, deviceType, sprite, translate) => {
    if (!value) {
        return true;
    }
    switch (deviceType) {
        case DEVICE_TYPE.SHELF:
            if (!sprite?.data?.row || !sprite?.data?.bay) {
                return translate('page.map.settings.map.copy.valid.shelf');
            }
            break;
        default:
            if (!sprite?.data?.no) {
                return translate('page.map.settings.map.copy.valid.common');
            }
            break;
    }
    return true;
};
const getDefaultFormValues = (value = {}) => ({
    copyDirect: value.copyDirect || '',
    copyCount: value.copyCount || '',
    gap: 0.0,
    autoIncrement: false,
    incrementMode: 'ascending',
    incrementValue: undefined,
});
const CopyDrawer = (props) => {
    const { open, onCancel, sprite, value, width = PAGE_DRAWER_WIDTH, handleOnCopy } = props;
    const notify = useNotification();
    const translate = useTranslate();
    const theme = useTheme();
    const themeMode = theme.palette.mode;
    const deviceType = sprite?.data?.type;
    const incrementOptions = incrementOptionsMap[deviceType]
    const { control, handleSubmit, reset, watch, setValue, formState: { errors } } = useForm({
        defaultValues: {
            copyDirect: value?.copyDirect || '',
            copyCount: value?.copyCount || '',
            gap: value?.gap || 0.0,
        },
        defaultValues: getDefaultFormValues(value),
    });
    useEffect(() => {
        if (value && Object.keys(value).length > 0) {
        }
    }, [value, setValue])
    const autoIncrement = useWatch({ control, name: 'autoIncrement' });
    const incrementValue = useWatch({ control, name: 'incrementValue' });
    // if (!value || !sprite) return <LinearProgress />;
    useEffect(() => {
        if (sprite && value && Object.keys(value).length > 0) {
            reset(getDefaultFormValues(value));
        }
    }, [sprite, value, reset, incrementOptions, setValue]);
    useEffect(() => {
        if (autoIncrement && incrementOptions && incrementOptions.length > 0) {
            if (!incrementValue) {
                setValue('incrementValue', incrementOptions[0].value);
            }
        } else {
            setValue('incrementValue', undefined);
        }
    }, [autoIncrement, incrementOptions, setValue]);
    const handleClose = () => {
        onCancel();
    }
    const onFormSubmit = (data) => {
        if (data) {
            console.log(data);
        }
        if (handleOnCopy) {
            handleOnCopy(data);
        }
        console.log(data);
        handleOnCopy?.(data);
        notify.info(translate('common.response.success'));
    };
@@ -84,98 +141,189 @@
                        </Stack>
                        <Box p={3}>
                            <Box component="form" onSubmit={handleSubmit(onFormSubmit)} noValidate sx={{ mt: 0 }}>
                                <Grid container spacing={1.4}>
                                    <Grid item xs={6}>
                                        <Controller
                                            name="copyDirect"
                                            control={control}
                                            render={({ field }) => (
                                                <TextField
                                                    {...field}
                                                    label={translate('page.map.settings.map.copy.direction')}
                                                    InputProps={{
                                                        readOnly: true,
                                                    }}
                                                    fullWidth
                            <Card sx={{
                                p: 2,
                                transition: '0.3s',
                                boxShadow: themeMode === 'light'
                                    ? '0px 2px 8px rgba(0, 0, 0, 0.1)'
                                    : '0px 2px 2px rgba(255, 255, 255, 0.1)',
                                '&:hover': {
                                    boxShadow: themeMode === 'light'
                                        ? '0px 4px 16px rgba(0, 0, 0, 0.2)'
                                        : '0px 4px 8px rgba(255, 255, 255, 0.2)',
                                },
                                borderRadius: '8px',
                            }}>
                                <CardContent>
                                    <Box component="form" onSubmit={handleSubmit(onFormSubmit)} noValidate sx={{ mt: 0 }}>
                                        <Grid container spacing={1.4}>
                                            <Grid item xs={6}>
                                                <Controller
                                                    name="copyDirect"
                                                    control={control}
                                                    render={({ field }) => (
                                                        <TextField
                                                            {...field}
                                                            label={translate('page.map.settings.map.copy.direction')}
                                                            InputProps={{
                                                                readOnly: true,
                                                            }}
                                                            fullWidth
                                                        />
                                                    )}
                                                />
                                            )}
                                        />
                                    </Grid>
                                    <Grid item xs={6}>
                                        <Controller
                                            name="copyCount"
                                            control={control}
                                            render={({ field }) => (
                                                <TextField
                                                    {...field}
                                                    label={translate('page.map.settings.map.copy.count')}
                                                    InputProps={{
                                                        readOnly: true,
                                                    }}
                                                    fullWidth
                                            </Grid>
                                            <Grid item xs={6}>
                                                <Controller
                                                    name="copyCount"
                                                    control={control}
                                                    render={({ field }) => (
                                                        <TextField
                                                            {...field}
                                                            label={translate('page.map.settings.map.copy.count')}
                                                            InputProps={{
                                                                readOnly: true,
                                                            }}
                                                            fullWidth
                                                        />
                                                    )}
                                                />
                                            )}
                                        />
                                    </Grid>
                                            </Grid>
                                    <Grid item xs={12}>
                                        <Controller
                                            name="gap"
                                            control={control}
                                            render={({ field }) => (
                                                <TextField
                                                    {...field}
                                                    label={translate('page.map.settings.map.copy.field.gap')}
                                                    type="number"
                                                    sx={{ width: '50%' }}
                                                    fullWidth
                                                    onChange={(e) => {
                                                        const value = parseFloat(e.target.value).toFixed(1);
                                                        field.onChange(value);
                                                    }}
                                            <Grid item xs={12}>
                                                <Controller
                                                    name="gap"
                                                    control={control}
                                                    render={({ field }) => (
                                                        <TextField
                                                            {...field}
                                                            label={translate('page.map.settings.map.copy.field.gap')}
                                                            type="number"
                                                            sx={{ width: '50%' }}
                                                            fullWidth
                                                            inputProps={{
                                                                min: 0,
                                                                step: 1,
                                                            }}
                                                        />
                                                    )}
                                                />
                                            </Grid>
                                            <Grid item xs={12} mt={2} mb={1}>
                                                <Divider />
                                            </Grid>
                                            <Grid item xs={12}>
                                                <Controller
                                                    name="autoIncrement"
                                                    control={control}
                                                    rules={{ validate: (value) => validateIncrement(value, deviceType, sprite, translate) }}
                                                    render={({ field }) => (
                                                        <FormControlLabel
                                                            control={
                                                                <Switch
                                                                    {...field}
                                                                    checked={field.value || false}
                                                                    onChange={(e) => field.onChange(e.target.checked)}
                                                                />
                                                            }
                                                            label={translate('page.map.settings.map.copy.field.autoIncrement')}
                                                        />
                                                    )}
                                                />
                                                {errors.autoIncrement && (
                                                    <Typography color="error">
                                                        {errors.autoIncrement.message}
                                                    </Typography>
                                                )}
                                            </Grid>
                                            {(!!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) => {
                                                                        if (value !== null) {
                                                                            field.onChange(value);
                                                                        }
                                                                    }}
                                                                    fullWidth
                                                                >
                                                                    {incrementOptions.map((option, idx) => (
                                                                        <ToggleButton key={idx} value={option.value}>
                                                                            {translate(option.label)}
                                                                        </ToggleButton>
                                                                    ))}
                                                                </ToggleButtonGroup>
                                                            )}
                                                        />
                                                    </FormControl>
                                                </Grid>
                                            )}
                                        />
                                    </Grid>
                                    {deviceType === DEVICE_TYPE.SHELF && (
                                        <>
                                        </>
                                    )}
                                            {autoIncrement && (
                                                <Grid item xs={12}>
                                                    <FormControl fullWidth>
                                                        <FormLabel sx={{
                                                            mb: 1
                                                        }}>
                                                            {translate('page.map.settings.map.copy.field.incrementMode')}
                                                        </FormLabel>
                                                        <Controller
                                                            name="incrementMode"
                                                            control={control}
                                                            render={({ field }) => (
                                                                <ToggleButtonGroup
                                                                    {...field}
                                                                    value={field.value}
                                                                    exclusive
                                                                    onChange={(event, value) => {
                                                                        if (value !== null) {
                                                                            field.onChange(value);
                                                                        }
                                                                    }}
                                                                    fullWidth
                                                                >
                                                                    <ToggleButton value="ascending">
                                                                        {translate('page.map.settings.map.copy.field.ascend')}
                                                                    </ToggleButton>
                                                                    <ToggleButton value="descending">
                                                                        {translate('page.map.settings.map.copy.field.descend')}
                                                                    </ToggleButton>
                                                                </ToggleButtonGroup>
                                                            )}
                                                        />
                                                    </FormControl>
                                                </Grid>
                                            )}
                                    {deviceType === DEVICE_TYPE.CHARGE && (
                                        <>
                                        </>
                                    )}
                                            <Grid item xs={12} mt={2}>
                                                <Divider />
                                            </Grid>
                                    {deviceType === DEVICE_TYPE.STATION && (
                                        <>
                                        </>
                                    )}
                                            <Grid item xs={12} mt={2}>
                                                <Stack direction="row" spacing={2}>
                                                    <Button variant="contained" color="primary" type="submit">
                                                        {translate('ra.action.confirm')}
                                                    </Button>
                                                </Stack>
                                            </Grid>
                                    {deviceType === DEVICE_TYPE.POINT && (
                                        <>
                                        </>
                                    )}
                                    <Grid item xs={12}>
                                        <Divider />
                                    </Grid>
                                    <Grid item xs={12} mt={2}>
                                        <Stack direction="row" spacing={2}>
                                            <Button variant="contained" color="primary" type="submit">
                                                {translate('ra.action.confirm')}
                                            </Button>
                                        </Stack>
                                    </Grid>
                                </Grid>
                            </Box>
                                        </Grid>
                                    </Box>
                                </CardContent>
                            </Card>
                        </Box>
                    </Box>
                )}