-
Notifications
You must be signed in to change notification settings - Fork 340
FAQ
If the dashboard is nearly empty and all you can see is a message saying tracking_log_session index does not exist yet. Make sure everything is reindexed
, you might be affected by the following issue.
The problem is the Fastly Image Optimization feature, as it detects h.png as an image and removes the parameters from the request.
The solution is to add a custom Fastly VCL pass removing the faslty header :
if (req.url ~ "^/elasticsuite/tracker/hit/image(/.*)?$") { set req.http.X-Fastly-Imageopto-Api = "none"; return (pass); }
If you encounters the following error :
Call to undefined method Magento\Catalog\Model\ResourceModel\Product\Collection\Interceptor::addIsInStockFilter() in ../vendor/smile/elasticsuite/src/module-elasticsuite-catalog/Plugin/LayerPlugin.php on line 56
or
Call to undefined method Magento\Catalog\Model\ResourceModel\Product\Collection\Interceptor::addSortFilterParameters() in ../vendor/smile/elasticsuite/src/module-elasticsuite-catalog/Plugin/LayerPlugin.php:78
This is due to the fact that the Product Collection getting catched by the Interceptor is not an "ElasticSuite Product Collection".
This can be due to several causes :
-
the configuration is not set properly to use ElasticSuite as search engine. You can verify that the following parameter is correctly set : Stores > Configuration > Catalog > Catalog Search > Search Engine.
-
a third party module may cause troubles by overriding the Catalog Product Collection. Please try to deactivate any third party module to find which one is causing trouble. You should look for refrences to
\Magento\Catalog\Model\ResourceModel\Product\Collection
orMagento\CatalogSearch\Model\ResourceModel\Fulltext\Collection
in the di.xml files to see who is replacing this one. -
a third party module is using unclean piece of code involving the Catalog Layer. This has been proven to be the case with Infortis Ultimo theme.
The layer should not be used to call directly the prepareProductCollection
method with a side-way created Product Collection.
Wrong Usage :
$collection = $category->getProductCollection();
....
$this->_categoryLayerFactory
->create()
->prepareProductCollection($collection);
Which should be corrected to :
$collection = $this->_categoryLayerFactory
->create()
->setCurrentCategory($category)
->getProductCollection(); // The getProductCollection method calls the prepareProductCollection() internally
Another wrong example :
// $collectionFactory is a Magento\Catalog\Model\ResourceModel\Product\CollectionFactory
$collection = $layer->prepareProductCollection($collectionFactory->create())
A correct example of call could also be :
// $collectionFactory must be a Magento\CatalogSearch\Model\ResourceModel\Fulltext\CollectionFactory
$collection = $layer->prepareProductCollection($collectionFactory->create())
This is a common problem which also occurs on Magento's native implementation.
This problem is mainly due to the fact that the pagination/sorting does not work anymore if you are doing the following things :
- you have a layout which is moving the
product_list_toolbar
block outside theListProduct
block. - you have a layout which is removing the
product_list_toolbar
. - you have a layout which is rendering the layered navigation blocks before the product listing.
You can also check for the issue on the Magento2's tracker : https://github.com/magento/magento2/issues/7253
This one can occurs when using custom theme or third party modules :
-
your third party module is removing the
header-wrapper
block. This has been proven to be the case with the Infortis Ultimo theme and a workardound has been discussed in this issue : https://github.com/Smile-SA/elasticsuite/issues/297 -
you are using a custom theme which is overriding the
form.mini.phtml
template. ElasticSuite is doing the same. You will have to mixin the two templates files in a custom module :
In a new custom module:
app/code/Vendor/ModuleName/view/frontend/layout/default.xml
:
<body>
<referenceContainer name="header-wrapper">
<block class="Smile\ElasticsuiteCore\Block\Search\Form\Autocomplete" name="top.search" as="topSearch" template="Vendor_Module::search/form.mini.phtml"/>
</referenceContainer>
</body>
And then copy (and modify) the template /vendor/smile/elasticsuite/src/module-elasticsuite-core/view/frontend/templates/search/form.mini.phtml
to /app/code/Vendor/Module/view/frontend/templates/search/form.mini.phtml
Also, to ensure loads in the right order, include in your /app/code/Vendor/Module/etc/module.xml
file:
<module name="Vendor_Module" setup_version="1.0.0">
<sequence>
<module name="Smile_ElasticsuiteCore"/>
</sequence>
</module>
Beware, this means that each time you will install a new Elasticsuite version, you will have to report the modification we made to the form.mini.phtml
to yours if needed.
You may want to see the Uninstalling the module properly page to figure out how to fix it.
-
User's Guide
-
Developer's Guide
-
Releases
- Magento 2.3.x
- Magento 2.2.x
- Magento 2.1.x
- ElasticSuite 2.5.15
- ElasticSuite 2.5.14
- ElasticSuite 2.5.13
- ElasticSuite 2.5.12
- ElasticSuite 2.5.11
- ElasticSuite 2.5.10
- ElasticSuite 2.5.9
- ElasticSuite 2.5.8
- ElasticSuite 2.5.7
- ElasticSuite 2.5.6
- ElasticSuite 2.5.5
- ElasticSuite 2.5.4
- ElasticSuite 2.5.3
- ElasticSuite 2.5.2
- ElasticSuite 2.5.1
- ElasticSuite 2.5.0
- ElasticSuite 2.4.6
- ElasticSuite 2.4.5
- ElasticSuite 2.4.4
- ElasticSuite 2.4.3
- ElasticSuite 2.4.2
- ElasticSuite 2.4.1
- ElasticSuite 2.4.0
- ElasticSuite 2.3.10
- ElasticSuite 2.3.9
- ElasticSuite 2.3.8
- ElasticSuite 2.3.7
- ElasticSuite 2.3.6
- ElasticSuite 2.3.5
- ElasticSuite 2.3.4
- ElasticSuite 2.3.3
- ElasticSuite 2.3.2
- ElasticSuite 2.3.1
- ElasticSuite 2.3.0
- Magento 2.0.x