feat(MED-131): handle analysis order
This commit is contained in:
@@ -2,7 +2,7 @@ import { cache } from 'react';
|
||||
|
||||
import { AdminAccountPage } from '@kit/admin/components/admin-account-page';
|
||||
import { AdminGuard } from '@kit/admin/components/admin-guard';
|
||||
import { getSupabaseServerClient } from '@kit/supabase/server-client';
|
||||
import { getAccount } from '~/lib/services/account.service';
|
||||
|
||||
interface Params {
|
||||
params: Promise<{
|
||||
@@ -28,21 +28,4 @@ async function AccountPage(props: Params) {
|
||||
|
||||
export default AdminGuard(AccountPage);
|
||||
|
||||
const loadAccount = cache(accountLoader);
|
||||
|
||||
async function accountLoader(id: string) {
|
||||
const client = getSupabaseServerClient();
|
||||
|
||||
const { data, error } = await client
|
||||
.schema('medreport')
|
||||
.from('accounts')
|
||||
.select('*, memberships: accounts_memberships (*)')
|
||||
.eq('id', id)
|
||||
.single();
|
||||
|
||||
if (error) {
|
||||
throw error;
|
||||
}
|
||||
|
||||
return data;
|
||||
}
|
||||
const loadAccount = cache(getAccount);
|
||||
|
||||
51
app/api/order/medipost-create/route.ts
Normal file
51
app/api/order/medipost-create/route.ts
Normal file
@@ -0,0 +1,51 @@
|
||||
import { retrieveOrder } from "@lib/data";
|
||||
import { NextRequest, NextResponse } from "next/server";
|
||||
import { getAccountAdmin } from "~/lib/services/account.service";
|
||||
import { composeOrderXML, sendPrivateMessage } from "~/lib/services/medipost.service";
|
||||
import { getOrder, updateOrder } from "~/lib/services/order.service";
|
||||
|
||||
interface MedipostCreateRequest {
|
||||
medusaOrderId: string;
|
||||
}
|
||||
|
||||
export const POST = async (request: NextRequest) => {
|
||||
const { medusaOrderId } = (await request.json()) as MedipostCreateRequest;
|
||||
const medusaOrder = await retrieveOrder(medusaOrderId)
|
||||
const medreportOrder = await getOrder({ medusaOrderId });
|
||||
|
||||
const account = await getAccountAdmin({ primaryOwnerUserId: medreportOrder.user_id });
|
||||
|
||||
const ANALYSIS_ELEMENT_HANDLE_PREFIX = 'analysis-element-';
|
||||
const orderedAnalysisElementsIds = (medusaOrder?.items ?? [])
|
||||
.filter((item) => item.product?.handle?.startsWith(ANALYSIS_ELEMENT_HANDLE_PREFIX))
|
||||
.map((item) => {
|
||||
const id = Number(item.product?.handle?.replace(ANALYSIS_ELEMENT_HANDLE_PREFIX, ''));
|
||||
if (Number.isNaN(id)) {
|
||||
return null;
|
||||
}
|
||||
return id;
|
||||
})
|
||||
.filter(Boolean) as number[];
|
||||
const orderXml = await composeOrderXML({
|
||||
person: {
|
||||
idCode: account.personal_code!,
|
||||
firstName: account.name ?? '',
|
||||
lastName: account.last_name ?? '',
|
||||
phone: account.phone ?? '',
|
||||
},
|
||||
orderedAnalysisElementsIds,
|
||||
orderedAnalysesIds: [],
|
||||
orderId: medusaOrderId,
|
||||
orderCreatedAt: new Date(medreportOrder.created_at),
|
||||
comment: '',
|
||||
});
|
||||
|
||||
await sendPrivateMessage(orderXml);
|
||||
|
||||
await updateOrder({
|
||||
orderId: medreportOrder.id,
|
||||
orderStatus: 'PROCESSING',
|
||||
});
|
||||
|
||||
return NextResponse.json({ orderXml });
|
||||
};
|
||||
Reference in New Issue
Block a user