You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
146 lines
3.9 KiB
PHTML
146 lines
3.9 KiB
PHTML
8 months ago
|
<?php
|
||
|
/**
|
||
|
* Add Open Graph data for the WooCommerce module.
|
||
|
*
|
||
|
* @since 1.0.32
|
||
|
* @package RankMath
|
||
|
* @subpackage RankMath\WooCommerce
|
||
|
* @author Rank Math <support@rankmath.com>
|
||
|
*/
|
||
|
|
||
|
namespace RankMath\WooCommerce;
|
||
|
|
||
|
use RankMath\OpenGraph\Image as OpenGraph_Image;
|
||
|
|
||
|
defined( 'ABSPATH' ) || exit;
|
||
|
|
||
|
/**
|
||
|
* WC Opengraph class.
|
||
|
*/
|
||
|
class Opengraph extends Sitemap {
|
||
|
|
||
|
/**
|
||
|
* Register hooks.
|
||
|
*/
|
||
|
public function opengraph() {
|
||
|
$this->filter( 'language_attributes', 'og_product_namespace', 11 );
|
||
|
$this->filter( 'rank_math/opengraph/desc', 'og_desc_product_taxonomy' );
|
||
|
$this->action( 'rank_math/opengraph/facebook', 'og_enhancement', 50 );
|
||
|
$this->action( 'rank_math/opengraph/facebook/add_additional_images', 'set_opengraph_image' );
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Add the OpenGraph namespace.
|
||
|
*
|
||
|
* @param string $namespace The original namespace.
|
||
|
*
|
||
|
* @return string
|
||
|
*/
|
||
|
public function og_product_namespace( $namespace ) {
|
||
|
if ( is_singular( 'product' ) ) {
|
||
|
$namespace = preg_replace( '/prefix="([^"]+)"/', 'prefix="$1 product: https://ogp.me/ns/product#"', $namespace );
|
||
|
}
|
||
|
|
||
|
return $namespace;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Make sure the OpenGraph description is put out.
|
||
|
*
|
||
|
* @param string $desc The current description, will be overwritten if we're on a product page.
|
||
|
*
|
||
|
* @return string
|
||
|
*/
|
||
|
public function og_desc_product_taxonomy( $desc ) {
|
||
|
if ( is_product_taxonomy() ) {
|
||
|
$term_desc = term_description();
|
||
|
if ( ! empty( $term_desc ) ) {
|
||
|
$desc = wp_strip_all_tags( $term_desc, true );
|
||
|
$desc = strip_shortcodes( $desc );
|
||
|
}
|
||
|
}
|
||
|
|
||
|
return $desc;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Adds the other product images to the OpenGraph output.
|
||
|
*
|
||
|
* @param OpenGraph $opengraph The current opengraph network object.
|
||
|
*/
|
||
|
public function og_enhancement( $opengraph ) {
|
||
|
$product = $this->get_product();
|
||
|
if ( ! is_object( $product ) ) {
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
$brand = WooCommerce::get_brands( get_the_ID() );
|
||
|
if ( ! empty( $brand ) ) {
|
||
|
$opengraph->tag( 'product:brand', $brand );
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Allow developers to prevent the output of the price in the OpenGraph tags.
|
||
|
*
|
||
|
* @param bool unsigned Defaults to true.
|
||
|
*/
|
||
|
if ( $this->do_filter( 'woocommerce/og_price', ! $product->is_type( 'variable' ) ) ) {
|
||
|
$opengraph->tag( 'product:price:amount', $product->get_price() );
|
||
|
$opengraph->tag( 'product:price:currency', get_woocommerce_currency() );
|
||
|
}
|
||
|
|
||
|
if ( $product->is_in_stock() ) {
|
||
|
$opengraph->tag( 'product:availability', 'instock' );
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Adds the opengraph images.
|
||
|
*
|
||
|
* @param OpenGraph_Image $opengraph_image The OpenGraph image to use.
|
||
|
*/
|
||
|
public function set_opengraph_image( OpenGraph_Image $opengraph_image ) {
|
||
|
if ( ! function_exists( 'is_product_category' ) || is_product_category() ) {
|
||
|
global $wp_query;
|
||
|
$cat = $wp_query->get_queried_object();
|
||
|
$thumbnail_id = get_term_meta( $cat->term_id, 'thumbnail_id', true );
|
||
|
$opengraph_image->add_image_by_id( $thumbnail_id );
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Passing a truthy value to the filter will effectively short-circuit the process of adding gallery images.
|
||
|
*
|
||
|
* @param bool $return Short-circuit return value. Either false or true.
|
||
|
*/
|
||
|
if ( ! $this->do_filter( 'woocommerce/opengraph/add_gallery_images', false ) ) {
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
$product = $this->get_product();
|
||
|
if ( ! is_object( $product ) ) {
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
$this->set_image_ids( $product, $opengraph_image );
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Set images for the given product.
|
||
|
*
|
||
|
* @param WC_Product $product The product to get the image ids for.
|
||
|
* @param OpenGraph_Image $opengraph_image The OpenGraph image to use.
|
||
|
*/
|
||
|
protected function set_image_ids( $product, $opengraph_image ) {
|
||
|
$img_ids = method_exists( $product, 'get_gallery_image_ids' ) ?
|
||
|
$product->get_gallery_image_ids() : $product->get_gallery_attachment_ids();
|
||
|
|
||
|
if ( ! is_array( $img_ids ) || empty( $img_ids ) ) {
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
foreach ( $img_ids as $img_id ) {
|
||
|
$opengraph_image->add_image_by_id( $img_id );
|
||
|
}
|
||
|
}
|
||
|
}
|