Untitled
unknown
plain_text
a year ago
12 kB
11
Indexable
(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;
}Editor is loading...
Leave a Comment