diff --git a/app/home/(user)/(dashboard)/cart/montonio-callback/[montonioId]/route.ts b/app/home/(user)/(dashboard)/cart/montonio-callback/[montonioId]/route.ts index b87d810..0769f7c 100644 --- a/app/home/(user)/(dashboard)/cart/montonio-callback/[montonioId]/route.ts +++ b/app/home/(user)/(dashboard)/cart/montonio-callback/[montonioId]/route.ts @@ -73,11 +73,12 @@ const handleOrderToken = async (orderToken: string) => { } const { productTypes } = await listProductTypes(); const analysisPackagesType = productTypes.find(({ metadata }) => metadata?.handle === 'analysis-packages'); - const { order } = await placeOrder(cartId, { revalidateCacheTags: true }); + const order = await placeOrder(cartId, { revalidateCacheTags: true }); + const analysisPackageOrderItem = order.items?.find(({ product_type_id }) => product_type_id === analysisPackagesType?.id); return { email: order.email, - partnerLocationName: order.metadata?.partner_location_name as string ?? '', - analysisPackageName: order.items?.find(item => item.product_type_id === analysisPackagesType?.id)?.title ?? '', + partnerLocationName: analysisPackageOrderItem?.metadata?.partner_location_name as string ?? '', + analysisPackageName: analysisPackageOrderItem?.title ?? '', }; } catch (error) { throw new Error(`Failed to place order, message=${error}`); @@ -105,8 +106,10 @@ export async function GET(request: Request) { const { email, partnerLocationName, analysisPackageName } = orderResult; const personName = account.name; - if (email && analysisPackageName && partnerLocationName) { + if (email && analysisPackageName) { await sendEmail({ email, analysisPackageName, personName, partnerLocationName, language }); + } else { + console.error("Missing email or analysisPackageName", orderResult); } return Response.redirect(new URL('/home/order', baseUrl)) } catch (error) { diff --git a/app/home/(user)/(dashboard)/order/[orderId]/confirmed/page.tsx b/app/home/(user)/(dashboard)/order/[orderId]/confirmed/page.tsx index 95d9e81..2ca1b55 100644 --- a/app/home/(user)/(dashboard)/order/[orderId]/confirmed/page.tsx +++ b/app/home/(user)/(dashboard)/order/[orderId]/confirmed/page.tsx @@ -3,6 +3,7 @@ import { notFound } from 'next/navigation'; import { retrieveOrder } from '~/medusa/lib/data/orders'; import { createI18nServerInstance } from '@/lib/i18n/i18n.server'; import OrderCompleted from '@/app/home/(user)/_components/order/order-completed'; +import { withI18n } from '~/lib/i18n/with-i18n'; type Props = { params: Promise<{ orderId: string }>; @@ -16,7 +17,7 @@ export async function generateMetadata() { }; } -export default async function OrderConfirmedPage(props: Props) { +async function OrderConfirmedPage(props: Props) { const params = await props.params; const order = await retrieveOrder(params.orderId).catch(() => null); @@ -26,3 +27,5 @@ export default async function OrderConfirmedPage(props: Props) { return ; } + +export default withI18n(OrderConfirmedPage); diff --git a/app/home/(user)/_components/cart/analysis-location.tsx b/app/home/(user)/_components/cart/analysis-location.tsx index 89da90c..b6128e7 100644 --- a/app/home/(user)/_components/cart/analysis-location.tsx +++ b/app/home/(user)/_components/cart/analysis-location.tsx @@ -3,8 +3,8 @@ import { toast } from 'sonner'; import { useForm } from "react-hook-form"; import { z } from "zod"; -import { updateCart } from "@lib/data/cart" -import { StoreCart } from "@medusajs/types" +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"; @@ -29,7 +29,7 @@ const MOCK_LOCATIONS: { id: string, name: string }[] = [ { id: "synlab-parnu-1", name: "SYNLAB - Pärnu" }, ] -export default function AnalysisLocation({ cart }: { cart: StoreCart }) { +export default function AnalysisLocation({ cart, analysisPackages }: { cart: StoreCart, analysisPackages: StoreCartLineItem[] }) { const { t } = useTranslation('cart'); const form = useForm>({ @@ -40,12 +40,16 @@ export default function AnalysisLocation({ cart }: { cart: StoreCart }) { }); const onSubmit = async ({ locationId }: z.infer) => { - const promise = updateCart({ - metadata: { - partner_location_name: MOCK_LOCATIONS.find(({ id }) => id === locationId)?.name ?? '', - partner_location_id: locationId, - }, - }); + 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`), diff --git a/app/home/(user)/_components/cart/index.tsx b/app/home/(user)/_components/cart/index.tsx index fc05d7c..4e0086b 100644 --- a/app/home/(user)/_components/cart/index.tsx +++ b/app/home/(user)/_components/cart/index.tsx @@ -121,7 +121,7 @@ export default function Cart({ - + )} diff --git a/app/home/(user)/_components/order/order-item.tsx b/app/home/(user)/_components/order/order-item.tsx index f938360..4cd4e7a 100644 --- a/app/home/(user)/_components/order/order-item.tsx +++ b/app/home/(user)/_components/order/order-item.tsx @@ -22,7 +22,7 @@ export default function OrderItem({ item, currencyCode }: { className="txt-medium-plus text-ui-fg-base" data-testid="product-name" > - {item.product_title} + {item.product_title}{` (${item.metadata?.partner_location_name ?? "-"})`} diff --git a/packages/features/medusa-storefront/src/lib/data/cart.ts b/packages/features/medusa-storefront/src/lib/data/cart.ts index c981ebd..6962415 100644 --- a/packages/features/medusa-storefront/src/lib/data/cart.ts +++ b/packages/features/medusa-storefront/src/lib/data/cart.ts @@ -14,6 +14,7 @@ import { } from "./cookies"; import { getRegion } from "./regions"; import { sdk } from "@lib/config"; +import { retrieveOrder } from "./orders"; /** * Retrieves a cart by its ID. If no ID is provided, it will use the cart ID from the cookies. @@ -161,9 +162,11 @@ export async function addToCart({ export async function updateLineItem({ lineId, quantity, + metadata, }: { lineId: string; quantity: number; + metadata?: Record; }) { if (!lineId) { throw new Error("Missing lineItem ID when updating line item"); @@ -180,7 +183,7 @@ export async function updateLineItem({ }; await sdk.store.cart - .updateLineItem(cartId, lineId, { quantity }, {}, headers) + .updateLineItem(cartId, lineId, { quantity, metadata }, {}, headers) .then(async () => { const cartCacheTag = await getCacheTag("carts"); revalidateTag(cartCacheTag); @@ -425,7 +428,7 @@ export async function placeOrder(cartId?: string, options: { revalidateCacheTags throw new Error("Cart is not an order"); } - return cartRes; + return retrieveOrder(cartRes.order.id); } /**