You are here

OrderItemMatcherInterface.php in Commerce Core 8.2

File

modules/cart/src/OrderItemMatcherInterface.php
View source
<?php

namespace Drupal\commerce_cart;

use Drupal\commerce_order\Entity\OrderItemInterface;

/**
 * Finds matching order items.
 *
 * Used for combining order items in the add to cart process.
 *
 * By default, takes into account the order item type, purchased entity ID,
 * and any custom fields shown on the add to cart form.
 *
 * For example, when a custom "engraving" field is shown on the add to cart
 * form, two order items will be combined if they have the same
 * engraving, type, purchased entity ID.
 */
interface OrderItemMatcherInterface {

  /**
   * Finds the first matching order item for the given order item.
   *
   * @param \Drupal\commerce_order\Entity\OrderItemInterface $order_item
   *   The order item.
   * @param \Drupal\commerce_order\Entity\OrderItemInterface[] $order_items
   *   The order items to match against.
   *
   * @return \Drupal\commerce_order\Entity\OrderItemInterface|null
   *   A matching order item, or NULL if none was found.
   */
  public function match(OrderItemInterface $order_item, array $order_items);

  /**
   * Finds all matching order items for the given order item.
   *
   * @param \Drupal\commerce_order\Entity\OrderItemInterface $order_item
   *   The order item.
   * @param \Drupal\commerce_order\Entity\OrderItemInterface[] $order_items
   *   The order items to match against.
   *
   * @return \Drupal\commerce_order\Entity\OrderItemInterface[]
   *   The matching order items.
   */
  public function matchAll(OrderItemInterface $order_item, array $order_items);

}

Interfaces

Namesort descending Description
OrderItemMatcherInterface Finds matching order items.