(function ($) {
"use strict";
/*=================================
JS Index Here
==================================*/
/*
On Load Function
Preloader
Mobile Menu Active
Sticky fix
Scroll To Top
Set Background Image
Global Slider
Custom Animaiton For Slider
Ajax Contact Form
Search Box Popup
Popup Sidemenu
Magnific Popup
Section Position
Filter
Counter Up
Default Tab
Shape Mockup
Countdown
Progress Bar Animation
One Page Nav
Indicator
Woocommerce Toggle
Right Click Disable
*/
/*=================================
JS Index End
==================================*/
/*
/*---------- 01. On Load Function ----------*/
$(window).on("load", function () {
$(".preloader").fadeOut();
setTimeout(function () {
$('.popup-subscribe-area').addClass('show');
}, 1500);
});
$(window).on('resize', function () {
$(".slick-slider").slick("refresh");
});
/*---------- 02. Preloader ----------*/
if ($(".preloader").length > 0) {
$(".preloaderCls").each(function () {
$(this).on("click", function (e) {
e.preventDefault();
$(".preloader").css("display", "none");
});
});
}
/*---------- 03. Mobile Menu Active ----------*/
$.fn.mobilemenu = function (options) {
var opt = $.extend(
{
menuToggleBtn: ".menu-toggle",
bodyToggleClass: "body-visible",
subMenuClass: "submenu-class",
subMenuParent: "submenu-item-has-children",
subMenuParentToggle: "active-class",
meanExpandClass: "mean-expand-class",
appendElement: '',
subMenuToggleClass: "menu-open",
toggleSpeed: 400,
},
options
);
return this.each(function () {
var menu = $(this); // Select menu
// Menu Show & Hide
function menuToggle() {
var expanded = menu.hasClass(opt.bodyToggleClass);
menu.toggleClass(opt.bodyToggleClass);
$(opt.menuToggleBtn).attr('aria-expanded', !expanded);
// collapse submenu on menu hide or show
var subMenu = "." + opt.subMenuClass;
$(subMenu).each(function () {
if ($(this).hasClass(opt.subMenuToggleClass)) {
$(this).removeClass(opt.subMenuToggleClass);
$(this).css("display", "none");
$(this).parent().removeClass(opt.subMenuParentToggle);
$(this).prev("button." + opt.meanExpandClass).attr('aria-expanded', false);
}
});
}
// Class Set Up for every submenu
menu.find("li").each(function () {
var submenu = $(this).find("ul");
submenu.addClass(opt.subMenuClass);
submenu.css("display", "none");
submenu.parent().addClass(opt.subMenuParent);
submenu.prev("a").after(opt.appendElement);
});
// Toggle Submenu
function toggleDropDown($element) {
var expanded = $element.attr('aria-expanded') === 'true';
$element.attr('aria-expanded', !expanded);
if ($($element).next("ul").length > 0) {
$($element).parent().toggleClass(opt.subMenuParentToggle);
$($element).next("ul").slideToggle(opt.toggleSpeed);
$($element).next("ul").toggleClass(opt.subMenuToggleClass);
} else if ($($element).prev("ul").length > 0) {
$($element).parent().toggleClass(opt.subMenuParentToggle);
$($element).prev("ul").slideToggle(opt.toggleSpeed);
$($element).prev("ul").toggleClass(opt.subMenuToggleClass);
}
}
// Submenu toggle Button
var expandToggler = "." + opt.meanExpandClass;
$(expandToggler).each(function () {
$(this).on("click", function (e) {
e.preventDefault();
toggleDropDown($(this));
});
});
// Menu Show & Hide On Toggle Btn click
$(opt.menuToggleBtn).each(function () {
$(this).attr('aria-expanded', false);
$(this).on("click", function () {
menuToggle();
});
});
// Hide Menu On outside click
$(document).on("click", function (e) {
if (!$(e.target).closest(menu).length && !$(e.target).closest(opt.menuToggleBtn).length) {
if (menu.hasClass(opt.bodyToggleClass)) {
menuToggle();
}
}
});
// Stop Hide full menu on menu click
menu.on("click", function (e) {
e.stopPropagation();
});
});
};
$(".mobile-menu-wrapper").mobilemenu();
/*---------- 03. Sidebar Menu Active ----------*/
$.fn.sidebarmenu = function (options) {
var opt = $.extend(
{
menuToggleBtn: ".sidemenu-toggle",
bodyToggleClass: "body-visible",
subMenuClass: "submenu-class",
subMenuParent: "submenu-item-has-children",
subMenuParentToggle: "active-class",
meanExpandClass: "mean-expand-class",
appendElement: '',
subMenuToggleClass: "menu-open",
toggleSpeed: 400,
},
options
);
return this.each(function () {
var menu = $(this); // Select menu
// Menu Show & Hide
function menuToggle() {
menu.toggleClass(opt.bodyToggleClass);
// collapse submenu on menu hide or show
var subMenu = "." + opt.subMenuClass;
$(subMenu).each(function () {
if ($(this).hasClass(opt.subMenuToggleClass)) {
$(this).removeClass(opt.subMenuToggleClass);
$(this).css("display", "none");
$(this).parent().removeClass(opt.subMenuParentToggle);
}
});
}
// Class Set Up for every submenu
menu.find("li").each(function () {
var submenu = $(this).find("ul");
submenu.addClass(opt.subMenuClass);
submenu.css("display", "none");
submenu.parent().addClass(opt.subMenuParent);
submenu.prev("a").append(opt.appendElement);
submenu.next("a").append(opt.appendElement);
});
// Toggle Submenu
function toggleDropDown($element) {
if ($($element).next("ul").length > 0) {
$($element).parent().toggleClass(opt.subMenuParentToggle);
$($element).next("ul").slideToggle(opt.toggleSpeed);
$($element).next("ul").toggleClass(opt.subMenuToggleClass);
} else if ($($element).prev("ul").length > 0) {
$($element).parent().toggleClass(opt.subMenuParentToggle);
$($element).prev("ul").slideToggle(opt.toggleSpeed);
$($element).prev("ul").toggleClass(opt.subMenuToggleClass);
}
}
// Submenu toggle Button
var expandToggler = "." + opt.meanExpandClass;
$(expandToggler).each(function () {
$(this).on("click", function (e) {
e.preventDefault();
toggleDropDown($(this).parent());
});
});
// Menu Show & Hide On Toggle Btn click
$(opt.menuToggleBtn).each(function () {
$(this).on("click", function () {
menuToggle();
});
});
// Hide Menu On out side click
menu.on("click", function (e) {
e.stopPropagation();
menuToggle();
});
// Stop Hide full menu on menu click
menu.find("div").on("click", function (e) {
e.stopPropagation();
});
});
};
$(".sidebar-menu-wrapper").sidebarmenu();
/*---------- Close Popup ----------*/
function closePopup($popupBox, $popupClose) {
$($popupClose).on("click", function (e) {
$($popupBox).addClass('hide');
});
}
closePopup(".popup-subscribe-area", ".popupClose");
$("#destroyPopup").on("click", function () {
$(".popup-subscribe-area").addClass('hide');
localStorage.setItem("popupDestroyed", "true");
});
const popupDestroyed = localStorage.getItem("popupDestroyed");
if (popupDestroyed === "true") {
$(".popup-subscribe-area").hide();
}
/*---------- 04. Sticky fix ----------*/
$(window).scroll(function () {
var topPos = $(this).scrollTop();
if (topPos > 500) {
$('.sticky-wrapper').addClass('sticky');
} else {
$('.sticky-wrapper').removeClass('sticky')
}
})
/*---------- 05. Scroll To Top ----------*/
// progressAvtivation
if ($('.scroll-top')) {
var scrollTopbtn = document.querySelector('.scroll-top');
var progressPath = document.querySelector('.scroll-top path');
var pathLength = progressPath.getTotalLength();
progressPath.style.transition = progressPath.style.WebkitTransition = 'none';
progressPath.style.strokeDasharray = pathLength + ' ' + pathLength;
progressPath.style.strokeDashoffset = pathLength;
progressPath.getBoundingClientRect();
progressPath.style.transition = progressPath.style.WebkitTransition = 'stroke-dashoffset 10ms linear';
var updateProgress = function () {
var scroll = $(window).scrollTop();
var height = $(document).height() - $(window).height();
var progress = pathLength - (scroll * pathLength / height);
progressPath.style.strokeDashoffset = progress;
}
updateProgress();
$(window).scroll(updateProgress);
var offset = 50;
var duration = 750;
jQuery(window).on('scroll', function () {
if (jQuery(this).scrollTop() > offset) {
jQuery(scrollTopbtn).addClass('show');
} else {
jQuery(scrollTopbtn).removeClass('show');
}
});
jQuery(scrollTopbtn).on('click', function (event) {
event.preventDefault();
jQuery('html, body').animate({scrollTop: 0}, 1);
return false;
})
}
/*---------- 06. Set Background Image ----------*/
if ($("[data-bg-src]").length > 0) {
$("[data-bg-src]").each(function () {
var src = $(this).attr("data-bg-src");
$(this).css("background-image", "url(" + src + ")");
$(this).removeAttr("data-bg-src").addClass("background-image");
});
}
/*----------- 07. Global Slider ----------*/
$(".global-carousel").each(function () {
var carouselSlide = $(this);
// Collect Data
function d(data) {
return carouselSlide.data(data);
}
// Custom Arrow Button
var prevButton =
'',
nextButton =
'';
// Function For Custom Arrow Btn
$("[data-slick-next]").each(function () {
$(this).on("click", function (e) {
e.preventDefault();
$($(this).data("slick-next")).slick("slickNext");
});
});
$("[data-slick-prev]").each(function () {
$(this).on("click", function (e) {
e.preventDefault();
$($(this).data("slick-prev")).slick("slickPrev");
});
});
// Check for arrow wrapper
if (d("arrows") == true) {
if (!carouselSlide.closest(".arrow-wrap").length) {
carouselSlide.closest(".container").parent().addClass("arrow-wrap");
}
}
carouselSlide.slick({
dots: d("dots") ? true : false,
fade: d("fade") ? true : false,
arrows: d("arrows") ? true : false,
speed: d("speed") ? d("speed") : 1000,
asNavfor: d("asnavfor") ? d("asnavfor") : false,
autoplay: d("autoplay") == false ? false : true,
infinite: d("infinite") == false ? false : true,
slidesToShow: d("slide-show") ? d("slide-show") : 1,
adaptiveHeight: d("adaptive-height") ? true : false,
centerMode: d("center-mode") ? true : false,
autoplaySpeed: d("autoplay-speed") ? d("autoplay-speed") : 8000,
centerPadding: d("center-padding") ? d("center-padding") : "0",
focusOnSelect: d("focuson-select") == false ? false : true,
pauseOnFocus: d("pauseon-focus") ? true : false,
pauseOnHover: d("pauseon-hover") ? true : false,
variableWidth: d("variable-width") ? true : false,
vertical: d("vertical") ? true : false,
verticalSwiping: d("vertical") ? true : false,
prevArrow: d("prev-arrow")
? prevButton
: '',
nextArrow: d("next-arrow")
? nextButton
: '',
rtl: $("html").attr("dir") == "rtl" ? true : false,
responsive: [
{
breakpoint: 1600,
settings: {
arrows: d("xl-arrows") ? true : false,
dots: d("xl-dots") ? true : false,
slidesToShow: d("xl-slide-show")
? d("xl-slide-show")
: d("slide-show"),
centerMode: d("xl-center-mode") ? true : false,
centerPadding: "0",
},
},
{
breakpoint: 1400,
settings: {
arrows: d("ml-arrows") ? true : false,
dots: d("ml-dots") ? true : false,
slidesToShow: d("ml-slide-show")
? d("ml-slide-show")
: d("slide-show"),
centerMode: d("ml-center-mode") ? true : false,
centerPadding: 0,
},
},
{
breakpoint: 1200,
settings: {
arrows: d("lg-arrows") ? true : false,
dots: d("lg-dots") ? true : false,
slidesToShow: d("lg-slide-show")
? d("lg-slide-show")
: d("slide-show"),
centerMode: d("lg-center-mode")
? d("lg-center-mode")
: false,
centerPadding: 0,
},
},
{
breakpoint: 992,
settings: {
arrows: d("md-arrows") ? true : false,
dots: d("md-dots") ? true : false,
slidesToShow: d("md-slide-show")
? d("md-slide-show")
: 1,
centerMode: d("md-center-mode")
? d("md-center-mode")
: false,
centerPadding: 0,
},
},
{
breakpoint: 768,
settings: {
arrows: d("sm-arrows") ? true : false,
dots: d("sm-dots") ? true : false,
slidesToShow: d("sm-slide-show")
? d("sm-slide-show")
: 1,
centerMode: d("sm-center-mode")
? d("sm-center-mode")
: false,
centerPadding: 0,
},
},
{
breakpoint: 576,
settings: {
arrows: d("xs-arrows") ? true : false,
dots: d("xs-dots") ? true : false,
slidesToShow: d("xs-slide-show")
? d("xs-slide-show")
: 1,
centerMode: d("xs-center-mode")
? d("xs-center-mode")
: false,
centerPadding: 0,
},
},
// You can unslick at a given breakpoint now by adding:
// settings: "unslick"
// instead of a settings object
],
});
});
/*----------- 08. Custom Animaiton For Slider ----------*/
$('[data-ani-duration]').each(function () {
var durationTime = $(this).data('ani-duration');
$(this).css('animation-duration', durationTime);
});
$('[data-ani-delay]').each(function () {
var delayTime = $(this).data('ani-delay');
$(this).css('animation-delay', delayTime);
});
$('[data-ani]').each(function () {
var animaionName = $(this).data('ani');
$(this).addClass(animaionName);
$('.slick-current [data-ani]').addClass('slider-animated');
});
$('.global-carousel').on('afterChange', function (event, slick, currentSlide, nextSlide) {
$(slick.$slides).find('[data-ani]').removeClass('slider-animated');
$(slick.$slides[currentSlide]).find('[data-ani]').addClass('slider-animated');
})
/*----------- 10. Ajax Contact Form ----------*/
var form = ".ajax-contact";
var invalidCls = "is-invalid";
var $email = '[name="email"]';
var $validation =
'[name="name"],[name="email"],[name="subject"],[name="number"],[name="message"]'; // Must be use (,) without any space
var formMessages = $(".form-messages");
function sendContact() {
var formData = $(form).serialize();
var valid;
valid = validateContact();
if (valid) {
jQuery
.ajax({
url: $(form).attr("action"),
data: formData,
type: "POST",
})
.done(function (response) {
// Make sure that the formMessages div has the 'success' class.
formMessages.removeClass("error");
formMessages.addClass("success");
// Set the message text.
formMessages.text(response);
// Clear the form.
$(
form +
' input:not([type="submit"]),' +
form +
" textarea"
).val("");
})
.fail(function (data) {
// Make sure that the formMessages div has the 'error' class.
formMessages.removeClass("success");
formMessages.addClass("error");
// Set the message text.
if (data.responseText !== "") {
formMessages.html(data.responseText);
} else {
formMessages.html(
"Oops! An error occured and your message could not be sent."
);
}
});
}
}
/*---------- 19. Circle Progress ----------*/
function animateElements() {
$('.counter-circle .progressbar').each(function () {
var elementPos = $(this).offset().top;
var topOfWindow = $(window).scrollTop();
var percent = $(this).find('.circle').attr('data-percent');
var percentage = parseInt(percent, 10) / parseInt(100, 10);
var animate = $(this).data('animate');
if (elementPos < topOfWindow + $(window).height() - 30 && !animate) {
$(this).data('animate', true);
$(this).find('.circle').circleProgress({
startAngle: -Math.PI / 2,
value: percent / 100,
size: 135,
thickness: 7,
emptyFill: "#2C2C2C",
fill: {
color: '#F41E1E'
}
}).on('circle-animation-progress', function (event, progress, stepValue) {
$(this).find('.circle-num').text((stepValue * 100).toFixed(0) + "%");
}).stop();
}
});
}
// Show animated elements
animateElements();
$(window).scroll(animateElements);
function validateContact() {
var valid = true;
var formInput;
function unvalid($validation) {
$validation = $validation.split(",");
for (var i = 0; i < $validation.length; i++) {
formInput = form + " " + $validation[i];
if (!$(formInput).val()) {
$(formInput).addClass(invalidCls);
valid = false;
} else {
$(formInput).removeClass(invalidCls);
valid = true;
}
}
}
unvalid($validation);
if (
!$($email).val() ||
!$($email)
.val()
.match(/^([\w-\.]+@([\w-]+\.)+[\w-]{2,4})?$/)
) {
$($email).addClass(invalidCls);
valid = false;
} else {
$($email).removeClass(invalidCls);
valid = true;
}
return valid;
}
$(form).on("submit", function (element) {
element.preventDefault();
sendContact();
});
/*---------- 11. Search Box Popup ----------*/
function popupSarchBox($searchBox, $searchOpen, $searchCls, $toggleCls) {
$($searchOpen).on("click", function (e) {
e.preventDefault();
$($searchBox).addClass($toggleCls);
});
$($searchBox).on("click", function (e) {
e.stopPropagation();
$($searchBox).removeClass($toggleCls);
});
$($searchBox)
.find("form")
.on("click", function (e) {
e.stopPropagation();
$($searchBox).addClass($toggleCls);
});
$($searchCls).on("click", function (e) {
e.preventDefault();
e.stopPropagation();
$($searchBox).removeClass($toggleCls);
});
}
popupSarchBox(
".popup-search-box",
".searchBoxToggler",
".searchClose",
"show"
);
/*---------- 12. Popup Sidemenu ----------*/
function popupSideMenu($sideMenu, $sideMunuOpen, $sideMenuCls, $toggleCls) {
// Sidebar Popup
$($sideMunuOpen).on('click', function (e) {
e.preventDefault();
$($sideMenu).addClass($toggleCls);
});
$($sideMenu).on('click', function (e) {
e.stopPropagation();
$($sideMenu).removeClass($toggleCls)
});
var sideMenuChild = $sideMenu + ' > div';
$(sideMenuChild).on('click', function (e) {
e.stopPropagation();
$($sideMenu).addClass($toggleCls)
});
$($sideMenuCls).on('click', function (e) {
e.preventDefault();
e.stopPropagation();
$($sideMenu).removeClass($toggleCls);
});
};
popupSideMenu('.sidemenu-wrapper', '.sideMenuToggler', '.sideMenuCls', 'show');
/*----------- 13. Magnific Popup ----------*/
/* magnificPopup img view */
$(".popup-image").magnificPopup({
type: "image",
mainClass: 'mfp-zoom-in',
removalDelay: 260,
gallery: {
enabled: true,
},
});
/* magnificPopup video view */
$(".popup-video").magnificPopup({
type: "iframe",
mainClass: 'mfp-zoom-in',
removalDelay: 260,
});
/* magnificPopup video view */
$(".popup-content").magnificPopup({
type: "inline",
midClick: true,
});
$(".popup-content").on("click", function () {
$(".slick-slider").slick("refresh");
});
/*---------- 14. Section Position ----------*/
// Interger Converter
function convertInteger(str) {
return parseInt(str, 10);
}
$.fn.sectionPosition = function (mainAttr, posAttr) {
$(this).each(function () {
var section = $(this);
function setPosition() {
var sectionHeight = Math.floor(section.height() / 2), // Main Height of section
posData = section.attr(mainAttr), // where to position
posFor = section.attr(posAttr), // On Which section is for positioning
topMark = "top-half", // Pos top
bottomMark = "bottom-half", // Pos Bottom
parentPT = convertInteger($(posFor).css("padding-top")), // Default Padding of parent
parentPB = convertInteger($(posFor).css("padding-bottom")); // Default Padding of parent
if (posData === topMark) {
$(posFor).css(
"padding-bottom",
parentPB + sectionHeight + "px"
);
section.css("margin-top", "-" + sectionHeight + "px");
} else if (posData === bottomMark) {
$(posFor).css(
"padding-top",
parentPT + sectionHeight + "px"
);
section.css("margin-bottom", "-" + sectionHeight + "px");
}
}
setPosition(); // Set Padding On Load
});
};
var postionHandler = "[data-sec-pos]";
if ($(postionHandler).length) {
$(postionHandler).imagesLoaded(function () {
$(postionHandler).sectionPosition("data-sec-pos", "data-pos-for");
});
}
/*----------- 15. Filter ----------*/
$(".filter-active").imagesLoaded(function () {
var $filter = ".filter-active",
$filterItem = ".filter-item",
$filterMenu = ".filter-menu-active";
if ($($filter).length > 0) {
var $grid = $($filter).isotope({
itemSelector: $filterItem,
filter: "*",
});
// filter items on button click
$($filterMenu).on("click", "button", function () {
var filterValue = $(this).attr("data-filter");
$grid.isotope({
filter: filterValue,
});
});
// Menu Active Class
$($filterMenu).on("click", "button", function (event) {
event.preventDefault();
$(this).addClass("active");
$(this).siblings(".active").removeClass("active");
});
}
});
$(".masonary-active").imagesLoaded(function () {
var $filter = ".masonary-active",
$filterItem = ".filter-item",
$filterMenu = ".filter-menu-active";
if ($($filter).length > 0) {
var $grid = $($filter).isotope({
itemSelector: $filterItem,
filter: "*",
masonry: {
// use outer width of grid-sizer for columnWidth
columnWidth: 1,
},
});
// filter items on button click
$($filterMenu).on("click", "button", function () {
var filterValue = $(this).attr("data-filter");
$grid.isotope({
filter: filterValue,
});
});
// Menu Active Class
$($filterMenu).on("click", "button", function (event) {
event.preventDefault();
$(this).addClass("active");
$(this).siblings(".active").removeClass("active");
});
}
});
// Active specifix
$('.filter-active-cat1').imagesLoaded(function () {
var $filter = '.filter-active-cat1',
$filterItem = '.filter-item',
$filterMenu = '.filter-menu-active';
if ($($filter).length > 0) {
var $grid = $($filter).isotope({
itemSelector: $filterItem,
filter: '.cat1',
masonry: {
// use outer width of grid-sizer for columnWidth
columnWidth: 1
}
});
// filter items on button click
$($filterMenu).on('click', 'button', function () {
var filterValue = $(this).attr('data-filter');
$grid.isotope({
filter: filterValue
});
});
// Menu Active Class
$($filterMenu).on('click', 'button', function (event) {
event.preventDefault();
$(this).addClass('active');
$(this).siblings('.active').removeClass('active');
});
}
;
});
/*----------- 16. Counter Up ----------*/
$(".counter-number").counterUp({
delay: 10,
time: 1000,
});
/*----------- 14. Indicator ----------*/
// Indicator
$.fn.indicator = function () {
// Loop through each .indicator-active element
$(this).each(function () {
var $menu = $(this),
$linkBtn = $menu.find("a"),
$btn = $menu.find("button");
// Append indicator
$menu.append('');
var $line = $menu.find(".indicator");
// Check which type button is Available
var $currentBtn;
if ($linkBtn.length) {
$currentBtn = $linkBtn;
} else if ($btn.length) {
$currentBtn = $btn;
}
// On Click Button Class Remove
$currentBtn.on("click", function (e) {
e.preventDefault();
$(this).addClass("active");
$(this).siblings(".active").removeClass("active");
linePos();
});
// Indicator Position
function linePos() {
var $btnActive = $menu.find(".active"),
$height = $btnActive.css("height"),
$width = $btnActive.css("width"),
$top = $btnActive.position().top + "px",
$left = $btnActive.position().left + "px";
$(window).on('resize', function () {
$top = $btnActive.position().top + "px",
$left = $btnActive.position().left + "px";
});
$line.get(0).style.setProperty("--height-set", $height);
$line.get(0).style.setProperty("--width-set", $width);
$line.get(0).style.setProperty("--pos-y", $top);
$line.get(0).style.setProperty("--pos-x", $left);
}
linePos();
$(window).on('resize', function () {
linePos();
});
});
};
if ($(".indicator-active").length) {
$(".indicator-active").indicator();
}
/*---------- 15. Default Tab ----------*/
$.fn.defaultTab = function (options) {
var opt = $.extend(
{
sliderTab: false,
tabButton: "button",
},
options
);
$(this).each(function () {
var $menu = $(this);
var $button = $menu.find(opt.tabButton);
// Append indicator
$menu.append('');
var $line = $menu.find(".indicator");
// On Click Button Class Remove and indecator postion set
$button.on("click", function (e) {
e.preventDefault();
var cBtn = $(this);
cBtn.addClass("active").siblings().removeClass("active");
if (opt.sliderTab) {
$(slider).slick("slickGoTo", cBtn.data("slide-go-to"));
} else {
linePos();
}
});
// Work With slider
if (opt.sliderTab) {
var slider = $menu.data("asnavfor"); // select slider
// Select All button and set attribute
var i = 0;
$button.each(function () {
var slideBtn = $(this);
slideBtn.attr("data-slide-go-to", i);
i++;
// Active Slide On load > Actived Button
if (slideBtn.hasClass("active")) {
$(slider).slick(
"slickGoTo",
slideBtn.data("slide-go-to")
);
}
// Change Indicator On slide Change
$(slider).on(
"beforeChange",
function (event, slick, currentSlide, nextSlide) {
$menu
.find(
opt.tabButton +
'[data-slide-go-to="' +
nextSlide +
'"]'
)
.addClass("active")
.siblings()
.removeClass("active");
linePos();
}
);
});
}
// Indicator Position
function linePos() {
var $btnActive = $menu.find(opt.tabButton + ".active"),
$height = $btnActive.css("height"),
$width = $btnActive.css("width"),
$top = $btnActive.position().top + "px",
$left = $btnActive.position().left + "px";
$line.get(0).style.setProperty("--height-set", $height);
$line.get(0).style.setProperty("--width-set", $width);
$line.get(0).style.setProperty("--pos-y", $top);
$line.get(0).style.setProperty("--pos-x", $left);
if (
$($button).first().position().left ==
$btnActive.position().left
) {
$line
.addClass("start")
.removeClass("center")
.removeClass("end");
} else if (
$($button).last().position().left ==
$btnActive.position().left
) {
$line
.addClass("end")
.removeClass("center")
.removeClass("start");
} else {
$line
.addClass("center")
.removeClass("start")
.removeClass("end");
}
}
linePos();
});
};
if ($(".blog-tab").length) {
$(".blog-tab").defaultTab({
sliderTab: true,
tabButton: ".tab-btn",
});
}
if ($(".shop-slider-indicator").length) {
$(".shop-slider-indicator").defaultTab({
sliderTab: true,
tabButton: ".slider-indicator",
});
}
/*----------- 18. Shape Mockup ----------*/
$.fn.shapeMockup = function () {
var $shape = $(this);
$shape.each(function () {
var $currentShape = $(this),
shapeTop = $currentShape.data("top"),
shapeRight = $currentShape.data("right"),
shapeBottom = $currentShape.data("bottom"),
shapeLeft = $currentShape.data("left");
$currentShape
.css({
top: shapeTop,
right: shapeRight,
bottom: shapeBottom,
left: shapeLeft,
})
.removeAttr("data-top")
.removeAttr("data-right")
.removeAttr("data-bottom")
.removeAttr("data-left")
.parent()
.addClass("shape-mockup-wrap");
});
};
if ($(".shape-mockup")) {
$(".shape-mockup").shapeMockup();
}
/*----------- 19. Countdown ----------*/
$.fn.countdown = function () {
$(this).each(function () {
var $counter = $(this),
countDownDate = new Date($counter.data("offer-date")).getTime(), // Set the date we're counting down toz
exprireCls = "expired";
// Finding Function
function s$(element) {
return $counter.find(element);
}
// Update the count down every 1 second
var counter = setInterval(function () {
// Get today's date and time
var now = new Date().getTime();
// Find the distance between now and the count down date
var distance = countDownDate - now;
// Time calculations for days, hours, minutes and seconds
var days = Math.floor(distance / (1000 * 60 * 60 * 24));
var hours = Math.floor(
(distance % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60)
);
var minutes = Math.floor(
(distance % (1000 * 60 * 60)) / (1000 * 60)
);
var seconds = Math.floor((distance % (1000 * 60)) / 1000);
// Check If value is lower than ten, so add zero before number
days < 10 ? (days = "0" + days) : null;
hours < 10 ? (hours = "0" + hours) : null;
minutes < 10 ? (minutes = "0" + minutes) : null;
seconds < 10 ? (seconds = "0" + seconds) : null;
// If the count down is over, write some text
if (distance < 0) {
clearInterval(counter);
$counter.addClass(exprireCls);
$counter.find(".message").css("display", "block");
} else {
// Output the result in elements
s$(".day").html(days);
s$(".hour").html(hours);
s$(".minute").html(minutes);
s$(".seconds").html(seconds);
}
}, 1000);
});
};
if ($(".counter-list").length) {
$(".counter-list").countdown();
}
/*----------- 20. Progress Bar Animation ----------*/
$('.progress-bar').waypoint(function () {
$('.progress-bar').css({
animation: "animate-positive 1.8s",
opacity: "1"
});
}, {offset: '75%'});
/*----------- 22. One Page Nav ----------*/
function onePageNav(element) {
if ($(element).length > 0) {
$(element).each(function () {
var link = $(this).find('a');
$(this).find(link).each(function () {
$(this).on('click', function () {
var target = $(this.getAttribute('href'));
if (target.length) {
event.preventDefault();
$('html, body').stop().animate({
scrollTop: target.offset().top - 10
}, 1000);
}
;
});
});
})
}
};
onePageNav('.onepage-nav');
//one page sticky menu
$(window).on('scroll', function () {
if ($('.onepage-nav').length > 0) {
if ($(window).scrollTop() > 0) {
$('.nav-header .sticky-active').addClass('sticky');
} else {
$('.nav-header .sticky-active').removeClass('sticky');
}
}
;
});
/*----------- 23. Indicator ----------*/
// Indicator
$.fn.indicator = function () {
var $menu = $(this),
$linkBtn = $menu.find("a"),
$btn = $menu.find("button");
// Append indicator
$menu.append('');
var $line = $menu.find(".indicator");
// Check which type button is Available
if ($linkBtn.length) {
var $currentBtn = $linkBtn;
} else if ($btn.length) {
var $currentBtn = $btn;
}
// On Click Button Class Remove
$currentBtn.on("click", function (e) {
e.preventDefault();
$(this).addClass("active");
$(this).siblings(".active").removeClass("active");
linePos();
});
function linePos() {
var $btnActive = $menu.find(".active"),
$height = $btnActive.css("height"),
$width = $btnActive.css("width"),
$top = $btnActive.position().top + "px",
$left = $btnActive.position().left + "px";
$(window).on('resize', function () {
$top = $btnActive.position().top + "px",
$left = $btnActive.position().left + "px";
});
$line.get(0).style.setProperty("--height-set", $height);
$line.get(0).style.setProperty("--width-set", $width);
$line.get(0).style.setProperty("--pos-y", $top);
$line.get(0).style.setProperty("--pos-x", $left);
}
linePos();
};
// Call On Load
if ($(".indicator-active").length) {
$(".indicator-active").indicator();
}
/*----------- 00. Woocommerce Toggle ----------*/
// Ship To Different Address
$("#ship-to-different-address-checkbox").on("change", function () {
if ($(this).is(":checked")) {
$("#ship-to-different-address")
.next(".shipping_address")
.slideDown();
} else {
$("#ship-to-different-address").next(".shipping_address").slideUp();
}
});
// Login Toggle
$(".woocommerce-form-login-toggle a").on("click", function (e) {
e.preventDefault();
$(".woocommerce-form-login").slideToggle();
});
// Coupon Toggle
$(".woocommerce-form-coupon-toggle a").on("click", function (e) {
e.preventDefault();
$(".woocommerce-form-coupon").slideToggle();
});
// Woocommerce Shipping Method
$(".shipping-calculator-button").on("click", function (e) {
e.preventDefault();
$(this).next(".shipping-calculator-form").slideToggle();
});
// Woocommerce Payment Toggle
$('.wc_payment_methods input[type="radio"]:checked')
.siblings(".payment_box")
.show();
$('.wc_payment_methods input[type="radio"]').each(function () {
$(this).on("change", function () {
$(".payment_box").slideUp();
$(this).siblings(".payment_box").slideDown();
});
});
// Woocommerce Rating Toggle
$(".rating-select .stars a").each(function () {
$(this).on("click", function (e) {
e.preventDefault();
$(this).siblings().removeClass("active");
$(this).parent().parent().addClass("selected");
$(this).addClass("active");
});
});
// WooCommerce product Popup
var $rtl = $('body').hasClass("rtl") ? true : false;
if ($('.woo-spimg').length) {
$('.woo-spimg').magnificPopup({
delegate: 'a',
type: 'image',
mainClass: 'mfp-zoom-out', // this class is for CSS animation below
gallery: {enabled: true},
zoom: {
enabled: true,
duration: 300,
easing: 'ease-in-out',
opener: function (openerElement) {
return openerElement.is('img') ? openerElement : openerElement.find('img');
}
}
});
}
// WooCommerce Big Image
if ($('.woo-product-big-img').length) {
$('.woo-product-big-img').slick({
slidesToShow: 1,
slidesToScroll: 1,
arrows: false,
fade: true,
asNavFor: '.woo-product-small-img',
rtl: $rtl,
});
}
// WooCommerce Small Image
if ($('.woo-product-small-img').length) {
$('.woo-product-small-img').slick({
slidesToShow: 4,
slidesToScroll: 1,
asNavFor: '.woo-product-big-img',
dots: true,
arrows: false,
focusOnSelect: true,
centerMode: true,
centerPadding: '60px',
rtl: $rtl,
});
}
// Quantity Plus Minus ---------------------------
$(".quantity-plus").each(function () {
$(this).on("click", function (e) {
e.preventDefault();
var $qty = $(this).siblings(".qty-input");
var currentVal = parseInt($qty.val());
if (!isNaN(currentVal)) {
$qty.val(currentVal + 1);
}
});
});
$(".quantity-minus").each(function () {
$(this).on("click", function (e) {
e.preventDefault();
var $qty = $(this).siblings(".qty-input");
var currentVal = parseInt($qty.val());
if (!isNaN(currentVal) && currentVal > 1) {
$qty.val(currentVal - 1);
}
});
});
jQuery(
$('.owl-carousel').owlCarousel({
loop: true,
margin: 10,
nav: true,
autoplay: 8000,
autoplayHoverPause: true,
responsive: {
0: {
items: 1
},
600: {
items: 1
},
1000: {
items: 1
}
}
})
)
/*----------- 13. Dark Mode Toggle ----------*/
// Function to toggle the theme
function toggleTheme() {
$("html").toggleClass("dark-theme").removeClass("light-theme");
const currentTheme = $("html").hasClass("dark-theme") ? "dark" : "light";
$("html").attr("data-theme", currentTheme);
$('.theme-switcher').toggleClass('active');
// Save the theme preference to localStorage
localStorage.setItem("themePreference", currentTheme);
}
// Check if the theme preference is saved in localStorage and apply it
const savedTheme = localStorage.getItem("themePreference");
if (savedTheme) {
if (savedTheme === "dark") {
$("html").addClass("dark-theme").attr("data-theme", "dark");
$('.theme-switcher').addClass('active');
} else {
$("html").addClass("light-theme").attr("data-theme", "light");
$('.theme-switcher').removeClass('active');
}
}
// Attach click event handler to theme toggler
$(".theme-toggler, .theme-switcher").on("click", function (e) {
e.preventDefault();
toggleTheme();
});
/*===========================================
= Marquee Active =
=============================================*/
if ($(".marquee_mode").length) {
$('.marquee_mode').marquee({
speed: 50,
gap: 0,
delayBeforeStart: 0,
direction: 'left',
duplicated: true,
pauseOnHover: true,
startVisible: true,
});
}
})(jQuery);
// newsticker loader js
jQuery(window).on('load',
loader_spinner_control()
);
function loader_spinner_control() {
jQuery(".top-news-ticker-loader").css('display', 'none');
jQuery(".top-news-ticker-content").css('display', 'block');
}
// ============== mobile menu when last item then back to aria expanded ==============
document.addEventListener('DOMContentLoaded', function () {
const menuToggle = document.querySelector('.menu-toggle');
const mobileMenuWrapper = document.querySelector('.mobile-menu-wrapper');
const closeButton = document.querySelector('.mobile-menu-wrapper .menu-toggle');
const mobileMenuLinks = document.querySelectorAll('.mobile-menu a');
// Function to toggle the mobile menu visibility
const toggleMobileMenu = () => {
const isOpen = mobileMenuWrapper.classList.toggle('open');
if (isOpen) {
closeButton.focus(); // Focus on the close button when the menu opens
} else {
menuToggle.focus(); // Focus back on menuToggle when the menu closes
}
};
// Add click event to open/close the menu
menuToggle.addEventListener('click', toggleMobileMenu);
closeButton.addEventListener('click', toggleMobileMenu);
// Handle tab navigation to loop focus back to the close button
mobileMenuWrapper.addEventListener('keydown', (event) => {
if (event.key === 'Tab') {
const focusableElements = Array.from(
mobileMenuWrapper.querySelectorAll('a, button, [tabindex]:not([tabindex="-1"])')
);
const firstElement = focusableElements[0];
const lastElement = focusableElements[focusableElements.length - 1];
if (event.shiftKey && document.activeElement === firstElement) {
// If Shift + Tab is pressed on the first element, loop to the last
event.preventDefault();
lastElement.focus();
} else if (!event.shiftKey && document.activeElement === lastElement) {
// If Tab is pressed on the last element, loop to the close button
event.preventDefault();
firstElement.focus();
}
}
});
});