Вывод контента у термина и всех его дочерних терминов
Есть древовидный словарь таксономии. Нужно на странице catalog/%
вывести контент у термина указанного в адресе и всех его дочерних терминов.
Вариант 1
Если заранее известна максимальная глубина дерева, то можно добавить в представление контекстный фильтр по Content: Has taxonomy term ID (with depth) в котором указать максимальную глубину:
При таком варианте на каждый уровень вложенности создаётся отдельный sql join, что возможно не лучший выход (скриншот).
Вариант 2
Если максимальный уровень заранее неизвестен или хочется избавиться от джоинов, то можно добавить контекстный фильтр по полю термина (в моём случае это "Content: Tags (field_tags)"), отметить опцию Allow multiple values и подменить значение фильтра с помощью кода:
$tids = [$argument]; foreach (taxonomy_get_tree(VID_СЛОВАРЯ, $argument) as $terms) { $tids[] = $terms->tid; } $handler->argument = implode('+', $tids); return TRUE;
Profit.
Полезное — как получить список всех дочерних терминов любой глубины