/**
* Global variables
*/
"use strict";
var userAgent = navigator.userAgent.toLowerCase(),
initialDate = new Date(),
$document = $(document),
$window = $(window),
$html = $("html"),
isDesktop = $html.hasClass("desktop"),
isIE = userAgent.indexOf("msie") != -1 ? parseInt(userAgent.split("msie")[1]) : 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),
isTouch = "ontouchstart" in window,
plugins = {
pointerEvents: isIE < 11 ? "js/pointer-events.min.js" : false,
smoothScroll: $html.hasClass("use--smoothscroll") ? "js/smoothscroll.min.js" : false,
bootstrapTooltip: $("[data-toggle='tooltip']"),
bootstrapTabs: $(".tabs"),
rdParallax: $(".rd-parallax"),
rdAudioPlayer: $(".rd-audio"),
rdVideoPlayer: $(".rd-video-player"),
responsiveTabs: $(".responsive-tabs"),
rdGoogleMaps: $(".rd-google-map"),
rdNavbar: $(".rd-navbar"),
rdVideoBG: $(".rd-video"),
rdRange: $('.rd-range'),
textRotator: $(".text-rotator"),
mfp: $('[data-lightbox]').not('[data-lightbox="gallery"] [data-lightbox]'),
mfpGallery: $('[data-lightbox^="gallery"]'),
owl: $(".owl-carousel"),
swiper: $(".swiper-slider"),
counter: $(".counter"),
progressBar: $(".progress-bar-js"),
progressLinear: $(".progress-linear"),
isotope: $(".isotope"),
countDown: $(".countdown"),
calendar: $(".rd-calendar"),
materialTabs: $('.rd-material-tabs'),
filePicker: $('.rd-file-picker'),
fileDrop: $('.rd-file-drop'),
popover: $('[data-toggle="popover"]'),
dateCountdown: $('.DateCountdown'),
statefulButton: $('.btn-stateful'),
slick: $('.slick-slider'),
scroller: $(".scroll-wrap"),
socialite: $(".socialite"),
viewAnimate: $('.view-animate'),
selectFilter: $("select"),
rdInputLabel: $(".form-label"),
stacktable: $("[data-responsive=true]"),
bootstrapDateTimePicker: $("[data-time-picker]"),
customWaypoints: $('[data-custom-scroll-to]'),
photoSwipeGallery: $("[data-photo-swipe-item]"),
circleProgress: $(".progress-bar-circle"),
stepper: $("input[type='number']"),
radio: $("input[type='radio']"),
checkbox: $("input[type='checkbox']"),
customToggle: $("[data-custom-toggle]"),
rdMailForm: $(".rd-mailform"),
regula: $("[data-constraints]"),
imgZoom: $('[mag-thumb]')
};
/**
* Initialize All Scripts
*/
$document.ready(function () {
/**
* getSwiperHeight
* @description calculate the height of swiper slider basing on data attr
*/
function getSwiperHeight(object, attr) {
var val = object.attr("data-" + attr),
dim;
if (!val) {
return undefined;
}
dim = val.match(/(px)|(%)|(vh)$/i);
if (dim.length) {
switch (dim[0]) {
case "px":
return parseFloat(val);
case "vh":
return $(window).height() * (parseFloat(val) / 100);
case "%":
return object.width() * (parseFloat(val) / 100);
}
} else {
return undefined;
}
}
/**
* toggleSwiperInnerVideos
* @description toggle swiper videos on active slides
*/
function toggleSwiperInnerVideos(swiper) {
var prevSlide = $(swiper.slides[swiper.previousIndex]),
nextSlide = $(swiper.slides[swiper.activeIndex]),
videos;
prevSlide.find("video").each(function () {
this.pause();
});
videos = nextSlide.find("video");
if (videos.length) {
videos.get(0).play();
}
}
/**
* toggleSwiperCaptionAnimation
* @description toggle swiper animations on active slides
*/
function toggleSwiperCaptionAnimation(swiper) {
var prevSlide = $(swiper.container),
nextSlide = $(swiper.slides[swiper.activeIndex]);
prevSlide
.find("[data-caption-animate]")
.each(function () {
var $this = $(this);
$this
.removeClass("animated")
.removeClass($this.attr("data-caption-animate"))
.addClass("not-animated");
});
nextSlide
.find("[data-caption-animate]")
.each(function () {
var $this = $(this),
delay = $this.attr("data-caption-delay");
setTimeout(function () {
$this
.removeClass("not-animated")
.addClass($this.attr("data-caption-animate"))
.addClass("animated");
}, delay ? parseInt(delay) : 0);
});
}
/**
* makeParallax
* @description create swiper parallax scrolling effect
*/
function makeParallax(el, speed, wrapper, prevScroll) {
var scrollY = window.scrollY || window.pageYOffset;
if (prevScroll != scrollY) {
prevScroll = scrollY;
el.addClass('no-transition');
el[0].style['transform'] = 'translate3d(0,' + -scrollY * (1 - speed) + 'px,0)';
el.height();
el.removeClass('no-transition');
if (el.attr('data-fade') === 'true') {
var bound = el[0].getBoundingClientRect(),
offsetTop = bound.top * 2 + scrollY,
sceneHeight = wrapper.outerHeight(),
sceneDevider = wrapper.offset().top + sceneHeight / 2.0,
layerDevider = offsetTop + el.outerHeight() / 2.0,
pos = sceneHeight / 6.0,
opacity;
if (sceneDevider + pos > layerDevider && sceneDevider - pos < layerDevider) {
el[0].style["opacity"] = 1;
} else {
if (sceneDevider - pos < layerDevider) {
opacity = 1 + ((sceneDevider + pos - layerDevider) / sceneHeight / 3.0 * 5);
} else {
opacity = 1 - ((sceneDevider - pos - layerDevider) / sceneHeight / 3.0 * 5);
}
el[0].style["opacity"] = opacity < 0 ? 0 : opacity > 1 ? 1 : opacity.toFixed(2);
}
}
}
requestAnimationFrame(function () {
makeParallax(el, speed, wrapper, prevScroll);
});
}
/**
* isScrolledIntoView
* @description check the element whas been scrolled into the view
*/
function isScrolledIntoView(elem) {
var $window = $(window);
return elem.offset().top + elem.outerHeight() >= $window.scrollTop() && elem.offset().top <= $window.scrollTop() + $window.height();
}
/**
* initOnView
* @description calls a function when element has been scrolled into the view
*/
function lazyInit(element, func) {
var $win = jQuery(window);
$win.on('load scroll', function () {
if ((!element.hasClass('lazy-loaded') && (isScrolledIntoView(element)))) {
func.call();
element.addClass('lazy-loaded');
}
});
}
/**
* attachFormValidator
* @description attach form validation to elements
*/
function attachFormValidator(elements) {
for (var i = 0; i < elements.length; i++) {
var o = $(elements[i]), v;
o.addClass("form-control-has-validation").after("");
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');
}
/**
* isValidated
* @description check if all elemnts pass validation
*/
function isValidated(elements) {
var results, errors = 0;
if (elements.length) {
for (j = 0; j < elements.length; j++) {
var $input = $(elements[j]);
if ((results = $input.regula('validate')).length) {
for (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")
}
}
return errors == 0;
}
return true;
}
/**
* Init Bootstrap tooltip
* @description calls a function when need to init bootstrap tooltips
*/
function initBootstrapTooltip(tooltipPlacement) {
if (window.innerWidth < 599) {
plugins.bootstrapTooltip.tooltip('destroy');
plugins.bootstrapTooltip.tooltip({
placement: 'bottom'
});
} else {
plugins.bootstrapTooltip.tooltip('destroy');
plugins.bootstrapTooltip.tooltipPlacement;
plugins.bootstrapTooltip.tooltip();
}
}
/**
* ChangeExternalButtons
* @description Change active tab in responsive active tab by external buttons (next tab, prev tab)
*/
function changeExternalButtons(respTabItem, direction) {
var prev,
next,
activeItem;
respTabItem.find('.resp-tabs-extertal-list li').removeClass('active');
activeItem = respTabItem.find('.resp-tab-item.resp-tab-active');
next = activeItem.next();
if (!next.length) {
next = respTabItem.find('.resp-tab-item:first-child()');
}
prev = activeItem.prev();
if (!prev.length) {
prev = respTabItem.find('.resp-tab-item:last-child()');
}
if (direction) {
if (direction === 'next') {
next.trigger('click');
} else {
prev.trigger('click');
}
setTimeout(function () {
changeExternalButtons(respTabItem);
}, 10);
}
respTabItem.find('.resp-tab-external-prev li:nth-child(' + (prev.index() + 1) + ')').addClass('active');
respTabItem.find('.resp-tab-external-next li:nth-child(' + (next.index() + 1) + ')').addClass('active');
}
/**
* IE Polyfills
* @description Adds some loosing functionality to IE browsers
*/
if (isIE) {
if (isIE < 10) {
$html.addClass("lt-ie-10");
}
if (isIE < 11) {
if (plugins.pointerEvents) {
$.getScript(plugins.pointerEvents)
.done(function () {
$html.addClass("ie-10");
PointerEventsPolyfill.initialize({});
});
}
}
if (isIE === 11) {
$("html").addClass("ie-11");
}
if (isIE === 12) {
$("html").addClass("ie-edge");
}
}
/**
* Bootstrap Tooltips
* @description Activate Bootstrap Tooltips
*/
if (plugins.bootstrapTooltip.length) {
var tooltipPlacement = plugins.bootstrapTooltip.attr('data-placement');
initBootstrapTooltip(tooltipPlacement);
$(window).on('resize orientationchange', function () {
initBootstrapTooltip(tooltipPlacement);
})
}
/**
* Smooth scrolling
* @description Enables a smooth scrolling for Google Chrome (Windows)
*/
if (plugins.smoothScroll) {
$.getScript(plugins.smoothScroll);
}
/**
* RD Audio player
* @description Enables RD Audio player plugin
*/
if (plugins.rdAudioPlayer.length > 0) {
var i;
for (i = 0; i < plugins.rdAudioPlayer.length; i++) {
$(plugins.rdAudioPlayer[i]).RDAudio();
}
}
/**
* Text Rotator
* @description Enables Text Rotator plugin
*/
if (plugins.textRotator.length) {
var i;
for (i = 0; i < plugins.textRotator.length; i++) {
var textRotatorItem = plugins.textRotator[i];
$(textRotatorItem).rotator();
}
}
/**
* RD Google Maps
* @description Enables RD Google Maps plugin
*/
if (plugins.rdGoogleMaps.length) {
var i;
$.getScript("https://maps.google.com/maps/api/js?key=AIzaSyAFeB0kVA6ouyJ_gEvFbMaefLy3cBCyRwo&sensor=false&libraries=geometry,places&v=3.7", function () {
var head = document.getElementsByTagName('head')[0],
insertBefore = head.insertBefore;
head.insertBefore = function (newElement, referenceElement) {
if (newElement.href && newElement.href.indexOf('https://fonts.googleapis.com/css?family=Roboto') != -1 || newElement.innerHTML.indexOf('gm-style') != -1) {
return;
}
insertBefore.call(head, newElement, referenceElement);
};
for (i = 0; i < plugins.rdGoogleMaps.length; i++) {
var $googleMapItem = $(plugins.rdGoogleMaps[i]);
lazyInit($googleMapItem, $.proxy(function () {
var $this = $(this),
styles = $this.attr("data-styles");
$this.googleMap({
styles: styles ? JSON.parse(styles) : [],
onInit: function (map) {
var inputAddress = $('#rd-google-map-address');
if (inputAddress.length) {
var input = inputAddress;
var geocoder = new google.maps.Geocoder();
var marker = new google.maps.Marker(
{
map: map,
icon: "images/gmap_marker.png",
}
);
var autocomplete = new google.maps.places.Autocomplete(inputAddress[0]);
autocomplete.bindTo('bounds', map);
inputAddress.attr('placeholder', '');
inputAddress.on('change', function () {
$("#rd-google-map-address-submit").trigger('click');
});
inputAddress.on('keydown', function (e) {
if (e.keyCode == 13) {
$("#rd-google-map-address-submit").trigger('click');
}
});
$("#rd-google-map-address-submit").on('click', function (e) {
e.preventDefault();
var address = input.val();
geocoder.geocode({'address': address}, function (results, status) {
if (status == google.maps.GeocoderStatus.OK) {
var latitude = results[0].geometry.location.lat();
var longitude = results[0].geometry.location.lng();
map.setCenter(new google.maps.LatLng(
parseFloat(latitude),
parseFloat(longitude)
));
marker.setPosition(new google.maps.LatLng(
parseFloat(latitude),
parseFloat(longitude)
))
}
});
});
}
}
});
}, $googleMapItem));
}
});
}
/**
* Bootstrap Date time picker
*/
if (plugins.bootstrapDateTimePicker.length) {
var i;
for (i = 0; i < plugins.bootstrapDateTimePicker.length; i++) {
var $dateTimePicker = $(plugins.bootstrapDateTimePicker[i]);
var options = {};
options['format'] = 'dddd DD MMMM YYYY - HH:mm';
if ($dateTimePicker.attr("data-time-picker") == "date") {
options['format'] = 'MM/DD/YYYY';
options['minDate'] = new Date();
} else if ($dateTimePicker.attr("data-time-picker") == "time") {
options['format'] = 'HH:mm';
}
options["time"] = ($dateTimePicker.attr("data-time-picker") != "date");
options["date"] = ($dateTimePicker.attr("data-time-picker") != "time");
options["shortTime"] = true;
$dateTimePicker.bootstrapMaterialDatePicker(options);
}
}
/**
* Responsive Tabs
* @description Enables Responsive Tabs plugin
*/
if (plugins.responsiveTabs.length > 0) {
var i;
for (i = 0; i < plugins.responsiveTabs.length; i++) {
var responsiveTabsItem = $(plugins.responsiveTabs[i]);
var setCustomHash = responsiveTabsItem.attr('data-custom-hash') == 'true';
$('.tabs-nav button').click(function () {
responsiveTabsItem.find("li[data-href$='" + $(this).attr('data-href').split('#').pop() + "']").first().click();
});
responsiveTabsItem.easyResponsiveTabs({
type: responsiveTabsItem.attr("data-type") === "accordion" ? "accordion" : "default"
});
//If have owl carousel inside tab - resize owl carousel on click
if (responsiveTabsItem.find('.owl-carousel').length) {
responsiveTabsItem.find('.resp-tab-item').on('click', $.proxy(function (event) {
var $this = $(this),
carouselObj = ($this.find('.resp-tab-content-active .owl-carousel').owlCarousel()).data('owlCarousel');
if (carouselObj && typeof carouselObj.onResize === "function") {
carouselObj.onResize();
}
}, responsiveTabsItem));
}
//If have slick carousel inside tab - resize slick carousel on click
if (responsiveTabsItem.find('.slick-slider').length) {
responsiveTabsItem.find('.resp-tab-item').on('click', $.proxy(function (event) {
var $this = $(this);
$this.find('.resp-tab-content-active .slick-slider').slick('setPosition');
}, responsiveTabsItem));
}
// Enable external buttons (prev, text tab)
if (responsiveTabsItem.attr('data-external-buttons') == "true") {
var list = responsiveTabsItem.find('.resp-tabs-list li'),
newList = '
';
for (var j = 0; j < list.length; j++) {
newList += '- ' + $(list[j]).text() + '
';
}
newList += '
';
responsiveTabsItem.find('.resp-tabs-container').before('')
responsiveTabsItem.find('.resp-tab-external-prev').html(newList);
responsiveTabsItem.find('.resp-tabs-container').after('');
responsiveTabsItem.find('.resp-tab-external-next').html(newList);
changeExternalButtons(responsiveTabsItem);
responsiveTabsItem.find('.resp-tab-external-prev').on('click', $.proxy(function (event) {
var $this = $(this);
changeExternalButtons($this, 'prev');
}, responsiveTabsItem));
responsiveTabsItem.find('.resp-tab-external-next').on('click', $.proxy(function (event) {
var $this = $(this);
changeExternalButtons($this, 'next');
}, responsiveTabsItem));
responsiveTabsItem.find('.resp-tabs-list .resp-tab-item').on('click', $.proxy(function (event) {
var $this = $(this);
changeExternalButtons($this);
}, responsiveTabsItem));
}
}
}
/**
* RD MaterialTabs
* @description Enables RD MaterialTabs plugin
*/
if (plugins.materialTabs.length) {
var i;
for (i = 0; i < plugins.materialTabs.length; i++) {
var materialTabsItem = plugins.materialTabs[i];
$(materialTabsItem).RDMaterialTabs({});
}
}
/**
* Select2
* @description Enables select2 plugin
*/
if (plugins.selectFilter.length) {
var i;
for (i = 0; i < plugins.selectFilter.length; i++) {
var select = $(plugins.selectFilter[i]);
select.select2({
theme: "bootstrap"
}).next().addClass(select.attr("class").match(/(input-sm)|(input-lg)|($)/i).toString().replace(new RegExp(",", 'g'), " "));
}
}
/**
* Stepper
* @description Enables Stepper Plugin
*/
if (plugins.stepper.length) {
plugins.stepper.stepper({
labels: {
up: "",
down: ""
}
});
}
/**
* Radio
* @description Add custom styling options for input[type="radio"]
*/
if (plugins.radio.length) {
var i;
for (i = 0; i < plugins.radio.length; i++) {
var $this = $(plugins.radio[i]);
$this.addClass("radio-custom").after("")
}
}
/**
* Checkbox
* @description Add custom styling options for input[type="checkbox"]
*/
if (plugins.checkbox.length) {
var i;
for (i = 0; i < plugins.checkbox.length; i++) {
var $this = $(plugins.checkbox[i]);
$this.addClass("checkbox-custom").after("")
}
}
/**
* RD Filepicker
* @description Enables RD Filepicker plugin
*/
if (plugins.filePicker.length || plugins.fileDrop.length) {
var i;
for (i = 0; i < plugins.filePicker.length; i++) {
var filePickerItem = plugins.filePicker[i];
$(filePickerItem).RDFilepicker({
metaFieldClass: "rd-file-picker-meta"
});
}
for (i = 0; i < plugins.fileDrop.length; i++) {
var fileDropItem = plugins.fileDrop[i];
$(fileDropItem).RDFilepicker({
metaFieldClass: "rd-file-drop-meta",
buttonClass: "rd-file-drop-btn",
dropZoneClass: "rd-file-drop"
});
}
}
/**
* Popovers
* @description Enables Popovers plugin
*/
if (plugins.popover.length) {
if (window.innerWidth < 767) {
plugins.popover.attr('data-placement', 'bottom');
plugins.popover.popover();
}
else {
plugins.popover.popover();
}
}
/**
* jQuery Countdown
* @description Enable countdown plugin
*/
if (plugins.countDown.length) {
var i;
for (i = 0; i < plugins.countDown.length; i++) {
var countDownItem = plugins.countDown[i],
d = new Date(),
type = countDownItem.getAttribute('data-type'),
time = countDownItem.getAttribute('data-time'),
format = countDownItem.getAttribute('data-format'),
settings = [];
d.setTime(Date.parse(time)).toLocaleString();
settings[type] = d;
settings['format'] = format;
$(countDownItem).countdown(settings);
}
}
/**
* TimeCircles
* @description Enable TimeCircles plugin
*/
if (plugins.dateCountdown.length) {
var i;
for (i = 0; i < plugins.dateCountdown.length; i++) {
var dateCountdownItem = $(plugins.dateCountdown[i]),
time = {
"Days": {
"text": "Days",
"show": true,
color: dateCountdownItem.attr("data-color") ? dateCountdownItem.attr("data-color") : "#f9f9f9"
},
"Hours": {
"text": "Hours",
"show": true,
color: dateCountdownItem.attr("data-color") ? dateCountdownItem.attr("data-color") : "#f9f9f9"
},
"Minutes": {
"text": "Minutes",
"show": true,
color: dateCountdownItem.attr("data-color") ? dateCountdownItem.attr("data-color") : "#f9f9f9"
},
"Seconds": {
"text": "Seconds",
"show": true,
color: dateCountdownItem.attr("data-color") ? dateCountdownItem.attr("data-color") : "#f9f9f9"
}
};
dateCountdownItem.TimeCircles({
color: dateCountdownItem.attr("data-color") ? dateCountdownItem.attr("data-color") : "rgba(247, 247, 247, 1)",
animation: "smooth",
bg_width: dateCountdownItem.attr("data-bg-width") ? dateCountdownItem.attr("data-bg-width") : 1.1,
circle_bg_color: dateCountdownItem.attr("data-bg") ? dateCountdownItem.attr("data-bg") : "rgba(0, 0, 0, 1)",
fg_width: dateCountdownItem.attr("data-width") ? dateCountdownItem.attr("data-width") : 0.04
});
$(window).on('load resize orientationchange', function () {
if (window.innerWidth < 479) {
dateCountdownItem.TimeCircles({
time: {
"Days": {
"text": "Days",
"show": true,
color: dateCountdownItem.attr("data-color") ? dateCountdownItem.attr("data-color") : "#f9f9f9"
},
"Hours": {
"text": "Hours",
"show": true,
color: dateCountdownItem.attr("data-color") ? dateCountdownItem.attr("data-color") : "#f9f9f9"
},
"Minutes": {
"text": "Minutes",
"show": true,
color: dateCountdownItem.attr("data-color") ? dateCountdownItem.attr("data-color") : "#f9f9f9"
},
Seconds: {
"text": "Seconds",
show: false,
color: dateCountdownItem.attr("data-color") ? dateCountdownItem.attr("data-color") : "#f9f9f9"
}
}
}).rebuild();
} else if (window.innerWidth < 767) {
dateCountdownItem.TimeCircles({
time: {
"Days": {
"text": "Days",
"show": true,
color: dateCountdownItem.attr("data-color") ? dateCountdownItem.attr("data-color") : "#f9f9f9"
},
"Hours": {
"text": "Hours",
"show": true,
color: dateCountdownItem.attr("data-color") ? dateCountdownItem.attr("data-color") : "#f9f9f9"
},
"Minutes": {
"text": "Minutes",
"show": true,
color: dateCountdownItem.attr("data-color") ? dateCountdownItem.attr("data-color") : "#f9f9f9"
},
Seconds: {
"text": "Seconds",
show: false,
color: dateCountdownItem.attr("data-color") ? dateCountdownItem.attr("data-color") : "#f9f9f9"
}
}
}).rebuild();
} else {
dateCountdownItem.TimeCircles({
time: {
"Days": {
"text": "Days",
"show": true,
color: dateCountdownItem.attr("data-color") ? dateCountdownItem.attr("data-color") : "#f9f9f9"
},
"Hours": {
"text": "Hours",
"show": true,
color: dateCountdownItem.attr("data-color") ? dateCountdownItem.attr("data-color") : "#f9f9f9"
},
"Minutes": {
"text": "Minutes",
"show": true,
color: dateCountdownItem.attr("data-color") ? dateCountdownItem.attr("data-color") : "#f9f9f9"
},
"Seconds": {
"text": "Seconds",
"show": true,
color: dateCountdownItem.attr("data-color") ? dateCountdownItem.attr("data-color") : "#f9f9f9"
}
}
}).rebuild();
}
});
}
}
/**
* Bootstrap Buttons
* @description Enable Bootstrap Buttons plugin
*/
if (plugins.statefulButton.length) {
$(plugins.statefulButton).on('click', function () {
var statefulButtonLoading = $(this).button('loading');
setTimeout(function () {
statefulButtonLoading.button('reset')
}, 2000);
})
}
/**
* RD Calendar
* @description Enables RD Calendar plugin
*/
if (plugins.calendar.length) {
var i;
for (i = 0; i < plugins.calendar.length; i++) {
var calendarItem = $(plugins.calendar[i]);
calendarItem.rdCalendar({
days: calendarItem.attr("data-days") ? calendarItem.attr("data-days").split(/\s?,\s?/i) : ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'],
month: calendarItem.attr("data-months") ? calendarItem.attr("data-months").split(/\s?,\s?/i) : ['January', 'February', 'March', 'April', 'May', 'June', 'July', 'August', 'September', 'October', 'November', 'December']
});
}
}
/**
* Circle Progress
* @description Enable Circle Progress plugin
*/
if (plugins.circleProgress.length) {
var i;
for (i = 0; i < plugins.circleProgress.length; i++) {
var circleProgressItem = $(plugins.circleProgress[i]);
$document
.on("scroll", function () {
if (!circleProgressItem.hasClass('animated')) {
var arrayGradients = circleProgressItem.attr('data-gradient').split(",");
circleProgressItem.circleProgress({
value: circleProgressItem.attr('data-value'),
size: circleProgressItem.attr('data-size') ? circleProgressItem.attr('data-size') : 175,
fill: {gradient: arrayGradients, gradientAngle: Math.PI / 4},
startAngle: -Math.PI / 4 * 2,
emptyFill: circleProgressItem.attr('data-empty-fill') ? circleProgressItem.attr('data-empty-fill') : "rgb(245,245,245)",
thickness: circleProgressItem.attr('data-thickness') ? parseInt(circleProgressItem.attr('data-thickness')) : 10,
}).on('circle-animation-progress', function (event, progress, stepValue) {
$(this).find('span').text(String(stepValue.toFixed(2)).replace('0.', '').replace('1.', '1'));
});
circleProgressItem.addClass('animated');
}
})
.trigger("scroll");
}
}
/**
* Linear Progress bar
* @description Enable progress bar
*/
if (plugins.progressLinear.length) {
for (i = 0; i < plugins.progressLinear.length; i++) {
var progressBar = $(plugins.progressLinear[i]);
$window
.on("scroll load", $.proxy(function () {
var bar = $(this);
if (!bar.hasClass('animated-first') && isScrolledIntoView(bar)) {
var end = bar.attr("data-to");
bar.find('.progress-bar-linear').css({width: end + '%'});
bar.find('.progress-value').countTo({
refreshInterval: 40,
from: 0,
to: end,
speed: 500
});
bar.addClass('animated-first');
}
}, progressBar));
}
}
/**
* Progress bar
* @description Enable progress bar
*/
if (plugins.progressBar.length) {
var i,
bar,
type;
for (i = 0; i < plugins.progressBar.length; i++) {
var progressItem = plugins.progressBar[i];
bar = null;
if (progressItem.className.indexOf("progress-bar-horizontal") > -1) {
type = 'Line';
}
if (progressItem.className.indexOf("progress-bar-radial") > -1) {
type = 'Circle';
}
if (progressItem.getAttribute("data-stroke") && progressItem.getAttribute("data-value") && type) {
bar = new ProgressBar[type](progressItem, {
strokeWidth: Math.round(parseFloat(progressItem.getAttribute("data-stroke")) / progressItem.offsetWidth * 100),
trailWidth: progressItem.getAttribute("data-trail") ? Math.round(parseFloat(progressItem.getAttribute("data-trail")) / progressItem.offsetWidth * 100) : 0,
text: {
value: progressItem.getAttribute("data-counter") === "true" ? '0' : null,
className: 'progress-bar__body',
style: null
}
});
bar.svg.setAttribute('preserveAspectRatio', "none meet");
if (type === 'Line') {
bar.svg.setAttributeNS(null, "height", progressItem.getAttribute("data-stroke"));
}
bar.path.removeAttribute("stroke");
bar.path.className.baseVal = "progress-bar__stroke";
if (bar.trail) {
bar.trail.removeAttribute("stroke");
bar.trail.className.baseVal = "progress-bar__trail";
}
if (progressItem.getAttribute("data-easing") && !isIE) {
$(document)
.on("scroll", {"barItem": bar}, $.proxy(function (event) {
var bar = event.data.barItem;
var $this = $(this);
if (isScrolledIntoView($this) && this.className.indexOf("progress-bar--animated") === -1) {
this.className += " progress-bar--animated";
bar.animate(parseInt($this.attr("data-value")) / 100.0, {
easing: $this.attr("data-easing"),
duration: $this.attr("data-duration") ? parseInt($this.attr("data-duration")) : 800,
step: function (state, b) {
if (b._container.className.indexOf("progress-bar-horizontal") > -1 ||
b._container.className.indexOf("progress-bar-vertical") > -1) {
b.text.style.width = Math.abs(b.value() * 100).toFixed(0) + "%"
}
b.setText(Math.abs(b.value() * 100).toFixed(0));
}
});
}
}, progressItem))
.trigger("scroll");
} else {
bar.set(parseInt($(progressItem).attr("data-value")) / 100.0);
bar.setText($(progressItem).attr("data-value"));
if (type === 'Line') {
bar.text.style.width = parseInt($(progressItem).attr("data-value")) + "%";
}
}
} else {
console.error(progressItem.className + ": progress bar type is not defined");
}
}
}
/**
* UI To Top
* @description Enables ToTop Button
*/
if (isDesktop) {
$().UItoTop({
easingType: 'easeOutQuart',
containerClass: 'ui-to-top fa fa-angle-up'
});
}
/**
* RD Navbar
* @description Enables RD Navbar plugin
*/
if (plugins.rdNavbar.length) {
plugins.rdNavbar.RDNavbar({
stickUpClone: (plugins.rdNavbar.attr("data-stick-up-clone")) ? plugins.rdNavbar.attr("data-stick-up-clone") === 'true' : false
});
if (plugins.rdNavbar.attr("data-body-class")) {
document.body.className += ' ' + plugins.rdNavbar.attr("data-body-class");
}
}
/**
* ViewPort Universal
* @description Add class in viewport
*/
if (plugins.viewAnimate.length) {
var i;
for (i = 0; i < plugins.viewAnimate.length; i++) {
var $view = $(plugins.viewAnimate[i]).not('.active');
$document.on("scroll", $.proxy(function () {
if (isScrolledIntoView(this)) {
this.addClass("active");
}
}, $view))
.trigger("scroll");
}
}
/**
* Swiper 3.1.7
* @description Enable Swiper Slider
*/
if (plugins.swiper.length) {
var i;
for (i = 0; i < plugins.swiper.length; i++) {
var s = $(plugins.swiper[i]);
var pag = s.find(".swiper-pagination"),
next = s.find(".swiper-button-next"),
prev = s.find(".swiper-button-prev"),
bar = s.find(".swiper-scrollbar"),
parallax = s.parents('.rd-parallax').length,
swiperSlide = s.find(".swiper-slide");
for (j = 0; j < swiperSlide.length; j++) {
var $this = $(swiperSlide[j]),
url;
if (url = $this.attr("data-slide-bg")) {
$this.css({
"background-image": "url(" + url + ")",
"background-size": "cover"
})
}
}
swiperSlide.end()
.find("[data-caption-animate]")
.addClass("not-animated")
.end()
.swiper({
autoplay: s.attr('data-autoplay') ? s.attr('data-autoplay') === "false" ? undefined : s.attr('data-autoplay') : 5000,
direction: s.attr('data-direction') ? s.attr('data-direction') : "horizontal",
effect: s.attr('data-slide-effect') ? s.attr('data-slide-effect') : "slide",
speed: s.attr('data-slide-speed') ? s.attr('data-slide-speed') : 600,
keyboardControl: s.attr('data-keyboard') === "true",
mousewheelControl: s.attr('data-mousewheel') === "true",
mousewheelReleaseOnEdges: s.attr('data-mousewheel-release') === "true",
nextButton: next.length ? next.get(0) : null,
prevButton: prev.length ? prev.get(0) : null,
pagination: pag.length ? pag.get(0) : null,
paginationClickable: pag.length ? pag.attr("data-clickable") !== "false" : false,
paginationBulletRender: pag.length ? pag.attr("data-index-bullet") === "true" ? function (index, className) {
return '' + (index + 1) + '';
} : null : null,
scrollbar: bar.length ? bar.get(0) : null,
scrollbarDraggable: bar.length ? bar.attr("data-draggable") !== "false" : true,
scrollbarHide: bar.length ? bar.attr("data-draggable") === "false" : false,
loop: s.attr('data-loop') !== "false",
simulateTouch: s.attr('data-simulate-touch') ? s.attr('data-simulate-touch') === "true" : false,
onTransitionStart: function (swiper) {
toggleSwiperInnerVideos(swiper);
},
onTransitionEnd: function (swiper) {
toggleSwiperCaptionAnimation(swiper);
},
onInit: function (swiper) {
toggleSwiperInnerVideos(swiper);
toggleSwiperCaptionAnimation(swiper);
var swiperParalax = s.find(".swiper-parallax");
for (var k = 0; k < swiperParalax.length; k++) {
var $this = $(swiperParalax[k]),
speed;
if (parallax && !isIEBrows && !isMobile) {
if (speed = $this.attr("data-speed")) {
makeParallax($this, speed, s, false);
}
}
}
$(window).on('resize', function () {
swiper.update(true);
})
}
});
$(window)
.on("resize", function () {
var mh = getSwiperHeight(s, "min-height"),
h = getSwiperHeight(s, "height");
if (h) {
s.css("height", mh ? mh > h ? mh : h : h);
}
})
.trigger("resize");
}
}
/**
* RD Video Player
* @description Enables RD Video player plugin
*/
if (plugins.rdVideoPlayer.length) {
var i;
for (i = 0; i < plugins.rdVideoPlayer.length; i++) {
var videoItem = plugins.rdVideoPlayer[i],
volumeWrap = $(".rd-video-volume-wrap");
$(videoItem).RDVideoPlayer({});
volumeWrap.on("mouseenter", function () {
$(this).addClass("hover")
});
volumeWrap.on("mouseleave", function () {
$(this).removeClass("hover")
});
if (isTouch) {
volumeWrap.find(".rd-video-volume").on("click", function () {
$(this).toggleClass("hover")
});
$document.on("click", function (e) {
if (!$(e.target).is(volumeWrap) && $(e.target).parents(volumeWrap).length == 0) {
volumeWrap.find(".rd-video-volume").removeClass("hover")
}
})
}
}
}
/**
* Slick carousel
* @description Enable Slick carousel plugin
*/
if (plugins.slick.length) {
var i;
for (i = 0; i < plugins.slick.length; i++) {
var $slickItem = $(plugins.slick[i]);
$slickItem.slick({
slidesToScroll: parseInt($slickItem.attr('data-slide-to-scroll')) || 1,
asNavFor: $slickItem.attr('data-for') || false,
dots: $slickItem.attr("data-dots") == "true",
infinite: $slickItem.attr("data-loop") == "true",
focusOnSelect: false,
respondTo: 'window',
arrows: $slickItem.attr("data-arrows") == "true",
swipe: $slickItem.attr("data-swipe") == "true",
autoplay: $slickItem.attr("data-autoplay") == "true",
vertical: $slickItem.attr("data-vertical") == "true",
centerMode: $slickItem.attr("data-center-mode") == "true",
centerPadding: $slickItem.attr("data-center-padding") ? $slickItem.attr("data-center-padding") : '0.50',
mobileFirst: true,
responsive: [
{
breakpoint: 0,
settings: {
slidesToShow: parseInt($slickItem.attr('data-items')) || 1,
}
},
{
breakpoint: 480,
settings: {
slidesToShow: parseInt($slickItem.attr('data-xs-items')) || 1,
}
},
{
breakpoint: 767,
settings: {
slidesToShow: parseInt($slickItem.attr('data-sm-items')) || 1,
}
},
{
breakpoint: 992,
settings: {
slidesToShow: parseInt($slickItem.attr('data-md-items')) || 1,
}
},
{
breakpoint: 1199,
settings: {
slidesToShow: parseInt($slickItem.attr('data-lg-items')) || 1,
}
},
{
breakpoint: 1800,
settings: {
slidesToShow: parseInt($slickItem.attr('data-xl-items')) || 1,
}
}
]
})
.on('afterChange', function (event, slick, currentSlide, nextSlide) {
var $this = $(this),
childCarousel = $this.attr('data-child');
if (childCarousel) {
$(childCarousel + ' .slick-slide').removeClass('slick-current');
$(childCarousel + ' .slick-slide').eq(currentSlide).addClass('slick-current');
}
});
}
}
/**
* Owl carousel
* @description Enables Owl carousel plugin
*/
if (plugins.owl.length) {
var i;
for (i = 0; i < plugins.owl.length; i++) {
var c = $(plugins.owl[i]),
responsive = {};
var aliaces = ["-", "-xs-", "-sm-", "-md-", "-lg-", '-xl-'],
values = [0, 480, 768, 992, 1200, 1800],
j, k;
for (j = 0; j < values.length; j++) {
responsive[values[j]] = {};
for (k = j; k >= -1; k--) {
if (!responsive[values[j]]["items"] && c.attr("data" + aliaces[k] + "items")) {
responsive[values[j]]["items"] = k < 0 ? 1 : parseInt(c.attr("data" + aliaces[k] + "items"));
}
if (!responsive[values[j]]["dotsEach"] && c.attr("data" + aliaces[k] + "dots-each")) {
responsive[values[j]]["dotsEach"] = k < 0 ? 1 : parseInt(c.attr("data" + aliaces[k] + "dots-each"));
}
if (!responsive[values[j]]["stagePadding"] && responsive[values[j]]["stagePadding"] !== 0 && c.attr("data" + aliaces[k] + "stage-padding")) {
responsive[values[j]]["stagePadding"] = k < 0 ? 0 : parseInt(c.attr("data" + aliaces[k] + "stage-padding"));
}
if (!responsive[values[j]]["margin"] && responsive[values[j]]["margin"] !== 0 && c.attr("data" + aliaces[k] + "margin")) {
responsive[values[j]]["margin"] = k < 0 ? 30 : parseInt(c.attr("data" + aliaces[k] + "margin"));
}
}
}
c.owlCarousel({
autoplay: c.attr("data-autoplay") === "true",
loop: c.attr("data-loop") !== "false",
items: 1,
dotsContainer: c.attr("data-pagination-class") || false,
navContainer: c.attr("data-navigation-class") || false,
mouseDrag: c.attr("data-mouse-drag") !== "false",
nav: c.attr("data-nav") === "true",
dots: c.attr("data-dots") === "true",
animateIn: c.attr('data-animation-in') ? c.attr('data-animation-in') : 'slide',
animateOut: c.attr('data-animation-out') ? c.attr('data-animation-out') : false,
responsive: responsive,
navText: []
});
}
}
/**
* jQuery Count To
* @description Enables Count To plugin
*/
if (plugins.counter.length) {
var i;
for (i = 0; i < plugins.counter.length; i++) {
var $counterNotAnimated = $(plugins.counter[i]).not('.animated');
$document
.on("scroll", $.proxy(function () {
var $this = this;
if ((!$this.hasClass("animated")) && (isScrolledIntoView($this))) {
$this.countTo({
refreshInterval: 40,
speed: $this.attr("data-speed") || 1000
});
$this.addClass('animated');
}
}, $counterNotAnimated))
.trigger("scroll");
}
}
/**
* Isotope
* @description Enables Isotope plugin
*/
if (plugins.isotope.length) {
var i, j, isogroup = [];
for (i = 0; i < plugins.isotope.length; i++) {
var isotopeItem = plugins.isotope[i],
filterItems = $(isotopeItem).closest('.isotope-wrap').find('[data-isotope-filter]'),
iso;
if (isotopeItem.getAttribute('data-masonry')) {
iso = new Isotope(isotopeItem, {
itemSelector: '.isotope-item',
layoutMode: isotopeItem.getAttribute('data-isotope-layout') ? isotopeItem.getAttribute('data-isotope-layout') : 'masonry',
filter: '*',
masonry: {
columnWidth: 1.4
}
});
} else {
iso = new Isotope(isotopeItem, {
itemSelector: '.isotope-item',
layoutMode: isotopeItem.getAttribute('data-isotope-layout') ? isotopeItem.getAttribute('data-isotope-layout') : 'masonry',
filter: '*'
});
}
isogroup.push(iso);
filterItems.on("click", function (e) {
e.preventDefault();
var filter = $(this),
iso = $('.isotope[data-isotope-group="' + this.getAttribute("data-isotope-group") + '"]'),
filtersContainer = filter.closest(".isotope-filters");
filtersContainer
.find('.active')
.removeClass("active");
filter.addClass("active");
if (isotopeItem.getAttribute('data-masonry')) {
iso.isotope({
itemSelector: '.isotope-item',
layoutMode: iso.attr('data-isotope-layout') ? iso.attr('data-isotope-layout') : 'masonry',
filter: this.getAttribute("data-isotope-filter") == '*' ? '*' : '[data-filter*="' + this.getAttribute("data-isotope-filter") + '"]',
masonry: {
columnWidth: 1.4
}
})
} else {
iso.isotope({
itemSelector: '.isotope-item',
layoutMode: iso.attr('data-isotope-layout') ? iso.attr('data-isotope-layout') : 'masonry',
filter: this.getAttribute("data-isotope-filter") == '*' ? '*' : '[data-filter*="' + this.getAttribute("data-isotope-filter") + '"]'
})
}
$window.trigger('resize');
// If d3Charts contains in isotop, resize it on click.
if (filtersContainer.hasClass('isotope-has-d3-graphs') && c3ChartsArray != undefined) {
setTimeout(function () {
for (var j = 0; j < c3ChartsArray.length; j++) {
c3ChartsArray[j].resize();
}
}, 500);
}
}).eq(0).trigger("click");
}
$(window).on('load', function () {
setTimeout(function () {
var i;
for (i = 0; i < isogroup.length; i++) {
isogroup[i].element.className += " isotope--loaded";
isogroup[i].layout();
}
}, 600);
});
}
/**
* Isotope
* @description Enables Isotope plugin
*/
if (plugins.isotope.length) {
var i, isogroup = [];
for (i = 0; i < plugins.isotope.length; i++) {
var isotopeItem = plugins.isotope[i],
iso;
if (isotopeItem.getAttribute('data-masonry')) {
iso = new Isotope(isotopeItem, {
itemSelector: '.isotope-item',
layoutMode: isotopeItem.getAttribute('data-isotope-layout') ? isotopeItem.getAttribute('data-isotope-layout') : 'masonry',
filter: '*',
masonry: {
columnWidth: 1.4
}
});
} else {
iso = new Isotope(isotopeItem, {
itemSelector: '.isotope-item',
layoutMode: isotopeItem.getAttribute('data-isotope-layout') ? isotopeItem.getAttribute('data-isotope-layout') : 'masonry',
filter: '*'
});
}
isogroup.push(iso);
}
$(window).on('load', function () {
setTimeout(function () {
var i;
for (i = 0; i < isogroup.length; i++) {
isogroup[i].element.className += " isotope--loaded";
isogroup[i].layout();
}
}, 600);
});
var resizeTimout;
$("[data-isotope-filter]").on("click", function (e) {
e.preventDefault();
var filter = $(this);
clearTimeout(resizeTimout);
filter.parents(".isotope-filters").find('.active').removeClass("active");
filter.addClass("active");
var iso = $('.isotope[data-isotope-group="' + this.getAttribute("data-isotope-group") + '"]');
if (isotopeItem.getAttribute('data-masonry')) {
iso.isotope({
itemSelector: '.isotope-item',
layoutMode: iso.attr('data-isotope-layout') ? iso.attr('data-isotope-layout') : 'masonry',
filter: this.getAttribute("data-isotope-filter") == '*' ? '*' : '[data-filter*="' + this.getAttribute("data-isotope-filter") + '"]',
masonry: {
columnWidth: 1.4
}
})
} else {
iso.isotope({
itemSelector: '.isotope-item',
layoutMode: iso.attr('data-isotope-layout') ? iso.attr('data-isotope-layout') : 'masonry',
filter: this.getAttribute("data-isotope-filter") == '*' ? '*' : '[data-filter*="' + this.getAttribute("data-isotope-filter") + '"]'
})
}
}).eq(0).trigger("click")
}
/**
* WOW
* @description Enables Wow animation plugin
*/
if (isDesktop && $html.hasClass("wow-animation") && $(".wow").length) {
new WOW().init();
}
/**
* Bootstrap tabs
* @description Activate Bootstrap Tabs
*/
if (plugins.bootstrapTabs.length) {
var i;
for (i = 0; i < plugins.bootstrapTabs.length; i++) {
var bootstrapTabsItem = $(plugins.bootstrapTabs[i]);
bootstrapTabsItem.on("click", "a", function (event) {
event.preventDefault();
$(this).tab('show');
});
}
}
/**
* JQuery mousewheel plugin
* @description Enables jquery mousewheel plugin
*/
if (plugins.scroller.length) {
var i;
for (i = 0; i < plugins.scroller.length; i++) {
var scrollerItem = $(plugins.scroller[i]);
scrollerItem.mCustomScrollbar({
scrollInertia: 200,
scrollButtons: {enable: true}
});
}
}
/**
* Socialite v2
* @description Enables Socialite v2 plugin
*/
if (plugins.socialite.length) {
Socialite.load();
}
/**
* RD Video
* @description Enables RD Video plugin
*/
if (plugins.rdVideoBG.length) {
var i;
for (i = 0; i < plugins.rdVideoBG.length; i++) {
var videoItem = $(plugins.rdVideoBG[i]);
videoItem.RDVideo({});
}
}
/**
* RD Input Label
* @description Enables RD Input Label Plugin
*/
if (plugins.rdInputLabel.length) {
plugins.rdInputLabel.RDInputLabel();
}
/**
* Regula
* @description Enables Regula plugin
*/
if (plugins.regula.length) {
attachFormValidator(plugins.regula);
}
/**
* RD Mailform
*/
if (plugins.rdMailForm.length) {
var 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++) {
var $form = $(plugins.rdMailForm[i]);
$form.attr('novalidate', 'novalidate').ajaxForm({
data: {
"form-type": $form.attr("data-form-type") || "contact",
"counter": i
},
beforeSubmit: function () {
var form = $(plugins.rdMailForm[this.extraData.counter]);
var inputs = form.find("[data-constraints]");
if (isValidated(inputs)) {
var output = $("#" + form.attr("data-form-output"));
if (output.hasClass("snackbars")) {
output.html('Sending
');
output.addClass("active");
}
} else {
return false;
}
},
error: function (result) {
var output = $("#" + $(plugins.rdMailForm[this.extraData.counter]).attr("data-form-output"));
output.text(msg[result]);
},
success: function (result) {
var form = $(plugins.rdMailForm[this.extraData.counter]),
output = $("#" + form.attr("data-form-output")),
$select = $form.find('select');
// Clear select2 after submit form
if ($select.length) {
for (j = 0; j < $select.length; j++) {
var $selectitem = $($select[j]);
$selectitem.select2('val', null);
}
}
form.addClass('success');
result = result.length == 5 ? result : 'MF255';
output.text(msg[result]);
if (result === "MF000") {
if (output.hasClass("snackbars")) {
output.html('' + msg[result] + '
');
}
output.addClass("success active");
} else {
if (output.hasClass("snackbars")) {
output.html(' ' + msg[result] + '
');
}
output.addClass("error active");
}
form.clearForm();
form.find('input, textarea').blur();
setTimeout(function () {
output.removeClass("active error success");
form.removeClass('success');
}, 5000);
}
});
}
}
/**
* RD Range
* @description Enables RD Range plugin
*/
if (plugins.rdRange.length) {
plugins.rdRange.RDRange({});
}
/**
* PhotoSwipe Gallery
* @description Enables PhotoSwipe Gallery plugin
*/
if (plugins.photoSwipeGallery.length) {
// init image click event
$document.delegate("[data-photo-swipe-item]", "click", function (event) {
event.preventDefault();
var $el = $(this),
$galleryItems = $el.parents("[data-photo-swipe-gallery]").find("a[data-photo-swipe-item]"),
pswpElement = document.querySelectorAll('.pswp')[0],
encounteredItems = {},
pswpItems = [],
options,
pswpIndex = 0,
pswp;
if ($galleryItems.length == 0) {
$galleryItems = $el;
}
// loop over the gallery to build up the photoswipe items
$galleryItems.each(function () {
var $item = $(this),
src = $item.attr('href'),
size = $item.attr('data-size').split('x'),
pswdItem;
if ($item.is(':visible')) {
// if we have this image the first time
if (!encounteredItems[src]) {
// build the photoswipe item
pswdItem = {
src: src,
w: parseInt(size[0], 10),
h: parseInt(size[1], 10),
el: $item // save link to element for getThumbBoundsFn
};
// store that we already had this item
encounteredItems[src] = {
item: pswdItem,
index: pswpIndex
};
// push the item to the photoswipe list
pswpItems.push(pswdItem);
pswpIndex++;
}
}
});
options = {
index: encounteredItems[$el.attr('href')].index,
getThumbBoundsFn: function (index) {
var $el = pswpItems[index].el,
offset = $el.offset();
return {
x: offset.left,
y: offset.top,
w: $el.width()
};
}
};
// open the photoswipe gallery
pswp = new PhotoSwipe(pswpElement, PhotoSwipeUI_Default, pswpItems, options);
pswp.init();
});
}
/**
* Stacktable
* @description Enables Stacktable plugin
*/
if (plugins.stacktable.length) {
var i;
for (i = 0; i < plugins.stacktable.length; i++) {
var stacktableItem = $(plugins.stacktable[i]);
stacktableItem.stacktable();
}
}
/**
* Custom Toggles
*/
if (plugins.customToggle.length) {
var i;
for (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-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
&& e.data.find($(e.target)).length == 0) {
$(e.data.attr('data-custom-toggle')).add(e.data[0]).removeClass('active');
}
})
}
}
}
/**
* Magnificent image zoom
*/
if (plugins.imgZoom.length) {
var i;
for (i = 0; i < plugins.imgZoom.length; i++) {
var $imgZoomItem = $(plugins.imgZoom[i]);
$imgZoomItem.mag();
}
}
/**
* Custom Waypoints
*/
if (plugins.customWaypoints.length) {
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");
});
});
}
}
/**
* RD Parallax
* @description Enables RD Parallax plugin
*/
if (plugins.rdParallax.length) {
var i;
$.RDParallax();
if (!isIE && !isMobile) {
$(window).on("scroll", function () {
for (i = 0; i < plugins.rdParallax.length; i++) {
var parallax = $(plugins.rdParallax[i]);
if (isScrolledIntoView(parallax)) {
parallax.find(".rd-parallax-inner").css("position", "fixed");
} else {
parallax.find(".rd-parallax-inner").css("position", "absolute");
}
}
});
}
$("a[href='#'], a[href^='#']").on("click", function (event) {
setTimeout(function () {
$(window).trigger("resize");
}, 300);
});
}
/**
* @module Magnific Popup
* @author Dmitry Semenov
* @see http://dimsemenov.com/plugins/magnific-popup/
* @version v1.0.0
*/
if (plugins.mfp.length > 0 || plugins.mfpGallery.length > 0) {
if (plugins.mfp.length) {
for (i = 0; i < plugins.mfp.length; i++) {
var mfpItem = plugins.mfp[i];
$(mfpItem).magnificPopup({
type: mfpItem.getAttribute("data-lightbox")
});
}
}
if (plugins.mfpGallery.length) {
for (i = 0; i < plugins.mfpGallery.length; i++) {
var mfpGalleryItem = $(plugins.mfpGallery[i]).find('[data-lightbox]');
for (var c = 0; c < mfpGalleryItem.length; c++) {
$(mfpGalleryItem).addClass("mfp-" + $(mfpGalleryItem).attr("data-lightbox"));
}
mfpGalleryItem.end()
.magnificPopup({
delegate: '[data-lightbox]',
type: "image",
gallery: {
enabled: true
}
});
}
}
}
});