public function EntityField::calculateDependencies in Drupal 9
Same name and namespace in other branches
- 8 core/modules/views/src/Plugin/views/field/EntityField.php \Drupal\views\Plugin\views\field\EntityField::calculateDependencies()
Calculates dependencies for the configured plugin.
Dependencies are saved in the plugin's configuration entity and are used to determine configuration synchronization order. For example, if the plugin integrates with specific user roles, this method should return an array of dependencies listing the specified roles.
Return value
array An array of dependencies grouped by type (config, content, module, theme). For example:
array(
'config' => array(
'user.role.anonymous',
'user.role.authenticated',
),
'content' => array(
'node:article:f0a189e6-55fb-47fb-8005-5bef81c44d6d',
),
'module' => array(
'node',
'user',
),
'theme' => array(
'seven',
),
);
Overrides HandlerBase::calculateDependencies
See also
\Drupal\Core\Config\Entity\ConfigDependencyManager
\Drupal\Core\Entity\EntityInterface::getConfigDependencyName()
1 call to EntityField::calculateDependencies()
- EntityField::onDependencyRemoval in core/
modules/ views/ src/ Plugin/ views/ field/ EntityField.php - Allows a plugin to define whether it should be removed.
File
- core/
modules/ views/ src/ Plugin/ views/ field/ EntityField.php, line 1008
Class
- EntityField
- A field that displays entity field data.
Namespace
Drupal\views\Plugin\views\fieldCode
public function calculateDependencies() {
$this->dependencies = parent::calculateDependencies();
// Add the module providing the configured field storage as a dependency.
if (($field_storage_definition = $this
->getFieldStorageDefinition()) && $field_storage_definition instanceof EntityInterface) {
$this->dependencies['config'][] = $field_storage_definition
->getConfigDependencyName();
}
if (!empty($this->options['type'])) {
// Add the module providing the formatter.
$this->dependencies['module'][] = $this->formatterPluginManager
->getDefinition($this->options['type'])['provider'];
// Add the formatter's dependencies.
if (($formatter = $this
->getFormatterInstance()) && $formatter instanceof DependentPluginInterface) {
$this
->calculatePluginDependencies($formatter);
}
}
return $this->dependencies;
}