[WordPress] WordPress Popular Posts プラグインの人気記事表示をタグ付けデータで絞り込む方法

人気記事を表示したい時によく WordPress Popular Posts プラグインを利用させてもらっています。

オプションも豊富に用意されており、特定カテゴリーで人気記事表示をしたい場合にはデフォルトオプションで絞り込みができます。しかし、絞り込みたいのがタグだった場合はデフォルトオプションでできる方法が見当たりませんでした…。

どうやってタグで絞り込んで表示しようかと、プラグインファイルを眺めていたら人気記事のデータを取ってくるクエリを書き換えることができるフィルターフックを発見しました!

wpp_query_posts フィルターフックを使って特定タグの記事に絞り込んで表示する

クエリを書き換えるには wpp_query_posts フィルターフックを使用します。

以下のコードを functions.php 又は テンプレートファイルに記入します。

function result_query( $result ) {
  global $wpdb;
  // ↓ 絞り込みたいタグID
  $term_id = 157;
  $now = current_time('mysql');
  // ↓ 集計期間
  $interval = '1 MONTH';
  // ↓ 表示件数
  $limit = 5;

  $query = "SELECT p.ID AS 'id', p.post_title AS 'title', p.post_date AS 'date', p.post_author AS 'uid', SUM(v.pageviews) AS 'pageviews' FROM wp_popularpostssummary v LEFT JOIN wp_posts p ON v.postid = p.ID WHERE 1 = 1 AND p.post_type = 'post' AND p.ID IN ( SELECT object_id FROM wp_term_relationships AS r JOIN wp_term_taxonomy AS x ON x.term_taxonomy_id = r.term_taxonomy_id WHERE x.taxonomy = 'post_tag' AND x.term_id IN( $term_id ) ) AND v.last_viewed > DATE_SUB( '{$now}', INTERVAL {$interval} ) AND p.post_password = '' AND p.post_status = 'publish' GROUP BY v.postid ORDER BY pageviews DESC LIMIT $limit;";
  
  $result = $wpdb->get_results( $query );
  return $result;
}
add_filter( 'wpp_query_posts', 'result_query' );

$term_id

$term_id には絞り込みたいタグ ID を記入します。
タグの ID は「管理画面 > 投稿 > タグ」の画面で絞り込みたいタグ名のすぐ下にある「編集」ボタンをクリックしたタグ編集画面のURL欄で確認できます。以下画像のtag_ID=◯◯ となっている数字の部分がタグIDです。

$interval

$interval には、ページビューの集計期間を設定します。
集計期間が1日だった場合は “1 DAY” 、一週間なら “1 WEEK” 、一ヶ月なら “1 MONTH” とします。

クエリを書き換えるには wpp_query_posts フィルターフックを使用します。

以下のコードを functions.php 又は テンプレートファイルに記入します。

$limit

$limit には人気記事として表示する件数を記入して下さい。

これでタグに絞り込んだ人気記事が表示できます。

wpp_query_posts フィルターフックを使って特定タグの記事に絞り込んで表示する

$limit には人気記事として表示する件数を記入して下さい。
これでタグに絞り込んだ人気記事が表示できます。
プラグインを直接書き換えてしまうとアップデートもできなくなってしまい、不都合が多いのでフィルターフックを用意してくださっていて大変助かりました!

関連記事

[WordPress] WordPress Popular Posts プラグインでの表示を自由にカスタマイズしたい時に便利なフックとその使い方

Related Article

No Comments & Tracbacks

Leave a Comment

Emailは公開されません。*は必須項目です。


*


Categorys

Tags

CSS3 ダッシュボード ヘッダー トラブル コードサンプル コンテンツ スライドショー jQueryプラグイン php 引っ越し 素材 お知らせ JavaScript Facebook CSS カテゴリー 投稿タイプ IE HTML5 Shareボタン seo レスポンシブ Photoshop タクソノミー ナビゲーション カスタムメニュー Git Macアプリ サイドバー WPセキュリティ SVG iTunes PHPリファレンス API WP使い方 query_posts データベース get_posts() 条件分岐 コメント function RSS スマートフォン Sass/Compass さくらVPS