Я не на 100% впевнений, чи правильно я визнаю вашу проблему, але ... Можливо, це допоможе вам ...
Завантажувач медіа-файлів отримує додатки з простими WP_Query
, тому ви можете використовувати багато фільтрів, щоб змінювати його вміст.
Єдина проблема полягає в тому, що ви не можете запитувати повідомлення з конкретним CPT як батьків, використовуючи WP_Query
аргументи ... Отже, нам доведеться використовувати posts_where
і posts_join
фільтрувати.
Щоб бути впевненим, що ми змінимо лише запит для завантаження медіа, і ми використаємо ajax_query_attachments_args
.
Ось як це виглядає в поєднанні:
function my_posts_where($where) {
global $wpdb;
$post_id = false;
if ( isset($_POST['post_id']) ) {
$post_id = $_POST['post_id'];
$post = get_post($post_id);
if ( $post ) {
$where .= $wpdb->prepare(" AND my_post_parent.post_type = %s ", $post->post_type);
}
}
return $where;
}
function my_posts_join($join) {
global $wpdb;
$join .= " LEFT JOIN {$wpdb->posts} as my_post_parent ON ({$wpdb->posts}.post_parent = my_post_parent.ID) ";
return $join;
}
function my_bind_media_uploader_special_filters($query) {
add_filter('posts_where', 'my_posts_where');
add_filter('posts_join', 'my_posts_join');
return $query;
}
add_filter('ajax_query_attachments_args', 'my_bind_media_uploader_special_filters');
Під час відкриття діалогового вікна завантаження медіа під час редагування публікації (публікація / сторінка / CPT) ви побачите лише зображення, додані до цього конкретного типу публікації.
Якщо ви хочете, щоб він працював лише для одного конкретного типу публікації (скажімо сторінки), вам доведеться змінити умову у my_posts_where
такій функції:
function my_posts_where($where) {
global $wpdb;
$post_id = false;
if ( isset($_POST['post_id']) ) {
$post_id = $_POST['post_id'];
$post = get_post($post_id);
if ( $post && 'page' == $post->post_type ) { // you can change 'page' to any other post type
$where .= $wpdb->prepare(" AND my_post_parent.post_type = %s ", $post->post_type);
}
}
return $where;
}