WC_Product_Data_Store_CPT::create_all_product_variations( WC_Product $product, int $limit = -1 )
Creates all possible combinations of variations from the attributes, without creating duplicates.
Description Description
Parameters Parameters
- $product
-
(Required) Variable product.
- $limit
-
(Optional) Limit the number of created variations.
Default value: -1
Return Return
(int) Number of created variations.
Source Source
File: includes/data-stores/class-wc-product-data-store-cpt.php
public function create_all_product_variations( $product, $limit = -1 ) { $count = 0; if ( ! $product ) { return $count; } $attributes = wc_list_pluck( array_filter( $product->get_attributes(), 'wc_attributes_array_filter_variation' ), 'get_slugs' ); if ( empty( $attributes ) ) { return $count; } // Get existing variations so we don't create duplicates. $existing_variations = array_map( 'wc_get_product', $product->get_children() ); $existing_attributes = array(); foreach ( $existing_variations as $existing_variation ) { $existing_attributes[] = $existing_variation->get_attributes(); } $possible_attributes = array_reverse( wc_array_cartesian( $attributes ) ); foreach ( $possible_attributes as $possible_attribute ) { // Allow any order if key/values -- do not use strict mode. if ( in_array( $possible_attribute, $existing_attributes ) ) { // phpcs:ignore WordPress.PHP.StrictInArray.MissingTrueStrict continue; } $variation = wc_get_product_object( 'variation' ); $variation->set_parent_id( $product->get_id() ); $variation->set_attributes( $possible_attribute ); $variation_id = $variation->save(); do_action( 'product_variation_linked', $variation_id ); $count ++; if ( $limit > 0 && $count >= $limit ) { break; } } return $count; }
Changelog Changelog
Version | Description |
---|---|
3.6.0 | Introduced. |