You are here

public function CheckoutFlowWithPanesBase::calculateDependencies in Commerce Core 8.2

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

See also

\Drupal\Core\Config\Entity\ConfigDependencyManager

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

File

modules/checkout/src/Plugin/Commerce/CheckoutFlow/CheckoutFlowWithPanesBase.php, line 138

Class

CheckoutFlowWithPanesBase
Provides a base checkout flow that uses checkout panes.

Namespace

Drupal\commerce_checkout\Plugin\Commerce\CheckoutFlow

Code

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

  // Merge-in the pane dependencies.
  foreach ($this
    ->getPanes() as $id => $pane) {
    if (!isset($this->configuration['panes'][$id])) {
      continue;
    }
    foreach ($pane
      ->calculateDependencies() as $dependency_type => $list) {
      foreach ($list as $name) {
        $dependencies[$dependency_type][] = $name;
      }
    }
  }
  return $dependencies;
}