Search code examples
widgetwordpress-themingthemesarchivesidebar

How do I display the "Archives" widget layout (sidebar) in Wordpress by 'year' then by 'months'?


I am using the default widget in my sidebar Archive which currently displays the archive this way:

Mar 2018
Feb 2018
Jan 2018

However, I'd like it to display this way:

2018
March
February
January

2017
December
November
October

Where the months are links. How do I achieve that? What do I do to my sidebar.php file?


Solution

  • I found the answer, just use this on your sidebar.php or anywhere else you want the archive to appear:

    <?php
                                global $wpdb;
                                $limit = 0;
                                $year_prev = null;
                                $months = $wpdb->get_results("SELECT DISTINCT MONTH( post_date ) AS month ,  YEAR( post_date ) AS year, COUNT( id ) as post_count FROM $wpdb->posts WHERE post_status = 'publish' and post_date <= now( ) and post_type = 'post' GROUP BY month , year ORDER BY post_date DESC");
                                foreach($months as $month) :
                                $year_current = $month->year;
                                if ($year_current != $year_prev){
                                    if ($year_prev != null){?>
    
                                    <?php } ?>
    
                                <li class="archive-year"><?php echo $month->year; ?></li>
    
                                <?php } ?>
                                <li><a href="<?php bloginfo('url') ?>/<?php echo $month->year; ?>/<?php echo date("m", mktime(0, 0, 0, $month->month, 1, $month->year)) ?>"><span class="archive-month"><?php echo date_i18n("F", mktime(0, 0, 0, $month->month, 1, $month->year)) ?></span></a></li>
    
                            <?php $year_prev = $year_current;
    
                            if(++$limit >= 18) { break; }
    
                            endforeach; ?>  
    

    Style as per your liking.