+++ /dev/null
-<?php
-
-namespace Drupal\paragraphs;
-
-use Drupal\Core\Cache\CacheBackendInterface;
-use Drupal\Core\Extension\ModuleHandlerInterface;
-use Drupal\Core\Plugin\DefaultPluginManager;
-
-/**
- * Plugin type manager for paragraphs type behavior plugins.
- *
- * @ingroup paragraphs_behavior
- */
-class ParagraphsBehaviorManager extends DefaultPluginManager {
-
- /**
- * Constructs a ParagraphsBehaviorManager object.
- *
- * @param \Traversable $namespaces
- * An object that implements \Traversable which contains the root paths
- * keyed by the corresponding namespace to look for plugin implementations.
- * @param \Drupal\Core\Cache\CacheBackendInterface $cache_backend
- * Cache backend instance to use.
- * @param \Drupal\Core\Extension\ModuleHandlerInterface $module_handler
- * The module handler.
- */
- public function __construct(\Traversable $namespaces, CacheBackendInterface $cache_backend, ModuleHandlerInterface $module_handler) {
- parent::__construct('Plugin/paragraphs/Behavior', $namespaces, $module_handler, 'Drupal\paragraphs\ParagraphsBehaviorInterface', 'Drupal\paragraphs\Annotation\ParagraphsBehavior');
- $this->setCacheBackend($cache_backend, 'paragraphs_behavior_plugins');
- $this->alterInfo('paragraphs_behavior_info');
- }
-
- /**
- * {@inheritdoc}
- */
- public function getDefinitions() {
- $definitions = parent::getDefinitions();
- uasort($definitions, 'Drupal\Component\Utility\SortArray::sortByWeightElement');
- return $definitions;
- }
-
- /**
- * Gets the applicable behavior plugins.
- *
- * Loop over the plugin definitions, check the applicability of each one of
- * them and return the array of the applicable plugins.
- *
- * @return array
- * The applicable behavior plugins.
- */
- public function getApplicableDefinitions($paragraphs_type) {
- $definitions = $this->getDefinitions();
- $applicable_plugins = [];
- foreach ($definitions as $key => $definition) {
- if ($definition['class']::isApplicable($paragraphs_type)) {
- $applicable_plugins[$key] = $definition;
- }
- }
- return $applicable_plugins;
- }
-
-}