Merge pull request #18720 from woocommerce/fix/18683

Protect against theme support being defined too late
This commit is contained in:
Claudiu Lodromanean 2018-01-31 11:33:33 -08:00 committed by GitHub
commit fa7fb6061f
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 14 additions and 6 deletions

View File

@ -31,14 +31,22 @@ class WC_Template_Loader {
*/ */
private static $in_content_filter = false; private static $in_content_filter = false;
/**
* Is WooCommerce support defined?
*
* @var boolean
*/
private static $theme_support = false;
/** /**
* Hook in methods. * Hook in methods.
*/ */
public static function init() { public static function init() {
self::$shop_page_id = wc_get_page_id( 'shop' ); self::$theme_support = current_theme_supports( 'woocommerce' );
self::$shop_page_id = wc_get_page_id( 'shop' );
// Supported themes. // Supported themes.
if ( current_theme_supports( 'woocommerce' ) ) { if ( self::$theme_support ) {
add_filter( 'template_include', array( __CLASS__, 'template_loader' ) ); add_filter( 'template_include', array( __CLASS__, 'template_loader' ) );
add_filter( 'comments_template', array( __CLASS__, 'comments_template_loader' ) ); add_filter( 'comments_template', array( __CLASS__, 'comments_template_loader' ) );
} else { } else {
@ -103,7 +111,7 @@ class WC_Template_Loader {
$default_file = 'archive-product.php'; $default_file = 'archive-product.php';
} }
} elseif ( is_post_type_archive( 'product' ) || is_page( wc_get_page_id( 'shop' ) ) ) { } elseif ( is_post_type_archive( 'product' ) || is_page( wc_get_page_id( 'shop' ) ) ) {
$default_file = current_theme_supports( 'woocommerce' ) ? 'archive-product.php' : ''; $default_file = self::$theme_support ? 'archive-product.php' : '';
} else { } else {
$default_file = ''; $default_file = '';
} }
@ -362,7 +370,7 @@ class WC_Template_Loader {
* @return string * @return string
*/ */
public static function unsupported_theme_title_filter( $title, $id ) { public static function unsupported_theme_title_filter( $title, $id ) {
if ( ! current_theme_supports( 'woocommerce' ) && is_page( self::$shop_page_id ) && $id === self::$shop_page_id ) { if ( ! self::$theme_support && is_page( self::$shop_page_id ) && $id === self::$shop_page_id ) {
$args = self::get_current_shop_view_args(); $args = self::get_current_shop_view_args();
$title_suffix = array(); $title_suffix = array();
@ -389,7 +397,7 @@ class WC_Template_Loader {
public static function unsupported_theme_shop_content_filter( $content ) { public static function unsupported_theme_shop_content_filter( $content ) {
global $wp_query; global $wp_query;
if ( current_theme_supports( 'woocommerce' ) || ! is_main_query() ) { if ( self::$theme_support || ! is_main_query() ) {
return $content; return $content;
} }
@ -442,7 +450,7 @@ class WC_Template_Loader {
public static function unsupported_theme_product_content_filter( $content ) { public static function unsupported_theme_product_content_filter( $content ) {
global $wp_query; global $wp_query;
if ( current_theme_supports( 'woocommerce' ) || ! is_main_query() ) { if ( self::$theme_support || ! is_main_query() ) {
return $content; return $content;
} }