class Grouping in Search API Grouping 8
Processor for grouping up items on behalf of user defined fields.
(see https://issues.apache.org/jira/browse/SOLR-10894 and https://mail-archives.apache.org/mod_mbox/lucene-solr-user/201805.mbox/%...)
Plugin annotation
@SearchApiProcessor(
id = "grouping",
label = @Translation("Grouping"),
description = @Translation("This processor will group the result items based on the configured fields"),
stages = {
"add_properties" = 0,
"postprocess_query" = 0,
"preprocess_query" = -6,
},
)
Hierarchy
- class \Drupal\Component\Plugin\PluginBase implements DerivativeInspectionInterface, PluginInspectionInterface
- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait
- class \Drupal\search_api\Plugin\HideablePluginBase implements HideablePluginInterface
- class \Drupal\search_api\Plugin\ConfigurablePluginBase implements ConfigurablePluginInterface uses PluginDependencyTrait
- class \Drupal\search_api\Plugin\IndexPluginBase implements IndexPluginInterface
- class \Drupal\search_api\Processor\ProcessorPluginBase implements ProcessorInterface
- class \Drupal\search_api\Processor\FieldsProcessorPluginBase implements PluginFormInterface, TrustedCallbackInterface uses PluginFormTrait
- class \Drupal\search_api_grouping\Plugin\search_api\processor\Grouping implements PluginFormInterface
- class \Drupal\search_api\Processor\FieldsProcessorPluginBase implements PluginFormInterface, TrustedCallbackInterface uses PluginFormTrait
- class \Drupal\search_api\Processor\ProcessorPluginBase implements ProcessorInterface
- class \Drupal\search_api\Plugin\IndexPluginBase implements IndexPluginInterface
- class \Drupal\search_api\Plugin\ConfigurablePluginBase implements ConfigurablePluginInterface uses PluginDependencyTrait
- class \Drupal\search_api\Plugin\HideablePluginBase implements HideablePluginInterface
- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait
Expanded class hierarchy of Grouping
4 files declare their use of Grouping
- GroupingBuildFormTest.php in tests/
src/ Unit/ GroupingBuildFormTest.php - GroupingSolrTest.php in tests/
src/ Unit/ GroupingSolrTest.php - GroupLimitValidationTest.php in tests/
src/ Unit/ GroupLimitValidationTest.php - SupportedGroupingFieldsTest.php in tests/
src/ Unit/ SupportedGroupingFieldsTest.php
File
- src/
Plugin/ search_api/ processor/ Grouping.php, line 27
Namespace
Drupal\search_api_grouping\Plugin\search_api\processorView source
class Grouping extends FieldsProcessorPluginBase implements PluginFormInterface {
/**
* {@inheritdoc}
*/
public function defaultConfiguration() {
$configuration = parent::defaultConfiguration();
$configuration += [
'grouping_fields' => [],
'group_sort' => [],
'group_sort_direction' => 'asc',
'truncate' => FALSE,
'group_limit' => 1,
];
return $configuration;
}
/**
* {@inheritdoc}
*/
public function submitConfigurationForm(array &$form, FormStateInterface $form_state) {
$grouping_fields =& $form_state
->getValue('grouping_fields');
$grouping_fields = array_keys(array_filter($grouping_fields));
$this
->setConfiguration($form_state
->getValues());
}
/**
* Return the settings form for this processor.
*/
public function buildConfigurationForm(array $form, FormStateInterface $form_state) {
$supported_fields = $this
->getSupportedFields();
$form['grouping_fields'] = [
'#type' => 'checkboxes',
'#title' => $this
->t('Fields to collapse on'),
'#options' => $supported_fields['field_options'],
'#attributes' => [
'class' => [
'search-api-checkboxes-list',
],
],
'#description' => $this
->t('Choose the fields upon which to collapse the results into groups. Note that while selecting multiple fields is technicially supported, it may result in unexpected behaviour.'),
'#default_value' => $this->configuration['grouping_fields'],
];
$form['group_sort'] = [
'#type' => 'select',
'#title' => $this
->t('Group sort'),
'#options' => $supported_fields['field_sorts'],
'#description' => $this
->t('Choose the field by to sort within each group, the groups themselves will be sorted by the main query sorts.'),
'#default_value' => $this->configuration['group_sort'],
];
$form['group_sort_direction'] = [
'#type' => 'select',
'#title' => $this
->t('Group sort direction'),
'#options' => [
'asc' => $this
->t('Ascending'),
'desc' => $this
->t('Descending'),
],
'#default_value' => $this->configuration['group_sort_direction'],
];
$form['truncate'] = [
'#type' => 'checkbox',
'#title' => $this
->t('Truncate results before facets'),
'#description' => $this
->t('If checked, facet counts are based on the most relevant document of each group matching the query, otherwise they are calculated for all documents before grouping.'),
'#default_value' => $this->configuration['truncate'],
];
$form['group_limit'] = [
'#type' => 'textfield',
'#title' => $this
->t('Results per group'),
'#description' => $this
->t('The number of results are limited per group. By default, 1 result per group is returned.'),
'#default_value' => $this->configuration['group_limit'],
'#element_validate' => [
'element_validate_integer_positive',
],
'#size' => 3,
];
return $form;
}
/**
* Returns an array of supported fields to choose of.
*
* This function respects the server behind the index to provide only valid
* fields.
*
* @return array
* An associative array with child arrays for the supported fields for each
* feature:
* [
* 'field_options' => [],
* 'field_sorts' => [],
* 'field' => [],
* ];
*/
public function getSupportedFields() {
$fields = $this->index
->getFields();
$supported_fields = [
'field_options' => [],
'field_sorts' => [
'' => $this
->t('None'),
'search_api_relevance' => $this
->t('Score/Relevance'),
],
'default_fields' => [],
];
foreach ($fields as $name => $field) {
if ($field
->getType() == 'string' || $field
->getType() == 'integer') {
$conversion_msg = $field
->getType() != 'string' ? ' (' . $this
->t('Converted to string for indexing') . ')' : NULL;
$supported_fields['field_options'][$name] = $field
->getLabel() . $conversion_msg;
if (!empty($default_fields[$name]) || !isset($this->configuration['grouping_fields']) && $this
->testField($name, $field)) {
$supported_fields['default_fields'][$name] = $name;
}
$supported_fields['field_sorts'][$name] = $field
->getLabel();
}
}
return $supported_fields;
}
/**
* {@inheritdoc}
*/
public function preprocessSearchQuery(QueryInterface $query) {
$grouping_fields = $this
->getGroupingFields();
if (!empty($grouping_fields)) {
// We move the options from our options array into where the Solr Service
// is expecting them.
$options = [
'use_grouping' => TRUE,
'grouping_fields' => $grouping_fields,
'truncate' => isset($this->configuration['truncate']) ? $this->configuration['truncate'] : TRUE,
'group_limit' => isset($this->configuration['group_limit']) ? $this->configuration['group_limit'] : NULL,
'group_sort' => [],
];
if (!empty($this->configuration['group_sort'])) {
$options['group_sort'][$this->configuration['group_sort']] = isset($this->configuration['group_sort_direction']) ? $this->configuration['group_sort_direction'] : 'asc';
}
$query
->setOption('search_api_grouping', $options);
}
}
/**
* Returns the fields to group on.
*
* @return array
* The list of fields to use for grouping.
*/
public function getGroupingFields() {
$fields = $this->configuration['grouping_fields'];
foreach ($fields as $key => $field) {
if ($field === 0) {
unset($fields[$key]);
}
}
return $fields;
}
/**
* Form validation handler.
*
* @param array $form
* An associative array containing the structure of the plugin form as built
* by static::buildConfigurationForm().
* @param \Drupal\Core\Form\FormStateInterface $form_state
* The current state of the form. Calling code should pass on a subform
* state created through
* \Drupal\Core\Form\SubformState::createForSubform().
*/
public function validateConfigurationForm(array &$form, FormStateInterface $form_state) {
$results_per_group = $form['group_limit']['#value'];
if (!ctype_digit($results_per_group)) {
$title = $form["group_limit"]["#title"];
$form_state
->setError($form["group_limit"], sprintf('%s must be numeric', $title));
}
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
ConfigurablePluginBase:: |
public | function |
Calculates dependencies for the configured plugin. Overrides DependentPluginInterface:: |
6 |
ConfigurablePluginBase:: |
protected | function | Calculates and adds dependencies of a specific plugin instance. | |
ConfigurablePluginBase:: |
public | function |
Gets this plugin's configuration. Overrides ConfigurableInterface:: |
|
ConfigurablePluginBase:: |
public | function |
Returns the plugin's description. Overrides ConfigurablePluginInterface:: |
|
ConfigurablePluginBase:: |
protected | function | Calculates and returns dependencies of a specific plugin instance. | |
ConfigurablePluginBase:: |
public | function |
Returns the label for use on the administration pages. Overrides ConfigurablePluginInterface:: |
|
ConfigurablePluginBase:: |
protected | function | Wraps the module handler. | |
ConfigurablePluginBase:: |
public | function |
Informs the plugin that some of its dependencies are being removed. Overrides ConfigurablePluginInterface:: |
5 |
ConfigurablePluginBase:: |
public | function |
Sets the configuration for this plugin instance. Overrides ConfigurableInterface:: |
3 |
ConfigurablePluginBase:: |
protected | function | Wraps the theme handler. | |
DependencySerializationTrait:: |
protected | property | An array of entity type IDs keyed by the property name of their storages. | |
DependencySerializationTrait:: |
protected | property | An array of service IDs keyed by property name used for serialization. | |
DependencySerializationTrait:: |
public | function | 1 | |
DependencySerializationTrait:: |
public | function | 2 | |
DependencyTrait:: |
protected | property | The object's dependencies. | |
DependencyTrait:: |
protected | function | Adds multiple dependencies. | |
DependencyTrait:: |
protected | function | Adds a dependency. | |
FieldsProcessorPluginBase:: |
protected | property | The data type helper. | 1 |
FieldsProcessorPluginBase:: |
protected | property | The element info manager. | |
FieldsProcessorPluginBase:: |
public static | function |
Creates an instance of the plugin. Overrides ProcessorPluginBase:: |
1 |
FieldsProcessorPluginBase:: |
public | function | Retrieves the data type helper. | 1 |
FieldsProcessorPluginBase:: |
public | function | Retrieves the element info manager. | |
FieldsProcessorPluginBase:: |
public | function |
Preprocesses the search index entity before it is saved. Overrides ProcessorPluginBase:: |
|
FieldsProcessorPluginBase:: |
public | function |
Preprocesses search items for indexing. Overrides ProcessorPluginBase:: |
1 |
FieldsProcessorPluginBase:: |
public static | function | Preprocesses the "fields" checkboxes before rendering. | |
FieldsProcessorPluginBase:: |
protected | function | Processes a single string value. | 8 |
FieldsProcessorPluginBase:: |
protected | function | Preprocesses the query conditions. | |
FieldsProcessorPluginBase:: |
protected | function | Processes a single condition value. | 1 |
FieldsProcessorPluginBase:: |
protected | function | Processes a single field's value. | 3 |
FieldsProcessorPluginBase:: |
protected | function | Processes a single text element in a field. | 3 |
FieldsProcessorPluginBase:: |
protected | function | Processes a single search keyword. | 1 |
FieldsProcessorPluginBase:: |
protected | function | Preprocesses the search keywords. | |
FieldsProcessorPluginBase:: |
public | function | Sets the data type helper. | 1 |
FieldsProcessorPluginBase:: |
public | function | Sets the element info manager. | |
FieldsProcessorPluginBase:: |
protected | function | Determines whether a single value (not an array) should be processed. | 1 |
FieldsProcessorPluginBase:: |
protected | function | Tests whether a certain field should be processed. | 1 |
FieldsProcessorPluginBase:: |
protected | function | Determines whether a field of a certain type should be preprocessed. | 4 |
FieldsProcessorPluginBase:: |
public static | function |
Lists the trusted callbacks provided by the implementing class. Overrides TrustedCallbackInterface:: |
|
Grouping:: |
public | function |
Return the settings form for this processor. Overrides FieldsProcessorPluginBase:: |
|
Grouping:: |
public | function |
Gets default configuration for this plugin. Overrides FieldsProcessorPluginBase:: |
|
Grouping:: |
public | function | Returns the fields to group on. | |
Grouping:: |
public | function | Returns an array of supported fields to choose of. | |
Grouping:: |
public | function |
Preprocesses a search query. Overrides FieldsProcessorPluginBase:: |
|
Grouping:: |
public | function |
Form submission handler. Overrides PluginFormTrait:: |
|
Grouping:: |
public | function |
Form validation handler. Overrides FieldsProcessorPluginBase:: |
|
IndexPluginBase:: |
protected | property | The index this processor is configured for. | |
IndexPluginBase:: |
public | function |
Retrieves the index this plugin is configured for. Overrides IndexPluginInterface:: |
|
IndexPluginBase:: |
public | function |
Sets the index this plugin is configured for. Overrides IndexPluginInterface:: |
|
IndexPluginBase:: |
public | function |
Constructs a \Drupal\Component\Plugin\PluginBase object. Overrides ConfigurablePluginBase:: |
2 |
MessengerTrait:: |
protected | property | The messenger. | 29 |
MessengerTrait:: |
public | function | Gets the messenger. | 29 |
MessengerTrait:: |
public | function | Sets the messenger. | |
PluginBase:: |
protected | property | Configuration information passed into the plugin. | 1 |
PluginBase:: |
protected | property | The plugin implementation definition. | 1 |
PluginBase:: |
protected | property | The plugin_id. | |
PluginBase:: |
constant | A string which is used to separate base plugin IDs from the derivative ID. | ||
PluginBase:: |
public | function |
Gets the base_plugin_id of the plugin instance. Overrides DerivativeInspectionInterface:: |
|
PluginBase:: |
public | function |
Gets the derivative_id of the plugin instance. Overrides DerivativeInspectionInterface:: |
|
PluginBase:: |
public | function |
Gets the definition of the plugin implementation. Overrides PluginInspectionInterface:: |
3 |
PluginBase:: |
public | function |
Gets the plugin_id of the plugin instance. Overrides PluginInspectionInterface:: |
|
PluginBase:: |
public | function | Determines if the plugin is configurable. | |
PluginDependencyTrait:: |
protected | function | Calculates and adds dependencies of a specific plugin instance. Aliased as: traitCalculatePluginDependencies | 1 |
PluginDependencyTrait:: |
protected | function | Calculates and returns dependencies of a specific plugin instance. Aliased as: traitGetPluginDependencies | |
PluginDependencyTrait:: |
protected | function | Wraps the module handler. Aliased as: traitModuleHandler | 1 |
PluginDependencyTrait:: |
protected | function | Wraps the theme handler. Aliased as: traitThemeHandler | 1 |
ProcessorInterface:: |
constant | Processing stage: add properties. | ||
ProcessorInterface:: |
constant | Processing stage: alter indexed items. | ||
ProcessorInterface:: |
constant | Processing stage: postprocess query. | ||
ProcessorInterface:: |
constant | Processing stage: preprocess index. | ||
ProcessorInterface:: |
constant | Processing stage: preprocess query. | ||
ProcessorInterface:: |
constant | Processing stage: preprocess index. | ||
ProcessorPluginBase:: |
protected | property | The fields helper. | 1 |
ProcessorPluginBase:: |
public | function |
Adds the values of properties defined by this processor to the item. Overrides ProcessorInterface:: |
8 |
ProcessorPluginBase:: |
public | function |
Alter the items to be indexed. Overrides ProcessorInterface:: |
3 |
ProcessorPluginBase:: |
protected | function | Ensures that a field with certain properties is indexed on the index. | |
ProcessorPluginBase:: |
protected | function | Finds a certain field in the index. | |
ProcessorPluginBase:: |
public | function | Retrieves the fields helper. | 1 |
ProcessorPluginBase:: |
public | function |
Retrieves the properties this processor defines for the given datasource. Overrides ProcessorInterface:: |
8 |
ProcessorPluginBase:: |
public | function |
Returns the weight for a specific processing stage. Overrides ProcessorInterface:: |
|
ProcessorPluginBase:: |
public | function |
Determines whether this plugin should be hidden in the UI. Overrides HideablePluginBase:: |
|
ProcessorPluginBase:: |
public | function |
Determines whether this processor should always be enabled. Overrides ProcessorInterface:: |
|
ProcessorPluginBase:: |
public | function |
Postprocess search results before they are returned by the query. Overrides ProcessorInterface:: |
2 |
ProcessorPluginBase:: |
public | function |
Determines whether re-indexing is required after a settings change. Overrides ProcessorInterface:: |
|
ProcessorPluginBase:: |
public | function | Sets the fields helper. | 1 |
ProcessorPluginBase:: |
public | function |
Sets the weight for a specific processing stage. Overrides ProcessorInterface:: |
|
ProcessorPluginBase:: |
public static | function |
Checks whether this processor is applicable for a certain index. Overrides ProcessorInterface:: |
8 |
ProcessorPluginBase:: |
public | function |
Checks whether this processor implements a particular stage. Overrides ProcessorInterface:: |
2 |
StringTranslationTrait:: |
protected | property | The string translation service. | 1 |
StringTranslationTrait:: |
protected | function | Formats a string containing a count of items. | |
StringTranslationTrait:: |
protected | function | Returns the number of plurals supported by a given language. | |
StringTranslationTrait:: |
protected | function | Gets the string translation service. | |
StringTranslationTrait:: |
public | function | Sets the string translation service to use. | 2 |
StringTranslationTrait:: |
protected | function | Translates a string to the current language or to a given language. | |
TrustedCallbackInterface:: |
constant | Untrusted callbacks throw exceptions. | ||
TrustedCallbackInterface:: |
constant | Untrusted callbacks trigger silenced E_USER_DEPRECATION errors. | ||
TrustedCallbackInterface:: |
constant | Untrusted callbacks trigger E_USER_WARNING errors. |