public function GroupContentViewsData::getViewsData in Group 8
Same name and namespace in other branches
- 2.0.x src/Entity/Views/GroupContentViewsData.php \Drupal\group\Entity\Views\GroupContentViewsData::getViewsData()
Returns views data for the entity type.
Return value
array Views data in the format of hook_views_data().
Overrides EntityViewsData::getViewsData
File
- src/
Entity/ Views/ GroupContentViewsData.php, line 34
Class
- GroupContentViewsData
- Provides the views data for the group content entity type.
Namespace
Drupal\group\Entity\ViewsCode
public function getViewsData() {
$data = parent::getViewsData();
// Add a custom numeric argument for the parent group ID that allows us to
// use replacement titles with the parent group's label.
$data['group_content_field_data']['gid']['argument'] = [
'id' => 'group_id',
'numeric' => TRUE,
];
// Get the data table for GroupContent entities.
$data_table = $this->entityType
->getDataTable();
// Unset the 'entity_id' field relationship as we want a more powerful one.
// @todo Eventually, we may want to replace all of 'entity_id'.
unset($data[$data_table]['entity_id']['relationship']);
/** @var \Drupal\Core\Entity\EntityTypeInterface[] $entity_types */
$entity_types = $this->entityTypeManager
->getDefinitions();
// Add views data for all defined plugins so modules can provide default
// views even though their plugins may not have been installed yet.
foreach ($this->pluginManager
->getAll() as $plugin) {
$entity_type_id = $plugin
->getEntityTypeId();
if (!isset($entity_types[$entity_type_id])) {
continue;
}
$entity_type = $entity_types[$entity_type_id];
$entity_data_table = $entity_type
->getDataTable() ?: $entity_type
->getBaseTable();
// Create a unique field name for this views field.
$field_name = 'gc__' . $entity_type_id;
// We only add one 'group_content' relationship per entity type.
if (isset($data[$entity_data_table][$field_name])) {
continue;
}
$t_args = [
'@entity_type' => $entity_type
->getLabel(),
];
// This relationship will allow a group content entity to easily map to a
// content entity that it ties to a group, optionally filtering by plugin.
$data[$data_table][$field_name] = [
'title' => $this
->t('@entity_type from group content', $t_args),
'help' => $this
->t('Relates to the @entity_type entity the group content represents.', $t_args),
'relationship' => [
'group' => $entity_type
->getLabel(),
'base' => $entity_data_table,
'base field' => $entity_type
->getKey('id'),
'relationship field' => 'entity_id',
'id' => 'group_content_to_entity',
'label' => $this
->t('Group content @entity_type', $t_args),
'target_entity_type' => $entity_type_id,
],
];
}
return $data;
}