import { Autocomplete, Button, styled, TextField } from '@mui/material'; import Input from 'component/common/Input/Input'; import React, { useEffect } from 'react'; import { useNavigate } from 'react-router-dom'; import { SegmentFormStep } from './SegmentForm'; import { SEGMENT_NAME_ID, SEGMENT_DESC_ID, SEGMENT_NEXT_BTN_ID, } from 'utils/testIds'; import { ConditionallyRender } from 'component/common/ConditionallyRender/ConditionallyRender'; import useUiConfig from 'hooks/api/getters/useUiConfig/useUiConfig'; import useProjects from 'hooks/api/getters/useProjects/useProjects'; interface ISegmentFormPartOneProps { name: string; description: string; project: string | null; setName: React.Dispatch>; setDescription: React.Dispatch>; setProject: React.Dispatch>; errors: { [key: string]: string }; clearErrors: () => void; setCurrentStep: React.Dispatch>; } const StyledForm = styled('div')(({ theme }) => ({ display: 'flex', flexDirection: 'column', height: '100%', })); const StyledContainer = styled('div')(({ theme }) => ({ maxWidth: '400px', })); const StyledInputDescription = styled('p')(({ theme }) => ({ marginBottom: theme.spacing(1), })); const StyledInput = styled(Input)(({ theme }) => ({ width: '100%', marginBottom: theme.spacing(2), })); const StyledButtonContainer = styled('div')(({ theme }) => ({ marginTop: 'auto', display: 'flex', justifyContent: 'flex-end', })); const StyledCancelButton = styled(Button)(({ theme }) => ({ marginLeft: theme.spacing(3), })); export const SegmentFormStepOne: React.FC = ({ children, name, description, project, setName, setDescription, setProject, errors, clearErrors, setCurrentStep, }) => { const { uiConfig } = useUiConfig(); const navigate = useNavigate(); const { projects } = useProjects(); const [selectedProject, setSelectedProject] = React.useState( projects.find(({ id }) => id === project) ?? null ); useEffect(() => { setSelectedProject(projects.find(({ id }) => id === project) ?? null); }, [project, projects]); return ( What is the segment name? setName(e.target.value)} error={Boolean(errors.name)} errorText={errors.name} autoFocus required data-testid={SEGMENT_NAME_ID} /> What is the segment description? setDescription(e.target.value)} error={Boolean(errors.description)} errorText={errors.description} data-testid={SEGMENT_DESC_ID} /> Is this segment tied to a specific project? { setProject(newValue?.id ?? null); }} options={projects} getOptionLabel={option => option.name} renderInput={params => ( )} /> } /> { navigate('/segments'); }} > Cancel ); };