File: /var/www/html/ielts-store/wp-content/plugins/automatewoo/includes/product-functions.php
<?php
// phpcs:ignoreFile
defined( 'ABSPATH' ) || exit;
/**
 * Wrapper for wc_get_products()
 *
 * - Adds order by by popularity option
 * - Makes 'status' default to 'publish'
 *
 * @since 4.4.0
 *
 * @param array $args
 *
 * @return array|stdClass|WC_Product[]
 */
function aw_get_products( $args ) {
	add_filter( 'woocommerce_product_data_store_cpt_get_products_query', 'aw_filter_get_products_query_args', 10, 2 );
	$args = wp_parse_args(
		$args,
		[
			'status' => 'publish',
		]
	);
	$products = wc_get_products( $args );
	remove_filter( 'woocommerce_product_data_store_cpt_get_products_query', 'aw_filter_get_products_query_args', 10 );
	return $products;
}
/**
 * Filters the WC get products query args.
 *
 * Adds orderby popularity option.
 *
 * @since 4.4.0
 *
 * @param array $query      Args for WP_Query.
 * @param array $query_vars Query vars from WC_Product_Query.
 *
 * @return array
 */
function aw_filter_get_products_query_args( $query, $query_vars ) {
	if ( $query_vars['orderby'] === 'popularity' ) {
		$query['meta_key'] = 'total_sales';
		$query['orderby']  = 'meta_value_num';
	}
	return $query;
}
/**
 * Function that returns an array containing the IDs of the recent products.
 *
 * @since 2.1.0
 *
 * @param int $limit
 * @return array
 */
function aw_get_recent_product_ids( $limit = -1 ) {
	$query = new WP_Query([
		'post_type' => 'product',
		'posts_per_page' => $limit,
		'post_status' => 'publish',
		'ignore_sticky_posts' => 1,
		'no_found_rows' => true,
		'orderby' => 'date',
		'order' => 'desc',
		'fields' => 'ids',
		'meta_query' => WC()->query->get_meta_query(),
		'tax_query' => WC()->query->get_tax_query()
	]);
	return $query->posts;
}
/**
 * Function that returns an array containing the IDs of the recent products.
 *
 * @since 3.2.5
 *
 * @param int $limit
 * @return array
 */
function aw_get_top_selling_product_ids( $limit = -1 ) {
	$query = new WP_Query([
		'post_type' => 'product',
		'posts_per_page' => $limit,
		'post_status' => 'publish',
		'ignore_sticky_posts' => 1,
		'no_found_rows' => true,
		'fields' => 'ids',
		'meta_key' => 'total_sales',
		'orderby' => 'meta_value_num',
		'order' => 'desc',
		'tax_query' => WC()->query->get_tax_query(),
		'meta_query' => WC()->query->get_meta_query()
	]);
	return $query->posts;
}
/**
 * Remove unreviewable products from an array of product objects.
 *
 * @param \WC_Product[] $products
 *
 * @return \WC_Product[]
 *
 * @since 4.6.0
 */
function aw_get_reviewable_products( $products ) {
	$return = [];
	if ( ! is_array( $products ) ) {
		return [];
	}
	foreach( $products as $product ) {
		if ( ! $product instanceof WC_Product ) {
			continue;
		}
		// Replace variations with their parent product
		if ( $product->is_type( 'variation' ) ) {
			$parent = wc_get_product( $product->get_parent_id() );
			if ( $parent ) {
				// Deliberately replace duplicates
				$return[ $parent->get_id() ] = $parent;
			}
		} else {
			$return[ $product->get_id() ] = $product;
		}
	}
	return $return;
}