言語ごとに分類項をフィルタリングするにはどうすればよいですか?

drupal.stackexchange https://drupal.stackexchange.com/questions/1993

  •  16-10-2019
  •  | 
  •  

質問

言語で分類学の用語をフィルタリングする方法を検索しました(ノードで行われたように)が、それを行う方法は見つかりませんでした。

ビューモジュールは、分類法でもそのフィルターをサポートしていますか、それともノードだけですか?
言語ごとに分類項をフィルタリングするにはどうすればよいですか?

役に立ちましたか?

解決

モジュールを有効にすることにより 国際化の見解, 、言語で分類用語をフィルタリングするオプションが利用可能です。バージョンは現在開発されているが、魅力のように機能することに注意してください。

screenshot showing effect of installing i18nviews

他のヒント

使用できます 国際化の見解 分類翻訳モジュールと組み合わせたモジュール(の一部です 国際化)分類条件の言語フィルターを取得する。

国際化を使用してビューを翻訳します。これは進行中の作業であり、すべてのビュープロパティをまだ翻訳できるわけではありません。 国際化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',
    );
  }
}

ソース ここ.

Viewsモジュールでは、Drupalが言語をノードに関連付けるだけであるため、それに関連する言語で分類項をフィルタリングすることはできません。

ただし、事前定義された言語でノードのみを表示するようにビューを設定できます。

  • 「フィルター基準」で、「追加」を選択します
  • 次の形式では、「コンテンツ翻訳:言語」を選択します
  • 次のフォームでは、「すべての選択」、「現在のユーザーの言語」、「デフォルトサイト言語」、「言語なし」、およびサイトで有効な言語の1つの間のビューコンテンツをフィルタリングするために使用する言語を選択できます。

このフィルターは、ビューモジュールに付属する分類学の用語ビューに追加し、コンテンツをフィルタリングするための言語として英語を選択し、2つのノードを作成しました。1つは英語で、もう1つはラテン語です。両方のノードに同じ分類項を割り当てました。IDが22に等しいものです。
私が訪れたとき http://example.com/taxonomy/term/22, 、ビューは、英語のコンテンツだけを効果的に示しています。

エンティティ翻訳の言語フィルタリング。 ビューの「フィルター基準」セクションの言語フィルターは、ノード変換システムを使用する場合にのみ必要です。代わりに、よりモダンを使用する場合 エンティティの翻訳 Drupal 7で利用可能なシステムは、ビューの「その他」セクションで「フィールド言語」設定を適応させるだけです。

分類条件のためにそれを行う方法。 私はこれを分類条件のために試しましたが、それは機能します。翻訳可能なすべてのフィールドに2つのフィールドインスタンスのうち正しい1つ、つまり「Taxonomy-Term:Your-Vocab-name」の説明があるものを追加してください。詳細については、参照してください 号#1841434.

your_module.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

モジュールディレクトリ内で「Views/Handlers/Filter/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';
  }
}

すべてのキャッシュをクリアし、新しい基準が表示されます。

または、私のモジュールを使用します アクマ分類法

国際化ビューモジュールに他のいくつかの問題があるため、つまり、見た目(ページャーの指示、ヘッダー /フッターテキストなど)から翻訳されたUIを変更するように思われるため、言語フィルターを作成するための関連するコードを別のものに掲載していますモジュール。以下の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');
  }
}
ライセンス: CC-BY-SA帰属
所属していません drupal.stackexchange
scroll top