From ca94c106da0c4c5cbf2b30f907db5ce3ec2ac03d Mon Sep 17 00:00:00 2001 From: andreishichko Date: Tue, 16 Jul 2024 13:47:03 +0300 Subject: [PATCH] MAGE-6 Fix: recommend.js get null from script when script loading before definition configuration --- view/frontend/web/recommend.js | 159 +++++++++++++++++---------------- 1 file changed, 84 insertions(+), 75 deletions(-) diff --git a/view/frontend/web/recommend.js b/view/frontend/web/recommend.js index f98ec6c31..15684a325 100644 --- a/view/frontend/web/recommend.js +++ b/view/frontend/web/recommend.js @@ -8,107 +8,116 @@ define([ ],function ($, algoliaBundle, recommend, recommendJs, recommendProductsHtml) { 'use strict'; - if (typeof algoliaConfig === 'undefined') { - return; - } - return function (config, element) { - $(function ($) { - this.defaultIndexName = algoliaConfig.indexName + '_products'; - const appId = algoliaConfig.applicationId; - const apiKey = algoliaConfig.apiKey; - const recommendClient = recommend(appId, apiKey); - const indexName = this.defaultIndexName; - if ($('body').hasClass('catalog-product-view') || $('body').hasClass('checkout-cart-index')) { - // --- Add the current product objectID here --- - if ((algoliaConfig.recommend.enabledFBT && $('body').hasClass('catalog-product-view')) || (algoliaConfig.recommend.enabledFBTInCart && $('body').hasClass('checkout-cart-index'))) { - recommendJs.frequentlyBoughtTogether({ - container: '#frequentlyBoughtTogether', + + function checkerConfigLoading() { + if (typeof algoliaConfig === 'undefined') + setTimeout(checkerConfigLoading, '500') + else + exec() + } + + function exec() { + + $(function ($) { + this.defaultIndexName = algoliaConfig.indexName + '_products'; + const appId = algoliaConfig.applicationId; + const apiKey = algoliaConfig.apiKey; + const recommendClient = recommend(appId, apiKey); + const indexName = this.defaultIndexName; + if ($('body').hasClass('catalog-product-view') || $('body').hasClass('checkout-cart-index')) { + // --- Add the current product objectID here --- + if ((algoliaConfig.recommend.enabledFBT && $('body').hasClass('catalog-product-view')) || (algoliaConfig.recommend.enabledFBTInCart && $('body').hasClass('checkout-cart-index'))) { + recommendJs.frequentlyBoughtTogether({ + container: '#frequentlyBoughtTogether', + recommendClient, + indexName, + objectIDs: config.algoliObjectId, + maxRecommendations: algoliaConfig.recommend.limitFBTProducts, + transformItems: function (items) { + return items.map((item, index) => ({ + ...item, + position: index + 1, + })); + }, + headerComponent({html}) { + return recommendProductsHtml.getHeaderHtml(html, algoliaConfig.recommend.FBTTitle); + }, + itemComponent({item, html}) { + return recommendProductsHtml.getItemHtml(item, html, algoliaConfig.recommend.isAddToCartEnabledInFBT); + }, + }); + } + if ((algoliaConfig.recommend.enabledRelated && $('body').hasClass('catalog-product-view')) || (algoliaConfig.recommend.enabledRelatedInCart && $('body').hasClass('checkout-cart-index'))) { + recommendJs.relatedProducts({ + container: '#relatedProducts', + recommendClient, + indexName, + objectIDs: config.algoliObjectId, + maxRecommendations: algoliaConfig.recommend.limitRelatedProducts, + transformItems: function (items) { + return items.map((item, index) => ({ + ...item, + position: index + 1, + })); + }, + headerComponent({html}) { + return recommendProductsHtml.getHeaderHtml(html, algoliaConfig.recommend.relatedProductsTitle); + }, + itemComponent({item, html}) { + return recommendProductsHtml.getItemHtml(item, html, algoliaConfig.recommend.isAddToCartEnabledInRelatedProduct); + }, + }); + } + } + + if ((algoliaConfig.recommend.isTrendItemsEnabledInPDP && $('body').hasClass('catalog-product-view')) || (algoliaConfig.recommend.isTrendItemsEnabledInCartPage && $('body').hasClass('checkout-cart-index'))) { + recommendJs.trendingItems({ + container: '#trendItems', + facetName: algoliaConfig.recommend.trendItemFacetName ? algoliaConfig.recommend.trendItemFacetName : '', + facetValue: algoliaConfig.recommend.trendItemFacetValue ? algoliaConfig.recommend.trendItemFacetValue : '', recommendClient, indexName, - objectIDs: config.algoliObjectId, - maxRecommendations: algoliaConfig.recommend.limitFBTProducts, - transformItems:function (items) { + maxRecommendations: algoliaConfig.recommend.limitTrendingItems, + transformItems: function (items) { return items.map((item, index) => ({ ...item, position: index + 1, })); }, headerComponent({html}) { - return recommendProductsHtml.getHeaderHtml(html,algoliaConfig.recommend.FBTTitle); + return recommendProductsHtml.getHeaderHtml(html, algoliaConfig.recommend.trendingItemsTitle); }, itemComponent({item, html}) { - return recommendProductsHtml.getItemHtml(item, html, algoliaConfig.recommend.isAddToCartEnabledInFBT); + return recommendProductsHtml.getItemHtml(item, html, algoliaConfig.recommend.isAddToCartEnabledInTrendsItem); }, }); - } - if ((algoliaConfig.recommend.enabledRelated && $('body').hasClass('catalog-product-view')) || (algoliaConfig.recommend.enabledRelatedInCart && $('body').hasClass('checkout-cart-index'))) { - recommendJs.relatedProducts({ - container: '#relatedProducts', + } else if (algoliaConfig.recommend.enabledTrendItems && typeof config.recommendTrendContainer !== "undefined") { + let containerValue = "#" + config.recommendTrendContainer; + recommendJs.trendingItems({ + container: containerValue, + facetName: config.facetName ? config.facetName : '', + facetValue: config.facetValue ? config.facetValue : '', recommendClient, indexName, - objectIDs: config.algoliObjectId, - maxRecommendations: algoliaConfig.recommend.limitRelatedProducts, - transformItems:function (items) { + maxRecommendations: config.numOfTrendsItem ? parseInt(config.numOfTrendsItem) : algoliaConfig.recommend.limitTrendingItems, + transformItems: function (items) { return items.map((item, index) => ({ ...item, position: index + 1, })); }, headerComponent({html}) { - return recommendProductsHtml.getHeaderHtml(html,algoliaConfig.recommend.relatedProductsTitle); + return recommendProductsHtml.getHeaderHtml(html, algoliaConfig.recommend.trendingItemsTitle); }, itemComponent({item, html}) { - return recommendProductsHtml.getItemHtml(item, html, algoliaConfig.recommend.isAddToCartEnabledInRelatedProduct); + return recommendProductsHtml.getItemHtml(item, html, algoliaConfig.recommend.isAddToCartEnabledInTrendsItem); }, }); } - } + }); + } - if ((algoliaConfig.recommend.isTrendItemsEnabledInPDP && $('body').hasClass('catalog-product-view')) || (algoliaConfig.recommend.isTrendItemsEnabledInCartPage && $('body').hasClass('checkout-cart-index'))) { - recommendJs.trendingItems({ - container: '#trendItems', - facetName: algoliaConfig.recommend.trendItemFacetName ? algoliaConfig.recommend.trendItemFacetName : '', - facetValue: algoliaConfig.recommend.trendItemFacetValue ? algoliaConfig.recommend.trendItemFacetValue : '', - recommendClient, - indexName, - maxRecommendations: algoliaConfig.recommend.limitTrendingItems, - transformItems:function (items) { - return items.map((item, index) => ({ - ...item, - position: index + 1, - })); - }, - headerComponent({html}) { - return recommendProductsHtml.getHeaderHtml(html,algoliaConfig.recommend.trendingItemsTitle); - }, - itemComponent({item, html}) { - return recommendProductsHtml.getItemHtml(item, html, algoliaConfig.recommend.isAddToCartEnabledInTrendsItem); - }, - }); - } else if (algoliaConfig.recommend.enabledTrendItems && typeof config.recommendTrendContainer !== "undefined") { - let containerValue = "#" + config.recommendTrendContainer; - recommendJs.trendingItems({ - container: containerValue, - facetName: config.facetName ? config.facetName : '', - facetValue: config.facetValue ? config.facetValue : '', - recommendClient, - indexName, - maxRecommendations: config.numOfTrendsItem ? parseInt(config.numOfTrendsItem) : algoliaConfig.recommend.limitTrendingItems, - transformItems:function (items) { - return items.map((item, index) => ({ - ...item, - position: index + 1, - })); - }, - headerComponent({html}) { - return recommendProductsHtml.getHeaderHtml(html,algoliaConfig.recommend.trendingItemsTitle); - }, - itemComponent({item, html}) { - return recommendProductsHtml.getItemHtml(item, html, algoliaConfig.recommend.isAddToCartEnabledInTrendsItem); - }, - }); - } - }); + checkerConfigLoading() } });