drupal8におけるViewsプログラミング

カテゴリ Viewsプログラミング コアバージョン 8.4x 関連モジュール Views

Viewsのパラメータを自由に追加したり、クエリを変更する方法

コメント

ユーザー actbrain の写真

■ 関連API

検索フォームを変更する

function MODULE_NAME_form_views_exposed_form_alter(&$form, FormStateInterface $form_state, $form_id);

検索フォーム入力値を変更する

function MODULE_NAME_views_pre_view(ViewExecutable $view, $display_id, array &$args);

Viewsのクエリを加工する

function MODULE_NAME_views_query_alter(ViewExecutable $view, QueryPluginBase $query);

最終的なクエリを変更する

function MODULE_NAME_query_alter(\Drupal\Core\Database\Query\AlterableInterface $query);

■ 例

プルダウンをチェックボックスに変更する

function MODULE_NAME_form_views_exposed_form_alter(&$form, FormStateInterface $form_state, $form_id) {
  $form[FIELD_NAME]['#type'] = 'checkboxes';
}

空白区切りのtextフィールドを改行区切りのtextareaにする

function MODULE_NAME_form_views_exposed_form_alter(&$form, FormStateInterface $form_state, $form_id) {
  $form[FIELD_NAME]['#type'] = 'textarea';
  $form[FIELD_NAME]['#rows'] = 5;
}
function MODULE_NAME_views_pre_view(ViewExecutable $view, $display_id, array &$args) {
  $_SESSION[MODULE_NAME][ANY_NAME][FIELD_NAME] = $_REQUEST[FIELD_NAME];
  unset($_GET[FIELD_NAME], $_POST[FIELD_NAME], $_REQUEST[FIELD_NAME]);
}
function MODULE_NAME_query_alter(\Drupal\Core\Database\Query\AlterableInterface $query){
  // フィールド内ORの場合
  if ($view->id() == MY_VIEW) {
    $or = new Condition('OR');
    foreach ($_SESSION[MODULE_NAME][ANY_NAME][FIELD_NAME] as $val) {
      $or->condition('node__FIELD_NAME_value', $val);
    }
    $query->addWhere($whereGroup++, $or);
  }
}

hook_views_query_alter()では完結できないクエリ補整を行う

function MODULE_NAME_query_alter(\Drupal\Core\Database\Query\AlterableInterface $query){
  if ($view->id() == MY_VIEW) {
    $query->addTag('this_is_my_views_query');
}
function MODULE_NAME_query_alter(\Drupal\Core\Database\Query\AlterableInterface $query) {
  if ($query->hasTag('this_is_my_views_query')) {
    $tables =& $query->getTables();
    foreach ($tables[ALIAS]['arguments'] as &$value) {
      if ($value == THIS) {
        $value = VALUE;
      }
    }
  }
}

クエリ情報を保存しておいてあとで使う

function MODULE_NAME_query_alter(\Drupal\Core\Database\Query\AlterableInterface $query){
  $q = $query->query();
  $_SESSION[MODULE_NAME][ANY] = [
    'string' => $q->__toString(),
    'arguments' => $q->arguments(),
  ];
}
〜
  $p = $_SESSION[MODULE_NAME][ANY];
  $result = \Drupal::database()->query($p['string'], $p['arguments']);
〜

フォームを持たないViewsに場合に応じて条件を付ける

function MODULE_NAME_query_alter(\Drupal\Core\Database\Query\AlterableInterface $query){
  if ($view->id() == MY_VIEW) {
    $whereGroup = 2;
    $and = new Condition('AND');
    $and->condition(
      "watchdog.timestamp",
      \Drupal::configFactory()->getEditable('image_manager.setting')->get('log_error_mailed_datetime'),
      '>');
    $query->addWhere($whereGroup++, $and);
  }
}

ページ

OTHER FAQ

Drupal開発・運用の疑問/質問の答えはここに

無料ユーザー登録すると質問できます。

カテゴリ Core Ver. 関連モジュール降順で並び替える タイトル
サイト情報 8.4x JavaScript JavaScriptに変数を渡す方法
フォーム 8.6.x JavaScript 特定のformにJavaScriptを紐付ける方法
フォーム 8.6.x JavaScript 特定のformに動的にJavaScriptをロードする方法
見栄え 7.15 js Injector 簡単にJavascriptを追加する方法は?
コンテンツの作成 8.4x json jQueryにjsonで渡す方法
言語 7.15 Language まだ翻訳されていない英語文、どうにかならない?
Libraries 8.5.x Libraries Commerceで外部JavaScriptをテスト/本番で読み分ける方法
PhpStorm 7.50 LocalForward PhpStormから踏み台を使う
排他 7.26 lock Viewsモジュールの設定ページのような排他機能
mac linux ファイル名 文字化け 8.7.x mac linux ファイル名 文字化け Macからlinuxにrsyncするとファイル名(濁点)が文字化けする場合の対応方法
開発 mail 7.50 Mail Safety 開発/テスト用サイトのメール
コンテンツの作成 7.15 Mailhandler メールを通じてnodeの投稿をするには
コンテンツの作成 7.23 maxlength テキストフィールドの最大長のチェック&カウントダウン
アップデート 8.7.2 menu drupal-core 8.7.2にupdateしたところ
サイトの構築 7.50 Module Missing Message Fixer モジュールをアンインストールしたらエラーがでるようになった
リバースプロキシ 8.9.x mod_proxy mod_proxy_http mod_ssl Apache2.4 から httpsサーバーへリバースプロキシする方法
コンテンツの作成 7.38 node 代理投稿を可能にしたい
コンテンツの作成 8.4x node 新規ノードを作成する
コンテンツの作成 8.4x node node保存前に色々やる方法
コンテンツの作成 8.9.x node ノード保存時の前回値の参照方法

ページ