class BaseField in Synonyms 2.0.x
Same name and namespace in other branches
- 8 src/Plugin/Synonyms/Provider/BaseField.php \Drupal\synonyms\Plugin\Synonyms\Provider\BaseField
Provide synonyms from base fields.
Plugin annotation
@Provider(
  id = "base_field",
  deriver = "Drupal\synonyms\Plugin\Derivative\Field"
)
Hierarchy
- class \Drupal\Component\Plugin\PluginBase implements DerivativeInspectionInterface, PluginInspectionInterface- class \Drupal\synonyms\Plugin\Synonyms\Provider\AbstractProvider implements ContainerFactoryPluginInterface, ConfigurationInterface, FindInterface, FormatWordingInterface, GetInterface, ProviderInterface uses ConfigurationTrait- class \Drupal\synonyms\Plugin\Synonyms\Provider\BaseField
 
 
- class \Drupal\synonyms\Plugin\Synonyms\Provider\AbstractProvider implements ContainerFactoryPluginInterface, ConfigurationInterface, FindInterface, FormatWordingInterface, GetInterface, ProviderInterface uses ConfigurationTrait
Expanded class hierarchy of BaseField
File
- src/Plugin/ Synonyms/ Provider/ BaseField.php, line 20 
Namespace
Drupal\synonyms\Plugin\Synonyms\ProviderView source
class BaseField extends AbstractProvider {
  /**
   * The field type to synonyms.
   *
   * @var \Drupal\synonyms\SynonymsService\FieldTypeToSynonyms
   */
  protected $fieldTypeToSynonyms;
  /**
   * The entity type manager.
   *
   * @var \Drupal\Core\Entity\EntityTypeManagerInterface
   */
  protected $entityTypeManager;
  /**
   * The database connection.
   *
   * @var \Drupal\Core\Database\Connection
   */
  protected $database;
  /**
   * BaseField constructor.
   */
  public function __construct(array $configuration, $plugin_id, $plugin_definition, FieldTypeToSynonyms $field_type_to_synonyms, EntityTypeManagerInterface $entity_type_manager, Connection $database, ContainerInterface $container) {
    parent::__construct($configuration, $plugin_id, $plugin_definition, $container);
    $this->fieldTypeToSynonyms = $field_type_to_synonyms;
    $this->entityTypeManager = $entity_type_manager;
    $this->database = $database;
  }
  /**
   * {@inheritdoc}
   */
  public static function create(ContainerInterface $container, array $configuration, $plugin_id, $plugin_definition) {
    return new static($configuration, $plugin_id, $plugin_definition, $container
      ->get('synonyms.provider.field_type_to_synonyms'), $container
      ->get('entity_type.manager'), $container
      ->get('database'), $container);
  }
  /**
   * {@inheritdoc}
   */
  public function getSynonyms(ContentEntityInterface $entity) {
    $map = $this->fieldTypeToSynonyms
      ->getSimpleFieldTypeToPropertyMap();
    $field_type = $entity
      ->getFieldDefinition($this
      ->getPluginDefinition()['field'])
      ->getType();
    $synonyms = [];
    if (isset($map[$field_type])) {
      foreach ($entity
        ->get($this
        ->getPluginDefinition()['field']) as $item) {
        if (!$item
          ->isEmpty()) {
          $synonyms[] = $item->{$map[$field_type]};
        }
      }
    }
    return $synonyms;
  }
  /**
   * {@inheritdoc}
   */
  public function synonymsFind(ConditionInterface $condition) {
    $entity_type_definition = $this->entityTypeManager
      ->getDefinition($this
      ->getPluginDefinition()['controlled_entity_type']);
    $entity_keys = $entity_type_definition
      ->getKeys();
    $query = $this->database
      ->select($entity_type_definition
      ->getDataTable(), 'base');
    $query
      ->addField('base', $entity_keys['id'], 'entity_id');
    $query
      ->addField('base', $this
      ->getPluginDefinition()['field'], 'synonym');
    if ($this
      ->getPluginDefinition()['controlled_entity_type'] != $this
      ->getPluginDefinition()['controlled_bundle'] && isset($entity_keys['bundle']) && $entity_keys['bundle']) {
      $query
        ->condition($entity_keys['bundle'], $this
        ->getPluginDefinition()['controlled_bundle']);
    }
    $this
      ->synonymsFindProcessCondition($condition, $this
      ->getPluginDefinition()['field'], $entity_keys['id']);
    $query
      ->condition($condition);
    return $query
      ->execute();
  }
}Members
| Name   | Modifiers | Type | Description | Overrides | 
|---|---|---|---|---|
| AbstractProvider:: | protected | property | The container. | |
| BaseField:: | protected | property | The database connection. | |
| BaseField:: | protected | property | The entity type manager. | |
| BaseField:: | protected | property | The field type to synonyms. | |
| BaseField:: | public static | function | Creates an instance of the plugin. Overrides AbstractProvider:: | |
| BaseField:: | public | function | Fetch synonyms from an entity. Overrides GetInterface:: | |
| BaseField:: | public | function | Look up entities by their synonyms within a behavior implementation. Overrides FindInterface:: | |
| BaseField:: | public | function | BaseField constructor. Overrides AbstractProvider:: | |
| ConfigurationTrait:: | public | function | ||
| ConfigurationTrait:: | public | function | ||
| ConfigurationTrait:: | public | function | ||
| ConfigurationTrait:: | public | function | ||
| ConfigurationTrait:: | public | function | ||
| ConfigurationTrait:: | public | function | ||
| FindInterface:: | constant | Constant which denotes placeholder of an entity ID column. | ||
| FindInterface:: | constant | Constant which denotes placeholder of a synonym column. | ||
| FindInterface:: | public | function | Supportive method to process $condition argument in synonymsFind(). | |
| FormatWordingInterface:: | public | function | Get available tokens for format wording. | |
| FormatWordingInterface:: | public | function | Format a synonym into wording as requested by configuration. | |
| GetInterface:: | public | function | Fetch synonyms from multiple entities at once. | |
| PluginBase:: | protected | property | Configuration information passed into the plugin. | 1 | 
| PluginBase:: | protected | property | The plugin implementation definition. | 1 | 
| PluginBase:: | protected | property | The plugin_id. | |
| PluginBase:: | constant | A string which is used to separate base plugin IDs from the derivative ID. | ||
| PluginBase:: | public | function | Gets the base_plugin_id of the plugin instance. Overrides DerivativeInspectionInterface:: | |
| PluginBase:: | public | function | Gets the derivative_id of the plugin instance. Overrides DerivativeInspectionInterface:: | |
| PluginBase:: | public | function | Gets the definition of the plugin implementation. Overrides PluginInspectionInterface:: | 2 | 
| PluginBase:: | public | function | Gets the plugin_id of the plugin instance. Overrides PluginInspectionInterface:: | |
| PluginBase:: | public | function | Determines if the plugin is configurable. | |
| StringTranslationTrait:: | protected | property | The string translation service. | 4 | 
| StringTranslationTrait:: | protected | function | Formats a string containing a count of items. | |
| StringTranslationTrait:: | protected | function | Returns the number of plurals supported by a given language. | |
| StringTranslationTrait:: | protected | function | Gets the string translation service. | |
| StringTranslationTrait:: | public | function | Sets the string translation service to use. | 2 | 
| StringTranslationTrait:: | protected | function | Translates a string to the current language or to a given language. | 
