Files
2026-05-17 18:29:30 -05:00

1791 lines
56 KiB
JavaScript

"use strict";
(function () {
// Global variables
var userAgent = navigator.userAgent.toLowerCase(),
initialDate = new Date(),
$document = $(document),
$window = $(window),
$html = $("html"),
$body = $("body"),
isDesktop = $html.hasClass("desktop"),
isIE = userAgent.indexOf("msie") !== -1 ? parseInt(userAgent.split("msie")[1], 10) : userAgent.indexOf("trident") !== -1 ? 11 : userAgent.indexOf("edge") !== -1 ? 12 : false,
isMobile = /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent),
windowReady = false,
isNoviBuilder = false,
loaderTimeoutId,
plugins = {
bootstrapModalDialog: $('.modal'),
rdNavbar: $(".rd-navbar"),
materialParallax: $(".parallax-container"),
rdMailForm: $(".rd-mailform"),
rdInputLabel: $(".form-label"),
regula: $("[data-constraints]"),
wow: $(".wow"),
owl: $(".owl-carousel"),
swiper: $(".swiper-slider"),
search: $(".rd-search"),
searchResults: $('.rd-search-results'),
isotope: $(".isotope-wrap"),
radio: $("input[type='radio']"),
checkbox: $("input[type='checkbox']"),
customToggle: $("[data-custom-toggle]"),
preloader: $(".preloader"),
captcha: $('.recaptcha'),
scroller: $(".scroll-wrap"),
lightGallery: $("[data-lightgallery='group']"),
lightGalleryItem: $("[data-lightgallery='item']"),
lightDynamicGalleryItem: $("[data-lightgallery='dynamic']"),
mailchimp: $('.mailchimp-mailform'),
campaignMonitor: $('.campaign-mailform'),
copyrightYear: $(".copyright-year"),
layoutToggle: $(".layout-toggle"),
themeSwitcher: $("[data-color-picker], [data-theme-name]"),
themeCheckbox: $("[data-theme-checkbox]"),
buttonNina: $('.button-nina'),
typedjs: $('.typed-text-wrap'),
projectToggle: $('[data-project-toggle]'),
maps: $(".google-map-container"),
parallaxJs: $('.parallax-scene'),
customWaypoints: $('[data-custom-scroll-to]'),
vide: $(".vide_bg"),
tiltHover: $('.js-tilt'),
counter: document.querySelectorAll('.counter'),
progressLinear: document.querySelectorAll('.progress-linear'),
};
/**
* @desc Check the element was been scrolled into the view
* @param {object} elem - jQuery object
* @return {boolean}
*/
function isScrolledIntoView(elem) {
if (isNoviBuilder) return true;
return elem.offset().top + elem.outerHeight() >= $window.scrollTop() && elem.offset().top <= $window.scrollTop() + $window.height();
}
/**
* @desc Calls a function when element has been scrolled into the view
* @param {object} element - jQuery object
* @param {function} func - init function
*/
function lazyInit(element, func) {
let scrollHandler = function () {
if ((!element.hasClass('lazy-loaded') && (isScrolledIntoView(element)))) {
func.call(element);
element.addClass('lazy-loaded');
}
};
scrollHandler();
$window.on('scroll', scrollHandler);
}
// Initialize scripts that require a loaded page
$window.on('load', function () {
// Page loader & Page transition
if (plugins.preloader.length && !isNoviBuilder) {
pageTransition({
target: document.querySelector( '.page' ),
delay: 0,
duration: 500,
classIn: 'fadeIn',
classOut: 'fadeOut',
classActive: 'animated',
conditions: function (event, link) {
return !/(\#|callto:|tel:|mailto:|:\/\/)/.test(link) && !event.currentTarget.hasAttribute('data-lightgallery');
},
onTransitionStart: function ( options ) {
setTimeout( function () {
plugins.preloader.removeClass('loaded');
}, options.duration * .75 );
},
onReady: function () {
plugins.preloader.addClass('loaded');
windowReady = true;
}
});
}
/**
* WOW
* @description Enables Wow animation plugin
*/
if ($html.hasClass("wow-animation") && plugins.wow.length && !isNoviBuilder && isDesktop) {
setTimeout(function() {
new WOW().initCustom()
},500)
}
// Isotope
if (plugins.isotope.length) {
for (let i = 0; i < plugins.isotope.length; i++) {
let
wrap = plugins.isotope[i],
filterHandler = function (event) {
event.preventDefault();
for (let n = 0; n < this.isoGroup.filters.length; n++) this.isoGroup.filters[n].classList.remove('active');
this.classList.add('active');
this.isoGroup.isotope.arrange({filter: this.getAttribute("data-isotope-filter") !== '*' ? '[data-filter*="' + this.getAttribute("data-isotope-filter") + '"]' : '*'});
},
resizeHandler = function () {
this.isoGroup.isotope.layout();
};
wrap.isoGroup = {};
wrap.isoGroup.filters = wrap.querySelectorAll('[data-isotope-filter]');
wrap.isoGroup.node = wrap.querySelector('.isotope');
wrap.isoGroup.layout = wrap.isoGroup.node.getAttribute('data-isotope-layout') ? wrap.isoGroup.node.getAttribute('data-isotope-layout') : 'masonry';
wrap.isoGroup.isotope = new Isotope(wrap.isoGroup.node, {
itemSelector: '.isotope-item',
layoutMode: wrap.isoGroup.layout,
filter: '*',
columnWidth: (function () {
if (wrap.isoGroup.node.hasAttribute('data-column-class')) return wrap.isoGroup.node.getAttribute('data-column-class');
if (wrap.isoGroup.node.hasAttribute('data-column-width')) return parseFloat(wrap.isoGroup.node.getAttribute('data-column-width'));
}())
});
for (let n = 0; n < wrap.isoGroup.filters.length; n++) {
let filter = wrap.isoGroup.filters[n];
filter.isoGroup = wrap.isoGroup;
filter.addEventListener('click', filterHandler);
}
window.addEventListener('resize', resizeHandler.bind(wrap));
}
}
// Counter
if (plugins.counter) {
for (let i = 0; i < plugins.counter.length; i++) {
let
node = plugins.counter[i],
counter = aCounter({
node: node,
duration: node.getAttribute('data-duration') || 1000
}),
scrollHandler = (function () {
if (Util.inViewport(this) && !this.classList.contains('animated-first')) {
this.counter.run();
this.classList.add('animated-first');
}
}).bind(node),
blurHandler = (function () {
this.counter.params.to = parseInt(this.textContent, 10);
this.counter.run();
}).bind(node);
if (isNoviBuilder) {
node.counter.run();
node.addEventListener('blur', blurHandler);
} else {
scrollHandler();
window.addEventListener('scroll', scrollHandler);
}
}
}
// Progress Bar
if (plugins.progressLinear) {
for (let i = 0; i < plugins.progressLinear.length; i++) {
let
container = plugins.progressLinear[i],
counter = aCounter({
node: container.querySelector('.progress-linear-counter'),
duration: container.getAttribute('data-duration') || 1000,
onStart: function () {
this.custom.bar.style.width = this.params.to + '%';
}
});
counter.custom = {
container: container,
bar: container.querySelector('.progress-linear-bar'),
onScroll: (function () {
if ((Util.inViewport(this.custom.container) && !this.custom.container.classList.contains('animated')) || isNoviBuilder) {
this.run();
this.custom.container.classList.add('animated');
}
}).bind(counter),
onBlur: (function () {
this.params.to = parseInt(this.params.node.textContent, 10);
this.run();
}).bind(counter)
};
if (isNoviBuilder) {
counter.run();
counter.params.node.addEventListener('blur', counter.custom.onBlur);
} else {
counter.custom.onScroll();
document.addEventListener('scroll', counter.custom.onScroll);
}
}
}
});
// Initialize scripts that require a finished document
$(function () {
isNoviBuilder = window.xMode;
/**
* Wrapper to eliminate json errors
* @param {string} str - JSON string
* @returns {object} - parsed or empty object
*/
function parseJSON ( str ) {
try {
if ( str ) return JSON.parse( str );
else return {};
} catch ( error ) {
console.warn( error );
return {};
}
}
/**
* @desc Sets the actual previous index based on the position of the slide in the markup. Should be the most recent action.
* @param {object} swiper - swiper instance
*/
function setRealPrevious(swiper) {
let element = swiper.$wrapperEl[0].children[swiper.activeIndex];
swiper.realPrevious = Array.prototype.indexOf.call(element.parentNode.children, element);
}
/**
* @desc Sets slides background images from attribute 'data-slide-bg'
* @param {object} swiper - swiper instance
*/
function setBackgrounds(swiper) {
let swipersBg = swiper.el.querySelectorAll('[data-slide-bg]');
for (let i = 0; i < swipersBg.length; i++) {
let swiperBg = swipersBg[i];
swiperBg.style.backgroundImage = 'url(' + swiperBg.getAttribute('data-slide-bg') + ')';
}
}
/**
* @desc Animate captions on active slides
* @param {object} swiper - swiper instance
*/
function initCaptionAnimate(swiper) {
let
animate = function (caption) {
return function () {
let duration;
if (duration = caption.getAttribute('data-caption-duration')) caption.style.animationDuration = duration + 'ms';
caption.classList.remove('not-animated');
caption.classList.add(caption.getAttribute('data-caption-animate'));
caption.classList.add('animated');
};
},
initializeAnimation = function (captions) {
for (let i = 0; i < captions.length; i++) {
let caption = captions[i];
caption.classList.remove('animated');
caption.classList.remove(caption.getAttribute('data-caption-animate'));
caption.classList.add('not-animated');
}
},
finalizeAnimation = function (captions) {
for (let i = 0; i < captions.length; i++) {
let caption = captions[i];
if (caption.getAttribute('data-caption-delay')) {
setTimeout(animate(caption), Number(caption.getAttribute('data-caption-delay')));
} else {
animate(caption)();
}
}
};
// Caption parameters
swiper.params.caption = {
animationEvent: 'slideChangeTransitionEnd'
};
initializeAnimation(swiper.$wrapperEl[0].querySelectorAll('[data-caption-animate]'));
finalizeAnimation(swiper.$wrapperEl[0].children[swiper.activeIndex].querySelectorAll('[data-caption-animate]'));
if (swiper.params.caption.animationEvent === 'slideChangeTransitionEnd') {
swiper.on(swiper.params.caption.animationEvent, function () {
initializeAnimation(swiper.$wrapperEl[0].children[swiper.previousIndex].querySelectorAll('[data-caption-animate]'));
finalizeAnimation(swiper.$wrapperEl[0].children[swiper.activeIndex].querySelectorAll('[data-caption-animate]'));
});
} else {
swiper.on('slideChangeTransitionEnd', function () {
initializeAnimation(swiper.$wrapperEl[0].children[swiper.previousIndex].querySelectorAll('[data-caption-animate]'));
});
swiper.on(swiper.params.caption.animationEvent, function () {
finalizeAnimation(swiper.$wrapperEl[0].children[swiper.activeIndex].querySelectorAll('[data-caption-animate]'));
});
}
}
/**
* initNinaButtons
* @description Make hover effect for nina buttons
*/
function initNinaButtons(ninaButtons) {
for (var i = 0; i < ninaButtons.length; i++) {
var btn = ninaButtons[i],
origContent = btn.innerHTML.trim();
if (!origContent) {
continue;
}
var textNode = Array.prototype.slice.call(ninaButtons[i].childNodes).filter(function (node) {
return node.nodeType === 3;
}).pop();
if (textNode == null) {
continue;
}
var dummy = document.createElement('div');
btn.replaceChild(dummy, textNode);
dummy.outerHTML = textNode.textContent.split('').map(function (letter) {
return "<span>" + letter.trim() + "</span>";
}).join('');
Array.prototype.slice.call(btn.childNodes).forEach(function (el, count) {
el.style.transition = 'opacity .22s ' + 0.03 * count + 's,' + ' transform .22s ' + 0.03 * count + 's' + ', color .22s';
});
btn.innerHTML += "<span class='button-original-content'>" + origContent + "</span>";
var delay = 0.03 * (btn.childElementCount - 1);
// btn.getElementsByClassName('button-original-content')[0].style.transitionDelay = delay + 's';
btn.getElementsByClassName('button-original-content')[0].style.transition = 'background .22s, color .22s, transform .22s ' + delay + 's';
btn.addEventListener('mouseenter', function(e) {
e.stopPropagation();
});
btn.addEventListener('mouseleave', function(e) {
e.stopPropagation();
});
}
}
/**
* @desc Google map function for getting latitude and longitude
*/
function getLatLngObject(str, marker, map, callback) {
let coordinates = {};
try {
coordinates = JSON.parse(str);
callback(new google.maps.LatLng(
coordinates.lat,
coordinates.lng
), marker, map)
} catch (e) {
map.geocoder.geocode({'address': str}, function (results, status) {
if (status === google.maps.GeocoderStatus.OK) {
let latitude = results[0].geometry.location.lat();
let longitude = results[0].geometry.location.lng();
callback(new google.maps.LatLng(
parseFloat(latitude),
parseFloat(longitude)
), marker, map)
}
})
}
}
/**
* @desc Initialize Google maps
*/
function initMaps() {
let key;
for (let i = 0; i < plugins.maps.length; i++) {
if (plugins.maps[i].hasAttribute("data-key")) {
key = plugins.maps[i].getAttribute("data-key");
break;
}
}
$.getScript('//maps.google.com/maps/api/js?' + (key ? 'key=' + key + '&' : '') + 'libraries=geometry,places&v=quarterly', function () {
let head = document.getElementsByTagName('head')[0],
insertBefore = head.insertBefore;
head.insertBefore = function (newElement, referenceElement) {
if (newElement.href && newElement.href.indexOf('//fonts.googleapis.com/css?family=Roboto') !== -1 || newElement.innerHTML.indexOf('gm-style') !== -1) {
return;
}
insertBefore.call(head, newElement, referenceElement);
};
let geocoder = new google.maps.Geocoder;
for (let i = 0; i < plugins.maps.length; i++) {
let zoom = parseInt(plugins.maps[i].getAttribute("data-zoom"), 10) || 5;
let styles = plugins.maps[i].hasAttribute('data-styles') ? JSON.parse(plugins.maps[i].getAttribute("data-styles")) : [];
let center = plugins.maps[i].getAttribute("data-center") || "New York";
// Initialize map
let map = new google.maps.Map(plugins.maps[i].querySelectorAll(".google-map")[0], {
zoom: zoom,
styles: styles,
scrollwheel: false,
center: {
lat: 0,
lng: 0
}
});
// Add map object to map node
plugins.maps[i].map = map;
plugins.maps[i].geocoder = geocoder;
plugins.maps[i].keySupported = true;
plugins.maps[i].google = google;
// Get Center coordinates from attribute
getLatLngObject(center, null, plugins.maps[i], function (location, markerElement, mapElement) {
mapElement.map.setCenter(location);
});
// Add markers from google-map-markers array
let markerItems = plugins.maps[i].querySelectorAll(".google-map-markers li");
if (markerItems.length) {
let markers = [];
for (let j = 0; j < markerItems.length; j++) {
let markerElement = markerItems[j];
getLatLngObject(markerElement.getAttribute("data-location"), markerElement, plugins.maps[i], function (location, markerElement, mapElement) {
let icon = markerElement.getAttribute("data-icon") || mapElement.getAttribute("data-icon");
let activeIcon = markerElement.getAttribute("data-icon-active") || mapElement.getAttribute("data-icon-active");
let info = markerElement.getAttribute("data-description") || "";
let infoWindow = new google.maps.InfoWindow({
content: info
});
markerElement.infoWindow = infoWindow;
let markerData = {
position: location,
map: mapElement.map
}
if (icon) {
markerData.icon = icon;
}
let marker = new google.maps.Marker(markerData);
markerElement.gmarker = marker;
markers.push({
markerElement: markerElement,
infoWindow: infoWindow
});
marker.isActive = false;
// Handle infoWindow close click
google.maps.event.addListener(infoWindow, 'closeclick', (function (markerElement, mapElement) {
let markerIcon = null;
markerElement.gmarker.isActive = false;
markerIcon = markerElement.getAttribute("data-icon") || mapElement.getAttribute("data-icon");
markerElement.gmarker.setIcon(markerIcon);
}).bind(this, markerElement, mapElement));
// Set marker active on Click and open infoWindow
google.maps.event.addListener(marker, 'click', (function (markerElement, mapElement) {
let markerIcon;
if (markerElement.infoWindow.getContent().length === 0) return;
let gMarker, currentMarker = markerElement.gmarker, currentInfoWindow;
for (let k = 0; k < markers.length; k++) {
if (markers[k].markerElement === markerElement) {
currentInfoWindow = markers[k].infoWindow;
}
gMarker = markers[k].markerElement.gmarker;
if (gMarker.isActive && markers[k].markerElement !== markerElement) {
gMarker.isActive = false;
markerIcon = markers[k].markerElement.getAttribute("data-icon") || mapElement.getAttribute("data-icon")
gMarker.setIcon(markerIcon);
markers[k].infoWindow.close();
}
}
currentMarker.isActive = !currentMarker.isActive;
if (currentMarker.isActive) {
if (markerIcon = markerElement.getAttribute("data-icon-active") || mapElement.getAttribute("data-icon-active")) {
currentMarker.setIcon(markerIcon);
}
currentInfoWindow.open(map, marker);
} else {
if (markerIcon = markerElement.getAttribute("data-icon") || mapElement.getAttribute("data-icon")) {
currentMarker.setIcon(markerIcon);
}
currentInfoWindow.close();
}
}).bind(this, markerElement, mapElement))
})
}
}
}
});
}
/**
* @desc Create live search results
* @param {object} options
*/
function liveSearch(options) {
$('#' + options.live).removeClass('cleared').html();
options.current++;
options.spin.addClass('loading');
$.get(handler, {
s: decodeURI(options.term),
liveSearch: options.live,
dataType: "html",
liveCount: options.liveCount,
filter: options.filter,
template: options.template
}, function (data) {
options.processed++;
var live = $('#' + options.live);
if ((options.processed === options.current) && !live.hasClass('cleared')) {
live.find('> #search-results').removeClass('active');
live.html(data);
setTimeout(function () {
live.find('> #search-results').addClass('active');
}, 50);
}
options.spin.parents('.rd-search').find('.input-group-addon').removeClass('loading');
})
}
/**
* @desc Attach form validation to elements
* @param {object} elements - jQuery object
*/
function attachFormValidator(elements) {
// Custom validator - phone number
regula.custom({
name: 'PhoneNumber',
defaultMessage: 'Invalid phone number format',
validator: function() {
if ( this.value === '' ) return true;
else return /^(\+\d)?[0-9\-\(\) ]{5,}$/i.test( this.value );
}
});
for (var i = 0; i < elements.length; i++) {
var o = $(elements[i]), v;
o.addClass("form-control-has-validation").before("<span class='form-validation'></span>");
v = o.parent().find(".form-validation");
if (v.is(":last-child")) o.addClass("form-control-last-child");
}
elements.on('input change propertychange blur', function (e) {
var $this = $(this), results;
if (e.type !== "blur") if (!$this.parent().hasClass("has-error")) return;
if ($this.parents('.rd-mailform').hasClass('success')) return;
if (( results = $this.regula('validate') ).length) {
for (i = 0; i < results.length; i++) {
$this.siblings(".form-validation").text(results[i].message).parent().addClass("has-error");
}
} else {
$this.siblings(".form-validation").text("").parent().removeClass("has-error")
}
}).regula('bind');
var regularConstraintsMessages = [
{
type: regula.Constraint.Required,
newMessage: "The text field is required."
},
{
type: regula.Constraint.Email,
newMessage: "The email is not a valid email."
},
{
type: regula.Constraint.Numeric,
newMessage: "Only numbers are required"
},
{
type: regula.Constraint.Selected,
newMessage: "Please choose an option."
}
];
for (var i = 0; i < regularConstraintsMessages.length; i++) {
var regularConstraint = regularConstraintsMessages[i];
regula.override({
constraintType: regularConstraint.type,
defaultMessage: regularConstraint.newMessage
});
}
}
/**
* @desc Check if all elements pass validation
* @param {object} elements - object of items for validation
* @param {object} captcha - captcha object for validation
* @return {boolean}
*/
function isValidated(elements, captcha) {
var results, errors = 0;
if (elements.length) {
for (var j = 0; j < elements.length; j++) {
var $input = $(elements[j]);
if ((results = $input.regula('validate')).length) {
for (var k = 0; k < results.length; k++) {
errors++;
$input.siblings(".form-validation").text(results[k].message).parent().addClass("has-error");
}
} else {
$input.siblings(".form-validation").text("").parent().removeClass("has-error")
}
}
if (captcha) {
if (captcha.length) {
return validateReCaptcha(captcha) && errors === 0
}
}
return errors === 0;
}
return true;
}
/**
* @desc Validate google reCaptcha
* @param {object} captcha - captcha object for validation
* @return {boolean}
*/
function validateReCaptcha(captcha) {
var captchaToken = captcha.find('.g-recaptcha-response').val();
if (captchaToken.length === 0) {
captcha
.siblings('.form-validation')
.html('Please, prove that you are not robot.')
.addClass('active');
captcha
.closest('.form-wrap')
.addClass('has-error');
captcha.on('propertychange', function () {
var $this = $(this),
captchaToken = $this.find('.g-recaptcha-response').val();
if (captchaToken.length > 0) {
$this
.closest('.form-wrap')
.removeClass('has-error');
$this
.siblings('.form-validation')
.removeClass('active')
.html('');
$this.off('propertychange');
}
});
return false;
}
return true;
}
/**
* @desc Initialize Google reCaptcha
*/
window.onloadCaptchaCallback = function () {
for (var i = 0; i < plugins.captcha.length; i++) {
var $capthcaItem = $(plugins.captcha[i]);
grecaptcha.render(
$capthcaItem.attr('id'),
{
sitekey: $capthcaItem.attr('data-sitekey'),
size: $capthcaItem.attr('data-size') ? $capthcaItem.attr('data-size') : 'normal',
theme: $capthcaItem.attr('data-theme') ? $capthcaItem.attr('data-theme') : 'light',
callback: function (e) {
$('.recaptcha').trigger('propertychange');
}
}
);
$capthcaItem.after("<span class='form-validation'></span>");
}
};
/**
* @desc Initialize the gallery with set of images
* @param {object} itemsToInit - jQuery object
* @param {string} [addClass] - additional gallery class
*/
function initLightGallery(itemsToInit, addClass) {
if (!isNoviBuilder) {
$(itemsToInit).lightGallery({
thumbnail: $(itemsToInit).attr("data-lg-thumbnail") !== "false",
selector: "[data-lightgallery='item']",
autoplay: $(itemsToInit).attr("data-lg-autoplay") === "true",
pause: parseInt($(itemsToInit).attr("data-lg-autoplay-delay")) || 5000,
addClass: addClass,
mode: $(itemsToInit).attr("data-lg-animation") || "lg-slide",
loop: $(itemsToInit).attr("data-lg-loop") !== "false"
});
}
}
/**
* @desc Initialize the gallery with dynamic addition of images
* @param {object} itemsToInit - jQuery object
* @param {string} [addClass] - additional gallery class
*/
function initDynamicLightGallery(itemsToInit, addClass) {
if (!isNoviBuilder) {
$(itemsToInit).on("click", function () {
$(itemsToInit).lightGallery({
thumbnail: $(itemsToInit).attr("data-lg-thumbnail") !== "false",
selector: "[data-lightgallery='item']",
autoplay: $(itemsToInit).attr("data-lg-autoplay") === "true",
pause: parseInt($(itemsToInit).attr("data-lg-autoplay-delay")) || 5000,
addClass: addClass,
mode: $(itemsToInit).attr("data-lg-animation") || "lg-slide",
loop: $(itemsToInit).attr("data-lg-loop") !== "false",
dynamic: true,
dynamicEl: JSON.parse($(itemsToInit).attr("data-lg-dynamic-elements")) || []
});
});
}
}
/**
* @desc Initialize the gallery with one image
* @param {object} itemToInit - jQuery object
* @param {string} [addClass] - additional gallery class
*/
function initLightGalleryItem(itemToInit, addClass) {
if (!isNoviBuilder) {
$(itemToInit).lightGallery({
selector: "this",
addClass: addClass,
counter: false,
youtubePlayerParams: {
modestbranding: 1,
showinfo: 0,
rel: 0,
controls: 0
},
vimeoPlayerParams: {
byline: 0,
portrait: 0
}
});
}
}
/**
* Vide - v0.5.2
* @description jQuery plugin for video backgrounds
*/
for ( let i = 0; i < plugins.vide.length; i++ ) {
let
$element = $(plugins.vide[i]),
options = $element.data('vide-options'),
path = $element.data('vide-bg');
if ( !isMobile ) {
$element.vide( path, options );
let
videObj = $element.data('vide').getVideoObject(),
scrollHandler = (function( $element ) {
if ( isScrolledIntoView( $element ) ) this.play();
else this.pause();
}).bind( videObj, $element );
scrollHandler();
if ( isNoviBuilder ) videObj.pause();
else document.addEventListener( 'scroll', scrollHandler );
} else {
$element.css({ 'background-image': 'url('+ path +'.jpg)' });
}
}
// Google maps
if (plugins.maps.length) {
lazyInit(plugins.maps, initMaps);
}
if ( !isIE ) {
console.log( isIE );
// ripples
$('#section-ripples-1').ripples({
resolution: 512,
perturbance: 0.01,
});
$('#section-ripples-2').ripples({
resolution: 512,
perturbance: 0.01,
});
// Automatic drops
setInterval(function() {
var $el = $('#section-ripples-1, #section-ripples-2');
var x = Math.random() * $el.outerWidth();
var y = Math.random() * $el.outerHeight();
var dropRadius = 20;
var strength = 0.01 + Math.random() * 0.04;
$el.ripples('drop', x, y, dropRadius, strength);
}, 3000);
}
// tilt hover effect
if( plugins.tiltHover.length ) {
plugins.tiltHover.tilt({
maxTilt: 5,
glare: true,
maxGlare: .5
})
}
// Google ReCaptcha
if (plugins.captcha.length) {
$.getScript("//www.google.com/recaptcha/api.js?onload=onloadCaptchaCallback&render=explicit&hl=en");
}
// Additional class on html if mac os.
if (navigator.platform.match(/(Mac)/i)) {
$html.addClass("mac-os");
}
// Adds some loosing functionality to IE browsers (IE Polyfills)
if (isIE) {
if (isIE < 10) {
$html.addClass("lt-ie-10");
}
if (isIE < 11) {
$.getScript('js/pointer-events.min.js')
.done(function () {
$html.addClass("ie-10");
PointerEventsPolyfill.initialize({});
});
}
if (isIE === 11) {
$html.addClass("ie-11");
}
if (isIE === 12) {
$html.addClass("ie-edge");
}
}
// Stop vioeo in bootstrapModalDialog
if (plugins.bootstrapModalDialog.length) {
for (var i = 0; i < plugins.bootstrapModalDialog.length; i++) {
var modalItem = $(plugins.bootstrapModalDialog[i]);
modalItem.on('hidden.bs.modal', $.proxy(function () {
var activeModal = $(this),
rdVideoInside = activeModal.find('video'),
youTubeVideoInside = activeModal.find('iframe');
if (rdVideoInside.length) {
rdVideoInside[0].pause();
}
if (youTubeVideoInside.length) {
var videoUrl = youTubeVideoInside.attr('src');
youTubeVideoInside
.attr('src', '')
.attr('src', videoUrl);
}
}, modalItem))
}
}
// Copyright Year (Evaluates correct copyright year)
if (plugins.copyrightYear.length) {
plugins.copyrightYear.text(initialDate.getFullYear());
}
// Page loader
if (plugins.preloader.length) {
loaderTimeoutId = setTimeout(function () {
if (!windowReady && !isNoviBuilder) plugins.preloader.removeClass('loaded');
}, 2000);
}
// Add custom styling options for input[type="radio"]
if (plugins.radio.length) {
for (var i = 0; i < plugins.radio.length; i++) {
$(plugins.radio[i]).addClass("radio-custom").after("<span class='radio-custom-dummy'></span>")
}
}
// Add custom styling options for input[type="checkbox"]
if (plugins.checkbox.length) {
for (var i = 0; i < plugins.checkbox.length; i++) {
$(plugins.checkbox[i]).addClass("checkbox-custom").after("<span class='checkbox-custom-dummy'></span>")
}
}
// UI To Top
if (isDesktop && !isNoviBuilder) {
$().UItoTop({
easingType: 'easeOutQuad',
containerClass: 'ui-to-top mdi mdi-arrow-up'
});
}
// RD Navbar
if (plugins.rdNavbar.length) {
let
navbar = plugins.rdNavbar,
aliases = {
'-': 0,
'-sm-': 576,
'-md-': 768,
'-lg-': 992,
'-xl-': 1200,
'-xxl-': 1600
},
responsive = {};
for (let alias in aliases) {
let link = responsive[aliases[alias]] = {};
if (navbar.attr('data' + alias + 'layout')) link.layout = navbar.attr('data' + alias + 'layout');
if (navbar.attr('data' + alias + 'device-layout')) link.deviceLayout = navbar.attr('data' + alias + 'device-layout');
if (navbar.attr('data' + alias + 'hover-on')) link.focusOnHover = navbar.attr('data' + alias + 'hover-on') === 'true';
if (navbar.attr('data' + alias + 'auto-height')) link.autoHeight = navbar.attr('data' + alias + 'auto-height') === 'true';
if (navbar.attr('data' + alias + 'stick-up-offset')) link.stickUpOffset = navbar.attr('data' + alias + 'stick-up-offset');
if (navbar.attr('data' + alias + 'stick-up')) link.stickUp = navbar.attr('data' + alias + 'stick-up') === 'true';
if (isNoviBuilder) link.stickUp = false;
else if (navbar.attr('data' + alias + 'stick-up')) link.stickUp = navbar.attr('data' + alias + 'stick-up') === 'true';
}
plugins.rdNavbar.RDNavbar({
anchorNav: !isNoviBuilder,
stickUpClone: (plugins.rdNavbar.attr("data-stick-up-clone") && !isNoviBuilder) ? plugins.rdNavbar.attr("data-stick-up-clone") === 'true' : false,
responsive: responsive,
callbacks: {
onStuck: function () {
let navbarSearch = this.$element.find('.rd-search input');
if (navbarSearch) {
navbarSearch.val('').trigger('propertychange');
}
},
onDropdownOver: function () {
return !isNoviBuilder;
},
onUnstuck: function () {
if (this.$clone === null)
return;
let navbarSearch = this.$clone.find('.rd-search input');
if (navbarSearch) {
navbarSearch.val('').trigger('propertychange');
navbarSearch.trigger('blur');
}
}
}
});
}
// RD Search
if (plugins.search.length || plugins.searchResults) {
var handler = "bat/rd-search.php";
var defaultTemplate = '<h5 class="search-title"><a target="_top" href="#{href}" class="search-link">#{title}</a></h5>' +
'<p>...#{token}...</p>' +
'<p class="match"><em>Terms matched: #{count} - URL: #{href}</em></p>';
var defaultFilter = '*.html';
if (plugins.search.length) {
for (var i = 0; i < plugins.search.length; i++) {
var searchItem = $(plugins.search[i]),
options = {
element: searchItem,
filter: (searchItem.attr('data-search-filter')) ? searchItem.attr('data-search-filter') : defaultFilter,
template: (searchItem.attr('data-search-template')) ? searchItem.attr('data-search-template') : defaultTemplate,
live: (searchItem.attr('data-search-live')) ? searchItem.attr('data-search-live') : false,
liveCount: (searchItem.attr('data-search-live-count')) ? parseInt(searchItem.attr('data-search-live'), 10) : 4,
current: 0, processed: 0, timer: {}
};
var $toggle = $('.rd-navbar-search-toggle');
if ($toggle.length) {
$toggle.on('click', (function (searchItem) {
return function () {
if (!($(this).hasClass('active'))) {
searchItem.find('input').val('').trigger('propertychange');
}
}
})(searchItem));
}
if (options.live) {
var clearHandler = false;
searchItem.find('input').on("input propertychange", $.proxy(function () {
this.term = this.element.find('input').val().trim();
this.spin = this.element.find('.input-group-addon');
clearTimeout(this.timer);
if (this.term.length > 2) {
this.timer = setTimeout(liveSearch(this), 200);
if (clearHandler === false) {
clearHandler = true;
$body.on("click", function (e) {
if ($(e.toElement).parents('.rd-search').length === 0) {
$('#rd-search-results-live').addClass('cleared').html('');
}
})
}
} else if (this.term.length === 0) {
$('#' + this.live).addClass('cleared').html('');
}
}, options, this));
}
searchItem.submit($.proxy(function () {
$('<input />').attr('type', 'hidden')
.attr('name', "filter")
.attr('value', this.filter)
.appendTo(this.element);
return true;
}, options, this))
}
}
if (plugins.searchResults.length) {
var regExp = /\?.*s=([^&]+)\&filter=([^&]+)/g;
var match = regExp.exec(location.search);
if (match !== null) {
$.get(handler, {
s: decodeURI(match[1]),
dataType: "html",
filter: match[2],
template: defaultTemplate,
live: ''
}, function (data) {
plugins.searchResults.html(data);
})
}
}
}
// Swiper
if (plugins.swiper.length) {
for (let i = 0; i < plugins.swiper.length; i++) {
let
node = plugins.swiper[i],
params = parseJSON(node.getAttribute('data-swiper')),
defaults = {
speed: 1000,
loop: true,
pagination: {
el: '.swiper-pagination',
clickable: true
},
navigation: {
nextEl: '.swiper-button-next',
prevEl: '.swiper-button-prev'
},
autoplay: {
delay: 5000
}
},
xMode = {
autoplay: false,
loop: false,
simulateTouch: false
};
params.on = {
init: function () {
setBackgrounds(this);
setRealPrevious(this);
initCaptionAnimate(this);
// Real Previous Index must be set recent
this.on('slideChangeTransitionEnd', function () {
setRealPrevious(this);
});
}
};
new Swiper( node, Util.merge( isNoviBuilder ? [ defaults, params, xMode ] : [ defaults, params ] ) );
}
}
// Owl carousel
if (plugins.owl.length) {
for (let i = 0; i < plugins.owl.length; i++) {
let
node = plugins.owl[i],
params = parseJSON( node.getAttribute( 'data-owl' ) ),
defaults = {
items: 1,
margin: 30,
loop: true,
mouseDrag: false,
stagePadding: 0,
nav: false,
navText: [],
dots: false,
autoplay: true,
autoplayTimeout: 3000,
autoplayHoverPause: true,
smartSpeed: 550,
},
xMode = {
autoplay: false,
loop: false,
mouseDrag: false
},
generated = {
autoplay: node.getAttribute( 'data-autoplay' ) !== 'false',
loop: node.getAttribute( 'data-loop' ) !== 'false',
mouseDrag: node.getAttribute( 'data-mouse-drag' ) !== 'false',
responsive: {}
},
aliases = [ '-', '-sm-', '-md-', '-lg-', '-xl-', '-xxl-' ],
values = [ 0, 576, 768, 992, 1200, 1600 ],
responsive = generated.responsive;
for ( let j = 0; j < values.length; j++ ) {
responsive[ values[ j ] ] = {};
for ( let k = j; k >= -1; k-- ) {
if ( !responsive[ values[ j ] ][ 'items' ] && node.getAttribute( 'data' + aliases[ k ] + 'items' ) ) {
responsive[ values[ j ] ][ 'items' ] = k < 0 ? 1 : parseInt( node.getAttribute( 'data' + aliases[ k ] + 'items' ), 10 );
}
if ( !responsive[ values[ j ] ][ 'stagePadding' ] && responsive[ values[ j ] ][ 'stagePadding' ] !== 0 && node.getAttribute( 'data' + aliases[ k ] + 'stage-padding' ) ) {
responsive[ values[ j ] ][ 'stagePadding' ] = k < 0 ? 0 : parseInt( node.getAttribute( 'data' + aliases[ k ] + 'stage-padding' ), 10 );
}
if ( !responsive[ values[ j ] ][ 'margin' ] && responsive[ values[ j ] ][ 'margin' ] !== 0 && node.getAttribute( 'data' + aliases[ k ] + 'margin' ) ) {
responsive[ values[ j ] ][ 'margin' ] = k < 0 ? 30 : parseInt( node.getAttribute( 'data' + aliases[ k ] + 'margin' ), 10 );
}
}
}
// Initialize lightgallery items in cloned owl items
$(node).on('initialized.owl.carousel', function () {
initLightGalleryItem($(node).find('[data-lightgallery="item"]'), 'lightGallery-in-carousel');
});
node.owl = $( node );
$( node ).owlCarousel( Util.merge( isNoviBuilder ? [ defaults, params, generated, xMode ] : [ defaults, params, generated ] ) );
}
}
// RD Input Label
if (plugins.rdInputLabel.length) {
plugins.rdInputLabel.RDInputLabel();
}
// Regula
if (plugins.regula.length) {
attachFormValidator(plugins.regula);
}
// MailChimp Ajax subscription
if (plugins.mailchimp.length) {
for (i = 0; i < plugins.mailchimp.length; i++) {
var $mailchimpItem = $(plugins.mailchimp[i]),
$email = $mailchimpItem.find('input[type="email"]');
// Required by MailChimp
$mailchimpItem.attr('novalidate', 'true');
$email.attr('name', 'EMAIL');
$mailchimpItem.on('submit', $.proxy( function ( $email, event ) {
event.preventDefault();
var $this = this;
var data = {},
url = $this.attr('action').replace('/post?', '/post-json?').concat('&c=?'),
dataArray = $this.serializeArray(),
$output = $("#" + $this.attr("data-form-output"));
for (i = 0; i < dataArray.length; i++) {
data[dataArray[i].name] = dataArray[i].value;
}
$.ajax({
data: data,
url: url,
dataType: 'jsonp',
error: function (resp, text) {
$output.html('Server error: ' + text);
setTimeout(function () {
$output.removeClass("active");
}, 4000);
},
success: function (resp) {
$output.html(resp.msg).addClass('active');
$email[0].value = '';
var $label = $('[for="'+ $email.attr( 'id' ) +'"]');
if ( $label.length ) $label.removeClass( 'focus not-empty' );
setTimeout(function () {
$output.removeClass("active");
}, 6000);
},
beforeSend: function (data) {
var isNoviBuilder = window.xMode;
var isValidated = (function () {
var results, errors = 0;
var elements = $this.find('[data-constraints]');
var captcha = null;
if (elements.length) {
for (var j = 0; j < elements.length; j++) {
var $input = $(elements[j]);
if ((results = $input.regula('validate')).length) {
for (var k = 0; k < results.length; k++) {
errors++;
$input.siblings(".form-validation").text(results[k].message).parent().addClass("has-error");
}
} else {
$input.siblings(".form-validation").text("").parent().removeClass("has-error")
}
}
if (captcha) {
if (captcha.length) {
return validateReCaptcha(captcha) && errors === 0
}
}
return errors === 0;
}
return true;
})();
// Stop request if builder or inputs are invalide
if (isNoviBuilder || !isValidated)
return false;
$output.html('Submitting...').addClass('active');
}
});
return false;
}, $mailchimpItem, $email ));
}
}
// Campaign Monitor ajax subscription
if (plugins.campaignMonitor.length) {
for (i = 0; i < plugins.campaignMonitor.length; i++) {
var $campaignItem = $(plugins.campaignMonitor[i]);
$campaignItem.on('submit', $.proxy(function (e) {
var data = {},
url = this.attr('action'),
dataArray = this.serializeArray(),
$output = $("#" + plugins.campaignMonitor.attr("data-form-output")),
$this = $(this);
for (i = 0; i < dataArray.length; i++) {
data[dataArray[i].name] = dataArray[i].value;
}
$.ajax({
data: data,
url: url,
dataType: 'jsonp',
error: function (resp, text) {
$output.html('Server error: ' + text);
setTimeout(function () {
$output.removeClass("active");
}, 4000);
},
success: function (resp) {
$output.html(resp.Message).addClass('active');
setTimeout(function () {
$output.removeClass("active");
}, 6000);
},
beforeSend: function (data) {
// Stop request if builder or inputs are invalide
if (isNoviBuilder || !isValidated($this.find('[data-constraints]')))
return false;
$output.html('Submitting...').addClass('active');
}
});
// Clear inputs after submit
var inputs = $this[0].getElementsByTagName('input');
for (var i = 0; i < inputs.length; i++) {
inputs[i].value = '';
var label = document.querySelector( '[for="'+ inputs[i].getAttribute( 'id' ) +'"]' );
if( label ) label.classList.remove( 'focus', 'not-empty' );
}
return false;
}, $campaignItem));
}
}
// RD Mailform
if (plugins.rdMailForm.length) {
let i, j, k,
msg = {
'MF000': 'Successfully sent!',
'MF001': 'Recipients are not set!',
'MF002': 'Form will not work locally!',
'MF003': 'Please, define email field in your form!',
'MF004': 'Please, define type of your form!',
'MF254': 'Something went wrong with PHPMailer!',
'MF255': 'Aw, snap! Something went wrong.'
};
for (i = 0; i < plugins.rdMailForm.length; i++) {
let $form = $(plugins.rdMailForm[i]),
formHasCaptcha = false;
$form.attr('novalidate', 'novalidate').ajaxForm({
data: {
"form-type": $form.attr("data-form-type") || "contact",
"counter": i
},
beforeSubmit: function (arr, $form, options) {
if (isNoviBuilder)
return;
let form = $(plugins.rdMailForm[this.extraData.counter]),
inputs = form.find("[data-constraints]"),
output = $("#" + form.attr("data-form-output")),
captcha = form.find('.recaptcha'),
captchaFlag = true;
output.removeClass("active error success");
if (isValidated(inputs, captcha)) {
// veify reCaptcha
if (captcha.length) {
let captchaToken = captcha.find('.g-recaptcha-response').val(),
captchaMsg = {
'CPT001': 'Please, setup you "site key" and "secret key" of reCaptcha',
'CPT002': 'Something wrong with google reCaptcha'
};
formHasCaptcha = true;
$.ajax({
method: "POST",
url: "bat/reCaptcha.php",
data: {'g-recaptcha-response': captchaToken},
async: false
})
.done(function (responceCode) {
if (responceCode !== 'CPT000') {
if (output.hasClass("snackbars")) {
output.html('<p><span class="icon text-middle mdi mdi-check icon-xxs"></span><span>' + captchaMsg[responceCode] + '</span></p>')
setTimeout(function () {
output.removeClass("active");
}, 3500);
captchaFlag = false;
} else {
output.html(captchaMsg[responceCode]);
}
output.addClass("active");
}
});
}
if (!captchaFlag) {
return false;
}
form.addClass('form-in-process');
if (output.hasClass("snackbars")) {
output.html('<p><span class="icon text-middle fa fa-circle-o-notch fa-spin icon-xxs"></span><span>Sending</span></p>');
output.addClass("active");
}
} else {
return false;
}
},
error: function (result) {
if (isNoviBuilder)
return;
let output = $("#" + $(plugins.rdMailForm[this.extraData.counter]).attr("data-form-output")),
form = $(plugins.rdMailForm[this.extraData.counter]);
output.text(msg[result]);
form.removeClass('form-in-process');
if (formHasCaptcha) {
grecaptcha.reset();
window.dispatchEvent( new Event( 'resize' ) );
}
},
success: function (result) {
if (isNoviBuilder)
return;
let form = $(plugins.rdMailForm[this.extraData.counter]),
output = $("#" + form.attr("data-form-output")),
select = form.find('select');
form
.addClass('success')
.removeClass('form-in-process');
if (formHasCaptcha) {
grecaptcha.reset();
window.dispatchEvent( new Event( 'resize' ) );
}
result = result.length === 5 ? result : 'MF255';
output.text(msg[result]);
if (result === "MF000") {
if (output.hasClass("snackbars")) {
output.html('<p><span class="icon text-middle mdi mdi-check icon-xxs"></span><span>' + msg[result] + '</span></p>');
} else {
output.addClass("active success");
}
} else {
if (output.hasClass("snackbars")) {
output.html(' <p class="snackbars-left"><span class="icon icon-xxs mdi mdi-alert-outline text-middle"></span><span>' + msg[result] + '</span></p>');
} else {
output.addClass("active error");
}
}
form.clearForm();
if (select.length) {
select.select2("val", "");
}
form.find('input, textarea').trigger('blur');
setTimeout(function () {
output.removeClass("active error success");
form.removeClass('success');
}, 3500);
}
});
}
}
// lightGallery
if (plugins.lightGallery.length) {
for (let i = 0; i < plugins.lightGallery.length; i++) {
initLightGallery(plugins.lightGallery[i]);
}
}
// lightGallery item
if (plugins.lightGalleryItem.length) {
// Filter carousel items
let notCarouselItems = [];
for (let z = 0; z < plugins.lightGalleryItem.length; z++) {
if (!$(plugins.lightGalleryItem[z]).parents('.owl-carousel').length &&
!$(plugins.lightGalleryItem[z]).parents('.swiper-slider').length &&
!$(plugins.lightGalleryItem[z]).parents('.slick-slider').length) {
notCarouselItems.push(plugins.lightGalleryItem[z]);
}
}
plugins.lightGalleryItem = notCarouselItems;
for (let i = 0; i < plugins.lightGalleryItem.length; i++) {
initLightGalleryItem(plugins.lightGalleryItem[i]);
}
}
// Dynamic lightGallery
if (plugins.lightDynamicGalleryItem.length) {
for (let i = 0; i < plugins.lightDynamicGalleryItem.length; i++) {
initDynamicLightGallery(plugins.lightDynamicGalleryItem[i]);
}
}
// Custom Toggles
if (plugins.customToggle.length) {
for (var i = 0; i < plugins.customToggle.length; i++) {
var $this = $(plugins.customToggle[i]);
$this.on('click', $.proxy(function (event) {
event.preventDefault();
var $ctx = $(this);
$($ctx.attr('data-custom-toggle')).add(this).toggleClass('active');
}, $this));
if ($this.attr("data-custom-toggle-hide-on-blur") === "true") {
$body.on("click", $this, function (e) {
if (e.target !== e.data[0]
&& $(e.data.attr('data-custom-toggle')).find($(e.target)).length
&& e.data.find($(e.target)).length === 0) {
$(e.data.attr('data-custom-toggle')).add(e.data[0]).removeClass('active');
}
})
}
if ($this.attr("data-custom-toggle-disable-on-blur") === "true") {
$body.on("click", $this, function (e) {
if (e.target !== e.data[0] && $(e.data.attr('data-custom-toggle')).find($(e.target)).length === 0 && e.data.find($(e.target)).length === 0) {
$(e.data.attr('data-custom-toggle')).add(e.data[0]).removeClass('active');
}
})
}
}
}
// Material Parallax
if (plugins.materialParallax.length) {
if (!isNoviBuilder && !isIE && !isMobile) {
plugins.materialParallax.parallax();
} else {
for (let i = 0; i < plugins.materialParallax.length; i++) {
let $parallax = $(plugins.materialParallax[i]);
$parallax.addClass('parallax-disabled');
$parallax.css({"background-image": 'url(' + $parallax.data("parallax-img") + ')'});
}
}
}
// JQuery mousewheel plugin
if (plugins.scroller.length) {
for (var i = 0; i < plugins.scroller.length; i++) {
var scrollerItem = $(plugins.scroller[i]);
scrollerItem.mCustomScrollbar({
theme: scrollerItem.attr('data-theme') ? scrollerItem.attr('data-theme') : 'minimal',
scrollInertia: 100,
scrollButtons: {enable: false}
});
}
}
// Wide/Boxed Layout Toggle
if (plugins.layoutToggle.length) {
for (var i = 0; i < plugins.layoutToggle.length; i++) {
var $layoutToggleElement = $(plugins.layoutToggle[i]);
$layoutToggleElement.on('click', function () {
sessionStorage.setItem('pageLayoutBoxed', !(sessionStorage.getItem('pageLayoutBoxed') === "true"));
$html.toggleClass('boxed');
$window.trigger('resize');
});
}
if (sessionStorage.getItem('pageLayoutBoxed') === "true") {
plugins.layoutToggle.attr('checked', true);
$html.addClass('boxed');
$window.trigger('resize');
}
var themeResetButton = document.querySelectorAll('[data-theme-reset]');
if (themeResetButton) {
for (var z = 0; z < themeResetButton.length; z++) {
themeResetButton[z].addEventListener('click', function () {
sessionStorage.setItem('pageLayoutBoxed', false);
plugins.layoutToggle.attr('checked', false);
$html.removeClass('boxed');
$window.trigger('resize');
});
}
}
}
// ThemeSwitcher
if (plugins.themeSwitcher.length) {
document.documentElement.addEventListener('theme-switching', function () {
loaderTimeoutId = setTimeout(function () {
plugins.preloader.removeClass("loaded");
}, 500);
});
document.documentElement.addEventListener('theme-switched', function (event) {
clearTimeout(loaderTimeoutId);
setTimeout(function () {
if (windowReady) {
plugins.preloader.addClass("loaded");
}
}, 400);
if (plugins.themeCheckbox.length) {
plugins.themeCheckbox.checked = (plugins.themeCheckbox.getAttribute('data-theme-checkbox') === event.switcher.active );
}
});
document.documentElement.addEventListener('theme-color-change', function (event) {
document.querySelector(event.switcher.selectors.color + '[name="' + event.variable + '"]').style.backgroundColor = event.value;
});
var switcher = themeSwitcherInit({
variablesFallback: isIE,
cookie: false,
themes: {
"default": {
styles: 'css/style.css'
},
"style-1": {
styles: 'css/style-1.css'
},
"style-2": {
styles: 'css/style-2.css'
},
"style-3": {
styles: 'css/style-3.css'
},
"style-4": {
styles: 'css/style-4.css'
},
"style-5": {
styles: 'css/style-5.css'
},
"style-6": {
styles: 'css/style-6.css'
},
"style-7": {
styles: 'css/style-7.css'
},
"style-8": {
styles: 'css/style-8.css'
}
}
});
}
// ThemeSwitcher Checkbox
if (plugins.themeSwitcher.length && plugins.themeCheckbox.length) {
plugins.themeCheckbox.addEventListener('change', function (event) {
if (this.checked) {
switcher.setTheme(this.getAttribute('data-theme-checkbox'));
}
else {
switcher.setTheme(switcher.initial);
}
});
}
/**
* Button Nina
* @description Handle button Nina animation effect
*/
if (plugins.buttonNina.length && !isNoviBuilder) {
initNinaButtons(plugins.buttonNina);
}
/**
* Stop an iframe <video> from playing
*/
$(".modal").on('hidden.bs.modal', function () {
$(".modal iframe").attr("src", $(".modal iframe").attr("src"));
$("body").css('position', 'static');
});
//fix for iphone input
if(isMobile) {
$(".modal").on('show.bs.modal', function () {
$("body").css({'position': 'fixed', 'top': '0', 'left': '0', 'right': '0', 'bottom': '0'});
});
}
/**
* typedjs
*/
if (!isNoviBuilder && plugins.typedjs.length) {
var typed = new Typed(".typed-text", {
stringsElement: ".typed-strings",
typeSpeed: 80,
loop: !0,
backDelay: 1500,
backSpeed: 80
});
}
/**
* Custom toggle on event post
*/
if (plugins.projectToggle.length) {
plugins.projectToggle = $('[data-project-toggle]');
plugins.projectToggle.on('click', function(event){
event.preventDefault();
event.stopPropagation();
$(this).parents('.box-project-social').find('.box-project-icon-list').toggleClass('active');
$(this).toggleClass('active');
});
$body.on('click', function(){
$('.box-project-icon-list').removeClass('active');
plugins.projectToggle.removeClass('active');
});
}
/**
* Enable parallax by mouse
*/
var parallaxJs = document.getElementsByClassName('parallax-scene');
if (parallaxJs && !isNoviBuilder) {
for (var i = 0; i < parallaxJs.length; i++) {
var scene = parallaxJs[i];
new Parallax(scene);
}
}
/**
* Custom Waypoints
*/
if (plugins.customWaypoints.length && !isNoviBuilder) {
var i;
for (i = 0; i < plugins.customWaypoints.length; i++) {
var $this = $(plugins.customWaypoints[i]);
$this.on('click', function (e) {
e.preventDefault();
$("body, html").stop().animate({
scrollTop: $("#" + $(this).attr('data-custom-scroll-to')).offset().top
}, 1000, function () {
$window.trigger("resize");
});
});
}
}
});
}());