Solo un punto de partida, ya que seguramente surgirán problemas durante el desarrollo posterior. Por ejemplo, en este momento, la funcionalidad de búsqueda se rompe ya que espera una cadena (post_type) y recibe una matriz.
Para enumerar más de un tipo de publicación en la pantalla Publicaciones, conectamos pre_get_posts
y modificamos la consulta. En esta prueba, las publicaciones, las páginas y los productos se mostrarán juntos en la pantalla Publicaciones ( http://example.com/wp-admin/edit.php
).
add_action( 'pre_get_posts', 'join_cpt_list_wspe_113808' );
function join_cpt_list_wspe_113808( $query )
{
// If not backend, bail out
if( !is_admin() )
return $query;
// Detect current page and list of CPTs to be shown in Dashboard > Posts > Edit screen
global $pagenow;
$cpts = array( 'post', 'page', 'product' );
if( 'edit.php' == $pagenow && ( get_query_var('post_type') && 'post' == get_query_var('post_type') ) )
$query->set( 'post_type', $cpts );
return $query;
}
Un código auxiliar para mostrar una columna con cada publicación Tipo de publicación:
add_filter( 'manage_edit-post_columns', 'add_cpt_column_wspe_113808' );
foreach( array( 'post', 'page', 'product' ) as $cpt )
add_action( "manage_{$cpt}_posts_custom_column", 'show_cpt_column_wspe_113808', 10, 2 );
function add_cpt_column_wspe_113808( $columns )
{
$columns[ 'cpt' ] = 'Post Type';
return $columns;
}
function show_cpt_column_wspe_113808( $column_name, $post_id )
{
if ( 'cpt' != $column_name )
return;
echo get_post_type( $post_id );
}