You are here

OrderBillingAddress.php in Commerce Core 8.2

File

modules/order/src/Plugin/Commerce/Condition/OrderBillingAddress.php
View source
<?php

namespace Drupal\commerce_order\Plugin\Commerce\Condition;

use CommerceGuys\Addressing\Zone\Zone;
use Drupal\commerce\Plugin\Commerce\Condition\ConditionBase;
use Drupal\Core\Entity\EntityInterface;
use Drupal\Core\Form\FormStateInterface;

/**
 * Provides the billing address condition for orders.
 *
 * @CommerceCondition(
 *   id = "order_billing_address",
 *   label = @Translation("Billing address"),
 *   category = @Translation("Customer"),
 *   entity_type = "commerce_order",
 *   weight = 10,
 * )
 */
class OrderBillingAddress extends ConditionBase {

  /**
   * {@inheritdoc}
   */
  public function defaultConfiguration() {
    return [
      'zone' => NULL,
    ] + parent::defaultConfiguration();
  }

  /**
   * {@inheritdoc}
   */
  public function buildConfigurationForm(array $form, FormStateInterface $form_state) {
    $form = parent::buildConfigurationForm($form, $form_state);
    $form['zone'] = [
      '#type' => 'address_zone',
      '#default_value' => $this->configuration['zone'],
      '#required' => TRUE,
    ];
    return $form;
  }

  /**
   * {@inheritdoc}
   */
  public function submitConfigurationForm(array &$form, FormStateInterface $form_state) {
    parent::submitConfigurationForm($form, $form_state);
    $values = $form_state
      ->getValue($form['#parents']);

    // Work around an Address bug where the Remove button value is kept in the array.
    foreach ($values['zone']['territories'] as &$territory) {
      unset($territory['remove']);
    }

    // Don't store the label, it's always hidden and empty.
    unset($values['zone']['label']);
    $this->configuration['zone'] = $values['zone'];
  }

  /**
   * {@inheritdoc}
   */
  public function evaluate(EntityInterface $entity) {
    $this
      ->assertEntity($entity);

    /** @var \Drupal\commerce_order\Entity\OrderInterface $order */
    $order = $entity;
    $billing_profile = $order
      ->getBillingProfile();
    if (!$billing_profile) {

      // The promotion can't be applied until the billing address is known.
      return FALSE;
    }
    $zone = new Zone([
      'id' => 'billing',
      'label' => 'N/A',
    ] + $this->configuration['zone']);
    $address = $billing_profile
      ->get('address')
      ->first();
    return $zone
      ->match($address);
  }

}

Classes

Namesort descending Description
OrderBillingAddress Provides the billing address condition for orders.