You are here

public function View::calculateDependencies in Drupal 8

Same name in this branch
  1. 8 core/modules/views/src/Entity/View.php \Drupal\views\Entity\View::calculateDependencies()
  2. 8 core/modules/views/src/Plugin/views/area/View.php \Drupal\views\Plugin\views\area\View::calculateDependencies()
Same name and namespace in other branches
  1. 9 core/modules/views/src/Plugin/views/area/View.php \Drupal\views\Plugin\views\area\View::calculateDependencies()

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 HandlerBase::calculateDependencies

See also

\Drupal\Core\Config\Entity\ConfigDependencyManager

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

File

core/modules/views/src/Plugin/views/area/View.php, line 152

Class

View
Views area handlers. Insert a view inside of an area.

Namespace

Drupal\views\Plugin\views\area

Code

public function calculateDependencies() {
  $dependencies = parent::calculateDependencies();
  list($view_id) = explode(':', $this->options['view_to_insert'], 2);

  // Don't call the current view, as it would result into an infinite recursion.
  if ($view_id && $this->view->storage
    ->id() != $view_id) {
    $view = $this->viewStorage
      ->load($view_id);
    $dependencies[$view
      ->getConfigDependencyKey()][] = $view
      ->getConfigDependencyName();
  }
  return $dependencies;
}