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:
parent
e225c12704
commit
d1b5eca1a5
|
@ -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 ] ) ) {
|
||||||
|
|
Loading…
Reference in New Issue