EntityAutocompleteMatcher.php in Open Social 8.8
Same filename and directory in other branches
- 8.9 modules/social_features/social_core/src/Entity/EntityAutocompleteMatcher.php
- 8 modules/social_features/social_core/src/Entity/EntityAutocompleteMatcher.php
- 8.2 modules/social_features/social_core/src/Entity/EntityAutocompleteMatcher.php
- 8.3 modules/social_features/social_core/src/Entity/EntityAutocompleteMatcher.php
- 8.4 modules/social_features/social_core/src/Entity/EntityAutocompleteMatcher.php
- 8.5 modules/social_features/social_core/src/Entity/EntityAutocompleteMatcher.php
- 8.6 modules/social_features/social_core/src/Entity/EntityAutocompleteMatcher.php
- 8.7 modules/social_features/social_core/src/Entity/EntityAutocompleteMatcher.php
- 10.3.x modules/social_features/social_core/src/Entity/EntityAutocompleteMatcher.php
- 10.0.x modules/social_features/social_core/src/Entity/EntityAutocompleteMatcher.php
- 10.1.x modules/social_features/social_core/src/Entity/EntityAutocompleteMatcher.php
- 10.2.x modules/social_features/social_core/src/Entity/EntityAutocompleteMatcher.php
Namespace
Drupal\social_core\EntityFile
modules/social_features/social_core/src/Entity/EntityAutocompleteMatcher.phpView source
<?php
namespace Drupal\social_core\Entity;
use Drupal\Core\Entity\EntityAutocompleteMatcher as EntityAutocompleteMatcherBase;
use Drupal\Component\Utility\Tags;
use Drupal\Component\Utility\Html;
/**
* Class EntityAutocompleteMatcher.
*
* @package Drupal\social_core\Entity
*/
class EntityAutocompleteMatcher extends EntityAutocompleteMatcherBase {
/**
* {@inheritdoc}
*/
public function getMatches($target_type, $selection_handler, $selection_settings, $string = '') {
$matches = [];
$options = [
'target_type' => $target_type,
'handler' => $selection_handler,
'handler_settings' => $selection_settings,
];
$handler = $this->selectionManager
->getInstance($options);
if (isset($string)) {
// Get an array of matching entities.
$match_operator = !empty($selection_settings['match_operator']) ? $selection_settings['match_operator'] : 'CONTAINS';
$entity_labels = $handler
->getReferenceableEntities($string, $match_operator, 10);
// Loop through the entities and convert them into autocomplete output.
foreach ($entity_labels as $values) {
foreach ($values as $entity_id => $label) {
// Skip certain entity_id's that are already a member or a enrollee.
// We can just add this to our render arrays from now on.
// '#selection_settings' => [ 'skip_entity' => ['7', '8', '9'] ].
if (!empty($selection_settings['skip_entity']) && in_array($entity_id, $selection_settings['skip_entity'], FALSE)) {
continue;
}
$key = !empty($selection_settings['hide_id']) ? $label : "{$label} ({$entity_id})";
// Strip things like starting/trailing white spaces, line breaks and
// tags.
$key = preg_replace('/\\s\\s+/', ' ', str_replace("\n", '', trim(Html::decodeEntities(strip_tags($key)))));
// Names containing commas or quotes must be wrapped in quotes.
$key = Tags::encode($key);
$matches[] = [
'value' => $key,
'label' => $label,
];
}
}
}
return $matches;
}
}
Classes
Name | Description |
---|---|
EntityAutocompleteMatcher | Class EntityAutocompleteMatcher. |