Skip to main content

Workflows

getFormattedOrderSetListWorkflow

This documentation provides a reference to the getFormattedOrderSetListWorkflow. It belongs to the @mercurjs/b2c-core package. This workflow retrieves order sets with calculated totals and aggregated statuses. An order set represents a group of orders created from a single cart in a multi-vendor marketplace. The workflow computes the overall payment status, fulfillment status, and financial totals by aggregating data from all orders within each set. Source code

Examples

packages/modules/b2c-core/src/api/store/order-set/route.ts
import { AuthenticatedMedusaRequest, MedusaResponse } from '@medusajs/framework'
import { ContainerRegistrationKeys } from '@medusajs/framework/utils'
import { getFormattedOrderSetListWorkflow } from '../../../workflows/order-set/workflows'
import { defaultStoreRetrieveOrderSetFields } from './query-config'

export async function GET(
  req: AuthenticatedMedusaRequest,
  res: MedusaResponse
): Promise<void> {
  const query = req.scope.resolve(ContainerRegistrationKeys.QUERY)

  const { data: order_set_ids, metadata } = await query.graph({
    entity: 'order_set',
    fields: ['id'],
    filters: {
      customer_id: req.auth_context.actor_id
    },
    pagination: req.queryConfig.pagination
  })

  const {
    result: { data: order_sets }
  } = await getFormattedOrderSetListWorkflow(req.scope).run({
    input: {
      filters: { id: order_set_ids.map((set) => set.id) },
      fields: defaultStoreRetrieveOrderSetFields
    }
  })

  res.json({
    order_sets,
    count: metadata?.count,
    offset: metadata?.skip,
    limit: metadata?.take
  })
}

Steps

  • useQueryGraphStep: Fetches order sets with related orders, items, fulfillments, and payment data.
  • transform (formatOrderSets): Aggregates order data to calculate totals and statuses for the entire order set.

Input

input
object
required
The order set query parameters.

Output

object
object