* ../../core/types/src/dml/index.ts * ../../core/types/src/dml/index.ts * fix: relationships mapping * handle nullable foreign keys types * handle nullable foreign keys types * handle nullable foreign keys types * continue to update product category repository * fix all product category repositories issues * fix product category service types * fix product module service types * fix product module service types * fix repository template type * refactor: use a singleton DMLToMikroORM factory instance Since the MikroORM MetadataStorage is global, we will also have to turn DML to MikroORM entities conversion use a global bucket as well * refactor: update product module to use DML in tests * wip: tests * WIP product linkable fixes * continue type fixing and start test fixing * test: fix more tests * fix repository * fix pivot table computaion + fix mikro orm repository * fix many to many management and configuration * fix many to many management and configuration * fix many to many management and configuration * update product tag relation configuration * Introduce experimental dml hooks to fix some issues with categories * more fixes * fix product tests * add missing id prefixes * fix product category handle management * test: fix more failing tests * test: make it all green * test: fix breaking tests * fix: build issues * fix: build issues * fix: more breaking tests * refactor: fix issues after merge * refactor: fix issues after merge * refactor: surpress types error * test: fix DML failing tests * improve many to many inference + tests * Wip fix columns from product entity * remove product model before create hook and manage handle validation and transformation at the service level * test: fix breaking unit tests * fix: product module service to not update handle on product update * fix define link and joiner config * test: fix joiner config test * test: fix joiner config test * fix joiner config primary keys * Fix joiner config builder * Fix joiner config builder * test: remove only modifier from test * refactor: remove hooks usage from product collection * refactor: remove hooks usage from product-option * refactor: remove hooks usage for computing category handle * refactor: remove hooks usage from productCategory model * refactor: remove hooks from DML * refactor: remove cruft * order dml * cleanup * re add foerign key indexes * wip * chore: remove unused types * wip * changes * rm raw * autoincrement * wip * rel * refactor: cleanup * migration and models configuration adjustments * cleanup * number searchable * fix random ordering * fix * test: fix product-category tests * test: update breaking DML tests * test: array assertion to not care about ordering * fix: temporarily apply id ordering for products * types * wip * WIP type improvements * update order models * partially fix types temporarely * rel * fix: recursive type issue * improve type inference breaks * improve type inference breaks * update models * rm nullable * default value * repository * update default value handling * fix unit tests * WIP * toMikroORM * fix relations * cascades * fix * experimental dml hooks * rm migration * serial * nullable autoincrement * fix model * model changes * fix one to one DML * order test * fix addresses * fix unit tests * Re align dml entity name inference * update model table name config * update model table name config * revert * update return relation * WIP * hasOne * models * fix * model * initial commit * cart service * order module * utils unit test * index engine * changeset * merge * fix hasOne with fk * update * free text filter per entity * tests * prod category * property string many to many * fix big number * link modules migration set names * merge * shipping option rules * serializer * unit test * fix test mikro orm init * fix test mikro orm init * Maintain merge object properties * fix test mikro orm init * prevent unit test from connecting to db * wip * fix test * fix test * link test * schema * models * auto increment * hook * model hooks * order * wip * orm version * request return field * fix return configuration on order model * workflows * core flows * unit test * test * base repo * test * base repo * test fix * inventory move * locking inventory * test * free text fix * rm timeout mock * migrate fulfillment values * v6.4.3 * cleanup * link-modules update sql * revert test * remove fake timers --------- Co-authored-by: adrien2p <adrien.deperetti@gmail.com> Co-authored-by: Harminder Virk <virk.officials@gmail.com> Co-authored-by: Oli Juhl <59018053+olivermrbl@users.noreply.github.com>
163 lines
4.5 KiB
TypeScript
163 lines
4.5 KiB
TypeScript
import {
|
|
InferEntityType,
|
|
OrderChangeActionDTO,
|
|
} from "@medusajs/framework/types"
|
|
import {
|
|
ChangeActionType,
|
|
MathBN,
|
|
createRawPropertiesFromBigNumber,
|
|
isDefined,
|
|
} from "@medusajs/framework/utils"
|
|
import { OrderItem, OrderShippingMethod } from "@models"
|
|
import { calculateOrderChange } from "./calculate-order-change"
|
|
|
|
export interface ApplyOrderChangeDTO extends OrderChangeActionDTO {
|
|
id: string
|
|
order_id: string
|
|
version: number
|
|
applied: boolean
|
|
}
|
|
|
|
export function applyChangesToOrder(
|
|
orders: any[],
|
|
actionsMap: Record<string, any[]>,
|
|
options?: {
|
|
addActionReferenceToObject?: boolean
|
|
}
|
|
) {
|
|
const itemsToUpsert: InferEntityType<typeof OrderItem>[] = []
|
|
const shippingMethodsToUpsert: InferEntityType<typeof OrderShippingMethod>[] =
|
|
[]
|
|
const summariesToUpsert: any[] = []
|
|
const orderToUpdate: any[] = []
|
|
|
|
const orderEditableAttributes = [
|
|
"customer_id",
|
|
"sales_channel_id",
|
|
"email",
|
|
"no_notification",
|
|
]
|
|
|
|
const calculatedOrders = {}
|
|
for (const order of orders) {
|
|
const calculated = calculateOrderChange({
|
|
order: order as any,
|
|
actions: actionsMap[order.id],
|
|
transactions: order.transactions ?? [],
|
|
options,
|
|
})
|
|
|
|
createRawPropertiesFromBigNumber(calculated)
|
|
|
|
calculatedOrders[order.id] = calculated
|
|
|
|
const version = actionsMap[order.id]?.[0]?.version ?? order.version
|
|
const orderAttributes: {
|
|
version?: number
|
|
customer_id?: string
|
|
} = {}
|
|
|
|
// Editable attributes that have changed
|
|
for (const attr of orderEditableAttributes) {
|
|
if (order[attr] !== calculated.order[attr]) {
|
|
orderAttributes[attr] = calculated.order[attr]
|
|
}
|
|
}
|
|
|
|
for (const item of calculated.order.items) {
|
|
if (MathBN.lte(item.quantity, 0)) {
|
|
continue
|
|
}
|
|
|
|
const isExistingItem = item.id === item.detail?.item_id
|
|
const orderItem = isExistingItem ? (item.detail as any) : item
|
|
const itemId = isExistingItem ? orderItem.item_id : item.id
|
|
|
|
const itemToUpsert = {
|
|
id: orderItem.version === version ? orderItem.id : undefined,
|
|
item_id: itemId,
|
|
order_id: order.id,
|
|
version,
|
|
quantity: orderItem.quantity,
|
|
unit_price: item.unit_price ?? orderItem.unit_price,
|
|
compare_at_unit_price:
|
|
item.compare_at_unit_price ?? orderItem.compare_at_unit_price,
|
|
fulfilled_quantity: orderItem.fulfilled_quantity ?? 0,
|
|
delivered_quantity: orderItem.delivered_quantity ?? 0,
|
|
shipped_quantity: orderItem.shipped_quantity ?? 0,
|
|
return_requested_quantity: orderItem.return_requested_quantity ?? 0,
|
|
return_received_quantity: orderItem.return_received_quantity ?? 0,
|
|
return_dismissed_quantity: orderItem.return_dismissed_quantity ?? 0,
|
|
written_off_quantity: orderItem.written_off_quantity ?? 0,
|
|
metadata: orderItem.metadata,
|
|
} as any
|
|
|
|
itemsToUpsert.push(itemToUpsert)
|
|
}
|
|
|
|
const orderSummary = order.summary as any
|
|
summariesToUpsert.push({
|
|
id: orderSummary?.version === version ? orderSummary.id : undefined,
|
|
order_id: order.id,
|
|
version,
|
|
totals: calculated.summary,
|
|
})
|
|
|
|
if (version > order.version) {
|
|
for (const shippingMethod of calculated.order.shipping_methods ?? []) {
|
|
const shippingMethod_ = shippingMethod as any
|
|
const isNewShippingMethod = !isDefined(shippingMethod_?.detail)
|
|
if (!shippingMethod_) {
|
|
continue
|
|
}
|
|
|
|
let associatedMethodId
|
|
let hasShippingMethod = false
|
|
if (isNewShippingMethod) {
|
|
associatedMethodId = shippingMethod_.actions?.find((sm) => {
|
|
return (
|
|
sm.action === ChangeActionType.SHIPPING_ADD && sm.reference_id
|
|
)
|
|
})
|
|
hasShippingMethod = !!associatedMethodId
|
|
} else {
|
|
associatedMethodId = shippingMethod_?.detail?.shipping_method_id
|
|
}
|
|
|
|
const sm = {
|
|
...(isNewShippingMethod ? shippingMethod_ : shippingMethod_.detail),
|
|
version,
|
|
shipping_method_id: associatedMethodId,
|
|
} as any
|
|
|
|
delete sm.id
|
|
|
|
if (!hasShippingMethod) {
|
|
shippingMethodsToUpsert.push(sm)
|
|
}
|
|
}
|
|
|
|
orderAttributes.version = version
|
|
}
|
|
|
|
if (Object.keys(orderAttributes).length > 0) {
|
|
orderToUpdate.push({
|
|
selector: {
|
|
id: order.id,
|
|
},
|
|
data: {
|
|
...orderAttributes,
|
|
},
|
|
})
|
|
}
|
|
}
|
|
|
|
return {
|
|
itemsToUpsert,
|
|
shippingMethodsToUpsert,
|
|
summariesToUpsert,
|
|
orderToUpdate,
|
|
calculatedOrders,
|
|
}
|
|
}
|