class ViewsEntityRow in Zircon Profile 8
Same name and namespace in other branches
- 8.0 core/modules/views/src/Plugin/Derivative/ViewsEntityRow.php \Drupal\views\Plugin\Derivative\ViewsEntityRow
Provides views row plugin definitions for all non-special entity types.
Hierarchy
- class \Drupal\views\Plugin\Derivative\ViewsEntityRow implements ContainerDeriverInterface
Expanded class hierarchy of ViewsEntityRow
See also
\Drupal\views\Plugin\views\row\EntityRow
Related topics
File
- core/
modules/ views/ src/ Plugin/ Derivative/ ViewsEntityRow.php, line 22 - Contains \Drupal\views\Plugin\Derivative\ViewsEntityRow.
Namespace
Drupal\views\Plugin\DerivativeView source
class ViewsEntityRow implements ContainerDeriverInterface {
/**
* Stores all entity row plugin information.
*
* @var array
*/
protected $derivatives = array();
/**
* The base plugin ID that the derivative is for.
*
* @var string
*/
protected $basePluginId;
/**
* The entity manager.
*
* @var \Drupal\Core\Entity\EntityManagerInterface
*/
protected $entityManager;
/**
* The views data service.
*
* @var \Drupal\views\ViewsData
*/
protected $viewsData;
/**
* Constructs a ViewsEntityRow object.
*
* @param string $base_plugin_id
* The base plugin ID.
* @param \Drupal\Core\Entity\EntityManagerInterface $entity_manager
* The entity manager.
* @param \Drupal\views\ViewsData $views_data
* The views data service.
*/
public function __construct($base_plugin_id, EntityManagerInterface $entity_manager, ViewsData $views_data) {
$this->basePluginId = $base_plugin_id;
$this->entityManager = $entity_manager;
$this->viewsData = $views_data;
}
/**
* {@inheritdoc}
*/
public static function create(ContainerInterface $container, $base_plugin_id) {
return new static($base_plugin_id, $container
->get('entity.manager'), $container
->get('views.views_data'));
}
/**
* {@inheritdoc}
*/
public function getDerivativeDefinition($derivative_id, $base_plugin_definition) {
if (!empty($this->derivatives) && !empty($this->derivatives[$derivative_id])) {
return $this->derivatives[$derivative_id];
}
$this
->getDerivativeDefinitions($base_plugin_definition);
return $this->derivatives[$derivative_id];
}
/**
* {@inheritdoc}
*/
public function getDerivativeDefinitions($base_plugin_definition) {
foreach ($this->entityManager
->getDefinitions() as $entity_type_id => $entity_type) {
// Just add support for entity types which have a views integration.
if (($base_table = $entity_type
->getBaseTable()) && $this->viewsData
->get($base_table) && $this->entityManager
->hasHandler($entity_type_id, 'view_builder')) {
$this->derivatives[$entity_type_id] = array(
'id' => 'entity:' . $entity_type_id,
'provider' => 'views',
'title' => $entity_type
->getLabel(),
'help' => t('Display the @label', array(
'@label' => $entity_type
->getLabel(),
)),
'base' => array(
$entity_type
->getDataTable() ?: $entity_type
->getBaseTable(),
),
'entity_type' => $entity_type_id,
'display_types' => array(
'normal',
),
'class' => $base_plugin_definition['class'],
);
}
}
return $this->derivatives;
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
ViewsEntityRow:: |
protected | property | The base plugin ID that the derivative is for. | |
ViewsEntityRow:: |
protected | property | Stores all entity row plugin information. | |
ViewsEntityRow:: |
protected | property | The entity manager. | |
ViewsEntityRow:: |
protected | property | The views data service. | |
ViewsEntityRow:: |
public static | function |
Creates a new class instance. Overrides ContainerDeriverInterface:: |
|
ViewsEntityRow:: |
public | function |
Gets the definition of a derivative plugin. Overrides DeriverInterface:: |
|
ViewsEntityRow:: |
public | function |
Gets the definition of all derivatives of a base plugin. Overrides DeriverInterface:: |
|
ViewsEntityRow:: |
public | function | Constructs a ViewsEntityRow object. |