add: manejar errores para que no lleguen datos vacíos al endpoint
This commit is contained in:
@@ -13,24 +13,38 @@ export default function BasicMode() {
|
||||
|
||||
const [isLoading, setIsLoading] = useState(false);
|
||||
const [result, setResult] = useState(null);
|
||||
|
||||
const [errors, setErrors] = useState({ criterion: false, levels: [] });
|
||||
|
||||
const handleCalculate = async () => {
|
||||
|
||||
let hasError = false;
|
||||
const newErrors = { criterion: false, levels: Array(levels.length).fill(false) };
|
||||
|
||||
if (!criterionName.trim()) {
|
||||
newErrors.criterion = true;
|
||||
hasError = true;
|
||||
}
|
||||
|
||||
levels.forEach((level, idx) => {
|
||||
if (!level.trim()) {
|
||||
newErrors.levels[idx] = true;
|
||||
hasError = true;
|
||||
}
|
||||
});
|
||||
|
||||
setErrors(newErrors);
|
||||
|
||||
if (hasError) return;
|
||||
|
||||
setIsLoading(true);
|
||||
setResult(null);
|
||||
|
||||
const firstIndex = "0";
|
||||
const lastIndex = (levels.length - 1).toString();
|
||||
|
||||
const currentReferences = {
|
||||
[firstIndex]: 0,
|
||||
[lastIndex]: 1
|
||||
};
|
||||
|
||||
const payload = {
|
||||
criterion_name: criterionName || "Criterio sin nombre",
|
||||
levels: levels,
|
||||
criterion_name: criterionName.trim(),
|
||||
levels: levels.map(l => l.trim()),
|
||||
blank_cards: blankCards,
|
||||
references: currentReferences
|
||||
references: { "0": 0, [(levels.length - 1).toString()]: 1 }
|
||||
};
|
||||
|
||||
try {
|
||||
@@ -43,15 +57,27 @@ export default function BasicMode() {
|
||||
}
|
||||
};
|
||||
|
||||
const handleCriterionChange = (val) => {
|
||||
setCriterionName(val);
|
||||
if (errors.criterion) setErrors({ ...errors, criterion: false });
|
||||
};
|
||||
|
||||
const handleLevelChange = (index, newValue) => {
|
||||
const newLevels = [...levels];
|
||||
newLevels[index] = newValue;
|
||||
setLevels(newLevels);
|
||||
|
||||
if (errors.levels[index]) {
|
||||
const newErrLevels = [...errors.levels];
|
||||
newErrLevels[index] = false;
|
||||
setErrors({ ...errors, levels: newErrLevels });
|
||||
}
|
||||
};
|
||||
|
||||
const handleAddLevel = () => {
|
||||
setLevels([...levels, '']);
|
||||
setBlankCards([...blankCards, 0]);
|
||||
setErrors({ ...errors, levels: [...errors.levels, false] });
|
||||
};
|
||||
|
||||
const handleRemoveLevel = (indexToRemove) => {
|
||||
@@ -59,8 +85,12 @@ export default function BasicMode() {
|
||||
const newLevels = levels.filter((_, index) => index !== indexToRemove);
|
||||
const blankIndexToRemove = indexToRemove === 0 ? 0 : indexToRemove - 1;
|
||||
const newBlankCards = blankCards.filter((_, index) => index !== blankIndexToRemove);
|
||||
|
||||
const newErrLevels = errors.levels.filter((_, index) => index !== indexToRemove);
|
||||
|
||||
setLevels(newLevels);
|
||||
setBlankCards(newBlankCards);
|
||||
setErrors({ ...errors, levels: newErrLevels });
|
||||
};
|
||||
|
||||
const handleBlankCardChange = (index, delta) => {
|
||||
@@ -74,10 +104,11 @@ export default function BasicMode() {
|
||||
|
||||
return (
|
||||
<div className="w-full flex flex-col items-center">
|
||||
|
||||
|
||||
<CriterionInput
|
||||
criterionName={criterionName}
|
||||
setCriterionName={setCriterionName}
|
||||
setCriterionName={handleCriterionChange}
|
||||
error={errors.criterion}
|
||||
/>
|
||||
|
||||
<div className="w-full max-w-lg flex flex-col items-center">
|
||||
@@ -90,6 +121,7 @@ export default function BasicMode() {
|
||||
handleLevelChange={handleLevelChange}
|
||||
handleRemoveLevel={handleRemoveLevel}
|
||||
totalLevels={levels.length}
|
||||
error={errors.levels[index]}
|
||||
/>
|
||||
|
||||
{index < levels.length - 1 && (
|
||||
@@ -107,18 +139,18 @@ export default function BasicMode() {
|
||||
|
||||
<div className="w-full max-w-lg mt-12 pt-8 border-t-2 border-slate-200 flex flex-col items-center">
|
||||
<button
|
||||
onClick={handleCalculate}
|
||||
disabled={isLoading}
|
||||
className={`w-full py-4 text-white text-xl font-bold rounded-xl shadow-lg transition-all active:scale-[0.98] ${
|
||||
isLoading ? 'bg-slate-400 cursor-not-allowed' : 'bg-gradient-to-r from-blue-600 to-indigo-600 hover:from-blue-700 hover:to-indigo-700 hover:shadow-xl'
|
||||
onClick={handleCalculate}
|
||||
disabled={isLoading}
|
||||
className={`w-full py-4 text-white text-xl font-bold rounded-xl shadow-lg transition-all active:scale-[0.98] ${
|
||||
isLoading ? 'bg-slate-400 cursor-not-allowed' : 'bg-gradient-to-r from-blue-600 to-indigo-600 hover:from-blue-700 hover:to-indigo-700 hover:shadow-xl'
|
||||
}`}
|
||||
>
|
||||
{isLoading ? 'Calculando...' : 'Calcular Valores DoC'}
|
||||
{isLoading ? 'Calculando...' : 'Calcular Valores DoC'}
|
||||
</button>
|
||||
</div>
|
||||
|
||||
<ValueFunctionChart result={result} />
|
||||
|
||||
</div>
|
||||
);
|
||||
);
|
||||
}
|
||||
Reference in New Issue
Block a user