Untitled

mail@pastecode.io avatar
unknown
plain_text
a month ago
12 kB
4
Indexable
Never
(function () {
  try {
    /* main variables */
    var debug = 0;
    var variation_name = "";
    var $;

    /* all Pure helper functions */
    function waitForElement(selector, trigger, delayInterval, delayTimeout) {
      var interval = setInterval(function () {
        if (
          document &&
          document.querySelector(selector) &&
          document.querySelectorAll(selector).length > 0
        ) {
          clearInterval(interval);
          trigger();
        }
      }, delayInterval);
      setTimeout(function () {
        clearInterval(interval);
      }, delayTimeout);
    }
    var marginRight;
    let progressbar = `<div class="eg-progressbar">
    <div class="eg-shippingmessage">
        <p class="eg-shipping">Free Shipping!</p>
        <p class="eg-message">Add $75 worth of products to unlock FREE SHIPPING!</p>
    </div>
    <div class="eg-progresscontainer">
        <div class="eg-bar">
            <div style="width: 0%;"></div>
        </div>
        <div class="eg-worthofproduct">
            <p></p>
        </div>
        <div class="eg-amount">
            <p>$0</p>
            <p>FREE <br> SHIPPING</p>
        </div>
    </div>
    </div>`;

    let egstring = `<div class="eg-minicartprice">
    <p class="eg-shippingmessage"><span>Shipping</span><span></span></p>
    <p class="eg-total"><span>Total</span><span></span></p>
    </div>`
    let egPriceNew;

    function getPriceFromString(priceString) {
      return parseFloat(priceString.replace('$', '').replace('USD', '').trim());
    }

    function animateProgressBar(targetWidth) {
      const barElement = document.querySelector('.eg-progressbar .eg-progresscontainer .eg-bar > div');
      let currentWidth = parseFloat(barElement.style.width) || 0;
       marginRight = (100 - targetWidth);
      const difference = targetWidth - currentWidth;
      const increment = difference / 100;
      const interval = setInterval(function () {
        currentWidth += increment;

        if ((increment > 0 && currentWidth >= targetWidth) || (increment < 0 && currentWidth <= targetWidth)) {
          currentWidth = targetWidth;
          clearInterval(interval);
        }
        barElement.style.width = currentWidth + '%';
      }, 10);
      document.querySelector('.AB031 .eg-progressbar .eg-progresscontainer .eg-worthofproduct p').style.marginRight = marginRight + '%';

    }

    function updateProgressBar() {
      let barShip = document.querySelector('.AB031 .eg-progressbar .eg-progresscontainer .eg-amount p:last-of-type');
      let congratulationMsg = document.querySelector('.AB031 .eg-progressbar .eg-shippingmessage .eg-shipping');
      let shippingmsg = document.querySelector('.AB031 .eg-progressbar .eg-shippingmessage .eg-message');
      let remainingMsg = document.querySelector('.AB031 .eg-progressbar .eg-progresscontainer .eg-worthofproduct');
      let egPrice = document.querySelector('.eg-minicartprice .eg-total > span:last-of-type');
      let free = document.querySelector('.eg-minicartprice .eg-shippingmessage > span:last-of-type');
      const minicartPriceElement = document.querySelector('.footer .slidecart-subtotal span');
      let cartprice = document.querySelector('.AB031 .eg-progressbar .eg-progresscontainer .eg-worthofproduct p');
      if (minicartPriceElement) {
        const minicartPrice = egPriceNew;
        // let priceelement = minicartPriceElement.textContent.trim();
        if (minicartPrice >= 75) {
          animateProgressBar(100);
          congratulationMsg.innerText = 'Congratulations!';
          shippingmsg.innerText = 'Your order will ship to you for free.';
          remainingMsg.style.display = 'none';
          egPrice.innerText = '$' + minicartPrice + ' USD';
          free.innerText = 'FREE';
          cartprice.style.display = "none";
          cartprice.style.fontSize = "12px !important";
          barShip.style.marginRight = '0px';

        } else if (minicartPrice < 75) {
          const targetWidth = (minicartPrice / 75) * 100;
          animateProgressBar(targetWidth);
          const amountNeeded = 75 - minicartPrice;
          congratulationMsg.innerText = 'Free Shipping!';
          shippingmsg.innerText = `Add $${amountNeeded.toFixed(2)} worth of products to unlock FREE SHIPPING!`;
          remainingMsg.style.display = 'flex';
          cartprice.innerText = '$' + minicartPrice;
          egPrice.innerText = '$' + (minicartPrice + 5).toFixed(2) + ' USD';
          free.innerText = '$5 USD';
          cartprice.style.display = "block";

        }
        if(minicartPrice > 70){
          cartprice.style.fontSize = "10px";
          barShip.style.marginRight = '-15px';
          document.querySelector('.AB031 .eg-progressbar .eg-progresscontainer .eg-worthofproduct p').style.marginRight = (marginRight+4) + '%';

         }
      }
    }

    function init() {
      if (!document.querySelector('.eg-progressbar')) {
        document.body.classList.add("AB031");
        document.querySelector('#slidecarthq .header').insertAdjacentHTML('afterend', progressbar);
        waitForElement('.footer > .footer-row:not([style])', function () {
          document.querySelector('.footer > .footer-row:not([style])').insertAdjacentHTML('afterend', egstring);
        }, 50, 2000);
      }
      setTimeout(() => {
        var slideCartHQ = document.querySelector('#slidecarthq .slidecarthq');
        var progressBar = document.querySelector('.eg-progressbar');
        if (slideCartHQ.classList.contains('cartEmpty')) {
          progressBar.style.display = 'none';
        } else {
          progressBar.style.display = 'block';
        }
        updateProgressBar();
      }, 1000);
    }

    function update() {
      var cartCount = 0;
      const send = XMLHttpRequest.prototype.send
      XMLHttpRequest.prototype.send = function () {
        this.addEventListener('load', function () {
          if (this.responseURL.indexOf('/cart.js') != -1) {
            var data = JSON.parse(this.responseText);
            var cartNewCount = data.item_count;
            egPriceNew = (data.total_price / 100);
            if (cartNewCount == 0 || cartNewCount == '0') {
              document.querySelector('.eg-progressbar') && document.querySelector('.eg-progressbar').remove();
              return;
            }
            if (cartCount != cartNewCount && cartNewCount != 0) {
              cartCount = data.item_count;
              init();
            }
          }
        })
        return send.apply(this, arguments)
      }
    }
    update();

    waitForElement('.footer .slidecart-subtotal span', init, 100, 15000);
  } catch (e) {
    if (debug) console.log(e, "error in Test" + variation_name);
  }
})();




.AB031 #slidecarthq #AB-018-banner {
    display: none !important;
}

.AB031 .eg-progressbar {
    background: #F2F2F2;
    padding: 12px 24px 12px 14px;
}

.AB031 .eg-progressbar .eg-shippingmessage p {
    font-family: Roboto;
    font-size: 14px;
    font-weight: 700;
    line-height: 16.8px;
    letter-spacing: 0.382999986410141px;
    text-align: center;
}

.AB031 .eg-progressbar .eg-shippingmessage .eg-message {
    font-size: 12px !important;
    font-weight: 400 !important;
    line-height: 14.4px !important;
    margin-top: 8px;
}

.AB031 .eg-progressbar .eg-progresscontainer .eg-amount p:first-of-type {
    font-size: 12px !important;
}

.AB031 .eg-progressbar .eg-progresscontainer .eg-bar {
    background: #FFFFFF !important;
    width: 100%;
    height: 10px;
    border-radius: 100px;
    margin-top: 14px;
    margin-bottom: 7px;
}

.AB031 .eg-progressbar .eg-progresscontainer .eg-bar>div {
    background: #A02447;
    width: 50%;
    height: 10px;
    border-radius: 100px;
    position: relative;
}

.AB031 .eg-progressbar .eg-progresscontainer .eg-bar>div:after {
    content: '';
    display: flex;
    width: 17px;
    height: 17px;
    position: absolute;
    right: -1px;
    border: 1px solid #FFFFFF;
    background: #A02447;
    border-radius: 100px;
    top: -3px;
}

.AB031 .eg-progressbar .eg-progresscontainer .eg-amount {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.AB031 .eg-progressbar .eg-progresscontainer .eg-amount p,
.AB031 .eg-progressbar .eg-progresscontainer .eg-worthofproduct p {
    font-family: Roboto !important;
    font-size: 7px;
    font-weight: 400;
    line-height: 8px;
    letter-spacing: 0.382999986410141px;
    text-align: center;
}

.AB031 .eg-progressbar .eg-progresscontainer .eg-worthofproduct p {
    font-size: 12px !important;
    line-height: 14.4px !important;
    width: 40px;
    overflow: hidden;
}

.AB031 .eg-progressbar .eg-progresscontainer {
    position: relative;
}

.AB031 .eg-progressbar .eg-progresscontainer .eg-worthofproduct {
    position: absolute;
    bottom: 0px;
    width: 100%;
    display: flex;
    justify-content: flex-end;
}

.AB031 .eg-minicartprice {
    display: flex;
    flex-direction: column;
    grid-gap: 10px;
    margin-bottom: 15px;
}

.AB031 .eg-minicartprice>p {
    display: flex;
    justify-content: space-between;
}

.AB031 .eg-minicartprice>p span {
    font-family: SF Pro Text;
    font-size: 16px;
    font-weight: 600;
    line-height: 19.09px;
    text-align: left;
    color: #000000;
}
.AB031 .eg-progressbar .eg-progresscontainer .eg-amount p:last-of-type{
    margin-right: -10px;
}
.AB031 .footer>.footer-row:not([style]) {
    border-bottom: unset !important;
    padding-bottom: 10px !important;
}

.AB031 .eg-progressbar .eg-progresscontainer .eg-bar:after {
    content: '';
    background-image: url('');
    width: 19px;
    display: flex;
    background-size: contain;
    position: absolute;
    height: 20px;
    right: -1px;
    top: -6px;
    background-repeat: no-repeat;
}
Leave a Comment