1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
<?php
/**
* Copyright © Magento, Inc. All rights reserved.
* See COPYING.txt for license details.
*/
declare(strict_types=1);
namespace Magento\ConfigurableImportExport\Model\Export;
use Magento\Catalog\Model\ResourceModel\Product\Collection as ProductCollection;
use Magento\CatalogImportExport\Model\Export\RowCustomizerInterface;
use Magento\CatalogImportExport\Model\Import\Product as ImportProduct;
use Magento\ConfigurableProduct\Model\Product\Type\Configurable as ConfigurableProductType;
use Magento\ImportExport\Model\Import;
use Magento\Store\Model\Store;
use Magento\Store\Model\StoreManagerInterface;
/**
* Customizes output during export
*/
class RowCustomizer implements RowCustomizerInterface
{
/**
* Header column for Configurable Product variations
*/
const CONFIGURABLE_VARIATIONS_COLUMN = 'configurable_variations';
/**
* Header column for Configurable Product variation labels
*/
const CONFIGURABLE_VARIATIONS_LABELS_COLUMN = 'configurable_variation_labels';
/**
* @var array
*/
protected $configurableData = [];
/**
* @var string[]
*/
private $configurableColumns = [
self::CONFIGURABLE_VARIATIONS_COLUMN,
self::CONFIGURABLE_VARIATIONS_LABELS_COLUMN
];
/**
* @var StoreManagerInterface
*/
private $storeManager;
/**
* @param StoreManagerInterface $storeManager
*/
public function __construct(StoreManagerInterface $storeManager)
{
$this->storeManager = $storeManager;
}
/**
* Prepare configurable data for export
*
* @param ProductCollection $collection
* @param int[] $productIds
* @return void
*/
public function prepareData($collection, $productIds)
{
$productCollection = clone $collection;
$productCollection->addAttributeToFilter('entity_id', ['in' => $productIds])
->addAttributeToFilter('type_id', ['eq' => ConfigurableProductType::TYPE_CODE]);
// set global scope during export
$this->storeManager->setCurrentStore(Store::DEFAULT_STORE_ID);
while ($product = $productCollection->fetchItem()) {
$productAttributesOptions = $product->getTypeInstance()->getConfigurableOptions($product);
$this->configurableData[$product->getId()] = [];
$variations = [];
$variationsLabels = [];
foreach ($productAttributesOptions as $productAttributeOption) {
foreach ($productAttributeOption as $optValues) {
$variations[$optValues['sku']][] = $optValues['attribute_code'] . '=' . $optValues['option_title'];
if (!empty($optValues['super_attribute_label'])) {
$variationsLabels[$optValues['attribute_code']] = $optValues['attribute_code'] . '='
. $optValues['super_attribute_label'];
}
}
}
foreach ($variations as $sku => $values) {
$variations[$sku] = 'sku=' . $sku . Import::DEFAULT_GLOBAL_MULTI_VALUE_SEPARATOR
. implode(Import::DEFAULT_GLOBAL_MULTI_VALUE_SEPARATOR, $values);
}
$this->configurableData[$product->getId()] = [
self::CONFIGURABLE_VARIATIONS_COLUMN => implode(
ImportProduct::PSEUDO_MULTI_LINE_SEPARATOR,
$variations
),
self::CONFIGURABLE_VARIATIONS_LABELS_COLUMN => implode(
Import::DEFAULT_GLOBAL_MULTI_VALUE_SEPARATOR,
$variationsLabels
)
];
}
}
/**
* Set headers columns
*
* @param array $columns
* @return array
*/
public function addHeaderColumns($columns)
{
return array_merge($columns, $this->configurableColumns);
}
/**
* Add configurable data for export
*
* @param array $dataRow
* @param int $productId
* @return array
*/
public function addData($dataRow, $productId)
{
if (!empty($this->configurableData[$productId])) {
$dataRow = array_merge($dataRow, $this->configurableData[$productId]);
}
return $dataRow;
}
/**
* Calculate the largest links block
*
* @param array $additionalRowsCount
* @param int $productId
* @return array
*/
public function getAdditionalRowsCount($additionalRowsCount, $productId)
{
if (!empty($this->configurableData[$productId])) {
$additionalRowsCount = max($additionalRowsCount, count($this->configurableData[$productId]));
}
return $additionalRowsCount;
}
}