You are here

public function WrapperTarget::calculateDependencies in Feeds Paragraphs 8

Calculates dependencies for the configured plugin.

Dependencies are saved in the plugin's configuration entity and are used to determine configuration synchronization order. For example, if the plugin integrates with specific user roles, this method should return an array of dependencies listing the specified roles.

Return value

array An array of dependencies grouped by type (config, content, module, theme). For example:

array(
  'config' => array(
    'user.role.anonymous',
    'user.role.authenticated',
  ),
  'content' => array(
    'node:article:f0a189e6-55fb-47fb-8005-5bef81c44d6d',
  ),
  'module' => array(
    'node',
    'user',
  ),
  'theme' => array(
    'seven',
  ),
);

Overrides FieldTargetBase::calculateDependencies

See also

\Drupal\Core\Config\Entity\ConfigDependencyManager

\Drupal\Core\Entity\EntityInterface::getConfigDependencyName()

File

src/Feeds/Target/WrapperTarget.php, line 323

Class

WrapperTarget
Defines a wrapper target around a paragraph bundle's target field.

Namespace

Drupal\feeds_para_mapper\Feeds\Target

Code

public function calculateDependencies() {
  $this->dependencies = parent::calculateDependencies();

  // Add the configured field as a dependency.
  $field_definition = $this->targetDefinition
    ->getFieldDefinition();

  // We need to add all parent fields as dependencies
  $fields = $this->mapper
    ->loadParentFields($field_definition);
  $fields[] = $field_definition;
  foreach ($fields as $field) {
    if ($field && $field instanceof EntityInterface) {
      $this->dependencies['config'][] = $field
        ->getConfigDependencyName();
    }
  }
  return $this->dependencies;
}