class ShowSummaryProcessor in Facets 8
Provides a processor that shows a summary of all selected facets.
Plugin annotation
@SummaryProcessor(
id = "show_summary",
label = @Translation("Show a summary of all selected facets"),
description = @Translation("When checked, this facet will show an imploded list of all selected facets."),
stages = {
"build" = 20
}
)
Hierarchy
- class \Drupal\Component\Plugin\PluginBase implements DerivativeInspectionInterface, PluginInspectionInterface
- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait
- class \Drupal\facets_summary\Processor\ProcessorPluginBase implements ProcessorInterface
- class \Drupal\facets_summary\Plugin\facets_summary\processor\ShowSummaryProcessor implements BuildProcessorInterface
- class \Drupal\facets_summary\Processor\ProcessorPluginBase implements ProcessorInterface
- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait
Expanded class hierarchy of ShowSummaryProcessor
File
- modules/
facets_summary/ src/ Plugin/ facets_summary/ processor/ ShowSummaryProcessor.php, line 21
Namespace
Drupal\facets_summary\Plugin\facets_summary\processorView source
class ShowSummaryProcessor extends ProcessorPluginBase implements BuildProcessorInterface {
/**
* {@inheritdoc}
*/
public function build(FacetsSummaryInterface $facets_summary, array $build, array $facets) {
$facets_config = $facets_summary
->getFacets();
if (!isset($build['#items'])) {
return $build;
}
/** @var \Drupal\facets\Entity\Facet $facet */
foreach ($facets as $facet) {
if (empty($facet
->getActiveItems())) {
continue;
}
$items = $this
->getActiveDisplayValues($facet
->getResults());
$facet_summary = [
'#theme' => 'facets_summary_facet',
'#label' => $facets_config[$facet
->id()]['label'],
'#separator' => $facets_config[$facet
->id()]['separator'],
'#items' => $items,
'#facet_id' => $facet
->id(),
'#facet_admin_label' => $facet
->getName(),
];
array_unshift($build['#items'], $facet_summary);
}
return $build;
}
/**
* Get all active results' display values from hierarchy.
*
* @param \Drupal\facets\Result\ResultInterface[] $results
* The results to check for active children.
*
* @return \Drupal\facets\Result\ResultInterface[]
* The active results found.
*/
protected function getActiveDisplayValues(array $results) {
$items = [];
foreach ($results as $result) {
if ($result
->isActive()) {
$items[] = $result
->getDisplayValue();
}
if ($result
->hasActiveChildren()) {
$items = array_merge($items, $this
->getActiveDisplayValues($result
->getChildren()));
}
}
return $items;
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
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 | |
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. | |
PluginBase:: |
public | function | Constructs a \Drupal\Component\Plugin\PluginBase object. | 92 |
ProcessorInterface:: |
constant | Processing stage: build. | ||
ProcessorPluginBase:: |
public | function |
Adds a configuration form for this processor. Overrides ProcessorInterface:: |
|
ProcessorPluginBase:: |
public | function |
Calculates dependencies for the configured plugin. Overrides DependentPluginInterface:: |
|
ProcessorPluginBase:: |
public | function |
Gets default configuration for this plugin. Overrides ConfigurableInterface:: |
|
ProcessorPluginBase:: |
public | function |
Gets this plugin's configuration. Overrides ConfigurableInterface:: |
|
ProcessorPluginBase:: |
public | function |
Returns the default weight for a specific processing stage. Overrides ProcessorInterface:: |
|
ProcessorPluginBase:: |
public | function |
Retrieves the processor description. Overrides ProcessorInterface:: |
|
ProcessorPluginBase:: |
public | function |
Determines whether this processor should be hidden from the user. Overrides ProcessorInterface:: |
|
ProcessorPluginBase:: |
public | function |
Determines whether this processor should always be enabled. Overrides ProcessorInterface:: |
|
ProcessorPluginBase:: |
public | function |
Sets the configuration for this plugin instance. Overrides ConfigurableInterface:: |
|
ProcessorPluginBase:: |
public | function |
Submits a configuration form for this processor. Overrides ProcessorInterface:: |
|
ProcessorPluginBase:: |
public | function |
Checks whether this processor implements a particular stage. Overrides ProcessorInterface:: |
|
ProcessorPluginBase:: |
public | function |
Validates a configuration form for this processor. Overrides ProcessorInterface:: |
|
ShowSummaryProcessor:: |
public | function |
Alter the items in the summary before creating the renderable array. Overrides BuildProcessorInterface:: |
|
ShowSummaryProcessor:: |
protected | function | Get all active results' display values from hierarchy. | |
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. |