wpseek.com
A WordPress-centric search engine for devs and theme authors



get_block_template › WordPress Function

Since5.8.0
Deprecatedn/a
get_block_template ( $id, $template_type = 'wp_template' )
Parameters: (2)
  • (string) $id Template unique identifier (example: 'theme_slug//template_slug').
    Required: Yes
  • (string) $template_type Optional. Template type. Either 'wp_template' or 'wp_template_part'. Default 'wp_template'.
    Required: No
    Default: 'wp_template'
Returns:
  • (WP_Block_Template|null) Template.
Defined at:
Codex:

Retrieves a single unified template object using its id.



Source

function get_block_template( $id, $template_type = 'wp_template' ) {
	/**
	 * Filters the block template object before the query takes place.
	 *
	 * Return a non-null value to bypass the WordPress queries.
	 *
	 * @since 5.9.0
	 *
	 * @param WP_Block_Template|null $block_template Return block template object to short-circuit the default query,
	 *                                               or null to allow WP to run its normal queries.
	 * @param string                 $id             Template unique identifier (example: 'theme_slug//template_slug').
	 * @param string                 $template_type  Template type. Either 'wp_template' or 'wp_template_part'.
	 */
	$block_template = apply_filters( 'pre_get_block_template', null, $id, $template_type );
	if ( ! is_null( $block_template ) ) {
		return $block_template;
	}

	$parts = explode( '//', $id, 2 );
	if ( count( $parts ) < 2 ) {
		return null;
	}
	list( $theme, $slug ) = $parts;

	$active_templates = get_option( 'active_templates', array() );

	if ( ! empty( $active_templates[ $slug ] ) ) {
		if ( is_int( $active_templates[ $slug ] ) ) {
			$post = get_post( $active_templates[ $slug ] );
			if ( $post && 'publish' === $post->post_status ) {
				$template = _build_block_template_result_from_post( $post );

				if ( ! is_wp_error( $template ) && $theme === $template->theme ) {
					return $template;
				}
			}
		} elseif ( false === $active_templates[ $slug ] ) {
			return null;
		}
	}

	$wp_query_args  = array(
		'post_name__in'  => array( $slug ),
		'post_type'      => $template_type,
		'post_status'    => array( 'auto-draft', 'draft', 'publish', 'trash' ),
		'posts_per_page' => 1,
		'no_found_rows'  => true,
		'tax_query'      => array(
			array(
				'taxonomy' => 'wp_theme',
				'field'    => 'name',
				'terms'    => $theme,
			),
		),
	);
	$template_query = new WP_Query( $wp_query_args );
	$posts          = $template_query->posts;

	if ( count( $posts ) > 0 ) {
		$template = _build_block_template_result_from_post( $posts[0] );

		// Custom templates don't need to be activated, so if it's a custom
		// template, return it.
		if ( ! is_wp_error( $template ) && $template->is_custom ) {
			return $template;
		}

		if ( ! is_wp_error( $template ) ) {
			return $template;
		}
	}

	$block_template = get_block_file_template( $id, $template_type );

	/**
	 * Filters the queried block template object after it's been fetched.
	 *
	 * @since 5.9.0
	 *
	 * @param WP_Block_Template|null $block_template The found block template, or null if there isn't one.
	 * @param string                 $id             Template unique identifier (example: 'theme_slug//template_slug').
	 * @param string                 $template_type  Template type. Either 'wp_template' or 'wp_template_part'.
	 */
	return apply_filters( 'get_block_template', $block_template, $id, $template_type );
}