class ExtraFieldDisplayManager in Extra Field 8
Same name and namespace in other branches
- 8.2 src/Plugin/ExtraFieldDisplayManager.php \Drupal\extra_field\Plugin\ExtraFieldDisplayManager
Manages Extra Field plugins.
@package Drupal\extra_field\Plugin
Hierarchy
- class \Drupal\Component\Plugin\PluginManagerBase implements PluginManagerInterface uses DiscoveryTrait
- class \Drupal\Core\Plugin\DefaultPluginManager implements CachedDiscoveryInterface, PluginManagerInterface, CacheableDependencyInterface uses DiscoveryCachedTrait, UseCacheBackendTrait
- class \Drupal\extra_field\Plugin\ExtraFieldDisplayManager implements ExtraFieldDisplayManagerInterface
- class \Drupal\Core\Plugin\DefaultPluginManager implements CachedDiscoveryInterface, PluginManagerInterface, CacheableDependencyInterface uses DiscoveryCachedTrait, UseCacheBackendTrait
Expanded class hierarchy of ExtraFieldDisplayManager
1 string reference to 'ExtraFieldDisplayManager'
1 service uses ExtraFieldDisplayManager
File
- src/
Plugin/ ExtraFieldDisplayManager.php, line 17
Namespace
Drupal\extra_field\PluginView source
class ExtraFieldDisplayManager extends DefaultPluginManager implements ExtraFieldDisplayManagerInterface {
/**
* Caches bundles per entity type.
*
* @var array
*/
protected $entityBundles;
/**
* The entity type manager.
*
* @var \Drupal\Core\Entity\EntityTypeManagerInterface
*/
protected $entityTypeManager;
/**
* Constructor for ExtraFieldDisplayManager objects.
*
* @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 to invoke the alter hook with.
* @param \Drupal\Core\Entity\EntityTypeManagerInterface $entity_type_manager
* The entity type manager.
*/
public function __construct(\Traversable $namespaces, CacheBackendInterface $cache_backend, ModuleHandlerInterface $module_handler, EntityTypeManagerInterface $entity_type_manager) {
parent::__construct('Plugin/ExtraField/Display', $namespaces, $module_handler, 'Drupal\\extra_field\\Plugin\\ExtraFieldDisplayInterface', 'Drupal\\extra_field\\Annotation\\ExtraFieldDisplay');
$this
->alterInfo('extra_field_display_info');
$this
->setCacheBackend($cache_backend, 'extra_field_display_plugins');
$this->entityTypeManager = $entity_type_manager;
}
/**
* {@inheritdoc}
*/
public function fieldInfo() {
$info = [];
$definitions = $this
->getDefinitions();
foreach ($definitions as $key => $definition) {
$entityBundles = $this
->supportedEntityBundles($definition['bundles']);
foreach ($entityBundles as $entityBundle) {
$entityType = $entityBundle['entity'];
$bundle = $entityBundle['bundle'];
$fieldName = $this
->fieldName($key);
$info[$entityType][$bundle]['display'][$fieldName] = [
'label' => $definition['label'],
'weight' => $definition['weight'],
'visible' => $definition['visible'],
];
}
}
return $info;
}
/**
* {@inheritdoc}
*/
public function entityView(array &$build, ContentEntityInterface $entity, EntityViewDisplayInterface $display, $viewMode) {
$definitions = $this
->getDefinitions();
$entityBundleKey = $this
->entityBundleKey($entity
->getEntityTypeId(), $entity
->bundle());
foreach ($definitions as $pluginId => $definition) {
if ($this
->matchEntityBundleKey($definition['bundles'], $entityBundleKey)) {
$factory = $this
->getFactory();
if ($display
->getComponent($this
->fieldName($pluginId))) {
/** @var ExtraFieldDisplayInterface $plugin */
$plugin = $factory
->createInstance($pluginId);
$fieldName = $this
->fieldName($pluginId);
$plugin
->setEntity($entity);
$plugin
->setEntityViewDisplay($display);
$plugin
->setViewMode($viewMode);
$elements = $plugin
->view($entity);
if (!empty($elements)) {
$build[$fieldName] = $elements;
}
}
}
}
}
/**
* Checks if the plugin bundle definition matches the entity bundle key.
*
* @param string[] $pluginBundles
* Defines which entity-bundle pair the plugin can be used for.
* Format: [entity type].[bundle] or [entity type].* .
* @param string $entityBundleKey
* The entity-bundle string of a content entity.
* Format: [entity type].[bundle] .
*
* @return bool
* True of the plugin bundle definition matches the entity bundle key.
*/
protected function matchEntityBundleKey(array $pluginBundles, $entityBundleKey) {
$match = FALSE;
foreach ($pluginBundles as $pluginBundle) {
if (strpos($pluginBundle, '.*')) {
$match = explode('.', $pluginBundle)[0] == explode('.', $entityBundleKey)[0];
}
else {
$match = $pluginBundle == $entityBundleKey;
}
if ($match) {
break;
}
}
return $match;
}
/**
* Returns entity-bundle combinations this plugin supports.
*
* If a wildcard bundle is set, all bundles of the entity will be included.
*
* @param string[] $entityBundleKeys
* Array of entity-bundle strings that define the bundles for which the
* plugin can be used. Format: [entity].[bundle]
* '*' can be used as bundle wildcard.
*
* @return array
* Array of entity and bundle names. Keyed by the [entity].[bundle] key.
*/
protected function supportedEntityBundles(array $entityBundleKeys) {
$result = [];
foreach ($entityBundleKeys as $entityBundleKey) {
if (strpos($entityBundleKey, '.')) {
list($entityType, $bundle) = explode('.', $entityBundleKey);
if ($bundle == '*') {
foreach ($this
->allEntityBundles($entityType) as $bundle) {
$key = $this
->entityBundleKey($entityType, $bundle);
$result[$key] = [
'entity' => $entityType,
'bundle' => $bundle,
];
}
}
else {
$result[$entityBundleKey] = [
'entity' => $entityType,
'bundle' => $bundle,
];
}
}
}
return $result;
}
/**
* Returns the bundles that are defined for an entity type.
*
* @param string $entityType
* The entity type to get the bundles for.
*
* @return string[]
* Array of bundle names.
*/
protected function allEntityBundles($entityType) {
if (!isset($this->entityBundles[$entityType])) {
$bundleType = $this->entityTypeManager
->getDefinition($entityType)
->getBundleEntityType();
if ($bundleType) {
$bundles = $this->entityTypeManager
->getStorage($bundleType)
->getQuery()
->execute();
}
else {
$bundles = [
$entityType => $entityType,
];
}
$this->entityBundles[$entityType] = $bundles;
}
return $this->entityBundles[$entityType];
}
/**
* Build the field name string.
*
* @param string $pluginId
* The machine name of the Extra Field plugin.
*
* @return string
* Field name.
*/
protected function fieldName($pluginId) {
return 'extra_field_' . $pluginId;
}
/**
* Creates a key string with entity type and bundle.
*
* @param string $entityType
* The entity type.
* @param string $bundle
* The bundle.
*
* @return string
* Formatted string.
*/
protected function entityBundleKey($entityType, $bundle) {
return "{$entityType}.{$bundle}";
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
DefaultPluginManager:: |
protected | property | Additional namespaces the annotation discovery mechanism should scan for annotation definitions. | |
DefaultPluginManager:: |
protected | property | Name of the alter hook if one should be invoked. | |
DefaultPluginManager:: |
protected | property | The cache key. | |
DefaultPluginManager:: |
protected | property | An array of cache tags to use for the cached definitions. | |
DefaultPluginManager:: |
protected | property | A set of defaults to be referenced by $this->processDefinition() if additional processing of plugins is necessary or helpful for development purposes. | 9 |
DefaultPluginManager:: |
protected | property | The module handler to invoke the alter hook. | 1 |
DefaultPluginManager:: |
protected | property | An object that implements \Traversable which contains the root paths keyed by the corresponding namespace to look for plugin implementations. | |
DefaultPluginManager:: |
protected | property | The name of the annotation that contains the plugin definition. | |
DefaultPluginManager:: |
protected | property | The interface each plugin should implement. | 1 |
DefaultPluginManager:: |
protected | property | The subdirectory within a namespace to look for plugins, or FALSE if the plugins are in the top level of the namespace. | |
DefaultPluginManager:: |
protected | function | Invokes the hook to alter the definitions if the alter hook is set. | 1 |
DefaultPluginManager:: |
protected | function | Sets the alter hook name. | |
DefaultPluginManager:: |
public | function |
Clears static and persistent plugin definition caches. Overrides CachedDiscoveryInterface:: |
5 |
DefaultPluginManager:: |
protected | function | Extracts the provider from a plugin definition. | |
DefaultPluginManager:: |
protected | function | Finds plugin definitions. | 7 |
DefaultPluginManager:: |
private | function | Fix the definitions of context-aware plugins. | |
DefaultPluginManager:: |
public | function |
The cache contexts associated with this object. Overrides CacheableDependencyInterface:: |
|
DefaultPluginManager:: |
protected | function | Returns the cached plugin definitions of the decorated discovery class. | |
DefaultPluginManager:: |
public | function |
The maximum age for which this object may be cached. Overrides CacheableDependencyInterface:: |
|
DefaultPluginManager:: |
public | function |
The cache tags associated with this object. Overrides CacheableDependencyInterface:: |
|
DefaultPluginManager:: |
public | function |
Gets the definition of all plugins for this type. Overrides DiscoveryTrait:: |
2 |
DefaultPluginManager:: |
protected | function |
Gets the plugin discovery. Overrides PluginManagerBase:: |
12 |
DefaultPluginManager:: |
protected | function |
Gets the plugin factory. Overrides PluginManagerBase:: |
|
DefaultPluginManager:: |
public | function | Performs extra processing on plugin definitions. | 13 |
DefaultPluginManager:: |
protected | function | Determines if the provider of a definition exists. | 3 |
DefaultPluginManager:: |
public | function | Initialize the cache backend. | |
DefaultPluginManager:: |
protected | function | Sets a cache of plugin definitions for the decorated discovery class. | |
DefaultPluginManager:: |
public | function |
Disable the use of caches. Overrides CachedDiscoveryInterface:: |
1 |
DiscoveryCachedTrait:: |
protected | property | Cached definitions array. | 1 |
DiscoveryCachedTrait:: |
public | function |
Overrides DiscoveryTrait:: |
3 |
DiscoveryTrait:: |
protected | function | Gets a specific plugin definition. | |
DiscoveryTrait:: |
public | function | ||
ExtraFieldDisplayManager:: |
protected | property | Caches bundles per entity type. | |
ExtraFieldDisplayManager:: |
protected | property | The entity type manager. | |
ExtraFieldDisplayManager:: |
protected | function | Returns the bundles that are defined for an entity type. | |
ExtraFieldDisplayManager:: |
protected | function | Creates a key string with entity type and bundle. | |
ExtraFieldDisplayManager:: |
public | function |
Appends the renderable data from ExtraField plugins to hook_entity_view(). Overrides ExtraFieldDisplayManagerInterface:: |
|
ExtraFieldDisplayManager:: |
public | function |
Exposes the ExtraFieldDisplay plugins to hook_entity_extra_field_info(). Overrides ExtraFieldDisplayManagerInterface:: |
|
ExtraFieldDisplayManager:: |
protected | function | Build the field name string. | |
ExtraFieldDisplayManager:: |
protected | function | Checks if the plugin bundle definition matches the entity bundle key. | |
ExtraFieldDisplayManager:: |
protected | function | Returns entity-bundle combinations this plugin supports. | |
ExtraFieldDisplayManager:: |
public | function |
Constructor for ExtraFieldDisplayManager objects. Overrides DefaultPluginManager:: |
|
PluginManagerBase:: |
protected | property | The object that discovers plugins managed by this manager. | |
PluginManagerBase:: |
protected | property | The object that instantiates plugins managed by this manager. | |
PluginManagerBase:: |
protected | property | The object that returns the preconfigured plugin instance appropriate for a particular runtime condition. | |
PluginManagerBase:: |
public | function |
Creates a pre-configured instance of a plugin. Overrides FactoryInterface:: |
12 |
PluginManagerBase:: |
public | function |
Gets a preconfigured instance of a plugin. Overrides MapperInterface:: |
7 |
PluginManagerBase:: |
protected | function | Allows plugin managers to specify custom behavior if a plugin is not found. | 1 |
UseCacheBackendTrait:: |
protected | property | Cache backend instance. | |
UseCacheBackendTrait:: |
protected | property | Flag whether caches should be used or skipped. | |
UseCacheBackendTrait:: |
protected | function | Fetches from the cache backend, respecting the use caches flag. | 1 |
UseCacheBackendTrait:: |
protected | function | Stores data in the persistent cache, respecting the use caches flag. |