feat: Add requested_at + open status to return (#8391)

* feat: Add requested_at + open status to return

* Update return in confirm claim workflow

* Revert snapshot

* feat: Change OrderChangeType

* fix test
This commit is contained in:
Oli Juhl
2024-08-01 16:20:45 +02:00
committed by GitHub
parent f81652bf6e
commit dbd0b18726
17 changed files with 89 additions and 34 deletions

View File

@@ -413,7 +413,7 @@ medusaIntegrationTestRunner({
expect.objectContaining({
id: expect.any(String),
order_id: order.id,
status: "requested",
status: "open",
})
)
@@ -421,7 +421,7 @@ medusaIntegrationTestRunner({
expect.objectContaining({
id: expect.any(String),
return_id: returnId,
change_type: "return",
change_type: "return_request",
description: "Test",
status: "pending",
order_id: order.id,
@@ -485,7 +485,7 @@ medusaIntegrationTestRunner({
})
)
// Remove item return requesta
// Remove item return request
const returnItemActionId =
result.data.order_preview.items[0].actions[0].id
result = await api.delete(
@@ -693,6 +693,9 @@ medusaIntegrationTestRunner({
expect(result.data.return).toEqual(
expect.objectContaining({
id: returnId,
status: "requested",
requested_at: expect.any(String),
items: [
expect.objectContaining({
reason: expect.objectContaining({
@@ -872,7 +875,7 @@ medusaIntegrationTestRunner({
expect(result.data.order.order_change).toEqual(
expect.objectContaining({
return_id: returnId,
change_type: "return",
change_type: "return_receive",
status: "pending",
internal_note: "Test internal note",
})

View File

@@ -394,7 +394,7 @@ medusaIntegrationTestRunner({
const [returnOrder] = await remoteQuery(remoteQueryObject)
expect(returnOrder.order_id).toEqual(order.id)
expect(returnOrder.status).toEqual("requested")
expect(returnOrder.status).toEqual("open")
expect(returnOrder.id).toBeDefined()
})
})

View File

@@ -5,7 +5,12 @@ import {
OrderClaimDTO,
OrderDTO,
} from "@medusajs/types"
import { ChangeActionType, Modules, OrderChangeStatus } from "@medusajs/utils"
import {
ChangeActionType,
Modules,
OrderChangeStatus,
ReturnStatus,
} from "@medusajs/utils"
import {
WorkflowResponse,
createStep,
@@ -17,7 +22,7 @@ import {
import { createRemoteLinkStep, useRemoteQueryStep } from "../../../common"
import { createFulfillmentWorkflow } from "../../../fulfillment/workflows/create-fulfillment"
import { createReturnFulfillmentWorkflow } from "../../../fulfillment/workflows/create-return-fulfillment"
import { previewOrderChangeStep } from "../../steps"
import { previewOrderChangeStep, updateReturnsStep } from "../../steps"
import { createOrderClaimItemsFromActionsStep } from "../../steps/claim/create-claim-items-from-actions"
import { confirmOrderChanges } from "../../steps/confirm-order-changes"
import { createReturnItemsFromActionsStep } from "../../steps/return/create-return-items-from-actions"
@@ -239,6 +244,14 @@ export const confirmClaimRequestWorkflow = createWorkflow(
}
)
updateReturnsStep([
{
id: returnId,
status: ReturnStatus.REQUESTED,
requested_at: new Date(),
},
])
const claimId = transform({ createClaimItems }, ({ createClaimItems }) => {
return createClaimItems?.[0]?.claim_id
})

View File

@@ -60,7 +60,7 @@ export const beginReceiveReturnWorkflow = createWorkflow(
{ orderReturn, order, input },
({ orderReturn, order, input }) => {
return {
change_type: "return" as const,
change_type: "return_receive" as const,
order_id: order.id,
return_id: orderReturn.id,
created_by: input.created_by,

View File

@@ -45,7 +45,7 @@ export const beginReturnOrderWorkflow = createWorkflow(
{ created, input },
({ created, input }) => {
return {
change_type: "return" as const,
change_type: "return_request" as const,
order_id: input.order_id,
return_id: created[0].id,
created_by: input.created_by,

View File

@@ -4,17 +4,23 @@ import {
OrderDTO,
ReturnDTO,
} from "@medusajs/types"
import { ChangeActionType, Modules, OrderChangeStatus } from "@medusajs/utils"
import {
ChangeActionType,
Modules,
OrderChangeStatus,
ReturnStatus,
} from "@medusajs/utils"
import {
WorkflowResponse,
createStep,
createWorkflow,
parallelize,
transform,
when,
} from "@medusajs/workflows-sdk"
import { createRemoteLinkStep, useRemoteQueryStep } from "../../../common"
import { createReturnFulfillmentWorkflow } from "../../../fulfillment/workflows/create-return-fulfillment"
import { previewOrderChangeStep } from "../../steps"
import { previewOrderChangeStep, updateReturnsStep } from "../../steps"
import { confirmOrderChanges } from "../../steps/confirm-order-changes"
import { createReturnItemsFromActionsStep } from "../../steps/return/create-return-items-from-actions"
import {
@@ -232,7 +238,16 @@ export const confirmReturnRequestWorkflow = createWorkflow(
createRemoteLinkStep(link)
})
confirmOrderChanges({ changes: [orderChange], orderId: order.id })
parallelize(
updateReturnsStep([
{
id: orderReturn.id,
status: ReturnStatus.REQUESTED,
requested_at: new Date(),
},
]),
confirmOrderChanges({ changes: [orderChange], orderId: order.id })
)
return new WorkflowResponse(orderPreview)
}

View File

@@ -259,7 +259,12 @@ export interface CreateOrderChangeDTO {
return_id?: string
claim_id?: string
exchange_id?: string
change_type?: "return" | "exchange" | "claim" | "edit"
change_type?:
| "return_request"
| "return_receive"
| "exchange"
| "claim"
| "edit"
description?: string
internal_note?: string | null
requested_by?: string
@@ -437,6 +442,13 @@ export interface CreateOrderReturnDTO extends BaseOrderBundledActionsDTO {
exchange_id?: string
}
export type ReturnStatus =
| "open"
| "requested"
| "received"
| "partially_received"
| "canceled"
export interface UpdateReturnDTO {
id: string
location_id?: string
@@ -453,6 +465,8 @@ export interface UpdateReturnDTO {
return_id?: string | null
metadata?: Record<string, unknown> | null
}[]
status?: ReturnStatus
requested_at?: Date
}
export interface UpdateOrderClaimDTO {

View File

@@ -22,7 +22,8 @@ export enum OrderChangeStatus {
}
export enum OrderChangeType {
RETURN = "return",
RETURN_REQUEST = "return_request",
RETURN_RECEIVE = "return_receive",
EXCHANGE = "exchange",
CLAIM = "claim",
EDIT = "edit",

View File

@@ -36,6 +36,10 @@ export enum OrderStatus {
* The return's status.
*/
export enum ReturnStatus {
/**
* The return is open.
*/
OPEN = "open",
/**
* The return is requested.
*/

View File

@@ -13,6 +13,7 @@ export const defaultAdminReturnFields = [
"created_at",
"updated_at",
"canceled_at",
"requested_at",
]
export const defaultAdminDetailsReturnFields = [

View File

@@ -2627,4 +2627,4 @@
}
}
]
}
}

View File

@@ -0,0 +1,12 @@
import { Migration } from "@mikro-orm/migrations"
export class Migration20240801085921 extends Migration {
async up(): Promise<void> {
this.addSql(`
ALTER TABLE "return"
ADD COLUMN IF NOT exists "requested_at" timestamptz NULL;
ALTER TYPE return_status_enum ADD VALUE 'open';
`)
}
}

View File

@@ -4,7 +4,6 @@ import {
DALUtils,
generateEntityId,
OrderChangeStatus,
OrderChangeType,
} from "@medusajs/utils"
import {
BeforeCreate,
@@ -21,7 +20,7 @@ import {
Property,
Rel,
} from "@mikro-orm/core"
import {} from "@types"
import { } from "@types"
import OrderClaim from "./claim"
import OrderExchange from "./exchange"
import Order from "./order"
@@ -60,12 +59,6 @@ const OrderChangeStatusIndex = createPsqlIndexStatementHelper({
where: "deleted_at IS NOT NULL",
})
const OrderChangeTypeIndex = createPsqlIndexStatementHelper({
tableName: "order_change",
columns: "change_type",
where: "deleted_at IS NOT NULL",
})
const DeletedAtIndex = createPsqlIndexStatementHelper({
tableName: "order_change",
columns: "deleted_at",
@@ -154,9 +147,8 @@ export default class OrderChange {
@VersionIndex.MikroORMIndex()
version: number
@Enum({ items: () => OrderChangeType, nullable: true })
@OrderChangeTypeIndex.MikroORMIndex()
change_type: OrderChangeType | null = null
@Property({ columnType: "text", nullable: true })
change_type: string | null = null
@OneToMany(() => OrderChangeAction, (action) => action.order_change, {
cascade: [Cascade.PERSIST, "soft-remove" as Cascade],

View File

@@ -114,8 +114,8 @@ export default class Return {
@DisplayIdIndex.MikroORMIndex()
display_id: number
@Enum({ items: () => ReturnStatus, default: ReturnStatus.REQUESTED })
status: ReturnStatus = ReturnStatus.REQUESTED
@Enum({ items: () => ReturnStatus, default: ReturnStatus.OPEN })
status: ReturnStatus = ReturnStatus.OPEN
@Property({ columnType: "text", nullable: true })
location_id: string | null = null
@@ -172,6 +172,9 @@ export default class Return {
@ReturnDeletedAtIndex.MikroORMIndex()
deleted_at: Date | null = null
@Property({ columnType: "timestamptz", nullable: true })
requested_at: Date | null = null
@Property({ columnType: "timestamptz", nullable: true })
received_at: Date | null = null

View File

@@ -114,7 +114,7 @@ async function createOrderChange(
{
order_id: data.order_id,
return_id: returnRef.id,
change_type: OrderChangeType.RETURN,
change_type: OrderChangeType.RETURN_REQUEST,
reference: "return",
reference_id: returnRef.id,
description: data.description,

View File

@@ -33,7 +33,7 @@ async function createOrderChange(
return_id: returnEntry.id,
reference: "return",
reference_id: returnEntry.id,
change_type: OrderChangeType.RETURN,
change_type: OrderChangeType.RETURN_RECEIVE,
description: data.description,
internal_note: data.internal_note,
created_by: data.created_by,

View File

@@ -1,6 +1,3 @@
import { OrderTypes } from "@medusajs/types"
import { OrderChangeType } from "@medusajs/utils"
export interface CreateOrderChangeDTO extends OrderTypes.CreateOrderChangeDTO {
change_type?: OrderChangeType
}
export interface CreateOrderChangeDTO extends OrderTypes.CreateOrderChangeDTO {}