Server IP : 162.214.80.37 / Your IP : 216.73.216.83 Web Server : Apache System : Linux sh013.webhostingservices.com 4.19.286-203.ELK.el7.x86_64 #1 SMP Wed Jun 14 04:33:55 CDT 2023 x86_64 User : imyrqtmy ( 2189) PHP Version : 8.2.18 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON Directory (0755) : /home2/imyrqtmy/public_html/lashadesigns/js/ |
[ Home ] | [ C0mmand ] | [ Upload File ] |
---|
"use strict"; function Util() {} Util.setAttributes = function (el, attrs) { for (var key in attrs) { el.setAttribute(key, attrs[key]); } }; (function () { var CountDown = function (element) { this.element = element; this.labels = this.element.getAttribute("data-labels") ? this.element.getAttribute("data-labels").split(",") : []; this.intervalId; // set visible labels this.setVisibleLabels(); //create countdown HTML this.createCountDown(); //store time elements this.days = this.element.getElementsByClassName( "js-countdown__value--0" )[0]; this.hours = this.element.getElementsByClassName( "js-countdown__value--1" )[0]; this.mins = this.element.getElementsByClassName( "js-countdown__value--2" )[0]; this.secs = this.element.getElementsByClassName( "js-countdown__value--3" )[0]; this.endTime = this.getEndTime(); //init counter this.initCountDown(); }; CountDown.prototype.setVisibleLabels = function () { this.visibleLabels = this.element.getAttribute("data-visible-labels") ? this.element.getAttribute("data-visible-labels").split(",") : []; this.visibleLabels = this.visibleLabels.map(function (label) { return label.trim(); }); }; CountDown.prototype.createCountDown = function () { var wrapper = document.createElement("div"); Util.setAttributes(wrapper, { "aria-hidden": "true", class: "countdown__timer", }); for (var i = 0; i < 4; i++) { var timeItem = document.createElement("span"), timeValue = document.createElement("span"), timeLabel = document.createElement("span"); timeItem.setAttribute("class", "countdown__item"); timeValue.setAttribute( "class", "countdown__value countdown__value--" + i + " js-countdown__value--" + i ); timeItem.appendChild(timeValue); if (this.labels && this.labels.length > 0) { timeLabel.textContent = this.labels[i].trim(); timeLabel.setAttribute("class", "countdown__label"); timeItem.appendChild(timeLabel); } wrapper.appendChild(timeItem); } // append new content to countdown element this.element.insertBefore(wrapper, this.element.firstChild); // this.element.appendChild(wrapper); }; CountDown.prototype.getEndTime = function () { // get number of remaining seconds if (this.element.getAttribute("data-timer")) return ( Number(this.element.getAttribute("data-timer")) * 1000 + new Date().getTime() ); else if (this.element.getAttribute("data-countdown")) return Number( new Date(this.element.getAttribute("data-countdown")).getTime() ); }; CountDown.prototype.initCountDown = function () { this.updateCountDown(); }; CountDown.prototype.updateCountDown = function (bool) { var time = Math.floor((this.endTime - new Date().getTime()) / 1000), days = 0, hours = 0, mins = 0, seconds = 0; if (isNaN(time) || time < 0) { this.emitEndEvent(); return; } else { days = parseInt(time / 86400); time = time % 86400; hours = parseInt(time / 3600); time = time % 3600; mins = parseInt(time / 60); time = time % 60; seconds = parseInt(time); } if (!this.labels || this.labels.length < 4) { this.labels = ["Days", "Hours", "Mins", "Secs"]; } let labels = [...this.labels]; if (days === 1) labels[0] = this.labels[0].replace(/s$/, ""); if (hours === 1) labels[1] = this.labels[1].replace(/s$/, ""); if (mins === 1) labels[2] = this.labels[2].replace(/s$/, ""); if (seconds === 1) labels[3] = this.labels[3].replace(/s$/, ""); this.days.textContent = days.toString(); this.hours.textContent = this.getTimeFormat(hours); this.mins.textContent = this.getTimeFormat(mins); this.secs.textContent = this.getTimeFormat(seconds); let countdownItems = this.element.getElementsByClassName("countdown__item"); for (let i = 0; i < countdownItems.length; i++) { let labelEl = countdownItems[i].querySelector(".countdown__label"); if (labelEl) { labelEl.textContent = labels[i]; } } setTimeout(() => this.updateCountDown(false), 1000); }; CountDown.prototype.getTimeFormat = function (time) { return time.toString(); }; CountDown.prototype.emitEndEvent = function (time) { var event = new CustomEvent("countDownFinished"); this.element.dispatchEvent(event); }; // Functions calling window.addEventListener("load", function () { //initialize the CountDown objects /* window.setTimeout(() => {*/ var countDown = document.getElementsByClassName("js-countdown"); if (countDown.length > 0) { for (var i = 0; i < countDown.length; i++) { (function (i) { new CountDown(countDown[i]); })(i); } } /* }, 1000);*/ }); })();