Add 'order' to wp_get_archives(). props tar.gz. fixes #18832.

git-svn-id: http://core.svn.wordpress.org/trunk@21610 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
Andrew Nacin 2012-08-24 20:50:22 +00:00
parent e225c12704
commit d1b5eca1a5
1 changed files with 9 additions and 5 deletions

View File

@ -869,7 +869,7 @@ function wp_get_archives($args = '') {
'type' => 'monthly', 'limit' => '', 'type' => 'monthly', 'limit' => '',
'format' => 'html', 'before' => '', 'format' => 'html', 'before' => '',
'after' => '', 'show_post_count' => false, 'after' => '', 'show_post_count' => false,
'echo' => 1 'echo' => 1, 'order' => 'DESC',
); );
$r = wp_parse_args( $args, $defaults ); $r = wp_parse_args( $args, $defaults );
@ -883,6 +883,10 @@ function wp_get_archives($args = '') {
$limit = ' LIMIT '.$limit; $limit = ' LIMIT '.$limit;
} }
$order = strtoupper( $order );
if ( $order !== 'ASC' )
$order = 'DESC';
// this is what will separate dates on weekly archive links // this is what will separate dates on weekly archive links
$archive_week_separator = '–'; $archive_week_separator = '–';
@ -909,7 +913,7 @@ function wp_get_archives($args = '') {
$output = ''; $output = '';
if ( 'monthly' == $type ) { if ( 'monthly' == $type ) {
$query = "SELECT YEAR(post_date) AS `year`, MONTH(post_date) AS `month`, count(ID) as posts FROM $wpdb->posts $join $where GROUP BY YEAR(post_date), MONTH(post_date) ORDER BY post_date DESC $limit"; $query = "SELECT YEAR(post_date) AS `year`, MONTH(post_date) AS `month`, count(ID) as posts FROM $wpdb->posts $join $where GROUP BY YEAR(post_date), MONTH(post_date) ORDER BY post_date $order $limit";
$key = md5($query); $key = md5($query);
$cache = wp_cache_get( 'wp_get_archives' , 'general'); $cache = wp_cache_get( 'wp_get_archives' , 'general');
if ( !isset( $cache[ $key ] ) ) { if ( !isset( $cache[ $key ] ) ) {
@ -931,7 +935,7 @@ function wp_get_archives($args = '') {
} }
} }
} elseif ('yearly' == $type) { } elseif ('yearly' == $type) {
$query = "SELECT YEAR(post_date) AS `year`, count(ID) as posts FROM $wpdb->posts $join $where GROUP BY YEAR(post_date) ORDER BY post_date DESC $limit"; $query = "SELECT YEAR(post_date) AS `year`, count(ID) as posts FROM $wpdb->posts $join $where GROUP BY YEAR(post_date) ORDER BY post_date $order $limit";
$key = md5($query); $key = md5($query);
$cache = wp_cache_get( 'wp_get_archives' , 'general'); $cache = wp_cache_get( 'wp_get_archives' , 'general');
if ( !isset( $cache[ $key ] ) ) { if ( !isset( $cache[ $key ] ) ) {
@ -952,7 +956,7 @@ function wp_get_archives($args = '') {
} }
} }
} elseif ( 'daily' == $type ) { } elseif ( 'daily' == $type ) {
$query = "SELECT YEAR(post_date) AS `year`, MONTH(post_date) AS `month`, DAYOFMONTH(post_date) AS `dayofmonth`, count(ID) as posts FROM $wpdb->posts $join $where GROUP BY YEAR(post_date), MONTH(post_date), DAYOFMONTH(post_date) ORDER BY post_date DESC $limit"; $query = "SELECT YEAR(post_date) AS `year`, MONTH(post_date) AS `month`, DAYOFMONTH(post_date) AS `dayofmonth`, count(ID) as posts FROM $wpdb->posts $join $where GROUP BY YEAR(post_date), MONTH(post_date), DAYOFMONTH(post_date) ORDER BY post_date $order $limit";
$key = md5($query); $key = md5($query);
$cache = wp_cache_get( 'wp_get_archives' , 'general'); $cache = wp_cache_get( 'wp_get_archives' , 'general');
if ( !isset( $cache[ $key ] ) ) { if ( !isset( $cache[ $key ] ) ) {
@ -975,7 +979,7 @@ function wp_get_archives($args = '') {
} }
} elseif ( 'weekly' == $type ) { } elseif ( 'weekly' == $type ) {
$week = _wp_mysql_week( '`post_date`' ); $week = _wp_mysql_week( '`post_date`' );
$query = "SELECT DISTINCT $week AS `week`, YEAR( `post_date` ) AS `yr`, DATE_FORMAT( `post_date`, '%Y-%m-%d' ) AS `yyyymmdd`, count( `ID` ) AS `posts` FROM `$wpdb->posts` $join $where GROUP BY $week, YEAR( `post_date` ) ORDER BY `post_date` DESC $limit"; $query = "SELECT DISTINCT $week AS `week`, YEAR( `post_date` ) AS `yr`, DATE_FORMAT( `post_date`, '%Y-%m-%d' ) AS `yyyymmdd`, count( `ID` ) AS `posts` FROM `$wpdb->posts` $join $where GROUP BY $week, YEAR( `post_date` ) ORDER BY `post_date` $order $limit";
$key = md5($query); $key = md5($query);
$cache = wp_cache_get( 'wp_get_archives' , 'general'); $cache = wp_cache_get( 'wp_get_archives' , 'general');
if ( !isset( $cache[ $key ] ) ) { if ( !isset( $cache[ $key ] ) ) {