class EntityReference in Conditional Fields 8
Same name and namespace in other branches
- 4.x src/Plugin/conditional_fields/handler/EntityReference.php \Drupal\conditional_fields\Plugin\conditional_fields\handler\EntityReference
Provides states handler for entity reference fields.
Plugin annotation
@ConditionalFieldsHandler(
id = "states_handler_entity_reference_autocomplete",
)
Hierarchy
- class \Drupal\conditional_fields\ConditionalFieldsHandlerBase implements ConditionalFieldsHandlersPluginInterface
- class \Drupal\conditional_fields\Plugin\conditional_fields\handler\EntityReference
Expanded class hierarchy of EntityReference
File
- src/
Plugin/ conditional_fields/ handler/ EntityReference.php, line 16
Namespace
Drupal\conditional_fields\Plugin\conditional_fields\handlerView source
class EntityReference extends ConditionalFieldsHandlerBase {
/**
* {@inheritdoc}
*/
public function statesHandler($field, $field_info, $options) {
$state = [];
$values_set = $options['values_set'];
switch ($values_set) {
case ConditionalFieldsInterface::CONDITIONAL_FIELDS_DEPENDENCY_VALUES_WIDGET:
$value_form = $this
->getWidgetValue($options['value_form']);
if (empty($value_form)) {
break;
}
if ($options['field_cardinality'] == 1) {
$node = Node::load($value_form[0]['target_id']);
if ($node instanceof Node) {
// Create an array of valid formats of title for autocomplete.
$state[$options['state']][$options['selector']] = $this
->getAutocompleteSuggestions($node);
}
}
else {
$ids = array_column($value_form, 'target_id');
$nodes = Node::loadMultiple($ids);
if (!empty($nodes)) {
foreach (array_values($nodes) as $key => $node) {
$selector = str_replace('[0]', "[{$key}]", $options['selector']);
$state[$options['state']][$selector] = $this
->getAutocompleteSuggestions($node);
}
}
}
break;
default:
break;
}
return $state;
}
/**
* Get a variants of node title for autocomplete.
*
* @param $node
* A node object.
* @return array
* An array with a few relevant suggestions for autocomplete.
*/
private function getAutocompleteSuggestions($node) {
/** @var Node $node */
return [
// Node title (nid).
[
'value' => $node
->label() . ' (' . $node
->id() . ')',
],
// Node title.
[
'value' => $node
->label(),
],
];
}
/**
* Get values from widget settings for plugin.
*
* @param array $value_form
* Dependency options.
*
* @return mixed
* Values for triggering events.
*/
public function getWidgetValue(array $value_form) {
return $value_form;
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
ConditionalFieldsHandlerBase:: |
public | function |
Get values form the condition options Overrides ConditionalFieldsHandlersPluginInterface:: |
|
EntityReference:: |
private | function | Get a variants of node title for autocomplete. | |
EntityReference:: |
public | function |
Get values from widget settings for plugin. Overrides ConditionalFieldsHandlerBase:: |
|
EntityReference:: |
public | function |
Executes states handler according to conditional fields settings. Overrides ConditionalFieldsHandlersPluginInterface:: |