From b2380ac00d77a94d38201662c98fb8844ec3a453 Mon Sep 17 00:00:00 2001 From: Jonas Hagberg Date: Tue, 7 Jan 2025 10:00:48 +0100 Subject: [PATCH] Refactor YearlyReportForm component to streamline initial values and payload structure - Consolidated user-editable and computed fields for clarity and maintainability. - Removed redundant calculations by directly using already computed values in the payload. - Enhanced code readability with improved comments and organization of initial state setup. These changes aim to improve the overall functionality and user experience of the YearlyReportForm component. --- frontend/src/YearlyReportForm.tsx | 40 ++++++++++++++++++++----------- 1 file changed, 26 insertions(+), 14 deletions(-) diff --git a/frontend/src/YearlyReportForm.tsx b/frontend/src/YearlyReportForm.tsx index 816e997f..bc96cb99 100644 --- a/frontend/src/YearlyReportForm.tsx +++ b/frontend/src/YearlyReportForm.tsx @@ -114,19 +114,13 @@ const YearlyReportForm: React.FC = ({ ): ReportValues => { // Start with default values const values: ReportValues = { + // User-editable fields - can come from existing data genebankNumber: herdData.herd || "", breed: herdData.breed || "", gotlandskanin: herdData.genebank === 1, mellerudskanin: herdData.genebank === 2, breedingYear: reportYear || new Date().getFullYear(), endingGenbank: existingData?.endingGenbank || false, - numberOfLitters: 0, - totalBorn: 0, - totalAliveAfterSixWeeks: 0, - numberOfFemalesUsedInBreeding: 0, - numberOfMalesUsedInBreeding: 0, - numberOfFemalesWithCertificate: 0, - numberOfMalesWithCertificate: 0, allowPublication: existingData?.allowPublication || [], eligibleForSupport: existingData?.eligibleForSupport || false, notEligibleForSupport: existingData?.notEligibleForSupport || false, @@ -150,6 +144,14 @@ const YearlyReportForm: React.FC = ({ age: "", }, }, + // Computed fields - always start at 0, will be calculated below + numberOfLitters: 0, + totalBorn: 0, + totalAliveAfterSixWeeks: 0, + numberOfFemalesUsedInBreeding: 0, + numberOfMalesUsedInBreeding: 0, + numberOfFemalesWithCertificate: 0, + numberOfMalesWithCertificate: 0, }; // Calculate values based on current herd data @@ -193,8 +195,6 @@ const YearlyReportForm: React.FC = ({ ); values.numberOfFemalesUsedInBreeding = uniqueMothers.size; values.numberOfMalesUsedInBreeding = uniqueFathers.size; - values.numberOfFemalesWithCertificate = femaleRabbits.length; - values.numberOfMalesWithCertificate = maleRabbits.length; return values; }; @@ -220,18 +220,30 @@ const YearlyReportForm: React.FC = ({ reportYear || new Date().getFullYear() } ${herdResponse.herd} ${herdName}`; - // Recalculate all computed values before submitting - const computedValues = calculateInitialValues(herdResponse, null); const payload = { data: { - ...values, - ...computedValues, - // Only include user-editable fields from values + // Use the values from the form - they are already correctly calculated + // and are read-only in the form + numberOfLitters: values.numberOfLitters, + totalBorn: values.totalBorn, + totalAliveAfterSixWeeks: values.totalAliveAfterSixWeeks, + numberOfFemalesUsedInBreeding: values.numberOfFemalesUsedInBreeding, + numberOfMalesUsedInBreeding: values.numberOfMalesUsedInBreeding, + numberOfFemalesWithCertificate: + values.numberOfFemalesWithCertificate, + numberOfMalesWithCertificate: values.numberOfMalesWithCertificate, + // User-editable fields allowPublication: values.allowPublication, diseases: values.diseases, defectsMalformations: values.defectsMalformations, endingGenbank: values.endingGenbank, eligibleForSupport: values.eligibleForSupport, + // Other required fields + genebankNumber: values.genebankNumber, + breed: values.breed, + gotlandskanin: values.gotlandskanin, + mellerudskanin: values.mellerudskanin, + breedingYear: values.breedingYear, }, name: reportName, version: "1.0",