var currentPage = typeof currentPage == 'undefined' ? false : currentPage; var accsShown = false; var denyProductPlacements = false; var category_js_loaded = jquery_libs_loaded = false; var dadata_token = "f8839a8a2767b481eb7badee3789f86528d6b8b9"; var deviceGalleryTO; var jsonProduct_standalone_firstload=true; var toAdd=500; function on_mousestop(callback){ var callback = typeof callback !== 'undefined' ? callback : false; if(jQuery().mousestop){ if(callback){ callback(); } }else{ setTimeout(function(){on_mousestop(callback)},250); } } function on_orientationchange(callback){ var callback = typeof callback !== 'undefined' ? callback : false; if(jQuery().orientationchange){ if(callback){ callback(); } }else{ setTimeout(function(){on_orientationchange(callback)},250); } } /* function on_sly(callback){ var callback = typeof callback !== 'undefined' ? callback : false; if(jQuery().sly){ if(callback){ callback(); } }else{ setTimeout(function(){on_sly(callback)},250); } } */ var onvisibleTO; var onvisibleLoop = 0; function on_visible(callback){ var callback = typeof callback !== 'undefined' ? callback : false; clearTimeout(onvisibleTO); if(onvisibleLoop==40){ console.error('Can not load jQuery.visible(): 10 seconds timeout.'); return false; } if(jQuery().visible){ if(callback){ callback(); } }else{ if(onvisibleLoop==0){ console.log("Waiting for jQuery.visible..."); } onvisibleTO = setTimeout(function(){ onvisibleLoop = onvisibleLoop+1; on_visible(callback)},250); } } function on_history(callback){ var callback = typeof callback !== 'undefined' ? callback : false; if(History.getState==undefined){ setTimeout(function(){on_history(callback)},250); }else{ if(callback){ callback(); } } } function deviceGalleryLazy(){ lazyLoadImgs(); clearTimeout(deviceGalleryTO); deviceGalleryTO = setTimeout(deviceGalleryLazy,1000); } $(window).on('load',function(){ setTimeout(lazyLoadImgs,250); $(window).on('scrollstop scrollleft resize scroll checkLazyImg',lazyLoadImgs); setTimeout(lazyLoadDivs,250); $(window).on('scrollstop scrollleft resize scroll',lazyLoadDivs); // if(mobile==1){ // deviceGalleryTO = setTimeout(deviceGalleryLazy,1000); // } $('#carSame').on('jcarousel:animateend', lazyLoadImgs); $(".jsonProductContainer").each(function(i,el){ loadJsonProduct_standalone(el); }); $(document).on("click",".chooseModButton",function(){ $(this).fadeOut(); $(this).parent().parent().find(".variants").slideDown(); }); }); function loadJsonProduct_standalone(el){ if(jsonProduct_standalone_firstload==true){ jsonProduct_standalone_firstload = false; attrs = "?jsonLoad=1&getHeaders=1&summary=1"; }else{ attrs = "?jsonLoad=1&summary=1"; } url = $(el).attr('data-href')+attrs; $.ajax({ type: 'GET', url: url, success: function(data){ $(el).html(data).addClass('noOpacity'); setTimeout(function(){ setTimeout(function(){ $(el).removeClass('noOpacity'); },350); productOnPageLoad('.jsonProductContainer.product_'+$(el).attr('data-pid')); onceOnLoad(); setTimeout(function(){ $('.jsonProductContainer.product_'+$(el).attr('data-pid')).removeClass('placeholder').fadeIn(); toAdd = toAdd + 50},toAdd); },250); }, async: true, dataType: "json" }); } function lazyLoadImgs(){ on_visible(function(){ $('img.lazy:not(.loaded),.mce-content-body img').each(function(i,el){ if($(el).hasClass('full')){ halfVisiblility = false; }else{ halfVisiblility = true; } if($(el).visible(halfVisiblility)==true){ $(el).attr('src',$(el).attr('data-src')).addClass('loaded'); } }); }); } function lazyLoadDivs(){ on_visible(function(){ $('div.lazyDiv:not(.loaded)').each(function(i,el){ if($(el).hasClass('full')){ halfVisiblility = false; }else{ halfVisiblility = true; } if($(el).visible(halfVisiblility)==true){ $(el).addClass('loaded'); $.ajax({ type: 'GET', url: $(el).attr('data-href'), success: function(data){ $(el).html(data); $(el).addClass('placeholder-cleared'); }, async: true, dataType: "json" }); } }); }); } function loadLater(filename, filetype, timeout, callback, rel, as){ if(filetype=='js'){ setTimeout(function(){ $.getScript(filename,callback); },timeout); }else{ setTimeout(function(){load(filename,filetype,callback,rel,as);},timeout); } } function load(filename, filetype, callback, rel, as){ if (filetype=="js"){ $.getScript(filename,callback); }else{ if (filetype=="css" || filetype=="link"){ //if filename is an external CSS file if($("link[href='"+filename+"']").attr('type')==undefined){ var fileref=document.createElement("link") fileref.setAttribute("href", filename) fileref.setAttribute("type", "text/css") fileref.setAttribute("rel", "stylesheet") } } if (typeof fileref!="undefined") document.getElementsByTagName("head")[0].appendChild(fileref) if(typeof callback!=='undefined'){ setTimeout(callback,250); } } } function globalScriptsLoad(callback){ var callback = typeof callback !== 'undefined' ? callback : false; if(jquery_libs_loaded==false){ $.getScript("/cache/js/jquery_libs.min.js?v="+currentVersion,()=>{ $(window).trigger('jquery_libs_loaded'); jquery_libs_loaded = true; }); } if(serverSide==1){ loadLater("https://code.jivosite.com/widget/qTzNG0GjFP","js",4000); } // loadLater("/cache/js/site_cart_widget.js","js",2000); if(currentPage=='cart'){ // load("/cache/js/site_delivery_fias.js","js",function(){ // load("/cache/js/site_region_run_later.js?v="+currentVersion,"js"); // }); }else{ load("/assets/js/countrySelector.js?v="+currentVersion,"js"); // loadLater("/cache/js/site_delivery_fias.js","js",1500,function(){ // load("/cache/js/site_region_run_later.js?v="+currentVersion,"js"); // }); } if(currentPage=='category'){ $.getScript("/cache/js/category.js?v="+currentVersion,()=>{ category_js_loaded = true; $(window).trigger('category_js_loaded'); }); } // if(mobile){ // load("/cache/js/libs/jquery.migrate.js","js"); // load("/cache/js/libs/jquery.mobile.custom2.min.js","js"); // load("/cache/js/window_mobile.js","js"); // } if(currentPage=='product'){ // loadLater("/cache/css/content.min.css","css",1000); // loadLater("/assets/css/content.min.css","css",1000); // load("/js/product.js","js"); } loadLater("/cache/css/libs/noUI/jquery.nouislider.css","css",1000); if(callback!=false){ callback(); } } $(window).on('load',function(){globalScriptsLoad();}); $(document).on("keyup", function(e){ $(document).trigger("press_"+e.keyCode); }); function plural_form(count, words) { var cases = [2, 0, 1, 1, 1, 2]; return count + ' ' + words[ (count % 100 > 4 && count % 100 < 20) ? 2 : cases[ Math.min(count % 10, 5)] ]; }