web-dev-qa-db-fra.com

Filtrer par catégorie de poste dans la médiathèque

J'essaie de trouver un moyen de filtrer la médiathèque en fonction de la catégorie de publication associée à un élément multimédia. Je peux voir que vous pouvez trier par "attaché à" mais cela ne me fait que faire un peu du chemin. Aucune suggestion?

6
whodeee

Vous pouvez utiliser pre_get_posts pour filtrer la requête.

Afin que vous puissiez

  1. récupérer une catégorie à partir de vars de requête
  2. le récupérer le poste avec cette catégorie
  3. définir la requête multimédia de manière à n'inclure que les publications ayant comme publications

Pour donner une interface utilisateur, vous pouvez utiliser restrict_manage_posts hook pour afficher une liste déroulante de catégories.

add_action('pre_get_posts', 'my_filter_media_by_cat');
add_action( 'restrict_manage_posts', 'my_add_media_cat_dropdown' );

function my_filter_media_by_cat( $q ) {
  $scr = get_current_screen();
  $cat = filter_input(INPUT_GET, 'postcat', FILTER_SANITIZE_STRING );   
  if ( ! $q->is_main_query() || ! is_admin() || (int)$cat <= 0 || $scr->base !== 'upload' )
      return;
  // get the posts
  $posts = get_posts( 'nopaging=1&category=' . $cat );
  // get post ids
  $pids = ( ! empty( $posts ) ) ? wp_list_pluck($posts, 'ID') : false;
  if ( ! empty($pids) ) {
    $pidstxt = implode($pids, ',');
    global $wpdb;
    // get the ids of media having retrieved posts as parent
    $mids = $wpdb->get_col("SELECT ID FROM $wpdb->posts WHERE post_parent IN ($pidstxt)");
    if ( ! empty($mids) ) {
      // force media query to retrieve only media having retrieved posts as parent
      $q->set( 'post__in', $mids );
    } else {
      // force media query to return no posts
      $q->set( 'p', -1 ); // let query found nothing
    }
  }
}

function my_add_media_cat_dropdown() {
  $scr = get_current_screen();
  if ( $scr->base !== 'upload' ) return;
  $cat = filter_input(INPUT_GET, 'postcat', FILTER_SANITIZE_STRING );   
  $selected = (int)$cat > 0 ? $cat : '-1';  
  $args = array(
      'show_option_none'   => 'All Post Categories',
      'name'               => 'postcat',
      'selected'           => $selected
  ); 
  wp_dropdown_categories( $args );
}

Négatif de ce code est que vous devez exécuter 3 requêtes pour filtrer le média ...

Résultat sur l'interface utilisateur:

enter image description here

2
gmazzap