mirror of
https://github.com/ForFarmTeam/ForFarm.git
synced 2025-12-19 14:04:08 +01:00
feat: update harvest and planting detail forms to handle data changes and improve type safety
This commit is contained in:
parent
f7f64562ab
commit
4ffb6567ba
@ -24,7 +24,11 @@ import { Button } from "@/components/ui/button";
|
|||||||
|
|
||||||
type harvestSchema = z.infer<typeof harvestDetailsFormSchema>;
|
type harvestSchema = z.infer<typeof harvestDetailsFormSchema>;
|
||||||
|
|
||||||
export default function HarvestDetailsForm() {
|
export default function HarvestDetailsForm({
|
||||||
|
onChange,
|
||||||
|
}: {
|
||||||
|
onChange: (data: harvestSchema) => void;
|
||||||
|
}) {
|
||||||
const form = useForm<harvestSchema>({
|
const form = useForm<harvestSchema>({
|
||||||
resolver: zodResolver(harvestDetailsFormSchema),
|
resolver: zodResolver(harvestDetailsFormSchema),
|
||||||
defaultValues: {
|
defaultValues: {
|
||||||
@ -38,9 +42,15 @@ export default function HarvestDetailsForm() {
|
|||||||
expectedYieldPerAcre: 0,
|
expectedYieldPerAcre: 0,
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
const onSubmit: (data: harvestSchema) => void = (data) => {
|
||||||
|
onChange(data);
|
||||||
|
};
|
||||||
return (
|
return (
|
||||||
<Form {...form}>
|
<Form {...form}>
|
||||||
<form className="grid grid-cols-3 gap-5">
|
<form
|
||||||
|
className="grid grid-cols-3 gap-5"
|
||||||
|
onSubmit={form.handleSubmit(onSubmit)}
|
||||||
|
>
|
||||||
<FormField
|
<FormField
|
||||||
control={form.control}
|
control={form.control}
|
||||||
name="daysToFlower"
|
name="daysToFlower"
|
||||||
@ -57,6 +67,13 @@ export default function HarvestDetailsForm() {
|
|||||||
id="daysToFlower"
|
id="daysToFlower"
|
||||||
className="w-96"
|
className="w-96"
|
||||||
{...field}
|
{...field}
|
||||||
|
onChange={(e) => {
|
||||||
|
// convert to number
|
||||||
|
const value = e.target.value
|
||||||
|
? parseInt(e.target.value, 10)
|
||||||
|
: "";
|
||||||
|
field.onChange(value);
|
||||||
|
}}
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -81,6 +98,13 @@ export default function HarvestDetailsForm() {
|
|||||||
id="daysToMaturity"
|
id="daysToMaturity"
|
||||||
className="w-96"
|
className="w-96"
|
||||||
{...field}
|
{...field}
|
||||||
|
onChange={(e) => {
|
||||||
|
// convert to number
|
||||||
|
const value = e.target.value
|
||||||
|
? parseInt(e.target.value, 10)
|
||||||
|
: "";
|
||||||
|
field.onChange(value);
|
||||||
|
}}
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -105,6 +129,13 @@ export default function HarvestDetailsForm() {
|
|||||||
id="harvestWindow"
|
id="harvestWindow"
|
||||||
className="w-96"
|
className="w-96"
|
||||||
{...field}
|
{...field}
|
||||||
|
onChange={(e) => {
|
||||||
|
// convert to number
|
||||||
|
const value = e.target.value
|
||||||
|
? parseInt(e.target.value, 10)
|
||||||
|
: "";
|
||||||
|
field.onChange(value);
|
||||||
|
}}
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -129,6 +160,13 @@ export default function HarvestDetailsForm() {
|
|||||||
id="estimatedLossRate"
|
id="estimatedLossRate"
|
||||||
className="w-96"
|
className="w-96"
|
||||||
{...field}
|
{...field}
|
||||||
|
onChange={(e) => {
|
||||||
|
// convert to number
|
||||||
|
const value = e.target.value
|
||||||
|
? parseInt(e.target.value, 10)
|
||||||
|
: "";
|
||||||
|
field.onChange(value);
|
||||||
|
}}
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -178,6 +216,13 @@ export default function HarvestDetailsForm() {
|
|||||||
id="estimatedRevenue"
|
id="estimatedRevenue"
|
||||||
className="w-96"
|
className="w-96"
|
||||||
{...field}
|
{...field}
|
||||||
|
onChange={(e) => {
|
||||||
|
// convert to number
|
||||||
|
const value = e.target.value
|
||||||
|
? parseInt(e.target.value, 10)
|
||||||
|
: "";
|
||||||
|
field.onChange(value);
|
||||||
|
}}
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -202,6 +247,13 @@ export default function HarvestDetailsForm() {
|
|||||||
id="expectedYieldPer100ft"
|
id="expectedYieldPer100ft"
|
||||||
className="w-96"
|
className="w-96"
|
||||||
{...field}
|
{...field}
|
||||||
|
onChange={(e) => {
|
||||||
|
// convert to number
|
||||||
|
const value = e.target.value
|
||||||
|
? parseInt(e.target.value, 10)
|
||||||
|
: "";
|
||||||
|
field.onChange(value);
|
||||||
|
}}
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
@ -226,6 +278,13 @@ export default function HarvestDetailsForm() {
|
|||||||
id="expectedYieldPerAcre"
|
id="expectedYieldPerAcre"
|
||||||
className="w-96"
|
className="w-96"
|
||||||
{...field}
|
{...field}
|
||||||
|
onChange={(e) => {
|
||||||
|
// convert to number
|
||||||
|
const value = e.target.value
|
||||||
|
? parseInt(e.target.value, 10)
|
||||||
|
: "";
|
||||||
|
field.onChange(value);
|
||||||
|
}}
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|||||||
@ -4,48 +4,31 @@ import PlantingDetailsForm from "./planting-detail-form";
|
|||||||
import HarvestDetailsForm from "./harvest-detail-form";
|
import HarvestDetailsForm from "./harvest-detail-form";
|
||||||
import { Separator } from "@/components/ui/separator";
|
import { Separator } from "@/components/ui/separator";
|
||||||
import GoogleMapWithDrawing from "@/components/google-map-with-drawing";
|
import GoogleMapWithDrawing from "@/components/google-map-with-drawing";
|
||||||
|
import {
|
||||||
|
plantingDetailsFormSchema,
|
||||||
|
harvestDetailsFormSchema,
|
||||||
|
} from "@/schemas/application.schema";
|
||||||
|
import { z } from "zod";
|
||||||
|
|
||||||
|
type plantingSchema = z.infer<typeof plantingDetailsFormSchema>;
|
||||||
|
type harvestSchema = z.infer<typeof harvestDetailsFormSchema>;
|
||||||
|
|
||||||
export default function SetupPage() {
|
export default function SetupPage() {
|
||||||
type PlantingDetails = {
|
const [plantingDetails, setPlantingDetails] = useState<plantingSchema | null>(
|
||||||
daysToEmerge: number;
|
null
|
||||||
plantSpacing: number;
|
);
|
||||||
rowSpacing: number;
|
const [harvestDetails, setHarvestDetails] = useState<harvestSchema | null>(
|
||||||
plantingDepth: number;
|
null
|
||||||
averageHeight: number;
|
);
|
||||||
isPerennial: boolean;
|
|
||||||
autoCreateTasks: boolean;
|
|
||||||
startMethod?: string;
|
|
||||||
lightProfile?: string;
|
|
||||||
soilConditions?: string;
|
|
||||||
plantingDetails?: string;
|
|
||||||
pruningDetails?: string;
|
|
||||||
};
|
|
||||||
|
|
||||||
const [plantingDetails, setPlantingDetails] =
|
|
||||||
useState<PlantingDetails | null>(null);
|
|
||||||
const [harvestDetails, setHarvestDetails] = useState(null);
|
|
||||||
const [mapData, setMapData] = useState(null);
|
const [mapData, setMapData] = useState(null);
|
||||||
|
|
||||||
// handle planting details submission
|
// handle planting details submission
|
||||||
const handlePlantingDetailsChange = (data: {
|
const handlePlantingDetailsChange = (data: plantingSchema) => {
|
||||||
daysToEmerge: number;
|
|
||||||
plantSpacing: number;
|
|
||||||
rowSpacing: number;
|
|
||||||
plantingDepth: number;
|
|
||||||
averageHeight: number;
|
|
||||||
isPerennial: boolean;
|
|
||||||
autoCreateTasks: boolean;
|
|
||||||
startMethod?: string;
|
|
||||||
lightProfile?: string;
|
|
||||||
soilConditions?: string;
|
|
||||||
plantingDetails?: string;
|
|
||||||
pruningDetails?: string;
|
|
||||||
}) => {
|
|
||||||
setPlantingDetails(data);
|
setPlantingDetails(data);
|
||||||
};
|
};
|
||||||
|
|
||||||
// handle harvest details submission
|
// handle harvest details submission
|
||||||
const handleHarvestDetailsChange = (data: SetStateAction<null>) => {
|
const handleHarvestDetailsChange = (data: harvestSchema) => {
|
||||||
setHarvestDetails(data);
|
setHarvestDetails(data);
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -54,9 +37,11 @@ export default function SetupPage() {
|
|||||||
setMapData(data);
|
setMapData(data);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// log the changes
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
console.log(plantingDetails);
|
console.log(plantingDetails);
|
||||||
}, [plantingDetails]);
|
console.log(harvestDetails);
|
||||||
|
}, [plantingDetails, harvestDetails]);
|
||||||
|
|
||||||
const handleSubmit = () => {
|
const handleSubmit = () => {
|
||||||
if (!plantingDetails || !harvestDetails || !mapData) {
|
if (!plantingDetails || !harvestDetails || !mapData) {
|
||||||
@ -105,7 +90,7 @@ export default function SetupPage() {
|
|||||||
</div>
|
</div>
|
||||||
<Separator className="mt-3" />
|
<Separator className="mt-3" />
|
||||||
<div className="mt-10 flex justify-center">
|
<div className="mt-10 flex justify-center">
|
||||||
{/* <HarvestDetailsForm onChange={handleHarvestDetailsChange} /> */}
|
<HarvestDetailsForm onChange={handleHarvestDetailsChange} />
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
{/* Map Section */}
|
{/* Map Section */}
|
||||||
|
|||||||
@ -23,23 +23,8 @@ import {
|
|||||||
import { Textarea } from "@/components/ui/textarea";
|
import { Textarea } from "@/components/ui/textarea";
|
||||||
import { Switch } from "@/components/ui/switch";
|
import { Switch } from "@/components/ui/switch";
|
||||||
import { Button } from "@/components/ui/button";
|
import { Button } from "@/components/ui/button";
|
||||||
import { useState } from "react";
|
|
||||||
|
|
||||||
type plantingSchema = z.infer<typeof plantingDetailsFormSchema>;
|
type plantingSchema = z.infer<typeof plantingDetailsFormSchema>;
|
||||||
interface FormData {
|
|
||||||
daysToEmerge: number;
|
|
||||||
plantSpacing: number;
|
|
||||||
rowSpacing: number;
|
|
||||||
plantingDepth: number;
|
|
||||||
averageHeight: number;
|
|
||||||
startMethod?: string;
|
|
||||||
lightProfile?: string;
|
|
||||||
soilConditions?: string;
|
|
||||||
plantingDetails?: string;
|
|
||||||
pruningDetails?: string;
|
|
||||||
isPerennial: boolean;
|
|
||||||
autoCreateTasks: boolean;
|
|
||||||
}
|
|
||||||
|
|
||||||
export default function PlantingDetailsForm({
|
export default function PlantingDetailsForm({
|
||||||
onChange,
|
onChange,
|
||||||
@ -64,7 +49,7 @@ export default function PlantingDetailsForm({
|
|||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
||||||
const onSubmit = (data: FormData) => {
|
const onSubmit = (data: plantingSchema) => {
|
||||||
onChange(data);
|
onChange(data);
|
||||||
};
|
};
|
||||||
return (
|
return (
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user