IndexTidDepthModifier.php in Views (for Drupal 7) 8.3
Definition of Views\taxonomy\Plugin\views\argument\IndexTidDepthModifier.
Namespace
Views\taxonomy\Plugin\views\argumentFile
lib/Views/taxonomy/Plugin/views/argument/IndexTidDepthModifier.phpView source
<?php
/**
* @file
* Definition of Views\taxonomy\Plugin\views\argument\IndexTidDepthModifier.
*/
namespace Views\taxonomy\Plugin\views\argument;
use Drupal\views\Plugin\views\argument\ArgumentPluginBase;
use Drupal\Core\Annotation\Plugin;
/**
* Argument handler for to modify depth for a previous term.
*
* This handler is actually part of the node table and has some restrictions,
* because it uses a subquery to find nodes with.
*
* @ingroup views_argument_handlers
*
* @Plugin(
* id = "taxonomy_index_tid_depth_modifier",
* module = "taxonomy"
* )
*/
class IndexTidDepthModifier extends ArgumentPluginBase {
public function buildOptionsForm(&$form, &$form_state) {
}
public function query($group_by = FALSE) {
}
public function preQuery() {
// We don't know our argument yet, but it's based upon our position:
$argument = isset($this->view->args[$this->position]) ? $this->view->args[$this->position] : NULL;
if (!is_numeric($argument)) {
return;
}
if ($argument > 10) {
$argument = 10;
}
if ($argument < -10) {
$argument = -10;
}
// figure out which argument preceded us.
$keys = array_reverse(array_keys($this->view->argument));
$skip = TRUE;
foreach ($keys as $key) {
if ($key == $this->options['id']) {
$skip = FALSE;
continue;
}
if ($skip) {
continue;
}
if (empty($this->view->argument[$key])) {
continue;
}
if (isset($handler)) {
unset($handler);
}
$handler =& $this->view->argument[$key];
if (empty($handler->definition['accept depth modifier'])) {
continue;
}
// Finally!
$handler->options['depth'] = $argument;
}
}
}
Classes
Name | Description |
---|---|
IndexTidDepthModifier | Argument handler for to modify depth for a previous term. |