From b53f0aad6970be40183df7fcc7b23b3569ab1fb9 Mon Sep 17 00:00:00 2001 From: Reinhard Schneidewind Date: Sun, 13 Feb 2022 12:44:18 +0100 Subject: [PATCH] #888 update custom product attribute group mapping --- src/Migration/Step/Eav/Data.php | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/src/Migration/Step/Eav/Data.php b/src/Migration/Step/Eav/Data.php index f925ea94..6c5adac2 100644 --- a/src/Migration/Step/Eav/Data.php +++ b/src/Migration/Step/Eav/Data.php @@ -385,14 +385,25 @@ private function migrateAttributeGroups($attributeGroupIds) ); $recordsToSave = $destinationDocument->getRecords(); $recordTransformer = $this->helper->getRecordTransformer($sourceDocument, $destinationDocument); + $attributeNameMapping = $this->mapProductAttributeGroupNamesSourceDest; + $productAttributeSetIds = array_keys($this->modelData->getProductAttributeSets()); foreach ($sourceRecords as $recordData) { $recordData['attribute_group_id'] = null; $sourceRecord = $this->factory->create(['document' => $sourceDocument, 'data' => $recordData]); $destinationRecord = $this->factory->create(['document' => $destinationDocument]); $recordTransformer->transform($sourceRecord, $destinationRecord); $recordsToSave->addRecord($destinationRecord); + + $sourceAttributeGroupName = $recordData['attribute_group_name']; + $destAttributeGroupName = $destinationRecord->getValue('attribute_group_name'); + if (in_array($recordData['attribute_set_id'], $productAttributeSetIds) + && !in_array($sourceAttributeGroupName, $attributeNameMapping) + && $sourceAttributeGroupName != $destAttributeGroupName ) { + $attributeNameMapping[$sourceAttributeGroupName] = $destAttributeGroupName; + } } $this->saveRecords($destinationDocument, $recordsToSave); + $this->mapProductAttributeGroupNamesSourceDest = $attributeNameMapping; } /**