From ff4663713a2f05886a924556b5fa1baf90073e4e Mon Sep 17 00:00:00 2001 From: Oli Juhl <59018053+olivermrbl@users.noreply.github.com> Date: Wed, 4 Dec 2024 17:21:07 +0100 Subject: [PATCH] fix(core-flows): Listing return shipping options (#10432) --- .../cart/store/cart.workflows.spec.ts | 154 ++++++++++++++++++ .../list-shipping-options-for-cart.ts | 4 +- 2 files changed, 157 insertions(+), 1 deletion(-) diff --git a/integration-tests/modules/__tests__/cart/store/cart.workflows.spec.ts b/integration-tests/modules/__tests__/cart/store/cart.workflows.spec.ts index 32cdc7e052d3a..78f66698d01bc 100644 --- a/integration-tests/modules/__tests__/cart/store/cart.workflows.spec.ts +++ b/integration-tests/modules/__tests__/cart/store/cart.workflows.spec.ts @@ -1957,6 +1957,160 @@ medusaIntegrationTestRunner({ ]) }) + it("should exclude return shipping options for cart by default", async () => { + const salesChannel = await scModuleService.createSalesChannels({ + name: "Webshop", + }) + + const location = await stockLocationModule.createStockLocations({ + name: "Europe", + }) + + let cart = await cartModuleService.createCarts({ + currency_code: "usd", + region_id: region.id, + sales_channel_id: salesChannel.id, + shipping_address: { + city: "CPH", + province: "Sjaelland", + country_code: "dk", + }, + }) + + const shippingProfile = + await fulfillmentModule.createShippingProfiles({ + name: "Test", + type: "default", + }) + + const fulfillmentSet = await fulfillmentModule.createFulfillmentSets({ + name: "Test", + type: "test-type", + service_zones: [ + { + name: "Test", + geo_zones: [ + { + type: "country", + country_code: "dk", + }, + ], + }, + ], + }) + + const shippingOption = await fulfillmentModule.createShippingOptions([ + { + name: "Return shipping option", + service_zone_id: fulfillmentSet.service_zones[0].id, + shipping_profile_id: shippingProfile.id, + provider_id: "manual_test-provider", + rules: [ + { + operator: RuleOperator.EQ, + attribute: "is_return", + value: "true", + }, + ], + price_type: "flat", + type: { + label: "Test type", + description: "Test description", + code: "test-code", + }, + }, + { + name: "Test shipping option", + service_zone_id: fulfillmentSet.service_zones[0].id, + shipping_profile_id: shippingProfile.id, + provider_id: "manual_test-provider", + price_type: "flat", + type: { + label: "Test type", + description: "Test description", + code: "test-code", + }, + }, + ]) + + const priceSet = await pricingModule.createPriceSets({ + prices: [ + { + amount: 3000, + currency_code: "usd", + }, + ], + }) + + const priceSetTwo = await pricingModule.createPriceSets({ + prices: [ + { + amount: 3000, + currency_code: "usd", + }, + ], + }) + + await remoteLink.create([ + { + [Modules.SALES_CHANNEL]: { + sales_channel_id: salesChannel.id, + }, + [Modules.STOCK_LOCATION]: { + stock_location_id: location.id, + }, + }, + { + [Modules.STOCK_LOCATION]: { + stock_location_id: location.id, + }, + [Modules.FULFILLMENT]: { + fulfillment_set_id: fulfillmentSet.id, + }, + }, + { + [Modules.FULFILLMENT]: { + shipping_option_id: shippingOption.find( + (o) => o.name === "Test shipping option" + )?.id, + }, + [Modules.PRICING]: { + price_set_id: priceSet.id, + }, + }, + { + [Modules.FULFILLMENT]: { + shipping_option_id: shippingOption.find( + (o) => o.name === "Return shipping option" + )?.id, + }, + [Modules.PRICING]: { + price_set_id: priceSetTwo.id, + }, + }, + ]) + + cart = await cartModuleService.retrieveCart(cart.id, { + select: ["id"], + relations: ["shipping_address"], + }) + + const { result } = await listShippingOptionsForCartWorkflow( + appContainer + ).run({ + input: { + cart_id: cart.id, + }, + }) + + expect(result.length).toEqual(1) + expect(result).toEqual([ + expect.objectContaining({ + name: "Test shipping option", + }), + ]) + }) + it("should list no shipping options for cart, if sales channel is not associated with location", async () => { const salesChannel = await scModuleService.createSalesChannels({ name: "Webshop", diff --git a/packages/core/core-flows/src/cart/workflows/list-shipping-options-for-cart.ts b/packages/core/core-flows/src/cart/workflows/list-shipping-options-for-cart.ts index a2ada51ac1b76..655e55ad0a10f 100644 --- a/packages/core/core-flows/src/cart/workflows/list-shipping-options-for-cart.ts +++ b/packages/core/core-flows/src/cart/workflows/list-shipping-options-for-cart.ts @@ -100,6 +100,8 @@ export const listShippingOptionsForCartWorkflow = createWorkflow( }) ) + const isReturn = transform({ input }, ({ input }) => !!input.is_return) + const shippingOptions = useRemoteQueryStep({ entry_point: "shipping_options", fields: [ @@ -128,7 +130,7 @@ export const listShippingOptionsForCartWorkflow = createWorkflow( ], variables: { context: { - is_return: !!input.is_return, + is_return: isReturn, enabled_in_store: "true", }, filters: {