feat(MED-100): partner location metadata stored on order line instead of order

This commit is contained in:
2025-07-24 09:23:44 +03:00
parent 3341dbd306
commit 894cf1b454
6 changed files with 31 additions and 18 deletions

View File

@@ -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) {