How can I list all pages with their templates?
I want to list all site pages with the template they use.
Is there a mod to wp_list_pages which does this?
Topic wp-list-pages Wordpress
Category Web
I want to list all site pages with the template they use.
Is there a mod to wp_list_pages which does this?
Topic wp-list-pages Wordpress
Category Web
Using phpmyadmin (sql) you can run this query to get a list of all pages with its used template:
SELECT p.post_name, p.post_title, meta_key, meta_value FROM `wp_postmeta` INNER JOIN wp_posts p ON p.ID = post_id WHERE meta_key='_wp_page_template' ORDER BY meta_value, p.post_name
Rather than do this in PHP, you can do it with this mysql:
SELECT distinct meta_value FROM `wp_postmeta` WHERE meta_key='_wp_page_template'
I just needed it for a quick check so that I could clean up unused templates with the theme_page_templates filter.
https://codex.wordpress.org/Function_Reference/get_page_template_slug
a basic query to get all pages, sorted by title, then output page title and template file name:
$args = array(
    'post_type' => array( 'page' ),
    'order' => 'ASC',
    'orderby' => 'title'
    );
$the_query = new WP_Query( $args );
if ( $the_query->have_posts() ) {
    while ( $the_query->have_posts() ) {
        $the_query->the_post();
        echo '<p>'; 
        the_title();
        echo ' - ';
        echo get_page_template_slug(); 
        echo '</p>';
    }
    wp_reset_postdata();
}
I have tried flowing code to get all page with template, and worked perfect for me. this code purpose was to get all custom page template,as i was developed single page template.
$args = array(
    "post_type" => "page",
    "order" => "ASC",
    "orderby" => "menu_order"
);
$the_query = new WP_Query( $args );
if ( have_posts() ) {
    while ( $the_query->have_posts() ) {
        $the_query->the_post();
        ?>
        <div id="post-<?php the_ID() ?>">
        <?php
        global $post;
        $slug = $post->post_name;
        get_template_part("page", $slug);
        ?>
        </div>
        <?php
    }
    wp_reset_postdata();
}
Geeks Mental is a community that publishes articles and tutorials about Web, Android, Data Science, new techniques and Linux security.