Skip to content
Snippets Groups Projects
Commit 502c857b authored by catch's avatar catch
Browse files

Issue #3408698 by lauriii, alexpott: Provide alter for the field type UI definitions

parent 1630c1a9
No related branches found
No related tags found
No related merge requests found
...@@ -226,6 +226,15 @@ public function getUiDefinitions() { ...@@ -226,6 +226,15 @@ public function getUiDefinitions() {
return $definitions; return $definitions;
} }
/**
* {@inheritdoc}
*/
public function getEntityTypeUiDefinitions(string $entity_type_id): array {
$ui_definitions = $this->getUiDefinitions();
$this->moduleHandler->alter('field_info_entity_type_ui_definitions', $ui_definitions, $entity_type_id);
return $ui_definitions;
}
/** /**
* {@inheritdoc} * {@inheritdoc}
*/ */
......
...@@ -113,6 +113,20 @@ public function getFieldSettingsSummary(FieldDefinitionInterface $field_definiti ...@@ -113,6 +113,20 @@ public function getFieldSettingsSummary(FieldDefinitionInterface $field_definiti
*/ */
public function getUiDefinitions(); public function getUiDefinitions();
/**
* Get the field type definitions that can be added via UI for an entity type.
*
* @param string $entity_type_id
* The entity type id.
*
* @return array
* An array of field type definitions.
*
* @see \Drupal\Core\Field\FieldTypePluginManagerInterface::getUiDefinitions()
* @see hook_field_info_entity_type_ui_definitions_alter()
*/
public function getEntityTypeUiDefinitions(string $entity_type_id): array;
/** /**
* Returns preconfigured field options for a field type. * Returns preconfigured field options for a field type.
* *
......
...@@ -238,23 +238,15 @@ function comment_form_field_ui_field_storage_add_form_alter(&$form, FormStateInt ...@@ -238,23 +238,15 @@ function comment_form_field_ui_field_storage_add_form_alter(&$form, FormStateInt
if ($form_state->get('entity_type_id') == 'comment' && $route_match->getParameter('commented_entity_type')) { if ($form_state->get('entity_type_id') == 'comment' && $route_match->getParameter('commented_entity_type')) {
$form['#title'] = \Drupal::service('comment.manager')->getFieldUIPageTitle($route_match->getParameter('commented_entity_type'), $route_match->getParameter('field_name')); $form['#title'] = \Drupal::service('comment.manager')->getFieldUIPageTitle($route_match->getParameter('commented_entity_type'), $route_match->getParameter('field_name'));
} }
if (!_comment_entity_uses_integer_id($form_state->get('entity_type_id'))) {
$form['add']['new_storage_type']['#process'][] = 'comment_new_storage_type_process_callback';
}
} }
/** /**
* Process callback to remove comment type field option. * Implements hook_field_info_entity_type_ui_definitions_alter().
*/ */
function comment_new_storage_type_process_callback($element, &$form_state, $form) { function comment_field_info_entity_type_ui_definitions_alter(array &$ui_definitions, string $entity_type_id) {
foreach ($element as $key => $value) { if (!_comment_entity_uses_integer_id($entity_type_id)) {
if (isset($value['radio']['#return_value']) && $value['radio']['#return_value'] === 'comment') { unset($ui_definitions['comment']);
// You cannot use comment fields on entity types with non-integer IDs.
unset($element[$key]);
}
} }
return $element;
} }
/** /**
......
...@@ -57,6 +57,26 @@ function hook_field_info_alter(&$info) { ...@@ -57,6 +57,26 @@ function hook_field_info_alter(&$info) {
} }
} }
/**
* Alters the UI field definitions.
*
* This hook can be used for altering field definitions available in the UI
* dynamically per entity type. For example, it can be used to hide field types
* that are incompatible with an entity type.
*
* @param array $ui_definitions
* Definition of all field types that can be added via UI.
* @param string $entity_type_id
* The entity type id.
*
* @see \Drupal\Core\Field\FieldTypePluginManagerInterface::getEntityTypeUiDefinitions
*/
function hook_field_info_entity_type_ui_definitions_alter(array &$ui_definitions, string $entity_type_id) {
if ($entity_type_id === 'node') {
unset($ui_definitions['field_type_not_compatible_with_node']);
}
}
/** /**
* Perform alterations on preconfigured field options. * Perform alterations on preconfigured field options.
* *
......
...@@ -15,6 +15,7 @@ ...@@ -15,6 +15,7 @@
use Drupal\Core\Entity\EntityTypeInterface; use Drupal\Core\Entity\EntityTypeInterface;
use Drupal\Core\Form\FormStateInterface; use Drupal\Core\Form\FormStateInterface;
use Drupal\Core\Render\Element; use Drupal\Core\Render\Element;
use Drupal\Core\StringTranslation\TranslatableMarkup;
use Drupal\field\FieldStorageConfigInterface; use Drupal\field\FieldStorageConfigInterface;
require_once __DIR__ . '/field_test.entity.inc'; require_once __DIR__ . '/field_test.entity.inc';
...@@ -215,3 +216,12 @@ function field_test_field_ui_preconfigured_options_alter(array &$options, $field ...@@ -215,3 +216,12 @@ function field_test_field_ui_preconfigured_options_alter(array &$options, $field
]; ];
} }
} }
/**
* Implements hook_field_info_entity_type_ui_definitions_alter().
*/
function field_test_field_info_entity_type_ui_definitions_alter(array &$ui_definitions, string $entity_type_id) {
if ($entity_type_id === 'node') {
$ui_definitions['boolean']['label'] = new TranslatableMarkup('Boolean (overridden by alter)');
}
}
...@@ -110,6 +110,18 @@ public function testMainProperty() { ...@@ -110,6 +110,18 @@ public function testMainProperty() {
} }
} }
/**
* Tests UI definitions per entity type.
*/
public function testUiDefinitionsPerEntityType() {
/** @var \Drupal\Core\Field\FieldTypePluginManagerInterface $field_type_manager */
$field_type_manager = \Drupal::service('plugin.manager.field.field_type');
$definitions = $field_type_manager->getEntityTypeUiDefinitions('node');
$this->assertEquals('Boolean (overridden by alter)', (string) $definitions['boolean']['label']);
$definitions = $field_type_manager->getEntityTypeUiDefinitions('entity_test');
$this->assertEquals('Boolean', (string) $definitions['boolean']['label']);
}
/** /**
* Enable all core modules. * Enable all core modules.
*/ */
......
...@@ -150,7 +150,7 @@ public function buildForm(array $form, FormStateInterface $form_state, $entity_t ...@@ -150,7 +150,7 @@ public function buildForm(array $form, FormStateInterface $form_state, $entity_t
]; ];
$field_type_options = $unique_definitions = []; $field_type_options = $unique_definitions = [];
$grouped_definitions = $this->fieldTypePluginManager->getGroupedDefinitions($this->fieldTypePluginManager->getUiDefinitions(), 'label', 'id'); $grouped_definitions = $this->fieldTypePluginManager->getGroupedDefinitions($this->fieldTypePluginManager->getEntityTypeUiDefinitions($this->entityTypeId), 'label', 'id');
$category_definitions = $this->fieldTypeCategoryManager->getDefinitions(); $category_definitions = $this->fieldTypeCategoryManager->getDefinitions();
// Invoke a hook to get category properties. // Invoke a hook to get category properties.
foreach ($grouped_definitions as $category => $field_types) { foreach ($grouped_definitions as $category => $field_types) {
......
...@@ -345,4 +345,15 @@ public function testFieldTypeCardinalityAlter() { ...@@ -345,4 +345,15 @@ public function testFieldTypeCardinalityAlter() {
$this->assertSession()->elementTextContains('css', '#edit-field-storage', 'Greetings from Drupal\field_test\Plugin\Field\FieldType\TestItem::storageSettingsForm'); $this->assertSession()->elementTextContains('css', '#edit-field-storage', 'Greetings from Drupal\field_test\Plugin\Field\FieldType\TestItem::storageSettingsForm');
} }
/**
* Tests hook_field_info_entity_type_ui_definitions_alter().
*/
public function testFieldUiDefinitionsAlter() {
$user = $this->drupalCreateUser(['administer node fields']);
$node_type = $this->drupalCreateContentType();
$this->drupalLogin($user);
$this->drupalGet('/admin/structure/types/manage/' . $node_type->id() . '/fields/add-field');
$this->assertSession()->pageTextContains('Boolean (overridden by alter)');
}
} }
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment