@medusajs/order 0.1.3-snapshot-20240718083016 → 0.1.3-snapshot-20240719080828
Sign up to get free protection for your applications and to get access to all the features.
- package/dist/index.d.ts +6 -8
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +4 -26
- package/dist/index.js.map +1 -1
- package/dist/migrations/Migration20240219102530.d.ts +1 -0
- package/dist/migrations/Migration20240219102530.d.ts.map +1 -0
- package/dist/migrations/Migration20240219102530.js +38 -4
- package/dist/migrations/Migration20240219102530.js.map +1 -1
- package/dist/migrations/Migration20240604100512.d.ts +5 -0
- package/dist/migrations/Migration20240604100512.d.ts.map +1 -0
- package/dist/migrations/Migration20240604100512.js +364 -0
- package/dist/migrations/Migration20240604100512.js.map +1 -0
- package/dist/migrations/Migration20240715102100.d.ts +5 -0
- package/dist/migrations/Migration20240715102100.d.ts.map +1 -0
- package/dist/migrations/Migration20240715102100.js +15 -0
- package/dist/migrations/Migration20240715102100.js.map +1 -0
- package/dist/migrations/Migration20240715174100.d.ts +5 -0
- package/dist/migrations/Migration20240715174100.d.ts.map +1 -0
- package/dist/migrations/Migration20240715174100.js +21 -0
- package/dist/migrations/Migration20240715174100.js.map +1 -0
- package/dist/migrations/Migration20240716081800.d.ts +5 -0
- package/dist/migrations/Migration20240716081800.d.ts.map +1 -0
- package/dist/migrations/Migration20240716081800.js +67 -0
- package/dist/migrations/Migration20240716081800.js.map +1 -0
- package/dist/models/address.d.ts +2 -1
- package/dist/models/address.d.ts.map +1 -0
- package/dist/models/adjustment-line.d.ts +3 -1
- package/dist/models/adjustment-line.d.ts.map +1 -0
- package/dist/models/adjustment-line.js +5 -0
- package/dist/models/adjustment-line.js.map +1 -1
- package/dist/models/claim-item-image.d.ts +19 -0
- package/dist/models/claim-item-image.d.ts.map +1 -0
- package/dist/models/claim-item-image.js +109 -0
- package/dist/models/claim-item-image.js.map +1 -0
- package/dist/models/claim-item.d.ts +29 -0
- package/dist/models/claim-item.d.ts.map +1 -0
- package/dist/models/claim-item.js +156 -0
- package/dist/models/claim-item.js.map +1 -0
- package/dist/models/claim.d.ts +36 -0
- package/dist/models/claim.d.ts.map +1 -0
- package/dist/models/claim.js +195 -0
- package/dist/models/claim.js.map +1 -0
- package/dist/models/exchange-item.d.ts +24 -0
- package/dist/models/exchange-item.d.ts.map +1 -0
- package/dist/models/exchange-item.js +138 -0
- package/dist/models/exchange-item.js.map +1 -0
- package/dist/models/exchange.d.ts +34 -0
- package/dist/models/exchange.d.ts.map +1 -0
- package/dist/models/exchange.js +188 -0
- package/dist/models/exchange.js.map +1 -0
- package/dist/models/index.d.ts +9 -0
- package/dist/models/index.d.ts.map +1 -0
- package/dist/models/index.js +17 -1
- package/dist/models/index.js.map +1 -1
- package/dist/models/line-item-adjustment.d.ts +3 -1
- package/dist/models/line-item-adjustment.d.ts.map +1 -0
- package/dist/models/line-item-adjustment.js +3 -3
- package/dist/models/line-item-adjustment.js.map +1 -1
- package/dist/models/line-item-tax-line.d.ts +3 -1
- package/dist/models/line-item-tax-line.d.ts.map +1 -0
- package/dist/models/line-item-tax-line.js +3 -3
- package/dist/models/line-item-tax-line.js.map +1 -1
- package/dist/models/line-item.d.ts +3 -1
- package/dist/models/line-item.d.ts.map +1 -0
- package/dist/models/line-item.js +18 -4
- package/dist/models/line-item.js.map +1 -1
- package/dist/models/order-change-action.d.ts +15 -4
- package/dist/models/order-change-action.d.ts.map +1 -0
- package/dist/models/order-change-action.js +102 -7
- package/dist/models/order-change-action.js.map +1 -1
- package/dist/models/order-change.d.ts +17 -5
- package/dist/models/order-change.d.ts.map +1 -0
- package/dist/models/order-change.js +109 -4
- package/dist/models/order-change.js.map +1 -1
- package/dist/models/order-item.d.ts +5 -4
- package/dist/models/order-item.d.ts.map +1 -0
- package/dist/models/order-item.js +13 -13
- package/dist/models/order-item.js.map +1 -1
- package/dist/models/order-shipping-method.d.ts +14 -4
- package/dist/models/order-shipping-method.d.ts.map +1 -0
- package/dist/models/order-shipping-method.js +89 -13
- package/dist/models/order-shipping-method.js.map +1 -1
- package/dist/models/order-summary.d.ts +6 -7
- package/dist/models/order-summary.d.ts.map +1 -0
- package/dist/models/order-summary.js +9 -6
- package/dist/models/order-summary.js.map +1 -1
- package/dist/models/order.d.ts +6 -4
- package/dist/models/order.d.ts.map +1 -0
- package/dist/models/order.js +11 -1
- package/dist/models/order.js.map +1 -1
- package/dist/models/return-item.d.ts +29 -0
- package/dist/models/return-item.d.ts.map +1 -0
- package/dist/models/return-item.js +170 -0
- package/dist/models/return-item.js.map +1 -0
- package/dist/models/return-reason.d.ts +21 -0
- package/dist/models/return-reason.d.ts.map +1 -0
- package/dist/models/return-reason.js +120 -0
- package/dist/models/return-reason.js.map +1 -0
- package/dist/models/return.d.ts +39 -0
- package/dist/models/return.d.ts.map +1 -0
- package/dist/models/return.js +216 -0
- package/dist/models/return.js.map +1 -0
- package/dist/models/shipping-method-adjustment.d.ts +3 -1
- package/dist/models/shipping-method-adjustment.d.ts.map +1 -0
- package/dist/models/shipping-method-adjustment.js +3 -3
- package/dist/models/shipping-method-adjustment.js.map +1 -1
- package/dist/models/shipping-method-tax-line.d.ts +3 -1
- package/dist/models/shipping-method-tax-line.d.ts.map +1 -0
- package/dist/models/shipping-method-tax-line.js +3 -3
- package/dist/models/shipping-method-tax-line.js.map +1 -1
- package/dist/models/shipping-method.d.ts +2 -0
- package/dist/models/shipping-method.d.ts.map +1 -0
- package/dist/models/shipping-method.js +17 -4
- package/dist/models/shipping-method.js.map +1 -1
- package/dist/models/tax-line.d.ts +2 -0
- package/dist/models/tax-line.d.ts.map +1 -0
- package/dist/models/tax-line.js +7 -0
- package/dist/models/tax-line.js.map +1 -1
- package/dist/models/transaction.d.ts +15 -3
- package/dist/models/transaction.d.ts.map +1 -0
- package/dist/models/transaction.js +109 -4
- package/dist/models/transaction.js.map +1 -1
- package/dist/repositories/claim.d.ts +9 -0
- package/dist/repositories/claim.d.ts.map +1 -0
- package/dist/repositories/claim.js +11 -0
- package/dist/repositories/claim.js.map +1 -0
- package/dist/repositories/exchange.d.ts +9 -0
- package/dist/repositories/exchange.d.ts.map +1 -0
- package/dist/repositories/exchange.js +11 -0
- package/dist/repositories/exchange.js.map +1 -0
- package/dist/repositories/index.d.ts +4 -1
- package/dist/repositories/index.d.ts.map +1 -0
- package/dist/repositories/index.js +7 -16
- package/dist/repositories/index.js.map +1 -1
- package/dist/repositories/order.d.ts +1 -3
- package/dist/repositories/order.d.ts.map +1 -0
- package/dist/repositories/order.js +2 -85
- package/dist/repositories/order.js.map +1 -1
- package/dist/repositories/return.d.ts +9 -0
- package/dist/repositories/return.d.ts.map +1 -0
- package/dist/repositories/return.js +11 -0
- package/dist/repositories/return.js.map +1 -0
- package/dist/services/actions/cancel-claim.d.ts +3 -0
- package/dist/services/actions/cancel-claim.d.ts.map +1 -0
- package/dist/services/actions/cancel-claim.js +107 -0
- package/dist/services/actions/cancel-claim.js.map +1 -0
- package/dist/services/actions/cancel-exchange.d.ts +3 -0
- package/dist/services/actions/cancel-exchange.d.ts.map +1 -0
- package/dist/services/actions/cancel-exchange.js +92 -0
- package/dist/services/actions/cancel-exchange.js.map +1 -0
- package/dist/services/actions/cancel-fulfillment.d.ts +3 -0
- package/dist/services/actions/cancel-fulfillment.d.ts.map +1 -0
- package/dist/services/actions/cancel-fulfillment.js +32 -0
- package/dist/services/actions/cancel-fulfillment.js.map +1 -0
- package/dist/services/actions/cancel-return.d.ts +3 -0
- package/dist/services/actions/cancel-return.d.ts.map +1 -0
- package/dist/services/actions/cancel-return.js +72 -0
- package/dist/services/actions/cancel-return.js.map +1 -0
- package/dist/services/actions/create-claim.d.ts +3 -0
- package/dist/services/actions/create-claim.d.ts.map +1 -0
- package/dist/services/actions/create-claim.js +228 -0
- package/dist/services/actions/create-claim.js.map +1 -0
- package/dist/services/actions/create-exchange.d.ts +3 -0
- package/dist/services/actions/create-exchange.d.ts.map +1 -0
- package/dist/services/actions/create-exchange.js +193 -0
- package/dist/services/actions/create-exchange.js.map +1 -0
- package/dist/services/actions/create-return.d.ts +3 -0
- package/dist/services/actions/create-return.d.ts.map +1 -0
- package/dist/services/actions/create-return.js +102 -0
- package/dist/services/actions/create-return.js.map +1 -0
- package/dist/services/actions/index.d.ts +11 -0
- package/dist/services/actions/index.d.ts.map +1 -0
- package/dist/services/actions/index.js +27 -0
- package/dist/services/actions/index.js.map +1 -0
- package/dist/services/actions/receive-return.d.ts +3 -0
- package/dist/services/actions/receive-return.d.ts.map +1 -0
- package/dist/services/actions/receive-return.js +72 -0
- package/dist/services/actions/receive-return.js.map +1 -0
- package/dist/services/actions/register-fulfillment.d.ts +3 -0
- package/dist/services/actions/register-fulfillment.d.ts.map +1 -0
- package/dist/services/actions/register-fulfillment.js +30 -0
- package/dist/services/actions/register-fulfillment.js.map +1 -0
- package/dist/services/actions/register-shipment.d.ts +3 -0
- package/dist/services/actions/register-shipment.d.ts.map +1 -0
- package/dist/services/actions/register-shipment.js +38 -0
- package/dist/services/actions/register-shipment.js.map +1 -0
- package/dist/services/index.d.ts +1 -1
- package/dist/services/index.d.ts.map +1 -0
- package/dist/services/index.js +1 -3
- package/dist/services/index.js.map +1 -1
- package/dist/services/order-module-service.d.ts +138 -67
- package/dist/services/order-module-service.d.ts.map +1 -0
- package/dist/services/order-module-service.js +992 -240
- package/dist/services/order-module-service.js.map +1 -1
- package/dist/services/order-service.d.ts +5 -4
- package/dist/services/order-service.d.ts.map +1 -0
- package/dist/services/order-service.js +1 -1
- package/dist/services/order-service.js.map +1 -1
- package/dist/types/address.d.ts +1 -0
- package/dist/types/address.d.ts.map +1 -0
- package/dist/types/index.d.ts +3 -1
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +1 -0
- package/dist/types/index.js.map +1 -1
- package/dist/types/line-item-adjustment.d.ts +1 -0
- package/dist/types/line-item-adjustment.d.ts.map +1 -0
- package/dist/types/line-item-tax-line.d.ts +1 -0
- package/dist/types/line-item-tax-line.d.ts.map +1 -0
- package/dist/types/line-item.d.ts +1 -0
- package/dist/types/line-item.d.ts.map +1 -0
- package/dist/types/order-change.d.ts +6 -0
- package/dist/types/order-change.d.ts.map +1 -0
- package/dist/types/order-change.js +3 -0
- package/dist/types/order-change.js.map +1 -0
- package/dist/types/order-detail.d.ts +2 -1
- package/dist/types/order-detail.d.ts.map +1 -0
- package/dist/types/order.d.ts +3 -2
- package/dist/types/order.d.ts.map +1 -0
- package/dist/types/shipping-method-adjustment.d.ts +1 -0
- package/dist/types/shipping-method-adjustment.d.ts.map +1 -0
- package/dist/types/shipping-method-tax-line.d.ts +1 -0
- package/dist/types/shipping-method-tax-line.d.ts.map +1 -0
- package/dist/types/shipping-method.d.ts +4 -0
- package/dist/types/shipping-method.d.ts.map +1 -0
- package/dist/types/tax-line.d.ts +1 -0
- package/dist/types/tax-line.d.ts.map +1 -0
- package/dist/types/transaction.d.ts +1 -0
- package/dist/types/transaction.d.ts.map +1 -0
- package/dist/types/utils/index.d.ts +40 -21
- package/dist/types/utils/index.d.ts.map +1 -0
- package/dist/types/utils/index.js +0 -1
- package/dist/types/utils/index.js.map +1 -1
- package/dist/utils/actions/cancel-item-fulfillment.d.ts +2 -0
- package/dist/utils/actions/cancel-item-fulfillment.d.ts.map +1 -0
- package/dist/utils/actions/cancel-item-fulfillment.js +34 -0
- package/dist/utils/actions/cancel-item-fulfillment.js.map +1 -0
- package/dist/utils/actions/cancel-return.d.ts +1 -0
- package/dist/utils/actions/cancel-return.d.ts.map +1 -0
- package/dist/utils/actions/cancel-return.js +6 -10
- package/dist/utils/actions/cancel-return.js.map +1 -1
- package/dist/utils/actions/fulfill-item.d.ts +1 -0
- package/dist/utils/actions/fulfill-item.d.ts.map +1 -0
- package/dist/utils/actions/fulfill-item.js +6 -10
- package/dist/utils/actions/fulfill-item.js.map +1 -1
- package/dist/utils/actions/index.d.ts +4 -1
- package/dist/utils/actions/index.d.ts.map +1 -0
- package/dist/utils/actions/index.js +3 -1
- package/dist/utils/actions/index.js.map +1 -1
- package/dist/utils/actions/item-add.d.ts +1 -0
- package/dist/utils/actions/item-add.d.ts.map +1 -0
- package/dist/utils/actions/item-add.js +15 -24
- package/dist/utils/actions/item-add.js.map +1 -1
- package/dist/utils/actions/item-remove.d.ts +1 -0
- package/dist/utils/actions/item-remove.d.ts.map +1 -0
- package/dist/utils/actions/item-remove.js +8 -22
- package/dist/utils/actions/item-remove.js.map +1 -1
- package/dist/utils/actions/receive-damaged-return-item.d.ts +1 -0
- package/dist/utils/actions/receive-damaged-return-item.d.ts.map +1 -0
- package/dist/utils/actions/receive-damaged-return-item.js +9 -35
- package/dist/utils/actions/receive-damaged-return-item.js.map +1 -1
- package/dist/utils/actions/receive-return-item.d.ts +1 -0
- package/dist/utils/actions/receive-return-item.d.ts.map +1 -0
- package/dist/utils/actions/receive-return-item.js +7 -36
- package/dist/utils/actions/receive-return-item.js.map +1 -1
- package/dist/utils/actions/reinstate-item.d.ts +2 -0
- package/dist/utils/actions/reinstate-item.d.ts.map +1 -0
- package/dist/utils/actions/reinstate-item.js +32 -0
- package/dist/utils/actions/reinstate-item.js.map +1 -0
- package/dist/utils/actions/return-item.d.ts +1 -0
- package/dist/utils/actions/return-item.d.ts.map +1 -0
- package/dist/utils/actions/return-item.js +8 -12
- package/dist/utils/actions/return-item.js.map +1 -1
- package/dist/utils/actions/ship-item.d.ts +1 -0
- package/dist/utils/actions/ship-item.d.ts.map +1 -0
- package/dist/utils/actions/ship-item.js +6 -10
- package/dist/utils/actions/ship-item.js.map +1 -1
- package/dist/utils/actions/shipping-add.d.ts +1 -0
- package/dist/utils/actions/shipping-add.d.ts.map +1 -0
- package/dist/utils/actions/shipping-add.js +16 -16
- package/dist/utils/actions/shipping-add.js.map +1 -1
- package/dist/utils/actions/shipping-remove.d.ts +2 -0
- package/dist/utils/actions/shipping-remove.d.ts.map +1 -0
- package/dist/utils/actions/shipping-remove.js +25 -0
- package/dist/utils/actions/shipping-remove.js.map +1 -0
- package/dist/utils/actions/write-off-item.d.ts +1 -0
- package/dist/utils/actions/write-off-item.d.ts.map +1 -0
- package/dist/utils/actions/write-off-item.js +6 -10
- package/dist/utils/actions/write-off-item.js.map +1 -1
- package/dist/utils/apply-order-changes.d.ts +18 -0
- package/dist/utils/apply-order-changes.d.ts.map +1 -0
- package/dist/utils/apply-order-changes.js +95 -0
- package/dist/utils/apply-order-changes.js.map +1 -0
- package/dist/utils/base-repository-find.d.ts +3 -0
- package/dist/utils/base-repository-find.d.ts.map +1 -0
- package/dist/utils/base-repository-find.js +142 -0
- package/dist/utils/base-repository-find.js.map +1 -0
- package/dist/utils/calculate-order-change.d.ts +11 -5
- package/dist/utils/calculate-order-change.d.ts.map +1 -0
- package/dist/utils/calculate-order-change.js +57 -182
- package/dist/utils/calculate-order-change.js.map +1 -1
- package/dist/utils/index.d.ts +4 -1
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +3 -1
- package/dist/utils/index.js.map +1 -1
- package/dist/utils/set-action-reference.d.ts +2 -0
- package/dist/utils/set-action-reference.d.ts.map +1 -0
- package/dist/utils/set-action-reference.js +11 -0
- package/dist/utils/set-action-reference.js.map +1 -0
- package/dist/utils/transform-order.d.ts +4 -2
- package/dist/utils/transform-order.d.ts.map +1 -0
- package/dist/utils/transform-order.js +131 -17
- package/dist/utils/transform-order.js.map +1 -1
- package/package.json +8 -14
- package/dist/joiner-config.d.ts +0 -5
- package/dist/joiner-config.js +0 -36
- package/dist/joiner-config.js.map +0 -1
- package/dist/module-definition.d.ts +0 -2
- package/dist/module-definition.js +0 -59
- package/dist/module-definition.js.map +0 -1
- package/dist/scripts/bin/run-seed.d.ts +0 -3
- package/dist/scripts/bin/run-seed.js +0 -49
- package/dist/scripts/bin/run-seed.js.map +0 -1
- package/dist/services/order-change-service.d.ts +0 -15
- package/dist/services/order-change-service.js +0 -96
- package/dist/services/order-change-service.js.map +0 -1
- package/dist/utils/action-key.d.ts +0 -13
- package/dist/utils/action-key.js +0 -18
- package/dist/utils/action-key.js.map +0 -1
- package/dist/utils/actions/cancel.d.ts +0 -1
- package/dist/utils/actions/cancel.js +0 -8
- package/dist/utils/actions/cancel.js.map +0 -1
@@ -1,35 +1,41 @@
|
|
1
1
|
import { OrderSummaryDTO } from "@medusajs/types";
|
2
2
|
import { ActionTypeDefinition, InternalOrderChangeEvent, OrderChangeEvent, OrderTransaction, VirtualOrder } from "../types";
|
3
|
+
interface ProcessOptions {
|
4
|
+
addActionReferenceToObject?: boolean;
|
5
|
+
[key: string]: any;
|
6
|
+
}
|
3
7
|
export declare class OrderChangeProcessing {
|
4
8
|
private static typeDefinition;
|
5
9
|
private static defaultConfig;
|
6
10
|
private order;
|
7
11
|
private transactions;
|
8
12
|
private actions;
|
13
|
+
private options;
|
9
14
|
private actionsProcessed;
|
10
15
|
private groupTotal;
|
11
16
|
private summary;
|
12
17
|
static registerActionType(key: string, type: ActionTypeDefinition): void;
|
13
|
-
constructor({ order, transactions, actions, }: {
|
18
|
+
constructor({ order, transactions, actions, options, }: {
|
14
19
|
order: VirtualOrder;
|
15
20
|
transactions: OrderTransaction[];
|
16
21
|
actions: InternalOrderChangeEvent[];
|
22
|
+
options: ProcessOptions;
|
17
23
|
});
|
18
24
|
private isEventActive;
|
19
25
|
private isEventDone;
|
20
|
-
private isEventPending;
|
21
26
|
processActions(): void;
|
22
27
|
private processAction_;
|
23
|
-
private resolveReferences;
|
24
|
-
private resolveGroup;
|
25
28
|
getSummary(): OrderSummaryDTO;
|
26
29
|
getCurrentOrder(): VirtualOrder;
|
27
30
|
}
|
28
|
-
export declare function calculateOrderChange({ order, transactions, actions, }: {
|
31
|
+
export declare function calculateOrderChange({ order, transactions, actions, options, }: {
|
29
32
|
order: VirtualOrder;
|
30
33
|
transactions?: OrderTransaction[];
|
31
34
|
actions?: OrderChangeEvent[];
|
35
|
+
options?: ProcessOptions;
|
32
36
|
}): {
|
33
37
|
summary: OrderSummaryDTO;
|
34
38
|
order: VirtualOrder;
|
35
39
|
};
|
40
|
+
export {};
|
41
|
+
//# sourceMappingURL=calculate-order-change.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"calculate-order-change.d.ts","sourceRoot":"","sources":["../../src/utils/calculate-order-change.ts"],"names":[],"mappings":"AAAA,OAAO,EAAkB,eAAe,EAAE,MAAM,iBAAiB,CAAA;AAQjE,OAAO,EACL,oBAAoB,EAEpB,wBAAwB,EACxB,gBAAgB,EAEhB,gBAAgB,EAChB,YAAY,EACb,MAAM,QAAQ,CAAA;AAEf,UAAU,cAAc;IACtB,0BAA0B,CAAC,EAAE,OAAO,CAAA;IACpC,CAAC,GAAG,EAAE,MAAM,GAAG,GAAG,CAAA;CACnB;AAED,qBAAa,qBAAqB;IAChC,OAAO,CAAC,MAAM,CAAC,cAAc,CAA8C;IAC3E,OAAO,CAAC,MAAM,CAAC,aAAa,CAE3B;IAED,OAAO,CAAC,KAAK,CAAc;IAC3B,OAAO,CAAC,YAAY,CAAoB;IACxC,OAAO,CAAC,OAAO,CAA4B;IAC3C,OAAO,CAAC,OAAO,CAAqB;IAEpC,OAAO,CAAC,gBAAgB,CAAoD;IAC5E,OAAO,CAAC,UAAU,CAAqC;IACvD,OAAO,CAAC,OAAO,CAAwB;WAEzB,kBAAkB,CAAC,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,oBAAoB;gBAI5D,EACV,KAAK,EACL,YAAY,EACZ,OAAO,EACP,OAAO,GACR,EAAE;QACD,KAAK,EAAE,YAAY,CAAA;QACnB,YAAY,EAAE,gBAAgB,EAAE,CAAA;QAChC,OAAO,EAAE,wBAAwB,EAAE,CAAA;QACnC,OAAO,EAAE,cAAc,CAAA;KACxB;IAiCD,OAAO,CAAC,aAAa;IAQrB,OAAO,CAAC,WAAW;IAKZ,cAAc;IA6DrB,OAAO,CAAC,cAAc;IA8Cf,UAAU,IAAI,eAAe;IAgB7B,eAAe,IAAI,YAAY;CAGvC;AAED,wBAAgB,oBAAoB,CAAC,EACnC,KAAK,EACL,YAAiB,EACjB,OAAY,EACZ,OAAY,GACb,EAAE;IACD,KAAK,EAAE,YAAY,CAAA;IACnB,YAAY,CAAC,EAAE,gBAAgB,EAAE,CAAA;IACjC,OAAO,CAAC,EAAE,gBAAgB,EAAE,CAAA;IAC5B,OAAO,CAAC,EAAE,cAAc,CAAA;CACzB;;;EAaA"}
|
@@ -7,24 +7,36 @@ class OrderChangeProcessing {
|
|
7
7
|
static registerActionType(key, type) {
|
8
8
|
OrderChangeProcessing.typeDefinition[key] = type;
|
9
9
|
}
|
10
|
-
constructor({ order, transactions, actions, }) {
|
10
|
+
constructor({ order, transactions, actions, options, }) {
|
11
|
+
this.options = {};
|
11
12
|
this.actionsProcessed = {};
|
12
13
|
this.groupTotal = {};
|
13
14
|
this.order = JSON.parse(JSON.stringify(order));
|
14
15
|
this.transactions = JSON.parse(JSON.stringify(transactions ?? []));
|
15
16
|
this.actions = JSON.parse(JSON.stringify(actions ?? []));
|
16
|
-
|
17
|
+
this.options = options;
|
18
|
+
let paid = utils_1.MathBN.convert(0);
|
19
|
+
let refunded = utils_1.MathBN.convert(0);
|
20
|
+
let transactionTotal = utils_1.MathBN.convert(0);
|
21
|
+
for (const tr of transactions) {
|
22
|
+
if (utils_1.MathBN.lt(tr.amount, 0)) {
|
23
|
+
refunded = utils_1.MathBN.add(refunded, utils_1.MathBN.abs(tr.amount));
|
24
|
+
}
|
25
|
+
else {
|
26
|
+
paid = utils_1.MathBN.add(paid, tr.amount);
|
27
|
+
}
|
28
|
+
transactionTotal = utils_1.MathBN.add(transactionTotal, tr.amount);
|
29
|
+
}
|
17
30
|
(0, utils_1.transformPropertiesToBigNumber)(this.order.metadata);
|
18
31
|
this.summary = {
|
19
|
-
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
transactionTotal,
|
32
|
+
temporary_difference: 0,
|
33
|
+
pending_difference: 0,
|
34
|
+
difference_sum: 0,
|
35
|
+
current_order_total: this.order.total ?? 0,
|
36
|
+
original_order_total: this.order.total ?? 0,
|
37
|
+
transaction_total: transactionTotal,
|
38
|
+
paid_total: paid,
|
39
|
+
refunded_total: refunded,
|
28
40
|
};
|
29
41
|
}
|
30
42
|
isEventActive(action) {
|
@@ -37,12 +49,7 @@ class OrderChangeProcessing {
|
|
37
49
|
const status = action.status;
|
38
50
|
return status === _types_1.EVENT_STATUS.DONE;
|
39
51
|
}
|
40
|
-
isEventPending(action) {
|
41
|
-
const status = action.status;
|
42
|
-
return status === undefined || status === _types_1.EVENT_STATUS.PENDING;
|
43
|
-
}
|
44
52
|
processActions() {
|
45
|
-
var _a, _b;
|
46
53
|
for (const action of this.actions) {
|
47
54
|
this.processAction_(action);
|
48
55
|
}
|
@@ -56,59 +63,46 @@ class OrderChangeProcessing {
|
|
56
63
|
...OrderChangeProcessing.typeDefinition[action.action],
|
57
64
|
};
|
58
65
|
const amount = utils_1.MathBN.mult(action.amount, type.isDeduction ? -1 : 1);
|
59
|
-
if (action.
|
60
|
-
|
61
|
-
this.groupTotal[action.
|
66
|
+
if (action.change_id) {
|
67
|
+
this.groupTotal[action.change_id] ??= 0;
|
68
|
+
this.groupTotal[action.change_id] = utils_1.MathBN.add(this.groupTotal[action.change_id], amount);
|
62
69
|
}
|
63
|
-
if (type.awaitRequired
|
64
|
-
|
65
|
-
summary.futureTemporarySum = utils_1.MathBN.add(summary.futureTemporarySum, amount);
|
66
|
-
}
|
67
|
-
else {
|
68
|
-
summary.temporaryDifference = utils_1.MathBN.add(summary.temporaryDifference, amount);
|
69
|
-
}
|
70
|
+
if (type.awaitRequired) {
|
71
|
+
summary.temporary_difference = utils_1.MathBN.add(summary.temporary_difference, amount);
|
70
72
|
}
|
71
|
-
if (action.
|
72
|
-
summary.
|
73
|
-
}
|
74
|
-
else {
|
75
|
-
if (!this.isEventDone(action) && !action.group_id) {
|
76
|
-
summary.differenceSum = utils_1.MathBN.add(summary.differenceSum, amount);
|
77
|
-
}
|
78
|
-
summary.currentOrderTotal = utils_1.MathBN.add(summary.currentOrderTotal, amount);
|
73
|
+
if (!this.isEventDone(action) && !action.change_id) {
|
74
|
+
summary.difference_sum = utils_1.MathBN.add(summary.difference_sum, amount);
|
79
75
|
}
|
76
|
+
summary.current_order_total = utils_1.MathBN.add(summary.current_order_total, amount);
|
80
77
|
}
|
81
78
|
const groupSum = utils_1.MathBN.add(...Object.values(this.groupTotal));
|
82
|
-
summary.
|
83
|
-
summary.
|
84
|
-
summary.
|
85
|
-
summary.
|
86
|
-
summary.pendingDifference = utils_1.MathBN.sub(summary.currentOrderTotal, summary.transactionTotal);
|
79
|
+
summary.difference_sum = utils_1.MathBN.add(summary.difference_sum, groupSum);
|
80
|
+
summary.transaction_total = utils_1.MathBN.sum(...this.transactions.map((tr) => tr.amount));
|
81
|
+
summary.temporary_difference = utils_1.MathBN.sub(summary.difference_sum, summary.temporary_difference);
|
82
|
+
summary.pending_difference = utils_1.MathBN.sub(summary.current_order_total, summary.transaction_total);
|
87
83
|
}
|
88
84
|
processAction_(action, isReplay = false) {
|
89
|
-
|
85
|
+
const definedType = OrderChangeProcessing.typeDefinition[action.action];
|
86
|
+
if (!(0, utils_1.isPresent)(definedType)) {
|
87
|
+
throw new Error(`Action type ${action.action} is not defined`);
|
88
|
+
}
|
90
89
|
const type = {
|
91
90
|
...OrderChangeProcessing.defaultConfig,
|
92
|
-
...
|
91
|
+
...definedType,
|
93
92
|
};
|
94
|
-
|
93
|
+
this.actionsProcessed[action.action] ??= [];
|
95
94
|
if (!isReplay) {
|
96
95
|
this.actionsProcessed[action.action].push(action);
|
97
96
|
}
|
98
|
-
let previousEvents;
|
99
|
-
if (type.commitsAction) {
|
100
|
-
previousEvents = (this.actionsProcessed[type.commitsAction] ?? []).filter((ac_) => ac_.reference_id === action.reference_id &&
|
101
|
-
ac_.status !== _types_1.EVENT_STATUS.VOIDED);
|
102
|
-
}
|
103
97
|
let calculatedAmount = action.amount ?? 0;
|
104
98
|
const params = {
|
105
99
|
actions: this.actions,
|
106
100
|
action,
|
107
|
-
previousEvents,
|
108
101
|
currentOrder: this.order,
|
109
102
|
summary: this.summary,
|
110
103
|
transactions: this.transactions,
|
111
104
|
type,
|
105
|
+
options: this.options,
|
112
106
|
};
|
113
107
|
if (typeof type.validate === "function") {
|
114
108
|
type.validate(params);
|
@@ -120,143 +114,20 @@ class OrderChangeProcessing {
|
|
120
114
|
action.amount = calculatedAmount ?? 0;
|
121
115
|
}
|
122
116
|
}
|
123
|
-
// If an action commits previous ones, replay them with updated values
|
124
|
-
if (type.commitsAction) {
|
125
|
-
for (const previousEvent of previousEvents ?? []) {
|
126
|
-
this.processAction_(previousEvent, true);
|
127
|
-
}
|
128
|
-
}
|
129
|
-
if (action.resolve) {
|
130
|
-
if (action.resolve.reference_id) {
|
131
|
-
this.resolveReferences(action);
|
132
|
-
}
|
133
|
-
const groupId = action.resolve.group_id ?? "__default";
|
134
|
-
if (action.resolve.group_id) {
|
135
|
-
// resolve all actions in the same group
|
136
|
-
this.resolveGroup(action);
|
137
|
-
}
|
138
|
-
if (action.resolve.amount && !action.evaluationOnly) {
|
139
|
-
(_c = this.groupTotal)[groupId] ?? (_c[groupId] = 0);
|
140
|
-
this.groupTotal[groupId] = utils_1.MathBN.sub(this.groupTotal[groupId], action.resolve.amount);
|
141
|
-
}
|
142
|
-
}
|
143
117
|
return calculatedAmount;
|
144
118
|
}
|
145
|
-
resolveReferences(self) {
|
146
|
-
const resolve = self.resolve;
|
147
|
-
const resolveType = OrderChangeProcessing.typeDefinition[self.action];
|
148
|
-
Object.keys(this.actionsProcessed).forEach((actionKey) => {
|
149
|
-
const type = OrderChangeProcessing.typeDefinition[actionKey];
|
150
|
-
const actions = this.actionsProcessed[actionKey];
|
151
|
-
for (const action of actions) {
|
152
|
-
if (action === self ||
|
153
|
-
!this.isEventPending(action) ||
|
154
|
-
action.reference_id !== resolve?.reference_id) {
|
155
|
-
continue;
|
156
|
-
}
|
157
|
-
if (type.revert && (action.evaluationOnly || resolveType.void)) {
|
158
|
-
let previousEvents;
|
159
|
-
if (type.commitsAction) {
|
160
|
-
previousEvents = (this.actionsProcessed[type.commitsAction] ?? []).filter((ac_) => ac_.reference_id === action.reference_id &&
|
161
|
-
ac_.status !== _types_1.EVENT_STATUS.VOIDED);
|
162
|
-
}
|
163
|
-
type.revert({
|
164
|
-
actions: this.actions,
|
165
|
-
action,
|
166
|
-
previousEvents,
|
167
|
-
currentOrder: this.order,
|
168
|
-
summary: this.summary,
|
169
|
-
transactions: this.transactions,
|
170
|
-
type,
|
171
|
-
});
|
172
|
-
for (const previousEvent of previousEvents ?? []) {
|
173
|
-
this.processAction_(previousEvent, true);
|
174
|
-
}
|
175
|
-
action.status =
|
176
|
-
action.evaluationOnly || resolveType.void
|
177
|
-
? _types_1.EVENT_STATUS.VOIDED
|
178
|
-
: _types_1.EVENT_STATUS.DONE;
|
179
|
-
}
|
180
|
-
}
|
181
|
-
});
|
182
|
-
}
|
183
|
-
resolveGroup(self) {
|
184
|
-
const resolve = self.resolve;
|
185
|
-
Object.keys(this.actionsProcessed).forEach((actionKey) => {
|
186
|
-
const type = OrderChangeProcessing.typeDefinition[actionKey];
|
187
|
-
const actions = this.actionsProcessed[actionKey];
|
188
|
-
for (const action of actions) {
|
189
|
-
if (!resolve?.group_id || action?.group_id !== resolve.group_id) {
|
190
|
-
continue;
|
191
|
-
}
|
192
|
-
if (type.revert &&
|
193
|
-
action.status !== _types_1.EVENT_STATUS.DONE &&
|
194
|
-
action.status !== _types_1.EVENT_STATUS.VOIDED &&
|
195
|
-
(action.evaluationOnly || type.void)) {
|
196
|
-
let previousEvents;
|
197
|
-
if (type.commitsAction) {
|
198
|
-
previousEvents = (this.actionsProcessed[type.commitsAction] ?? []).filter((ac_) => ac_.reference_id === action.reference_id &&
|
199
|
-
ac_.status !== _types_1.EVENT_STATUS.VOIDED);
|
200
|
-
}
|
201
|
-
type.revert({
|
202
|
-
actions: this.actions,
|
203
|
-
action: action,
|
204
|
-
previousEvents,
|
205
|
-
currentOrder: this.order,
|
206
|
-
summary: this.summary,
|
207
|
-
transactions: this.transactions,
|
208
|
-
type: OrderChangeProcessing.typeDefinition[action.action],
|
209
|
-
});
|
210
|
-
for (const previousEvent of previousEvents ?? []) {
|
211
|
-
this.processAction_(previousEvent, true);
|
212
|
-
}
|
213
|
-
action.status =
|
214
|
-
action.evaluationOnly || type.void
|
215
|
-
? _types_1.EVENT_STATUS.VOIDED
|
216
|
-
: _types_1.EVENT_STATUS.DONE;
|
217
|
-
}
|
218
|
-
}
|
219
|
-
});
|
220
|
-
}
|
221
119
|
getSummary() {
|
222
120
|
const summary = this.summary;
|
223
121
|
const orderSummary = {
|
224
|
-
|
225
|
-
|
226
|
-
|
227
|
-
|
228
|
-
|
229
|
-
|
230
|
-
|
231
|
-
|
122
|
+
transaction_total: new utils_1.BigNumber(summary.transaction_total),
|
123
|
+
original_order_total: new utils_1.BigNumber(summary.original_order_total),
|
124
|
+
current_order_total: new utils_1.BigNumber(summary.current_order_total),
|
125
|
+
temporary_difference: new utils_1.BigNumber(summary.temporary_difference),
|
126
|
+
pending_difference: new utils_1.BigNumber(summary.pending_difference),
|
127
|
+
difference_sum: new utils_1.BigNumber(summary.difference_sum),
|
128
|
+
paid_total: new utils_1.BigNumber(summary.paid_total),
|
129
|
+
refunded_total: new utils_1.BigNumber(summary.refunded_total),
|
232
130
|
};
|
233
|
-
/*
|
234
|
-
{
|
235
|
-
total: summary.currentOrderTotal
|
236
|
-
|
237
|
-
subtotal: number
|
238
|
-
total_tax: number
|
239
|
-
|
240
|
-
ordered_total: summary.originalOrderTotal
|
241
|
-
fulfilled_total: number
|
242
|
-
returned_total: number
|
243
|
-
return_request_total: number
|
244
|
-
write_off_total: number
|
245
|
-
projected_total: number
|
246
|
-
|
247
|
-
net_total: number
|
248
|
-
net_subtotal: number
|
249
|
-
net_total_tax: number
|
250
|
-
|
251
|
-
future_total: number
|
252
|
-
future_subtotal: number
|
253
|
-
future_total_tax: number
|
254
|
-
future_projected_total: number
|
255
|
-
|
256
|
-
balance: summary.pendingDifference
|
257
|
-
future_balance: number
|
258
|
-
}
|
259
|
-
*/
|
260
131
|
return orderSummary;
|
261
132
|
}
|
262
133
|
getCurrentOrder() {
|
@@ -266,11 +137,15 @@ class OrderChangeProcessing {
|
|
266
137
|
exports.OrderChangeProcessing = OrderChangeProcessing;
|
267
138
|
OrderChangeProcessing.typeDefinition = {};
|
268
139
|
OrderChangeProcessing.defaultConfig = {
|
269
|
-
awaitRequired: false,
|
270
140
|
isDeduction: false,
|
271
141
|
};
|
272
|
-
function calculateOrderChange({ order, transactions = [], actions = [], }) {
|
273
|
-
const calc = new OrderChangeProcessing({
|
142
|
+
function calculateOrderChange({ order, transactions = [], actions = [], options = {}, }) {
|
143
|
+
const calc = new OrderChangeProcessing({
|
144
|
+
order,
|
145
|
+
transactions,
|
146
|
+
actions,
|
147
|
+
options,
|
148
|
+
});
|
274
149
|
calc.processActions();
|
275
150
|
return {
|
276
151
|
summary: calc.getSummary(),
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"calculate-order-change.js","sourceRoot":"","sources":["../../src/utils/calculate-order-change.ts"],"names":[],"mappings":";;;AACA,
|
1
|
+
{"version":3,"file":"calculate-order-change.js","sourceRoot":"","sources":["../../src/utils/calculate-order-change.ts"],"names":[],"mappings":"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"}
|
package/dist/utils/index.d.ts
CHANGED
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/utils/index.ts"],"names":[],"mappings":"AAAA,cAAc,WAAW,CAAA;AACzB,cAAc,uBAAuB,CAAA;AACrC,cAAc,0BAA0B,CAAA;AACxC,cAAc,wBAAwB,CAAA;AACtC,cAAc,mBAAmB,CAAA"}
|
package/dist/utils/index.js
CHANGED
@@ -14,7 +14,9 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
14
|
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
15
15
|
};
|
16
16
|
Object.defineProperty(exports, "__esModule", { value: true });
|
17
|
-
__exportStar(require("./action-key"), exports);
|
18
17
|
__exportStar(require("./actions"), exports);
|
18
|
+
__exportStar(require("./apply-order-changes"), exports);
|
19
19
|
__exportStar(require("./calculate-order-change"), exports);
|
20
|
+
__exportStar(require("./set-action-reference"), exports);
|
21
|
+
__exportStar(require("./transform-order"), exports);
|
20
22
|
//# sourceMappingURL=index.js.map
|
package/dist/utils/index.js.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/utils/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/utils/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,4CAAyB;AACzB,wDAAqC;AACrC,2DAAwC;AACxC,yDAAsC;AACtC,oDAAiC"}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"set-action-reference.d.ts","sourceRoot":"","sources":["../../src/utils/set-action-reference.ts"],"names":[],"mappings":"AAAA,wBAAgB,kBAAkB,CAAC,QAAQ,KAAA,EAAE,MAAM,KAAA,EAAE,OAAO,KAAA,QAK3D"}
|
@@ -0,0 +1,11 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.setActionReference = void 0;
|
4
|
+
function setActionReference(existing, action, options) {
|
5
|
+
if (options?.addActionReferenceToObject) {
|
6
|
+
existing.actions ??= [];
|
7
|
+
existing.actions.push(action);
|
8
|
+
}
|
9
|
+
}
|
10
|
+
exports.setActionReference = setActionReference;
|
11
|
+
//# sourceMappingURL=set-action-reference.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"set-action-reference.js","sourceRoot":"","sources":["../../src/utils/set-action-reference.ts"],"names":[],"mappings":";;;AAAA,SAAgB,kBAAkB,CAAC,QAAQ,EAAE,MAAM,EAAE,OAAO;IAC1D,IAAI,OAAO,EAAE,0BAA0B,EAAE,CAAC;QACxC,QAAQ,CAAC,OAAO,KAAK,EAAE,CAAA;QACvB,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;IAC/B,CAAC;AACH,CAAC;AALD,gDAKC"}
|
@@ -1,5 +1,7 @@
|
|
1
1
|
import { OrderTypes } from "@medusajs/types";
|
2
2
|
export declare function formatOrder(order: any, options: {
|
3
|
+
entity: any;
|
3
4
|
includeTotals?: boolean;
|
4
|
-
}): OrderTypes.OrderDTO | OrderTypes.OrderDTO[];
|
5
|
-
export declare function mapRepositoryToOrderModel(config: any): any;
|
5
|
+
}): Partial<OrderTypes.OrderDTO> | Partial<OrderTypes.OrderDTO>[];
|
6
|
+
export declare function mapRepositoryToOrderModel(config: any, isRelatedEntity?: boolean): any;
|
7
|
+
//# sourceMappingURL=transform-order.d.ts.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"transform-order.d.ts","sourceRoot":"","sources":["../../src/utils/transform-order.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAA;AAU5C,wBAAgB,WAAW,CACzB,KAAK,KAAA,EACL,OAAO,EAAE;IACP,MAAM,EAAE,GAAG,CAAA;IACX,aAAa,CAAC,EAAE,OAAO,CAAA;CACxB,GACA,OAAO,CAAC,UAAU,CAAC,QAAQ,CAAC,GAAG,OAAO,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,CAkF/D;AAmFD,wBAAgB,yBAAyB,CAAC,MAAM,KAAA,EAAE,eAAe,UAAQ,OAwExE"}
|
@@ -2,11 +2,26 @@
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
3
3
|
exports.mapRepositoryToOrderModel = exports.formatOrder = void 0;
|
4
4
|
const utils_1 = require("@medusajs/utils");
|
5
|
+
// Reshape the order object to match the OrderDTO
|
6
|
+
// This function is used to format the order object before returning to the main module methods
|
5
7
|
function formatOrder(order, options) {
|
6
8
|
const isArray = Array.isArray(order);
|
7
9
|
const orders = [...(isArray ? order : [order])];
|
8
10
|
orders.map((order) => {
|
9
|
-
|
11
|
+
let mainOrder = order;
|
12
|
+
const isRelatedEntity = options?.entity?.name !== "Order";
|
13
|
+
// If the entity is a related entity, the original order is located in the order property
|
14
|
+
if (isRelatedEntity) {
|
15
|
+
if (!order.order) {
|
16
|
+
return order;
|
17
|
+
}
|
18
|
+
mainOrder = order.order;
|
19
|
+
}
|
20
|
+
mainOrder.items = mainOrder.items?.map((orderItem) => {
|
21
|
+
const isFormatted = (0, utils_1.isDefined)(orderItem.detail?.fulfilled_quantity);
|
22
|
+
if (isFormatted) {
|
23
|
+
return orderItem;
|
24
|
+
}
|
10
25
|
const detail = { ...orderItem };
|
11
26
|
delete detail.order;
|
12
27
|
delete detail.item;
|
@@ -17,26 +32,105 @@ function formatOrder(order, options) {
|
|
17
32
|
detail,
|
18
33
|
};
|
19
34
|
});
|
20
|
-
|
21
|
-
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
+
if (isRelatedEntity) {
|
36
|
+
if (order.return) {
|
37
|
+
formatOrderReturn(order.return, mainOrder);
|
38
|
+
}
|
39
|
+
const entityName = options.entity.name;
|
40
|
+
if (entityName === "OrderClaim") {
|
41
|
+
formatClaim(order);
|
42
|
+
}
|
43
|
+
else if (entityName === "OrderExchange") {
|
44
|
+
formatExchange(order);
|
45
|
+
}
|
46
|
+
else if (entityName === "Return") {
|
47
|
+
formatReturn(order);
|
48
|
+
}
|
49
|
+
}
|
50
|
+
if (order.shipping_methods) {
|
51
|
+
order.shipping_methods = order.shipping_methods?.map((shippingMethod) => {
|
52
|
+
if (shippingMethod.detail) {
|
53
|
+
return shippingMethod;
|
54
|
+
}
|
55
|
+
const sm = { ...shippingMethod.shipping_method };
|
56
|
+
delete shippingMethod.shipping_method;
|
57
|
+
cleanNestedRelations(shippingMethod);
|
58
|
+
return {
|
59
|
+
...sm,
|
60
|
+
order_id: shippingMethod.order_id,
|
61
|
+
detail: {
|
62
|
+
...shippingMethod,
|
63
|
+
},
|
64
|
+
};
|
65
|
+
});
|
66
|
+
}
|
67
|
+
if (mainOrder.summary) {
|
68
|
+
mainOrder.summary = mainOrder.summary?.[0]?.totals;
|
69
|
+
}
|
70
|
+
return (0, utils_1.createRawPropertiesFromBigNumber)(options?.includeTotals ? (0, utils_1.decorateCartTotals)(order) : order);
|
35
71
|
});
|
36
72
|
return isArray ? orders : orders[0];
|
37
73
|
}
|
38
74
|
exports.formatOrder = formatOrder;
|
39
|
-
function
|
75
|
+
function cleanNestedRelations(obj) {
|
76
|
+
delete obj.order;
|
77
|
+
delete obj.return;
|
78
|
+
delete obj.claim;
|
79
|
+
delete obj.exchange;
|
80
|
+
}
|
81
|
+
function formatOrderReturn(orderReturn, mainOrder) {
|
82
|
+
orderReturn.items?.forEach((orderItem) => {
|
83
|
+
const item = mainOrder.items?.find((item) => item.id === orderItem.item_id);
|
84
|
+
orderItem.detail = item?.detail;
|
85
|
+
});
|
86
|
+
}
|
87
|
+
function formatClaim(claim) {
|
88
|
+
if (claim.additional_items) {
|
89
|
+
claim.additional_items = claim.additional_items.filter((item) => item.is_additional_item);
|
90
|
+
claim.additional_items.forEach((orderItem) => {
|
91
|
+
const item = claim.order.items?.find((item) => item.id === orderItem.item_id);
|
92
|
+
cleanNestedRelations(item);
|
93
|
+
orderItem.detail = item?.detail;
|
94
|
+
});
|
95
|
+
}
|
96
|
+
if (!claim.claim_items) {
|
97
|
+
return;
|
98
|
+
}
|
99
|
+
claim.claim_items = claim.claim_items.filter((item) => !item.is_additional_item);
|
100
|
+
claim.claim_items.forEach((orderItem) => {
|
101
|
+
const item = claim.order.items?.find((item) => item.id === orderItem.item_id);
|
102
|
+
cleanNestedRelations(item);
|
103
|
+
orderItem.detail = item?.detail;
|
104
|
+
});
|
105
|
+
}
|
106
|
+
function formatExchange(exchange) {
|
107
|
+
if (!exchange.additional_items) {
|
108
|
+
return;
|
109
|
+
}
|
110
|
+
exchange.additional_items.forEach((orderItem) => {
|
111
|
+
const item = exchange.order.items?.find((item) => item.id === orderItem.item_id);
|
112
|
+
cleanNestedRelations(item);
|
113
|
+
orderItem.detail = item?.detail;
|
114
|
+
});
|
115
|
+
}
|
116
|
+
function formatReturn(returnOrder) {
|
117
|
+
if (!returnOrder.items) {
|
118
|
+
return;
|
119
|
+
}
|
120
|
+
returnOrder.items.forEach((orderItem) => {
|
121
|
+
const item = returnOrder.order.items?.find((item) => item.id === orderItem.item_id);
|
122
|
+
cleanNestedRelations(item);
|
123
|
+
orderItem.detail = item?.detail;
|
124
|
+
});
|
125
|
+
}
|
126
|
+
// Map the public order model to the repository model format
|
127
|
+
// As the public responses have a different shape than the repository responses, this function is used to map the public properties to the internal db entities
|
128
|
+
// e.g "items" is the relation between "line-item" and "order" + "version", The line item itself is in "items.item"
|
129
|
+
// This helper maps to the correct repository to query the DB, and the function "formatOrder" remap the response to the public shape
|
130
|
+
function mapRepositoryToOrderModel(config, isRelatedEntity = false) {
|
131
|
+
if (isRelatedEntity) {
|
132
|
+
return mapRepositoryToRelatedEntity(config);
|
133
|
+
}
|
40
134
|
const conf = { ...config };
|
41
135
|
function replace(obj, type) {
|
42
136
|
if (!(0, utils_1.isDefined)(obj[type])) {
|
@@ -94,4 +188,24 @@ function mapRepositoryToOrderModel(config) {
|
|
94
188
|
return conf;
|
95
189
|
}
|
96
190
|
exports.mapRepositoryToOrderModel = mapRepositoryToOrderModel;
|
191
|
+
// This function has the same purpose as "mapRepositoryToOrderModel" but for returns, claims and exchanges
|
192
|
+
function mapRepositoryToRelatedEntity(config) {
|
193
|
+
const conf = { ...config };
|
194
|
+
function replace(obj, type) {
|
195
|
+
if (!(0, utils_1.isDefined)(obj[type])) {
|
196
|
+
return;
|
197
|
+
}
|
198
|
+
return (0, utils_1.deduplicate)(obj[type].sort().map((rel) => {
|
199
|
+
if (rel.includes("shipping_methods") &&
|
200
|
+
!rel.includes("shipping_methods.shipping_method")) {
|
201
|
+
obj.populate.push("shipping_methods.shipping_method");
|
202
|
+
return rel.replace("shipping_methods", "shipping_methods.shipping_method");
|
203
|
+
}
|
204
|
+
return rel;
|
205
|
+
}));
|
206
|
+
}
|
207
|
+
conf.options.fields = replace(config.options, "fields");
|
208
|
+
conf.options.populate = replace(config.options, "populate");
|
209
|
+
return conf;
|
210
|
+
}
|
97
211
|
//# sourceMappingURL=transform-order.js.map
|