2022-03-29 09:30:57 +02:00
|
|
|
import { IConstraint } from 'interfaces/strategy';
|
2023-01-03 15:30:59 +01:00
|
|
|
import { SegmentFormStepOne } from './SegmentFormStepOne';
|
|
|
|
import { SegmentFormStepTwo } from './SegmentFormStepTwo';
|
2022-03-29 09:30:57 +02:00
|
|
|
import React, { useState } from 'react';
|
2023-01-03 15:30:59 +01:00
|
|
|
import { SegmentFormStepList } from 'component/segments/SegmentFormStepList';
|
2022-05-02 12:52:33 +02:00
|
|
|
import { ConditionallyRender } from 'component/common/ConditionallyRender/ConditionallyRender';
|
2023-01-03 15:30:59 +01:00
|
|
|
import { styled } from '@mui/material';
|
2022-03-29 09:30:57 +02:00
|
|
|
|
|
|
|
export type SegmentFormStep = 1 | 2;
|
2022-04-29 14:53:28 +02:00
|
|
|
export type SegmentFormMode = 'create' | 'edit';
|
|
|
|
|
2022-03-29 09:30:57 +02:00
|
|
|
interface ISegmentProps {
|
|
|
|
name: string;
|
|
|
|
description: string;
|
2023-03-10 09:16:54 +01:00
|
|
|
project: string | null;
|
2022-03-29 09:30:57 +02:00
|
|
|
constraints: IConstraint[];
|
|
|
|
setName: React.Dispatch<React.SetStateAction<string>>;
|
|
|
|
setDescription: React.Dispatch<React.SetStateAction<string>>;
|
2023-03-10 09:16:54 +01:00
|
|
|
setProject: React.Dispatch<React.SetStateAction<string | null>>;
|
2022-03-29 09:30:57 +02:00
|
|
|
setConstraints: React.Dispatch<React.SetStateAction<IConstraint[]>>;
|
|
|
|
handleSubmit: (e: any) => void;
|
|
|
|
errors: { [key: string]: string };
|
|
|
|
clearErrors: () => void;
|
2022-04-29 14:53:28 +02:00
|
|
|
mode: SegmentFormMode;
|
2022-03-29 09:30:57 +02:00
|
|
|
}
|
|
|
|
|
2023-01-03 15:30:59 +01:00
|
|
|
const StyledForm = styled('form')(({ theme }) => ({
|
|
|
|
display: 'flex',
|
|
|
|
flexDirection: 'column',
|
|
|
|
height: '100%',
|
|
|
|
}));
|
|
|
|
|
2022-03-29 09:30:57 +02:00
|
|
|
export const SegmentForm: React.FC<ISegmentProps> = ({
|
|
|
|
children,
|
|
|
|
name,
|
|
|
|
description,
|
2023-03-10 09:16:54 +01:00
|
|
|
project,
|
2022-03-29 09:30:57 +02:00
|
|
|
constraints,
|
|
|
|
setName,
|
|
|
|
setDescription,
|
2023-03-10 09:16:54 +01:00
|
|
|
setProject,
|
2022-03-29 09:30:57 +02:00
|
|
|
setConstraints,
|
|
|
|
handleSubmit,
|
|
|
|
errors,
|
|
|
|
clearErrors,
|
2022-04-29 14:53:28 +02:00
|
|
|
mode,
|
2022-03-29 09:30:57 +02:00
|
|
|
}) => {
|
|
|
|
const totalSteps = 2;
|
|
|
|
const [currentStep, setCurrentStep] = useState<SegmentFormStep>(1);
|
|
|
|
|
|
|
|
return (
|
|
|
|
<>
|
|
|
|
<SegmentFormStepList total={totalSteps} current={currentStep} />
|
2023-01-03 15:30:59 +01:00
|
|
|
<StyledForm onSubmit={handleSubmit}>
|
2022-03-29 09:30:57 +02:00
|
|
|
<ConditionallyRender
|
|
|
|
condition={currentStep === 1}
|
|
|
|
show={
|
|
|
|
<SegmentFormStepOne
|
|
|
|
name={name}
|
|
|
|
description={description}
|
2023-03-10 09:16:54 +01:00
|
|
|
project={project}
|
2022-03-29 09:30:57 +02:00
|
|
|
setName={setName}
|
|
|
|
setDescription={setDescription}
|
2023-03-10 09:16:54 +01:00
|
|
|
setProject={setProject}
|
2022-03-29 09:30:57 +02:00
|
|
|
errors={errors}
|
|
|
|
clearErrors={clearErrors}
|
|
|
|
setCurrentStep={setCurrentStep}
|
|
|
|
/>
|
|
|
|
}
|
|
|
|
/>
|
|
|
|
<ConditionallyRender
|
|
|
|
condition={currentStep === 2}
|
|
|
|
show={
|
|
|
|
<SegmentFormStepTwo
|
|
|
|
constraints={constraints}
|
|
|
|
setConstraints={setConstraints}
|
|
|
|
setCurrentStep={setCurrentStep}
|
2022-04-29 14:53:28 +02:00
|
|
|
mode={mode}
|
2022-03-29 09:30:57 +02:00
|
|
|
>
|
|
|
|
{children}
|
|
|
|
</SegmentFormStepTwo>
|
|
|
|
}
|
|
|
|
/>
|
2023-01-03 15:30:59 +01:00
|
|
|
</StyledForm>
|
2022-03-29 09:30:57 +02:00
|
|
|
</>
|
|
|
|
);
|
|
|
|
};
|