@medusajs/core-flows
Version:
Set of workflow definitions for Medusa
151 lines • 5.98 kB
JavaScript
Object.defineProperty(exports, "__esModule", { value: true });
exports.orderClaimAddNewItemWorkflow = exports.orderClaimAddNewItemWorkflowId = exports.orderClaimAddNewItemValidationStep = void 0;
const utils_1 = require("@medusajs/framework/utils");
const workflows_sdk_1 = require("@medusajs/framework/workflows-sdk");
const common_1 = require("../../../common");
const preview_order_change_1 = require("../../steps/preview-order-change");
const order_validation_1 = require("../../utils/order-validation");
const add_line_items_1 = require("../add-line-items");
const create_order_change_actions_1 = require("../create-order-change-actions");
const update_tax_lines_1 = require("../update-tax-lines");
const refresh_shipping_1 = require("./refresh-shipping");
/**
* This step validates that new items can be added to the claim. If the
* order or claim is canceled, or the order change is not active, the step will throw an error.
*
* :::note
*
* You can retrieve an order, order claim, and order change details using [Query](https://docs.medusajs.com/learn/fundamentals/module-links/query),
* or [useQueryGraphStep](https://docs.medusajs.com/resources/references/medusa-workflows/steps/useQueryGraphStep).
*
* :::
*
* @example
* const data = orderClaimAddNewItemValidationStep({
* order: {
* id: "order_123",
* // other order details...
* },
* orderChange: {
* id: "orch_123",
* // other order change details...
* },
* orderClaim: {
* id: "claim_123",
* // other order claim details...
* }
* })
*/
exports.orderClaimAddNewItemValidationStep = (0, workflows_sdk_1.createStep)("claim-add-new-item-validation", async function ({ order, orderChange, orderClaim, }) {
(0, order_validation_1.throwIfIsCancelled)(order, "Order");
(0, order_validation_1.throwIfIsCancelled)(orderClaim, "Claim");
(0, order_validation_1.throwIfOrderChangeIsNotActive)({ orderChange });
});
exports.orderClaimAddNewItemWorkflowId = "claim-add-new-item";
/**
* This workflow adds outbound (or new) items to a claim. It's used by the
* [Add Outbound Items Admin API Route](https://docs.medusajs.com/api/admin#claims_postclaimsidoutbounditems).
*
* You can use this workflow within your customizations or your own custom workflows, allowing you to add outbound items to a claim
* in your custom flows.
*
* @example
* const { result } = await orderClaimAddNewItemWorkflow(container)
* .run({
* input: {
* claim_id: "claim_123",
* items: [
* {
* variant_id: "variant_123",
* quantity: 1
* }
* ]
* }
* })
*
* @summary
*
* Add outbound or new items to a claim.
*/
exports.orderClaimAddNewItemWorkflow = (0, workflows_sdk_1.createWorkflow)(exports.orderClaimAddNewItemWorkflowId, function (input) {
const orderClaim = (0, common_1.useRemoteQueryStep)({
entry_point: "order_claim",
fields: ["id", "order_id", "canceled_at"],
variables: { id: input.claim_id },
list: false,
throw_if_key_not_found: true,
}).config({ name: "claim-query" });
const order = (0, common_1.useRemoteQueryStep)({
entry_point: "orders",
fields: ["id", "status", "canceled_at", "items.*"],
variables: { id: orderClaim.order_id },
list: false,
throw_if_key_not_found: true,
}).config({ name: "order-query" });
const orderChange = (0, common_1.useRemoteQueryStep)({
entry_point: "order_change",
fields: ["id", "status"],
variables: {
filters: {
order_id: orderClaim.order_id,
claim_id: orderClaim.id,
status: [utils_1.OrderChangeStatus.PENDING, utils_1.OrderChangeStatus.REQUESTED],
},
},
list: false,
}).config({ name: "order-change-query" });
(0, exports.orderClaimAddNewItemValidationStep)({
order,
orderClaim,
orderChange,
});
const lineItems = add_line_items_1.addOrderLineItemsWorkflow.runAsStep({
input: {
order_id: order.id,
items: input.items,
},
});
const lineItemIds = (0, workflows_sdk_1.transform)(lineItems, (lineItems) => {
return lineItems.map((item) => item.id);
});
update_tax_lines_1.updateOrderTaxLinesWorkflow.runAsStep({
input: {
order_id: order.id,
item_ids: lineItemIds,
},
});
const orderChangeActionInput = (0, workflows_sdk_1.transform)({ order, orderChange, orderClaim, items: input.items, lineItems }, ({ order, orderChange, orderClaim, items, lineItems }) => {
return items.map((item, index) => ({
order_change_id: orderChange.id,
order_id: order.id,
claim_id: orderClaim.id,
version: orderChange.version,
action: utils_1.ChangeActionType.ITEM_ADD,
internal_note: item.internal_note,
reference: "order_claim",
reference_id: orderClaim.id,
details: {
reference_id: lineItems[index].id,
quantity: item.quantity,
unit_price: item.unit_price ?? lineItems[index].unit_price,
metadata: item.metadata,
},
}));
});
create_order_change_actions_1.createOrderChangeActionsWorkflow.runAsStep({
input: orderChangeActionInput,
});
const refreshArgs = (0, workflows_sdk_1.transform)({ orderChange, orderClaim }, ({ orderChange, orderClaim }) => {
return {
order_change_id: orderChange.id,
claim_id: orderClaim.id,
order_id: orderClaim.order_id,
};
});
refresh_shipping_1.refreshClaimShippingWorkflow.runAsStep({
input: refreshArgs,
});
return new workflows_sdk_1.WorkflowResponse((0, preview_order_change_1.previewOrderChangeStep)(orderClaim.order_id));
});
//# sourceMappingURL=claim-add-new-item.js.map
;