PUM_Utils_Template

Class PUM_Utils_Template


Description Description


Source Source

File: classes/Utils/Template.php

class PUM_Utils_Template {

	/**
	 * @return array
	 */
	public static function paths() {
		$template_dir = apply_filters( 'pum_template_path', 'popup-maker' );

		$old_template_dir = apply_filters( 'popmake_templates_dir', 'popmake_templates' );

		$file_paths = apply_filters( 'pum_template_paths', array(
			1   => trailingslashit( get_stylesheet_directory() ) . $template_dir,
			2   => trailingslashit( get_stylesheet_directory() ) . $old_template_dir,
			10  => trailingslashit( get_template_directory() ) . $template_dir,
			11  => trailingslashit( get_template_directory() ) . $old_template_dir,
			100 => Popup_Maker::$DIR . 'templates',
		) );

		/* @deprecated 1.8.9 */
		$file_paths = apply_filters( 'popmake_template_paths', $file_paths );

		// sort the file paths based on priority
		ksort( $file_paths, SORT_NUMERIC );

		return array_map( 'trailingslashit', $file_paths );
	}

	/**
	 * Locate a template and return the path for inclusion.
	 *
	 * This is the load order:
	 *
	 *        yourtheme        /    $template_path    /    $template_name
	 *        yourtheme        /    $template_name
	 *        $default_path    /    $template_name
	 *
	 * @access   public
	 *
	 * @param string|array $template_names
	 * @param bool         $load
	 * @param bool         $require_once
	 *
	 * @return string
	 * @internal param string $template_path (default: '')
	 * @internal param string $default_path (default: '')
	 *
	 */
	public static function locate( $template_names, $load = false, $require_once = true ) {
		// No file found yet
		$located = false;

		$template_name = '';

		// Try to find a template file
		foreach ( (array) $template_names as $template_name ) {

			// Continue if template is empty
			if ( empty( $template_name ) ) {
				continue;
			}

			// Trim off any slashes from the template name
			$template_name = ltrim( $template_name, '/' );

			// try locating this template file by looping through the template paths
			foreach ( self::paths() as $template_path ) {

				if ( file_exists( $template_path . $template_name ) ) {
					$located = $template_path . $template_name;
					break;
				}
			}

			if ( $located ) {
				break;
			}
		}

		// Return what we found
		$located = apply_filters( 'pum_locate_template', $located, $template_name );

		if ( ( true == $load ) && ! empty( $located ) ) {
			load_template( $located, $require_once );
		}

		return $located;
	}

	/**
	 * Locate a template part (for templates like the topic-loops).
	 *
	 * Popup_Maker::$DEBUG will prevent overrides in themes from taking priority.
	 *
	 * @param mixed       $slug
	 * @param string|bool $name (default: false)
	 * @param bool        $load
	 *
	 * @return string
	 */
	public static function locate_part( $slug, $name = null, $load = false ) {
		$templates = array();
		if ( $name ) {
			// slug-name.php
			$templates[] = "{$slug}-{$name}.php";
		}

		// slug.php
		$templates[] = "{$slug}.php";

		// Allow template parts to be filtered
		$templates = apply_filters( 'pum_locate_template_part', $templates, $slug, $name );

		/* @deprecated 1.8.0 */
		$templates = apply_filters( 'popmake_get_template_part', $templates, $slug, $name );

		// Return the part that is found
		return self::locate( $templates, $load, false );
	}

	/**
	 * Render file with extracted arguments.
	 *
	 * @param       $template
	 * @param array $args
	 */
	public static function render( $template, $args = array() ) {

		if ( ! $template || ! file_exists( $template ) ) {
			_doing_it_wrong( __FUNCTION__, sprintf( '<code>%s</code> does not exist.', $template ), '1.0.0' );

			return;
		}

		if ( $args && is_array( $args ) ) {
			extract( $args );
		}

		include $template;
	}

	/**
	 * Render a template part in $slug-$name.php fashion.
	 *
	 * Allows passing arguments that will be globally accessible in the template.
	 *
	 * @param string $slug
	 * @param string $name
	 * @param array  $args
	 */
	public static function part( $slug, $name = null, $args = array() ) {
		echo self::get_part( $slug, $name, $args );
	}

	/**
	 * Get a template part in $slug-$name.php fashion.
	 *
	 * Allows passing arguments that will be globally accessible in the template.
	 *
	 * @param string $slug
	 * @param string $name
	 * @param array  $args
	 *
	 * @return string
	 */
	public static function get_part( $slug, $name = null, $args = array() ) {

		$template = self::locate_part( $slug, $name );

		ob_start();

		do_action( 'pum_before_template_part', $template, $slug, $name, $args );

		/* @deprecated 1.8.0 */
		do_action( 'get_template_part_' . $slug, $slug, $name );

		self::render( $template, $args );

		do_action( 'pum_after_template_part', $template, $slug, $name, $args );

		return ob_get_clean();
	}

	/**
	 * Gets the rendered contents of the specified template file.
	 *
	 * @param       $template_name
	 * @param array $args
	 *
	 * @return string
	 */
	public static function get( $template_name, $args = array() ) {
		$template = self::locate( $template_name );

		// Allow 3rd party plugin filter template file from their plugin.
		$template = apply_filters( 'pum_get_template', $template, $template_name, $args );

		ob_start();

		do_action( 'pum_before_template', $template_name, $template, $args );

		self::render( $template, $args );

		do_action( 'pum_after_template', $template_name, $template, $args );

		return ob_get_clean();
	}

	/**
	 * Get other templates (e.g. popup content) passing attributes and including the file.
	 *
	 * @deprecated  public
	 *
	 * @param string $template_name Template file name with extension: file-name.php
	 * @param array  $args          (default: array())
	 */
	public static function load( $template_name, $args = array() ) {
		echo self::get( $template_name, $args );
	}

}

Top ↑

Methods Methods

  • get — Gets the rendered contents of the specified template file.
  • get_part — Get a template part in $slug-$name.php fashion.
  • load — Get other templates (e.g. popup content) passing attributes and including the file. — deprecated
  • locate — Locate a template and return the path for inclusion.
  • locate_part — Locate a template part (for templates like the topic-loops).
  • part — Render a template part in $slug-$name.php fashion.
  • paths
  • render — Render file with extracted arguments.

Top ↑

User Contributed Notes User Contributed Notes

You must log in before being able to contribute a note or feedback.