年アーカイブで「前の年」と「次の年」のリンクを表示する【WordPress】

  • 投稿 : 2017-08-09
archive-year01.jpg

原理

現在年が、2017月としたときに、単純に-1するとダメです。というのは、その年の記事が1つもない場合があるからですね。
その辺も考慮して、WordpressのDBを直接参照して求めることにします。

カレント年が、2016月としたら、以下のSQLでわかります。

前の年

SELECT YEAR(post_date) AS year FROM wp_posts WHERE post_date < '2016-01-01' AND post_type = 'post' AND post_status = 'publish' ORDER BY post_date DESC LIMIT 1

次の年

SELECT YEAR(post_date) AS year FROM wp_posts WHERE post_date > '2016-12-31' AND YEAR( post_date ) != YEAR( '2016-12-31' ) AND post_type = 'post' AND post_status = 'publish' ORDER BY post_date ASC LIMIT 1

archive-year02.png

実際にphpAdminなどで上記のSQLを実行してみれば、期待通りのSQLかどうかはわかるかと思います。

PHPコード

//「前の年」取得関数
function gogo_fnc_get_previous_year($thisyear){
	global $wpdb;
	$previous = $wpdb->get_row(
"SELECT YEAR(post_date) AS year
FROM $wpdb->posts
WHERE post_date < '$thisyear-01-01' AND post_type = 'post' AND post_status = 'publish' ORDER BY post_date DESC LIMIT 1");
	
	return $previous;
}
//「次の年」取得関数
function gogo_fnc_get_next_year($thisyear){
	global $wpdb;
	$next = $wpdb->get_row(
"SELECT YEAR(post_date) AS year
FROM $wpdb->posts
WHERE post_date > '$thisyear-12-31'
AND YEAR( post_date ) != YEAR( '$thisyear-12-31' )
AND post_type = 'post'
AND post_status = 'publish'
ORDER BY post_date ASC
LIMIT 1");
	return $next;
}

テーマのfunctions.phpに上記を追加します。
そうすると、「前の年」取得関数gogo_fnc_get_previous_year、「次の年」取得関数 gogo_fnc_get_next_yearが使えるようになります。

動作確認

<?php
$previous = gogo_fnc_get_previous_year(2016);
$next = gogo_fnc_get_next_year(2016);

echo $previous->year;
echo "<br/>";
echo $next->year;

PHPコードが実行できるウジェットに上記を書いて、期待通りの動作することを確認すればOKかと思います。

PHP Code Widget — WordPress プラグイン

アーカイブの「前の年」「次の年」のリンクを取得する

<?php
if(is_year()){
    $this_year = intval(get_the_time('Y'));
    $this_month =intval(get_the_time('m'));

    $previous = gogo_fnc_get_previous_year($this_year);
    $next = gogo_fnc_get_next_year($this_year);

    if( $previous ) { $link_prev_year = get_year_link( $previous->year);}
    if( $next ){ $link_next_year = get_year_link( $next->year);}

    echo '<ul class="archive-pagination">';
    if( $next ){ printf('<li class="next"><a href="%s">%s年</a></li>',$link_next_year,$next->year);}else{printf('<li class="home next"><a href="/">Home</a></li>');}
    printf('<li class="current"><span>%s年%s</span></li>',$this_year,$page_x);

    if( $previous ) { printf('<li class="previous"><a href="%s">%s年</a></li>',$link_prev_year,$previous->year);}else{printf('<li class="home previous"><a href="/">Home</a></li>');}
    echo '</ul>';
} 
?>

上記を表示させたいところにコピペしてください。

スタイルシート

.archive-pagination{
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    justify-content: center;
    padding:0;
    list-style: none;
}
.archive-pagination li a{
    color: #fff;
    text-align: center;
    background-color: #0aaeda;
    border: 1px solid #93b8ca;

    padding: 4px 8px;
    text-decoration: none;
    margin: 0 10px;
    width: auto;
    width: calc(100% / 2);
    border-radius: 5px;
}
.archive-pagination li a:hover {
    background: #93b8ca;
}

.archive-pagination li.previous a:after{
    content: '>';
}
.archive-pagination li.next a:before{
    content: '<';
}

参考までに作成したCSSを載せておきます。

スポンサーリンク