oberonlai/wp-page-template-loader

Register and render Page templates from your plugin.

v1.0.1 2021-04-08 13:03 UTC

This package is auto-updated.

Last update: 2024-12-08 20:41:12 UTC


README

A simple class that allows registering WordPress Page templates from plugins.

Installation

composer require oberonlai/wp-page-template-loader

Usage

It's super simple. Run this somewhere in your WordPress plugin:

<?php
    use ODS\PageTemplateLoader;

    $pageTemplates = new PageTemplateLoader();
    $pageTemplates->addTemplate(
        WP_PLUGIN_DIR . '/my-custom-plugin/templates/template1.php'  => 'templateName1',
        WP_PLUGIN_DIR . '/my-custom-plugin/templates/template2.php'  => 'templateName2',
    );

This adds the template to your WordPress site's Page edit interface. The addTemplate() function takes one array:

    /**
     * Add a new custom template.
     *
     * @param $template array of file path and template name
     */
    public function addTemplate( Array $template )
    {
        foreach ( $template as $key => $value ) {
            $key = str_replace('\\', '/', $key);
            $this->templates[$key] = $value;
        }
    }

Credits

This library was adapted from http://www.wpexplorer.com/wordpress-page-templates-plugin/