public function MarkerDefault::renderGroupingSets in Leaflet 2.1.x
Same name and namespace in other branches
- 8 modules/leaflet_views/src/Plugin/views/style/MarkerDefault.php \Drupal\leaflet_views\Plugin\views\style\MarkerDefault::renderGroupingSets()
- 2.0.x modules/leaflet_views/src/Plugin/views/style/MarkerDefault.php \Drupal\leaflet_views\Plugin\views\style\MarkerDefault::renderGroupingSets()
Render the grouping sets.
Plugins may override this method if they wish some other way of handling grouping.
Parameters
$sets: An array keyed by group content containing the grouping sets to render. Each set contains the following associative array:
- group: The group content.
- level: The hierarchical level of the grouping.
- rows: The result rows to be rendered in this group..
Return value
array Render array of grouping sets.
Overrides StylePluginBase::renderGroupingSets
File
- modules/
leaflet_views/ src/ Plugin/ views/ style/ MarkerDefault.php, line 102
Class
- MarkerDefault
- Style plugin to render leaflet markers.
Namespace
Drupal\leaflet_views\Plugin\views\styleCode
public function renderGroupingSets($sets, $level = 0) {
$output = [];
foreach ($sets as $set) {
if ($this
->usesRowPlugin()) {
foreach ($set['rows'] as $index => $row) {
$this->view->row_index = $index;
$set['rows'][$index] = $this->view->rowPlugin
->render($row);
$this
->alterLeafletMarkerPoints($set['rows'][$index], $row);
if (!$set['rows'][$index]) {
unset($set['rows'][$index]);
}
}
}
$set['features'] = [];
foreach ($set['rows'] as $group) {
$set['features'] = array_merge($set['features'], $group);
}
// Abort if we haven't managed to build any features.
if (empty($set['features'])) {
continue;
}
if ($feature_group = $this
->renderLeafletGroup($set['group'], $level, $set['features'])) {
// Allow modules to adjust the feature group.
$this->moduleHandler
->alter('leaflet_views_feature_group', $feature_group, $this);
// If the rendered "feature group" is actually only a list of features,
// merge them into the output; else simply append the feature group.
if (empty($feature_group['group'])) {
$output = array_merge($output, $feature_group['features']);
}
else {
$output[] = $feature_group;
}
}
}
unset($this->view->row_index);
return $output;
}