class ExtraFieldDisplayManager in Extra Field 8.2
Same name and namespace in other branches
- 8 src/Plugin/ExtraFieldDisplayManager.php \Drupal\extra_field\Plugin\ExtraFieldDisplayManager
Manages Extra Field display 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\ExtraFieldManagerBase implements ExtraFieldManagerBaseInterface
- class \Drupal\extra_field\Plugin\ExtraFieldDisplayManager implements ExtraFieldDisplayManagerInterface
- class \Drupal\extra_field\Plugin\ExtraFieldManagerBase implements ExtraFieldManagerBaseInterface
- 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 16
Namespace
Drupal\extra_field\PluginView source
class ExtraFieldDisplayManager extends ExtraFieldManagerBase implements ExtraFieldDisplayManagerInterface {
/**
* The plugin's subdirectory.
*/
const PLUGIN_SUBDIR = 'Plugin/ExtraField/Display';
/**
* The interface each plugin should implement.
*/
const PLUGIN_INTERFACE = 'Drupal\\extra_field\\Plugin\\ExtraFieldDisplayInterface';
/**
* The name of the annotation that contains the plugin definition.
*/
const PLUGIN_ANNOTATION_NAME = 'Drupal\\extra_field\\Annotation\\ExtraFieldDisplay';
/**
* Name of the alter hook for the plugins.
*/
const ALTER_HOOK = 'extra_field_display_info';
/**
* Name of the cache key for plugin data.
*/
const CACHE_KEY = 'extra_field_display_plugins';
/**
* The entity type manager.
*
* @var \Drupal\Core\Entity\EntityTypeManagerInterface
*/
protected $entityTypeManager;
/**
* Constructor for ExtraFieldManager 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(self::PLUGIN_SUBDIR, $namespaces, $module_handler, self::PLUGIN_INTERFACE, self::PLUGIN_ANNOTATION_NAME);
$this
->alterInfo(self::ALTER_HOOK);
$this
->setCacheBackend($cache_backend, self::CACHE_KEY);
$this->entityTypeManager = $entity_type_manager;
}
/**
* {@inheritdoc}
*/
public function fieldInfo() {
$info = [];
$definitions = $this
->getDefinitions();
foreach ($definitions as $pluginId => $definition) {
$entityBundles = $this
->supportedEntityBundles($definition['bundles']);
foreach ($entityBundles as $entityBundle) {
$entityType = $entityBundle['entity'];
$bundle = $entityBundle['bundle'];
$fieldName = $this
->fieldName($pluginId);
$info[$entityType][$bundle]['display'][$fieldName] = [
'label' => $definition['label'],
'description' => isset($definition['description']) ? $definition['description'] : '',
'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)) {
continue;
}
$factory = $this
->getFactory();
if (!$display
->getComponent($this
->fieldName($pluginId))) {
continue;
}
/** @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)) {
continue;
}
$build[$fieldName] = $elements;
}
}
/**
* {@inheritdoc}
*/
protected function getEntityTypeManager() {
return $this->entityTypeManager;
}
}
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 | The entity type manager. | |
ExtraFieldDisplayManager:: |
constant | Name of the alter hook for the plugins. | ||
ExtraFieldDisplayManager:: |
constant | Name of the cache key for plugin data. | ||
ExtraFieldDisplayManager:: |
public | function |
Appends the renderable data from ExtraField plugins to hook_entity_view(). Overrides ExtraFieldDisplayManagerInterface:: |
|
ExtraFieldDisplayManager:: |
public | function |
Exposes the ExtraField plugins to hook_entity_extra_field_info(). Overrides ExtraFieldManagerBase:: |
|
ExtraFieldDisplayManager:: |
protected | function |
Returns the entity type manager. Overrides ExtraFieldManagerBase:: |
|
ExtraFieldDisplayManager:: |
constant | The name of the annotation that contains the plugin definition. | ||
ExtraFieldDisplayManager:: |
constant | The interface each plugin should implement. | ||
ExtraFieldDisplayManager:: |
constant | The plugin's subdirectory. | ||
ExtraFieldDisplayManager:: |
public | function |
Constructor for ExtraFieldManager objects. Overrides DefaultPluginManager:: |
|
ExtraFieldManagerBase:: |
protected | property | Caches bundles per entity type. | |
ExtraFieldManagerBase:: |
protected | function | Returns the bundles that are defined for an entity type. | |
ExtraFieldManagerBase:: |
public | function | Clear the service's local cache. | |
ExtraFieldManagerBase:: |
protected | function | Creates a key string with entity type and bundle. | |
ExtraFieldManagerBase:: |
protected | function | Build the field name string. | |
ExtraFieldManagerBase:: |
protected | function | Returns all bundles of an entity type. | |
ExtraFieldManagerBase:: |
protected | function | Returns the name of the entity type which provides bundles. | |
ExtraFieldManagerBase:: |
protected | function | Checks if the plugin bundle definition matches the entity bundle key. | |
ExtraFieldManagerBase:: |
protected | function | Returns entity-bundle combinations this plugin supports. | |
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. |