2022-01-18 11:23:24 +01:00
|
|
|
import { useEffect, useState } from 'react';
|
2022-03-28 10:49:59 +02:00
|
|
|
import useEnvironmentApi from 'hooks/api/actions/useEnvironmentApi/useEnvironmentApi';
|
2022-06-07 15:03:40 +02:00
|
|
|
import { formatUnknownError } from 'utils/formatUnknownError';
|
2022-01-18 11:23:24 +01:00
|
|
|
|
2022-02-18 09:51:10 +01:00
|
|
|
const useEnvironmentForm = (initialName = '', initialType = 'development') => {
|
2022-01-18 11:23:24 +01:00
|
|
|
const [name, setName] = useState(initialName);
|
|
|
|
const [type, setType] = useState(initialType);
|
|
|
|
const [errors, setErrors] = useState({});
|
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
setName(initialName);
|
|
|
|
}, [initialName]);
|
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
setType(initialType);
|
|
|
|
}, [initialType]);
|
|
|
|
|
|
|
|
const { validateEnvName } = useEnvironmentApi();
|
|
|
|
|
|
|
|
const getEnvPayload = () => {
|
|
|
|
return {
|
|
|
|
name,
|
|
|
|
type,
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
const validateEnvironmentName = async () => {
|
|
|
|
if (name.length === 0) {
|
2023-10-02 14:25:46 +02:00
|
|
|
setErrors((prev) => ({
|
2022-01-18 11:23:24 +01:00
|
|
|
...prev,
|
|
|
|
name: 'Environment name can not be empty',
|
|
|
|
}));
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
try {
|
|
|
|
await validateEnvName(name);
|
2022-06-07 15:03:40 +02:00
|
|
|
return true;
|
|
|
|
} catch (error: unknown) {
|
2023-10-02 14:25:46 +02:00
|
|
|
setErrors((prev) => ({ ...prev, name: formatUnknownError(error) }));
|
2022-01-18 11:23:24 +01:00
|
|
|
return false;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
const clearErrors = () => {
|
|
|
|
setErrors({});
|
|
|
|
};
|
|
|
|
|
|
|
|
return {
|
|
|
|
name,
|
|
|
|
setName,
|
|
|
|
type,
|
|
|
|
setType,
|
|
|
|
getEnvPayload,
|
|
|
|
validateEnvironmentName,
|
|
|
|
clearErrors,
|
|
|
|
errors,
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
export default useEnvironmentForm;
|