feat(MED-131): send to medipost on montonio callback
This commit is contained in:
@@ -6,6 +6,7 @@ import { listProductTypes } from "@lib/data/products";
|
|||||||
import { placeOrder, retrieveCart } from "@lib/data/cart";
|
import { placeOrder, retrieveCart } from "@lib/data/cart";
|
||||||
import { createI18nServerInstance } from "~/lib/i18n/i18n.server";
|
import { createI18nServerInstance } from "~/lib/i18n/i18n.server";
|
||||||
import { createOrder } from '~/lib/services/order.service';
|
import { createOrder } from '~/lib/services/order.service';
|
||||||
|
import { sendOrderToMedipost } from '~/lib/services/medipost.service';
|
||||||
|
|
||||||
const emailSender = process.env.EMAIL_SENDER;
|
const emailSender = process.env.EMAIL_SENDER;
|
||||||
const siteUrl = process.env.NEXT_PUBLIC_SITE_URL!;
|
const siteUrl = process.env.NEXT_PUBLIC_SITE_URL!;
|
||||||
@@ -93,6 +94,7 @@ const handleOrderToken = async (orderToken: string) => {
|
|||||||
const analysisPackagesType = productTypes.find(({ metadata }) => metadata?.handle === ANALYSIS_PACKAGES_TYPE_HANDLE);
|
const analysisPackagesType = productTypes.find(({ metadata }) => metadata?.handle === ANALYSIS_PACKAGES_TYPE_HANDLE);
|
||||||
const analysisPackageOrderItem = medusaOrder.items?.find(({ product_type_id }) => product_type_id === analysisPackagesType?.id);
|
const analysisPackageOrderItem = medusaOrder.items?.find(({ product_type_id }) => product_type_id === analysisPackagesType?.id);
|
||||||
return {
|
return {
|
||||||
|
medusaOrderId: medusaOrder.id,
|
||||||
email: medusaOrder.email,
|
email: medusaOrder.email,
|
||||||
partnerLocationName: analysisPackageOrderItem?.metadata?.partner_location_name as string ?? '',
|
partnerLocationName: analysisPackageOrderItem?.metadata?.partner_location_name as string ?? '',
|
||||||
analysisPackageName: analysisPackageOrderItem?.title ?? '',
|
analysisPackageName: analysisPackageOrderItem?.title ?? '',
|
||||||
@@ -121,7 +123,7 @@ export async function GET(request: Request) {
|
|||||||
throw new Error("Order result is missing");
|
throw new Error("Order result is missing");
|
||||||
}
|
}
|
||||||
|
|
||||||
const { email, partnerLocationName, analysisPackageName } = orderResult;
|
const { medusaOrderId, email, partnerLocationName, analysisPackageName } = orderResult;
|
||||||
const personName = account.name;
|
const personName = account.name;
|
||||||
if (email && analysisPackageName) {
|
if (email && analysisPackageName) {
|
||||||
await sendEmail({ email, analysisPackageName, personName, partnerLocationName, language });
|
await sendEmail({ email, analysisPackageName, personName, partnerLocationName, language });
|
||||||
@@ -129,6 +131,7 @@ export async function GET(request: Request) {
|
|||||||
// @TODO send email for separate analyses
|
// @TODO send email for separate analyses
|
||||||
console.error("Missing email or analysisPackageName", orderResult);
|
console.error("Missing email or analysisPackageName", orderResult);
|
||||||
}
|
}
|
||||||
|
sendOrderToMedipost({ medusaOrderId })
|
||||||
return Response.redirect(new URL('/home/order', baseUrl))
|
return Response.redirect(new URL('/home/order', baseUrl))
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
console.error("Failed to place order", error);
|
console.error("Failed to place order", error);
|
||||||
|
|||||||
@@ -41,12 +41,19 @@ import { getAnalysisElementsAdmin } from './analysis-element.service';
|
|||||||
import { getAnalyses } from './analyses.service';
|
import { getAnalyses } from './analyses.service';
|
||||||
import { retrieveOrder } from '@lib/data/orders';
|
import { retrieveOrder } from '@lib/data/orders';
|
||||||
import { getAccountAdmin } from './account.service';
|
import { getAccountAdmin } from './account.service';
|
||||||
|
import { StoreProduct } from '@medusajs/types';
|
||||||
|
import { listProducts } from '@lib/data/products';
|
||||||
|
import { listRegions } from '@lib/data/regions';
|
||||||
|
import { getAnalysisElementMedusaProductIds } from '@/utils/medusa-product';
|
||||||
|
|
||||||
const BASE_URL = process.env.MEDIPOST_URL!;
|
const BASE_URL = process.env.MEDIPOST_URL!;
|
||||||
const USER = process.env.MEDIPOST_USER!;
|
const USER = process.env.MEDIPOST_USER!;
|
||||||
const PASSWORD = process.env.MEDIPOST_PASSWORD!;
|
const PASSWORD = process.env.MEDIPOST_PASSWORD!;
|
||||||
const RECIPIENT = process.env.MEDIPOST_RECIPIENT!;
|
const RECIPIENT = process.env.MEDIPOST_RECIPIENT!;
|
||||||
|
|
||||||
|
const ANALYSIS_ELEMENT_HANDLE_PREFIX = 'analysis-element-';
|
||||||
|
const ANALYSIS_PACKAGE_HANDLE_PREFIX = 'analysis-package-';
|
||||||
|
|
||||||
function parseXML(xml: string) {
|
function parseXML(xml: string) {
|
||||||
const parser = new XMLParser({ ignoreAttributes: false });
|
const parser = new XMLParser({ ignoreAttributes: false });
|
||||||
return parser.parse(xml);
|
return parser.parse(xml);
|
||||||
@@ -630,16 +637,46 @@ export async function sendOrderToMedipost({
|
|||||||
}: {
|
}: {
|
||||||
medusaOrderId: string;
|
medusaOrderId: string;
|
||||||
}) {
|
}) {
|
||||||
const medusaOrder = await retrieveOrder(medusaOrderId)
|
const [medusaOrder, medreportOrder, countryCodes] = await Promise.all([
|
||||||
const medreportOrder = await getOrder({ medusaOrderId });
|
retrieveOrder(medusaOrderId),
|
||||||
|
getOrder({ medusaOrderId }),
|
||||||
|
listRegions(),
|
||||||
|
]);
|
||||||
|
const countryCode = countryCodes[0]!.countries![0]!.iso_2!;
|
||||||
const account = await getAccountAdmin({ primaryOwnerUserId: medreportOrder.user_id });
|
const account = await getAccountAdmin({ primaryOwnerUserId: medreportOrder.user_id });
|
||||||
|
|
||||||
const ANALYSIS_ELEMENT_HANDLE_PREFIX = 'analysis-element-';
|
let analysisPackageElements: StoreProduct[] = [];
|
||||||
const orderedAnalysisElementsIds = (medusaOrder?.items ?? [])
|
const orderedAnalysisPackages = (medusaOrder?.items ?? []).filter(({ product }) => product?.handle.startsWith(ANALYSIS_PACKAGE_HANDLE_PREFIX));
|
||||||
.filter((item) => item.product?.handle?.startsWith(ANALYSIS_ELEMENT_HANDLE_PREFIX))
|
const orderedAnalysisElements = (medusaOrder?.items ?? []).filter(({ product }) => product?.handle.startsWith(ANALYSIS_ELEMENT_HANDLE_PREFIX));
|
||||||
.map((item) => {
|
|
||||||
const id = Number(item.product?.handle?.replace(ANALYSIS_ELEMENT_HANDLE_PREFIX, ''));
|
if (orderedAnalysisPackages.length > 0) {
|
||||||
|
const { response: { products: analysisPackages } } = await listProducts({
|
||||||
|
countryCode,
|
||||||
|
queryParams: { limit: 100, "type_id[0]": orderedAnalysisPackages[0]!.product_type_id! },
|
||||||
|
});
|
||||||
|
const analysisElementMedusaProductIds = getAnalysisElementMedusaProductIds(analysisPackages);
|
||||||
|
const { response: { products } } = await listProducts({
|
||||||
|
countryCode,
|
||||||
|
queryParams: {
|
||||||
|
id: analysisElementMedusaProductIds,
|
||||||
|
limit: 100,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
analysisPackageElements = products;
|
||||||
|
}
|
||||||
|
|
||||||
|
const analysisPackageElementsIds = analysisPackageElements
|
||||||
|
.map((product) => {
|
||||||
|
const id = Number(product?.metadata?.analysisIdOriginal);
|
||||||
|
if (Number.isNaN(id)) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
return id;
|
||||||
|
})
|
||||||
|
.filter(Boolean) as number[];
|
||||||
|
const orderedAnalysisElementsIds = orderedAnalysisElements
|
||||||
|
.map((line) => {
|
||||||
|
const id = Number(line.product?.handle?.replace(ANALYSIS_ELEMENT_HANDLE_PREFIX, ''));
|
||||||
if (Number.isNaN(id)) {
|
if (Number.isNaN(id)) {
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
@@ -653,7 +690,7 @@ export async function sendOrderToMedipost({
|
|||||||
lastName: account.last_name ?? '',
|
lastName: account.last_name ?? '',
|
||||||
phone: account.phone ?? '',
|
phone: account.phone ?? '',
|
||||||
},
|
},
|
||||||
orderedAnalysisElementsIds,
|
orderedAnalysisElementsIds: [...analysisPackageElementsIds, ...orderedAnalysisElementsIds],
|
||||||
orderedAnalysesIds: [],
|
orderedAnalysesIds: [],
|
||||||
orderId: medusaOrderId,
|
orderId: medusaOrderId,
|
||||||
orderCreatedAt: new Date(medreportOrder.created_at),
|
orderCreatedAt: new Date(medreportOrder.created_at),
|
||||||
|
|||||||
Reference in New Issue
Block a user