Auparavant, je pouvais trier les résultats d'une requête selon deux critères ("trier les résultats d'abord par statut = ASC non vendu, puis par date DESC) comme ceci:
add_action( 'pre_get_posts', 'my_get_posts' );
function my_get_posts( $query )
{
if (is_admin()){
return;
}
if (is_post_type_archive('objet')){
// Stock: sort by unsold first, then by date
$query->set('meta_key', 'wpcf-object-sold-status' );
$query->set('orderby', 'meta_value date');
$query->set('order', 'ASC DESC' );
}
return $query;
}
Mais maintenant, cela ne change plus l'ordre des résultats. Je ne sais pas pourquoi il a cessé de fonctionner. Peut-être la mise à jour de Wordpress 3 à 4?
Comme disait Milo:
$query->set('meta_key', 'wpcf-object-sold-status' );
$query->set('orderby', array('meta_value' => 'ASC', 'date' => 'DESC'));
// $query->set('order', 'ASC DESC' ); // not needed
Lien pertinent: https://make.wordpress.org/core/2014/08/29/a-more-powerful-order-by-in-wordpress-4-0/