You are here

public function Menu::calculateDependencies in Menu Entity Index 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 HandlerBase::calculateDependencies

See also

\Drupal\Core\Config\Entity\ConfigDependencyManager

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

File

src/Plugin/views/filter/Menu.php, line 96

Class

Menu
Filter class which allows filtering by menu name.

Namespace

Drupal\menu_entity_index\Plugin\views\filter

Code

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

  // Add a cachable dependency on our configuration.
  if ($this->trackedOnly) {
    $dependencies['config'][] = 'menu_entity_index.configuration';
  }

  // Add a cachable dependency on each menu, that was selected.
  $menus = $this->entityTypeManager
    ->getStorage('menu')
    ->loadMultiple($this->value);
  foreach ($menus as $menu) {
    $dependencies[$menu
      ->getConfigDependencyKey()][] = $menu
      ->getConfigDependencyName();
  }
  return $dependencies;
}