|
| 1 | +diff -Nuar a/vendor/magento/module-shared-catalog/Model/SearchAdapter/Aggregation/Builder/DataProvider.php b/vendor/magento/module-shared-catalog/Model/SearchAdapter/Aggregation/Builder/DataProvider.php |
| 2 | +--- a/vendor/magento/module-shared-catalog/Model/SearchAdapter/Aggregation/Builder/DataProvider.php |
| 3 | ++++ b/vendor/magento/module-shared-catalog/Model/SearchAdapter/Aggregation/Builder/DataProvider.php |
| 4 | +@@ -103,18 +103,16 @@ public function __construct( |
| 5 | + * |
| 6 | + * @param BucketInterface $bucket |
| 7 | + * @param array $dimensions |
| 8 | +- * @param array $documentIds |
| 9 | + * @return array |
| 10 | + * @throws \Magento\Framework\Exception\LocalizedException |
| 11 | + * @throws \Zend_Db_Statement_Exception |
| 12 | + */ |
| 13 | + public function getAggregation( |
| 14 | + BucketInterface $bucket, |
| 15 | +- array $dimensions, |
| 16 | +- array $documentIds |
| 17 | ++ array $dimensions |
| 18 | + ) { |
| 19 | + $result = []; |
| 20 | +- $select = $this->getSelect($bucket, $dimensions, $documentIds); |
| 21 | ++ $select = $this->getSelect($bucket, $dimensions); |
| 22 | + $query = $this->connection->query($select); |
| 23 | + |
| 24 | + while ($row = $query->fetch()) { |
| 25 | +@@ -134,11 +132,10 @@ public function getAggregation( |
| 26 | + * |
| 27 | + * @param BucketInterface $bucket |
| 28 | + * @param array $dimensions |
| 29 | +- * @param array $documentIds |
| 30 | + * @return Select |
| 31 | + * @throws \Magento\Framework\Exception\LocalizedException |
| 32 | + */ |
| 33 | +- private function getSelect(BucketInterface $bucket, array $dimensions, array $documentIds) |
| 34 | ++ private function getSelect(BucketInterface $bucket, array $dimensions) |
| 35 | + { |
| 36 | + $attribute = $this->eavConfig->getAttribute(Product::ENTITY, $bucket->getField()); |
| 37 | + $currentScope = $this->scopeResolver->getScope($dimensions['scope']->getValue()); |
| 38 | +@@ -161,7 +158,6 @@ private function getSelect(BucketInterface $bucket, array $dimensions, array $do |
| 39 | + 'source_entity.sku = shared_catalog_item.sku', |
| 40 | + [] |
| 41 | + ) |
| 42 | +- ->where('eav.entity_id IN (?)', $documentIds) |
| 43 | + ->where('eav.attribute_id = ?', $attribute->getId()) |
| 44 | + ->where('eav.store_id = ? ', $currentScope->getId()) |
| 45 | + ->where('source_entity.type_id <> ?', 'configurable') |
| 46 | +diff -Nuar a/vendor/magento/module-shared-catalog/Plugin/Elasticsearch/SearchAdapter/Aggregation/Builder/UpdateTermBucketBuilderPlugin.php b/vendor/magento/module-shared-catalog/Plugin/Elasticsearch/SearchAdapter/Aggregation/Builder/UpdateTermBucketBuilderPlugin.php |
| 47 | +--- a/vendor/magento/module-shared-catalog/Plugin/Elasticsearch/SearchAdapter/Aggregation/Builder/UpdateTermBucketBuilderPlugin.php |
| 48 | ++++ b/vendor/magento/module-shared-catalog/Plugin/Elasticsearch/SearchAdapter/Aggregation/Builder/UpdateTermBucketBuilderPlugin.php |
| 49 | +@@ -65,8 +65,7 @@ public function afterBuild( |
| 50 | + $shouldAggregate = ($bucket->getField() !== 'category_ids'); |
| 51 | + |
| 52 | + if ($sharedCatalogIsEnabled && $shouldAggregate) { |
| 53 | +- $documentIds = array_column($queryResult['hits']['hits'], '_id'); |
| 54 | +- $values = $this->dataProvider->getAggregation($bucket, $dimensions, $documentIds); |
| 55 | ++ $values = $this->dataProvider->getAggregation($bucket, $dimensions); |
| 56 | + } |
| 57 | + |
| 58 | + return $values; |
0 commit comments