web-dev-qa-db-fra.com

Colonnes triables personnalisées classées par méta-valeur?

Je ne sais pas pourquoi ma fonction triable ne trie pas mes "événements" dans un post-méta personnalisé. J'ai un type de post personnalisé nommé wr_event… J'ai mes colonnes personnalisées configurées et mon post-méta est affiché dans les colonnes, exactement comme je le souhaite. Le descripteur "Event-Date" est même un lien triable! Seule chose si je clique sur le lien de tri pour la date de l'événement, la liste n'est pas mise à jour. La fonction est activée lorsque la page est rechargée, mais elle ne trie rien.

Même si l'URL bascule entre ces deux états si je clique sur le lien de tri…

http://url/wp-admin/edit.php?post_type=wr_event&orderby=event_date&order=desc

http://url/wp-admin/edit.php?post_type=wr_event&orderby=event_date&order=asc

Cependant, la liste est toujours la même!

Voici tout mon code pour les colonnes personnalisées:

add_filter("manage_edit-wr_event_columns", "wr_event_edit_columns");

function wr_event_edit_columns($columns) {
    $columns = array(
        "cb" => "<input type=\"checkbox\" />",
        "title" => "Event",
        "event_date" => "Event Date",
        "type" => "Type",
    );

    return $columns;
}

add_action("manage_posts_custom_column",  "event_custom_columns");

function event_custom_columns($column) {
    global $post;

    switch ($column) {
        case "event_date":
        $custom = get_post_custom();
        echo $custom['_wr_event_date'][0];
        break;
        case "type":
        echo get_the_term_list($post->ID, 'event_type', '', ', ','');
        break;
    }
}

add_filter("manage_edit-wr_event_sortable_columns", "wr_event_sortable_columns");   

function wr_event_sortable_columns( $columns ) {
    $columns['event_date'] = 'event_date';
    return $columns;
}

add_filter("request", "event_column_orderby");

function event_column_orderby( $vars ) {
    if ( isset( $vars['orderby'] ) && 'event_date' == $vars['event_date'] ) {
        $vars = array_merge( $vars,
            array(
                'meta_key'  => '_wr_event_date',
                'orderby'   => 'meta_value_num',
                'order'     => 'asc'
            )
        );
    }

    return $vars;
}
6
mathiregister

C'est parce que vous vérifiez 'event_date' == $vars['event_date'] pas 'event_date' == $vars['orderby].

Mais n'utilisez pas le filtre request. Au lieu:

add_action( 'pre_get_posts', 'event_column_orderby' );  
function event_column_orderby( $query ) {  
    if( ! is_admin() )  
        return;  

    $orderby = $query->get( 'orderby');  

    if( 'event_date' == $orderby ) {  
        $query->set('meta_key','_wr_event_date');  
        $query->set('orderby','meta_value_num');  
    }  
} 

... et ne définissez pas manuellement la order car vous ne verrez pas la différence lors du basculement entre ASC/DESC.

6
Stephen Harris