Mercurial > hg > isophonics-drupal-site
view core/lib/Drupal/Core/Plugin/DefaultLazyPluginCollection.php @ 19:fa3358dc1485 tip
Add ndrum files
author | Chris Cannam |
---|---|
date | Wed, 28 Aug 2019 13:14:47 +0100 |
parents | af1871eacc83 |
children |
line wrap: on
line source
<?php namespace Drupal\Core\Plugin; use Drupal\Component\Plugin\Exception\PluginNotFoundException; use Drupal\Component\Plugin\LazyPluginCollection; use Drupal\Component\Plugin\PluginHelper; use Drupal\Component\Plugin\PluginManagerInterface; use Drupal\Core\DependencyInjection\DependencySerializationTrait; /** * Provides a default plugin collection for a plugin type. * * A plugin collection is used to contain plugins that will be lazily * instantiated. The configurations of each potential plugin are passed in, and * the configuration key containing the plugin ID is specified by * self::$pluginKey. */ class DefaultLazyPluginCollection extends LazyPluginCollection { use DependencySerializationTrait; /** * The manager used to instantiate the plugins. * * @var \Drupal\Component\Plugin\PluginManagerInterface */ protected $manager; /** * The initial configuration for each plugin in the collection. * * @var array * An associative array containing the initial configuration for each plugin * in the collection, keyed by plugin instance ID. */ protected $configurations = []; /** * The key within the plugin configuration that contains the plugin ID. * * @var string */ protected $pluginKey = 'id'; /** * The original order of the instances. * * @var array */ protected $originalOrder = []; /** * Constructs a new DefaultLazyPluginCollection object. * * @param \Drupal\Component\Plugin\PluginManagerInterface $manager * The manager to be used for instantiating plugins. * @param array $configurations * (optional) An associative array containing the initial configuration for * each plugin in the collection, keyed by plugin instance ID. */ public function __construct(PluginManagerInterface $manager, array $configurations = []) { $this->manager = $manager; $this->configurations = $configurations; if (!empty($configurations)) { $instance_ids = array_keys($configurations); $this->instanceIDs = array_combine($instance_ids, $instance_ids); // Store the original order of the instance IDs for export. $this->originalOrder = $this->instanceIDs; } } /** * {@inheritdoc} */ protected function initializePlugin($instance_id) { $configuration = isset($this->configurations[$instance_id]) ? $this->configurations[$instance_id] : []; if (!isset($configuration[$this->pluginKey])) { throw new PluginNotFoundException($instance_id); } $this->set($instance_id, $this->manager->createInstance($configuration[$this->pluginKey], $configuration)); } /** * Sorts all plugin instances in this collection. * * @return $this */ public function sort() { uasort($this->instanceIDs, [$this, 'sortHelper']); return $this; } /** * Provides uasort() callback to sort plugins. */ public function sortHelper($aID, $bID) { $a = $this->get($aID); $b = $this->get($bID); return strnatcasecmp($a->getPluginId(), $b->getPluginId()); } /** * {@inheritdoc} */ public function getConfiguration() { $instances = []; // Store the current order of the instances. $current_order = $this->instanceIDs; // Reorder the instances to match the original order, adding new instances // to the end. $this->instanceIDs = $this->originalOrder + $current_order; foreach ($this as $instance_id => $instance) { if (PluginHelper::isConfigurable($instance)) { $instances[$instance_id] = $instance->getConfiguration(); } else { $instances[$instance_id] = $this->configurations[$instance_id]; } } // Restore the current order. $this->instanceIDs = $current_order; return $instances; } /** * {@inheritdoc} */ public function setConfiguration($configuration) { // Track each instance ID as it is updated. $unprocessed_instance_ids = $this->getInstanceIds(); foreach ($configuration as $instance_id => $instance_configuration) { $this->setInstanceConfiguration($instance_id, $instance_configuration); // Remove this instance ID from the list being updated. unset($unprocessed_instance_ids[$instance_id]); } // Remove remaining instances that had no configuration specified for them. foreach ($unprocessed_instance_ids as $unprocessed_instance_id) { $this->removeInstanceId($unprocessed_instance_id); } return $this; } /** * Updates the configuration for a plugin instance. * * If there is no plugin instance yet, a new will be instantiated. Otherwise, * the existing instance is updated with the new configuration. * * @param string $instance_id * The ID of a plugin to set the configuration for. * @param array $configuration * The plugin configuration to set. */ public function setInstanceConfiguration($instance_id, array $configuration) { $this->configurations[$instance_id] = $configuration; $instance = $this->get($instance_id); if (PluginHelper::isConfigurable($instance)) { $instance->setConfiguration($configuration); } } /** * {@inheritdoc} */ public function addInstanceId($id, $configuration = NULL) { parent::addInstanceId($id); if ($configuration !== NULL) { $this->setInstanceConfiguration($id, $configuration); } if (!isset($this->originalOrder[$id])) { $this->originalOrder[$id] = $id; } } /** * {@inheritdoc} */ public function removeInstanceId($instance_id) { parent::removeInstanceId($instance_id); unset($this->originalOrder[$instance_id]); unset($this->configurations[$instance_id]); } }