commerce_funds-8.x-1.7/src/Plugin/Field/FieldWidget/FundsTransactionWidgetBase.php

src/Plugin/Field/FieldWidget/FundsTransactionWidgetBase.php
<?php

namespace Drupal\commerce_funds\Plugin\Field\FieldWidget;

use Drupal\Core\Field\FieldDefinitionInterface;
use Drupal\Core\Field\FieldItemListInterface;
use Drupal\Core\Field\WidgetBase;
use Drupal\Core\Form\FormStateInterface;
use Drupal\Core\Render\Element;
use Drupal\commerce_funds\FeesManagerInterface;
use Symfony\Component\DependencyInjection\ContainerInterface;

/**
 * Base class for 'Transaction widgets' plugin implementations.
 *
 * @ingroup field_widget
 */
abstract class FundsTransactionWidgetBase extends WidgetBase {

  /**
   * The fees manager.
   *
   * @var \Drupal\commerce_funds\FeesManagerInterface
   */
  protected $feesManager;

  /**
   * {@inheritdoc}
   */
  public function __construct($plugin_id, $plugin_definition, FieldDefinitionInterface $field_definition, array $settings, array $third_party_settings, FeesManagerInterface $fees_manager) {
    parent::__construct($plugin_id, $plugin_definition, $field_definition, $settings, $third_party_settings);

    $this->feesManager = $fees_manager;
  }

  /**
   * {@inheritdoc}
   */
  public static function create(ContainerInterface $container, array $configuration, $plugin_id, $plugin_definition) {
    return new static(
      $plugin_id,
      $plugin_definition,
      $configuration['field_definition'],
      $configuration['settings'],
      $configuration['third_party_settings'],
      $container->get('commerce_funds.fees_manager')
    );
  }

  /**
   * {@inheritdoc}
   */
  public function formElement(FieldItemListInterface $items, $delta, array $element, array &$form, FormStateInterface $form_state) {
    // Add a custom entity builder handler.
    $form['#entity_builders']['update_funds_transaction'] = 'Drupal\commerce_funds\Element\FundsTransaction::updateFundsTransaction';
    // A transaction exist? We render it.
    if ($items->first()->getString()) {
      $renderable_array = $items->view('full');
      array_unshift($renderable_array, [
        '#markup' => '<div class="transaction-not-editable"><i>' . t('Transaction fields are not editable.') . '</i></div>',
      ]);

      return $renderable_array;
    }

    $settings = $this->getFieldSettings();

    $element += [
      '#type' => 'details',
      '#open' => TRUE,
    ];

    $element['target_id'] = [
      '#type' => 'funds_transaction',
      '#transaction_type' => '',
      '#available_currencies' => $settings['available_currencies'],
      '#notes_enabled' => $settings['enable_notes'],
    ];

    // Default widget ?
    if ($this->isDefaultValueWidget($form_state)) {
      // Make sure no properties are required on the default value widget.
      $element['target_id']['#after_build'][] = [
        get_class($this),
        'makeFieldsOptional',
      ];
      // Add a wrapper for the ajax callback.
      // We currently need to force a hardcoded ID here.
      // @see https://www.drupal.org/project/drupal/issues/2821793.
      // @see Drupal\commerce_funds\Plugin\Field\FieldType\FundsTransactionItem.
      $element['#prefix'] = '<div id="funds-transaction-wrapper">';
      $element['#suffix'] = '</div>';
    }

    return $element;
  }

  /**
   * Form API callback: Makes all funds field properties optional.
   */
  public static function makeFieldsOptional(array $element, FormStateInterface $form_state) {
    foreach (Element::getVisibleChildren($element) as $key) {
      if (!empty($element[$key]['#required'])) {
        $element[$key]['#required'] = FALSE;
      }
    }

    return $element;
  }

}

Главная | Обратная связь

drupal hosting | друпал хостинг | it patrol .inc