product variants table split off from category variants table, variant values table updated to reflect
This commit is contained in:
@@ -53,7 +53,8 @@ class ProductSkusController extends AppController
|
||||
$productSku = $this->ProductSkus->get($id, contain: [
|
||||
'Products',
|
||||
'ProductSkuVariantValues',
|
||||
'ProductSkuVariantValues.ProductCategoryVariants',
|
||||
'ProductSkuVariantValues.ProductVariants',
|
||||
'ProductSkuVariantValues.ProductVariants.ProductCategoryVariants',
|
||||
'ProductSkuVariantValues.ProductCategoryVariantOptions',
|
||||
]);
|
||||
$this->set(compact('productSku'));
|
||||
@@ -70,27 +71,50 @@ class ProductSkusController extends AppController
|
||||
$productSkus = [];
|
||||
$table = $this->getTable();
|
||||
|
||||
$productCategoryVariants = $table->Products->ProductCategoryVariants->find()
|
||||
->contain(['ProductCategoryVariantOptions'])
|
||||
->where(['product_id' => $productId])
|
||||
->toArray();
|
||||
$optionMapping = Hash::combine($productCategoryVariants, '{n}.product_category_variant_options.{n}.id', '{n}.product_category_variant_options.{n}.variant_value');
|
||||
$variantNameMapping = Hash::combine($productCategoryVariants, '{n}.id', '{n}.name');
|
||||
foreach ($productCategoryVariants as $productCategoryVariant) {
|
||||
$options = Hash::extract($productCategoryVariant->product_category_variant_options ?? [], '{n}.id');
|
||||
$toGetCartesianProductsFrom[$productCategoryVariant->id] = $options;
|
||||
$product = $table->Products->get($productId, contain: [
|
||||
'ProductSkus',
|
||||
'ProductSkus.ProductSkuVariantValues',
|
||||
'ProductVariants',
|
||||
'ProductVariants.ProductCategoryVariants',
|
||||
'ProductVariants.ProductCategoryVariants.ProductCategoryVariantOptions',
|
||||
]);
|
||||
$existingProductSkus = Hash::combine($product->product_skus ?? [], '{n}.id', '{n}');
|
||||
$existingProductSkusForMapping = Hash::combine($product->product_skus ?? [], '{n}.id', '{n}.product_sku_variant_values');
|
||||
$existingSkusForCartesianComparison = [];
|
||||
foreach ($existingProductSkusForMapping as $existingProductSkuId => $existingProductSku) {
|
||||
$existingSkusForCartesianComparison[$existingProductSkuId] = Hash::combine($existingProductSku, '{n}.product_category_variant_id', '{n}.product_category_variant_option_id');
|
||||
}
|
||||
$productVariants = isset($product->product_variants) ? $product->product_variants : [];
|
||||
// dd($productVariants);
|
||||
$productVariantsMapping = Hash::combine($productVariants, '{n}.product_category_variant.id', '{n}.id');
|
||||
$productCategoryVariants = Hash::extract($productVariants, '{n}.product_category_variant');
|
||||
// dd($productCategoryVariants);
|
||||
$optionMapping = Hash::combine($productCategoryVariants, '{n}.product_category_variant_options.{n}.id', '{n}.product_category_variant_options.{n}.variant_value');
|
||||
// dd($optionMapping);
|
||||
|
||||
$variantNameMapping = Hash::combine($productCategoryVariants, '{n}.id', '{n}.name');
|
||||
// dd($variantNameMapping);
|
||||
|
||||
foreach ($productCategoryVariants as $productCategoryVariant) {
|
||||
$options = Hash::extract($productCategoryVariant['product_category_variant_options'] ?? [], '{n}.id');
|
||||
$toGetCartesianProductsFrom[$productCategoryVariant['id']] = $options;
|
||||
}
|
||||
// dd($toGetCartesianProductsFrom);
|
||||
|
||||
$numSkusToAdd = count(combinations($toGetCartesianProductsFrom));
|
||||
for ($i = 0; $i < $numSkusToAdd; $i++) {
|
||||
$productSkus[$i] = $this->getTable()->newEmptyEntity();
|
||||
}
|
||||
$this->set(compact(
|
||||
'product',
|
||||
'productSkus',
|
||||
'productCategoryVariants',
|
||||
'toGetCartesianProductsFrom',
|
||||
'optionMapping',
|
||||
'variantNameMapping',
|
||||
'numSkusToAdd'
|
||||
'numSkusToAdd',
|
||||
'existingProductSkus',
|
||||
'existingSkusForCartesianComparison'
|
||||
));
|
||||
|
||||
if ($this->request->is('post')) {
|
||||
@@ -109,9 +133,8 @@ class ProductSkusController extends AppController
|
||||
],
|
||||
'associated' => [
|
||||
'ProductSkuVariantValues' => [
|
||||
'validate' => false,
|
||||
'fields' => [
|
||||
'product_category_variant_id',
|
||||
'product_variant_id',
|
||||
'product_category_variant_option_id',
|
||||
],
|
||||
],
|
||||
@@ -121,7 +144,7 @@ class ProductSkusController extends AppController
|
||||
$postedSkus = Hash::insert($postedSkus, '{n}.product_id', $productId);
|
||||
|
||||
foreach ($postedSkus as $postedSkuCnt => $postedSku) {
|
||||
if (!isset($postedSku['add']) || !$postedSku['add']) {
|
||||
if (!isset($postedSku['sku']) || !$postedSku['sku']) {
|
||||
unset($productSkus[$postedSkuCnt]);
|
||||
|
||||
continue;
|
||||
@@ -133,7 +156,7 @@ class ProductSkusController extends AppController
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
// dd($finalPostData);
|
||||
$productSkus = $table->patchEntities($productSkus, $finalPostData, $saveOptions);
|
||||
$errors = [];
|
||||
$successes = [];
|
||||
@@ -143,7 +166,7 @@ class ProductSkusController extends AppController
|
||||
if (!$table->save($productSkuToSave, $saveOptions)) {
|
||||
Log::debug(print_r('$productSkuToSave->getErrors()', true));
|
||||
Log::debug(print_r($productSkuToSave->getErrors(), true));
|
||||
|
||||
dd($productSkuToSave->getErrors());
|
||||
continue;
|
||||
}
|
||||
$successes[] = $productSkuToSave;
|
||||
|
||||
@@ -58,8 +58,11 @@ class ProductsController extends AppController
|
||||
'ProductAttributes',
|
||||
'ProductAttributes.ProductCategoryAttributes',
|
||||
'ProductAttributes.ProductCategoryAttributeOptions',
|
||||
'ProductCategoryVariants',
|
||||
'ProductSkus'
|
||||
'ProductVariants',
|
||||
'ProductVariants.ProductCategoryVariants',
|
||||
'ProductVariants.ProductCategoryVariants.ProductCategoryVariantOptions',
|
||||
'ProductSkus',
|
||||
'ProductPhotos',
|
||||
]);
|
||||
$this->set(compact('product'));
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user