document.body.style.overflow = 'hidden';
const loader = () => {
    document.body.style.overflow = '';
    const preloader = document.getElementById('preloader');
    const fadeout = setInterval(() => {
        const opacity = getComputedStyle(preloader).opacity;
        opacity > 0 ? preloader.style.opacity = opacity - 0.0150 : (clearInterval(fadeout), preloader.remove());
    }, 15);
}
const necodimLoadingArray = new Array();
const necodimPageReady = () => {
    let conditionDom = necodimLoadingArray.indexOf('dom') !== -1;
    let conditionShop = document.querySelectorAll('.js-store-grid-cont').length ? necodimLoadingArray.indexOf('store') !== -1 : true;
    let conditionZero = document.querySelectorAll('.t396__artboard').length ? necodimLoadingArray.indexOf('zero') !== -1 : true;
    conditionDom && conditionShop && conditionZero ? loader() : false;
}
document.addEventListener('DOMContentLoaded', () => (necodimLoadingArray.push('dom'), necodimPageReady()));
document.querySelectorAll('.js-store-grid-cont').forEach(catalogGrid => catalogGrid.addEventListener('tStoreRendered', () => (necodimLoadingArray.push('store'), necodimPageReady())));
document.querySelectorAll('.t396__artboard').forEach(artBoard => artBoard.addEventListener('artBoardRendered', () => (necodimLoadingArray.push('zero'), necodimPageReady())));



#preloader {
    position: fixed;
    top: 0;
    left: 0;
    z-index: 99999999;
    display: block;
    justify-content: top;
    align-items: top;
    width: 100vw;
    height: 100vh;
    opacity: 1;
    background-color: #111111;
    overflow: hidden;
    cursor: progress;
}
.loader {
  width: 100%;
  height: 2px;
  display: flex;
  position: relative;
  background: #2D2D2D;
  overflow: hidden;
}
.loader::after {
  content: '';
  width: 192px;
  height: 2px;
  background: #F1F1F1;
  position: fixed;
  top: 0;
  left: 0;
  box-sizing: border-box;
  animation: animFw 10s linear infinite;
}

@keyframes animFw {
  0% {
    width: 0;
  }
  100% {
    width: 100%;
  }
}
