Как я могу отфильтровать термины таксономии по языку?
Я искал способ фильтровать термины таксономии по языку (как это делается для узлов), но я не нашел никакого способа сделать это.
Поддерживает ли модуль представлений этот фильтр также в таксономиях или только в узлах?
Как я могу отфильтровать термины таксономии по языку?
7 answers
Включив модуль Представления интернационализации , можно отфильтровать термин таксономии по языку. Обратите внимание, что версия в настоящее время находится в разработке, но она работает как шарм.
Вы можете использовать модуль Представления интернационализации в сочетании с модулем перевода таксономии (который является частью Интернационализации), чтобы получить языковой фильтр для терминов таксономии.
Перевод представлений с использованием интернационализации. Эта работа продолжается, и еще не все свойства представлений могут быть переведены. Требуется интернационализация 6.x-1.5 или новее.
Вот еще одно решение:
function mymodule_views_query_alter(&$view, &$query) {
if ($view->name == 'yourviewmachinename') {
$query->where[] = array(
'conditions' => array(array(
'field' => 'taxonomy_term_data.language',
'value' => array('***CURRENT_LANGUAGE***'),
'operator' => 'in',
)),
'args' => array(),
'type' => 'AND',
);
}
}
Источник здесь.
Модуль представлений не позволяет фильтровать термины таксономии по языку, связанному с ним, так как Drupal связывает язык только с узлами.
Однако вы можете настроить представление так, чтобы в нем отображались только узлы с предопределенным языком.
- В разделе "Критерии фильтрации" выберите "Добавить"
- в следующей форме выберите "Перевод контента: Язык"
- следующая форма позволит вам выбрать, какой язык использовать для фильтрации содержимого представления между "Выбрать все", "Текущий язык пользователя", "Язык сайта по умолчанию", "Без языка" и один из языков, включенных на сайте.
Я добавил этот фильтр в представление терминов таксономии, которое поставляется с модулем Представления, выбрав английский в качестве языка для фильтрации содержимого, и создал два узла: один на английском языке и один на латыни. Я назначил обоим узлам один и тот же термин таксономии, с идентификатором, равным 22.
Когда я посетил http://example.com/taxonomy/term/22 , представление эффективно показано только содержание на английском языке.
Фильтрация языков для перевода сущностей. Языковой фильтр в разделе "Критерии фильтрации" представления необходим только в том случае, если вы используете систему перевода узлов. Если вместо этого вы используете более современную систему перевода сущностей, доступную для Drupal 7, просто измените настройку "Язык поля" в разделе "Другое" представления.
Как это сделать для терминов таксономии. Я попробовал это для терминов таксономии, и это работает. Просто убедитесь, что вы добавили правильный один из двух экземпляры полей для каждого переводимого поля, а именно поля с описанием "Отображается в: таксономия-термин: ваше-вокаб-имя". Для получения дополнительной информации см. о проблеме #1841434.
Добавьте в свой YOUR_MODULE.модуль
function YOUR_MODULE_views_data_alter(&$data) {
$opts['title'] = 'Language';
$opts['table'] = 'taxonomy_term_data';
$opts['help'] = 'Taxonomy term language.';
$opts['filter']['handler'] = 'YOUR_MODULE_handler_filter_language';
$data['taxonomy_term_data']['language'] = $opts;
}
Добавьте в свой YOUR_MODULE.info
files[] = views/handlers/filter/YOUR_MODULE_handler_filter_language.inc
Создайте файл "представления/обработчики/фильтр/your_module_handler_filter_language.inc" в каталоге вашего модуля и поместите следующее содержимое:
/**
* @file
* Views handler to filter language by term.
*/
/**
* Filter by submission status
*/
class YOUR_MODULE_handler_filter_language extends views_handler_filter_in_operator {
function get_value_options() {
$languages = array(
'***CURRENT_LANGUAGE***' => t("Current user's language"),
'***DEFAULT_LANGUAGE***' => t("Default site language"),
LANGUAGE_NONE => t('Language neutral'),
);
$this->value_title = t('Language');
$options = array_merge($languages, locale_language_list());
$this->value_options = $options;
}
// '0' won't work as a key for checkboxes.
function value_form(&$form, &$form_state) {
parent::value_form($form, $form_state);
$form['value']['#type'] = 'select';
}
}
Очистите все кэши, и появится новый критерий.
Или используйте мой модуль Таксономия Акума
Поскольку у меня возникли некоторые другие проблемы с модулем представлений интернационализации, а именно то, что он, похоже, изменяет уже переведенный пользовательский интерфейс из представлений (указания на пейджер, текст верхнего/нижнего колонтитула и т. Д.), Я поднимаю соответствующий код для создания языковых фильтров в отдельном модуле. Замените MYMODULE ниже именем вашего модуля. Работает как талисман для меня!
/**
* Code below is lifted from the i18nviews module. Gives the possibility to filter for
* language on term views
*
* Implementation of hook_views_data_alter().
*
* Registers views handlers with dependency to i18n_taxonomy.
*/
function MYMODULE_views_data_alter(&$data) {
// Add i18n language field to taxonomy_term_data. No clash.
$data['taxonomy_term_data']['language'] = array(
'group' => t('Taxonomy term'),
'title' => t('Language'),
'help' => t('The language the term is in.'),
'field' => array(
'handler' => 'MYMODULE_handler_field_taxonomy_term_language',
'click sortable' => TRUE,
),
'filter' => array(
'handler' => 'MYMODULE_handler_filter_taxonomy_term_language',
),
'argument' => array(
'handler' => 'MYMODULE_handler_argument_taxonomy_term_language',
),
);
}
/**
* Field handler to provide simple renderer that shows term language.
*/
class MYMODULE_handler_field_taxonomy_term_language extends views_handler_field_taxonomy {
function render($values) {
$languages = locale_language_list();
$value = isset($languages[$values->{$this->field_alias}]) ? $languages[$values->{$this->field_alias}] : '';
$value = $this->get_value($values);
return $this->render_link($this->sanitize_value($value), $values);
}
}
/**
* Filter by language
*/
class MYMODULE_handler_filter_taxonomy_term_language extends views_handler_filter_in_operator {
function get_value_options() {
if (!isset($this->value_options)) {
$this->value_title = t('Language');
$languages = array(
'***CURRENT_LANGUAGE***' => t("Current user's language"),
'***DEFAULT_LANGUAGE***' => t("Default site language"),
LANGUAGE_NONE => t('No language')
);
$languages = array_merge($languages, locale_language_list());
$this->value_options = $languages;
}
}
}
/**
* Argument handler to accept a language.
*/
class MYMODULE_handler_argument_taxonomy_term_language extends views_handler_argument {
function construct() {
parent::construct('language');
}
/**
* Override the behavior of summary_name(). Get the user friendly version
* of the language.
*/
function summary_name($data) {
return $this->term_language($data->{$this->name_alias});
}
/**
* Override the behavior of title(). Get the user friendly version of the
* node type.
*/
function title() {
return $this->term_language($this->argument);
}
function term_language($langcode) {
$languages = locale_language_list();
return isset($languages[$langcode]) ? $languages[$langcode] : t('Unknown language');
}
}