"use client" import { toast } from 'sonner'; import { useForm } from "react-hook-form"; import { z } from "zod"; import { updateLineItem } from "@lib/data/cart" import { StoreCart, StoreCartLineItem } from "@medusajs/types" import { Form } from "@kit/ui/form"; import { Trans } from '@kit/ui/trans'; import { useTranslation } from "react-i18next"; import { zodResolver } from "@hookform/resolvers/zod"; import { Select, SelectContent, SelectGroup, SelectItem, SelectLabel, SelectTrigger, SelectValue, } from '@kit/ui/select'; const AnalysisLocationSchema = z.object({ locationId: z.string().min(1), }); const MOCK_LOCATIONS: { id: string, name: string }[] = [ { id: "synlab-tallinn-1", name: "SYNLAB - Tallinn" }, { id: "synlab-tartu-1", name: "SYNLAB - Tartu" }, { id: "synlab-parnu-1", name: "SYNLAB - Pärnu" }, ] export default function AnalysisLocation({ cart, analysisPackages }: { cart: StoreCart, analysisPackages: StoreCartLineItem[] }) { const { t } = useTranslation('cart'); const form = useForm>({ defaultValues: { locationId: cart.metadata?.partner_location_id as string ?? '', }, resolver: zodResolver(AnalysisLocationSchema), }); const onSubmit = async ({ locationId }: z.infer) => { const promise = Promise.all(analysisPackages.map(async ({ id, quantity }) => { await updateLineItem({ lineId: id, quantity, metadata: { partner_location_name: MOCK_LOCATIONS.find((location) => location.id === locationId)?.name ?? '', partner_location_id: locationId, }, }); })); toast.promise(promise, { success: t(`cart:items.analysisLocation.success`), loading: t(`cart:items.analysisLocation.loading`), error: t(`cart:items.analysisLocation.error`), }); } return (
onSubmit(data))} className="w-full mb-2 flex gap-x-2" >

) }