###課題
「functions.php」に記述したフィルターフックを投稿一覧(テンプレート:home.php)で無効にしたい。
※サイトのトップページにはfront-page.phpを使用しています。
###そもそもの実現したいこと:
カテゴリー毎の年ごとのアーカイブメニューを作成したく思っています。
「wp_get_archives」はパラメーターにカテゴリーを指定することができないため、
検索をし、カテゴリーを指定できる記述をfunctions.phpに記述しました。
参考にしたサイト
http://www.d-wood.com/blog/2014/08/27_6760.html
###問題点:
上記サイトの記述で、カテゴリーアーカイブではうまく動作したのですが、
なぜか投稿一覧(home.php)では、削除した投稿の年がナビゲーションに残ってしまう
という問題が発生しました。
例えば2013年の投稿を公開して、それを下書きに変更するとナビゲーションに「2013年」は残り、
その年をクリックするとNot foundになってしまいます。
http://example.com/blog/2013/ ←Not found
投稿を下書きでは無く完全に削除すると2013年はナビゲーションから消えます。
これらの問題はカテゴリーアーカイブでは起きません。
###自分なりに思いついた解決策:
ソース部分は難しくて編集するのが困難なのでフィルターフックを投稿一覧(home.php)では無効にしたく思っています。
下記の2パターンを試しましたが、どうしても投稿トップに「問題点」で書きました事象が発生し、影響してしまいます。
#####NGだったパターン(その1) ※全部「!is_home」で囲む
php
1if(!is_home()){ //←これを追加しました 2 3add_filter('getarchives_where', 'custom_archives_where', 10, 2); 4add_filter('getarchives_join', 'custom_archives_join', 10, 2); 5 6function custom_archives_join($x, $r) { 7 global $wpdb; 8 $cat_ID = $r['cat']; 9 if (isset($cat_ID)) { 10 return $x . " INNER JOIN $wpdb->term_relationships ON ($wpdb->posts.ID = $wpdb->term_relationships.object_id) INNER JOIN $wpdb->term_taxonomy ON ($wpdb->term_relationships.term_taxonomy_id = $wpdb->term_taxonomy.term_taxonomy_id)"; 11 } else { 12 return $x; 13 } 14} 15 16function custom_archives_where($x, $r) { 17 global $wpdb; 18 $cat_ID = $r['cat']; 19 if (isset($cat_ID)) { 20 return $x . " AND $wpdb->term_taxonomy.taxonomy = 'category' AND $wpdb->term_taxonomy.term_id IN ($cat_ID)"; 21 } else { 22 $x; 23 } 24} 25 26function wp_get_cat_archives($opts, $cat) { 27 $args = wp_parse_args($opts, array('echo' => '1')); // default echo is 1. 28 $echo = $args['echo'] != '0'; // remember the original echo flag. 29 $args['echo'] = 0; 30 $args['cat'] = $cat; 31 32 $tag = ($args['format'] === 'option') ? 'option' : 'li'; 33 34 $archives = wp_get_archives(build_query($args)); 35 $archs = explode('</'.$tag.'>', $archives); 36 $links = array(); 37 38 foreach ($archs as $archive) { 39 $link = preg_replace("/='([^']+)'/", "='$1?cat={$cat}'", $archive); 40 array_push($links, $link); 41 } 42 $result = implode('</'.$tag.'>', $links); 43 44 if ($echo) { 45 echo $result; 46 } else { 47 return $result; 48 } 49} 50 51} //←これを追加しました
#####NGだったパターン(その2) ※functionごとに「!is_home」で囲む
php
1 2add_filter('getarchives_where', 'custom_archives_where', 10, 2); 3add_filter('getarchives_join', 'custom_archives_join', 10, 2); 4 5function custom_archives_join($x, $r) { 6 7if(!is_home()){ //←これを追加しました 8 9 global $wpdb; 10 $cat_ID = $r['cat']; 11 if (isset($cat_ID)) { 12 return $x . " INNER JOIN $wpdb->term_relationships ON ($wpdb->posts.ID = $wpdb->term_relationships.object_id) INNER JOIN $wpdb->term_taxonomy ON ($wpdb->term_relationships.term_taxonomy_id = $wpdb->term_taxonomy.term_taxonomy_id)"; 13 } else { 14 return $x; 15 } 16 17} //←これを追加しました 18 19} 20 21function custom_archives_where($x, $r) { 22 23if(!is_home()){ //←これを追加しました 24 25 global $wpdb; 26 $cat_ID = $r['cat']; 27 if (isset($cat_ID)) { 28 return $x . " AND $wpdb->term_taxonomy.taxonomy = 'category' AND $wpdb->term_taxonomy.term_id IN ($cat_ID)"; 29 } else { 30 $x; 31 } 32 33} //←これを追加しました 34 35} 36 37function wp_get_cat_archives($opts, $cat) { 38 39if(!is_home()){ //←これを追加しました 40 41 $args = wp_parse_args($opts, array('echo' => '1')); // default echo is 1. 42 $echo = $args['echo'] != '0'; // remember the original echo flag. 43 $args['echo'] = 0; 44 $args['cat'] = $cat; 45 46 $tag = ($args['format'] === 'option') ? 'option' : 'li'; 47 48 $archives = wp_get_archives(build_query($args)); 49 $archs = explode('</'.$tag.'>', $archives); 50 $links = array(); 51 52 foreach ($archs as $archive) { 53 $link = preg_replace("/='([^']+)'/", "='$1?cat={$cat}'", $archive); 54 array_push($links, $link); 55 } 56 $result = implode('</'.$tag.'>', $links); 57 58 if ($echo) { 59 echo $result; 60 } else { 61 return $result; 62 } 63 64} //←これを追加しました 65 66}
どのようにしたら上記のフィルター箇所の記述をhome.phpに影響させないようにできますでしょうか。
ご教授いただけますととても助かります。
###補足情報
できるだけプラグインを使用せず実現できたらと思っています。
回答2件
あなたの回答
tips
プレビュー