chore(medusa,core-flows): begin and cancel receive return (#8171)
What: * `POST /admin/returns/:id/receive` * `DELETE /admin/returns/:id/receive` CLOSES: CC-189
This commit is contained in:
committed by
GitHub
parent
8ffcec3fc4
commit
1a472733ae
@@ -201,12 +201,11 @@ medusaIntegrationTestRunner({
|
||||
})
|
||||
)
|
||||
|
||||
expect(result.data.order_preview).toEqual(
|
||||
expect(result.data.order.order_change).toEqual(
|
||||
expect.objectContaining({
|
||||
id: expect.any(String),
|
||||
return_id: returnId,
|
||||
change_type: "return",
|
||||
actions: [],
|
||||
description: "Test",
|
||||
status: "pending",
|
||||
order_id: order.id,
|
||||
@@ -578,6 +577,63 @@ medusaIntegrationTestRunner({
|
||||
`Return id not found: ${returnId}`
|
||||
)
|
||||
})
|
||||
|
||||
describe("should request a return and receive if", () => {
|
||||
let returnId
|
||||
beforeEach(async () => {
|
||||
let result = await api.post(
|
||||
"/admin/returns",
|
||||
{
|
||||
order_id: order.id,
|
||||
description: "Test",
|
||||
},
|
||||
adminHeaders
|
||||
)
|
||||
|
||||
returnId = result.data.return.id
|
||||
const item = order.items[0]
|
||||
await api.post(
|
||||
`/admin/returns/${returnId}/request-items`,
|
||||
{
|
||||
items: [
|
||||
{
|
||||
id: item.id,
|
||||
quantity: 2,
|
||||
reason_id: returnReason.id,
|
||||
},
|
||||
],
|
||||
},
|
||||
adminHeaders
|
||||
)
|
||||
await api.post(
|
||||
`/admin/returns/${returnId}/shipping-method`,
|
||||
{
|
||||
shipping_option_id: returnShippingOption.id,
|
||||
},
|
||||
adminHeaders
|
||||
)
|
||||
await api.post(`/admin/returns/${returnId}/request`, {}, adminHeaders)
|
||||
})
|
||||
|
||||
it("should receive the return", async () => {
|
||||
let result = await api.post(
|
||||
`/admin/returns/${returnId}/receive`,
|
||||
{
|
||||
internal_note: "Test internal note",
|
||||
},
|
||||
adminHeaders
|
||||
)
|
||||
|
||||
expect(result.data.order.order_change).toEqual(
|
||||
expect.objectContaining({
|
||||
return_id: returnId,
|
||||
change_type: "return",
|
||||
status: "pending",
|
||||
internal_note: "Test internal note",
|
||||
})
|
||||
)
|
||||
})
|
||||
})
|
||||
})
|
||||
},
|
||||
})
|
||||
|
||||
@@ -46,7 +46,7 @@ export const orderClaimAddNewItemWorkflow = createWorkflow(
|
||||
): WorkflowData<OrderDTO> {
|
||||
const orderClaim = useRemoteQueryStep({
|
||||
entry_point: "order_claim",
|
||||
fields: ["id", "order_id"],
|
||||
fields: ["id", "order_id", "canceled_at"],
|
||||
variables: { id: input.claim_id },
|
||||
list: false,
|
||||
throw_if_key_not_found: true,
|
||||
@@ -54,7 +54,7 @@ export const orderClaimAddNewItemWorkflow = createWorkflow(
|
||||
|
||||
const order: OrderDTO = useRemoteQueryStep({
|
||||
entry_point: "orders",
|
||||
fields: ["id", "status", "items.*"],
|
||||
fields: ["id", "status", "canceled_at", "items.*"],
|
||||
variables: { id: orderClaim.order_id },
|
||||
list: false,
|
||||
throw_if_key_not_found: true,
|
||||
|
||||
@@ -56,7 +56,7 @@ export const orderClaimRequestItemReturnWorkflow = createWorkflow(
|
||||
): WorkflowData<OrderDTO> {
|
||||
const orderClaim = useRemoteQueryStep({
|
||||
entry_point: "order_claim",
|
||||
fields: ["id", "order_id", "return_id"],
|
||||
fields: ["id", "order_id", "return_id", "canceled_at"],
|
||||
variables: { id: input.claim_id },
|
||||
list: false,
|
||||
throw_if_key_not_found: true,
|
||||
@@ -67,7 +67,7 @@ export const orderClaimRequestItemReturnWorkflow = createWorkflow(
|
||||
}).then(() => {
|
||||
return useRemoteQueryStep({
|
||||
entry_point: "return",
|
||||
fields: ["id", "status", "order_id"],
|
||||
fields: ["id", "status", "order_id", "canceled_at"],
|
||||
variables: { id: orderClaim.return_id },
|
||||
list: false,
|
||||
throw_if_key_not_found: true,
|
||||
|
||||
@@ -46,7 +46,7 @@ export const orderExchangeAddNewItemWorkflow = createWorkflow(
|
||||
): WorkflowData<OrderDTO> {
|
||||
const orderExchange = useRemoteQueryStep({
|
||||
entry_point: "order_exchange",
|
||||
fields: ["id", "order_id"],
|
||||
fields: ["id", "order_id", "canceled_at"],
|
||||
variables: { id: input.exchange_id },
|
||||
list: false,
|
||||
throw_if_key_not_found: true,
|
||||
@@ -54,7 +54,7 @@ export const orderExchangeAddNewItemWorkflow = createWorkflow(
|
||||
|
||||
const order: OrderDTO = useRemoteQueryStep({
|
||||
entry_point: "orders",
|
||||
fields: ["id", "status", "items.*"],
|
||||
fields: ["id", "status", "canceled_at", "items.*"],
|
||||
variables: { id: orderExchange.order_id },
|
||||
list: false,
|
||||
throw_if_key_not_found: true,
|
||||
|
||||
@@ -57,7 +57,7 @@ export const orderExchangeRequestItemReturnWorkflow = createWorkflow(
|
||||
): WorkflowData<OrderDTO> {
|
||||
const orderExchange = useRemoteQueryStep({
|
||||
entry_point: "order_exchange",
|
||||
fields: ["id", "order_id", "return_id"],
|
||||
fields: ["id", "order_id", "return_id", "canceled_at"],
|
||||
variables: { id: input.exchange_id },
|
||||
list: false,
|
||||
throw_if_key_not_found: true,
|
||||
@@ -68,7 +68,7 @@ export const orderExchangeRequestItemReturnWorkflow = createWorkflow(
|
||||
}).then(() => {
|
||||
return useRemoteQueryStep({
|
||||
entry_point: "return",
|
||||
fields: ["id", "status", "order_id"],
|
||||
fields: ["id", "status", "order_id", "canceled_at"],
|
||||
variables: { id: orderExchange.return_id },
|
||||
list: false,
|
||||
throw_if_key_not_found: true,
|
||||
|
||||
@@ -6,7 +6,6 @@ export * from "./cancel-order-fulfillment"
|
||||
export * from "./claim/begin-order-claim"
|
||||
export * from "./claim/claim-request-item-return"
|
||||
export * from "./complete-orders"
|
||||
export * from "./create-complete-return"
|
||||
export * from "./create-fulfillment"
|
||||
export * from "./create-order-change"
|
||||
export * from "./create-order-change-actions"
|
||||
@@ -21,12 +20,15 @@ export * from "./exchange/exchange-add-new-item"
|
||||
export * from "./exchange/exchange-request-item-return"
|
||||
export * from "./get-order-detail"
|
||||
export * from "./get-orders-list"
|
||||
export * from "./return/begin-receive-return"
|
||||
export * from "./return/begin-return"
|
||||
export * from "./return/cancel-receive-return"
|
||||
export * from "./return/cancel-request-return"
|
||||
export * from "./return/cancel-return"
|
||||
export * from "./return/confirm-return-request"
|
||||
export * from "./return/create-complete-return"
|
||||
export * from "./return/create-return-shipping-method"
|
||||
export * from "./return/receive-return"
|
||||
export * from "./return/receive-complete-return"
|
||||
export * from "./return/remove-request-item-return"
|
||||
export * from "./return/remove-return-shipping-method"
|
||||
export * from "./return/request-item-return"
|
||||
|
||||
@@ -0,0 +1,73 @@
|
||||
import {
|
||||
OrderChangeDTO,
|
||||
OrderDTO,
|
||||
OrderWorkflow,
|
||||
ReturnDTO,
|
||||
} from "@medusajs/types"
|
||||
import {
|
||||
WorkflowData,
|
||||
createStep,
|
||||
createWorkflow,
|
||||
transform,
|
||||
} from "@medusajs/workflows-sdk"
|
||||
import { useRemoteQueryStep } from "../../../common"
|
||||
import { createOrderChangeStep } from "../../steps"
|
||||
import { throwIfIsCancelled } from "../../utils/order-validation"
|
||||
|
||||
const validationStep = createStep(
|
||||
"begin-receive-return-validation",
|
||||
async function (
|
||||
{
|
||||
orderReturn,
|
||||
order,
|
||||
}: {
|
||||
orderReturn: ReturnDTO
|
||||
order: OrderDTO
|
||||
},
|
||||
context
|
||||
) {
|
||||
throwIfIsCancelled(order, "Order")
|
||||
throwIfIsCancelled(orderReturn, "Return")
|
||||
}
|
||||
)
|
||||
|
||||
export const beginReceiveReturnWorkflowId = "begin-receive-return"
|
||||
export const beginReceiveReturnWorkflow = createWorkflow(
|
||||
beginReceiveReturnWorkflowId,
|
||||
function (
|
||||
input: WorkflowData<OrderWorkflow.BeginReceiveOrderReturnWorkflowInput>
|
||||
): WorkflowData<OrderChangeDTO> {
|
||||
const orderReturn: ReturnDTO = useRemoteQueryStep({
|
||||
entry_point: "return",
|
||||
fields: ["id", "status", "order_id", "canceled_at"],
|
||||
variables: { id: input.return_id },
|
||||
list: false,
|
||||
throw_if_key_not_found: true,
|
||||
})
|
||||
|
||||
const order: OrderDTO = useRemoteQueryStep({
|
||||
entry_point: "orders",
|
||||
fields: ["id", "version", "status", "canceled_at"],
|
||||
variables: { id: orderReturn.order_id },
|
||||
list: false,
|
||||
throw_if_key_not_found: true,
|
||||
}).config({ name: "order-query" })
|
||||
|
||||
validationStep({ order, orderReturn })
|
||||
|
||||
const orderChangeInput = transform(
|
||||
{ orderReturn, order, input },
|
||||
({ orderReturn, order, input }) => {
|
||||
return {
|
||||
change_type: "return" as const,
|
||||
order_id: order.id,
|
||||
return_id: orderReturn.id,
|
||||
created_by: input.created_by,
|
||||
description: input.description,
|
||||
internal_note: input.internal_note,
|
||||
}
|
||||
}
|
||||
)
|
||||
return createOrderChangeStep(orderChangeInput)
|
||||
}
|
||||
)
|
||||
@@ -6,8 +6,7 @@ import {
|
||||
transform,
|
||||
} from "@medusajs/workflows-sdk"
|
||||
import { useRemoteQueryStep } from "../../../common"
|
||||
import { createOrderChangeStep } from "../../steps/create-order-change"
|
||||
import { createReturnsStep } from "../../steps/create-returns"
|
||||
import { createOrderChangeStep, createReturnsStep } from "../../steps"
|
||||
import { throwIfOrderIsCancelled } from "../../utils/order-validation"
|
||||
|
||||
const validationStep = createStep(
|
||||
|
||||
@@ -0,0 +1,69 @@
|
||||
import { OrderChangeDTO, OrderDTO, ReturnDTO } from "@medusajs/types"
|
||||
import { OrderChangeStatus } from "@medusajs/utils"
|
||||
import {
|
||||
WorkflowData,
|
||||
createStep,
|
||||
createWorkflow,
|
||||
} from "@medusajs/workflows-sdk"
|
||||
import { useRemoteQueryStep } from "../../../common"
|
||||
import { deleteOrderChangesStep } from "../../steps"
|
||||
import {
|
||||
throwIfIsCancelled,
|
||||
throwIfOrderChangeIsNotActive,
|
||||
} from "../../utils/order-validation"
|
||||
|
||||
const validationStep = createStep(
|
||||
"validate-cancel-return-shipping-method",
|
||||
async function ({
|
||||
order,
|
||||
orderChange,
|
||||
orderReturn,
|
||||
}: {
|
||||
order: OrderDTO
|
||||
orderReturn: ReturnDTO
|
||||
orderChange: OrderChangeDTO
|
||||
}) {
|
||||
throwIfIsCancelled(order, "Order")
|
||||
throwIfIsCancelled(orderReturn, "Return")
|
||||
throwIfOrderChangeIsNotActive({ orderChange })
|
||||
}
|
||||
)
|
||||
|
||||
export const cancelReturnReceiveWorkflowId = "cancel-receive-return"
|
||||
export const cancelReturnReceiveWorkflow = createWorkflow(
|
||||
cancelReturnReceiveWorkflowId,
|
||||
function (input: { return_id: string }): WorkflowData<void> {
|
||||
const orderReturn: ReturnDTO = useRemoteQueryStep({
|
||||
entry_point: "return",
|
||||
fields: ["id", "status", "order_id", "canceled_at"],
|
||||
variables: { id: input.return_id },
|
||||
list: false,
|
||||
throw_if_key_not_found: true,
|
||||
})
|
||||
|
||||
const order: OrderDTO = useRemoteQueryStep({
|
||||
entry_point: "orders",
|
||||
fields: ["id", "version", "canceled_at"],
|
||||
variables: { id: orderReturn.order_id },
|
||||
list: false,
|
||||
throw_if_key_not_found: true,
|
||||
}).config({ name: "order-query" })
|
||||
|
||||
const orderChange: OrderChangeDTO = useRemoteQueryStep({
|
||||
entry_point: "order_change",
|
||||
fields: ["id", "status", "version"],
|
||||
variables: {
|
||||
filters: {
|
||||
order_id: orderReturn.order_id,
|
||||
return_id: orderReturn.id,
|
||||
status: [OrderChangeStatus.PENDING, OrderChangeStatus.REQUESTED],
|
||||
},
|
||||
},
|
||||
list: false,
|
||||
}).config({ name: "order-change-query" })
|
||||
|
||||
validationStep({ order, orderReturn, orderChange })
|
||||
|
||||
deleteOrderChangesStep({ ids: [orderChange.id] })
|
||||
}
|
||||
)
|
||||
@@ -45,7 +45,7 @@ export const cancelReturnRequestWorkflow = createWorkflow(
|
||||
function (input: WorkflowInput): WorkflowData<void> {
|
||||
const orderReturn: ReturnDTO = useRemoteQueryStep({
|
||||
entry_point: "return",
|
||||
fields: ["id", "status", "order_id"],
|
||||
fields: ["id", "status", "order_id", "canceled_at"],
|
||||
variables: { id: input.return_id },
|
||||
list: false,
|
||||
throw_if_key_not_found: true,
|
||||
@@ -53,7 +53,7 @@ export const cancelReturnRequestWorkflow = createWorkflow(
|
||||
|
||||
const order: OrderDTO = useRemoteQueryStep({
|
||||
entry_point: "orders",
|
||||
fields: ["id", "version", "items"],
|
||||
fields: ["id", "version", "canceled_at"],
|
||||
variables: { id: orderReturn.order_id },
|
||||
list: false,
|
||||
throw_if_key_not_found: true,
|
||||
|
||||
@@ -67,6 +67,7 @@ export const cancelReturnWorkflow = createWorkflow(
|
||||
entry_point: "return",
|
||||
fields: [
|
||||
"id",
|
||||
"canceled_at",
|
||||
"items.id",
|
||||
"items.received_quantity",
|
||||
"fulfillments.canceled_at",
|
||||
|
||||
@@ -42,7 +42,7 @@ export const confirmReturnRequestWorkflow = createWorkflow(
|
||||
function (input: WorkflowInput): WorkflowData<OrderDTO> {
|
||||
const orderReturn: ReturnDTO = useRemoteQueryStep({
|
||||
entry_point: "return",
|
||||
fields: ["id", "status", "order_id"],
|
||||
fields: ["id", "status", "order_id", "canceled_at"],
|
||||
variables: { id: input.return_id },
|
||||
list: false,
|
||||
throw_if_key_not_found: true,
|
||||
@@ -50,7 +50,7 @@ export const confirmReturnRequestWorkflow = createWorkflow(
|
||||
|
||||
const order: OrderDTO = useRemoteQueryStep({
|
||||
entry_point: "orders",
|
||||
fields: ["id", "version", "items"],
|
||||
fields: ["id", "version", "canceled_at"],
|
||||
variables: { id: orderReturn.order_id },
|
||||
list: false,
|
||||
throw_if_key_not_found: true,
|
||||
|
||||
@@ -15,15 +15,15 @@ import {
|
||||
parallelize,
|
||||
transform,
|
||||
} from "@medusajs/workflows-sdk"
|
||||
import { createRemoteLinkStep, useRemoteQueryStep } from "../../common"
|
||||
import { createReturnFulfillmentWorkflow } from "../../fulfillment"
|
||||
import { createCompleteReturnStep } from "../steps/create-complete-return"
|
||||
import { receiveReturnStep } from "../steps/receive-return"
|
||||
import { createRemoteLinkStep, useRemoteQueryStep } from "../../../common"
|
||||
import { createReturnFulfillmentWorkflow } from "../../../fulfillment"
|
||||
import { createCompleteReturnStep } from "../../steps/create-complete-return"
|
||||
import { receiveReturnStep } from "../../steps/receive-return"
|
||||
import {
|
||||
throwIfItemsDoesNotExistsInOrder,
|
||||
throwIfOrderIsCancelled,
|
||||
} from "../utils/order-validation"
|
||||
import { validateReturnReasons } from "../utils/validate-return-reason"
|
||||
} from "../../utils/order-validation"
|
||||
import { validateReturnReasons } from "../../utils/validate-return-reason"
|
||||
|
||||
function prepareShippingMethodData({
|
||||
orderId,
|
||||
@@ -48,7 +48,7 @@ export const createReturnShippingMethodWorkflow = createWorkflow(
|
||||
}): WorkflowData<OrderDTO> {
|
||||
const orderReturn: ReturnDTO = useRemoteQueryStep({
|
||||
entry_point: "return",
|
||||
fields: ["id", "status", "order_id"],
|
||||
fields: ["id", "status", "order_id", "canceled_at"],
|
||||
variables: { id: input.return_id },
|
||||
list: false,
|
||||
throw_if_key_not_found: true,
|
||||
@@ -56,7 +56,7 @@ export const createReturnShippingMethodWorkflow = createWorkflow(
|
||||
|
||||
const order: OrderDTO = useRemoteQueryStep({
|
||||
entry_point: "orders",
|
||||
fields: ["id", "status", "currency_code"],
|
||||
fields: ["id", "status", "currency_code", "canceled_at"],
|
||||
variables: { id: orderReturn.order_id },
|
||||
list: false,
|
||||
throw_if_key_not_found: true,
|
||||
|
||||
@@ -21,7 +21,7 @@ const validationStep = createStep(
|
||||
input,
|
||||
}: {
|
||||
orderReturn
|
||||
input: OrderWorkflow.ReceiveOrderReturnWorkflowInput
|
||||
input: OrderWorkflow.ReceiveCompleteOrderReturnWorkflowInput
|
||||
},
|
||||
context
|
||||
) {
|
||||
@@ -30,11 +30,11 @@ const validationStep = createStep(
|
||||
}
|
||||
)
|
||||
|
||||
export const receiveReturnOrderWorkflowId = "receive-return-order"
|
||||
export const receiveReturnOrderWorkflow = createWorkflow(
|
||||
receiveReturnOrderWorkflowId,
|
||||
export const receiveAndCompleteReturnOrderWorkflowId = "receive-return-order"
|
||||
export const receiveAndCompleteReturnOrderWorkflow = createWorkflow(
|
||||
receiveAndCompleteReturnOrderWorkflowId,
|
||||
function (
|
||||
input: WorkflowData<OrderWorkflow.ReceiveOrderReturnWorkflowInput>
|
||||
input: WorkflowData<OrderWorkflow.ReceiveCompleteOrderReturnWorkflowInput>
|
||||
): WorkflowData<ReturnDTO> {
|
||||
const orderReturn: ReturnDTO = useRemoteQueryStep({
|
||||
entry_point: "returns",
|
||||
@@ -62,7 +62,7 @@ export const removeRequestItemReturnWorkflow = createWorkflow(
|
||||
): WorkflowData<OrderDTO> {
|
||||
const orderReturn: ReturnDTO = useRemoteQueryStep({
|
||||
entry_point: "return",
|
||||
fields: ["id", "status", "order_id"],
|
||||
fields: ["id", "status", "order_id", "canceled_at"],
|
||||
variables: { id: input.return_id },
|
||||
list: false,
|
||||
throw_if_key_not_found: true,
|
||||
@@ -70,7 +70,7 @@ export const removeRequestItemReturnWorkflow = createWorkflow(
|
||||
|
||||
const order: OrderDTO = useRemoteQueryStep({
|
||||
entry_point: "orders",
|
||||
fields: ["id", "status", "items.*"],
|
||||
fields: ["id", "status", "canceled_at", "items.*"],
|
||||
variables: { id: orderReturn.order_id },
|
||||
list: false,
|
||||
throw_if_key_not_found: true,
|
||||
|
||||
@@ -60,7 +60,7 @@ export const removeReturnShippingMethodWorkflow = createWorkflow(
|
||||
): WorkflowData {
|
||||
const orderReturn: ReturnDTO = useRemoteQueryStep({
|
||||
entry_point: "return",
|
||||
fields: ["id", "status", "order_id"],
|
||||
fields: ["id", "status", "order_id", "canceled_at"],
|
||||
variables: { id: input.return_id },
|
||||
list: false,
|
||||
throw_if_key_not_found: true,
|
||||
|
||||
@@ -57,7 +57,7 @@ export const requestItemReturnWorkflow = createWorkflow(
|
||||
): WorkflowData<OrderDTO> {
|
||||
const orderReturn: ReturnDTO = useRemoteQueryStep({
|
||||
entry_point: "return",
|
||||
fields: ["id", "status", "order_id"],
|
||||
fields: ["id", "status", "order_id", "canceled_at"],
|
||||
variables: { id: input.return_id },
|
||||
list: false,
|
||||
throw_if_key_not_found: true,
|
||||
@@ -65,7 +65,7 @@ export const requestItemReturnWorkflow = createWorkflow(
|
||||
|
||||
const order: OrderDTO = useRemoteQueryStep({
|
||||
entry_point: "orders",
|
||||
fields: ["id", "status", "items.*"],
|
||||
fields: ["id", "status", "canceled_at", "items.*"],
|
||||
variables: { id: orderReturn.order_id },
|
||||
list: false,
|
||||
throw_if_key_not_found: true,
|
||||
|
||||
@@ -77,7 +77,7 @@ export const updateRequestItemReturnWorkflow = createWorkflow(
|
||||
): WorkflowData<OrderDTO> {
|
||||
const orderReturn: ReturnDTO = useRemoteQueryStep({
|
||||
entry_point: "return",
|
||||
fields: ["id", "status", "order_id"],
|
||||
fields: ["id", "status", "order_id", "canceled_at"],
|
||||
variables: { id: input.return_id },
|
||||
list: false,
|
||||
throw_if_key_not_found: true,
|
||||
@@ -85,7 +85,7 @@ export const updateRequestItemReturnWorkflow = createWorkflow(
|
||||
|
||||
const order: OrderDTO = useRemoteQueryStep({
|
||||
entry_point: "orders",
|
||||
fields: ["id", "status", "items.*"],
|
||||
fields: ["id", "status", "canceled_at", "items.*"],
|
||||
variables: { id: orderReturn.order_id },
|
||||
list: false,
|
||||
throw_if_key_not_found: true,
|
||||
|
||||
@@ -62,7 +62,7 @@ export const updateReturnShippingMethodWorkflow = createWorkflow(
|
||||
): WorkflowData {
|
||||
const orderReturn: ReturnDTO = useRemoteQueryStep({
|
||||
entry_point: "return",
|
||||
fields: ["id", "status", "order_id"],
|
||||
fields: ["id", "status", "order_id", "canceled_at"],
|
||||
variables: { id: input.return_id },
|
||||
list: false,
|
||||
throw_if_key_not_found: true,
|
||||
|
||||
@@ -387,7 +387,7 @@ export interface UpdateOrderItemWithSelectorDTO {
|
||||
interface BaseOrderBundledItemActionsDTO {
|
||||
id: string
|
||||
quantity: BigNumberInput
|
||||
internal_note?: string | null
|
||||
internal_note?: string
|
||||
note?: string | null
|
||||
metadata?: Record<string, unknown> | null
|
||||
[key: string]: any
|
||||
@@ -399,7 +399,7 @@ interface BaseOrderBundledActionsDTO {
|
||||
exchange_id?: string
|
||||
|
||||
description?: string
|
||||
internal_note?: string | null
|
||||
internal_note?: string
|
||||
reference?: string
|
||||
reference_id?: string
|
||||
created_by?: string | null
|
||||
@@ -445,6 +445,7 @@ export interface UpdateReturnDTO {
|
||||
metadata?: Record<string, unknown> | null
|
||||
items?: {
|
||||
quantity: BigNumberInput
|
||||
internal_note?: string | null
|
||||
note?: string | null
|
||||
reason_id?: string | null
|
||||
metadata?: Record<string, unknown> | null
|
||||
|
||||
@@ -3,15 +3,28 @@ import { BigNumberInput } from "../../totals"
|
||||
interface ReceiveReturnItem {
|
||||
id: string
|
||||
quantity: BigNumberInput
|
||||
internal_note?: string | null
|
||||
reason_id?: string | null
|
||||
note?: string | null
|
||||
metadata?: Record<string, any>
|
||||
internal_note?: string
|
||||
metadata?: Record<string, any> | null
|
||||
}
|
||||
|
||||
export interface ReceiveOrderReturnWorkflowInput {
|
||||
export interface BeginReceiveOrderReturnWorkflowInput {
|
||||
return_id: string
|
||||
created_by?: string | null // The id of the authenticated user
|
||||
items: ReceiveReturnItem[]
|
||||
internal_note?: string | null
|
||||
created_by?: string // The id of the authenticated user
|
||||
description?: string
|
||||
internal_note?: string
|
||||
metadata?: Record<string, any> | null
|
||||
}
|
||||
|
||||
export interface ReceiveOrderReturnItemsWorkflowInput {
|
||||
return_id: string
|
||||
items: ReceiveReturnItem[]
|
||||
}
|
||||
|
||||
export interface ReceiveCompleteOrderReturnWorkflowInput {
|
||||
return_id: string
|
||||
created_by?: string // The id of the authenticated user
|
||||
items: ReceiveReturnItem[]
|
||||
description?: string
|
||||
internal_note?: string
|
||||
metadata?: Record<string, any> | null
|
||||
}
|
||||
|
||||
@@ -6,14 +6,17 @@ import {
|
||||
import { AdminPostCancelReturnReqSchemaType } from "../../validators"
|
||||
|
||||
export const POST = async (
|
||||
req: AuthenticatedMedusaRequest,
|
||||
req: AuthenticatedMedusaRequest<AdminPostCancelReturnReqSchemaType>,
|
||||
res: MedusaResponse
|
||||
) => {
|
||||
const input = req.validatedBody as AdminPostCancelReturnReqSchemaType
|
||||
const { id } = req.params
|
||||
|
||||
const workflow = cancelReturnWorkflow(req.scope)
|
||||
const { result } = await workflow.run({
|
||||
input,
|
||||
input: {
|
||||
...req.validatedBody,
|
||||
return_id: id,
|
||||
},
|
||||
})
|
||||
|
||||
res.status(200).json({ return: result })
|
||||
|
||||
@@ -1,4 +1,13 @@
|
||||
import { receiveReturnOrderWorkflow } from "@medusajs/core-flows"
|
||||
import {
|
||||
beginReceiveReturnWorkflow,
|
||||
cancelReturnReceiveWorkflow,
|
||||
} from "@medusajs/core-flows"
|
||||
import {
|
||||
ContainerRegistrationKeys,
|
||||
ModuleRegistrationName,
|
||||
promiseAll,
|
||||
remoteQueryObjectFromString,
|
||||
} from "@medusajs/utils"
|
||||
import {
|
||||
AuthenticatedMedusaRequest,
|
||||
MedusaResponse,
|
||||
@@ -9,12 +18,56 @@ export const POST = async (
|
||||
req: AuthenticatedMedusaRequest<AdminPostReceiveReturnsReqSchemaType>,
|
||||
res: MedusaResponse
|
||||
) => {
|
||||
const input = req.validatedBody as AdminPostReceiveReturnsReqSchemaType
|
||||
const remoteQuery = req.scope.resolve(ContainerRegistrationKeys.REMOTE_QUERY)
|
||||
const orderModuleService = req.scope.resolve(ModuleRegistrationName.ORDER)
|
||||
|
||||
const workflow = receiveReturnOrderWorkflow(req.scope)
|
||||
const { id } = req.params
|
||||
|
||||
const workflow = beginReceiveReturnWorkflow(req.scope)
|
||||
const { result } = await workflow.run({
|
||||
input,
|
||||
input: {
|
||||
...req.validatedBody,
|
||||
return_id: id,
|
||||
},
|
||||
})
|
||||
|
||||
res.status(200).json({ return: result })
|
||||
const queryObject = remoteQueryObjectFromString({
|
||||
entryPoint: "return",
|
||||
variables: {
|
||||
id: result.return_id,
|
||||
filters: {
|
||||
...req.filterableFields,
|
||||
},
|
||||
},
|
||||
fields: req.remoteQueryConfig.fields,
|
||||
})
|
||||
|
||||
const [order, orderReturn] = await promiseAll([
|
||||
orderModuleService.retrieveOrder(result.order_id),
|
||||
remoteQuery(queryObject),
|
||||
])
|
||||
|
||||
res.json({
|
||||
order,
|
||||
return: orderReturn[0],
|
||||
})
|
||||
}
|
||||
|
||||
export const DELETE = async (
|
||||
req: AuthenticatedMedusaRequest,
|
||||
res: MedusaResponse
|
||||
) => {
|
||||
const { id } = req.params
|
||||
|
||||
await cancelReturnReceiveWorkflow(req.scope).run({
|
||||
input: {
|
||||
return_id: id,
|
||||
},
|
||||
})
|
||||
|
||||
res.status(200).json({
|
||||
id,
|
||||
object: "return",
|
||||
deleted: true,
|
||||
})
|
||||
}
|
||||
|
||||
@@ -5,6 +5,7 @@ import * as QueryConfig from "./query-config"
|
||||
import {
|
||||
AdminGetOrdersOrderParams,
|
||||
AdminGetOrdersParams,
|
||||
AdminPostReceiveReturnsReqSchema,
|
||||
AdminPostReturnsConfirmRequestReqSchema,
|
||||
AdminPostReturnsReqSchema,
|
||||
AdminPostReturnsRequestItemsActionReqSchema,
|
||||
@@ -125,4 +126,20 @@ export const adminReturnRoutesMiddlewares: MiddlewareRoute[] = [
|
||||
matcher: "/admin/returns/:id/request",
|
||||
middlewares: [],
|
||||
},
|
||||
{
|
||||
method: ["POST"],
|
||||
matcher: "/admin/returns/:id/receive",
|
||||
middlewares: [
|
||||
validateAndTransformBody(AdminPostReceiveReturnsReqSchema),
|
||||
validateAndTransformQuery(
|
||||
AdminGetOrdersOrderParams,
|
||||
QueryConfig.retrieveTransformQueryConfig
|
||||
),
|
||||
],
|
||||
},
|
||||
{
|
||||
method: ["DELETE"],
|
||||
matcher: "/admin/returns/:id/receive",
|
||||
middlewares: [],
|
||||
},
|
||||
]
|
||||
|
||||
@@ -1,6 +1,8 @@
|
||||
import { beginReturnOrderWorkflow } from "@medusajs/core-flows"
|
||||
import {
|
||||
ContainerRegistrationKeys,
|
||||
ModuleRegistrationName,
|
||||
promiseAll,
|
||||
remoteQueryObjectFromString,
|
||||
} from "@medusajs/utils"
|
||||
import {
|
||||
@@ -42,6 +44,7 @@ export const POST = async (
|
||||
) => {
|
||||
const input = req.validatedBody as AdminPostReturnsReqSchemaType
|
||||
const remoteQuery = req.scope.resolve(ContainerRegistrationKeys.REMOTE_QUERY)
|
||||
const orderModuleService = req.scope.resolve(ModuleRegistrationName.ORDER)
|
||||
|
||||
const workflow = beginReturnOrderWorkflow(req.scope)
|
||||
const { result } = await workflow.run({
|
||||
@@ -59,10 +62,13 @@ export const POST = async (
|
||||
fields: req.remoteQueryConfig.fields,
|
||||
})
|
||||
|
||||
const [orderReturn] = await remoteQuery(queryObject)
|
||||
const [order, orderReturn] = await promiseAll([
|
||||
orderModuleService.retrieveOrder(result.order_id),
|
||||
remoteQuery(queryObject),
|
||||
])
|
||||
|
||||
res.json({
|
||||
order_preview: result,
|
||||
return: orderReturn,
|
||||
order,
|
||||
return: orderReturn[0],
|
||||
})
|
||||
}
|
||||
|
||||
@@ -38,13 +38,6 @@ export const AdminGetOrdersParams = createFindParams({
|
||||
|
||||
export type AdminGetOrdersParamsType = z.infer<typeof AdminGetOrdersParams>
|
||||
|
||||
const ItemSchema = z.object({
|
||||
id: z.string(),
|
||||
quantity: z.number().min(1),
|
||||
reason_id: z.string().nullish(),
|
||||
note: z.string().optional(),
|
||||
})
|
||||
|
||||
export const AdminPostReturnsReqSchema = z.object({
|
||||
order_id: z.string(),
|
||||
location_id: z.string().optional(),
|
||||
@@ -79,21 +72,33 @@ export type AdminPostOrderExchangesReqSchemaType = z.infer<
|
||||
>
|
||||
|
||||
export const AdminPostReceiveReturnsReqSchema = z.object({
|
||||
return_id: z.string(),
|
||||
items: z.array(ItemSchema),
|
||||
internal_note: z.string().nullish(),
|
||||
internal_note: z.string().optional(),
|
||||
description: z.string().optional(),
|
||||
metadata: z.record(z.unknown()).nullish(),
|
||||
})
|
||||
export type AdminPostReceiveReturnsReqSchemaType = z.infer<
|
||||
typeof AdminPostReceiveReturnsReqSchema
|
||||
>
|
||||
|
||||
const ReceiveItemSchema = z.object({
|
||||
id: z.string(),
|
||||
quantity: z.number().min(1),
|
||||
internal_note: z.string().optional(),
|
||||
})
|
||||
export const AdminPostReceiveReturnItemsReqSchema = z.object({
|
||||
items: z.array(ReceiveItemSchema),
|
||||
})
|
||||
export type AdminPostReceiveReturnItemsReqSchemaType = z.infer<
|
||||
typeof AdminPostReceiveReturnItemsReqSchema
|
||||
>
|
||||
|
||||
export const AdminPostCancelReturnReqSchema = z.object({
|
||||
return_id: z.string(),
|
||||
no_notification: z.boolean().optional(),
|
||||
internal_note: z.string().nullish(),
|
||||
})
|
||||
export type AdminPostCancelReturnReqSchemaType = z.infer<
|
||||
typeof AdminPostReceiveReturnsReqSchema
|
||||
typeof AdminPostCancelReturnReqSchema
|
||||
>
|
||||
|
||||
export const AdminPostReturnsShippingReqSchema = z.object({
|
||||
|
||||
@@ -16,7 +16,6 @@ function createReturnItems(data) {
|
||||
details: {
|
||||
reference_id: item.id,
|
||||
quantity: item.quantity,
|
||||
metadata: item.metadata,
|
||||
},
|
||||
}))
|
||||
}
|
||||
|
||||
@@ -2478,6 +2478,8 @@ export default class OrderModuleService<
|
||||
"requested_at",
|
||||
"requested_by",
|
||||
"status",
|
||||
"description",
|
||||
"internal_note",
|
||||
],
|
||||
relations: [] as string[],
|
||||
order: {},
|
||||
|
||||
Reference in New Issue
Block a user